{"version":3,"file":"static/js/main.a6d1d155.js","mappings":"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","sources":["../../../../../../webpack/universalModuleDefinition","../../../../../../webpack/bootstrap 06abc0fd1cd6e6cc78b4","../../../../../../highcharts-react.min.js","../../../../../../src/HighchartsReact.js","../../../../../../external {\"root\":\"React\",\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\"}","../node_modules/highcharts/highcharts.src.js","../node_modules/highcharts/highstock.src.js","../node_modules/highcharts/modules/annotations-advanced.src.js","../node_modules/highcharts/modules/drag-panes.src.js","../node_modules/highcharts/modules/full-screen.src.js","../node_modules/highcharts/modules/price-indicator.src.js","../node_modules/highcharts/modules/stock-tools.src.js","../node_modules/highcharts/modules/stock.src.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/react-dom/client.js","../node_modules/react-dom/index.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/scheduler/index.js","../node_modules/@babel/runtime/helpers/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/assertThisInitialized.js","../node_modules/@babel/runtime/helpers/classCallCheck.js","../node_modules/@babel/runtime/helpers/createClass.js","../node_modules/@babel/runtime/helpers/createForOfIteratorHelper.js","../node_modules/@babel/runtime/helpers/createSuper.js","../node_modules/@babel/runtime/helpers/defineProperty.js","../node_modules/@babel/runtime/helpers/get.js","../node_modules/@babel/runtime/helpers/getPrototypeOf.js","../node_modules/@babel/runtime/helpers/inherits.js","../node_modules/@babel/runtime/helpers/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/iterableToArray.js","../node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/nonIterableRest.js","../node_modules/@babel/runtime/helpers/nonIterableSpread.js","../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/slicedToArray.js","../node_modules/@babel/runtime/helpers/superPropBase.js","../node_modules/@babel/runtime/helpers/toConsumableArray.js","../node_modules/@babel/runtime/helpers/toPrimitive.js","../node_modules/@babel/runtime/helpers/toPropertyKey.js","../node_modules/@babel/runtime/helpers/typeof.js","../node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","../webpack/bootstrap","../webpack/runtime/compat get default export","../webpack/runtime/create fake namespace object","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/publicPath","../webpack/runtime/jsonp chunk loading","logo.svg","../node_modules/@aws-amplify/core/lib-esm/Logger/ConsoleLogger.js","../node_modules/@remix-run/router/history.ts","../node_modules/@aws-amplify/core/lib-esm/Util/Constants.js","../node_modules/@aws-amplify/core/lib-esm/Amplify.js","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/inherits.js","../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@babel/runtime/helpers/esm/createSuper.js","../node_modules/@babel/runtime/helpers/esm/construct.js","../node_modules/@babel/runtime/helpers/esm/wrapNativeSuper.js","../node_modules/@babel/runtime/helpers/esm/isNativeFunction.js","../node_modules/@remix-run/router/utils.ts","../node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper.js","../node_modules/@babel/runtime/helpers/esm/toArray.js","../node_modules/@remix-run/router/router.ts","../node_modules/react-router/lib/context.ts","../node_modules/react-router/lib/hooks.tsx","../node_modules/react-router/lib/components.tsx","../node_modules/react-router-dom/dom.ts","../node_modules/react-router-dom/index.tsx","../node_modules/@babel/runtime/helpers/esm/regeneratorRuntime.js","../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","components/FunViz/handlers/handleSymbolChange.js","components/FunViz/FunViz.js","components/FunViz/handlers/handlePointClick.js","components/FunViz/config/chartConfig.js","components/Layout/Layout.js","components/Home/Home.js","components/Blogs/Blogs.js","components/Contact/Contact.js","components/NoPage/NoPage.js","aws-config.js","App.js","reportWebVitals.js","index.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"HighchartsReact\"] = factory(require(\"react\"));\n\telse\n\t\troot[\"HighchartsReact\"] = factory(root[\"React\"]);\n})(typeof self !== 'undefined' ? self : this, function(__WEBPACK_EXTERNAL_MODULE_1__) {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 06abc0fd1cd6e6cc78b4","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"HighchartsReact\"] = factory(require(\"react\"));\n\telse\n\t\troot[\"HighchartsReact\"] = factory(root[\"React\"]);\n})(typeof self !== 'undefined' ? self : this, function(__WEBPACK_EXTERNAL_MODULE_1__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"HighchartsReact\", function() { return HighchartsReact; });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\n\n\n// React currently throws a warning when using `useLayoutEffect` on the server.\n// To get around it, we can conditionally `useEffect` on the server (no-op) and\n// `useLayoutEffect` in the browser. We need `useLayoutEffect` to ensure the\n// `Highcharts` ref is available in the layout phase. This makes it available\n// in a parent component's `componentDidMount`.\nvar useIsomorphicLayoutEffect = typeof window !== 'undefined' ? __WEBPACK_IMPORTED_MODULE_0_react__[\"useLayoutEffect\"] : __WEBPACK_IMPORTED_MODULE_0_react__[\"useEffect\"];\nvar HighchartsReact = /*#__PURE__*/Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"memo\"])( /*#__PURE__*/Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"forwardRef\"])(function HighchartsReact(props, ref) {\n var containerRef = Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useRef\"])();\n var chartRef = Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useRef\"])();\n var constructorType = Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useRef\"])(props.constructorType);\n var highcharts = Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useRef\"])(props.highcharts);\n useIsomorphicLayoutEffect(function () {\n function createChart() {\n var H = props.highcharts || (typeof window === \"undefined\" ? \"undefined\" : _typeof(window)) === 'object' && window.Highcharts;\n var constructorType = props.constructorType || 'chart';\n if (!H) {\n console.warn('The \"highcharts\" property was not passed.');\n } else if (!H[constructorType]) {\n console.warn('The \"constructorType\" property is incorrect or some ' + 'required module is not imported.');\n } else if (!props.options) {\n console.warn('The \"options\" property was not passed.');\n } else {\n // Create a chart\n chartRef.current = H[constructorType](containerRef.current, props.options, props.callback);\n }\n }\n if (!chartRef.current) {\n createChart();\n } else {\n if (props.allowChartUpdate !== false) {\n // Reacreate chart on Highcharts or constructor type change\n if (props.constructorType !== constructorType.current || props.highcharts !== highcharts.current) {\n constructorType.current = props.constructorType;\n highcharts.current = props.highcharts;\n createChart();\n // Use `chart.update` to apply changes\n } else if (!props.immutable && chartRef.current) {\n var _chartRef$current;\n (_chartRef$current = chartRef.current).update.apply(_chartRef$current, [props.options].concat(_toConsumableArray(props.updateArgs || [true, true])));\n } else {\n createChart();\n }\n }\n }\n }, [props.options, props.allowChartUpdate, props.updateArgs, props.containerProps, props.highcharts, props.constructorType]);\n\n // Destroy the chart on unmount\n useIsomorphicLayoutEffect(function () {\n return function () {\n if (chartRef.current) {\n chartRef.current.destroy();\n chartRef.current = null;\n }\n };\n }, []);\n Object(__WEBPACK_IMPORTED_MODULE_0_react__[\"useImperativeHandle\"])(ref, function () {\n return {\n get chart() {\n return chartRef.current;\n },\n container: containerRef\n };\n }, []);\n\n // Create container for the chart\n return /*#__PURE__*/__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(\"div\", _extends({}, props.containerProps, {\n ref: containerRef\n }));\n}));\n/* harmony default export */ __webpack_exports__[\"default\"] = (HighchartsReact);\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_1__;\n\n/***/ })\n/******/ ]);\n});\n\n\n// WEBPACK FOOTER //\n// highcharts-react.min.js","import React, {\n forwardRef,\n memo,\n useEffect,\n useImperativeHandle,\n useLayoutEffect,\n useRef\n} from 'react';\n\n// React currently throws a warning when using `useLayoutEffect` on the server.\n// To get around it, we can conditionally `useEffect` on the server (no-op) and\n// `useLayoutEffect` in the browser. We need `useLayoutEffect` to ensure the\n// `Highcharts` ref is available in the layout phase. This makes it available\n// in a parent component's `componentDidMount`.\nconst useIsomorphicLayoutEffect =\n typeof window !== 'undefined' ? useLayoutEffect : useEffect;\n\nexport const HighchartsReact = memo(forwardRef(\n function HighchartsReact(props, ref) {\n const containerRef = useRef();\n const chartRef = useRef();\n const constructorType = useRef(props.constructorType);\n const highcharts = useRef(props.highcharts);\n\n useIsomorphicLayoutEffect(() => {\n function createChart() {\n const H = props.highcharts || (\n typeof window === 'object' && window.Highcharts\n );\n const constructorType = props.constructorType || 'chart';\n \n if (!H) {\n console.warn('The \"highcharts\" property was not passed.');\n \n } else if (!H[constructorType]) {\n console.warn(\n 'The \"constructorType\" property is incorrect or some ' +\n 'required module is not imported.'\n );\n } else if (!props.options) {\n console.warn('The \"options\" property was not passed.');\n \n } else {\n // Create a chart\n chartRef.current = H[constructorType](\n containerRef.current,\n props.options,\n props.callback\n );\n }\n }\n\n if (!chartRef.current) {\n createChart();\n } else {\n if (props.allowChartUpdate !== false) {\n // Reacreate chart on Highcharts or constructor type change\n if (\n props.constructorType !== constructorType.current ||\n props.highcharts !== highcharts.current\n ) {\n constructorType.current = props.constructorType;\n highcharts.current = props.highcharts;\n createChart();\n // Use `chart.update` to apply changes\n } else if (!props.immutable && chartRef.current) {\n chartRef.current.update(\n props.options,\n ...(props.updateArgs || [true, true])\n );\n } else {\n createChart();\n }\n }\n }\n }, [\n props.options,\n props.allowChartUpdate,\n props.updateArgs,\n props.containerProps,\n props.highcharts,\n props.constructorType\n ]);\n\n // Destroy the chart on unmount\n useIsomorphicLayoutEffect(() => {\n return () => {\n if (chartRef.current) {\n chartRef.current.destroy();\n chartRef.current = null;\n }\n };\n }, []);\n\n useImperativeHandle(\n ref,\n () => ({\n get chart() {\n return chartRef.current;\n },\n container: containerRef\n }),\n []\n );\n\n // Create container for the chart\n return
;\n }\n));\n\nexport default HighchartsReact;\n\n\n\n// WEBPACK FOOTER //\n// ./src/HighchartsReact.js","module.exports = __WEBPACK_EXTERNAL_MODULE_1__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"root\":\"React\",\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\"}\n// module id = 1\n// module chunks = 0 1","/**\n * @license Highcharts JS v11.1.0 (2023-06-05)\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (root, factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = root.document ?\n factory(root) :\n factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/highcharts', function () {\n return factory(root);\n });\n } else {\n if (root.Highcharts) {\n root.Highcharts.error(16, true);\n }\n root.Highcharts = factory(root);\n }\n}(typeof window !== 'undefined' ? window : this, function (window) {\n 'use strict';\n var _modules = {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Core/Globals.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n /**\n * Shared Highcharts properties.\n * @private\n */\n var Globals;\n (function (Globals) {\n /* *\n *\n * Constants\n *\n * */\n Globals.SVG_NS = 'http://www.w3.org/2000/svg', Globals.product = 'Highcharts', Globals.version = '11.1.0', Globals.win = (typeof window !== 'undefined' ?\n window :\n {}), // eslint-disable-line node/no-unsupported-features/es-builtins\n Globals.doc = Globals.win.document, Globals.svg = (Globals.doc &&\n Globals.doc.createElementNS &&\n !!Globals.doc.createElementNS(Globals.SVG_NS, 'svg').createSVGRect), Globals.userAgent = (Globals.win.navigator && Globals.win.navigator.userAgent) || '', Globals.isChrome = Globals.userAgent.indexOf('Chrome') !== -1, Globals.isFirefox = Globals.userAgent.indexOf('Firefox') !== -1, Globals.isMS = /(edge|msie|trident)/i.test(Globals.userAgent) && !Globals.win.opera, Globals.isSafari = !Globals.isChrome && Globals.userAgent.indexOf('Safari') !== -1, Globals.isTouchDevice = /(Mobile|Android|Windows Phone)/.test(Globals.userAgent), Globals.isWebKit = Globals.userAgent.indexOf('AppleWebKit') !== -1, Globals.deg2rad = Math.PI * 2 / 360, Globals.hasBidiBug = (Globals.isFirefox &&\n parseInt(Globals.userAgent.split('Firefox/')[1], 10) < 4 // issue #38\n ), Globals.hasTouch = !!Globals.win.TouchEvent, Globals.marginNames = [\n 'plotTop',\n 'marginRight',\n 'marginBottom',\n 'plotLeft'\n ], Globals.noop = function () { }, Globals.supportsPassiveEvents = (function () {\n // Checks whether the browser supports passive events, (#11353).\n let supportsPassive = false;\n // Object.defineProperty doesn't work on IE as well as passive\n // events - instead of using polyfill, we can exclude IE totally.\n if (!Globals.isMS) {\n const opts = Object.defineProperty({}, 'passive', {\n get: function () {\n supportsPassive = true;\n }\n });\n if (Globals.win.addEventListener && Globals.win.removeEventListener) {\n Globals.win.addEventListener('testPassive', Globals.noop, opts);\n Globals.win.removeEventListener('testPassive', Globals.noop, opts);\n }\n }\n return supportsPassive;\n }());\n /**\n * An array containing the current chart objects in the page. A chart's\n * position in the array is preserved throughout the page's lifetime. When\n * a chart is destroyed, the array item becomes `undefined`.\n *\n * @name Highcharts.charts\n * @type {Array}\n */\n Globals.charts = [];\n /**\n * A hook for defining additional date format specifiers. New\n * specifiers are defined as key-value pairs by using the\n * specifier as key, and a function which takes the timestamp as\n * value. This function returns the formatted portion of the\n * date.\n *\n * @sample highcharts/global/dateformats/\n * Adding support for week number\n *\n * @name Highcharts.dateFormats\n * @type {Record}\n */\n Globals.dateFormats = {};\n /**\n * @private\n * @deprecated\n * @todo Use only `Core/Series/SeriesRegistry.seriesTypes`\n */\n Globals.seriesTypes = {};\n /**\n * @private\n */\n Globals.symbolSizes = {};\n /* *\n *\n * Properties\n *\n * */\n // eslint-disable-next-line prefer-const\n Globals.chartCount = 0;\n })(Globals || (Globals = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Theme options that should get applied to the chart. In module mode it\n * might not be possible to change this property because of read-only\n * restrictions, instead use {@link Highcharts.setOptions}.\n *\n * @deprecated\n * @name Highcharts.theme\n * @type {Highcharts.Options}\n */\n (''); // keeps doclets above in JS file\n\n return Globals;\n });\n _registerModule(_modules, 'Core/Utilities.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { charts, doc, win } = H;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Provide error messages for debugging, with links to online explanation. This\n * function can be overridden to provide custom error handling.\n *\n * @sample highcharts/chart/highcharts-error/\n * Custom error handler\n *\n * @function Highcharts.error\n *\n * @param {number|string} code\n * The error code. See\n * [errors.xml](https://github.com/highcharts/highcharts/blob/master/errors/errors.xml)\n * for available codes. If it is a string, the error message is printed\n * directly in the console.\n *\n * @param {boolean} [stop=false]\n * Whether to throw an error or just log a warning in the console.\n *\n * @param {Highcharts.Chart} [chart]\n * Reference to the chart that causes the error. Used in 'debugger'\n * module to display errors directly on the chart.\n * Important note: This argument is undefined for errors that lack\n * access to the Chart instance. In such case, the error will be\n * displayed on the last created chart.\n *\n * @param {Highcharts.Dictionary} [params]\n * Additional parameters for the generated message.\n *\n * @return {void}\n */\n function error(code, stop, chart, params) {\n const severity = stop ? 'Highcharts error' : 'Highcharts warning';\n if (code === 32) {\n code = `${severity}: Deprecated member`;\n }\n const isCode = isNumber(code);\n let message = isCode ?\n `${severity} #${code}: www.highcharts.com/errors/${code}/` :\n code.toString();\n const defaultHandler = function () {\n if (stop) {\n throw new Error(message);\n }\n // else ...\n if (win.console &&\n error.messages.indexOf(message) === -1 // prevent console flooting\n ) {\n console.warn(message); // eslint-disable-line no-console\n }\n };\n if (typeof params !== 'undefined') {\n let additionalMessages = '';\n if (isCode) {\n message += '?';\n }\n objectEach(params, function (value, key) {\n additionalMessages += `\\n - ${key}: ${value}`;\n if (isCode) {\n message += encodeURI(key) + '=' + encodeURI(value);\n }\n });\n message += additionalMessages;\n }\n fireEvent(H, 'displayError', { chart, code, message, params }, defaultHandler);\n error.messages.push(message);\n }\n (function (error) {\n error.messages = [];\n })(error || (error = {}));\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to deep merge two or more objects and return a third object.\n * If the first argument is true, the contents of the second object is copied\n * into the first object. The merge function can also be used with a single\n * object argument to create a deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {boolean} extend\n * Whether to extend the left-side object (a) or return a whole new\n * object.\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */ /**\n * Utility function to deep merge two or more objects and return a third object.\n * The merge function can also be used with a single object argument to create a\n * deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */\n function merge() {\n /* eslint-enable valid-jsdoc */\n let i, args = arguments, ret = {};\n const doCopy = function (copy, original) {\n // An object is replacing a primitive\n if (typeof copy !== 'object') {\n copy = {};\n }\n objectEach(original, function (value, key) {\n // Prototype pollution (#14883)\n if (key === '__proto__' || key === 'constructor') {\n return;\n }\n // Copy the contents of objects, but not arrays or DOM nodes\n if (isObject(value, true) &&\n !isClass(value) &&\n !isDOMElement(value)) {\n copy[key] = doCopy(copy[key] || {}, value);\n // Primitives and arrays are copied over directly\n }\n else {\n copy[key] = original[key];\n }\n });\n return copy;\n };\n // If first argument is true, copy into the existing object. Used in\n // setOptions.\n if (args[0] === true) {\n ret = args[1];\n args = Array.prototype.slice.call(args, 2);\n }\n // For each argument, extend the return\n const len = args.length;\n for (i = 0; i < len; i++) {\n ret = doCopy(ret, args[i]);\n }\n return ret;\n }\n /**\n * Constrain a value to within a lower and upper threshold.\n *\n * @private\n * @param {number} value The initial value\n * @param {number} min The lower threshold\n * @param {number} max The upper threshold\n * @return {number} Returns a number value within min and max.\n */\n function clamp(value, min, max) {\n return value > min ? value < max ? value : max : min;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Return the deep difference between two objects. It can either return the new\n * properties, or optionally return the old values of new properties.\n * @private\n */\n function diffObjects(newer, older, keepOlder, collectionsWithUpdate) {\n const ret = {};\n /**\n * Recurse over a set of options and its current values, and store the\n * current values in the ret object.\n */\n function diff(newer, older, ret, depth) {\n const keeper = keepOlder ? older : newer;\n objectEach(newer, function (newerVal, key) {\n if (!depth &&\n collectionsWithUpdate &&\n collectionsWithUpdate.indexOf(key) > -1 &&\n older[key]) {\n newerVal = splat(newerVal);\n ret[key] = [];\n // Iterate over collections like series, xAxis or yAxis and map\n // the items by index.\n for (let i = 0; i < Math.max(newerVal.length, older[key].length); i++) {\n // Item exists in current data (#6347)\n if (older[key][i]) {\n // If the item is missing from the new data, we need to\n // save the whole config structure. Like when\n // responsively updating from a dual axis layout to a\n // single axis and back (#13544).\n if (newerVal[i] === void 0) {\n ret[key][i] = older[key][i];\n // Otherwise, proceed\n }\n else {\n ret[key][i] = {};\n diff(newerVal[i], older[key][i], ret[key][i], depth + 1);\n }\n }\n }\n }\n else if (isObject(newerVal, true) &&\n !newerVal.nodeType // #10044\n ) {\n ret[key] = isArray(newerVal) ? [] : {};\n diff(newerVal, older[key] || {}, ret[key], depth + 1);\n // Delete empty nested objects\n if (Object.keys(ret[key]).length === 0 &&\n // Except colorAxis which is a special case where the empty\n // object means it is enabled. Which is unfortunate and we\n // should try to find a better way.\n !(key === 'colorAxis' && depth === 0)) {\n delete ret[key];\n }\n }\n else if (newer[key] !== older[key] ||\n // If the newer key is explicitly undefined, keep it (#10525)\n (key in newer && !(key in older))) {\n ret[key] = keeper[key];\n }\n });\n }\n diff(newer, older, ret, 0);\n return ret;\n }\n /**\n * Shortcut for parseInt\n *\n * @private\n * @function Highcharts.pInt\n *\n * @param {*} s\n * any\n *\n * @param {number} [mag]\n * Magnitude\n *\n * @return {number}\n * number\n */\n function pInt(s, mag) {\n return parseInt(s, mag || 10);\n }\n /**\n * Utility function to check for string type.\n *\n * @function Highcharts.isString\n *\n * @param {*} s\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a string.\n */\n function isString(s) {\n return typeof s === 'string';\n }\n /**\n * Utility function to check if an item is an array.\n *\n * @function Highcharts.isArray\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is an array.\n */\n function isArray(obj) {\n const str = Object.prototype.toString.call(obj);\n return str === '[object Array]' || str === '[object Array Iterator]';\n }\n /**\n * Utility function to check if an item is of type object.\n *\n * @function Highcharts.isObject\n *\n * @param {*} obj\n * The item to check.\n *\n * @param {boolean} [strict=false]\n * Also checks that the object is not an array.\n *\n * @return {boolean}\n * True if the argument is an object.\n */\n function isObject(obj, strict) {\n return (!!obj &&\n typeof obj === 'object' &&\n (!strict || !isArray(obj))); // eslint-disable-line @typescript-eslint/no-explicit-any\n }\n /**\n * Utility function to check if an Object is a HTML Element.\n *\n * @function Highcharts.isDOMElement\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a HTML Element.\n */\n function isDOMElement(obj) {\n return isObject(obj) && typeof obj.nodeType === 'number';\n }\n /**\n * Utility function to check if an Object is a class.\n *\n * @function Highcharts.isClass\n *\n * @param {object|undefined} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a class.\n */\n function isClass(obj) {\n const c = obj && obj.constructor;\n return !!(isObject(obj, true) &&\n !isDOMElement(obj) &&\n (c && c.name && c.name !== 'Object'));\n }\n /**\n * Utility function to check if an item is a number and it is finite (not NaN,\n * Infinity or -Infinity).\n *\n * @function Highcharts.isNumber\n *\n * @param {*} n\n * The item to check.\n *\n * @return {boolean}\n * True if the item is a finite number\n */\n function isNumber(n) {\n return typeof n === 'number' && !isNaN(n) && n < Infinity && n > -Infinity;\n }\n /**\n * Remove the last occurence of an item from an array.\n *\n * @function Highcharts.erase\n *\n * @param {Array<*>} arr\n * The array.\n *\n * @param {*} item\n * The item to remove.\n *\n * @return {void}\n */\n function erase(arr, item) {\n let i = arr.length;\n while (i--) {\n if (arr[i] === item) {\n arr.splice(i, 1);\n break;\n }\n }\n }\n /**\n * Insert a series or an axis in a collection with other items, either the\n * chart series or yAxis series or axis collections, in the correct order\n * according to the index option and whether it is internal. Used internally\n * when adding series and axes.\n *\n * @private\n * @function Highcharts.Chart#insertItem\n * @param {Highcharts.Series|Highcharts.Axis} item\n * The item to insert\n * @param {Array|Array} collection\n * A collection of items, like `chart.series` or `xAxis.series`.\n * @return {number} The index of the series in the collection.\n */\n function insertItem(item, collection) {\n const indexOption = item.options.index, length = collection.length;\n let i;\n for (\n // Internal item (navigator) should always be pushed to the end\n i = item.options.isInternal ? length : 0; i < length + 1; i++) {\n if (\n // No index option, reached the end of the collection,\n // equivalent to pushing\n !collection[i] ||\n // Handle index option, the element to insert has lower index\n (isNumber(indexOption) &&\n indexOption < pick(collection[i].options.index, collection[i]._i)) ||\n // Insert the new item before other internal items\n // (navigator)\n collection[i].options.isInternal) {\n collection.splice(i, 0, item);\n break;\n }\n }\n return i;\n }\n /**\n * Adds an item to an array, if it is not present in the array.\n *\n * @function Highcharts.pushUnique\n *\n * @param {Array} array\n * The array to add the item to.\n *\n * @param {unknown} item\n * The item to add.\n *\n * @return {boolean}\n * Returns true, if the item was not present and has been added.\n */\n function pushUnique(array, item) {\n return array.indexOf(item) < 0 && !!array.push(item);\n }\n /**\n * Check if an object is null or undefined.\n *\n * @function Highcharts.defined\n *\n * @param {*} obj\n * The object to check.\n *\n * @return {boolean}\n * False if the object is null or undefined, otherwise true.\n */\n function defined(obj) {\n return typeof obj !== 'undefined' && obj !== null;\n }\n /**\n * Set or get an attribute or an object of attributes.\n *\n * To use as a setter, pass a key and a value, or let the second argument be a\n * collection of keys and values. When using a collection, passing a value of\n * `null` or `undefined` will remove the attribute.\n *\n * To use as a getter, pass only a string as the second argument.\n *\n * @function Highcharts.attr\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} elem\n * The DOM element to receive the attribute(s).\n *\n * @param {string|Highcharts.HTMLAttributes|Highcharts.SVGAttributes} [keyOrAttribs]\n * The property or an object of key-value pairs.\n *\n * @param {number|string} [value]\n * The value if a single property is set.\n *\n * @return {string|null|undefined}\n * When used as a getter, return the value.\n */\n function attr(elem, keyOrAttribs, value) {\n const isGetter = isString(keyOrAttribs) && !defined(value);\n let ret;\n const attrSingle = (value, key) => {\n // Set the value\n if (defined(value)) {\n elem.setAttribute(key, value);\n // Get the value\n }\n else if (isGetter) {\n ret = elem.getAttribute(key);\n // IE7 and below cannot get class through getAttribute (#7850)\n if (!ret && key === 'class') {\n ret = elem.getAttribute(key + 'Name');\n }\n // Remove the value\n }\n else {\n elem.removeAttribute(key);\n }\n };\n // If keyOrAttribs is a string\n if (isString(keyOrAttribs)) {\n attrSingle(value, keyOrAttribs);\n // Else if keyOrAttribs is defined, it is a hash of key/value pairs\n }\n else {\n objectEach(keyOrAttribs, attrSingle);\n }\n return ret;\n }\n /**\n * Check if an element is an array, and if not, make it into an array.\n *\n * @function Highcharts.splat\n *\n * @param {*} obj\n * The object to splat.\n *\n * @return {Array}\n * The produced or original array.\n */\n function splat(obj) {\n return isArray(obj) ? obj : [obj];\n }\n /**\n * Set a timeout if the delay is given, otherwise perform the function\n * synchronously.\n *\n * @function Highcharts.syncTimeout\n *\n * @param {Function} fn\n * The function callback.\n *\n * @param {number} delay\n * Delay in milliseconds.\n *\n * @param {*} [context]\n * An optional context to send to the function callback.\n *\n * @return {number}\n * An identifier for the timeout that can later be cleared with\n * Highcharts.clearTimeout. Returns -1 if there is no timeout.\n */\n function syncTimeout(fn, delay, context) {\n if (delay > 0) {\n return setTimeout(fn, delay, context);\n }\n fn.call(0, context);\n return -1;\n }\n /**\n * Internal clear timeout. The function checks that the `id` was not removed\n * (e.g. by `chart.destroy()`). For the details see\n * [issue #7901](https://github.com/highcharts/highcharts/issues/7901).\n *\n * @function Highcharts.clearTimeout\n *\n * @param {number|undefined} id\n * Id of a timeout.\n */\n function internalClearTimeout(id) {\n if (defined(id)) {\n clearTimeout(id);\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to extend an object with the members of another.\n *\n * @function Highcharts.extend\n *\n * @param {T|undefined} a\n * The object to be extended.\n *\n * @param {Partial} b\n * The object to add to the first one.\n *\n * @return {T}\n * Object a, the original object.\n */\n function extend(a, b) {\n /* eslint-enable valid-jsdoc */\n let n;\n if (!a) {\n a = {};\n }\n for (n in b) { // eslint-disable-line guard-for-in\n a[n] = b[n];\n }\n return a;\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Return the first value that is not null or undefined.\n *\n * @function Highcharts.pick\n *\n * @param {...Array} items\n * Variable number of arguments to inspect.\n *\n * @return {T}\n * The value of the first argument that is not null or undefined.\n */\n function pick() {\n const args = arguments;\n const length = args.length;\n for (let i = 0; i < length; i++) {\n const arg = args[i];\n if (typeof arg !== 'undefined' && arg !== null) {\n return arg;\n }\n }\n }\n /**\n * Set CSS on a given element.\n *\n * @function Highcharts.css\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} el\n * An HTML DOM element.\n *\n * @param {Highcharts.CSSObject} styles\n * Style object with camel case property names.\n *\n * @return {void}\n */\n function css(el, styles) {\n if (H.isMS && !H.svg) { // #2686\n if (styles && defined(styles.opacity)) {\n styles.filter = `alpha(opacity=${styles.opacity * 100})`;\n }\n }\n extend(el.style, styles);\n }\n /**\n * Utility function to create an HTML element with attributes and styles.\n *\n * @function Highcharts.createElement\n *\n * @param {string} tag\n * The HTML tag.\n *\n * @param {Highcharts.HTMLAttributes} [attribs]\n * Attributes as an object of key-value pairs.\n *\n * @param {Highcharts.CSSObject} [styles]\n * Styles as an object of key-value pairs.\n *\n * @param {Highcharts.HTMLDOMElement} [parent]\n * The parent HTML object.\n *\n * @param {boolean} [nopad=false]\n * If true, remove all padding, border and margin.\n *\n * @return {Highcharts.HTMLDOMElement}\n * The created DOM element.\n */\n function createElement(tag, attribs, styles, parent, nopad) {\n const el = doc.createElement(tag);\n if (attribs) {\n extend(el, attribs);\n }\n if (nopad) {\n css(el, { padding: '0', border: 'none', margin: '0' });\n }\n if (styles) {\n css(el, styles);\n }\n if (parent) {\n parent.appendChild(el);\n }\n return el;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Extend a prototyped class by new members.\n *\n * @deprecated\n * @function Highcharts.extendClass\n *\n * @param {Highcharts.Class} parent\n * The parent prototype to inherit.\n *\n * @param {Highcharts.Dictionary<*>} members\n * A collection of prototype members to add or override compared to the\n * parent prototype.\n *\n * @return {Highcharts.Class}\n * A new prototype.\n */\n function extendClass(parent, members) {\n const obj = (function () { });\n obj.prototype = new parent(); // eslint-disable-line new-cap\n extend(obj.prototype, members);\n return obj;\n }\n /**\n * Left-pad a string to a given length by adding a character repetitively.\n *\n * @function Highcharts.pad\n *\n * @param {number} number\n * The input string or number.\n *\n * @param {number} [length]\n * The desired string length.\n *\n * @param {string} [padder=0]\n * The character to pad with.\n *\n * @return {string}\n * The padded string.\n */\n function pad(number, length, padder) {\n return new Array((length || 2) +\n 1 -\n String(number)\n .replace('-', '')\n .length).join(padder || '0') + number;\n }\n /**\n * Return a length based on either the integer value, or a percentage of a base.\n *\n * @function Highcharts.relativeLength\n *\n * @param {Highcharts.RelativeSize} value\n * A percentage string or a number.\n *\n * @param {number} base\n * The full length that represents 100%.\n *\n * @param {number} [offset=0]\n * A pixel offset to apply for percentage values. Used internally in\n * axis positioning.\n *\n * @return {number}\n * The computed length.\n */\n function relativeLength(value, base, offset) {\n return (/%$/).test(value) ?\n (base * parseFloat(value) / 100) + (offset || 0) :\n parseFloat(value);\n }\n /**\n * Wrap a method with extended functionality, preserving the original function.\n *\n * @function Highcharts.wrap\n *\n * @param {*} obj\n * The context object that the method belongs to. In real cases, this is\n * often a prototype.\n *\n * @param {string} method\n * The name of the method to extend.\n *\n * @param {Highcharts.WrapProceedFunction} func\n * A wrapper function callback. This function is called with the same\n * arguments as the original function, except that the original function\n * is unshifted and passed as the first argument.\n */\n function wrap(obj, method, func) {\n const proceed = obj[method];\n obj[method] = function () {\n const outerArgs = arguments, scope = this;\n return func.apply(this, [\n function () {\n return proceed.apply(scope, arguments.length ? arguments : outerArgs);\n }\n ].concat([].slice.call(arguments)));\n };\n }\n /**\n * Get the magnitude of a number.\n *\n * @function Highcharts.getMagnitude\n *\n * @param {number} num\n * The number.\n *\n * @return {number}\n * The magnitude, where 1-9 are magnitude 1, 10-99 magnitude 2 etc.\n */\n function getMagnitude(num) {\n return Math.pow(10, Math.floor(Math.log(num) / Math.LN10));\n }\n /**\n * Take an interval and normalize it to multiples of round numbers.\n *\n * @deprecated\n * @function Highcharts.normalizeTickInterval\n *\n * @param {number} interval\n * The raw, un-rounded interval.\n *\n * @param {Array<*>} [multiples]\n * Allowed multiples.\n *\n * @param {number} [magnitude]\n * The magnitude of the number.\n *\n * @param {boolean} [allowDecimals]\n * Whether to allow decimals.\n *\n * @param {boolean} [hasTickAmount]\n * If it has tickAmount, avoid landing on tick intervals lower than\n * original.\n *\n * @return {number}\n * The normalized interval.\n *\n * @todo\n * Move this function to the Axis prototype. It is here only for historical\n * reasons.\n */\n function normalizeTickInterval(interval, multiples, magnitude, allowDecimals, hasTickAmount) {\n let i, retInterval = interval;\n // round to a tenfold of 1, 2, 2.5 or 5\n magnitude = pick(magnitude, getMagnitude(interval));\n const normalized = interval / magnitude;\n // multiples for a linear scale\n if (!multiples) {\n multiples = hasTickAmount ?\n // Finer grained ticks when the tick amount is hard set, including\n // when alignTicks is true on multiple axes (#4580).\n [1, 1.2, 1.5, 2, 2.5, 3, 4, 5, 6, 8, 10] :\n // Else, let ticks fall on rounder numbers\n [1, 2, 2.5, 5, 10];\n // the allowDecimals option\n if (allowDecimals === false) {\n if (magnitude === 1) {\n multiples = multiples.filter(function (num) {\n return num % 1 === 0;\n });\n }\n else if (magnitude <= 0.1) {\n multiples = [1 / magnitude];\n }\n }\n }\n // normalize the interval to the nearest multiple\n for (i = 0; i < multiples.length; i++) {\n retInterval = multiples[i];\n // only allow tick amounts smaller than natural\n if ((hasTickAmount &&\n retInterval * magnitude >= interval) ||\n (!hasTickAmount &&\n (normalized <=\n (multiples[i] +\n (multiples[i + 1] || multiples[i])) / 2))) {\n break;\n }\n }\n // Multiply back to the correct magnitude. Correct floats to appropriate\n // precision (#6085).\n retInterval = correctFloat(retInterval * magnitude, -Math.round(Math.log(0.001) / Math.LN10));\n return retInterval;\n }\n /**\n * Sort an object array and keep the order of equal items. The ECMAScript\n * standard does not specify the behaviour when items are equal.\n *\n * @function Highcharts.stableSort\n *\n * @param {Array<*>} arr\n * The array to sort.\n *\n * @param {Function} sortFunction\n * The function to sort it with, like with regular Array.prototype.sort.\n */\n function stableSort(arr, sortFunction) {\n // @todo It seems like Chrome since v70 sorts in a stable way internally,\n // plus all other browsers do it, so over time we may be able to remove this\n // function\n const length = arr.length;\n let sortValue, i;\n // Add index to each item\n for (i = 0; i < length; i++) {\n arr[i].safeI = i; // stable sort index\n }\n arr.sort(function (a, b) {\n sortValue = sortFunction(a, b);\n return sortValue === 0 ? a.safeI - b.safeI : sortValue;\n });\n // Remove index from items\n for (i = 0; i < length; i++) {\n delete arr[i].safeI; // stable sort index\n }\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.min` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMin\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The lowest number.\n */\n function arrayMin(data) {\n let i = data.length, min = data[0];\n while (i--) {\n if (data[i] < min) {\n min = data[i];\n }\n }\n return min;\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.max` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMax\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The highest number.\n */\n function arrayMax(data) {\n let i = data.length, max = data[0];\n while (i--) {\n if (data[i] > max) {\n max = data[i];\n }\n }\n return max;\n }\n /**\n * Utility method that destroys any SVGElement instances that are properties on\n * the given object. It loops all properties and invokes destroy if there is a\n * destroy method. The property is then delete.\n *\n * @function Highcharts.destroyObjectProperties\n *\n * @param {*} obj\n * The object to destroy properties on.\n *\n * @param {*} [except]\n * Exception, do not destroy this property, only delete it.\n */\n function destroyObjectProperties(obj, except) {\n objectEach(obj, function (val, n) {\n // If the object is non-null and destroy is defined\n if (val && val !== except && val.destroy) {\n // Invoke the destroy\n val.destroy();\n }\n // Delete the property from the object.\n delete obj[n];\n });\n }\n /**\n * Discard a HTML element\n *\n * @function Highcharts.discardElement\n *\n * @param {Highcharts.HTMLDOMElement} element\n * The HTML node to discard.\n */\n function discardElement(element) {\n if (element && element.parentElement) {\n element.parentElement.removeChild(element);\n }\n }\n /**\n * Fix JS round off float errors.\n *\n * @function Highcharts.correctFloat\n *\n * @param {number} num\n * A float number to fix.\n *\n * @param {number} [prec=14]\n * The precision.\n *\n * @return {number}\n * The corrected float number.\n */\n function correctFloat(num, prec) {\n // When the number is higher than 1e14 use the number (#16275)\n return num > 1e14 ? num : parseFloat(num.toPrecision(prec || 14));\n }\n /**\n * The time unit lookup\n *\n * @ignore\n */\n const timeUnits = {\n millisecond: 1,\n second: 1000,\n minute: 60000,\n hour: 3600000,\n day: 24 * 3600000,\n week: 7 * 24 * 3600000,\n month: 28 * 24 * 3600000,\n year: 364 * 24 * 3600000\n };\n /**\n * Easing definition\n *\n * @private\n * @function Math.easeInOutSine\n *\n * @param {number} pos\n * Current position, ranging from 0 to 1.\n *\n * @return {number}\n * Ease result\n */\n Math.easeInOutSine = function (pos) {\n return -0.5 * (Math.cos(Math.PI * pos) - 1);\n };\n /**\n * Find the closest distance between two values of a two-dimensional array\n * @private\n * @function Highcharts.getClosestDistance\n *\n * @param {Array>} arrays\n * An array of arrays of numbers\n *\n * @return {number | undefined}\n * The closest distance between values\n */\n function getClosestDistance(arrays, onError) {\n const allowNegative = !onError;\n let closest, loopLength, distance, i;\n arrays.forEach((xData) => {\n if (xData.length > 1) {\n loopLength = xData.length - 1;\n for (i = loopLength; i > 0; i--) {\n distance = xData[i] - xData[i - 1];\n if (distance < 0 && !allowNegative) {\n onError === null || onError === void 0 ? void 0 : onError();\n // Only one call\n onError = void 0;\n }\n else if (distance && (typeof closest === 'undefined' || distance < closest)) {\n closest = distance;\n }\n }\n }\n });\n return closest;\n }\n /**\n * Returns the value of a property path on a given object.\n *\n * @private\n * @function getNestedProperty\n *\n * @param {string} path\n * Path to the property, for example `custom.myValue`.\n *\n * @param {unknown} obj\n * Instance containing the property on the specific path.\n *\n * @return {unknown}\n * The unknown property value.\n */\n function getNestedProperty(path, parent) {\n const pathElements = path.split('.');\n while (pathElements.length && defined(parent)) {\n const pathElement = pathElements.shift();\n // Filter on the key\n if (typeof pathElement === 'undefined' ||\n pathElement === '__proto__') {\n return; // undefined\n }\n if (pathElement === 'this') {\n let thisProp;\n if (isObject(parent)) {\n thisProp = parent['@this'];\n }\n return thisProp !== null && thisProp !== void 0 ? thisProp : parent;\n }\n const child = parent[pathElement];\n // Filter on the child\n if (!defined(child) ||\n typeof child === 'function' ||\n typeof child.nodeType === 'number' ||\n child === win) {\n return; // undefined\n }\n // Else, proceed\n parent = child;\n }\n return parent;\n }\n /**\n * Get the computed CSS value for given element and property, only for numerical\n * properties. For width and height, the dimension of the inner box (excluding\n * padding) is returned. Used for fitting the chart within the container.\n *\n * @function Highcharts.getStyle\n *\n * @param {Highcharts.HTMLDOMElement} el\n * An HTML element.\n *\n * @param {string} prop\n * The property name.\n *\n * @param {boolean} [toInt=true]\n * Parse to integer.\n *\n * @return {number|string|undefined}\n * The style value.\n */\n function getStyle(el, prop, toInt) {\n let style;\n // For width and height, return the actual inner pixel size (#4913)\n if (prop === 'width') {\n let offsetWidth = Math.min(el.offsetWidth, el.scrollWidth);\n // In flex boxes, we need to use getBoundingClientRect and floor it,\n // because scrollWidth doesn't support subpixel precision (#6427) ...\n const boundingClientRectWidth = el.getBoundingClientRect &&\n el.getBoundingClientRect().width;\n // ...unless if the containing div or its parents are transform-scaled\n // down, in which case the boundingClientRect can't be used as it is\n // also scaled down (#9871, #10498).\n if (boundingClientRectWidth < offsetWidth &&\n boundingClientRectWidth >= offsetWidth - 1) {\n offsetWidth = Math.floor(boundingClientRectWidth);\n }\n return Math.max(0, // #8377\n (offsetWidth -\n (getStyle(el, 'padding-left', true) || 0) -\n (getStyle(el, 'padding-right', true) || 0)));\n }\n if (prop === 'height') {\n return Math.max(0, // #8377\n (Math.min(el.offsetHeight, el.scrollHeight) -\n (getStyle(el, 'padding-top', true) || 0) -\n (getStyle(el, 'padding-bottom', true) || 0)));\n }\n // Otherwise, get the computed style\n const css = win.getComputedStyle(el, void 0); // eslint-disable-line no-undefined\n if (css) {\n style = css.getPropertyValue(prop);\n if (pick(toInt, prop !== 'opacity')) {\n style = pInt(style);\n }\n }\n return style;\n }\n /**\n * Search for an item in an array.\n *\n * @function Highcharts.inArray\n *\n * @deprecated\n *\n * @param {*} item\n * The item to search for.\n *\n * @param {Array<*>} arr\n * The array or node collection to search in.\n *\n * @param {number} [fromIndex=0]\n * The index to start searching from.\n *\n * @return {number}\n * The index within the array, or -1 if not found.\n */\n function inArray(item, arr, fromIndex) {\n error(32, false, void 0, { 'Highcharts.inArray': 'use Array.indexOf' });\n return arr.indexOf(item, fromIndex);\n }\n /**\n * Return the value of the first element in the array that satisfies the\n * provided testing function.\n *\n * @function Highcharts.find\n *\n * @param {Array} arr\n * The array to test.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if this item satisfies the condition.\n *\n * @return {T|undefined}\n * The value of the element.\n */\n const find = Array.prototype.find ?\n function (arr, callback) {\n return arr.find(callback);\n } :\n // Legacy implementation. PhantomJS, IE <= 11 etc. #7223.\n function (arr, callback) {\n let i;\n const length = arr.length;\n for (i = 0; i < length; i++) {\n if (callback(arr[i], i)) { // eslint-disable-line node/callback-return\n return arr[i];\n }\n }\n };\n /**\n * Returns an array of a given object's own properties.\n *\n * @function Highcharts.keys\n * @deprecated\n *\n * @param {*} obj\n * The object of which the properties are to be returned.\n *\n * @return {Array}\n * An array of strings that represents all the properties.\n */\n function keys(obj) {\n error(32, false, void 0, { 'Highcharts.keys': 'use Object.keys' });\n return Object.keys(obj);\n }\n /**\n * Get the element's offset position, corrected for `overflow: auto`.\n *\n * @function Highcharts.offset\n *\n * @param {global.Element} el\n * The DOM element.\n *\n * @return {Highcharts.OffsetObject}\n * An object containing `left` and `top` properties for the position in\n * the page.\n */\n function offset(el) {\n const docElem = doc.documentElement, box = (el.parentElement || el.parentNode) ?\n el.getBoundingClientRect() :\n { top: 0, left: 0, width: 0, height: 0 };\n return {\n top: box.top + (win.pageYOffset || docElem.scrollTop) -\n (docElem.clientTop || 0),\n left: box.left + (win.pageXOffset || docElem.scrollLeft) -\n (docElem.clientLeft || 0),\n width: box.width,\n height: box.height\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Iterate over object key pairs in an object.\n *\n * @function Highcharts.objectEach\n *\n * @param {*} obj\n * The object to iterate over.\n *\n * @param {Highcharts.ObjectEachCallbackFunction} fn\n * The iterator callback. It passes three arguments:\n * * value - The property value.\n * * key - The property key.\n * * obj - The object that objectEach is being applied to.\n *\n * @param {T} [ctx]\n * The context.\n */\n function objectEach(obj, fn, ctx) {\n /* eslint-enable valid-jsdoc */\n for (const key in obj) {\n if (Object.hasOwnProperty.call(obj, key)) {\n fn.call(ctx || obj[key], obj[key], key, obj);\n }\n }\n }\n /**\n * Iterate over an array.\n *\n * @deprecated\n * @function Highcharts.each\n *\n * @param {Array<*>} arr\n * The array to iterate over.\n *\n * @param {Function} fn\n * The iterator callback. It passes three arguments:\n * - `item`: The array item.\n * - `index`: The item's index in the array.\n * - `arr`: The array that each is being applied to.\n *\n * @param {*} [ctx]\n * The context.\n *\n * @return {void}\n */\n /**\n * Filter an array by a callback.\n *\n * @deprecated\n * @function Highcharts.grep\n *\n * @param {Array<*>} arr\n * The array to filter.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if the item is to be preserved.\n *\n * @return {Array<*>}\n * A new, filtered array.\n */\n /**\n * Map an array by a callback.\n *\n * @deprecated\n * @function Highcharts.map\n *\n * @param {Array<*>} arr\n * The array to map.\n *\n * @param {Function} fn\n * The callback function. Return the new value for the new array.\n *\n * @return {Array<*>}\n * A new array item with modified items.\n */\n /**\n * Reduce an array to a single value.\n *\n * @deprecated\n * @function Highcharts.reduce\n *\n * @param {Array<*>} arr\n * The array to reduce.\n *\n * @param {Function} fn\n * The callback function. Return the reduced value. Receives 4\n * arguments: Accumulated/reduced value, current value, current array\n * index, and the array.\n *\n * @param {*} initialValue\n * The initial value of the accumulator.\n *\n * @return {*}\n * The reduced value.\n */\n /**\n * Test whether at least one element in the array passes the test implemented by\n * the provided function.\n *\n * @deprecated\n * @function Highcharts.some\n *\n * @param {Array<*>} arr\n * The array to test\n *\n * @param {Function} fn\n * The function to run on each item. Return truty to pass the test.\n * Receives arguments `currentValue`, `index` and `array`.\n *\n * @param {*} ctx\n * The context.\n *\n * @return {boolean}\n */\n objectEach({\n map: 'map',\n each: 'forEach',\n grep: 'filter',\n reduce: 'reduce',\n some: 'some'\n }, function (val, key) {\n H[key] = function (arr) {\n error(32, false, void 0, { [`Highcharts.${key}`]: `use Array.${val}` });\n return Array.prototype[val].apply(arr, [].slice.call(arguments, 1));\n };\n });\n /* eslint-disable valid-jsdoc */\n /**\n * Add an event listener.\n *\n * @function Highcharts.addEvent\n *\n * @param {Highcharts.Class|T} el\n * The element or object to add a listener to. It can be a\n * {@link HTMLDOMElement}, an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The event type.\n *\n * @param {Highcharts.EventCallbackFunction|Function} fn\n * The function callback to execute when the event is fired.\n *\n * @param {Highcharts.EventOptionsObject} [options]\n * Options for adding the event.\n *\n * @return {Function}\n * A callback function to remove the added event.\n */\n function addEvent(el, type, fn, options = {}) {\n /* eslint-enable valid-jsdoc */\n // Add hcEvents to either the prototype (in case we're running addEvent on a\n // class) or the instance. If hasOwnProperty('hcEvents') is false, it is\n // inherited down the prototype chain, in which case we need to set the\n // property on this instance (which may itself be a prototype).\n const owner = typeof el === 'function' && el.prototype || el;\n if (!Object.hasOwnProperty.call(owner, 'hcEvents')) {\n owner.hcEvents = {};\n }\n const events = owner.hcEvents;\n // Allow click events added to points, otherwise they will be prevented by\n // the TouchPointer.pinch function after a pinch zoom operation (#7091).\n if (H.Point && // without H a dependency loop occurs\n el instanceof H.Point &&\n el.series &&\n el.series.chart) {\n el.series.chart.runTrackerClick = true;\n }\n // Handle DOM events\n // If the browser supports passive events, add it to improve performance\n // on touch events (#11353).\n const addEventListener = el.addEventListener;\n if (addEventListener) {\n addEventListener.call(el, type, fn, H.supportsPassiveEvents ? {\n passive: options.passive === void 0 ?\n type.indexOf('touch') !== -1 : options.passive,\n capture: false\n } : false);\n }\n if (!events[type]) {\n events[type] = [];\n }\n const eventObject = {\n fn,\n order: typeof options.order === 'number' ? options.order : Infinity\n };\n events[type].push(eventObject);\n // Order the calls\n events[type].sort((a, b) => a.order - b.order);\n // Return a function that can be called to remove this event.\n return function () {\n removeEvent(el, type, fn);\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Remove an event that was added with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.removeEvent\n *\n * @param {Highcharts.Class|T} el\n * The element to remove events on.\n *\n * @param {string} [type]\n * The type of events to remove. If undefined, all events are removed\n * from the element.\n *\n * @param {Highcharts.EventCallbackFunction} [fn]\n * The specific callback to remove. If undefined, all events that match\n * the element and optionally the type are removed.\n *\n * @return {void}\n */\n function removeEvent(el, type, fn) {\n /* eslint-enable valid-jsdoc */\n /**\n * @private\n */\n function removeOneEvent(type, fn) {\n const removeEventListener = el.removeEventListener;\n if (removeEventListener) {\n removeEventListener.call(el, type, fn, false);\n }\n }\n /**\n * @private\n */\n function removeAllEvents(eventCollection) {\n let types, len;\n if (!el.nodeName) {\n return; // break on non-DOM events\n }\n if (type) {\n types = {};\n types[type] = true;\n }\n else {\n types = eventCollection;\n }\n objectEach(types, function (_val, n) {\n if (eventCollection[n]) {\n len = eventCollection[n].length;\n while (len--) {\n removeOneEvent(n, eventCollection[n][len].fn);\n }\n }\n });\n }\n const owner = typeof el === 'function' && el.prototype || el;\n if (Object.hasOwnProperty.call(owner, 'hcEvents')) {\n const events = owner.hcEvents;\n if (type) {\n const typeEvents = (events[type] || []);\n if (fn) {\n events[type] = typeEvents.filter(function (obj) {\n return fn !== obj.fn;\n });\n removeOneEvent(type, fn);\n }\n else {\n removeAllEvents(events);\n events[type] = [];\n }\n }\n else {\n removeAllEvents(events);\n delete owner.hcEvents;\n }\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Fire an event that was registered with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.fireEvent\n *\n * @param {T} el\n * The object to fire the event on. It can be a {@link HTMLDOMElement},\n * an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The type of event.\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Custom event arguments that are passed on as an argument to the event\n * handler.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * The default function to execute if the other listeners haven't\n * returned false.\n *\n * @return {void}\n */\n function fireEvent(el, type, eventArguments, defaultFunction) {\n /* eslint-enable valid-jsdoc */\n let e, i;\n eventArguments = eventArguments || {};\n if (doc.createEvent &&\n (el.dispatchEvent ||\n (el.fireEvent &&\n // Enable firing events on Highcharts instance.\n el !== H))) {\n e = doc.createEvent('Events');\n e.initEvent(type, true, true);\n eventArguments = extend(e, eventArguments);\n if (el.dispatchEvent) {\n el.dispatchEvent(eventArguments);\n }\n else {\n el.fireEvent(type, eventArguments);\n }\n }\n else if (el.hcEvents) {\n if (!eventArguments.target) {\n // We're running a custom event\n extend(eventArguments, {\n // Attach a simple preventDefault function to skip\n // default handler if called. The built-in\n // defaultPrevented property is not overwritable (#5112)\n preventDefault: function () {\n eventArguments.defaultPrevented = true;\n },\n // Setting target to native events fails with clicking\n // the zoom-out button in Chrome.\n target: el,\n // If the type is not set, we're running a custom event\n // (#2297). If it is set, we're running a browser event.\n type: type\n });\n }\n const events = [];\n let object = el;\n let multilevel = false;\n // Recurse up the inheritance chain and collect hcEvents set as own\n // objects on the prototypes.\n while (object.hcEvents) {\n if (Object.hasOwnProperty.call(object, 'hcEvents') &&\n object.hcEvents[type]) {\n if (events.length) {\n multilevel = true;\n }\n events.unshift.apply(events, object.hcEvents[type]);\n }\n object = Object.getPrototypeOf(object);\n }\n // For performance reasons, only sort the event handlers in case we are\n // dealing with multiple levels in the prototype chain. Otherwise, the\n // events are already sorted in the addEvent function.\n if (multilevel) {\n // Order the calls\n events.sort((a, b) => a.order - b.order);\n }\n // Call the collected event handlers\n events.forEach((obj) => {\n // If the event handler returns false, prevent the default handler\n // from executing\n if (obj.fn.call(el, eventArguments) === false) {\n eventArguments.preventDefault();\n }\n });\n }\n // Run the default if not prevented\n if (defaultFunction && !eventArguments.defaultPrevented) {\n defaultFunction.call(el, eventArguments);\n }\n }\n let serialMode;\n /**\n * Get a unique key for using in internal element id's and pointers. The key is\n * composed of a random hash specific to this Highcharts instance, and a\n * counter.\n *\n * @example\n * let id = uniqueKey(); // => 'highcharts-x45f6hp-0'\n *\n * @function Highcharts.uniqueKey\n *\n * @return {string}\n * A unique key.\n */\n const uniqueKey = (function () {\n const hash = Math.random().toString(36).substring(2, 9) + '-';\n let id = 0;\n return function () {\n return 'highcharts-' + (serialMode ? '' : hash) + id++;\n };\n }());\n /**\n * Activates a serial mode for element IDs provided by\n * {@link Highcharts.uniqueKey}. This mode can be used in automated tests, where\n * a simple comparison of two rendered SVG graphics is needed.\n *\n * **Note:** This is only for testing purposes and will break functionality in\n * webpages with multiple charts.\n *\n * @example\n * if (\n * process &&\n * process.env.NODE_ENV === 'development'\n * ) {\n * Highcharts.useSerialIds(true);\n * }\n *\n * @function Highcharts.useSerialIds\n *\n * @param {boolean} [mode]\n * Changes the state of serial mode.\n *\n * @return {boolean|undefined}\n * State of the serial mode.\n */\n function useSerialIds(mode) {\n return (serialMode = pick(mode, serialMode));\n }\n function isFunction(obj) {\n return typeof obj === 'function';\n }\n // Register Highcharts as a plugin in jQuery\n if (win.jQuery) {\n /**\n * Highcharts-extended JQuery.\n *\n * @external JQuery\n */\n /**\n * Helper function to return the chart of the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @return {Highcharts.Chart}\n * The chart that is linked to the JQuery selector element.\n */ /**\n * Factory function to create a chart in the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @param {'Chart'|'Map'|'StockChart'|string} [className]\n * Name of the factory class in the Highcharts namespace.\n *\n * @param {Highcharts.Options} [options]\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {JQuery}\n * The current JQuery selector.\n */\n win.jQuery.fn.highcharts = function () {\n const args = [].slice.call(arguments);\n if (this[0]) { // this[0] is the renderTo div\n // Create the chart\n if (args[0]) {\n new H[ // eslint-disable-line computed-property-spacing, no-new\n // Constructor defaults to Chart\n isString(args[0]) ? args.shift() : 'Chart'](this[0], args[0], args[1]);\n return this;\n }\n // When called without parameters or with the return argument,\n // return an existing chart\n return charts[attr(this[0], 'data-highcharts-chart')];\n }\n };\n }\n /* *\n *\n * Default Export\n *\n * */\n // TODO use named exports when supported.\n const Utilities = {\n addEvent,\n arrayMax,\n arrayMin,\n attr,\n clamp,\n clearTimeout: internalClearTimeout,\n correctFloat,\n createElement,\n css,\n defined,\n destroyObjectProperties,\n diffObjects,\n discardElement,\n erase,\n error,\n extend,\n extendClass,\n find,\n fireEvent,\n getClosestDistance,\n getMagnitude,\n getNestedProperty,\n getStyle,\n inArray,\n insertItem,\n isArray,\n isClass,\n isDOMElement,\n isFunction,\n isNumber,\n isObject,\n isString,\n keys,\n merge,\n normalizeTickInterval,\n objectEach,\n offset,\n pad,\n pick,\n pInt,\n pushUnique,\n relativeLength,\n removeEvent,\n splat,\n stableSort,\n syncTimeout,\n timeUnits,\n uniqueKey,\n useSerialIds,\n wrap\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * An animation configuration. Animation configurations can also be defined as\n * booleans, where `false` turns off animation and `true` defaults to a duration\n * of 500ms and defer of 0ms.\n *\n * @interface Highcharts.AnimationOptionsObject\n */ /**\n * A callback function to exectute when the animation finishes.\n * @name Highcharts.AnimationOptionsObject#complete\n * @type {Function|undefined}\n */ /**\n * The animation defer in milliseconds.\n * @name Highcharts.AnimationOptionsObject#defer\n * @type {number|undefined}\n */ /**\n * The animation duration in milliseconds.\n * @name Highcharts.AnimationOptionsObject#duration\n * @type {number|undefined}\n */ /**\n * The name of an easing function as defined on the `Math` object.\n * @name Highcharts.AnimationOptionsObject#easing\n * @type {string|Function|undefined}\n */ /**\n * A callback function to execute on each step of each attribute or CSS property\n * that's being animated. The first argument contains information about the\n * animation and progress.\n * @name Highcharts.AnimationOptionsObject#step\n * @type {Function|undefined}\n */\n /**\n * Creates a frame for the animated SVG element.\n *\n * @callback Highcharts.AnimationStepCallbackFunction\n *\n * @param {Highcharts.SVGElement} this\n * The SVG element to animate.\n *\n * @return {void}\n */\n /**\n * Interface description for a class.\n *\n * @interface Highcharts.Class\n * @extends Function\n */ /**\n * Class costructor.\n * @function Highcharts.Class#new\n * @param {...Array<*>} args\n * Constructor arguments.\n * @return {T}\n * Class instance.\n */\n /**\n * A style object with camel case property names to define visual appearance of\n * a SVG element or HTML element. The properties can be whatever styles are\n * supported on the given SVG or HTML element.\n *\n * @example\n * {\n * fontFamily: 'monospace',\n * fontSize: '1.2em'\n * }\n *\n * @interface Highcharts.CSSObject\n */ /**\n * @name Highcharts.CSSObject#[key:string]\n * @type {boolean|number|string|undefined}\n */ /**\n * Background style for the element.\n * @name Highcharts.CSSObject#background\n * @type {string|undefined}\n */ /**\n * Background color of the element.\n * @name Highcharts.CSSObject#backgroundColor\n * @type {Highcharts.ColorString|undefined}\n */ /**\n * Border style for the element.\n * @name Highcharts.CSSObject#border\n * @type {string|undefined}\n */ /**\n * Radius of the element border.\n * @name Highcharts.CSSObject#borderRadius\n * @type {number|undefined}\n */ /**\n * Color used in the element. The 'contrast' option is a Highcharts custom\n * property that results in black or white, depending on the background of the\n * element.\n * @name Highcharts.CSSObject#color\n * @type {'contrast'|Highcharts.ColorString|undefined}\n */ /**\n * Style of the mouse cursor when resting over the element.\n * @name Highcharts.CSSObject#cursor\n * @type {Highcharts.CursorValue|undefined}\n */ /**\n * Font family of the element text. Multiple values have to be in decreasing\n * preference order and separated by comma.\n * @name Highcharts.CSSObject#fontFamily\n * @type {string|undefined}\n */ /**\n * Font size of the element text.\n * @name Highcharts.CSSObject#fontSize\n * @type {string|undefined}\n */ /**\n * Font weight of the element text.\n * @name Highcharts.CSSObject#fontWeight\n * @type {string|undefined}\n */ /**\n * Height of the element.\n * @name Highcharts.CSSObject#height\n * @type {number|undefined}\n */ /**\n * Width of the element border.\n * @name Highcharts.CSSObject#lineWidth\n * @type {number|undefined}\n */ /**\n * Opacity of the element.\n * @name Highcharts.CSSObject#opacity\n * @type {number|undefined}\n */ /**\n * Space around the element content.\n * @name Highcharts.CSSObject#padding\n * @type {string|undefined}\n */ /**\n * Behaviour of the element when the mouse cursor rests over it.\n * @name Highcharts.CSSObject#pointerEvents\n * @type {string|undefined}\n */ /**\n * Positioning of the element.\n * @name Highcharts.CSSObject#position\n * @type {string|undefined}\n */ /**\n * Alignment of the element text.\n * @name Highcharts.CSSObject#textAlign\n * @type {string|undefined}\n */ /**\n * Additional decoration of the element text.\n * @name Highcharts.CSSObject#textDecoration\n * @type {string|undefined}\n */ /**\n * Outline style of the element text.\n * @name Highcharts.CSSObject#textOutline\n * @type {string|undefined}\n */ /**\n * Line break style of the element text. Highcharts SVG elements support\n * `ellipsis` when a `width` is set.\n * @name Highcharts.CSSObject#textOverflow\n * @type {string|undefined}\n */ /**\n * Top spacing of the element relative to the parent element.\n * @name Highcharts.CSSObject#top\n * @type {string|undefined}\n */ /**\n * Animated transition of selected element properties.\n * @name Highcharts.CSSObject#transition\n * @type {string|undefined}\n */ /**\n * Line break style of the element text.\n * @name Highcharts.CSSObject#whiteSpace\n * @type {string|undefined}\n */ /**\n * Width of the element.\n * @name Highcharts.CSSObject#width\n * @type {number|undefined}\n */\n /**\n * All possible cursor styles.\n *\n * @typedef {'alias'|'all-scroll'|'auto'|'cell'|'col-resize'|'context-menu'|'copy'|'crosshair'|'default'|'e-resize'|'ew-resize'|'grab'|'grabbing'|'help'|'move'|'n-resize'|'ne-resize'|'nesw-resize'|'no-drop'|'none'|'not-allowed'|'ns-resize'|'nw-resize'|'nwse-resize'|'pointer'|'progress'|'row-resize'|'s-resize'|'se-resize'|'sw-resize'|'text'|'vertical-text'|'w-resize'|'wait'|'zoom-in'|'zoom-out'} Highcharts.CursorValue\n */\n /**\n * All possible dash styles.\n *\n * @typedef {'Dash'|'DashDot'|'Dot'|'LongDash'|'LongDashDot'|'LongDashDotDot'|'ShortDash'|'ShortDashDot'|'ShortDashDotDot'|'ShortDot'|'Solid'} Highcharts.DashStyleValue\n */\n /**\n * Generic dictionary in TypeScript notation.\n * Use the native `AnyRecord` instead.\n *\n * @deprecated\n * @interface Highcharts.Dictionary\n */ /**\n * @name Highcharts.Dictionary#[key:string]\n * @type {T}\n */\n /**\n * The function callback to execute when the event is fired. The `this` context\n * contains the instance, that fired the event.\n *\n * @callback Highcharts.EventCallbackFunction\n *\n * @param {T} this\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Event arguments.\n *\n * @return {boolean|void}\n */\n /**\n * The event options for adding function callback.\n *\n * @interface Highcharts.EventOptionsObject\n */ /**\n * The order the event handler should be called. This opens for having one\n * handler be called before another, independent of in which order they were\n * added.\n * @name Highcharts.EventOptionsObject#order\n * @type {number}\n */ /**\n * Whether an event should be passive or not.\n * When set to `true`, the function specified by listener will never call\n * `preventDefault()`.\n * @name Highcharts.EventOptionsObject#passive\n * @type boolean\n */\n /**\n * Formats data as a string. Usually the data is accessible throught the `this`\n * keyword.\n *\n * @callback Highcharts.FormatterCallbackFunction\n *\n * @param {T} this\n * Context to format\n *\n * @return {string}\n * Formatted text\n */\n /**\n * An object of key-value pairs for HTML attributes.\n *\n * @typedef {Highcharts.Dictionary} Highcharts.HTMLAttributes\n */\n /**\n * An HTML DOM element. The type is a reference to the regular HTMLElement in\n * the global scope.\n *\n * @typedef {global.HTMLElement} Highcharts.HTMLDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement\n */\n /**\n * The iterator callback.\n *\n * @callback Highcharts.ObjectEachCallbackFunction\n *\n * @param {T} this\n * The context.\n *\n * @param {*} value\n * The property value.\n *\n * @param {string} key\n * The property key.\n *\n * @param {*} obj\n * The object that objectEach is being applied to.\n */\n /**\n * An object containing `left` and `top` properties for the position in the\n * page.\n *\n * @interface Highcharts.OffsetObject\n */ /**\n * Left distance to the page border.\n * @name Highcharts.OffsetObject#left\n * @type {number}\n */ /**\n * Top distance to the page border.\n * @name Highcharts.OffsetObject#top\n * @type {number}\n */\n /**\n * Describes a range.\n *\n * @interface Highcharts.RangeObject\n */ /**\n * Maximum number of the range.\n * @name Highcharts.RangeObject#max\n * @type {number}\n */ /**\n * Minimum number of the range.\n * @name Highcharts.RangeObject#min\n * @type {number}\n */\n /**\n * If a number is given, it defines the pixel length. If a percentage string is\n * given, like for example `'50%'`, the setting defines a length relative to a\n * base size, for example the size of a container.\n *\n * @typedef {number|string} Highcharts.RelativeSize\n */\n /**\n * Proceed function to call original (wrapped) function.\n *\n * @callback Highcharts.WrapProceedFunction\n *\n * @param {*} [arg1]\n * Optional argument. Without any arguments defaults to first argument of\n * the wrapping function.\n *\n * @param {*} [arg2]\n * Optional argument. Without any arguments defaults to second argument\n * of the wrapping function.\n *\n * @param {*} [arg3]\n * Optional argument. Without any arguments defaults to third argument of\n * the wrapping function.\n *\n * @return {*}\n * Return value of the original function.\n */\n /**\n * The Highcharts object is the placeholder for all other members, and various\n * utility functions. The most important member of the namespace would be the\n * chart constructor.\n *\n * @example\n * let chart = Highcharts.chart('container', { ... });\n *\n * @namespace Highcharts\n */\n ''; // detach doclets above\n\n return Utilities;\n });\n _registerModule(_modules, 'Core/Chart/ChartDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for the chart.\n *\n * @optionparent chart\n */\n const ChartDefaults = {\n /**\n * Default `mapData` for all series, in terms of a GeoJSON or TopoJSON\n * object. If set to a string, it functions as an index into the\n * `Highcharts.maps` array.\n *\n * For picking out individual shapes and geometries to use for each series\n * of the map, see [series.mapData](#series.map.mapData).\n *\n * @sample maps/demo/geojson\n * Loading GeoJSON data\n * @sample maps/chart/topojson\n * Loading TopoJSON data\n *\n * @type {string|Array<*>|Highcharts.GeoJSON|Highcharts.TopoJSON}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.map\n */\n /**\n * Set lat/lon transformation definitions for the chart. If not defined,\n * these are extracted from the map data.\n *\n * @type {*}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.mapTransforms\n */\n /**\n * When using multiple axes, the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks, as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy, it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false,\n * then the `alignTicks ` will be disabled for the axis.\n *\n * Disabled for logarithmic axes.\n *\n * @sample {highcharts} highcharts/chart/alignticks-true/\n * True by default\n * @sample {highcharts} highcharts/chart/alignticks-false/\n * False\n * @sample {highstock} stock/chart/alignticks-true/\n * True by default\n * @sample {highstock} stock/chart/alignticks-false/\n * False\n *\n * @type {boolean}\n * @default true\n * @product highcharts highstock gantt\n * @apioption chart.alignTicks\n */\n /**\n * When using multiple axes, align the thresholds. When this is true, other\n * ticks will also be aligned.\n *\n * Note that for line series and some other series types, the `threshold`\n * option is set to `null` by default. This will in turn cause their y-axis\n * to not have a threshold. In order to avoid that, set the series\n * `threshold` to 0 or another number.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false, or\n * if the axis is logarithmic, the threshold will not be aligned.\n *\n * @sample {highcharts} highcharts/chart/alignthresholds/ Set to true\n *\n * @since 10.0.0\n * @product highcharts highstock gantt\n * @apioption chart.alignThresholds\n */\n alignThresholds: false,\n /**\n * Set the overall animation for all chart updating. Animation can be\n * disabled throughout the chart by setting it to false here. It can\n * be overridden for each individual API method as a function parameter.\n * The only animation not affected by this option is the initial series\n * animation, see [plotOptions.series.animation](\n * #plotOptions.series.animation).\n *\n * The animation can either be set as a boolean or a configuration\n * object. If `true`, it will use the 'swing' jQuery easing and a\n * duration of 500 ms. If used as a configuration object, the following\n * properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds.\n *\n * - `easing`: A string reference to an easing function set on the\n * `Math` object. See\n * [the easing demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-animation-easing/).\n *\n * When zooming on a series with less than 100 points, the chart redraw\n * will be done with animation, but in case of more data points, it is\n * necessary to set this option to ensure animation on zoom.\n *\n * @sample {highcharts} highcharts/chart/animation-none/\n * Updating with no animation\n * @sample {highcharts} highcharts/chart/animation-duration/\n * With a longer duration\n * @sample {highcharts} highcharts/chart/animation-easing/\n * With a jQuery UI easing\n * @sample {highmaps} maps/chart/animation-none/\n * Updating with no animation\n * @sample {highmaps} maps/chart/animation-duration/\n * With a longer duration\n *\n * @type {boolean|Partial}\n * @default true\n * @apioption chart.animation\n */\n /**\n * A CSS class name to apply to the charts container `div`, allowing\n * unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption chart.className\n */\n /**\n * Event listeners for the chart.\n *\n * @apioption chart.events\n */\n /**\n * Fires when a series is added to the chart after load time, using the\n * `addSeries` method. One parameter, `event`, is passed to the\n * function, containing common event information. Through\n * `event.options` you can access the series options that were passed to\n * the `addSeries` method. Returning false prevents the series from\n * being added.\n *\n * @sample {highcharts} highcharts/chart/events-addseries/\n * Alert on add series\n * @sample {highstock} stock/chart/events-addseries/\n * Alert on add series\n *\n * @type {Highcharts.ChartAddSeriesCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.addSeries\n */\n /**\n * Fires when clicking on the plot background. One parameter, `event`,\n * is passed to the function, containing common event information.\n *\n * Information on the clicked spot can be found through `event.xAxis`\n * and `event.yAxis`, which are arrays containing the axes of each\n * dimension and each axis' value at the clicked spot. The primary axes\n * are `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * click: function(e) {\n * console.log(\n * Highcharts.dateFormat('%Y-%m-%d %H:%M:%S', e.xAxis[0].value),\n * e.yAxis[0].value\n * )\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-click/\n * Alert coordinates on click\n * @sample {highcharts} highcharts/chart/events-container/\n * Alternatively, attach event to container\n * @sample {highstock} stock/chart/events-click/\n * Alert coordinates on click\n * @sample {highstock} highcharts/chart/events-container/\n * Alternatively, attach event to container\n * @sample {highmaps} maps/chart/events-click/\n * Record coordinates on click\n * @sample {highmaps} highcharts/chart/events-container/\n * Alternatively, attach event to container\n *\n * @type {Highcharts.ChartClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.click\n */\n /**\n * Fires when the chart is finished loading. Since v4.2.2, it also waits\n * for images to be loaded, for example from point markers. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * There is also a second parameter to the chart constructor where a\n * callback function can be passed to be executed on chart.load.\n *\n * @sample {highcharts} highcharts/chart/events-load/\n * Alert on chart load\n * @sample {highcharts} highcharts/chart/events-render/\n * Load vs Redraw vs Render\n * @sample {highstock} stock/chart/events-load/\n * Alert on chart load\n * @sample {highmaps} maps/chart/events-load/\n * Add series on chart load\n *\n * @type {Highcharts.ChartLoadCallbackFunction}\n * @context Highcharts.Chart\n * @apioption chart.events.load\n */\n /**\n * Fires when the chart is redrawn, either after a call to\n * `chart.redraw()` or after an axis, series or point is modified with\n * the `redraw` option set to `true`. One parameter, `event`, is passed\n * to the function, containing common event information.\n *\n * @sample {highcharts} highcharts/chart/events-redraw/\n * Alert on chart redraw\n * @sample {highcharts} highcharts/chart/events-render/\n * Load vs Redraw vs Render\n * @sample {highstock} stock/chart/events-redraw/\n * Alert on chart redraw when adding a series or moving the\n * zoomed range\n * @sample {highmaps} maps/chart/events-redraw/\n * Set subtitle on chart redraw\n *\n * @type {Highcharts.ChartRedrawCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.redraw\n */\n /**\n * Fires after initial load of the chart (directly after the `load`\n * event), and after each redraw (directly after the `redraw` event).\n *\n * @sample {highcharts} highcharts/chart/events-render/\n * Load vs Redraw vs Render\n *\n * @type {Highcharts.ChartRenderCallbackFunction}\n * @since 5.0.7\n * @context Highcharts.Chart\n * @apioption chart.events.render\n */\n /**\n * Fires when an area of the chart has been selected. Selection is\n * enabled by setting the chart's zoomType. One parameter, `event`, is\n * passed to the function, containing common event information. The\n * default action for the selection event is to zoom the chart to the\n * selected area. It can be prevented by calling\n * `event.preventDefault()` or return false.\n *\n * Information on the selected area can be found through `event.xAxis`\n * and `event.yAxis`, which are arrays containing the axes of each\n * dimension and each axis' min and max values. The primary axes are\n * `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * selection: function(event) {\n * // log the min and max of the primary, datetime x-axis\n * console.log(\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].min\n * ),\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].max\n * )\n * );\n * // log the min and max of the y axis\n * console.log(event.yAxis[0].min, event.yAxis[0].max);\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-selection/\n * Report on selection and reset\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highstock} stock/chart/events-selection/\n * Report on selection and reset\n * @sample {highstock} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * (Highcharts)\n *\n * @type {Highcharts.ChartSelectionCallbackFunction}\n * @apioption chart.events.selection\n */\n /**\n * The margin between the outer edge of the chart and the plot area.\n * The numbers in the array designate top, right, bottom and left\n * respectively. Use the options `marginTop`, `marginRight`,\n * `marginBottom` and `marginLeft` for shorthand setting of one option.\n *\n * By default there is no margin. The actual space is dynamically\n * calculated from the offset of axis labels, axis title, title,\n * subtitle and legend in addition to the `spacingTop`, `spacingRight`,\n * `spacingBottom` and `spacingLeft` options.\n *\n * @sample {highcharts} highcharts/chart/margins-zero/\n * Zero margins\n * @sample {highstock} stock/chart/margin-zero/\n * Zero margins\n *\n * @type {number|Array}\n * @apioption chart.margin\n */\n /**\n * The margin between the bottom outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingBottom`.\n *\n * @sample {highcharts} highcharts/chart/marginbottom/\n * 100px bottom margin\n * @sample {highstock} stock/chart/marginbottom/\n * 100px bottom margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginBottom\n */\n /**\n * The margin between the left outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingLeft`.\n *\n * @sample {highcharts} highcharts/chart/marginleft/\n * 150px left margin\n * @sample {highstock} stock/chart/marginleft/\n * 150px left margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginLeft\n */\n /**\n * The margin between the right outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingRight`.\n *\n * @sample {highcharts} highcharts/chart/marginright/\n * 100px right margin\n * @sample {highstock} stock/chart/marginright/\n * 100px right margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginRight\n */\n /**\n * The margin between the top outer edge of the chart and the plot area.\n * Use this to set a fixed pixel value for the margin as opposed to\n * the default dynamic margin. See also `spacingTop`.\n *\n * @sample {highcharts} highcharts/chart/margintop/ 100px top margin\n * @sample {highstock} stock/chart/margintop/\n * 100px top margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginTop\n */\n /**\n * Callback function to override the default function that formats all\n * the numbers in the chart. Returns a string with the formatted number.\n *\n * @sample highcharts/members/highcharts-numberformat\n * Arabic digits in Highcharts\n * @type {Highcharts.NumberFormatterCallbackFunction}\n * @since 8.0.0\n * @apioption chart.numberFormatter\n */\n /**\n * Allows setting a key to switch between zooming and panning. Can be\n * one of `alt`, `ctrl`, `meta` (the command key on Mac and Windows\n * key on Windows) or `shift`. The keys are mapped directly to the key\n * properties of the click event argument (`event.altKey`,\n * `event.ctrlKey`, `event.metaKey` and `event.shiftKey`).\n *\n * @type {string}\n * @since 4.0.3\n * @product highcharts gantt\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @apioption chart.panKey\n */\n /**\n * Allow panning in a chart. Best used with [panKey](#chart.panKey)\n * to combine zooming and panning.\n *\n * On touch devices, when the [tooltip.followTouchMove](\n * #tooltip.followTouchMove) option is `true` (default), panning\n * requires two fingers. To allow panning with one finger, set\n * `followTouchMove` to `false`.\n *\n * @sample {highcharts} highcharts/chart/pankey/ Zooming and panning\n * @sample {highstock} stock/chart/panning/ Zooming and xy panning\n */\n panning: {\n /**\n * Enable or disable chart panning.\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock|highmaps} true\n */\n enabled: false,\n /**\n * Decides in what dimensions the user can pan the chart. Can be\n * one of `x`, `y`, or `xy`.\n *\n * When this option is set to `y` or `xy`, [yAxis.startOnTick](#yAxis.startOnTick)\n * and [yAxis.endOnTick](#yAxis.endOnTick) are overwritten to `false`.\n *\n * @sample {highcharts} highcharts/chart/panning-type\n * Zooming and xy panning\n *\n * @declare Highcharts.OptionsChartPanningTypeValue\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @default {highcharts|highstock} x\n * @product highcharts highstock gantt\n */\n type: 'x'\n },\n /**\n * Equivalent to [zoomType](#chart.zoomType), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `zoomType` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} undefined\n * @since 3.0\n * @product highcharts highstock gantt\n * @deprecated\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.pinchType\n */\n /**\n * Whether to apply styled mode. When in styled mode, no presentational\n * attributes or CSS are applied to the chart SVG. Instead, CSS rules\n * are required to style the chart. The default style sheet is\n * available from `https://code.highcharts.com/css/highcharts.css`.\n *\n * [Read more in the docs](https://www.highcharts.com/docs/chart-design-and-style/style-by-css)\n * on what classes and variables are available.\n *\n * @sample highcharts/css/colors\n * Color theming with CSS\n * @sample highcharts/css/prefers-color-scheme\n * Dynamic theme based on system settings\n * @type {boolean}\n * @default false\n * @since 7.0\n * @apioption chart.styledMode\n */\n styledMode: false,\n /**\n * The corner radius of the outer chart border.\n *\n * @sample {highcharts} highcharts/chart/borderradius/\n * 20px radius\n * @sample {highstock} stock/chart/border/\n * 10px radius\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n */\n borderRadius: 0,\n /**\n * In styled mode, this sets how many colors the class names\n * should rotate between. With ten colors, series (or points) are\n * given class names like `highcharts-color-0`, `highcharts-color-1`\n * [...] `highcharts-color-9`. The equivalent in non-styled mode\n * is to set colors using the [colors](#colors) setting.\n *\n * @since 5.0.0\n */\n colorCount: 10,\n /**\n * By default, (because of memory and performance reasons) the chart does\n * not copy the data but keeps it as a reference. In some cases, this might\n * result in mutating the original data source. In order to prevent that,\n * set that property to false. Please note that changing that might decrease\n * performance, especially with bigger sets of data.\n *\n * @type {boolean}\n * @since 10.1.0\n */\n allowMutatingData: true,\n /**\n * If true, the axes will scale to the remaining visible series once\n * one series is hidden. If false, hiding and showing a series will\n * not affect the axes or the other series. For stacks, once one series\n * within the stack is hidden, the rest of the stack will close in\n * around it even if the axis is not affected.\n *\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-false/\n * False\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true-stacked/\n * True with stack\n * @sample {highstock} stock/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highstock} stock/chart/ignorehiddenseries-false/\n * False\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n ignoreHiddenSeries: true,\n /**\n * Whether to invert the axes so that the x axis is vertical and y axis\n * is horizontal. When `true`, the x axis is [reversed](#xAxis.reversed)\n * by default.\n *\n * @productdesc {highcharts}\n * If a bar series is present in the chart, it will be inverted\n * automatically. Inverting the chart doesn't have an effect if there\n * are no cartesian series in the chart, or if the chart is\n * [polar](#chart.polar).\n *\n * @sample {highcharts} highcharts/chart/inverted/\n * Inverted line\n * @sample {highstock} stock/navigator/inverted/\n * Inverted stock chart\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption chart.inverted\n */\n /**\n * The distance between the outer edge of the chart and the content,\n * like title or legend, or axis title and labels if present. The\n * numbers in the array designate top, right, bottom and left\n * respectively. Use the options spacingTop, spacingRight, spacingBottom\n * and spacingLeft options for shorthand setting of one option.\n *\n * @type {Array}\n * @see [chart.margin](#chart.margin)\n * @default [10, 10, 15, 10]\n * @since 3.0.6\n */\n spacing: [10, 10, 15, 10],\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n *\n * @since 2.2\n * @deprecated 10.2.1\n */\n resetZoomButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.resetZoomButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n */\n theme: {\n /**\n * @internal\n */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.resetZoomButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n },\n /**\n * The pixel width of the plot area border.\n *\n * @sample {highcharts} highcharts/chart/plotborderwidth/\n * 1px border\n * @sample {highstock} stock/chart/plotborder/\n * 2px border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.plotBorderWidth\n */\n /**\n * Whether to apply a drop shadow to the plot area. Requires that\n * plotBackgroundColor be set. The shadow can be an object configuration\n * containing `color`, `offsetX`, `offsetY`, `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/chart/plotshadow/\n * Plot shadow\n * @sample {highstock} stock/chart/plotshadow/\n * Plot shadow\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption chart.plotShadow\n */\n /**\n * When true, cartesian charts like line, spline, area and column are\n * transformed into the polar coordinate system. This produces _polar\n * charts_, also known as _radar charts_.\n *\n * @sample {highcharts} highcharts/demo/polar/\n * Polar chart\n * @sample {highcharts} highcharts/demo/polar-wind-rose/\n * Wind rose, stacked polar column chart\n * @sample {highcharts} highcharts/demo/polar-spider/\n * Spider web chart\n * @sample {highcharts} highcharts/parallel-coordinates/polar/\n * Star plot, multivariate data in a polar chart\n *\n * @type {boolean}\n * @default false\n * @since 2.3.0\n * @product highcharts\n * @requires highcharts-more\n * @apioption chart.polar\n */\n /**\n * Whether to reflow the chart to fit the width of the container div\n * on resizing the window.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * True by default\n * @sample {highcharts} highcharts/chart/reflow-false/\n * False\n * @sample {highstock} stock/chart/reflow-true/\n * True by default\n * @sample {highstock} stock/chart/reflow-false/\n * False\n * @sample {highmaps} maps/chart/reflow-true/\n * True by default\n * @sample {highmaps} maps/chart/reflow-false/\n * False\n *\n * @since 2.1\n */\n reflow: true,\n /**\n * The HTML element where the chart will be rendered. If it is a string,\n * the element by that id is used. The HTML element can also be passed\n * by direct reference, or as the first argument of the chart\n * constructor, in which case the option is not needed.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * String\n * @sample {highcharts} highcharts/chart/renderto-object/\n * Object reference\n * @sample {highstock} stock/chart/renderto-string/\n * String\n * @sample {highstock} stock/chart/renderto-object/\n * Object reference\n *\n * @type {string|Highcharts.HTMLDOMElement}\n * @apioption chart.renderTo\n */\n /**\n * The background color of the marker square when selecting (zooming\n * in on) an area of the chart.\n *\n * @see In styled mode, the selection marker fill is set with the\n * `.highcharts-selection-marker` class.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default rgba(51,92,173,0.25)\n * @since 2.1.7\n * @apioption chart.selectionMarkerFill\n */\n /**\n * Whether to apply a drop shadow to the global series group. This causes\n * all the series to have the same shadow. Contrary to the `series.shadow`\n * option, this prevents items from casting shadows on each other, like for\n * others series in a stack. The shadow can be an object configuration\n * containing `color`, `offsetX`, `offsetY`, `opacity` and `width`.\n *\n * @sample highcharts/chart/seriesgroupshadow/ Shadow\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption chart.shadow\n */\n /**\n * Whether to apply a drop shadow to the outer chart area. Requires\n * that backgroundColor be set. The shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity` and\n * `width`.\n *\n * @sample {highcharts} highcharts/chart/shadow/\n * Shadow\n * @sample {highstock} stock/chart/shadow/\n * Shadow\n * @sample {highmaps} maps/chart/border/\n * Chart border and shadow\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption chart.shadow\n */\n /**\n * Whether to show the axes initially. This only applies to empty charts\n * where series are added dynamically, as axes are automatically added\n * to cartesian series.\n *\n * @sample {highcharts} highcharts/chart/showaxes-false/\n * False by default\n * @sample {highcharts} highcharts/chart/showaxes-true/\n * True\n *\n * @type {boolean}\n * @since 1.2.5\n * @product highcharts gantt\n * @apioption chart.showAxes\n */\n /**\n * The space between the bottom edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highstock} stock/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 15\n * @since 2.1\n * @apioption chart.spacingBottom\n */\n /**\n * The space between the left edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highstock} stock/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingLeft\n */\n /**\n * The space between the right edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingright-100/\n * Spacing set to 100\n * @sample {highcharts} highcharts/chart/spacingright-legend/\n * Legend in right position with default spacing\n * @sample {highstock} stock/chart/spacingright/\n * Spacing set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingRight\n */\n /**\n * The space between the top edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingtop-100/\n * A top spacing of 100\n * @sample {highcharts} highcharts/chart/spacingtop-10/\n * Floating chart title makes the plot area align to the default\n * spacingTop of 10.\n * @sample {highstock} stock/chart/spacingtop/\n * A top spacing of 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingTop\n */\n /**\n * Additional CSS styles to apply inline to the container `div` and the root\n * SVG.\n *\n * Since v11, the root font size is 1rem by default, and all child element\n * are given a relative `em` font size by default. This allows implementers\n * to control all the chart's font sizes by only setting the root level.\n *\n * @see In styled mode, general chart styles can be set with the\n * `.highcharts-root` class.\n * @sample {highcharts} highcharts/chart/style-serif-font/\n * Using a serif type font\n * @sample {highcharts} highcharts/members/relative-font-size/\n * Relative font sizes\n * @sample {highcharts} highcharts/css/em/\n * Styled mode with relative font sizes\n * @sample {highstock} stock/chart/style/\n * Using a serif type font\n * @sample {highmaps} maps/chart/style-serif-font/\n * Using a serif type font\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontFamily\": Helvetica, Arial, sans-serif\",\"fontSize\":\"1rem\"}\n * @apioption chart.style\n */\n /**\n * The default series type for the chart. Can be any of the chart types\n * listed under [plotOptions](#plotOptions) and [series](#series) or can\n * be a series provided by an additional module.\n *\n * In TypeScript this option has no effect in sense of typing and\n * instead the `type` option must always be set in the series.\n *\n * @sample {highcharts} highcharts/chart/type-bar/\n * Bar\n * @sample {highstock} stock/chart/type/\n * Areaspline\n * @sample {highmaps} maps/chart/type-mapline/\n * Mapline\n *\n * @type {string}\n * @default {highcharts} line\n * @default {highstock} line\n * @default {highmaps} map\n * @since 2.1.0\n * @apioption chart.type\n */\n type: 'line',\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @see [panKey](#chart.panKey)\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * None by default\n * @sample {highcharts} highcharts/chart/zoomtype-x/\n * X\n * @sample {highcharts} highcharts/chart/zoomtype-y/\n * Y\n * @sample {highcharts} highcharts/chart/zoomtype-xy/\n * Xy\n * @sample {highcharts} highcharts/chart/zoomtype-polar/\n * Zoom on polar chart\n * @sample {highstock} stock/demo/basic-line/\n * None by default\n * @sample {highstock} stock/chart/zoomtype-x/\n * X\n * @sample {highstock} stock/chart/zoomtype-y/\n * Y\n * @sample {highstock} stock/chart/zoomtype-xy/\n * Xy\n * @sample {highmaps} maps/chart/zoomtype-xy/\n * Map with selection zoom\n *\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @deprecated\n * @apioption chart.zoomType\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zoomType](#chart.zoomType). When enabled, two-finger pinch\n * will still work as set up by [chart.pinchType](#chart.pinchType).\n * However, `zoomBySingleTouch` will interfere with touch-dragging the\n * chart to read the tooltip. And especially when vertical zooming is\n * enabled, it will make it hard to scroll vertically on the page.\n * @since 9.0.0\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n * @product highcharts highstock gantt\n * @deprecated\n */\n /**\n * Chart zooming options.\n * @since 10.2.1\n */\n zooming: {\n /**\n * Equivalent to [type](#chart.zooming.type), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `type` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} x\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.pinchType\n */\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @declare Highcharts.OptionsChartZoomingTypeValue\n * @type {string}\n * @default {highcharts} undefined\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.type\n */\n /**\n * Set a key to hold when dragging to zoom the chart. This is useful to\n * avoid zooming while moving points. Should be set different than\n * [chart.panKey](#chart.panKey).\n *\n * @type {string}\n * @default {highcharts} undefined\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @requires modules/draggable-points\n * @apioption chart.zooming.key\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zooming.type](#chart.zooming.type). When enabled, two-finger\n * pinch will still work as set up by [chart.zooming.pinchType]\n * (#chart.zooming.pinchType). However, `singleTouch` will interfere\n * with touch-dragging the chart to read the tooltip. And especially\n * when vertical zooming is enabled, it will make it hard to scroll\n * vertically on the page.\n *\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n *\n * @product highcharts highstock gantt\n */\n singleTouch: false,\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n */\n resetButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.zooming.resetButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n * @since 10.2.1\n */\n theme: {\n /** @internal */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n * @since 10.2.1\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.zooming.resetButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n }\n },\n /**\n * An explicit width for the chart. By default (when `null`) the width\n * is calculated from the offset width of the containing element.\n *\n * @sample {highcharts} highcharts/chart/width/\n * 800px wide\n * @sample {highstock} stock/chart/width/\n * 800px wide\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n *\n * @type {null|number|string}\n */\n width: null,\n /**\n * An explicit height for the chart. If a _number_, the height is\n * given in pixels. If given a _percentage string_ (for example\n * `'56%'`), the height is given as the percentage of the actual chart\n * width. This allows for preserving the aspect ratio across responsive\n * sizes.\n *\n * By default (when `null`) the height is calculated from the offset\n * height of the containing element, or 400 pixels if the containing\n * element's height is 0.\n *\n * @sample {highcharts} highcharts/chart/height/\n * 500px height\n * @sample {highstock} stock/chart/height/\n * 300px height\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n * @sample highcharts/chart/height-percent/\n * Highcharts with percentage height\n *\n * @type {null|number|string}\n */\n height: null,\n /**\n * The color of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/bordercolor/\n * Brown border\n * @sample {highstock} stock/chart/border/\n * Brown border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#334eff\" /* Palette.highlightColor80 */,\n /**\n * The pixel width of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/borderwidth/\n * 5px border\n * @sample {highstock} stock/chart/border/\n * 2px border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.borderWidth\n */\n /**\n * The background color or gradient for the outer chart area.\n *\n * @see In styled mode, the background is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/backgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/backgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/backgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/backgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The background color or gradient for the plot area.\n *\n * @see In styled mode, the plot background is set with the\n * `.highcharts-plot-background` class.\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption chart.plotBackgroundColor\n */\n /**\n * The URL for an image to use as the plot background. To set an image\n * as the background for the entire chart, set a CSS background image\n * to the container element. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export server.\n *\n * @see In styled mode, a plot background image can be set with the\n * `.highcharts-plot-background` class and a [custom pattern](\n * https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns).\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundimage/\n * Skies\n * @sample {highstock} stock/chart/plotbackgroundimage/\n * Skies\n *\n * @type {string}\n * @apioption chart.plotBackgroundImage\n */\n /**\n * The color of the inner chart or plot area border.\n *\n * @see In styled mode, a plot border stroke can be set with the\n * `.highcharts-plot-border` class.\n *\n * @sample {highcharts} highcharts/chart/plotbordercolor/\n * Blue border\n * @sample {highstock} stock/chart/plotborder/\n * Blue border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n plotBorderColor: \"#cccccc\" /* Palette.neutralColor20 */\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ChartDefaults;\n });\n _registerModule(_modules, 'Core/Color/Color.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isNumber, merge, pInt } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Handle color operations. Some object methods are chainable.\n *\n * @class\n * @name Highcharts.Color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n class Color {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Creates a color instance out of a color string or object.\n *\n * @function Highcharts.Color.parse\n *\n * @param {Highcharts.ColorType} [input]\n * The input color in either rbga or hex format.\n *\n * @return {Highcharts.Color}\n * Color instance.\n */\n static parse(input) {\n return input ? new Color(input) : Color.None;\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(input) {\n this.rgba = [NaN, NaN, NaN, NaN];\n this.input = input;\n const GlobalColor = H.Color;\n // Backwards compatibility, allow class overwrite\n if (GlobalColor && GlobalColor !== Color) {\n return new GlobalColor(input);\n }\n this.init(input);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Parse the input color to rgba array\n *\n * @private\n * @function Highcharts.Color#init\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n init(input) {\n let result, rgba, i, parser;\n // Gradients\n if (typeof input === 'object' &&\n typeof input.stops !== 'undefined') {\n this.stops = input.stops.map((stop) => new Color(stop[1]));\n // Solid colors\n }\n else if (typeof input === 'string') {\n this.input = input = (Color.names[input.toLowerCase()] || input);\n // Bitmasking as input[0] is not working for legacy IE.\n if (input.charAt(0) === '#') {\n const len = input.length, col = parseInt(input.substr(1), 16);\n // Handle long-form, e.g. #AABBCC\n if (len === 7) {\n rgba = [\n (col & 0xFF0000) >> 16,\n (col & 0xFF00) >> 8,\n (col & 0xFF),\n 1\n ];\n // Handle short-form, e.g. #ABC\n // In short form, the value is assumed to be the same\n // for both nibbles for each component. e.g. #ABC = #AABBCC\n }\n else if (len === 4) {\n rgba = [\n (((col & 0xF00) >> 4) |\n (col & 0xF00) >> 8),\n (((col & 0xF0) >> 4) |\n (col & 0xF0)),\n ((col & 0xF) << 4) | (col & 0xF),\n 1\n ];\n }\n }\n // Otherwise, check regex parsers\n if (!rgba) {\n i = Color.parsers.length;\n while (i-- && !rgba) {\n parser = Color.parsers[i];\n result = parser.regex.exec(input);\n if (result) {\n rgba = parser.parse(result);\n }\n }\n }\n }\n if (rgba) {\n this.rgba = rgba;\n }\n }\n /**\n * Return the color or gradient stops in the specified format\n *\n * @function Highcharts.Color#get\n *\n * @param {string} [format]\n * Possible values are 'a', 'rgb', 'rgba' (default).\n *\n * @return {Highcharts.ColorType}\n * This color as a string or gradient stops.\n */\n get(format) {\n const input = this.input, rgba = this.rgba;\n if (typeof input === 'object' &&\n typeof this.stops !== 'undefined') {\n const ret = merge(input);\n ret.stops = [].slice.call(ret.stops);\n this.stops.forEach((stop, i) => {\n ret.stops[i] = [\n ret.stops[i][0],\n stop.get(format)\n ];\n });\n return ret;\n }\n // it's NaN if gradient colors on a column chart\n if (rgba && isNumber(rgba[0])) {\n if (format === 'rgb' || (!format && rgba[3] === 1)) {\n return 'rgb(' + rgba[0] + ',' + rgba[1] + ',' + rgba[2] + ')';\n }\n if (format === 'a') {\n return `${rgba[3]}`;\n }\n return 'rgba(' + rgba.join(',') + ')';\n }\n return input;\n }\n /**\n * Brighten the color instance.\n *\n * @function Highcharts.Color#brighten\n *\n * @param {number} alpha\n * The alpha value.\n *\n * @return {Highcharts.Color}\n * This color with modifications.\n */\n brighten(alpha) {\n const rgba = this.rgba;\n if (this.stops) {\n this.stops.forEach(function (stop) {\n stop.brighten(alpha);\n });\n }\n else if (isNumber(alpha) && alpha !== 0) {\n for (let i = 0; i < 3; i++) {\n rgba[i] += pInt(alpha * 255);\n if (rgba[i] < 0) {\n rgba[i] = 0;\n }\n if (rgba[i] > 255) {\n rgba[i] = 255;\n }\n }\n }\n return this;\n }\n /**\n * Set the color's opacity to a given alpha value.\n *\n * @function Highcharts.Color#setOpacity\n *\n * @param {number} alpha\n * Opacity between 0 and 1.\n *\n * @return {Highcharts.Color}\n * Color with modifications.\n */\n setOpacity(alpha) {\n this.rgba[3] = alpha;\n return this;\n }\n /**\n * Return an intermediate color between two colors.\n *\n * @function Highcharts.Color#tweenTo\n *\n * @param {Highcharts.Color} to\n * The color object to tween to.\n *\n * @param {number} pos\n * The intermediate position, where 0 is the from color (current color\n * item), and 1 is the `to` color.\n *\n * @return {Highcharts.ColorType}\n * The intermediate color in rgba notation, or unsupported type.\n */\n tweenTo(to, pos) {\n const fromRgba = this.rgba, toRgba = to.rgba;\n // Unsupported color, return to-color (#3920, #7034)\n if (!isNumber(fromRgba[0]) || !isNumber(toRgba[0])) {\n return to.input || 'none';\n }\n // Check for has alpha, because rgba colors perform worse due to\n // lack of support in WebKit.\n const hasAlpha = (toRgba[3] !== 1 || fromRgba[3] !== 1);\n return (hasAlpha ? 'rgba(' : 'rgb(') +\n Math.round(toRgba[0] + (fromRgba[0] - toRgba[0]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[1] + (fromRgba[1] - toRgba[1]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[2] + (fromRgba[2] - toRgba[2]) * (1 - pos)) +\n (hasAlpha ?\n (',' +\n (toRgba[3] + (fromRgba[3] - toRgba[3]) * (1 - pos))) :\n '') +\n ')';\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * Collection of named colors. Can be extended from the outside by adding\n * colors to Highcharts.Color.names.\n * @private\n */\n Color.names = {\n white: '#ffffff',\n black: '#000000'\n };\n /**\n * Collection of parsers. This can be extended from the outside by pushing\n * parsers to `Color.parsers`.\n */\n Color.parsers = [{\n // RGBA color\n // eslint-disable-next-line max-len\n regex: /rgba\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]?(?:\\.[0-9]+)?)\\s*\\)/,\n parse: function (result) {\n return [\n pInt(result[1]),\n pInt(result[2]),\n pInt(result[3]),\n parseFloat(result[4], 10)\n ];\n }\n }, {\n // RGB color\n regex: /rgb\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*\\)/,\n parse: function (result) {\n return [pInt(result[1]), pInt(result[2]), pInt(result[3]), 1];\n }\n }];\n // Must be last static member for init cycle\n Color.None = new Color('');\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A valid color to be parsed and handled by Highcharts. Highcharts internally\n * supports hex colors like `#ffffff`, rgb colors like `rgb(255,255,255)` and\n * rgba colors like `rgba(255,255,255,1)`. Other colors may be supported by the\n * browsers and displayed correctly, but Highcharts is not able to process them\n * and apply concepts like opacity and brightening.\n *\n * @typedef {string} Highcharts.ColorString\n */\n /**\n * A valid color type than can be parsed and handled by Highcharts. It can be a\n * color string, a gradient object, or a pattern object.\n *\n * @typedef {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject} Highcharts.ColorType\n */\n /**\n * Gradient options instead of a solid color.\n *\n * @example\n * // Linear gradient used as a color option\n * color: {\n * linearGradient: { x1: 0, x2: 0, y1: 0, y2: 1 },\n * stops: [\n * [0, '#003399'], // start\n * [0.5, '#ffffff'], // middle\n * [1, '#3366AA'] // end\n * ]\n * }\n *\n * @interface Highcharts.GradientColorObject\n */ /**\n * Holds an object that defines the start position and the end position relative\n * to the shape.\n * @name Highcharts.GradientColorObject#linearGradient\n * @type {Highcharts.LinearGradientColorObject|undefined}\n */ /**\n * Holds an object that defines the center position and the radius.\n * @name Highcharts.GradientColorObject#radialGradient\n * @type {Highcharts.RadialGradientColorObject|undefined}\n */ /**\n * The first item in each tuple is the position in the gradient, where 0 is the\n * start of the gradient and 1 is the end of the gradient. Multiple stops can be\n * applied. The second item is the color for each stop. This color can also be\n * given in the rgba format.\n * @name Highcharts.GradientColorObject#stops\n * @type {Array}\n */\n /**\n * Color stop tuple.\n *\n * @see Highcharts.GradientColorObject\n *\n * @interface Highcharts.GradientColorStopObject\n */ /**\n * @name Highcharts.GradientColorStopObject#0\n * @type {number}\n */ /**\n * @name Highcharts.GradientColorStopObject#1\n * @type {Highcharts.ColorString}\n */ /**\n * @name Highcharts.GradientColorStopObject#color\n * @type {Highcharts.Color|undefined}\n */\n /**\n * Defines the start position and the end position for a gradient relative\n * to the shape. Start position (x1, y1) and end position (x2, y2) are relative\n * to the shape, where 0 means top/left and 1 is bottom/right.\n *\n * @interface Highcharts.LinearGradientColorObject\n */ /**\n * Start horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x1\n * @type {number}\n */ /**\n * End horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x2\n * @type {number}\n */ /**\n * Start vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y1\n * @type {number}\n */ /**\n * End vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y2\n * @type {number}\n */\n /**\n * Defines the center position and the radius for a gradient.\n *\n * @interface Highcharts.RadialGradientColorObject\n */ /**\n * Center horizontal position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cx\n * @type {number}\n */ /**\n * Center vertical position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cy\n * @type {number}\n */ /**\n * Radius relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#r\n * @type {number}\n */\n /**\n * Creates a color instance out of a color string.\n *\n * @function Highcharts.color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n *\n * @return {Highcharts.Color}\n * Color instance\n */\n (''); // detach doclets above\n\n return Color;\n });\n _registerModule(_modules, 'Core/Color/Palettes.js', [], function () {\n /**\n * Series palettes for Highcharts. Series colors are defined in highcharts.css.\n * **Do not edit this file!** This file is generated using the 'gulp palette' task.\n */\n const SeriesPalettes = {\n /**\n * Colors for data series and points\n */\n colors: [\n '#2caffe',\n '#544fc5',\n '#00e272',\n '#fe6a35',\n '#6b8abc',\n '#d568fb',\n '#2ee0ca',\n '#fa4b42',\n '#feb56a',\n '#91e8e1'\n ]\n };\n\n return SeriesPalettes;\n });\n _registerModule(_modules, 'Core/Time.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { win } = H;\n const { defined, error, extend, isObject, merge, objectEach, pad, pick, splat, timeUnits } = U;\n /* *\n *\n * Constants\n *\n * */\n const hasNewSafariBug = H.isSafari &&\n win.Intl &&\n win.Intl.DateTimeFormat.prototype.formatRange;\n // To do: Remove this when we no longer need support for Safari < v14.1\n const hasOldSafariBug = H.isSafari &&\n win.Intl &&\n !win.Intl.DateTimeFormat.prototype.formatRange;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Time class. Time settings are applied in general for each page using\n * `Highcharts.setOptions`, or individually for each Chart item through the\n * [time](https://api.highcharts.com/highcharts/time) options set.\n *\n * The Time object is available from {@link Highcharts.Chart#time},\n * which refers to `Highcharts.time` if no individual time settings are\n * applied.\n *\n * @example\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n *\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n *\n * @since 6.0.5\n *\n * @class\n * @name Highcharts.Time\n *\n * @param {Highcharts.TimeOptions} [options]\n * Time options as defined in [chart.options.time](/highcharts/time).\n */\n class Time {\n /* *\n *\n * Constructors\n *\n * */\n constructor(options) {\n /* *\n *\n * Properties\n *\n * */\n this.options = {};\n this.useUTC = false;\n this.variableTimezone = false;\n this.Date = win.Date;\n /**\n * Get the time zone offset based on the current timezone information as\n * set in the global options.\n *\n * @function Highcharts.Time#getTimezoneOffset\n *\n * @param {number} timestamp\n * The JavaScript timestamp to inspect.\n *\n * @return {number}\n * The timezone offset in minutes compared to UTC.\n */\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n this.update(options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Time units used in `Time.get` and `Time.set`\n *\n * @typedef {\"Date\"|\"Day\"|\"FullYear\"|\"Hours\"|\"Milliseconds\"|\"Minutes\"|\"Month\"|\"Seconds\"} Highcharts.TimeUnitValue\n */\n /**\n * Get the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.getXXX / Date.getUTCXXX`, so instead of calling\n * `date.getHours()` or `date.getUTCHours()` we will call\n * `time.get('Hours')`.\n *\n * @function Highcharts.Time#get\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n *\n * @return {number}\n * The given time unit\n */\n get(unit, date) {\n if (this.variableTimezone || this.timezoneOffset) {\n const realMs = date.getTime();\n const ms = realMs - this.getTimezoneOffset(date);\n date.setTime(ms); // Temporary adjust to timezone\n const ret = date['getUTC' + unit]();\n date.setTime(realMs); // Reset\n return ret;\n }\n // UTC time with no timezone handling\n if (this.useUTC) {\n return date['getUTC' + unit]();\n }\n // Else, local time\n return date['get' + unit]();\n }\n /**\n * Set the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.setXXX / Date.setUTCXXX`, so instead of calling\n * `date.setHours(0)` or `date.setUTCHours(0)` we will call\n * `time.set('Hours', 0)`.\n *\n * @function Highcharts.Time#set\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n * @param {number} value\n *\n * @return {number}\n * The epoch milliseconds of the updated date\n */\n set(unit, date, value) {\n // UTC time with timezone handling\n if (this.variableTimezone || this.timezoneOffset) {\n // For lower order time units, just set it directly using UTC\n // time\n if (unit === 'Milliseconds' ||\n unit === 'Seconds' ||\n (unit === 'Minutes' &&\n this.getTimezoneOffset(date) % 3600000 === 0) // #13961\n ) {\n return date['setUTC' + unit](value);\n }\n // Higher order time units need to take the time zone into\n // account\n // Adjust by timezone\n const offset = this.getTimezoneOffset(date);\n let ms = date.getTime() - offset;\n date.setTime(ms);\n date['setUTC' + unit](value);\n const newOffset = this.getTimezoneOffset(date);\n ms = date.getTime() + newOffset;\n return date.setTime(ms);\n }\n // UTC time with no timezone handling\n if (this.useUTC ||\n // leap calculation in UTC only\n (hasNewSafariBug && unit === 'FullYear')) {\n return date['setUTC' + unit](value);\n }\n // Else, local time\n return date['set' + unit](value);\n }\n /**\n * Update the Time object with current options. It is called internally on\n * initializing Highcharts, after running `Highcharts.setOptions` and on\n * `Chart.update`.\n *\n * @private\n * @function Highcharts.Time#update\n *\n * @param {Highcharts.TimeOptions} [options]\n *\n */\n update(options = {}) {\n const useUTC = pick(options.useUTC, true);\n this.options = options = merge(true, this.options, options);\n // Allow using a different Date class\n this.Date = options.Date || win.Date || Date;\n this.useUTC = useUTC;\n this.timezoneOffset = (useUTC && options.timezoneOffset) || void 0;\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n /*\n * The time object has options allowing for variable time zones, meaning\n * the axis ticks or series data needs to consider this.\n */\n this.variableTimezone = useUTC && !!(options.getTimezoneOffset ||\n options.timezone);\n }\n /**\n * Make a time and returns milliseconds. Interprets the inputs as UTC time,\n * local time or a specific timezone time depending on the current time\n * settings.\n *\n * @function Highcharts.Time#makeTime\n *\n * @param {number} year\n * The year\n *\n * @param {number} month\n * The month. Zero-based, so January is 0.\n *\n * @param {number} [date=1]\n * The day of the month\n *\n * @param {number} [hours=0]\n * The hour of the day, 0-23.\n *\n * @param {number} [minutes=0]\n * The minutes\n *\n * @param {number} [seconds=0]\n * The seconds\n *\n * @return {number}\n * The time in milliseconds since January 1st 1970.\n */\n makeTime(year, month, date, hours, minutes, seconds) {\n let d, offset, newOffset;\n if (this.useUTC) {\n d = this.Date.UTC.apply(0, arguments);\n offset = this.getTimezoneOffset(d);\n d += offset;\n newOffset = this.getTimezoneOffset(d);\n if (offset !== newOffset) {\n d += newOffset - offset;\n // A special case for transitioning from summer time to winter time.\n // When the clock is set back, the same time is repeated twice, i.e.\n // 02:30 am is repeated since the clock is set back from 3 am to\n // 2 am. We need to make the same time as local Date does.\n }\n else if (offset - 36e5 === this.getTimezoneOffset(d - 36e5) &&\n !hasOldSafariBug) {\n d -= 36e5;\n }\n }\n else {\n d = new this.Date(year, month, pick(date, 1), pick(hours, 0), pick(minutes, 0), pick(seconds, 0)).getTime();\n }\n return d;\n }\n /**\n * Sets the getTimezoneOffset function. If the `timezone` option is set, a\n * default getTimezoneOffset function with that timezone is returned. If\n * a `getTimezoneOffset` option is defined, it is returned. If neither are\n * specified, the function using the `timezoneOffset` option or 0 offset is\n * returned.\n *\n * @private\n * @function Highcharts.Time#timezoneOffsetFunction\n *\n * @return {Function}\n * A getTimezoneOffset function\n */\n timezoneOffsetFunction() {\n const time = this, options = this.options, getTimezoneOffset = options.getTimezoneOffset, moment = options.moment || win.moment;\n if (!this.useUTC) {\n return function (timestamp) {\n return new Date(timestamp.toString()).getTimezoneOffset() * 60000;\n };\n }\n if (options.timezone) {\n if (!moment) {\n // getTimezoneOffset-function stays undefined because it depends\n // on Moment.js\n error(25);\n }\n else {\n return function (timestamp) {\n return -moment.tz(timestamp, options.timezone).utcOffset() * 60000;\n };\n }\n }\n // If not timezone is set, look for the getTimezoneOffset callback\n if (this.useUTC && getTimezoneOffset) {\n return function (timestamp) {\n return getTimezoneOffset(timestamp.valueOf()) * 60000;\n };\n }\n // Last, use the `timezoneOffset` option if set\n return function () {\n return (time.timezoneOffset || 0) * 60000;\n };\n }\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970)\n * into a human readable date string. The available format keys are listed\n * below. Additional formats can be given in the\n * {@link Highcharts.dateFormats} hook.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @example\n * const time = new Highcharts.Time();\n * const s = time.dateFormat('%Y-%m-%d %H:%M:%S', Date.UTC(2020, 0, 1));\n * console.log(s); // => 2020-01-01 00:00:00\n *\n * @function Highcharts.Time#dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are\n * prefixed with %.\n *\n * @param {number} [timestamp]\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n dateFormat(format, timestamp, capitalize) {\n if (!defined(timestamp) || isNaN(timestamp)) {\n return (H.defaultOptions.lang &&\n H.defaultOptions.lang.invalidDate ||\n '');\n }\n format = pick(format, '%Y-%m-%d %H:%M:%S');\n const time = this, date = new this.Date(timestamp), \n // get the basic time values\n hours = this.get('Hours', date), day = this.get('Day', date), dayOfMonth = this.get('Date', date), month = this.get('Month', date), fullYear = this.get('FullYear', date), lang = H.defaultOptions.lang, langWeekdays = (lang && lang.weekdays), shortWeekdays = (lang && lang.shortWeekdays), \n // List all format keys. Custom formats can be added from the\n // outside.\n replacements = extend({\n // Day\n // Short weekday, like 'Mon'\n a: shortWeekdays ?\n shortWeekdays[day] :\n langWeekdays[day].substr(0, 3),\n // Long weekday, like 'Monday'\n A: langWeekdays[day],\n // Two digit day of the month, 01 to 31\n d: pad(dayOfMonth),\n // Day of the month, 1 through 31\n e: pad(dayOfMonth, 2, ' '),\n // Day of the week, 0 through 6\n w: day,\n // Week (none implemented)\n // 'W': weekNumber(),\n // Month\n // Short month, like 'Jan'\n b: lang.shortMonths[month],\n // Long month, like 'January'\n B: lang.months[month],\n // Two digit month number, 01 through 12\n m: pad(month + 1),\n // Month number, 1 through 12 (#8150)\n o: month + 1,\n // Year\n // Two digits year, like 09 for 2009\n y: fullYear.toString().substr(2, 2),\n // Four digits year, like 2009\n Y: fullYear,\n // Time\n // Two digits hours in 24h format, 00 through 23\n H: pad(hours),\n // Hours in 24h format, 0 through 23\n k: hours,\n // Two digits hours in 12h format, 00 through 11\n I: pad((hours % 12) || 12),\n // Hours in 12h format, 1 through 12\n l: (hours % 12) || 12,\n // Two digits minutes, 00 through 59\n M: pad(this.get('Minutes', date)),\n // Upper case AM or PM\n p: hours < 12 ? 'AM' : 'PM',\n // Lower case AM or PM\n P: hours < 12 ? 'am' : 'pm',\n // Two digits seconds, 00 through 59\n S: pad(date.getSeconds()),\n // Milliseconds (naming from Ruby)\n L: pad(Math.floor(timestamp % 1000), 3)\n }, H.dateFormats);\n // Do the replaces\n objectEach(replacements, function (val, key) {\n // Regex would do it in one line, but this is faster\n while (format.indexOf('%' + key) !== -1) {\n format = format.replace('%' + key, typeof val === 'function' ? val.call(time, timestamp) : val);\n }\n });\n // Optionally capitalize the string and return\n return capitalize ?\n (format.substr(0, 1).toUpperCase() +\n format.substr(1)) :\n format;\n }\n /**\n * Resolve legacy formats of dateTimeLabelFormats (strings and arrays) into\n * an object.\n * @private\n * @param {string|Array|Highcharts.Dictionary} f\n * General format description\n * @return {Highcharts.Dictionary}\n * The object definition\n */\n resolveDTLFormat(f) {\n if (!isObject(f, true)) { // check for string or array\n f = splat(f);\n return {\n main: f[0],\n from: f[1],\n to: f[2]\n };\n }\n return f;\n }\n /**\n * Return an array with time positions distributed on round time values\n * right and right after min and max. Used in datetime axes as well as for\n * grouping data on a datetime axis.\n *\n * @function Highcharts.Time#getTimeTicks\n *\n * @param {Highcharts.TimeNormalizedObject} normalizedInterval\n * The interval in axis values (ms) and the count\n *\n * @param {number} [min]\n * The minimum in axis values\n *\n * @param {number} [max]\n * The maximum in axis values\n *\n * @param {number} [startOfWeek=1]\n *\n * @return {Highcharts.AxisTickPositionsArray}\n * Time positions\n */\n getTimeTicks(normalizedInterval, min, max, startOfWeek) {\n const time = this, Date = time.Date, tickPositions = [], higherRanks = {}, \n // When crossing DST, use the max. Resolves #6278.\n minDate = new Date(min), interval = normalizedInterval.unitRange, count = normalizedInterval.count || 1;\n let i, minYear, // used in months and years as a basis for Date.UTC()\n variableDayLength, minDay;\n startOfWeek = pick(startOfWeek, 1);\n if (defined(min)) { // #1300\n time.set('Milliseconds', minDate, interval >= timeUnits.second ?\n 0 : // #3935\n count * Math.floor(time.get('Milliseconds', minDate) / count)); // #3652, #3654\n if (interval >= timeUnits.second) { // second\n time.set('Seconds', minDate, interval >= timeUnits.minute ?\n 0 : // #3935\n count * Math.floor(time.get('Seconds', minDate) / count));\n }\n if (interval >= timeUnits.minute) { // minute\n time.set('Minutes', minDate, interval >= timeUnits.hour ?\n 0 :\n count * Math.floor(time.get('Minutes', minDate) / count));\n }\n if (interval >= timeUnits.hour) { // hour\n time.set('Hours', minDate, interval >= timeUnits.day ?\n 0 :\n count * Math.floor(time.get('Hours', minDate) / count));\n }\n if (interval >= timeUnits.day) { // day\n time.set('Date', minDate, interval >= timeUnits.month ?\n 1 :\n Math.max(1, count * Math.floor(time.get('Date', minDate) / count)));\n }\n if (interval >= timeUnits.month) { // month\n time.set('Month', minDate, interval >= timeUnits.year ? 0 :\n count * Math.floor(time.get('Month', minDate) / count));\n minYear = time.get('FullYear', minDate);\n }\n if (interval >= timeUnits.year) { // year\n minYear -= minYear % count;\n time.set('FullYear', minDate, minYear);\n }\n // week is a special case that runs outside the hierarchy\n if (interval === timeUnits.week) {\n // get start of current week, independent of count\n minDay = time.get('Day', minDate);\n time.set('Date', minDate, (time.get('Date', minDate) -\n minDay + startOfWeek +\n // We don't want to skip days that are before\n // startOfWeek (#7051)\n (minDay < startOfWeek ? -7 : 0)));\n }\n // Get basics for variable time spans\n minYear = time.get('FullYear', minDate);\n const minMonth = time.get('Month', minDate), minDateDate = time.get('Date', minDate), minHours = time.get('Hours', minDate);\n // Redefine min to the floored/rounded minimum time (#7432)\n min = minDate.getTime();\n // Handle local timezone offset\n if ((time.variableTimezone || !time.useUTC) && defined(max)) {\n // Detect whether we need to take the DST crossover into\n // consideration. If we're crossing over DST, the day length may\n // be 23h or 25h and we need to compute the exact clock time for\n // each tick instead of just adding hours. This comes at a cost,\n // so first we find out if it is needed (#4951).\n variableDayLength = (\n // Long range, assume we're crossing over.\n max - min > 4 * timeUnits.month ||\n // Short range, check if min and max are in different time\n // zones.\n time.getTimezoneOffset(min) !==\n time.getTimezoneOffset(max));\n }\n // Iterate and add tick positions at appropriate values\n let t = minDate.getTime();\n i = 1;\n while (t < max) {\n tickPositions.push(t);\n // if the interval is years, use Date.UTC to increase years\n if (interval === timeUnits.year) {\n t = time.makeTime(minYear + i * count, 0);\n // if the interval is months, use Date.UTC to increase months\n }\n else if (interval === timeUnits.month) {\n t = time.makeTime(minYear, minMonth + i * count);\n // if we're using global time, the interval is not fixed as it\n // jumps one hour at the DST crossover\n }\n else if (variableDayLength &&\n (interval === timeUnits.day || interval === timeUnits.week)) {\n t = time.makeTime(minYear, minMonth, minDateDate +\n i * count * (interval === timeUnits.day ? 1 : 7));\n }\n else if (variableDayLength &&\n interval === timeUnits.hour &&\n count > 1) {\n // make sure higher ranks are preserved across DST (#6797,\n // #7621)\n t = time.makeTime(minYear, minMonth, minDateDate, minHours + i * count);\n // else, the interval is fixed and we use simple addition\n }\n else {\n t += interval * count;\n }\n i++;\n }\n // push the last time\n tickPositions.push(t);\n // Handle higher ranks. Mark new days if the time is on midnight\n // (#950, #1649, #1760, #3349). Use a reasonable dropout threshold\n // to prevent looping over dense data grouping (#6156).\n if (interval <= timeUnits.hour && tickPositions.length < 10000) {\n tickPositions.forEach(function (t) {\n if (\n // Speed optimization, no need to run dateFormat unless\n // we're on a full or half hour\n t % 1800000 === 0 &&\n // Check for local or global midnight\n time.dateFormat('%H%M%S%L', t) === '000000000') {\n higherRanks[t] = 'day';\n }\n });\n }\n }\n // record information on the chosen unit - for dynamic label formatter\n tickPositions.info = extend(normalizedInterval, {\n higherRanks,\n totalRange: interval * count\n });\n return tickPositions;\n }\n /**\n * Get the optimal date format for a point, based on a range.\n *\n * @private\n * @function Highcharts.Time#getDateFormat\n *\n * @param {number} range\n * The time range\n *\n * @param {number} timestamp\n * The timestamp of the date\n *\n * @param {number} startOfWeek\n * An integer representing the first day of the week, where 0 is\n * Sunday.\n *\n * @param {Highcharts.Dictionary} dateTimeLabelFormats\n * A map of time units to formats.\n *\n * @return {string}\n * The optimal date format for a point.\n */\n getDateFormat(range, timestamp, startOfWeek, dateTimeLabelFormats) {\n const dateStr = this.dateFormat('%m-%d %H:%M:%S.%L', timestamp), blank = '01-01 00:00:00.000', strpos = {\n millisecond: 15,\n second: 12,\n minute: 9,\n hour: 6,\n day: 3\n };\n let n = 'millisecond', \n // for sub-millisecond data, #4223\n lastN = n;\n for (n in timeUnits) { // eslint-disable-line guard-for-in\n // If the range is exactly one week and we're looking at a\n // Sunday/Monday, go for the week format\n if (range === timeUnits.week &&\n +this.dateFormat('%w', timestamp) === startOfWeek &&\n dateStr.substr(6) === blank.substr(6)) {\n n = 'week';\n break;\n }\n // The first format that is too great for the range\n if (timeUnits[n] > range) {\n n = lastN;\n break;\n }\n // If the point is placed every day at 23:59, we need to show\n // the minutes as well. #2637.\n if (strpos[n] &&\n dateStr.substr(strpos[n]) !== blank.substr(strpos[n])) {\n break;\n }\n // Weeks are outside the hierarchy, only apply them on\n // Mondays/Sundays like in the first condition\n if (n !== 'week') {\n lastN = n;\n }\n }\n return this.resolveDTLFormat(dateTimeLabelFormats[n]).main;\n }\n }\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Normalized interval.\n *\n * @interface Highcharts.TimeNormalizedObject\n */ /**\n * The count.\n *\n * @name Highcharts.TimeNormalizedObject#count\n * @type {number|undefined}\n */ /**\n * The interval in axis values (ms).\n *\n * @name Highcharts.TimeNormalizedObject#unitRange\n * @type {number}\n */\n /**\n * Function of an additional date format specifier.\n *\n * @callback Highcharts.TimeFormatCallbackFunction\n *\n * @param {number} timestamp\n * The time to format.\n *\n * @return {string}\n * The formatted portion of the date.\n */\n /**\n * Time ticks.\n *\n * @interface Highcharts.AxisTickPositionsArray\n * @extends global.Array\n */ /**\n * @name Highcharts.AxisTickPositionsArray#info\n * @type {Highcharts.TimeTicksInfoObject|undefined}\n */\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @callback Highcharts.TimezoneOffsetCallbackFunction\n *\n * @param {number} timestamp\n * Timestamp in terms of milliseconds since January 1 1970.\n *\n * @return {number}\n * Timezone offset in minutes.\n */\n /**\n * Allows to manually load the `moment.js` library from Highcharts options\n * instead of the `window`.\n * In case of loading the library from a `script` tag,\n * this option is not needed, it will be loaded from there by default.\n *\n * @type {Function}\n * @since 8.2.0\n * @apioption time.moment\n */\n ''; // keeps doclets above in JS file\n\n return Time;\n });\n _registerModule(_modules, 'Core/Defaults.js', [_modules['Core/Chart/ChartDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Color/Palettes.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js']], function (ChartDefaults, Color, H, Palettes, Time, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { isTouchDevice, svg } = H;\n const { merge } = U;\n /* *\n *\n * API Options\n *\n * */\n /**\n * Global default settings.\n *\n * @name Highcharts.defaultOptions\n * @type {Highcharts.Options}\n */ /**\n * @optionparent\n * @private\n */\n const defaultOptions = {\n /**\n * An array containing the default colors for the chart's series. When\n * all colors are used, new colors are pulled from the start again.\n *\n * Default colors can also be set on a series or series.type basis,\n * see [column.colors](#plotOptions.column.colors),\n * [pie.colors](#plotOptions.pie.colors).\n *\n * In styled mode, the colors option doesn't exist. Instead, colors\n * are defined in CSS and applied either through series or point class\n * names, or through the [chart.colorCount](#chart.colorCount) option.\n *\n * @sample {highcharts} highcharts/chart/colors/\n * Assign a global color theme\n * @sample highcharts/members/theme-v10/\n * Latest release styled like version 10\n *\n * @type {Array<(Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject)>}\n * @default [\n * \"#2caffe\",\n * \"#544fc5\",\n * \"#00e272\",\n * \"#fe6a35\",\n * \"#6b8abc\",\n * \"#d568fb\",\n * \"#2ee0ca\",\n * \"#fa4b42\",\n * \"#feb56a\",\n * \"#91e8e12\n * ]\n */\n colors: Palettes.colors,\n /**\n * Styled mode only. Configuration object for adding SVG definitions for\n * reusable elements. See [gradients, shadows and\n * patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns)\n * for more information and code examples.\n *\n * @type {*}\n * @since 5.0.0\n * @apioption defs\n */\n /**\n * @ignore-option\n */\n symbols: ['circle', 'diamond', 'square', 'triangle', 'triangle-down'],\n /**\n * The language object is global and it can't be set on each chart\n * initialization. Instead, use `Highcharts.setOptions` to set it before any\n * chart is initialized.\n *\n * ```js\n * Highcharts.setOptions({\n * lang: {\n * months: [\n * 'Janvier', 'Février', 'Mars', 'Avril',\n * 'Mai', 'Juin', 'Juillet', 'Août',\n * 'Septembre', 'Octobre', 'Novembre', 'Décembre'\n * ],\n * weekdays: [\n * 'Dimanche', 'Lundi', 'Mardi', 'Mercredi',\n * 'Jeudi', 'Vendredi', 'Samedi'\n * ]\n * }\n * });\n * ```\n */\n lang: {\n /**\n * The loading text that appears when the chart is set into the loading\n * state following a call to `chart.showLoading`.\n */\n loading: 'Loading...',\n /**\n * An array containing the months names. Corresponds to the `%B` format\n * in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\",\n * \"July\", \"August\", \"September\", \"October\", \"November\",\n * \"December\"]\n */\n months: [\n 'January', 'February', 'March', 'April', 'May', 'June', 'July',\n 'August', 'September', 'October', 'November', 'December'\n ],\n /**\n * An array containing the months names in abbreviated form. Corresponds\n * to the `%b` format in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n * \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n */\n shortMonths: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul',\n 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ],\n /**\n * An array containing the weekday names.\n *\n * @type {Array}\n * @default [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\",\n * \"Friday\", \"Saturday\"]\n */\n weekdays: [\n 'Sunday', 'Monday', 'Tuesday', 'Wednesday',\n 'Thursday', 'Friday', 'Saturday'\n ],\n /**\n * Short week days, starting Sunday. If not specified, Highcharts uses\n * the first three letters of the `lang.weekdays` option.\n *\n * @sample highcharts/lang/shortweekdays/\n * Finnish two-letter abbreviations\n *\n * @type {Array}\n * @since 4.2.4\n * @apioption lang.shortWeekdays\n */\n /**\n * What to show in a date field for invalid dates. Defaults to an empty\n * string.\n *\n * @type {string}\n * @since 4.1.8\n * @product highcharts highstock\n * @apioption lang.invalidDate\n */\n /**\n * The title appearing on hovering the zoom in button. The text itself\n * defaults to \"+\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom in\n * @product highmaps\n * @apioption lang.zoomIn\n */\n /**\n * The title appearing on hovering the zoom out button. The text itself\n * defaults to \"-\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom out\n * @product highmaps\n * @apioption lang.zoomOut\n */\n /**\n * The default decimal point used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments.\n *\n * @since 1.2.2\n */\n decimalPoint: '.',\n /**\n * [Metric prefixes](https://en.wikipedia.org/wiki/Metric_prefix) used\n * to shorten high numbers in axis labels. Replacing any of the\n * positions with `null` causes the full number to be written. Setting\n * `numericSymbols` to `null` disables shortening altogether.\n *\n * @sample {highcharts} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n * @sample {highstock} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n *\n * @type {Array}\n * @default [\"k\", \"M\", \"G\", \"T\", \"P\", \"E\"]\n * @since 2.3.0\n */\n numericSymbols: ['k', 'M', 'G', 'T', 'P', 'E'],\n /**\n * The magnitude of [numericSymbols](#lang.numericSymbol) replacements.\n * Use 10000 for Japanese, Korean and various Chinese locales, which\n * use symbols for 10^4, 10^8 and 10^12.\n *\n * @sample highcharts/lang/numericsymbolmagnitude/\n * 10000 magnitude for Japanese\n *\n * @type {number}\n * @default 1000\n * @since 5.0.3\n * @apioption lang.numericSymbolMagnitude\n */\n /**\n * The text for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoom: 'Reset zoom',\n /**\n * The tooltip title for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoomTitle: 'Reset zoom level 1:1',\n /**\n * The default thousands separator used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments. Defaults\n * to a single space character, which is recommended in\n * [ISO 31-0](https://en.wikipedia.org/wiki/ISO_31-0#Numbers) and works\n * across Anglo-American and continental European languages.\n *\n * @default \\u0020\n * @since 1.2.2\n */\n thousandsSep: ' '\n },\n /**\n * Global options that don't apply to each chart. These options, like\n * the `lang` options, must be set using the `Highcharts.setOptions`\n * method.\n *\n * ```js\n * Highcharts.setOptions({\n * global: {\n * useUTC: false\n * }\n * });\n * ```\n */\n /**\n * _Canvg rendering for Android 2.x is removed as of Highcharts 5.0\\.\n * Use the [libURL](#exporting.libURL) option to configure exporting._\n *\n * The URL to the additional file to lazy load for Android 2.x devices.\n * These devices don't support SVG, so we download a helper file that\n * contains [canvg](https://github.com/canvg/canvg), its dependency\n * rbcolor, and our own CanVG Renderer class. To avoid hotlinking to\n * our site, you can install canvas-tools.js on your own server and\n * change this option accordingly.\n *\n * @deprecated\n *\n * @type {string}\n * @default https://code.highcharts.com/{version}/modules/canvas-tools.js\n * @product highcharts highmaps\n * @apioption global.canvasToolsURL\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.useUTC](#time.useUTC) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {boolean}\n * @apioption global.useUTC\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.Date](#time.Date) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.Date\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.getTimezoneOffset](#time.getTimezoneOffset) that supports\n * individual time settings per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.getTimezoneOffset\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezone](#time.timezone) that supports individual time\n * settings per chart.\n *\n * @deprecated\n *\n * @type {string}\n * @product highcharts highstock\n * @apioption global.timezone\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezoneOffset](#time.timezoneOffset) that supports individual\n * time settings per chart.\n *\n * @deprecated\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption global.timezoneOffset\n */\n global: {},\n /**\n * Time options that can apply globally or to individual charts. These\n * settings affect how `datetime` axes are laid out, how tooltips are\n * formatted, how series\n * [pointIntervalUnit](#plotOptions.series.pointIntervalUnit) works and how\n * the Highcharts Stock range selector handles time.\n *\n * The common use case is that all charts in the same Highcharts object\n * share the same time settings, in which case the global settings are set\n * using `setOptions`.\n *\n * ```js\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n * ```\n *\n * Since v6.0.5, the time options were moved from the `global` obect to the\n * `time` object, and time options can be set on each individual chart.\n *\n * @sample {highcharts|highstock}\n * highcharts/time/timezone/\n * Set the timezone globally\n * @sample {highcharts}\n * highcharts/time/individual/\n * Set the timezone per chart instance\n * @sample {highstock}\n * stock/time/individual/\n * Set the timezone per chart instance\n *\n * @since 6.0.5\n * @optionparent time\n */\n time: {\n /**\n * A custom `Date` class for advanced date handling. For example,\n * [JDate](https://github.com/tahajahangir/jdate) can be hooked in to\n * handle Jalali dates.\n *\n * @type {*}\n * @since 4.0.4\n * @product highcharts highstock gantt\n */\n Date: void 0,\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @see [global.timezoneOffset](#global.timezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/gettimezoneoffset/\n * Use moment.js to draw Oslo time regardless of browser locale\n *\n * @type {Highcharts.TimezoneOffsetCallbackFunction}\n * @since 4.1.0\n * @product highcharts highstock gantt\n */\n getTimezoneOffset: void 0,\n /**\n * Requires [moment.js](https://momentjs.com/). If the timezone option\n * is specified, it creates a default\n * [getTimezoneOffset](#time.getTimezoneOffset) function that looks\n * up the specified timezone in moment.js. If moment.js is not included,\n * this throws a Highcharts error in the console, but does not crash the\n * chart.\n *\n * @see [getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezone/\n * Europe/Oslo\n *\n * @type {string}\n * @since 5.0.7\n * @product highcharts highstock gantt\n */\n timezone: void 0,\n /**\n * The timezone offset in minutes. Positive values are west, negative\n * values are east of UTC, as in the ECMAScript\n * [getTimezoneOffset](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/getTimezoneOffset)\n * method. Use this to display UTC based data in a predefined time zone.\n *\n * @see [time.getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezoneoffset/\n * Timezone offset\n *\n * @since 3.0.8\n * @product highcharts highstock gantt\n */\n timezoneOffset: 0,\n /**\n * Whether to use UTC time for axis scaling, tickmark placement and\n * time display in `Highcharts.dateFormat`. Advantages of using UTC\n * is that the time displays equally regardless of the user agent's\n * time zone settings. Local time can be used when the data is loaded\n * in real time or when correct Daylight Saving Time transitions are\n * required.\n *\n * @sample {highcharts} highcharts/time/useutc-true/\n * True by default\n * @sample {highcharts} highcharts/time/useutc-false/\n * False\n */\n useUTC: true\n },\n chart: ChartDefaults,\n /**\n * The chart's main title.\n *\n * @sample {highmaps} maps/title/title/\n * Title options demonstrated\n */\n title: {\n /**\n * When the title is floating, the plot area will not move to make space\n * for it.\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * False by default\n * @sample {highcharts} highcharts/title/floating/\n * True - title on top of the plot area\n * @sample {highstock} stock/chart/title-floating/\n * True - title on top of the plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption title.floating\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption title.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When a value is given, the title behaves\n * as if [floating](#title.floating) were `true`.\n *\n * @sample {highcharts} highcharts/title/verticalalign/\n * Chart title in bottom right corner\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption title.verticalAlign\n */\n /**\n * The x position of the title relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption title.x\n */\n /**\n * The y position of the title relative to the alignment within\n * [chart.spacingTop](#chart.spacingTop) and [chart.spacingBottom](\n * #chart.spacingBottom). By default it depends on the font size.\n *\n * @sample {highcharts} highcharts/title/y/\n * Title inside the plot area\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {number}\n * @since 2.0\n * @apioption title.y\n */\n /**\n * CSS styles for the title. Use this for font styling, but use `align`,\n * `x` and `y` for text alignment.\n *\n * In styled mode, the title style is given in the `.highcharts-title`\n * class.\n *\n * @sample {highcharts} highcharts/title/style/\n * Custom color and weight\n * @sample {highstock} stock/chart/title-style/\n * Custom color and weight\n * @sample highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {highcharts|highmaps} { \"color\": \"#333333\", \"fontSize\": \"18px\" }\n * @default {highstock} { \"color\": \"#333333\", \"fontSize\": \"16px\" }\n */\n style: {\n color: \"#333333\" /* Palette.neutralColor80 */,\n fontWeight: 'bold'\n },\n /**\n * The title of the chart. To disable the title, set the `text` to\n * `undefined`.\n *\n * @sample {highcharts} highcharts/title/text/\n * Custom title\n * @sample {highstock} stock/chart/title-text/\n * Custom title\n *\n * @default {highcharts|highmaps} Chart title\n * @default {highstock} undefined\n */\n text: 'Chart title',\n /**\n * The horizontal alignment of the title. Can be one of \"left\", \"center\"\n * and \"right\".\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * The margin between the title and the plot area, or if a subtitle\n * is present, the margin between the subtitle and the plot area.\n *\n * @sample {highcharts} highcharts/title/margin-50/\n * A chart title margin of 50\n * @sample {highcharts} highcharts/title/margin-subtitle/\n * The same margin applied with a subtitle\n * @sample {highstock} stock/chart/title-margin/\n * A chart title margin of 50\n *\n * @since 2.1\n */\n margin: 15,\n /**\n * Adjustment made to the title width, normally to reserve space for\n * the exporting burger menu.\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's subtitle. This can be used both to display a subtitle below\n * the main title, and to display random text anywhere in the chart. The\n * subtitle can be updated after chart initialization through the\n * `Chart.setTitle` method.\n *\n * @sample {highmaps} maps/title/subtitle/\n * Subtitle options demonstrated\n */\n subtitle: {\n /**\n * When the subtitle is floating, the plot area will not move to make\n * space for it.\n *\n * @sample {highcharts} highcharts/subtitle/floating/\n * Floating title and subtitle\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote floating at bottom right of plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption subtitle.floating\n */\n /**\n * CSS styles for the title.\n *\n * In styled mode, the subtitle style is given in the\n * `.highcharts-subtitle` class.\n *\n * @sample {highcharts} highcharts/subtitle/style/\n * Custom color and weight\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n * @sample {highstock} stock/chart/subtitle-style\n * Custom color and weight\n * @sample {highstock} highcharts/css/titles/\n * Styled mode\n * @sample {highmaps} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n * @apioption subtitle.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption subtitle.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the subtitle behaves as\n * floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption subtitle.verticalAlign\n */\n /**\n * The x position of the subtitle relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption subtitle.x\n */\n /**\n * The y position of the subtitle relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`. By default the subtitle\n * is laid out below the title unless the title is floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @since 2.0\n * @apioption subtitle.y\n */\n /**\n * CSS styles for the title.\n *\n * In styled mode, the subtitle style is given in the\n * `.highcharts-subtitle` class.\n *\n * @sample {highcharts} highcharts/subtitle/style/\n * Custom color and weight\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n * @sample {highstock} stock/chart/subtitle-style\n * Custom color and weight\n * @sample {highstock} highcharts/css/titles/\n * Styled mode\n * @sample {highmaps} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n */\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */,\n fontSize: '0.8em'\n },\n /**\n * The subtitle of the chart.\n *\n * @sample {highcharts|highstock} highcharts/subtitle/text/\n * Custom subtitle\n * @sample {highcharts|highstock} highcharts/subtitle/text-formatted/\n * Formatted and linked text.\n */\n text: '',\n /**\n * The horizontal alignment of the subtitle. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at bottom right of plot area\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * Adjustment made to the subtitle width, normally to reserve space\n * for the exporting burger menu.\n *\n * @see [title.widthAdjust](#title.widthAdjust)\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's caption, which will render below the chart and will be part\n * of exported charts. The caption can be updated after chart initialization\n * through the `Chart.update` or `Chart.caption.update` methods.\n *\n * @sample highcharts/caption/text/\n * A chart with a caption\n * @since 7.2.0\n */\n caption: {\n /**\n * When the caption is floating, the plot area will not move to make\n * space for it.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.floating\n */\n /**\n * The margin between the caption and the plot area.\n */\n margin: 15,\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.useHTML\n */\n /**\n * The x position of the caption relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @type {number}\n * @default 0\n * @apioption caption.x\n */\n /**\n * The y position of the caption relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`.\n *\n * @type {number}\n * @apioption caption.y\n */\n /**\n * CSS styles for the caption.\n *\n * In styled mode, the caption style is given in the\n * `.highcharts-caption` class.\n *\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n */\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */,\n fontSize: '0.8em'\n },\n /**\n * The caption text of the chart.\n *\n * @sample {highcharts} highcharts/caption/text/\n * Custom caption\n */\n text: '',\n /**\n * The horizontal alignment of the caption. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @type {Highcharts.AlignValue}\n */\n align: 'left',\n /**\n * The vertical alignment of the caption. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the caption behaves as\n * floating.\n *\n * @type {Highcharts.VerticalAlignValue}\n */\n verticalAlign: 'bottom'\n },\n /**\n * The plotOptions is a wrapper object for config objects for each series\n * type. The config objects for each series can also be overridden for\n * each series item as given in the series array.\n *\n * Configuration options for the series are given in three levels. Options\n * for all series in a chart are given in the [plotOptions.series](\n * #plotOptions.series) object. Then options for all series of a specific\n * type are given in the plotOptions of that type, for example\n * `plotOptions.line`. Next, options for one single series are given in\n * [the series array](#series).\n */\n plotOptions: {},\n /**\n * The legend is a box containing a symbol and name for each series\n * item or point item in the chart. Each series (or points in case\n * of pie charts) is represented by a symbol and its name in the legend.\n *\n * It is possible to override the symbol creator function and create\n * [custom legend symbols](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/studies/legend-custom-symbol/).\n *\n * @productdesc {highmaps}\n * A Highmaps legend by default contains one legend item per series, but if\n * a `colorAxis` is defined, the axis will be displayed in the legend.\n * Either as a gradient, or as multiple legend items for `dataClasses`.\n */\n legend: {\n /**\n * The background color of the legend.\n *\n * @see In styled mode, the legend background fill can be applied with\n * the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/backgroundcolor/\n * Yellowish background\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption legend.backgroundColor\n */\n /**\n * The width of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke width can be applied\n * with the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/borderwidth/\n * 2px border width\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {number}\n * @default 0\n * @apioption legend.borderWidth\n */\n /**\n * Enable or disable the legend. There is also a series-specific option,\n * [showInLegend](#plotOptions.series.showInLegend), that can hide the\n * series from the legend. In some series types this is `false` by\n * default, so it must set to `true` in order to show the legend for the\n * series.\n *\n * @sample {highcharts} highcharts/legend/enabled-false/ Legend disabled\n * @sample {highstock} stock/legend/align/ Various legend options\n * @sample {highmaps} maps/legend/enabled-false/ Legend disabled\n *\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} false\n */\n enabled: true,\n /**\n * The horizontal alignment of the legend box within the chart area.\n * Valid values are `left`, `center` and `right`.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * @sample {highcharts} highcharts/legend/align/\n * Legend at the right of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * If the [layout](legend.layout) is `horizontal` and the legend items\n * span over two lines or more, whether to align the items into vertical\n * columns. Setting this to `false` makes room for more items, but will\n * look more messy.\n *\n * @since 6.1.0\n */\n alignColumns: true,\n /**\n * A CSS class name to apply to the legend group.\n */\n className: 'highcharts-no-tooltip',\n /**\n * When the legend is floating, the plot area ignores it and is allowed\n * to be placed below it.\n *\n * @sample {highcharts} highcharts/legend/floating-false/\n * False by default\n * @sample {highcharts} highcharts/legend/floating-true/\n * True\n * @sample {highmaps} maps/legend/alignment/\n * Floating legend\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption legend.floating\n */\n /**\n * The layout of the legend items. Can be one of `horizontal` or\n * `vertical` or `proximate`. When `proximate`, the legend items will be\n * placed as close as possible to the graphs they're representing,\n * except in inverted charts or when the legend position doesn't allow\n * it.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highcharts} highcharts/legend/layout-vertical/\n * Vertical\n * @sample highcharts/legend/layout-proximate\n * Labels proximate to the data\n * @sample {highstock} stock/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Vertical with data classes\n * @sample {highmaps} maps/legend/layout-vertical/\n * Vertical with color axis gradient\n *\n * @validvalue [\"horizontal\", \"vertical\", \"proximate\"]\n */\n layout: 'horizontal',\n /**\n * In a legend with horizontal layout, the itemDistance defines the\n * pixel distance between each item.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * 50px item distance\n * @sample {highstock} highcharts/legend/layout-horizontal/\n * 50px item distance\n *\n * @type {number}\n * @default {highcharts} 20\n * @default {highstock} 20\n * @default {highmaps} 8\n * @since 3.0.3\n * @apioption legend.itemDistance\n */\n /**\n * The pixel bottom margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @since 2.2.0\n */\n itemMarginBottom: 2,\n /**\n * The pixel top margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @since 2.2.0\n */\n itemMarginTop: 2,\n /**\n * The width for each legend item. By default the items are laid out\n * successively. In a [horizontal layout](legend.layout), if the items\n * are laid out across two rows or more, they will be vertically aligned\n * depending on the [legend.alignColumns](legend.alignColumns) option.\n *\n * @sample {highcharts} highcharts/legend/itemwidth-default/\n * Undefined by default\n * @sample {highcharts} highcharts/legend/itemwidth-80/\n * 80 for aligned legend items\n *\n * @type {number}\n * @since 2.0\n * @apioption legend.itemWidth\n */\n /**\n * A [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for each legend label. Available variables relates to properties on\n * the series, or the point in case of pies.\n *\n * @type {string}\n * @default {name}\n * @since 1.3\n * @apioption legend.labelFormat\n */\n /* eslint-disable valid-jsdoc */\n /**\n * Callback function to format each of the series' labels. The `this`\n * keyword refers to the series object, or the point object in case of\n * pie charts. By default the series or point name is printed.\n *\n * @productdesc {highmaps}\n * In Highmaps the context can also be a data class in case of a\n * `colorAxis`.\n *\n * @sample {highcharts} highcharts/legend/labelformatter/\n * Add text\n * @sample {highmaps} maps/legend/labelformatter/\n * Data classes with label formatter\n *\n * @type {Highcharts.FormatterCallbackFunction}\n */\n labelFormatter: function () {\n /** eslint-enable valid-jsdoc */\n return this.name;\n },\n /**\n * Line height for the legend items. Deprecated as of 2.1\\. Instead,\n * the line height for each item can be set using\n * `itemStyle.lineHeight`, and the padding between items using\n * `itemMarginTop` and `itemMarginBottom`.\n *\n * @sample {highcharts} highcharts/legend/lineheight/\n * Setting padding\n *\n * @deprecated\n *\n * @type {number}\n * @default 16\n * @since 2.0\n * @product highcharts gantt\n * @apioption legend.lineHeight\n */\n /**\n * If the plot area sized is calculated automatically and the legend is\n * not floating, the legend margin is the space between the legend and\n * the axis labels or plot area.\n *\n * @sample {highcharts} highcharts/legend/margin-default/\n * 12 pixels by default\n * @sample {highcharts} highcharts/legend/margin-30/\n * 30 pixels\n *\n * @type {number}\n * @default 12\n * @since 2.1\n * @apioption legend.margin\n */\n /**\n * Maximum pixel height for the legend. When the maximum height is\n * extended, navigation will show.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption legend.maxHeight\n */\n /**\n * The color of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke can be applied with the\n * `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/bordercolor/\n * Brown border\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The border corner radius of the legend.\n *\n * @sample {highcharts} highcharts/legend/borderradius-default/\n * Square by default\n * @sample {highcharts} highcharts/legend/borderradius-round/\n * 5px rounded\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n */\n borderRadius: 0,\n /**\n * Options for the paging or navigation appearing when the legend is\n * overflown. Navigation works well on screen, but not in static\n * exported images. One way of working around that is to\n * [increase the chart height in\n * export](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/legend/navigation-enabled-false/).\n */\n navigation: {\n /**\n * How to animate the pages when navigating up or down. A value of\n * `true` applies the default navigation given in the\n * `chart.animation` option. Additional options can be given as an\n * object containing values for easing and duration.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {boolean|Partial}\n * @default true\n * @since 2.2.4\n * @apioption legend.navigation.animation\n */\n /**\n * The pixel size of the up and down arrows in the legend paging\n * navigation.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {number}\n * @default 12\n * @since 2.2.4\n * @apioption legend.navigation.arrowSize\n */\n /**\n * Whether to enable the legend navigation. In most cases, disabling\n * the navigation results in an unwanted overflow.\n *\n * See also the\n * [adapt chart to legend](https://github.com/highcharts/adapt-chart-to-legend)\n * plugin for a solution to extend the chart height to make room for\n * the legend, optionally in exported charts only.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.4\n * @apioption legend.navigation.enabled\n */\n /**\n * Text styles for the legend page navigation.\n *\n * @see In styled mode, the navigation items are styled with the\n * `.highcharts-legend-navigation` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.CSSObject}\n * @since 2.2.4\n * @apioption legend.navigation.style\n */\n style: {\n fontSize: '0.8em'\n },\n /**\n * The color for the active up or down arrow in the legend page\n * navigation.\n *\n * @see In styled mode, the active arrow be styled with the\n * `.highcharts-legend-nav-active` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n activeColor: \"#0022ff\" /* Palette.highlightColor100 */,\n /**\n * The color of the inactive up or down arrow in the legend page\n * navigation. .\n *\n * @see In styled mode, the inactive arrow be styled with the\n * `.highcharts-legend-nav-inactive` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n inactiveColor: \"#cccccc\" /* Palette.neutralColor20 */\n },\n /**\n * The inner padding of the legend box.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 8\n * @since 2.2.0\n * @apioption legend.padding\n */\n /**\n * Whether to reverse the order of the legend items compared to the\n * order of the series or points as defined in the configuration object.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks),\n * [series.legendIndex](#series.legendIndex)\n *\n * @sample {highcharts} highcharts/legend/reversed/\n * Stacked bar with reversed legend\n *\n * @type {boolean}\n * @default false\n * @since 1.2.5\n * @apioption legend.reversed\n */\n /**\n * Whether to show the symbol on the right side of the text rather than\n * the left side. This is common in Arabic and Hebrew.\n *\n * @sample {highcharts} highcharts/legend/rtl/\n * Symbol to the right\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption legend.rtl\n */\n /**\n * CSS styles for the legend area. In the 1.x versions the position\n * of the legend area was determined by CSS. In 2.x, the position is\n * determined by properties like `align`, `verticalAlign`, `x` and `y`,\n * but the styles are still parsed for backwards compatibility.\n *\n * @deprecated\n *\n * @type {Highcharts.CSSObject}\n * @product highcharts highstock\n * @apioption legend.style\n */\n /**\n * CSS styles for each legend item. Only a subset of CSS is supported,\n * notably those options related to text. The default `textOverflow`\n * property makes long texts truncate. Set it to `undefined` to wrap\n * text instead. A `width` property can be added to control the text\n * width.\n *\n * @see In styled mode, the legend items can be styled with the\n * `.highcharts-legend-item` class.\n *\n * @sample {highcharts} highcharts/legend/itemstyle/\n * Bold black text\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#333333\", \"cursor\": \"pointer\", \"fontSize\": \"0.75em\", \"fontWeight\": \"bold\", \"textOverflow\": \"ellipsis\"}\n */\n itemStyle: {\n /**\n * @ignore\n */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * @ignore\n */\n cursor: 'pointer',\n /**\n * @ignore\n */\n fontSize: '0.8em',\n /**\n * @ignore\n */\n textDecoration: 'none',\n /**\n * @ignore\n */\n textOverflow: 'ellipsis'\n },\n /**\n * CSS styles for each legend item in hover mode. Only a subset of\n * CSS is supported, notably those options related to text. Properties\n * are inherited from `style` unless overridden here.\n *\n * @see In styled mode, the hovered legend items can be styled with\n * the `.highcharts-legend-item:hover` pesudo-class.\n *\n * @sample {highcharts} highcharts/legend/itemhoverstyle/\n * Red on hover\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#000000\"}\n */\n itemHoverStyle: {\n /**\n * @ignore\n */\n color: \"#000000\" /* Palette.neutralColor100 */\n },\n /**\n * CSS styles for each legend item when the corresponding series or\n * point is hidden. Only a subset of CSS is supported, notably those\n * options related to text. Properties are inherited from `style`\n * unless overridden here.\n *\n * @see In styled mode, the hidden legend items can be styled with\n * the `.highcharts-legend-item-hidden` class.\n *\n * @sample {highcharts} highcharts/legend/itemhiddenstyle/\n * Darker gray color\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#cccccc\"}\n */\n itemHiddenStyle: {\n /**\n * @ignore\n */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /**\n * @ignore\n */\n textDecoration: 'line-through'\n },\n /**\n * Whether to apply a drop shadow to the legend. A `backgroundColor`\n * also needs to be applied for this to take effect. The shadow can be\n * an object configuration containing `color`, `offsetX`, `offsetY`,\n * `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/legend/shadow/\n * White background and drop shadow\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {boolean|Highcharts.CSSObject}\n */\n shadow: false,\n /**\n * Default styling for the checkbox next to a legend item when\n * `showCheckbox` is true.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"width\": \"13px\", \"height\": \"13px\", \"position\":\"absolute\"}\n */\n itemCheckboxStyle: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n width: '13px',\n /**\n * @ignore\n */\n height: '13px'\n },\n // itemWidth: undefined,\n /**\n * When this is true, the legend symbol width will be the same as\n * the symbol height, which in turn defaults to the font size of the\n * legend items.\n *\n * @since 5.0.0\n */\n squareSymbol: true,\n /**\n * The pixel height of the symbol for series types that use a rectangle\n * in the legend. Defaults to the font size of legend items.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a vertical color\n * axis, the height defaults to 200.\n *\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * No distance between data classes\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolHeight\n */\n /**\n * The border radius of the symbol for series types that use a rectangle\n * in the legend. Defaults to half the `symbolHeight`, effectively\n * creating a circle.\n *\n * For color axis scales, it defaults to 3.\n *\n * @sample {highcharts} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highstock} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highmaps} highcharts/legend/symbolradius/\n * Round symbols\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolRadius\n */\n /**\n * The pixel width of the legend item symbol. When the `squareSymbol`\n * option is set, this defaults to the `symbolHeight`, otherwise 16.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a horizontal color\n * axis, the width defaults to 200.\n *\n * @sample {highcharts} highcharts/legend/symbolwidth/\n * Greater symbol width and padding\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n *\n * @type {number}\n * @apioption legend.symbolWidth\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the legend item texts.\n *\n * Prior to 4.1.7, when using HTML, [legend.navigation](\n * #legend.navigation) was disabled.\n *\n * @type {boolean}\n * @default false\n * @apioption legend.useHTML\n */\n /**\n * For a color axis with data classes, how many decimals to render in\n * the legend. The default preserves the decimals of the range numbers.\n *\n * @type {number}\n * @default -1\n * @product highcharts highmaps\n * @apioption legend.valueDecimals\n */\n /**\n * For a color axis with data classes, a suffix for the range numbers in\n * the legend.\n *\n * @type {string}\n * @default ''\n * @product highcharts highmaps\n * @apioption legend.valueSuffix\n */\n /**\n * The width of the legend box. If a number is set, it translates to\n * pixels. Since v7.0.2 it allows setting a percent string of the full\n * chart width, for example `40%`.\n *\n * Defaults to the full chart width for legends below or above the\n * chart, half the chart width for legends to the left and right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n * @sample {highcharts} highcharts/legend/width-percent/\n * A percent of the chart width\n *\n * @type {number|string}\n * @since 2.0\n * @apioption legend.width\n */\n /**\n * The pixel padding between the legend item symbol and the legend\n * item text.\n *\n * @sample {highcharts} highcharts/legend/symbolpadding/\n * Greater symbol width and padding\n */\n symbolPadding: 5,\n /**\n * The vertical alignment of the legend box. Can be one of `top`,\n * `middle` or `bottom`. Vertical position can be further determined\n * by the `y` option.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * When the [layout](#legend.layout) option is `proximate`, the\n * `verticalAlign` option doesn't apply.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.0\n */\n verticalAlign: 'bottom',\n // width: undefined,\n /**\n * The x offset of the legend relative to its horizontal alignment\n * `align` within chart.spacingLeft and chart.spacingRight. Negative\n * x moves it to the left, positive x moves it to the right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n *\n * @since 2.0\n */\n x: 0,\n /**\n * The vertical offset of the legend relative to it's vertical alignment\n * `verticalAlign` within chart.spacingTop and chart.spacingBottom.\n * Negative y moves it up, positive y moves it down.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @since 2.0\n */\n y: 0,\n /**\n * A title to be added on top of the legend.\n *\n * @sample {highcharts} highcharts/legend/title/\n * Legend title\n * @sample {highmaps} maps/legend/alignment/\n * Legend with title\n *\n * @since 3.0\n */\n title: {\n /**\n * A text or HTML string for the title.\n *\n * @type {string}\n * @since 3.0\n * @apioption legend.title.text\n */\n /**\n * Generic CSS styles for the legend title.\n *\n * @see In styled mode, the legend title is styled with the\n * `.highcharts-legend-title` class.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontSize\": \"0.75em\", \"fontWeight\": \"bold\"}\n * @since 3.0\n */\n style: {\n /**\n * @ignore\n */\n fontSize: '0.8em',\n /**\n * @ignore\n */\n fontWeight: 'bold'\n }\n }\n },\n /**\n * The loading options control the appearance of the loading screen\n * that covers the plot area on chart operations. This screen only\n * appears after an explicit call to `chart.showLoading()`. It is a\n * utility for developers to communicate to the end user that something\n * is going on, for example while retrieving new data via an XHR connection.\n * The \"Loading...\" text itself is not part of this configuration\n * object, but part of the `lang` object.\n */\n loading: {\n /**\n * The duration in milliseconds of the fade out effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.hideDuration\n */\n /**\n * The duration in milliseconds of the fade in effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.showDuration\n */\n /**\n * CSS styles for the loading label `span`.\n *\n * @see In styled mode, the loading label is styled with the\n * `.highcharts-loading-inner` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/labelstyle/\n * Vertically centered\n * @sample {highstock} stock/loading/general/\n * Label styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontWeight\": \"bold\", \"position\": \"relative\", \"top\": \"45%\"}\n * @since 1.2.0\n */\n labelStyle: {\n /**\n * @ignore\n */\n fontWeight: 'bold',\n /**\n * @ignore\n */\n position: 'relative',\n /**\n * @ignore\n */\n top: '45%'\n },\n /**\n * CSS styles for the loading screen that covers the plot area.\n *\n * In styled mode, the loading label is styled with the\n * `.highcharts-loading` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/style/\n * Gray plot area, white text\n * @sample {highstock} stock/loading/general/\n * Gray plot area, white text\n *\n * @type {Highcharts.CSSObject}\n * @default {\"position\": \"absolute\", \"backgroundColor\": \"#ffffff\", \"opacity\": 0.5, \"textAlign\": \"center\"}\n * @since 1.2.0\n */\n style: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * @ignore\n */\n opacity: 0.5,\n /**\n * @ignore\n */\n textAlign: 'center'\n }\n },\n /**\n * Options for the tooltip that appears when the user hovers over a\n * series or point.\n *\n * @declare Highcharts.TooltipOptions\n */\n tooltip: {\n /**\n * The color of the tooltip border. When `undefined`, the border takes\n * the color of the corresponding series or point.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * Follow series by default\n * @sample {highcharts} highcharts/tooltip/bordercolor-black/\n * Black border\n * @sample {highstock} stock/tooltip/general/\n * Styled tooltip\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption tooltip.borderColor\n */\n /**\n * A CSS class name to apply to the tooltip's container div,\n * allowing unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption tooltip.className\n */\n /**\n * Since 4.1, the crosshair definitions are moved to the Axis object\n * in order for a better separation from the tooltip. See\n * [xAxis.crosshair](#xAxis.crosshair).\n *\n * @sample {highcharts} highcharts/tooltip/crosshairs-x/\n * Enable a crosshair for the x value\n *\n * @deprecated\n *\n * @type {*}\n * @default true\n * @apioption tooltip.crosshairs\n */\n /**\n * Distance from point to tooltip in pixels.\n *\n * @type {number}\n * @default 16\n * @apioption tooltip.distance\n */\n /**\n * Whether the tooltip should follow the mouse as it moves across\n * columns, pie slices and other point types with an extent.\n * By default it behaves this way for pie, polygon, map, sankey\n * and wordcloud series by override in the `plotOptions`\n * for those series types.\n *\n * Does not apply if [split](#tooltip.split) is `true`.\n *\n * For touch moves to behave the same way, [followTouchMove](\n * #tooltip.followTouchMove) must be `true` also.\n *\n * @sample highcharts/tooltip/followpointer/\n * Tooltip follow pointer comparison\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @since 3.0\n * @apioption tooltip.followPointer\n */\n /**\n * Whether the tooltip should update as the finger moves on a touch\n * device. If this is `true` and [chart.panning](#chart.panning) is\n * set,`followTouchMove` will take over one-finger touches, so the user\n * needs to use two fingers for zooming and panning.\n *\n * Note the difference to [followPointer](#tooltip.followPointer) that\n * only defines the _position_ of the tooltip. If `followPointer` is\n * false in for example a column series, the tooltip will show above or\n * below the column, but as `followTouchMove` is true, the tooltip will\n * jump from column to column as the user swipes across the plot area.\n *\n * @type {boolean}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 3.0.1\n * @apioption tooltip.followTouchMove\n */\n /**\n * A [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the whole tooltip. When format strings are a requirement, it is\n * usually more convenient to use `headerFormat`, `pointFormat` and\n * `footerFormat`, but the `format` option allows combining them into\n * one setting.\n *\n * The context of the format string is the same as that of the\n * `formatter` callback.\n *\n * @sample {highcharts} highcharts/tooltip/format-shared/\n * Format for shared tooltip\n *\n * @type {string}\n * @default undefined\n * @since 11.1.0\n * @apioption tooltip.format\n */\n /**\n * Callback function to format the text of the tooltip from scratch. In\n * case of single or [shared](#tooltip.shared) tooltips, a string should\n * be returned. In case of [split](#tooltip.split) tooltips, it should\n * return an array where the first item is the header, and subsequent\n * items are mapped to the points. Return `false` to disable tooltip for\n * a specific point on series.\n *\n * A subset of HTML is supported. Unless `useHTML` is true, the HTML of\n * the tooltip is parsed and converted to SVG, therefore this isn't a\n * complete HTML renderer. The following HTML tags are supported: `b`,\n * `br`, `em`, `i`, `span`, `strong`. Spans can be styled with a `style`\n * attribute, but only text-related CSS, that is shared with SVG, is\n * handled.\n *\n * The available data in the formatter differ a bit depending on whether\n * the tooltip is shared or split, or belongs to a single point. In a\n * shared/split tooltip, all properties except `x`, which is common for\n * all points, are kept in an array, `this.points`.\n *\n * Available data are:\n *\n * - **this.percentage (not shared) /**\n * **this.points[i].percentage (shared)**:\n * Stacked series and pies only. The point's percentage of the total.\n *\n * - **this.point (not shared) / this.points[i].point (shared)**:\n * The point object. The point name, if defined, is available through\n * `this.point.name`.\n *\n * - **this.points**:\n * In a shared tooltip, this is an array containing all other\n * properties for each point.\n *\n * - **this.series (not shared) / this.points[i].series (shared)**:\n * The series object. The series name is available through\n * `this.series.name`.\n *\n * - **this.total (not shared) / this.points[i].total (shared)**:\n * Stacked series only. The total value at this point's x value.\n *\n * - **this.x**:\n * The x value. This property is the same regardless of the tooltip\n * being shared or not.\n *\n * - **this.y (not shared) / this.points[i].y (shared)**:\n * The y value.\n *\n * @sample {highcharts} highcharts/tooltip/formatter-simple/\n * Simple string formatting\n * @sample {highcharts} highcharts/tooltip/formatter-shared/\n * Formatting with shared tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Formatting with split tooltip\n * @sample highcharts/tooltip/formatter-conditional-default/\n * Extending default formatter\n * @sample {highstock} stock/tooltip/formatter/\n * Formatting with shared tooltip\n * @sample {highmaps} maps/tooltip/formatter/\n * String formatting\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.formatter\n */\n /**\n * Callback function to format the text of the tooltip for\n * visible null points.\n * Works analogously to [formatter](#tooltip.formatter).\n *\n * @sample highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.nullFormatter\n */\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (`false`), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area. For small charts, this may result in clipping\n * or overlapping. When `true`, a separate SVG element is created and\n * overlaid on the page, allowing the tooltip to be aligned inside the\n * page itself.\n *\n * Defaults to `true` if `chart.scrollablePlotArea` is activated,\n * otherwise `false`.\n *\n * @sample highcharts/tooltip/outside\n * Small charts with tooltips outside\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 6.1.1\n * @apioption tooltip.outside\n */\n /**\n * A callback function for formatting the HTML output for a single point\n * in the tooltip. Like the `pointFormat` string, but with more\n * flexibility.\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 4.1.0\n * @context Highcharts.Point\n * @apioption tooltip.pointFormatter\n */\n /**\n * A callback function to place the tooltip in a custom position. The\n * callback receives three parameters: `labelWidth`, `labelHeight` and\n * `point`, where point contains values for `plotX` and `plotY` telling\n * where the reference point is in the plot area. Add `chart.plotLeft`\n * and `chart.plotTop` to get the full coordinates.\n *\n * To find the actual hovered `Point` instance, use\n * `this.chart.hoverPoint`. For shared or split tooltips, all the hover\n * points are available in `this.chart.hoverPoints`.\n *\n * Since v7, when [tooltip.split](#tooltip.split) option is enabled,\n * positioner is called for each of the boxes separately, including\n * xAxis header. xAxis header is not a point, instead `point` argument\n * contains info: `{ plotX: Number, plotY: Number, isHeader: Boolean }`\n *\n * The return should be an object containing x and y values, for example\n * `{ x: 100, y: 100 }`.\n *\n * @sample {highcharts} highcharts/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/positioner/\n * A fixed tooltip position on top of the chart\n * @sample {highmaps} maps/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/split-positioner/\n * Split tooltip with fixed positions\n * @sample {highstock} stock/tooltip/positioner-scrollable-plotarea/\n * Scrollable plot area combined with tooltip positioner\n *\n * @type {Highcharts.TooltipPositionerCallbackFunction}\n * @since 2.2.4\n * @apioption tooltip.positioner\n */\n /**\n * Split the tooltip into one label per series, with the header close\n * to the axis. This is recommended over [shared](#tooltip.shared)\n * tooltips for charts with multiple line series, generally making them\n * easier to read. This option takes precedence over `tooltip.shared`.\n *\n * Not supported for [polar](#chart.polar) and [inverted](#chart.inverted) charts.\n *\n * @productdesc {highstock} In Highcharts Stock, tooltips are split\n * by default since v6.0.0. Stock charts typically contain\n * multi-dimension points and multiple panes, making split tooltips\n * the preferred layout over\n * the previous `shared` tooltip.\n *\n * @sample highcharts/tooltip/split/\n * Split tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Split tooltip and custom formatter callback\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} true\n * @since 5.0.0\n * @product highcharts highstock\n * @apioption tooltip.split\n */\n /**\n * Prevents the tooltip from switching or closing, when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @type {boolean}\n * @since 8.0.1\n * @apioption tooltip.stickOnContact\n */\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption tooltip.useHTML\n */\n /**\n * How many decimals to show in each series' y value. This is\n * overridable in each series' tooltip options object. The default is to\n * preserve all decimals.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {number|undefined}\n * @since 2.2\n * @apioption tooltip.valueDecimals\n */\n /**\n * A string to prepend to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valuePrefix\n */\n /**\n * A string to append to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valueSuffix\n */\n /**\n * The format for the date in the tooltip header if the X axis is a\n * datetime axis. The default is a best guess based on the smallest\n * distance between points in the chart.\n *\n * @sample {highcharts} highcharts/tooltip/xdateformat/\n * A different format\n *\n * @type {string}\n * @product highcharts highstock gantt\n * @apioption tooltip.xDateFormat\n */\n /**\n * How many decimals to show for the `point.change`\n * or the `point.cumulativeSum` value when the `series.compare`\n * or the `series.cumulative` option is set.\n * This is overridable in each series' tooltip options object.\n *\n * @type {number}\n * @default 2\n * @since 1.0.1\n * @product highstock\n * @apioption tooltip.changeDecimals\n */\n /**\n * Enable or disable the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/enabled/\n * Disabled\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Disable tooltip and show values on chart instead\n */\n enabled: true,\n /**\n * Enable or disable animation of the tooltip.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n */\n animation: svg,\n /**\n * The radius of the rounded border corners.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * Default border radius\n * @sample {highcharts} highcharts/tooltip/borderradius-0/\n * Square borders\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n */\n borderRadius: 3,\n /**\n * For series on datetime axes, the date format in the tooltip's\n * header will by default be guessed based on the closest data points.\n * This member gives the default string representations used for\n * each unit. For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * @see [xAxis.dateTimeLabelFormats](#xAxis.dateTimeLabelFormats)\n *\n * @type {Highcharts.Dictionary}\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /** @internal */\n millisecond: '%A, %e %b, %H:%M:%S.%L',\n /** @internal */\n second: '%A, %e %b, %H:%M:%S',\n /** @internal */\n minute: '%A, %e %b, %H:%M',\n /** @internal */\n hour: '%A, %e %b, %H:%M',\n /** @internal */\n day: '%A, %e %b %Y',\n /** @internal */\n week: 'Week from %A, %e %b %Y',\n /** @internal */\n month: '%B %Y',\n /** @internal */\n year: '%Y'\n },\n /**\n * A string to append to the tooltip format.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @since 2.2\n */\n footerFormat: '',\n /**\n * The name of a symbol to use for the border around the tooltip\n * header. Applies only when [tooltip.split](#tooltip.split) is\n * enabled.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @see [tooltip.shape](#tooltip.shape)\n *\n * @sample {highstock} stock/tooltip/split-positioner/\n * Different shapes for header and split boxes\n *\n * @type {Highcharts.TooltipShapeValue}\n * @validvalue [\"callout\", \"square\"]\n * @since 7.0\n */\n headerShape: 'callout',\n /**\n * The number of milliseconds to wait until the tooltip is hidden when\n * mouse out from a point or chart.\n *\n * @since 3.0\n */\n hideDelay: 500,\n /**\n * Padding inside the tooltip, in pixels.\n *\n * @since 5.0.0\n */\n padding: 8,\n /**\n * The name of a symbol to use for the border around the tooltip. Can\n * be one of: `\"callout\"`, `\"circle\"` or `\"rect\"`. When\n * [tooltip.split](#tooltip.split)\n * option is enabled, shape is applied to all boxes except header, which\n * is controlled by\n * [tooltip.headerShape](#tooltip.headerShape).\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @type {Highcharts.TooltipShapeValue}\n * @since 4.0\n */\n shape: 'callout',\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events. Tooltip texts for series types with ordered\n * data (not pie, scatter, flags etc) will be shown in a single bubble.\n * This is recommended for single series charts and for tablet/mobile\n * optimized charts.\n *\n * See also [tooltip.split](#tooltip.split), that is better suited for\n * charts with many series, especially line-type series. The\n * `tooltip.split` option takes precedence over `tooltip.shared`.\n *\n * @sample {highcharts} highcharts/tooltip/shared-false/\n * False by default\n * @sample {highcharts} highcharts/tooltip/shared-true/\n * True\n * @sample {highcharts} highcharts/tooltip/shared-x-crosshair/\n * True with x axis crosshair\n * @sample {highcharts} highcharts/tooltip/shared-true-mixed-types/\n * True with mixed series types\n *\n * @since 2.1\n * @product highcharts highstock\n */\n shared: false,\n /**\n * Proximity snap for graphs or single points. It defaults to 10 for\n * mouse-powered devices and 25 for touch devices.\n *\n * Note that in most cases the whole plot area captures the mouse\n * movement, and in these cases `tooltip.snap` doesn't make sense. This\n * applies when [stickyTracking](#plotOptions.series.stickyTracking)\n * is `true` (default) and when the tooltip is [shared](#tooltip.shared)\n * or [split](#tooltip.split).\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 10 px by default\n * @sample {highcharts} highcharts/tooltip/snap-50/\n * 50 px on graph\n *\n * @type {number}\n * @default 10/25\n * @since 1.2.0\n * @product highcharts highstock\n */\n snap: isTouchDevice ? 25 : 10,\n /**\n * The HTML of the tooltip header line. Variables are enclosed by\n * curly brackets. Available variables are `point.key`, `series.name`,\n * `series.color` and other members from the `point` and `series`\n * objects. The `point.key` variable contains the category name, x\n * value or datetime string depending on the type of axis. For datetime\n * axes, the `point.key` date format can be set using\n * `tooltip.xDateFormat`.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highstock} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @apioption tooltip.headerFormat\n */\n headerFormat: '{point.key}
',\n /**\n * The HTML of the null point's line in the tooltip. Works analogously\n * to [pointFormat](#tooltip.pointFormat).\n *\n * @sample {highcharts} highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {string}\n * @apioption tooltip.nullFormat\n */\n /**\n * The HTML of the point's line in the tooltip. Variables are enclosed\n * by curly brackets. Available variables are `point.x`, `point.y`,\n * `series.name` and `series.color` and other properties on the same\n * form. Furthermore, `point.y` can be extended by the\n * `tooltip.valuePrefix` and `tooltip.valueSuffix` variables. This can\n * also be overridden for each series, which makes it a good hook for\n * displaying units.\n *\n * In styled mode, the dot is colored by a class name rather\n * than the point color.\n *\n * @sample {highcharts} highcharts/tooltip/pointformat/\n * A different point format with value suffix\n * @sample {highcharts|highstock} highcharts/tooltip/pointformat-extra-information/\n * Show extra information about points in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.pointFormat\n */\n pointFormat: '\\u25CF {series.name}: {point.y}
',\n /**\n * The background color or gradient for the tooltip.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-solid/\n * Yellowish background\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-gradient/\n * Gradient\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The pixel width of the tooltip border. Defaults to 0 for single\n * tooltips and 1 for split tooltips.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 2 pixels\n * @sample {highcharts} highcharts/tooltip/borderwidth/\n * No border (shadow only)\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n *\n * @type {number}\n */\n borderWidth: void 0,\n /**\n * Whether to apply a drop shadow to the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * True by default\n * @sample {highcharts} highcharts/tooltip/shadow/\n * False\n * @sample {highmaps} maps/tooltip/positioner/\n * Fixed tooltip position, border and shadow disabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n */\n shadow: true,\n /**\n * Prevents the tooltip from switching or closing when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @since 8.0.1\n */\n stickOnContact: false,\n /**\n * CSS styles for the tooltip. The tooltip can also be styled through\n * the CSS class `.highcharts-tooltip`.\n *\n * Note that the default `pointerEvents` style makes the tooltip ignore\n * mouse events, so in order to use clickable tooltips, this value must\n * be set to `auto`.\n *\n * @sample {highcharts} highcharts/tooltip/style/\n * Greater padding, bold text\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '0.8em'\n },\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @since 2.2\n */\n useHTML: false\n },\n /**\n * Highchart by default puts a credits label in the lower right corner\n * of the chart. This can be changed using these options.\n */\n credits: {\n /**\n * Credits for map source to be concatenated with conventional credit\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapTextFull](#credits.mapTextFull)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default \\u00a9 {geojson.copyrightShort}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapText\n */\n /**\n * Detailed credits for map source to be displayed on hover of credits\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapText](#credits.mapText)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default {geojson.copyright}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapTextFull\n */\n /**\n * Whether to show the credits text.\n *\n * @sample {highcharts} highcharts/credits/enabled-false/\n * Credits disabled\n * @sample {highstock} stock/credits/enabled/\n * Credits disabled\n * @sample {highmaps} maps/credits/enabled-false/\n * Credits disabled\n */\n enabled: true,\n /**\n * The URL for the credits label.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n href: 'https://www.highcharts.com?credits',\n /**\n * Position configuration for the credits label.\n *\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n *\n * @type {Highcharts.AlignObject}\n * @since 2.1\n */\n position: {\n /** @internal */\n align: 'right',\n /** @internal */\n x: -10,\n /** @internal */\n verticalAlign: 'bottom',\n /** @internal */\n y: -5\n },\n /**\n * CSS styles for the credits label.\n *\n * @see In styled mode, credits styles can be set with the\n * `.highcharts-credits` class.\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n cursor: 'pointer',\n /** @internal */\n color: \"#999999\" /* Palette.neutralColor40 */,\n /** @internal */\n fontSize: '0.6em'\n },\n /**\n * The text for the credits label.\n *\n * @productdesc {highmaps}\n * If a map is loaded as GeoJSON, the text defaults to\n * `Highcharts @ {map-credits}`. Otherwise, it defaults to\n * `Highcharts.com`.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n text: 'Highcharts.com'\n }\n };\n /* eslint-disable spaced-comment */\n\n defaultOptions.chart.styledMode = false;\n\n '';\n const defaultTime = new Time(defaultOptions.time);\n /**\n * Get the updated default options. Until 3.0.7, merely exposing defaultOptions\n * for outside modules wasn't enough because the setOptions method created a new\n * object.\n *\n * @function Highcharts.getOptions\n *\n * @return {Highcharts.Options}\n * Default options.\n */\n function getOptions() {\n return defaultOptions;\n }\n /**\n * Merge the default options with custom options and return the new options\n * structure. Commonly used for defining reusable templates.\n *\n * @sample highcharts/global/useutc-false Setting a global option\n * @sample highcharts/members/setoptions Applying a global theme\n *\n * @function Highcharts.setOptions\n *\n * @param {Highcharts.Options} options\n * The new custom chart options.\n *\n * @return {Highcharts.Options}\n * Updated options.\n */\n function setOptions(options) {\n // Copy in the default options\n merge(true, defaultOptions, options);\n // Update the time object\n if (options.time || options.global) {\n if (H.time) {\n H.time.update(merge(defaultOptions.global, defaultOptions.time, options.global, options.time));\n }\n else {\n /**\n * Global `Time` object with default options. Since v6.0.5, time\n * settings can be applied individually for each chart. If no\n * individual settings apply, this `Time` object is shared by all\n * instances.\n *\n * @name Highcharts.time\n * @type {Highcharts.Time}\n */\n H.time = defaultTime;\n }\n }\n return defaultOptions;\n }\n /* *\n *\n * Default Export\n *\n * */\n const DefaultOptions = {\n defaultOptions,\n defaultTime,\n getOptions,\n setOptions\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"plotBox\"|\"spacingBox\"} Highcharts.ButtonRelativeToValue\n */\n /**\n * Gets fired when a series is added to the chart after load time, using the\n * `addSeries` method. Returning `false` prevents the series from being added.\n *\n * @callback Highcharts.ChartAddSeriesCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.ChartAddSeriesEventObject} event\n * The event that occured.\n */\n /**\n * Contains common event information. Through the `options` property you can\n * access the series options that were passed to the `addSeries` method.\n *\n * @interface Highcharts.ChartAddSeriesEventObject\n */ /**\n * The series options that were passed to the `addSeries` method.\n * @name Highcharts.ChartAddSeriesEventObject#options\n * @type {Highcharts.SeriesOptionsType}\n */ /**\n * Prevents the default behaviour of the event.\n * @name Highcharts.ChartAddSeriesEventObject#preventDefault\n * @type {Function}\n */ /**\n * The event target.\n * @name Highcharts.ChartAddSeriesEventObject#target\n * @type {Highcharts.Chart}\n */ /**\n * The event type.\n * @name Highcharts.ChartAddSeriesEventObject#type\n * @type {\"addSeries\"}\n */\n /**\n * Gets fired when clicking on the plot background.\n *\n * @callback Highcharts.ChartClickCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.PointerEventObject} event\n * The event that occured.\n */\n /**\n * Contains an axes of the clicked spot.\n *\n * @interface Highcharts.ChartClickEventAxisObject\n */ /**\n * Axis at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#value\n * @type {number}\n */\n /**\n * Contains information about the clicked spot on the chart. Remember the unit\n * of a datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.ChartClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Information about the x-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#xAxis\n * @type {Array}\n */ /**\n * Information about the y-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#yAxis\n * @type {Array}\n */ /**\n * Information about the z-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#zAxis\n * @type {Array|undefined}\n */\n /**\n * Gets fired when the chart is finished loading.\n *\n * @callback Highcharts.ChartLoadCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Fires when the chart is redrawn, either after a call to `chart.redraw()` or\n * after an axis, series or point is modified with the `redraw` option set to\n * `true`.\n *\n * @callback Highcharts.ChartRedrawCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired after initial load of the chart (directly after the `load` event),\n * and after each redraw (directly after the `redraw` event).\n *\n * @callback Highcharts.ChartRenderCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired when an area of the chart has been selected. The default action\n * for the selection event is to zoom the chart to the selected area. It can be\n * prevented by calling `event.preventDefault()` or return false.\n *\n * @callback Highcharts.ChartSelectionCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.SelectEventObject} event\n * Event informations\n *\n * @return {boolean|undefined}\n * Return false to prevent the default action, usually zoom.\n */\n (''); // detach doclets above\n\n return DefaultOptions;\n });\n _registerModule(_modules, 'Core/Animation/Fx.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { win } = H;\n const { isNumber, objectEach } = U;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * An animator object used internally. One instance applies to one property\n * (attribute or style prop) on one element. Animation is always initiated\n * through {@link SVGElement#animate}.\n *\n * @example\n * let rect = renderer.rect(0, 0, 10, 10).add();\n * rect.animate({ width: 100 });\n *\n * @private\n * @class\n * @name Highcharts.Fx\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} elem\n * The element to animate.\n *\n * @param {Partial} options\n * Animation options.\n *\n * @param {string} prop\n * The single attribute or CSS property to animate.\n */\n class Fx {\n /* *\n *\n * Constructors\n *\n * */\n constructor(elem, options, prop) {\n this.pos = NaN;\n this.options = options;\n this.elem = elem;\n this.prop = prop;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the current step of a path definition on SVGElement.\n *\n * @function Highcharts.Fx#dSetter\n *\n */\n dSetter() {\n const paths = this.paths, start = paths && paths[0], end = paths && paths[1], now = this.now || 0;\n let path = [];\n // Land on the final path without adjustment points appended in the ends\n if (now === 1 || !start || !end) {\n path = this.toD || [];\n }\n else if (start.length === end.length && now < 1) {\n for (let i = 0; i < end.length; i++) {\n // Tween between the start segment and the end segment. Start\n // with a copy of the end segment and tween the appropriate\n // numerics\n const startSeg = start[i];\n const endSeg = end[i];\n const tweenSeg = [];\n for (let j = 0; j < endSeg.length; j++) {\n const startItem = startSeg[j];\n const endItem = endSeg[j];\n // Tween numbers\n if (isNumber(startItem) &&\n isNumber(endItem) &&\n // Arc boolean flags\n !(endSeg[0] === 'A' && (j === 4 || j === 5))) {\n tweenSeg[j] = startItem + now * (endItem - startItem);\n // Strings, take directly from the end segment\n }\n else {\n tweenSeg[j] = endItem;\n }\n }\n path.push(tweenSeg);\n }\n // If animation is finished or length not matching, land on right value\n }\n else {\n path = end;\n }\n this.elem.attr('d', path, void 0, true);\n }\n /**\n * Update the element with the current animation step.\n *\n * @function Highcharts.Fx#update\n *\n */\n update() {\n const elem = this.elem, prop = this.prop, // if destroyed, it is null\n now = this.now, step = this.options.step;\n // Animation setter defined from outside\n if (this[prop + 'Setter']) {\n this[prop + 'Setter']();\n // Other animations on SVGElement\n }\n else if (elem.attr) {\n if (elem.element) {\n elem.attr(prop, now, null, true);\n }\n // HTML styles, raw HTML content like container size\n }\n else {\n elem.style[prop] = now + this.unit;\n }\n if (step) {\n step.call(elem, now, this);\n }\n }\n /**\n * Run an animation.\n *\n * @function Highcharts.Fx#run\n *\n * @param {number} from\n * The current value, value to start from.\n *\n * @param {number} to\n * The end value, value to land on.\n *\n * @param {string} unit\n * The property unit, for example `px`.\n *\n */\n run(from, to, unit) {\n const self = this, options = self.options, timer = function (gotoEnd) {\n return timer.stopped ? false : self.step(gotoEnd);\n }, requestAnimationFrame = win.requestAnimationFrame ||\n function (step) {\n setTimeout(step, 13);\n }, step = function () {\n for (let i = 0; i < Fx.timers.length; i++) {\n if (!Fx.timers[i]()) {\n Fx.timers.splice(i--, 1);\n }\n }\n if (Fx.timers.length) {\n requestAnimationFrame(step);\n }\n };\n if (from === to && !this.elem['forceAnimate:' + this.prop]) {\n delete options.curAnim[this.prop];\n if (options.complete &&\n Object.keys(options.curAnim).length === 0) {\n options.complete.call(this.elem);\n }\n }\n else { // #7166\n this.startTime = +new Date();\n this.start = from;\n this.end = to;\n this.unit = unit;\n this.now = this.start;\n this.pos = 0;\n timer.elem = this.elem;\n timer.prop = this.prop;\n if (timer() && Fx.timers.push(timer) === 1) {\n requestAnimationFrame(step);\n }\n }\n }\n /**\n * Run a single step in the animation.\n *\n * @function Highcharts.Fx#step\n *\n * @param {boolean} [gotoEnd]\n * Whether to go to the endpoint of the animation after abort.\n *\n * @return {boolean}\n * Returns `true` if animation continues.\n */\n step(gotoEnd) {\n const t = +new Date(), options = this.options, elem = this.elem, complete = options.complete, duration = options.duration, curAnim = options.curAnim;\n let ret, done;\n if ((elem.attr) && !elem.element) { // #2616, element is destroyed\n ret = false;\n }\n else if (gotoEnd || t >= duration + this.startTime) {\n this.now = this.end;\n this.pos = 1;\n this.update();\n curAnim[this.prop] = true;\n done = true;\n objectEach(curAnim, function (val) {\n if (val !== true) {\n done = false;\n }\n });\n if (done && complete) {\n complete.call(elem);\n }\n ret = false;\n }\n else {\n this.pos = options.easing((t - this.startTime) / duration);\n this.now = this.start + ((this.end -\n this.start) * this.pos);\n this.update();\n ret = true;\n }\n return ret;\n }\n /**\n * Prepare start and end values so that the path can be animated one to one.\n *\n * @function Highcharts.Fx#initPath\n *\n * @param {Highcharts.SVGElement} elem\n * The SVGElement item.\n *\n * @param {Highcharts.SVGPathArray|undefined} fromD\n * Starting path definition.\n *\n * @param {Highcharts.SVGPathArray} toD\n * Ending path definition.\n *\n * @return {Array}\n * An array containing start and end paths in array form so that\n * they can be animated in parallel.\n */\n initPath(elem, fromD, toD) {\n const startX = elem.startX, endX = elem.endX, end = toD.slice(), // copy\n isArea = elem.isArea, positionFactor = isArea ? 2 : 1;\n let shift, fullLength, i, reverse, start = fromD && fromD.slice(); // copy\n if (!start) {\n return [end, end];\n }\n /**\n * If shifting points, prepend a dummy point to the end path.\n * @private\n */\n function prepend(arr, other) {\n while (arr.length < fullLength) {\n // Move to, line to or curve to?\n const moveSegment = arr[0], otherSegment = other[fullLength - arr.length];\n if (otherSegment && moveSegment[0] === 'M') {\n if (otherSegment[0] === 'C') {\n arr[0] = [\n 'C',\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2]\n ];\n }\n else {\n arr[0] = ['L', moveSegment[1], moveSegment[2]];\n }\n }\n // Prepend a copy of the first point\n arr.unshift(moveSegment);\n // For areas, the bottom path goes back again to the left, so we\n // need to append a copy of the last point.\n if (isArea) {\n const z = arr.pop();\n arr.push(arr[arr.length - 1], z); // append point and the Z\n }\n }\n }\n /**\n * Copy and append last point until the length matches the end length.\n * @private\n */\n function append(arr, other) {\n while (arr.length < fullLength) {\n // Pull out the slice that is going to be appended or inserted.\n // In a line graph, the positionFactor is 1, and the last point\n // is sliced out. In an area graph, the positionFactor is 2,\n // causing the middle two points to be sliced out, since an area\n // path starts at left, follows the upper path then turns and\n // follows the bottom back.\n const segmentToAdd = arr[Math.floor(arr.length / positionFactor) - 1].slice();\n // Disable the first control point of curve segments\n if (segmentToAdd[0] === 'C') {\n segmentToAdd[1] = segmentToAdd[5];\n segmentToAdd[2] = segmentToAdd[6];\n }\n if (!isArea) {\n arr.push(segmentToAdd);\n }\n else {\n const lowerSegmentToAdd = arr[Math.floor(arr.length / positionFactor)].slice();\n arr.splice(arr.length / 2, 0, segmentToAdd, lowerSegmentToAdd);\n }\n }\n }\n // For sideways animation, find out how much we need to shift to get the\n // start path Xs to match the end path Xs.\n if (startX && endX && endX.length) {\n for (i = 0; i < startX.length; i++) {\n // Moving left, new points coming in on right\n if (startX[i] === endX[0]) {\n shift = i;\n break;\n // Moving right\n }\n else if (startX[0] ===\n endX[endX.length - startX.length + i]) {\n shift = i;\n reverse = true;\n break;\n // Fixed from the right side, \"scaling\" left\n }\n else if (startX[startX.length - 1] ===\n endX[endX.length - startX.length + i]) {\n shift = startX.length - i;\n break;\n }\n }\n if (typeof shift === 'undefined') {\n start = [];\n }\n }\n if (start.length && isNumber(shift)) {\n // The common target length for the start and end array, where both\n // arrays are padded in opposite ends\n fullLength = end.length + shift * positionFactor;\n if (!reverse) {\n prepend(end, start);\n append(start, end);\n }\n else {\n prepend(start, end);\n append(end, start);\n }\n }\n return [start, end];\n }\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#fillSetter\n *\n */\n fillSetter() {\n Fx.prototype.strokeSetter.apply(this, arguments);\n }\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#strokeSetter\n *\n */\n strokeSetter() {\n this.elem.attr(this.prop, color(this.start).tweenTo(color(this.end), this.pos), void 0, true);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Fx.timers = [];\n /* *\n *\n * Default Export\n *\n * */\n\n return Fx;\n });\n _registerModule(_modules, 'Core/Animation/AnimationUtilities.js', [_modules['Core/Animation/Fx.js'], _modules['Core/Utilities.js']], function (Fx, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, getStyle, isArray, isNumber, isObject, merge, objectEach, pick } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the global animation to either a given value, or fall back to the given\n * chart's animation option.\n *\n * @function Highcharts.setAnimation\n *\n * @param {boolean|Partial|undefined} animation\n * The animation object.\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @todo\n * This function always relates to a chart, and sets a property on the renderer,\n * so it should be moved to the SVGRenderer.\n */\n function setAnimation(animation, chart) {\n chart.renderer.globalAnimation = pick(animation, chart.options.chart.animation, true);\n }\n /**\n * Get the animation in object form, where a disabled animation is always\n * returned as `{ duration: 0 }`.\n *\n * @function Highcharts.animObject\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} [animation=0]\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @return {Highcharts.AnimationOptionsObject}\n * An object with at least a duration property.\n */\n function animObject(animation) {\n return isObject(animation) ?\n merge({ duration: 500, defer: 0 }, animation) :\n { duration: animation ? 500 : 0, defer: 0 };\n }\n /**\n * Get the defer as a number value from series animation options.\n *\n * @function Highcharts.getDeferredAnimation\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} animation\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @param {Highcharts.Series} [series]\n * Series to defer animation.\n *\n * @return {number}\n * The numeric value.\n */\n function getDeferredAnimation(chart, animation, series) {\n const labelAnimation = animObject(animation), s = series ? [series] : chart.series;\n let defer = 0, duration = 0;\n s.forEach((series) => {\n const seriesAnim = animObject(series.options.animation);\n defer = animation && defined(animation.defer) ?\n labelAnimation.defer :\n Math.max(defer, seriesAnim.duration + seriesAnim.defer);\n duration = Math.min(labelAnimation.duration, seriesAnim.duration);\n });\n // Disable defer for exporting\n if (chart.renderer.forExport) {\n defer = 0;\n }\n const anim = {\n defer: Math.max(0, defer - duration),\n duration: Math.min(defer, duration)\n };\n return anim;\n }\n /**\n * The global animate method, which uses Fx to create individual animators.\n *\n * @function Highcharts.animate\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} el\n * The element to animate.\n *\n * @param {Highcharts.CSSObject|Highcharts.SVGAttributes} params\n * An object containing key-value pairs of the properties to animate.\n * Supports numeric as pixel-based CSS properties for HTML objects and\n * attributes for SVGElements.\n *\n * @param {Partial} [opt]\n * Animation options.\n *\n * @return {void}\n */\n function animate(el, params, opt) {\n let start, unit = '', end, fx, args;\n if (!isObject(opt)) { // Number or undefined/null\n args = arguments;\n opt = {\n duration: args[2],\n easing: args[3],\n complete: args[4]\n };\n }\n if (!isNumber(opt.duration)) {\n opt.duration = 400;\n }\n opt.easing = typeof opt.easing === 'function' ?\n opt.easing :\n (Math[opt.easing] || Math.easeInOutSine);\n opt.curAnim = merge(params);\n objectEach(params, function (val, prop) {\n // Stop current running animation of this property\n stop(el, prop);\n fx = new Fx(el, opt, prop);\n end = void 0;\n if (prop === 'd' && isArray(params.d)) {\n fx.paths = fx.initPath(el, el.pathArray, params.d);\n fx.toD = params.d;\n start = 0;\n end = 1;\n }\n else if (el.attr) {\n start = el.attr(prop);\n }\n else {\n start = parseFloat(getStyle(el, prop)) || 0;\n if (prop !== 'opacity') {\n unit = 'px';\n }\n }\n if (!end) {\n end = val;\n }\n if (typeof end === 'string' && end.match('px')) {\n end = end.replace(/px/g, ''); // #4351\n }\n fx.run(start, end, unit);\n });\n }\n /**\n * Stop running animation.\n *\n * @function Highcharts.stop\n *\n * @param {Highcharts.SVGElement} el\n * The SVGElement to stop animation on.\n *\n * @param {string} [prop]\n * The property to stop animating. If given, the stop method will stop a\n * single property from animating, while others continue.\n *\n * @return {void}\n *\n * @todo\n * A possible extension to this would be to stop a single property, when\n * we want to continue animating others. Then assign the prop to the timer\n * in the Fx.run method, and check for the prop here. This would be an\n * improvement in all cases where we stop the animation from .attr. Instead of\n * stopping everything, we can just stop the actual attributes we're setting.\n */\n function stop(el, prop) {\n let i = Fx.timers.length;\n // Remove timers related to this element (#4519)\n while (i--) {\n if (Fx.timers[i].elem === el && (!prop || prop === Fx.timers[i].prop)) {\n Fx.timers[i].stopped = true; // #4667\n }\n }\n }\n const animationExports = {\n animate,\n animObject,\n getDeferredAnimation,\n setAnimation,\n stop\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return animationExports;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/AST.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { SVG_NS, win } = H;\n const { attr, createElement, css, error, isFunction, isString, objectEach, splat } = U;\n const { trustedTypes } = win;\n /* *\n *\n * Constants\n *\n * */\n // Create the trusted type policy. This should not be exposed.\n const trustedTypesPolicy = (trustedTypes &&\n isFunction(trustedTypes.createPolicy) &&\n trustedTypes.createPolicy('highcharts', {\n createHTML: (s) => s\n }));\n const emptyHTML = trustedTypesPolicy ?\n trustedTypesPolicy.createHTML('') :\n '';\n // IE9 and PhantomJS are only able to parse XML.\n const hasValidDOMParser = (function () {\n try {\n return Boolean(new DOMParser().parseFromString(emptyHTML, 'text/html'));\n }\n catch (e) {\n return false;\n }\n }());\n /* *\n *\n * Class\n *\n * */\n /**\n * The AST class represents an abstract syntax tree of HTML or SVG content. It\n * can take HTML as an argument, parse it, optionally transform it to SVG, then\n * perform sanitation before inserting it into the DOM.\n *\n * @class\n * @name Highcharts.AST\n *\n * @param {string|Array} source\n * Either an HTML string or an ASTNode list to populate the tree.\n */\n class AST {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Filter an object of SVG or HTML attributes against the allow list.\n *\n * @static\n *\n * @function Highcharts.AST#filterUserAttributes\n *\n * @param {Highcharts.SVGAttributes} attributes The attributes to filter\n *\n * @return {Highcharts.SVGAttributes}\n * The filtered attributes\n */\n static filterUserAttributes(attributes) {\n objectEach(attributes, (val, key) => {\n let valid = true;\n if (AST.allowedAttributes.indexOf(key) === -1) {\n valid = false;\n }\n if (['background', 'dynsrc', 'href', 'lowsrc', 'src']\n .indexOf(key) !== -1) {\n valid = isString(val) && AST.allowedReferences.some((ref) => val.indexOf(ref) === 0);\n }\n if (!valid) {\n error(33, false, void 0, {\n 'Invalid attribute in config': `${key}`\n });\n delete attributes[key];\n }\n // #17753, < is not allowed in SVG attributes\n if (isString(val) && attributes[key]) {\n attributes[key] = val.replace(/ {\n const pair = line.split(':').map((s) => s.trim()), key = pair.shift();\n if (key && pair.length) {\n styles[key.replace(/-([a-z])/g, (g) => g[1].toUpperCase())] = pair.join(':'); // #17146\n }\n return styles;\n }, {});\n }\n /**\n * Utility function to set html content for an element by passing in a\n * markup string. The markup is safely parsed by the AST class to avoid\n * XSS vulnerabilities. This function should be used instead of setting\n * `innerHTML` in all cases where the content is not fully trusted.\n *\n * @static\n * @function Highcharts.AST#setElementHTML\n *\n * @param {SVGDOMElement|HTMLDOMElement} el\n * Node to set content of.\n *\n * @param {string} html\n * Markup string\n */\n static setElementHTML(el, html) {\n el.innerHTML = AST.emptyHTML; // Clear previous\n if (html) {\n const ast = new AST(html);\n ast.addToDOM(el);\n }\n }\n /* *\n *\n * Constructor\n *\n * */\n // Construct an AST from HTML markup, or wrap an array of existing AST nodes\n constructor(source) {\n this.nodes = typeof source === 'string' ?\n this.parseMarkup(source) : source;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add the tree defined as a hierarchical JS structure to the DOM\n *\n * @function Highcharts.AST#addToDOM\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} parent\n * The node where it should be added\n *\n * @return {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement}\n * The inserted node.\n */\n addToDOM(parent) {\n /**\n * @private\n * @param {Highcharts.ASTNode} subtree\n * HTML/SVG definition\n * @param {Element} [subParent]\n * parent node\n * @return {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n * The inserted node.\n */\n function recurse(subtree, subParent) {\n let ret;\n splat(subtree).forEach(function (item) {\n const tagName = item.tagName;\n const textNode = item.textContent ?\n H.doc.createTextNode(item.textContent) :\n void 0;\n // Whether to ignore the AST filtering totally, #15345\n const bypassHTMLFiltering = AST.bypassHTMLFiltering;\n let node;\n if (tagName) {\n if (tagName === '#text') {\n node = textNode;\n }\n else if (AST.allowedTags.indexOf(tagName) !== -1 ||\n bypassHTMLFiltering) {\n const NS = tagName === 'svg' ?\n SVG_NS :\n (subParent.namespaceURI || SVG_NS);\n const element = H.doc.createElementNS(NS, tagName);\n const attributes = item.attributes || {};\n // Apply attributes from root of AST node, legacy from\n // from before TextBuilder\n objectEach(item, function (val, key) {\n if (key !== 'tagName' &&\n key !== 'attributes' &&\n key !== 'children' &&\n key !== 'style' &&\n key !== 'textContent') {\n attributes[key] = val;\n }\n });\n attr(element, bypassHTMLFiltering ?\n attributes :\n AST.filterUserAttributes(attributes));\n if (item.style) {\n css(element, item.style);\n }\n // Add text content\n if (textNode) {\n element.appendChild(textNode);\n }\n // Recurse\n recurse(item.children || [], element);\n node = element;\n }\n else {\n error(33, false, void 0, {\n 'Invalid tagName in config': tagName\n });\n }\n }\n // Add to the tree\n if (node) {\n subParent.appendChild(node);\n }\n ret = node;\n });\n // Return last node added (on top level it's the only one)\n return ret;\n }\n return recurse(this.nodes, parent);\n }\n /**\n * Parse HTML/SVG markup into AST Node objects. Used internally from the\n * constructor.\n *\n * @private\n *\n * @function Highcharts.AST#getNodesFromMarkup\n *\n * @param {string} markup The markup string.\n *\n * @return {Array} The parsed nodes.\n */\n parseMarkup(markup) {\n const nodes = [];\n markup = markup\n .trim()\n // The style attribute throws a warning when parsing when CSP is\n // enabled (#6884), so use an alias and pick it up below\n // Make all quotation marks parse correctly to DOM (#17627)\n .replace(/ style=([\"'])/g, ' data-style=$1');\n let doc;\n if (hasValidDOMParser) {\n doc = new DOMParser().parseFromString(trustedTypesPolicy ?\n trustedTypesPolicy.createHTML(markup) :\n markup, 'text/html');\n }\n else {\n const body = createElement('div');\n body.innerHTML = markup;\n doc = { body };\n }\n const appendChildNodes = (node, addTo) => {\n const tagName = node.nodeName.toLowerCase();\n // Add allowed tags\n const astNode = {\n tagName\n };\n if (tagName === '#text') {\n astNode.textContent = node.textContent || '';\n }\n const parsedAttributes = node.attributes;\n // Add attributes\n if (parsedAttributes) {\n const attributes = {};\n [].forEach.call(parsedAttributes, (attrib) => {\n if (attrib.name === 'data-style') {\n astNode.style = AST.parseStyle(attrib.value);\n }\n else {\n attributes[attrib.name] = attrib.value;\n }\n });\n astNode.attributes = attributes;\n }\n // Handle children\n if (node.childNodes.length) {\n const children = [];\n [].forEach.call(node.childNodes, (childNode) => {\n appendChildNodes(childNode, children);\n });\n if (children.length) {\n astNode.children = children;\n }\n }\n addTo.push(astNode);\n };\n [].forEach.call(doc.body.childNodes, (childNode) => appendChildNodes(childNode, nodes));\n return nodes;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * The list of allowed SVG or HTML attributes, used for sanitizing\n * potentially harmful content from the chart configuration before adding to\n * the DOM.\n *\n * @see [Source code with default values](\n * https://github.com/highcharts/highcharts/blob/master/ts/Core/Renderer/HTML/AST.ts#:~:text=public%20static%20allowedAttributes)\n *\n * @example\n * // Allow a custom, trusted attribute\n * Highcharts.AST.allowedAttributes.push('data-value');\n *\n * @name Highcharts.AST.allowedAttributes\n * @type {Array}\n */\n AST.allowedAttributes = [\n 'alt',\n 'aria-controls',\n 'aria-describedby',\n 'aria-expanded',\n 'aria-haspopup',\n 'aria-hidden',\n 'aria-label',\n 'aria-labelledby',\n 'aria-live',\n 'aria-pressed',\n 'aria-readonly',\n 'aria-roledescription',\n 'aria-selected',\n 'class',\n 'clip-path',\n 'color',\n 'colspan',\n 'cx',\n 'cy',\n 'd',\n 'dx',\n 'dy',\n 'disabled',\n 'fill',\n 'flood-color',\n 'flood-opacity',\n 'height',\n 'href',\n 'id',\n 'in',\n 'markerHeight',\n 'markerWidth',\n 'offset',\n 'opacity',\n 'orient',\n 'padding',\n 'paddingLeft',\n 'paddingRight',\n 'patternUnits',\n 'r',\n 'refX',\n 'refY',\n 'role',\n 'scope',\n 'slope',\n 'src',\n 'startOffset',\n 'stdDeviation',\n 'stroke',\n 'stroke-linecap',\n 'stroke-width',\n 'style',\n 'tableValues',\n 'result',\n 'rowspan',\n 'summary',\n 'target',\n 'tabindex',\n 'text-align',\n 'text-anchor',\n 'textAnchor',\n 'textLength',\n 'title',\n 'type',\n 'valign',\n 'width',\n 'x',\n 'x1',\n 'x2',\n 'xlink:href',\n 'y',\n 'y1',\n 'y2',\n 'zIndex'\n ];\n /**\n * The list of allowed references for referring attributes like `href` and\n * `src`. Attribute values will only be allowed if they start with one of\n * these strings.\n *\n * @see [Source code with default values](\n * https://github.com/highcharts/highcharts/blob/master/ts/Core/Renderer/HTML/AST.ts#:~:text=public%20static%20allowedReferences)\n *\n * @example\n * // Allow tel:\n * Highcharts.AST.allowedReferences.push('tel:');\n *\n * @name Highcharts.AST.allowedReferences\n * @type {Array}\n */\n AST.allowedReferences = [\n 'https://',\n 'http://',\n 'mailto:',\n '/',\n '../',\n './',\n '#'\n ];\n /**\n * The list of allowed SVG or HTML tags, used for sanitizing potentially\n * harmful content from the chart configuration before adding to the DOM.\n *\n * @see [Source code with default values](\n * https://github.com/highcharts/highcharts/blob/master/ts/Core/Renderer/HTML/AST.ts#:~:text=public%20static%20allowedTags)\n *\n * @example\n * // Allow a custom, trusted tag\n * Highcharts.AST.allowedTags.push('blink'); // ;)\n *\n * @name Highcharts.AST.allowedTags\n * @type {Array}\n */\n AST.allowedTags = [\n 'a',\n 'abbr',\n 'b',\n 'br',\n 'button',\n 'caption',\n 'circle',\n 'clipPath',\n 'code',\n 'dd',\n 'defs',\n 'div',\n 'dl',\n 'dt',\n 'em',\n 'feComponentTransfer',\n 'feDropShadow',\n 'feFuncA',\n 'feFuncB',\n 'feFuncG',\n 'feFuncR',\n 'feGaussianBlur',\n 'feOffset',\n 'feMerge',\n 'feMergeNode',\n 'filter',\n 'h1',\n 'h2',\n 'h3',\n 'h4',\n 'h5',\n 'h6',\n 'hr',\n 'i',\n 'img',\n 'li',\n 'linearGradient',\n 'marker',\n 'ol',\n 'p',\n 'path',\n 'pattern',\n 'pre',\n 'rect',\n 'small',\n 'span',\n 'stop',\n 'strong',\n 'style',\n 'sub',\n 'sup',\n 'svg',\n 'table',\n 'text',\n 'textPath',\n 'thead',\n 'title',\n 'tbody',\n 'tspan',\n 'td',\n 'th',\n 'tr',\n 'u',\n 'ul',\n '#text'\n ];\n AST.emptyHTML = emptyHTML;\n /**\n * Allow all custom SVG and HTML attributes, references and tags (together\n * with potentially harmful ones) to be added to the DOM from the chart\n * configuration. In other words, disable the the allow-listing which is the\n * primary functionality of the AST.\n *\n * WARNING: Setting this property to `true` while allowing untrusted user\n * data in the chart configuration will expose your application to XSS\n * security risks!\n *\n * Note that in case you want to allow a known set of tags or attributes,\n * you should allow-list them instead of disabling the filtering totally.\n * See [allowedAttributes](Highcharts.AST#.allowedAttributes),\n * [allowedReferences](Highcharts.AST#.allowedReferences) and\n * [allowedTags](Highcharts.AST#.allowedTags). The `bypassHTMLFiltering`\n * setting is intended only for those cases where allow-listing is not\n * practical, and the chart configuration already comes from a secure\n * source.\n *\n * @example\n * // Allow all custom attributes, references and tags (disable DOM XSS\n * // filtering)\n * Highcharts.AST.bypassHTMLFiltering = true;\n *\n * @name Highcharts.AST.bypassHTMLFiltering\n * @static\n */\n AST.bypassHTMLFiltering = false;\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Serialized form of an SVG/HTML definition, including children.\n *\n * @interface Highcharts.ASTNode\n */ /**\n * @name Highcharts.ASTNode#attributes\n * @type {Highcharts.SVGAttributes|undefined}\n */ /**\n * @name Highcharts.ASTNode#children\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.ASTNode#tagName\n * @type {string|undefined}\n */ /**\n * @name Highcharts.ASTNode#textContent\n * @type {string|undefined}\n */\n (''); // keeps doclets above in file\n\n return AST;\n });\n _registerModule(_modules, 'Core/Templating.js', [_modules['Core/Defaults.js'], _modules['Core/Utilities.js']], function (D, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions, defaultTime } = D;\n const { extend, getNestedProperty, isArray, isNumber, isObject, isString, pick, pInt } = U;\n const helpers = {\n // Built-in helpers\n add: (a, b) => a + b,\n divide: (a, b) => (b !== 0 ? a / b : ''),\n // eslint-disable-next-line eqeqeq\n eq: (a, b) => a == b,\n each: function (arr) {\n const match = arguments[arguments.length - 1];\n return isArray(arr) ?\n arr.map((item, i) => format(match.body, extend(isObject(item) ? item : { '@this': item }, {\n '@index': i,\n '@first': i === 0,\n '@last': i === arr.length - 1\n }))).join('') :\n false;\n },\n ge: (a, b) => a >= b,\n gt: (a, b) => a > b,\n 'if': (condition) => !!condition,\n le: (a, b) => a <= b,\n lt: (a, b) => a < b,\n multiply: (a, b) => a * b,\n // eslint-disable-next-line eqeqeq\n ne: (a, b) => a != b,\n subtract: (a, b) => a - b,\n unless: (condition) => !condition\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970) into a\n * human readable date string. The format is a subset of the formats for PHP's\n * [strftime](https://www.php.net/manual/en/function.strftime.php) function.\n * Additional formats can be given in the {@link Highcharts.dateFormats} hook.\n *\n * Since v6.0.5, all internal dates are formatted through the\n * {@link Highcharts.Chart#time} instance to respect chart-level time settings.\n * The `Highcharts.dateFormat` function only reflects global time settings set\n * with `setOptions`.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @function Highcharts.dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are prefixed\n * with `%`.\n *\n * @param {number} timestamp\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n function dateFormat(format, timestamp, capitalize) {\n return defaultTime.dateFormat(format, timestamp, capitalize);\n }\n /**\n * Format a string according to a subset of the rules of Python's String.format\n * method.\n *\n * @example\n * let s = Highcharts.format(\n * 'The {color} fox was {len:.2f} feet long',\n * { color: 'red', len: Math.PI }\n * );\n * // => The red fox was 3.14 feet long\n *\n * @function Highcharts.format\n *\n * @param {string} str\n * The string to format.\n *\n * @param {Record} ctx\n * The context, a collection of key-value pairs where each key is\n * replaced by its value.\n *\n * @param {Highcharts.Chart} [chart]\n * A `Chart` instance used to get numberFormatter and time.\n *\n * @return {string}\n * The formatted string.\n */\n function format(str = '', ctx, chart) {\n const regex = /\\{([a-zA-Z0-9\\:\\.\\,;\\-\\/<>%_@\"'= #\\(\\)]+)\\}/g, \n // The sub expression regex is the same as the top expression regex,\n // but except parens and block helpers (#), and surrounded by parens\n // instead of curly brackets.\n subRegex = /\\(([a-zA-Z0-9\\:\\.\\,;\\-\\/<>%_@\"'= ]+)\\)/g, matches = [], floatRegex = /f$/, decRegex = /\\.([0-9])/, lang = defaultOptions.lang, time = chart && chart.time || defaultTime, numberFormatter = chart && chart.numberFormatter || numberFormat;\n /*\n * Get a literal or variable value inside a template expression. May be\n * extended with other types like string or null if needed, but keep it\n * small for now.\n */\n const resolveProperty = (key = '') => {\n let n;\n // Literals\n if (key === 'true') {\n return true;\n }\n if (key === 'false') {\n return false;\n }\n if ((n = Number(key)).toString() === key) {\n return n;\n }\n // Variables and constants\n return getNestedProperty(key, ctx);\n };\n let match, currentMatch, depth = 0, hasSub;\n // Parse and create tree\n while ((match = regex.exec(str)) !== null) {\n // When a sub expression is found, it is evaluated first, and the\n // results recursively evaluated until no subexpression exists.\n const subMatch = subRegex.exec(match[1]);\n if (subMatch) {\n match = subMatch;\n hasSub = true;\n }\n if (!currentMatch || !currentMatch.isBlock) {\n currentMatch = {\n ctx,\n expression: match[1],\n find: match[0],\n isBlock: match[1].charAt(0) === '#',\n start: match.index,\n startInner: match.index + match[0].length,\n length: match[0].length\n };\n }\n // Identify helpers\n const fn = match[1].split(' ')[0].replace('#', '');\n if (helpers[fn]) {\n // Block helper, only 0 level is handled\n if (currentMatch.isBlock && fn === currentMatch.fn) {\n depth++;\n }\n if (!currentMatch.fn) {\n currentMatch.fn = fn;\n }\n }\n // Closing a block helper\n const startingElseSection = match[1] === 'else';\n if (currentMatch.isBlock &&\n currentMatch.fn && (match[1] === `/${currentMatch.fn}` ||\n startingElseSection)) {\n if (!depth) { // === 0\n const start = currentMatch.startInner, body = str.substr(start, match.index - start);\n // Either closing without an else section, or when encountering\n // an else section\n if (currentMatch.body === void 0) {\n currentMatch.body = body;\n currentMatch.startInner = match.index + match[0].length;\n // The body exists already, so this is the else section\n }\n else {\n currentMatch.elseBody = body;\n }\n currentMatch.find += body + match[0];\n if (!startingElseSection) {\n matches.push(currentMatch);\n currentMatch = void 0;\n }\n }\n else if (!startingElseSection) {\n depth--;\n }\n // Common expression\n }\n else if (!currentMatch.isBlock) {\n matches.push(currentMatch);\n }\n // Evaluate sub-matches one by one to prevent orphaned block closers\n if (subMatch && !(currentMatch === null || currentMatch === void 0 ? void 0 : currentMatch.isBlock)) {\n break;\n }\n }\n // Execute\n matches.forEach((match) => {\n const { body, elseBody, expression, fn } = match;\n let replacement, i;\n // Helper function\n if (fn) {\n // Pass the helpers the amount of arguments defined by the function,\n // then the match as the last argument.\n const args = [match], parts = expression.split(' ');\n i = helpers[fn].length;\n while (i--) {\n args.unshift(resolveProperty(parts[i + 1]));\n }\n replacement = helpers[fn].apply(ctx, args);\n // Block helpers may return true or false. They may also return a\n // string, like the `each` helper.\n if (match.isBlock && typeof replacement === 'boolean') {\n replacement = format(replacement ? body : elseBody, ctx);\n }\n // Simple variable replacement\n }\n else {\n const valueAndFormat = expression.split(':');\n replacement = resolveProperty(valueAndFormat.shift() || '');\n // Format the replacement\n if (valueAndFormat.length && typeof replacement === 'number') {\n const segment = valueAndFormat.join(':');\n if (floatRegex.test(segment)) { // float\n const decimals = parseInt((segment.match(decRegex) || ['', '-1'])[1], 10);\n if (replacement !== null) {\n replacement = numberFormatter(replacement, decimals, lang.decimalPoint, segment.indexOf(',') > -1 ? lang.thousandsSep : '');\n }\n }\n else {\n replacement = time.dateFormat(segment, replacement);\n }\n }\n }\n str = str.replace(match.find, pick(replacement, ''));\n });\n return hasSub ? format(str, ctx, chart) : str;\n }\n /**\n * Format a number and return a string based on input settings.\n *\n * @sample highcharts/members/highcharts-numberformat/\n * Custom number format\n *\n * @function Highcharts.numberFormat\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string}\n * The formatted number.\n */\n function numberFormat(number, decimals, decimalPoint, thousandsSep) {\n number = +number || 0;\n decimals = +decimals;\n let ret, fractionDigits;\n const lang = defaultOptions.lang, origDec = (number.toString().split('.')[1] || '').split('e')[0].length, exponent = number.toString().split('e'), firstDecimals = decimals;\n if (decimals === -1) {\n // Preserve decimals. Not huge numbers (#3793).\n decimals = Math.min(origDec, 20);\n }\n else if (!isNumber(decimals)) {\n decimals = 2;\n }\n else if (decimals && exponent[1] && exponent[1] < 0) {\n // Expose decimals from exponential notation (#7042)\n fractionDigits = decimals + +exponent[1];\n if (fractionDigits >= 0) {\n // remove too small part of the number while keeping the notation\n exponent[0] = (+exponent[0]).toExponential(fractionDigits)\n .split('e')[0];\n decimals = fractionDigits;\n }\n else {\n // fractionDigits < 0\n exponent[0] = exponent[0].split('.')[0] || 0;\n if (decimals < 20) {\n // use number instead of exponential notation (#7405)\n number = (exponent[0] * Math.pow(10, exponent[1]))\n .toFixed(decimals);\n }\n else {\n // or zero\n number = 0;\n }\n exponent[1] = 0;\n }\n }\n // Add another decimal to avoid rounding errors of float numbers. (#4573)\n // Then use toFixed to handle rounding.\n const roundedNumber = (Math.abs(exponent[1] ? exponent[0] : number) +\n Math.pow(10, -Math.max(decimals, origDec) - 1)).toFixed(decimals);\n // A string containing the positive integer component of the number\n const strinteger = String(pInt(roundedNumber));\n // Leftover after grouping into thousands. Can be 0, 1 or 2.\n const thousands = strinteger.length > 3 ? strinteger.length % 3 : 0;\n // Language\n decimalPoint = pick(decimalPoint, lang.decimalPoint);\n thousandsSep = pick(thousandsSep, lang.thousandsSep);\n // Start building the return\n ret = number < 0 ? '-' : '';\n // Add the leftover after grouping into thousands. For example, in the\n // number 42 000 000, this line adds 42.\n ret += thousands ? strinteger.substr(0, thousands) + thousandsSep : '';\n if (+exponent[1] < 0 && !firstDecimals) {\n ret = '0';\n }\n else {\n // Add the remaining thousands groups, joined by the thousands separator\n ret += strinteger\n .substr(thousands)\n .replace(/(\\d{3})(?=\\d)/g, '$1' + thousandsSep);\n }\n // Add the decimal point and the decimal component\n if (decimals) {\n // Get the decimal component\n ret += decimalPoint + roundedNumber.slice(-decimals);\n }\n if (exponent[1] && +ret !== 0) {\n ret += 'e' + exponent[1];\n }\n return ret;\n }\n /* *\n *\n * Default Export\n *\n * */\n const Templating = {\n dateFormat,\n format,\n helpers,\n numberFormat\n };\n\n return Templating;\n });\n _registerModule(_modules, 'Core/Renderer/RendererUtilities.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Imports\n *\n * */\n const { clamp, pick, stableSort } = U;\n /* *\n *\n * Namespace\n *\n * */\n var RendererUtilities;\n (function (RendererUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * General distribution algorithm for distributing labels of differing size\n * along a confined length in two dimensions. The algorithm takes an array\n * of objects containing a size, a target and a rank. It will place the\n * labels as close as possible to their targets, skipping the lowest ranked\n * labels if necessary.\n * @private\n */\n function distribute(boxes, len, maxDistance) {\n // Original array will be altered with added .pos\n const origBoxes = boxes, reducedLen = origBoxes.reducedLen || len, sortByRank = (a, b) => (b.rank || 0) - (a.rank || 0), sortByTarget = (a, b) => a.target - b.target;\n let i, overlapping = true, restBoxes = [], // The outranked overshoot\n box, target, total = 0;\n // If the total size exceeds the len, remove those boxes with the lowest\n // rank\n i = boxes.length;\n while (i--) {\n total += boxes[i].size;\n }\n // Sort by rank, then slice away overshoot\n if (total > reducedLen) {\n stableSort(boxes, sortByRank);\n i = 0;\n total = 0;\n while (total <= reducedLen) {\n total += boxes[i].size;\n i++;\n }\n restBoxes = boxes.splice(i - 1, boxes.length);\n }\n // Order by target\n stableSort(boxes, sortByTarget);\n // So far we have been mutating the original array. Now\n // create a copy with target arrays\n boxes = boxes.map((box) => ({\n size: box.size,\n targets: [box.target],\n align: pick(box.align, 0.5)\n }));\n while (overlapping) {\n // Initial positions: target centered in box\n i = boxes.length;\n while (i--) {\n box = boxes[i];\n // Composite box, average of targets\n target = (Math.min.apply(0, box.targets) +\n Math.max.apply(0, box.targets)) / 2;\n box.pos = clamp(target - box.size * box.align, 0, len - box.size);\n }\n // Detect overlap and join boxes\n i = boxes.length;\n overlapping = false;\n while (i--) {\n // Overlap\n if (i > 0 &&\n boxes[i - 1].pos + boxes[i - 1].size >\n boxes[i].pos) {\n // Add this size to the previous box\n boxes[i - 1].size += boxes[i].size;\n boxes[i - 1].targets = boxes[i - 1]\n .targets\n .concat(boxes[i].targets);\n boxes[i - 1].align = 0.5;\n // Overlapping right, push left\n if (boxes[i - 1].pos + boxes[i - 1].size > len) {\n boxes[i - 1].pos = len - boxes[i - 1].size;\n }\n boxes.splice(i, 1); // Remove this item\n overlapping = true;\n }\n }\n }\n // Add the rest (hidden boxes)\n origBoxes.push.apply(origBoxes, restBoxes);\n // Now the composite boxes are placed, we need to put the original boxes\n // within them\n i = 0;\n boxes.some((box) => {\n let posInCompositeBox = 0;\n // Exceeded maxDistance => abort\n return (box.targets || []).some(() => {\n origBoxes[i].pos = box.pos + posInCompositeBox;\n // If the distance between the position and the target exceeds\n // maxDistance, abort the loop and decrease the length in\n // increments of 10% to recursively reduce the number of\n // visible boxes by rank. Once all boxes are within the\n // maxDistance, we're good.\n if (typeof maxDistance !== 'undefined' &&\n Math.abs(origBoxes[i].pos - origBoxes[i].target) > maxDistance) {\n // Reset the positions that are already set\n origBoxes\n .slice(0, i + 1)\n .forEach((box) => delete box.pos);\n // Try with a smaller length\n origBoxes.reducedLen =\n (origBoxes.reducedLen || len) - (len * 0.1);\n // Recurse\n if (origBoxes.reducedLen > len * 0.1) {\n distribute(origBoxes, len, maxDistance);\n }\n // Exceeded maxDistance => abort\n return true;\n }\n posInCompositeBox += origBoxes[i].size;\n i++;\n return false;\n });\n });\n // Add the rest (hidden) boxes and sort by target\n stableSort(origBoxes, sortByTarget);\n return origBoxes;\n }\n RendererUtilities.distribute = distribute;\n })(RendererUtilities || (RendererUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererUtilities;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGElement.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (A, Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animate, animObject, stop } = A;\n const { deg2rad, doc, noop, svg, SVG_NS, win } = H;\n const { addEvent, attr, createElement, css, defined, erase, extend, fireEvent, isArray, isFunction, isObject, isString, merge, objectEach, pick, pInt, syncTimeout, uniqueKey } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The SVGElement prototype is a JavaScript wrapper for SVG elements used in the\n * rendering layer of Highcharts. Combined with the\n * {@link Highcharts.SVGRenderer}\n * object, these prototypes allow freeform annotation in the charts or even in\n * HTML pages without instanciating a chart. The SVGElement can also wrap HTML\n * labels, when `text` or `label` elements are created with the `useHTML`\n * parameter.\n *\n * The SVGElement instances are created through factory functions on the\n * {@link Highcharts.SVGRenderer}\n * object, like\n * {@link Highcharts.SVGRenderer#rect|rect},\n * {@link Highcharts.SVGRenderer#path|path},\n * {@link Highcharts.SVGRenderer#text|text},\n * {@link Highcharts.SVGRenderer#label|label},\n * {@link Highcharts.SVGRenderer#g|g}\n * and more.\n *\n * @class\n * @name Highcharts.SVGElement\n */\n class SVGElement {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n this.element = void 0;\n this.onEvents = {};\n this.opacity = 1; // Default base for animation\n this.renderer = void 0;\n this.SVG_NS = SVG_NS;\n }\n // @todo public zIndex?: number;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the current value of an attribute or pseudo attribute,\n * used mainly for animation. Called internally from\n * the {@link Highcharts.SVGRenderer#attr} function.\n *\n * @private\n * @function Highcharts.SVGElement#_defaultGetter\n *\n * @param {string} key\n * Property key.\n *\n * @return {number|string}\n * Property value.\n */\n _defaultGetter(key) {\n let ret = pick(this[key + 'Value'], // align getter\n this[key], this.element ? this.element.getAttribute(key) : null, 0);\n if (/^[\\-0-9\\.]+$/.test(ret)) { // is numerical\n ret = parseFloat(ret);\n }\n return ret;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#_defaultSetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n _defaultSetter(value, key, element) {\n element.setAttribute(key, value);\n }\n /**\n * Add the element to the DOM. All elements must be added this way.\n *\n * @sample highcharts/members/renderer-g\n * Elements added to a group\n *\n * @function Highcharts.SVGElement#add\n *\n * @param {Highcharts.SVGElement} [parent]\n * The parent item to add it to. If undefined, the element is added\n * to the {@link Highcharts.SVGRenderer.box}.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n add(parent) {\n const renderer = this.renderer, element = this.element;\n let inserted;\n if (parent) {\n this.parentGroup = parent;\n }\n // Build formatted text\n if (typeof this.textStr !== 'undefined' &&\n this.element.nodeName === 'text' // Not for SVGLabel instances\n ) {\n renderer.buildText(this);\n }\n // Mark as added\n this.added = true;\n // If we're adding to renderer root, or other elements in the group\n // have a z index, we need to handle it\n if (!parent || parent.handleZ || this.zIndex) {\n inserted = this.zIndexSetter();\n }\n // If zIndex is not handled, append at the end\n if (!inserted) {\n (parent ?\n parent.element :\n renderer.box).appendChild(element);\n }\n // fire an event for internal hooks\n if (this.onAdd) {\n this.onAdd();\n }\n return this;\n }\n /**\n * Add a class name to an element.\n *\n * @function Highcharts.SVGElement#addClass\n *\n * @param {string} className\n * The new class name to add.\n *\n * @param {boolean} [replace=false]\n * When true, the existing class name(s) will be overwritten with the new\n * one. When false, the new one is added.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chainability.\n */\n addClass(className, replace) {\n const currentClassName = replace ? '' : (this.attr('class') || '');\n // Trim the string and remove duplicates\n className = (className || '')\n .split(/ /g)\n .reduce(function (newClassName, name) {\n if (currentClassName.indexOf(name) === -1) {\n newClassName.push(name);\n }\n return newClassName;\n }, (currentClassName ?\n [currentClassName] :\n []))\n .join(' ');\n if (className !== currentClassName) {\n this.attr('class', className);\n }\n return this;\n }\n /**\n * This method is executed in the end of `attr()`, after setting all\n * attributes in the hash. In can be used to efficiently consolidate\n * multiple attributes in one SVG property -- e.g., translate, rotate and\n * scale are merged in one \"transform\" attribute in the SVG node.\n *\n * @private\n * @function Highcharts.SVGElement#afterSetters\n */\n afterSetters() {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.updateTransform();\n this.doTransform = false;\n }\n }\n /**\n * Align the element relative to the chart or another box.\n *\n * @function Highcharts.SVGElement#align\n *\n * @param {Highcharts.AlignObject} [alignOptions]\n * The alignment options. The function can be called without this\n * parameter in order to re-align an element after the box has been\n * updated.\n *\n * @param {boolean} [alignByTranslate]\n * Align element by translation.\n *\n * @param {string|Highcharts.BBoxObject} [box]\n * The box to align to, needs a width and height. When the box is a\n * string, it refers to an object in the Renderer. For example, when\n * box is `spacingBox`, it refers to `Renderer.spacingBox` which\n * holds `width`, `height`, `x` and `y` properties.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n align(alignOptions, alignByTranslate, box) {\n const attribs = {}, renderer = this.renderer, alignedObjects = renderer.alignedObjects;\n let x, y, alignTo, alignFactor, vAlignFactor;\n // First call on instanciate\n if (alignOptions) {\n this.alignOptions = alignOptions;\n this.alignByTranslate = alignByTranslate;\n if (!box || isString(box)) {\n this.alignTo = alignTo = box || 'renderer';\n // prevent duplicates, like legendGroup after resize\n erase(alignedObjects, this);\n alignedObjects.push(this);\n box = void 0; // reassign it below\n }\n // When called on resize, no arguments are supplied\n }\n else {\n alignOptions = this.alignOptions;\n alignByTranslate = this.alignByTranslate;\n alignTo = this.alignTo;\n }\n box = pick(box, renderer[alignTo], alignTo === 'scrollablePlotBox' ?\n renderer.plotBox : void 0, renderer);\n // Assign variables\n const align = alignOptions.align, vAlign = alignOptions.verticalAlign;\n // default: left align\n x = (box.x || 0) + (alignOptions.x || 0);\n // default: top align\n y = (box.y || 0) + (alignOptions.y || 0);\n // Align\n if (align === 'right') {\n alignFactor = 1;\n }\n else if (align === 'center') {\n alignFactor = 2;\n }\n if (alignFactor) {\n x += (box.width - (alignOptions.width || 0)) /\n alignFactor;\n }\n attribs[alignByTranslate ? 'translateX' : 'x'] = Math.round(x);\n // Vertical align\n if (vAlign === 'bottom') {\n vAlignFactor = 1;\n }\n else if (vAlign === 'middle') {\n vAlignFactor = 2;\n }\n if (vAlignFactor) {\n y += (box.height - (alignOptions.height || 0)) /\n vAlignFactor;\n }\n attribs[alignByTranslate ? 'translateY' : 'y'] = Math.round(y);\n // Animate only if already placed\n this[this.placed ? 'animate' : 'attr'](attribs);\n this.placed = true;\n this.alignAttr = attribs;\n return this;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#alignSetter\n * @param {\"left\"|\"center\"|\"right\"} value\n */\n alignSetter(value) {\n const convert = {\n left: 'start',\n center: 'middle',\n right: 'end'\n };\n if (convert[value]) {\n this.alignValue = value;\n this.element.setAttribute('text-anchor', convert[value]);\n }\n }\n /**\n * Animate to given attributes or CSS properties.\n *\n * @sample highcharts/members/element-on/\n * Setting some attributes by animation\n *\n * @function Highcharts.SVGElement#animate\n *\n * @param {Highcharts.SVGAttributes} params\n * SVG attributes or CSS to animate.\n *\n * @param {boolean|Partial} [options]\n * Animation options.\n *\n * @param {Function} [complete]\n * Function to perform at the end of animation.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n animate(params, options, complete) {\n const animOptions = animObject(pick(options, this.renderer.globalAnimation, true)), deferTime = animOptions.defer;\n // When the page is hidden save resources in the background by not\n // running animation at all (#9749).\n if (doc.hidden) {\n animOptions.duration = 0;\n }\n if (animOptions.duration !== 0) {\n // allows using a callback with the global animation without\n // overwriting it\n if (complete) {\n animOptions.complete = complete;\n }\n // If defer option is defined delay the animation #12901\n syncTimeout(() => {\n if (this.element) {\n animate(this, params, animOptions);\n }\n }, deferTime);\n }\n else {\n this.attr(params, void 0, complete || animOptions.complete);\n // Call the end step synchronously\n objectEach(params, function (val, prop) {\n if (animOptions.step) {\n animOptions.step.call(this, val, { prop: prop, pos: 1, elem: this });\n }\n }, this);\n }\n return this;\n }\n /**\n * Apply a text outline through a custom CSS property, by copying the text\n * element and apply stroke to the copy. Used internally. Contrast checks at\n * [example](https://jsfiddle.net/highcharts/43soe9m1/2/).\n *\n * @example\n * // Specific color\n * text.css({\n * textOutline: '1px black'\n * });\n * // Automatic contrast\n * text.css({\n * color: '#000000', // black text\n * textOutline: '1px contrast' // => white outline\n * });\n *\n * @private\n * @function Highcharts.SVGElement#applyTextOutline\n *\n * @param {string} textOutline\n * A custom CSS `text-outline` setting, defined by `width color`.\n */\n applyTextOutline(textOutline) {\n const elem = this.element, hasContrast = textOutline.indexOf('contrast') !== -1, styles = {};\n // When the text shadow is set to contrast, use dark stroke for light\n // text and vice versa.\n if (hasContrast) {\n styles.textOutline = textOutline = textOutline.replace(/contrast/g, this.renderer.getContrast(elem.style.fill));\n }\n // Extract the stroke width and color\n const parts = textOutline.split(' ');\n const color = parts[parts.length - 1];\n let strokeWidth = parts[0];\n if (strokeWidth && strokeWidth !== 'none' && H.svg) {\n this.fakeTS = true; // Fake text shadow\n // Since the stroke is applied on center of the actual outline, we\n // need to double it to get the correct stroke-width outside the\n // glyphs.\n strokeWidth = strokeWidth.replace(/(^[\\d\\.]+)(.*?)$/g, function (match, digit, unit) {\n return (2 * Number(digit)) + unit;\n });\n // Remove shadows from previous runs.\n this.removeTextOutline();\n const outline = doc.createElementNS(SVG_NS, 'tspan');\n attr(outline, {\n 'class': 'highcharts-text-outline',\n fill: color,\n stroke: color,\n 'stroke-width': strokeWidth,\n 'stroke-linejoin': 'round'\n });\n // For each of the tspans and text nodes, create a copy in the\n // outline.\n const parentElem = elem.querySelector('textPath') || elem;\n [].forEach.call(parentElem.childNodes, (childNode) => {\n const clone = childNode.cloneNode(true);\n if (clone.removeAttribute) {\n ['fill', 'stroke', 'stroke-width', 'stroke'].forEach((prop) => clone\n .removeAttribute(prop));\n }\n outline.appendChild(clone);\n });\n // Collect the sum of dy from all children, included nested ones\n let totalHeight = 0;\n [].forEach.call(parentElem.querySelectorAll('text tspan'), (element) => {\n totalHeight += Number(element.getAttribute('dy'));\n });\n // Insert an absolutely positioned break before the original text\n // to keep it in place\n const br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B';\n // Reset the position for the following text\n attr(br, {\n x: Number(elem.getAttribute('x')),\n dy: -totalHeight\n });\n // Insert the outline\n outline.appendChild(br);\n parentElem.insertBefore(outline, parentElem.firstChild);\n }\n }\n /**\n * @function Highcharts.SVGElement#attr\n * @param {string} key\n * @return {number|string}\n */ /**\n * Apply native and custom attributes to the SVG elements.\n *\n * In order to set the rotation center for rotation, set x and y to 0 and\n * use `translateX` and `translateY` attributes to position the element\n * instead.\n *\n * Attributes frequently used in Highcharts are `fill`, `stroke`,\n * `stroke-width`.\n *\n * @sample highcharts/members/renderer-rect/\n * Setting some attributes\n *\n * @example\n * // Set multiple attributes\n * element.attr({\n * stroke: 'red',\n * fill: 'blue',\n * x: 10,\n * y: 10\n * });\n *\n * // Set a single attribute\n * element.attr('stroke', 'red');\n *\n * // Get an attribute\n * element.attr('stroke'); // => 'red'\n *\n * @function Highcharts.SVGElement#attr\n *\n * @param {string|Highcharts.SVGAttributes} [hash]\n * The native and custom SVG attributes.\n *\n * @param {number|string|Highcharts.SVGPathArray} [val]\n * If the type of the first argument is `string`, the second can be a\n * value, which will serve as a single attribute setter. If the first\n * argument is a string and the second is undefined, the function\n * serves as a getter and the current value of the property is\n * returned.\n *\n * @param {Function} [complete]\n * A callback function to execute after setting the attributes. This\n * makes the function compliant and interchangeable with the\n * {@link SVGElement#animate} function.\n *\n * @param {boolean} [continueAnimation=true]\n * Used internally when `.attr` is called as part of an animation\n * step. Otherwise, calling `.attr` for an attribute will stop\n * animation for that attribute.\n *\n * @return {Highcharts.SVGElement}\n * If used as a setter, it returns the current\n * {@link Highcharts.SVGElement} so the calls can be chained. If\n * used as a getter, the current value of the attribute is returned.\n */\n attr(hash, val, complete, continueAnimation) {\n const element = this.element, symbolCustomAttribs = SVGElement.symbolCustomAttribs;\n let key, hasSetSymbolSize, ret = this, skipAttr, setter;\n // single key-value pair\n if (typeof hash === 'string' && typeof val !== 'undefined') {\n key = hash;\n hash = {};\n hash[key] = val;\n }\n // used as a getter: first argument is a string, second is undefined\n if (typeof hash === 'string') {\n ret = (this[hash + 'Getter'] ||\n this._defaultGetter).call(this, hash, element);\n // setter\n }\n else {\n objectEach(hash, function eachAttribute(val, key) {\n skipAttr = false;\n // Unless .attr is from the animator update, stop current\n // running animation of this property\n if (!continueAnimation) {\n stop(this, key);\n }\n // Special handling of symbol attributes\n if (this.symbolName &&\n symbolCustomAttribs.indexOf(key) !== -1) {\n if (!hasSetSymbolSize) {\n this.symbolAttr(hash);\n hasSetSymbolSize = true;\n }\n skipAttr = true;\n }\n if (this.rotation && (key === 'x' || key === 'y')) {\n this.doTransform = true;\n }\n if (!skipAttr) {\n setter = (this[key + 'Setter'] ||\n this._defaultSetter);\n setter.call(this, val, key, element);\n }\n }, this);\n this.afterSetters();\n }\n // In accordance with animate, run a complete callback\n if (complete) {\n complete.call(this);\n }\n return ret;\n }\n /**\n * Apply a clipping rectangle to this element.\n *\n * @function Highcharts.SVGElement#clip\n *\n * @param {Highcharts.ClipRectElement} [clipRect]\n * The clipping rectangle. If skipped, the current clip is removed.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVG element to allow chaining.\n */\n clip(clipRect) {\n return this.attr('clip-path', clipRect ?\n 'url(' + this.renderer.url + '#' + clipRect.id + ')' :\n 'none');\n }\n /**\n * Calculate the coordinates needed for drawing a rectangle crisply and\n * return the calculated attributes.\n *\n * @function Highcharts.SVGElement#crisp\n *\n * @param {Highcharts.RectangleObject} rect\n * Rectangle to crisp.\n *\n * @param {number} [strokeWidth]\n * The stroke width to consider when computing crisp positioning. It can\n * also be set directly on the rect parameter.\n *\n * @return {Highcharts.RectangleObject}\n * The modified rectangle arguments.\n */\n crisp(rect, strokeWidth) {\n const wrapper = this;\n strokeWidth = strokeWidth || rect.strokeWidth || 0;\n // Math.round because strokeWidth can sometimes have roundoff errors\n const normalizer = Math.round(strokeWidth) % 2 / 2;\n // normalize for crisp edges\n rect.x = Math.floor(rect.x || wrapper.x || 0) + normalizer;\n rect.y = Math.floor(rect.y || wrapper.y || 0) + normalizer;\n rect.width = Math.floor((rect.width || wrapper.width || 0) - 2 * normalizer);\n rect.height = Math.floor((rect.height || wrapper.height || 0) - 2 * normalizer);\n if (defined(rect.strokeWidth)) {\n rect.strokeWidth = strokeWidth;\n }\n return rect;\n }\n /**\n * Build and apply an SVG gradient out of a common JavaScript configuration\n * object. This function is called from the attribute setters. An event\n * hook is added for supporting other complex color types.\n *\n * @private\n * @function Highcharts.SVGElement#complexColor\n *\n * @param {Highcharts.GradientColorObject|Highcharts.PatternObject} colorOptions\n * The gradient or pattern options structure.\n *\n * @param {string} prop\n * The property to apply, can either be `fill` or `stroke`.\n *\n * @param {Highcharts.SVGDOMElement} elem\n * SVG element to apply the gradient on.\n */\n complexColor(colorOptions, prop, elem) {\n const renderer = this.renderer;\n let colorObject, gradName, gradAttr, radAttr, gradients, stops, stopColor, stopOpacity, radialReference, id, key = [], value;\n fireEvent(this.renderer, 'complexColor', {\n args: arguments\n }, function () {\n // Apply linear or radial gradients\n if (colorOptions.radialGradient) {\n gradName = 'radialGradient';\n }\n else if (colorOptions.linearGradient) {\n gradName = 'linearGradient';\n }\n if (gradName) {\n gradAttr = colorOptions[gradName];\n gradients = renderer.gradients;\n stops = colorOptions.stops;\n radialReference = elem.radialReference;\n // Keep < 2.2 kompatibility\n if (isArray(gradAttr)) {\n colorOptions[gradName] = gradAttr = {\n x1: gradAttr[0],\n y1: gradAttr[1],\n x2: gradAttr[2],\n y2: gradAttr[3],\n gradientUnits: 'userSpaceOnUse'\n };\n }\n // Correct the radial gradient for the radial reference system\n if (gradName === 'radialGradient' &&\n radialReference &&\n !defined(gradAttr.gradientUnits)) {\n // Save the radial attributes for updating\n radAttr = gradAttr;\n gradAttr = merge(gradAttr, renderer.getRadialAttr(radialReference, radAttr), { gradientUnits: 'userSpaceOnUse' });\n }\n // Build the unique key to detect whether we need to create a\n // new element (#1282)\n objectEach(gradAttr, function (value, n) {\n if (n !== 'id') {\n key.push(n, value);\n }\n });\n objectEach(stops, function (val) {\n key.push(val);\n });\n key = key.join(',');\n // Check if a gradient object with the same config object is\n // created within this renderer\n if (gradients[key]) {\n id = gradients[key].attr('id');\n }\n else {\n // Set the id and create the element\n gradAttr.id = id = uniqueKey();\n const gradientObject = gradients[key] =\n renderer.createElement(gradName)\n .attr(gradAttr)\n .add(renderer.defs);\n gradientObject.radAttr = radAttr;\n // The gradient needs to keep a list of stops to be able to\n // destroy them\n gradientObject.stops = [];\n stops.forEach(function (stop) {\n if (stop[1].indexOf('rgba') === 0) {\n colorObject = Color.parse(stop[1]);\n stopColor = colorObject.get('rgb');\n stopOpacity = colorObject.get('a');\n }\n else {\n stopColor = stop[1];\n stopOpacity = 1;\n }\n const stopObject = renderer.createElement('stop').attr({\n offset: stop[0],\n 'stop-color': stopColor,\n 'stop-opacity': stopOpacity\n }).add(gradientObject);\n // Add the stop element to the gradient\n gradientObject.stops.push(stopObject);\n });\n }\n // Set the reference to the gradient object\n value = 'url(' + renderer.url + '#' + id + ')';\n elem.setAttribute(prop, value);\n elem.gradient = key;\n // Allow the color to be concatenated into tooltips formatters\n // etc. (#2995)\n colorOptions.toString = function () {\n return value;\n };\n }\n });\n }\n /**\n * Set styles for the element. In addition to CSS styles supported by\n * native SVG and HTML elements, there are also some custom made for\n * Highcharts, like `width`, `ellipsis` and `textOverflow` for SVG text\n * elements.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Styled text\n *\n * @function Highcharts.SVGElement#css\n *\n * @param {Highcharts.CSSObject} styles\n * The new CSS styles.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chaining.\n */\n css(styles) {\n const oldStyles = this.styles, newStyles = {}, elem = this.element;\n let textWidth, hasNew = !oldStyles;\n // Filter out existing styles to increase performance (#2640)\n if (oldStyles) {\n objectEach(styles, function (value, n) {\n if (oldStyles && oldStyles[n] !== value) {\n newStyles[n] = value;\n hasNew = true;\n }\n });\n }\n if (hasNew) {\n // Merge the new styles with the old ones\n if (oldStyles) {\n styles = extend(oldStyles, newStyles);\n }\n // Get the text width from style\n // Previously set, unset it (#8234)\n if (styles.width === null || styles.width === 'auto') {\n delete this.textWidth;\n // Apply new\n }\n else if (elem.nodeName.toLowerCase() === 'text' &&\n styles.width) {\n textWidth = this.textWidth = pInt(styles.width);\n }\n // store object\n this.styles = styles;\n if (textWidth && (!svg && this.renderer.forExport)) {\n delete styles.width;\n }\n const stylesToApply = merge(styles);\n if (elem.namespaceURI === this.SVG_NS) {\n // These CSS properties are interpreted internally by the SVG\n // renderer, but are not supported by SVG and should not be\n // added to the DOM. In styled mode, no CSS should find its way\n // to the DOM whatsoever (#6173, #6474).\n ['textOutline', 'textOverflow', 'width'].forEach((key) => (stylesToApply &&\n delete stylesToApply[key]));\n // SVG requires fill for text\n if (stylesToApply.color) {\n stylesToApply.fill = stylesToApply.color;\n }\n }\n css(elem, stylesToApply);\n }\n if (this.added) {\n // Rebuild text after added. Cache mechanisms in the buildText will\n // prevent building if there are no significant changes.\n if (this.element.nodeName === 'text') {\n this.renderer.buildText(this);\n }\n // Apply text outline after added\n if (styles.textOutline) {\n this.applyTextOutline(styles.textOutline);\n }\n }\n return this;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#dashstyleSetter\n * @param {string} value\n */\n dashstyleSetter(value) {\n let i, strokeWidth = this['stroke-width'];\n // If \"inherit\", like maps in IE, assume 1 (#4981). With HC5 and the new\n // strokeWidth function, we should be able to use that instead.\n if (strokeWidth === 'inherit') {\n strokeWidth = 1;\n }\n value = value && value.toLowerCase();\n if (value) {\n const v = value\n .replace('shortdashdotdot', '3,1,1,1,1,1,')\n .replace('shortdashdot', '3,1,1,1')\n .replace('shortdot', '1,1,')\n .replace('shortdash', '3,1,')\n .replace('longdash', '8,3,')\n .replace(/dot/g, '1,3,')\n .replace('dash', '4,3,')\n .replace(/,$/, '')\n .split(','); // ending comma\n i = v.length;\n while (i--) {\n v[i] = '' + (pInt(v[i]) * pick(strokeWidth, NaN));\n }\n value = v.join(',').replace(/NaN/g, 'none'); // #3226\n this.element.setAttribute('stroke-dasharray', value);\n }\n }\n /**\n * Destroy the element and element wrapper and clear up the DOM and event\n * hooks.\n *\n * @function Highcharts.SVGElement#destroy\n */\n destroy() {\n const wrapper = this, element = wrapper.element || {}, renderer = wrapper.renderer, ownerSVGElement = element.ownerSVGElement;\n let parentToClean = (element.nodeName === 'SPAN' &&\n wrapper.parentGroup ||\n void 0), grandParent, i;\n // remove events\n element.onclick = element.onmouseout = element.onmouseover =\n element.onmousemove = element.point = null;\n stop(wrapper); // stop running animations\n if (wrapper.clipPath && ownerSVGElement) {\n const clipPath = wrapper.clipPath;\n // Look for existing references to this clipPath and remove them\n // before destroying the element (#6196).\n // The upper case version is for Edge\n [].forEach.call(ownerSVGElement.querySelectorAll('[clip-path],[CLIP-PATH]'), function (el) {\n if (el.getAttribute('clip-path').indexOf(clipPath.element.id) > -1) {\n el.removeAttribute('clip-path');\n }\n });\n wrapper.clipPath = clipPath.destroy();\n }\n // Destroy stops in case this is a gradient object @todo old code?\n if (wrapper.stops) {\n for (i = 0; i < wrapper.stops.length; i++) {\n wrapper.stops[i].destroy();\n }\n wrapper.stops.length = 0;\n wrapper.stops = void 0;\n }\n // remove element\n wrapper.safeRemoveChild(element);\n // In case of useHTML, clean up empty containers emulating SVG groups\n // (#1960, #2393, #2697).\n while (parentToClean &&\n parentToClean.div &&\n parentToClean.div.childNodes.length === 0) {\n grandParent = parentToClean.parentGroup;\n wrapper.safeRemoveChild(parentToClean.div);\n delete parentToClean.div;\n parentToClean = grandParent;\n }\n // remove from alignObjects\n if (wrapper.alignTo) {\n erase(renderer.alignedObjects, wrapper);\n }\n objectEach(wrapper, function (val, key) {\n // Destroy child elements of a group\n if (wrapper[key] &&\n wrapper[key].parentGroup === wrapper &&\n wrapper[key].destroy) {\n wrapper[key].destroy();\n }\n // Delete all properties\n delete wrapper[key];\n });\n return;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#dSettter\n * @param {number|string|Highcharts.SVGPathArray} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n dSetter(value, key, element) {\n if (isArray(value)) {\n // Backwards compatibility, convert one-dimensional array into an\n // array of segments\n if (typeof value[0] === 'string') {\n value = this.renderer.pathToSegments(value);\n }\n this.pathArray = value;\n value = value.reduce((acc, seg, i) => {\n if (!seg || !seg.join) {\n return (seg || '').toString();\n }\n return (i ? acc + ' ' : '') + seg.join(' ');\n }, '');\n }\n if (/(NaN| {2}|^$)/.test(value)) {\n value = 'M 0 0';\n }\n // Check for cache before resetting. Resetting causes disturbance in the\n // DOM, causing flickering in some cases in Edge/IE (#6747). Also\n // possible performance gain.\n if (this[key] !== value) {\n element.setAttribute(key, value);\n this[key] = value;\n }\n }\n /**\n * Fade out an element by animating its opacity down to 0, and hide it on\n * complete. Used internally for the tooltip.\n *\n * @function Highcharts.SVGElement#fadeOut\n *\n * @param {number} [duration=150]\n * The fade duration in milliseconds.\n */\n fadeOut(duration) {\n const elemWrapper = this;\n elemWrapper.animate({\n opacity: 0\n }, {\n duration: pick(duration, 150),\n complete: function () {\n // #3088, assuming we're only using this for tooltips\n elemWrapper.hide();\n }\n });\n }\n /**\n * @private\n * @function Highcharts.SVGElement#fillSetter\n * @param {Highcharts.ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n fillSetter(value, key, element) {\n if (typeof value === 'string') {\n element.setAttribute(key, value);\n }\n else if (value) {\n this.complexColor(value, key, element);\n }\n }\n /**\n * Get the bounding box (width, height, x and y) for the element. Generally\n * used to get rendered text size. Since this is called a lot in charts,\n * the results are cached based on text properties, in order to save DOM\n * traffic. The returned bounding box includes the rotation, so for example\n * a single text line of rotation 90 will report a greater height, and a\n * width corresponding to the line-height.\n *\n * @sample highcharts/members/renderer-on-chart/\n * Draw a rectangle based on a text's bounding box\n *\n * @function Highcharts.SVGElement#getBBox\n *\n * @param {boolean} [reload]\n * Skip the cache and get the updated DOM bouding box.\n *\n * @param {number} [rot]\n * Override the element's rotation. This is internally used on axis\n * labels with a value of 0 to find out what the bounding box would\n * be have been if it were not rotated.\n *\n * @return {Highcharts.BBoxObject}\n * The bounding box with `x`, `y`, `width` and `height` properties.\n */\n getBBox(reload, rot) {\n const wrapper = this, { alignValue, element, renderer, styles, textStr } = wrapper, { cache, cacheKeys } = renderer, isSVG = element.namespaceURI === wrapper.SVG_NS, rotation = pick(rot, wrapper.rotation, 0), fontSize = renderer.styledMode ? (element &&\n SVGElement.prototype.getStyle.call(element, 'font-size')) : (styles && styles.fontSize);\n let bBox, width, height, toggleTextShadowShim, cacheKey;\n // Avoid undefined and null (#7316)\n if (defined(textStr)) {\n cacheKey = textStr.toString();\n // Since numbers are monospaced, and numerical labels appear a lot\n // in a chart, we assume that a label of n characters has the same\n // bounding box as others of the same length. Unless there is inner\n // HTML in the label. In that case, leave the numbers as is (#5899).\n if (cacheKey.indexOf('<') === -1) {\n cacheKey = cacheKey.replace(/[0-9]/g, '0');\n }\n // Properties that affect bounding box\n cacheKey += [\n '',\n renderer.rootFontSize,\n fontSize,\n rotation,\n wrapper.textWidth,\n alignValue,\n styles && styles.textOverflow,\n styles && styles.fontWeight // #12163\n ].join(',');\n }\n if (cacheKey && !reload) {\n bBox = cache[cacheKey];\n }\n // No cache found\n if (!bBox) {\n // SVG elements\n if (isSVG || renderer.forExport) {\n try { // Fails in Firefox if the container has display: none.\n // When the text shadow shim is used, we need to hide the\n // fake shadows to get the correct bounding box (#3872)\n toggleTextShadowShim = this.fakeTS && function (display) {\n const outline = element.querySelector('.highcharts-text-outline');\n if (outline) {\n css(outline, { display });\n }\n };\n // Workaround for #3842, Firefox reporting wrong bounding\n // box for shadows\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('none');\n }\n bBox = element.getBBox ?\n // SVG: use extend because IE9 is not allowed to change\n // width and height in case of rotation (below)\n extend({}, element.getBBox()) : {\n // HTML elements with `exporting.allowHTML` and\n // legacy IE in export mode\n width: element.offsetWidth,\n height: element.offsetHeight,\n x: 0,\n y: 0\n };\n // #3842\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('');\n }\n }\n catch (e) {\n '';\n }\n // If the bBox is not set, the try-catch block above failed. The\n // other condition is for Opera that returns a width of\n // -Infinity on hidden elements.\n if (!bBox || bBox.width < 0) {\n bBox = { x: 0, y: 0, width: 0, height: 0 };\n }\n // useHTML within SVG\n }\n else {\n bBox = wrapper.htmlGetBBox();\n }\n // True SVG elements as well as HTML elements in modern browsers\n // using the .useHTML option need to compensated for rotation\n width = bBox.width;\n height = bBox.height;\n // Workaround for wrong bounding box in IE, Edge and Chrome on\n // Windows. With Highcharts' default font, IE and Edge report\n // a box height of 16.899 and Chrome rounds it to 17. If this\n // stands uncorrected, it results in more padding added below\n // the text than above when adding a label border or background.\n // Also vertical positioning is affected.\n // https://jsfiddle.net/highcharts/em37nvuj/\n // (#1101, #1505, #1669, #2568, #6213).\n if (isSVG) {\n bBox.height = height = ({\n '11px,17': 14,\n '13px,20': 16\n }[`${fontSize || ''},${Math.round(height)}`] ||\n height);\n }\n // Adjust for rotated text\n if (rotation) {\n const baseline = Number(element.getAttribute('y') || 0) - bBox.y, alignFactor = {\n 'right': 1,\n 'center': 0.5\n }[alignValue || 0] || 0, rad = rotation * deg2rad, rad90 = (rotation - 90) * deg2rad, wCosRad = width * Math.cos(rad), wSinRad = width * Math.sin(rad), cosRad90 = Math.cos(rad90), sinRad90 = Math.sin(rad90), \n // Find the starting point on the left side baseline of\n // the text\n pX = bBox.x + alignFactor * (width - wCosRad), pY = bBox.y + baseline - alignFactor * wSinRad, \n // Find all corners\n aX = pX + baseline * cosRad90, bX = aX + wCosRad, cX = bX - height * cosRad90, dX = cX - wCosRad, aY = pY + baseline * sinRad90, bY = aY + wSinRad, cY = bY - height * sinRad90, dY = cY - wSinRad;\n // Deduct the bounding box from the corners\n bBox.x = Math.min(aX, bX, cX, dX);\n bBox.y = Math.min(aY, bY, cY, dY);\n bBox.width = Math.max(aX, bX, cX, dX) - bBox.x;\n bBox.height = Math.max(aY, bY, cY, dY) - bBox.y;\n }\n }\n // Cache it. When loading a chart in a hidden iframe in Firefox and\n // IE/Edge, the bounding box height is 0, so don't cache it (#5620).\n if (cacheKey && (textStr === '' || bBox.height > 0)) {\n // Rotate (#4681)\n while (cacheKeys.length > 250) {\n delete cache[cacheKeys.shift()];\n }\n if (!cache[cacheKey]) {\n cacheKeys.push(cacheKey);\n }\n cache[cacheKey] = bBox;\n }\n return bBox;\n }\n /**\n * Get the computed style. Only in styled mode.\n *\n * @example\n * chart.series[0].points[0].graphic.getStyle('stroke-width'); // => '1px'\n *\n * @function Highcharts.SVGElement#getStyle\n *\n * @param {string} prop\n * The property name to check for.\n *\n * @return {string}\n * The current computed value.\n */\n getStyle(prop) {\n return win\n .getComputedStyle(this.element || this, '')\n .getPropertyValue(prop);\n }\n /**\n * Check if an element has the given class name.\n *\n * @function Highcharts.SVGElement#hasClass\n *\n * @param {string} className\n * The class name to check for.\n *\n * @return {boolean}\n * Whether the class name is found.\n */\n hasClass(className) {\n return ('' + this.attr('class'))\n .split(' ')\n .indexOf(className) !== -1;\n }\n /**\n * Hide the element, similar to setting the `visibility` attribute to\n * `hidden`.\n *\n * @function Highcharts.SVGElement#hide\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n hide() {\n return this.attr({ visibility: 'hidden' });\n }\n /**\n * @private\n */\n htmlGetBBox() {\n return { height: 0, width: 0, x: 0, y: 0 };\n }\n /**\n * Initialize the SVG element. This function only exists to make the\n * initialization process overridable. It should not be called directly.\n *\n * @function Highcharts.SVGElement#init\n *\n * @param {Highcharts.SVGRenderer} renderer\n * The SVGRenderer instance to initialize to.\n *\n * @param {string} nodeName\n * The SVG node name.\n */\n init(renderer, nodeName) {\n /**\n * The primary DOM node. Each `SVGElement` instance wraps a main DOM\n * node, but may also represent more nodes.\n *\n * @name Highcharts.SVGElement#element\n * @type {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n */\n this.element = nodeName === 'span' ?\n createElement(nodeName) :\n doc.createElementNS(this.SVG_NS, nodeName);\n /**\n * The renderer that the SVGElement belongs to.\n *\n * @name Highcharts.SVGElement#renderer\n * @type {Highcharts.SVGRenderer}\n */\n this.renderer = renderer;\n fireEvent(this, 'afterInit');\n }\n /**\n * Add an event listener. This is a simple setter that replaces the\n * previous event of the same type added by this function, as opposed to\n * the {@link Highcharts#addEvent} function.\n *\n * @sample highcharts/members/element-on/\n * A clickable rectangle\n *\n * @function Highcharts.SVGElement#on\n *\n * @param {string} eventType\n * The event type.\n *\n * @param {Function} handler\n * The handler callback.\n *\n * @return {Highcharts.SVGElement}\n * The SVGElement for chaining.\n */\n on(eventType, handler) {\n const { onEvents } = this;\n if (onEvents[eventType]) {\n // Unbind existing event\n onEvents[eventType]();\n }\n onEvents[eventType] = addEvent(this.element, eventType, handler);\n return this;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#opacitySetter\n * @param {string} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n opacitySetter(value, key, element) {\n // Round off to avoid float errors, like tests where opacity lands on\n // 9.86957e-06 instead of 0\n const opacity = Number(Number(value).toFixed(3));\n this.opacity = opacity;\n element.setAttribute(key, opacity);\n }\n /**\n * Remove a class name from the element.\n *\n * @function Highcharts.SVGElement#removeClass\n *\n * @param {string|RegExp} className\n * The class name to remove.\n *\n * @return {Highcharts.SVGElement} Returns the SVG element for chainability.\n */\n removeClass(className) {\n return this.attr('class', ('' + this.attr('class'))\n .replace(isString(className) ?\n new RegExp(`(^| )${className}( |$)`) : // #12064, #13590\n className, ' ')\n .replace(/ +/g, ' ')\n .trim());\n }\n /**\n *\n * @private\n */\n removeTextOutline() {\n const outline = this.element\n .querySelector('tspan.highcharts-text-outline');\n if (outline) {\n this.safeRemoveChild(outline);\n }\n }\n /**\n * Removes an element from the DOM.\n *\n * @private\n * @function Highcharts.SVGElement#safeRemoveChild\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The DOM node to remove.\n */\n safeRemoveChild(element) {\n const parentNode = element.parentNode;\n if (parentNode) {\n parentNode.removeChild(element);\n }\n }\n /**\n * Set the coordinates needed to draw a consistent radial gradient across\n * a shape regardless of positioning inside the chart. Used on pie slices\n * to make all the slices have the same radial reference point.\n *\n * @function Highcharts.SVGElement#setRadialReference\n *\n * @param {Array} coordinates\n * The center reference. The format is `[centerX, centerY, diameter]` in\n * pixels.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n setRadialReference(coordinates) {\n const existingGradient = (this.element.gradient &&\n this.renderer.gradients[this.element.gradient]);\n this.element.radialReference = coordinates;\n // On redrawing objects with an existing gradient, the gradient needs\n // to be repositioned (#3801)\n if (existingGradient && existingGradient.radAttr) {\n existingGradient.animate(this.renderer.getRadialAttr(coordinates, existingGradient.radAttr));\n }\n return this;\n }\n /**\n * Set a text path for a `text` or `label` element, allowing the text to\n * flow along a path.\n *\n * In order to unset the path for an existing element, call `setTextPath`\n * with `{ enabled: false }` as the second argument.\n *\n * @sample highcharts/members/renderer-textpath/ Text path demonstrated\n *\n * @function Highcharts.SVGElement#setTextPath\n *\n * @param {Highcharts.SVGElement|undefined} path\n * Path to follow. If undefined, it allows changing options for the\n * existing path.\n *\n * @param {Highcharts.DataLabelsTextPathOptionsObject} textPathOptions\n * Options.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n setTextPath(path, textPathOptions) {\n // Defaults\n textPathOptions = merge(true, {\n enabled: true,\n attributes: {\n dy: -5,\n startOffset: '50%',\n textAnchor: 'middle'\n }\n }, textPathOptions);\n const url = this.renderer.url, textWrapper = this.text || this, textPath = textWrapper.textPath, { attributes, enabled } = textPathOptions;\n path = path || (textPath && textPath.path);\n // Remove previously added event\n if (textPath) {\n textPath.undo();\n }\n if (path && enabled) {\n const undo = addEvent(textWrapper, 'afterModifyTree', (e) => {\n if (path && enabled) {\n // Set ID for the path\n let textPathId = path.attr('id');\n if (!textPathId) {\n path.attr('id', textPathId = uniqueKey());\n }\n // Set attributes for the \n const textAttribs = {\n // dx/dy options must by set on (parent), the\n // rest should be set on \n x: 0,\n y: 0\n };\n if (defined(attributes.dx)) {\n textAttribs.dx = attributes.dx;\n delete attributes.dx;\n }\n if (defined(attributes.dy)) {\n textAttribs.dy = attributes.dy;\n delete attributes.dy;\n }\n textWrapper.attr(textAttribs);\n // Handle label properties\n this.attr({ transform: '' });\n if (this.box) {\n this.box = this.box.destroy();\n }\n // Wrap the nodes in a textPath\n const children = e.nodes.slice(0);\n e.nodes.length = 0;\n e.nodes[0] = {\n tagName: 'textPath',\n attributes: extend(attributes, {\n 'text-anchor': attributes.textAnchor,\n href: `${url}#${textPathId}`\n }),\n children\n };\n }\n });\n // Set the reference\n textWrapper.textPath = { path, undo };\n }\n else {\n textWrapper.attr({ dx: 0, dy: 0 });\n delete textWrapper.textPath;\n }\n if (this.added) {\n // Rebuild text after added\n textWrapper.textCache = '';\n this.renderer.buildText(textWrapper);\n }\n return this;\n }\n /**\n * Add a shadow to the element. In styled mode, this method is not used,\n * instead use `defs` and filters.\n *\n * @example\n * renderer.rect(10, 100, 100, 100)\n * .attr({ fill: 'red' })\n * .shadow(true);\n *\n * @function Highcharts.SVGElement#shadow\n *\n * @param {boolean|Highcharts.ShadowOptionsObject} [shadowOptions] The\n * shadow options. If `true`, the default options are applied. If\n * `false`, the current shadow will be removed.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n shadow(shadowOptions) {\n var _a;\n const { renderer } = this, options = merge(((_a = this.parentGroup) === null || _a === void 0 ? void 0 : _a.rotation) === 90 ? {\n offsetX: -1,\n offsetY: -1\n } : {}, isObject(shadowOptions) ? shadowOptions : {}), id = renderer.shadowDefinition(options);\n return this.attr({\n filter: shadowOptions ?\n `url(${renderer.url}#${id})` :\n 'none'\n });\n }\n /**\n * Show the element after it has been hidden.\n *\n * @function Highcharts.SVGElement#show\n *\n * @param {boolean} [inherit=true]\n * Set the visibility attribute to `inherit` rather than `visible`.\n * The difference is that an element with `visibility=\"visible\"`\n * will be visible even if the parent is hidden.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n show(inherit = true) {\n return this.attr({ visibility: inherit ? 'inherit' : 'visible' });\n }\n /**\n * Set the stroke-width and record it on the SVGElement\n *\n * @private\n * @function Highcharts.SVGElement#strokeSetter\n * @param {number|string|ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n 'stroke-widthSetter'(value, key, element) {\n // Record it for quick access in getter\n this[key] = value;\n element.setAttribute(key, value);\n }\n /**\n * Get the computed stroke width in pixel values. This is used extensively\n * when drawing shapes to ensure the shapes are rendered crisp and\n * positioned correctly relative to each other. Using\n * `shape-rendering: crispEdges` leaves us less control over positioning,\n * for example when we want to stack columns next to each other, or position\n * things pixel-perfectly within the plot box.\n *\n * The common pattern when placing a shape is:\n * - Create the SVGElement and add it to the DOM. In styled mode, it will\n * now receive a stroke width from the style sheet. In classic mode we\n * will add the `stroke-width` attribute.\n * - Read the computed `elem.strokeWidth()`.\n * - Place it based on the stroke width.\n *\n * @function Highcharts.SVGElement#strokeWidth\n *\n * @return {number}\n * The stroke width in pixels. Even if the given stroke widtch (in CSS or by\n * attributes) is based on `em` or other units, the pixel size is returned.\n */\n strokeWidth() {\n // In non-styled mode, read the stroke width as set by .attr\n if (!this.renderer.styledMode) {\n return this['stroke-width'] || 0;\n }\n // In styled mode, read computed stroke width\n const val = this.getStyle('stroke-width');\n let ret = 0, dummy;\n // Read pixel values directly\n if (val.indexOf('px') === val.length - 2) {\n ret = pInt(val);\n // Other values like em, pt etc need to be measured\n }\n else if (val !== '') {\n dummy = doc.createElementNS(SVG_NS, 'rect');\n attr(dummy, {\n width: val,\n 'stroke-width': 0\n });\n this.element.parentNode.appendChild(dummy);\n ret = dummy.getBBox().width;\n dummy.parentNode.removeChild(dummy);\n }\n return ret;\n }\n /**\n * If one of the symbol size affecting parameters are changed,\n * check all the others only once for each call to an element's\n * .attr() method\n *\n * @private\n * @function Highcharts.SVGElement#symbolAttr\n *\n * @param {Highcharts.SVGAttributes} hash\n * The attributes to set.\n */\n symbolAttr(hash) {\n const wrapper = this;\n SVGElement.symbolCustomAttribs.forEach(function (key) {\n wrapper[key] = pick(hash[key], wrapper[key]);\n });\n wrapper.attr({\n d: wrapper.renderer.symbols[wrapper.symbolName](wrapper.x, wrapper.y, wrapper.width, wrapper.height, wrapper)\n });\n }\n /**\n * @private\n * @function Highcharts.SVGElement#textSetter\n * @param {string} value\n */\n textSetter(value) {\n if (value !== this.textStr) {\n // Delete size caches when the text changes\n // delete this.bBox; // old code in series-label\n delete this.textPxLength;\n this.textStr = value;\n if (this.added) {\n this.renderer.buildText(this);\n }\n }\n }\n /**\n * @private\n * @function Highcharts.SVGElement#titleSetter\n * @param {string} value\n */\n titleSetter(value) {\n const el = this.element;\n const titleNode = el.getElementsByTagName('title')[0] ||\n doc.createElementNS(this.SVG_NS, 'title');\n // Move to first child\n if (el.insertBefore) {\n el.insertBefore(titleNode, el.firstChild);\n }\n else {\n el.appendChild(titleNode);\n }\n // Replace text content and escape markup\n titleNode.textContent =\n // #3276, #3895\n String(pick(value, ''))\n .replace(/<[^>]*>/g, '')\n .replace(/</g, '<')\n .replace(/>/g, '>');\n }\n /**\n * Bring the element to the front. Alternatively, a new zIndex can be set.\n *\n * @sample highcharts/members/element-tofront/\n * Click an element to bring it to front\n *\n * @function Highcharts.SVGElement#toFront\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n toFront() {\n const element = this.element;\n element.parentNode.appendChild(element);\n return this;\n }\n /**\n * Move an object and its children by x and y values.\n *\n * @function Highcharts.SVGElement#translate\n *\n * @param {number} x\n * The x value.\n *\n * @param {number} y\n * The y value.\n *\n * @return {Highcharts.SVGElement}\n * Translated element.\n */\n translate(x, y) {\n return this.attr({\n translateX: x,\n translateY: y\n });\n }\n /**\n * Update the transform attribute based on internal properties. Deals with\n * the custom `translateX`, `translateY`, `rotation`, `scaleX` and `scaleY`\n * attributes and updates the SVG `transform` attribute.\n *\n * @private\n * @function Highcharts.SVGElement#updateTransform\n */\n updateTransform() {\n const { element, matrix, rotation = 0, scaleX, scaleY, translateX = 0, translateY = 0 } = this;\n // Apply translate. Nearly all transformed elements have translation,\n // so instead of checking for translate = 0, do it always (#1767,\n // #1846).\n const transform = ['translate(' + translateX + ',' + translateY + ')'];\n // apply matrix\n if (defined(matrix)) {\n transform.push('matrix(' + matrix.join(',') + ')');\n }\n // Apply rotation\n if (rotation) { // text rotation or inverted chart\n transform.push('rotate(' + rotation + ' ' +\n pick(this.rotationOriginX, element.getAttribute('x'), 0) +\n ' ' +\n pick(this.rotationOriginY, element.getAttribute('y') || 0) + ')');\n }\n // apply scale\n if (defined(scaleX) || defined(scaleY)) {\n transform.push('scale(' + pick(scaleX, 1) + ' ' + pick(scaleY, 1) + ')');\n }\n if (transform.length && !(this.text || this).textPath) {\n element.setAttribute('transform', transform.join(' '));\n }\n }\n /**\n * @private\n * @function Highcharts.SVGElement#visibilitySetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n visibilitySetter(value, key, element) {\n // IE9-11 doesn't handle visibilty:inherit well, so we remove the\n // attribute instead (#2881, #3909)\n if (value === 'inherit') {\n element.removeAttribute(key);\n }\n else if (this[key] !== value) { // #6747\n element.setAttribute(key, value);\n }\n this[key] = value;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#xGetter\n */\n xGetter(key) {\n if (this.element.nodeName === 'circle') {\n if (key === 'x') {\n key = 'cx';\n }\n else if (key === 'y') {\n key = 'cy';\n }\n }\n return this._defaultGetter(key);\n }\n /**\n * @private\n * @function Highcharts.SVGElement#zIndexSetter\n */\n zIndexSetter(value, key) {\n const renderer = this.renderer, parentGroup = this.parentGroup, parentWrapper = parentGroup || renderer, parentNode = parentWrapper.element || renderer.box, element = this.element, svgParent = parentNode === renderer.box;\n let childNodes, otherElement, otherZIndex, inserted = false, undefinedOtherZIndex, run = this.added, i;\n if (defined(value)) {\n // So we can read it for other elements in the group\n element.setAttribute('data-z-index', value);\n value = +value;\n if (this[key] === value) {\n // Only update when needed (#3865)\n run = false;\n }\n }\n else if (defined(this[key])) {\n element.removeAttribute('data-z-index');\n }\n this[key] = value;\n // Insert according to this and other elements' zIndex. Before .add() is\n // called, nothing is done. Then on add, or by later calls to\n // zIndexSetter, the node is placed on the right place in the DOM.\n if (run) {\n value = this.zIndex;\n if (value && parentGroup) {\n parentGroup.handleZ = true;\n }\n childNodes = parentNode.childNodes;\n for (i = childNodes.length - 1; i >= 0 && !inserted; i--) {\n otherElement = childNodes[i];\n otherZIndex = otherElement.getAttribute('data-z-index');\n undefinedOtherZIndex = !defined(otherZIndex);\n if (otherElement !== element) {\n if (\n // Negative zIndex versus no zIndex:\n // On all levels except the highest. If the parent is\n // , then we don't want to put items before \n // or \n value < 0 &&\n undefinedOtherZIndex &&\n !svgParent &&\n !i) {\n parentNode.insertBefore(element, childNodes[i]);\n inserted = true;\n }\n else if (\n // Insert after the first element with a lower zIndex\n pInt(otherZIndex) <= value ||\n // If negative zIndex, add this before first undefined\n // zIndex element\n (undefinedOtherZIndex &&\n (!defined(value) || value >= 0))) {\n parentNode.insertBefore(element, childNodes[i + 1]);\n inserted = true;\n }\n }\n }\n if (!inserted) {\n parentNode.insertBefore(element, childNodes[svgParent ? 3 : 0]);\n inserted = true;\n }\n }\n return inserted;\n }\n }\n // Custom attributes used for symbols, these should be filtered out when\n // setting SVGElement attributes (#9375).\n SVGElement.symbolCustomAttribs = [\n 'anchorX',\n 'anchorY',\n 'clockwise',\n 'end',\n 'height',\n 'innerR',\n 'r',\n 'start',\n 'width',\n 'x',\n 'y'\n ];\n // Some shared setters and getters\n SVGElement.prototype.strokeSetter = SVGElement.prototype.fillSetter;\n SVGElement.prototype.yGetter = SVGElement.prototype.xGetter;\n SVGElement.prototype.matrixSetter =\n SVGElement.prototype.rotationOriginXSetter =\n SVGElement.prototype.rotationOriginYSetter =\n SVGElement.prototype.rotationSetter =\n SVGElement.prototype.scaleXSetter =\n SVGElement.prototype.scaleYSetter =\n SVGElement.prototype.translateXSetter =\n SVGElement.prototype.translateYSetter =\n SVGElement.prototype.verticalAlignSetter = function (value, key) {\n this[key] = value;\n this.doTransform = true;\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Reference to the global SVGElement class as a workaround for a name conflict\n * in the Highcharts namespace.\n *\n * @global\n * @typedef {global.SVGElement} GlobalSVGElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The horizontal alignment of an element.\n *\n * @typedef {\"center\"|\"left\"|\"right\"} Highcharts.AlignValue\n */\n /**\n * Options to align the element relative to the chart or another box.\n *\n * @interface Highcharts.AlignObject\n */ /**\n * Horizontal alignment. Can be one of `left`, `center` and `right`.\n *\n * @name Highcharts.AlignObject#align\n * @type {Highcharts.AlignValue|undefined}\n *\n * @default left\n */ /**\n * Vertical alignment. Can be one of `top`, `middle` and `bottom`.\n *\n * @name Highcharts.AlignObject#verticalAlign\n * @type {Highcharts.VerticalAlignValue|undefined}\n *\n * @default top\n */ /**\n * Horizontal pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#x\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Vertical pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#y\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Use the `transform` attribute with translateX and translateY custom\n * attributes to align this elements rather than `x` and `y` attributes.\n *\n * @name Highcharts.AlignObject#alignByTranslate\n * @type {boolean|undefined}\n *\n * @default false\n */\n /**\n * Bounding box of an element.\n *\n * @interface Highcharts.BBoxObject\n * @extends Highcharts.PositionObject\n */ /**\n * Height of the bounding box.\n *\n * @name Highcharts.BBoxObject#height\n * @type {number}\n */ /**\n * Width of the bounding box.\n *\n * @name Highcharts.BBoxObject#width\n * @type {number}\n */ /**\n * Horizontal position of the bounding box.\n *\n * @name Highcharts.BBoxObject#x\n * @type {number}\n */ /**\n * Vertical position of the bounding box.\n *\n * @name Highcharts.BBoxObject#y\n * @type {number}\n */\n /**\n * An object of key-value pairs for SVG attributes. Attributes in Highcharts\n * elements for the most parts correspond to SVG, but some are specific to\n * Highcharts, like `zIndex`, `rotation`, `rotationOriginX`,\n * `rotationOriginY`, `translateX`, `translateY`, `scaleX` and `scaleY`. SVG\n * attributes containing a hyphen are _not_ camel-cased, they should be\n * quoted to preserve the hyphen.\n *\n * @example\n * {\n * 'stroke': '#ff0000', // basic\n * 'stroke-width': 2, // hyphenated\n * 'rotation': 45 // custom\n * 'd': ['M', 10, 10, 'L', 30, 30, 'z'] // path definition, note format\n * }\n *\n * @interface Highcharts.SVGAttributes\n */ /**\n * @name Highcharts.SVGAttributes#[key:string]\n * @type {*}\n */ /**\n * @name Highcharts.SVGAttributes#d\n * @type {string|Highcharts.SVGPathArray|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dx\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dy\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#fill\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#matrix\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotation\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#stroke\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#style\n * @type {string|Highcharts.CSSObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#zIndex\n * @type {number|undefined}\n */\n /**\n * An SVG DOM element. The type is a reference to the regular SVGElement in the\n * global scope.\n *\n * @typedef {globals.GlobalSVGElement} Highcharts.SVGDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The vertical alignment of an element.\n *\n * @typedef {\"bottom\"|\"middle\"|\"top\"} Highcharts.VerticalAlignValue\n */\n ''; // keeps doclets above in JS file\n\n return SVGElement;\n });\n _registerModule(_modules, 'Core/Renderer/RendererRegistry.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var RendererRegistry;\n (function (RendererRegistry) {\n /* *\n *\n * Constants\n *\n * */\n RendererRegistry.rendererTypes = {};\n /* *\n *\n * Variables\n *\n * */\n let defaultRenderer;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Gets a registered renderer class. If no renderer type is provided or the\n * requested renderer was not founded, the default renderer is returned.\n *\n * @param {string} [rendererType]\n * Renderer type or the default renderer.\n *\n * @return {Highcharts.Class}\n * Returns the requested renderer class or the default renderer class.\n */\n function getRendererType(rendererType = defaultRenderer) {\n return (RendererRegistry.rendererTypes[rendererType] || RendererRegistry.rendererTypes[defaultRenderer]);\n }\n RendererRegistry.getRendererType = getRendererType;\n /**\n * Register a renderer class.\n *\n * @param {string} rendererType\n * Renderer type to register.\n *\n * @param {Highcharts.Class} rendererClass\n * Returns the requested renderer class or the default renderer class.\n *\n * @param {boolean} setAsDefault\n * Sets the renderer class as the default renderer.\n */\n function registerRendererType(rendererType, rendererClass, setAsDefault) {\n RendererRegistry.rendererTypes[rendererType] = rendererClass;\n if (!defaultRenderer || setAsDefault) {\n defaultRenderer = rendererType;\n H.Renderer = rendererClass; // compatibility\n }\n }\n RendererRegistry.registerRendererType = registerRendererType;\n })(RendererRegistry || (RendererRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererRegistry;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGLabel.js', [_modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, extend, isNumber, merge, pick, removeEvent } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG label to render text.\n * @private\n * @class\n * @name Highcharts.SVGLabel\n * @augments Highcharts.SVGElement\n */\n class SVGLabel extends SVGElement {\n /* *\n *\n * Constructor\n *\n * */\n constructor(renderer, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n super();\n this.paddingLeftSetter = this.paddingSetter;\n this.paddingRightSetter = this.paddingSetter;\n this.init(renderer, 'g');\n this.textStr = str;\n this.x = x;\n this.y = y;\n this.anchorX = anchorX;\n this.anchorY = anchorY;\n this.baseline = baseline;\n this.className = className;\n this.addClass(className === 'button' ?\n 'highcharts-no-tooltip' :\n 'highcharts-label');\n if (className) {\n this.addClass('highcharts-' + className);\n }\n // Create the text element. An undefined text content prevents redundant\n // box calculation (#16121)\n this.text = renderer.text(void 0, 0, 0, useHTML).attr({ zIndex: 1 });\n // Validate the shape argument\n let hasBGImage;\n if (typeof shape === 'string') {\n hasBGImage = /^url\\((.*?)\\)$/.test(shape);\n if (hasBGImage || this.renderer.symbols[shape]) {\n this.symbolKey = shape;\n }\n }\n this.bBox = SVGLabel.emptyBBox;\n this.padding = 3;\n this.baselineOffset = 0;\n this.needsBox = renderer.styledMode || hasBGImage;\n this.deferredAttr = {};\n this.alignFactor = 0;\n }\n /* *\n *\n * Functions\n *\n * */\n alignSetter(value) {\n const alignFactor = ({\n left: 0,\n center: 0.5,\n right: 1\n })[value];\n if (alignFactor !== this.alignFactor) {\n this.alignFactor = alignFactor;\n // Bounding box exists, means we're dynamically changing\n if (this.bBox && isNumber(this.xSetting)) {\n this.attr({ x: this.xSetting }); // #5134\n }\n }\n }\n anchorXSetter(value, key) {\n this.anchorX = value;\n this.boxAttr(key, Math.round(value) - this.getCrispAdjust() - this.xSetting);\n }\n anchorYSetter(value, key) {\n this.anchorY = value;\n this.boxAttr(key, value - this.ySetting);\n }\n /*\n * Set a box attribute, or defer it if the box is not yet created\n */\n boxAttr(key, value) {\n if (this.box) {\n this.box.attr(key, value);\n }\n else {\n this.deferredAttr[key] = value;\n }\n }\n /*\n * Pick up some properties and apply them to the text instead of the\n * wrapper.\n */\n css(styles) {\n if (styles) {\n const textStyles = {};\n // Create a copy to avoid altering the original object\n // (#537)\n styles = merge(styles);\n SVGLabel.textProps.forEach((prop) => {\n if (typeof styles[prop] !== 'undefined') {\n textStyles[prop] = styles[prop];\n delete styles[prop];\n }\n });\n this.text.css(textStyles);\n // Update existing text, box (#9400, #12163, #18212)\n if ('fontSize' in textStyles || 'fontWeight' in textStyles) {\n this.updateTextPadding();\n }\n else if ('width' in textStyles || 'textOverflow' in textStyles) {\n this.updateBoxSize();\n }\n }\n return SVGElement.prototype.css.call(this, styles);\n }\n /*\n * Destroy and release memory.\n */\n destroy() {\n // Added by button implementation\n removeEvent(this.element, 'mouseenter');\n removeEvent(this.element, 'mouseleave');\n if (this.text) {\n this.text.destroy();\n }\n if (this.box) {\n this.box = this.box.destroy();\n }\n // Call base implementation to destroy the rest\n SVGElement.prototype.destroy.call(this);\n return void 0;\n }\n fillSetter(value, key) {\n if (value) {\n this.needsBox = true;\n }\n // for animation getter (#6776)\n this.fill = value;\n this.boxAttr(key, value);\n }\n /*\n * Return the bounding box of the box, not the group.\n */\n getBBox() {\n // If we have a text string and the DOM bBox was 0, it typically means\n // that the label was first rendered hidden, so we need to update the\n // bBox (#15246)\n if (this.textStr && this.bBox.width === 0 && this.bBox.height === 0) {\n this.updateBoxSize();\n }\n const padding = this.padding;\n const paddingLeft = pick(this.paddingLeft, padding);\n return {\n width: this.width,\n height: this.height,\n x: this.bBox.x - paddingLeft,\n y: this.bBox.y - padding\n };\n }\n getCrispAdjust() {\n return this.renderer.styledMode && this.box ?\n this.box.strokeWidth() % 2 / 2 :\n (this['stroke-width'] ? parseInt(this['stroke-width'], 10) : 0) % 2 / 2;\n }\n heightSetter(value) {\n this.heightSetting = value;\n }\n /*\n * After the text element is added, get the desired size of the border\n * box and add it before the text in the DOM.\n */\n onAdd() {\n this.text.add(this);\n this.attr({\n // Alignment is available now (#3295, 0 not rendered if given\n // as a value)\n text: pick(this.textStr, ''),\n x: this.x || 0,\n y: this.y || 0\n });\n if (this.box && defined(this.anchorX)) {\n this.attr({\n anchorX: this.anchorX,\n anchorY: this.anchorY\n });\n }\n }\n paddingSetter(value, key) {\n if (!isNumber(value)) {\n this[key] = void 0;\n }\n else if (value !== this[key]) {\n this[key] = value;\n this.updateTextPadding();\n }\n }\n rSetter(value, key) {\n this.boxAttr(key, value);\n }\n strokeSetter(value, key) {\n // for animation getter (#6776)\n this.stroke = value;\n this.boxAttr(key, value);\n }\n 'stroke-widthSetter'(value, key) {\n if (value) {\n this.needsBox = true;\n }\n this['stroke-width'] = value;\n this.boxAttr(key, value);\n }\n 'text-alignSetter'(value) {\n this.textAlign = value;\n }\n textSetter(text) {\n if (typeof text !== 'undefined') {\n // Must use .attr to ensure transforms are done (#10009)\n this.text.attr({ text });\n }\n this.updateTextPadding();\n }\n /*\n * This function runs after the label is added to the DOM (when the bounding\n * box is available), and after the text of the label is updated to detect\n * the new bounding box and reflect it in the border box.\n */\n updateBoxSize() {\n const text = this.text, attribs = {}, padding = this.padding, \n // #12165 error when width is null (auto)\n // #12163 when fontweight: bold, recalculate bBox withot cache\n // #3295 && 3514 box failure when string equals 0\n bBox = this.bBox = (((!isNumber(this.widthSetting) ||\n !isNumber(this.heightSetting) ||\n this.textAlign) && defined(text.textStr)) ?\n text.getBBox() :\n SVGLabel.emptyBBox);\n let crispAdjust;\n this.width = this.getPaddedWidth();\n this.height = (this.heightSetting || bBox.height || 0) + 2 * padding;\n const metrics = this.renderer.fontMetrics(text);\n // Update the label-scoped y offset. Math.min because of inline\n // style (#9400)\n this.baselineOffset = padding + Math.min(\n // When applicable, use the font size of the first line (#15707)\n (this.text.firstLineMetrics || metrics).b, \n // When the height is 0, there is no bBox, so go with the font\n // metrics. Highmaps CSS demos.\n bBox.height || Infinity);\n // #15491: Vertical centering\n if (this.heightSetting) {\n this.baselineOffset += (this.heightSetting - metrics.h) / 2;\n }\n if (this.needsBox && !text.textPath) {\n // Create the border box if it is not already present\n if (!this.box) {\n // Symbol definition exists (#5324)\n const box = this.box = this.symbolKey ?\n this.renderer.symbol(this.symbolKey) :\n this.renderer.rect();\n box.addClass(// Don't use label className for buttons\n (this.className === 'button' ?\n '' : 'highcharts-label-box') +\n (this.className ?\n ' highcharts-' + this.className + '-box' : ''));\n box.add(this);\n }\n crispAdjust = this.getCrispAdjust();\n attribs.x = crispAdjust;\n attribs.y = ((this.baseline ? -this.baselineOffset : 0) + crispAdjust);\n // Apply the box attributes\n attribs.width = Math.round(this.width);\n attribs.height = Math.round(this.height);\n this.box.attr(extend(attribs, this.deferredAttr));\n this.deferredAttr = {};\n }\n }\n /*\n * This function runs after setting text or padding, but only if padding\n * is changed.\n */\n updateTextPadding() {\n const text = this.text;\n if (!text.textPath) {\n this.updateBoxSize();\n // Determine y based on the baseline\n const textY = this.baseline ? 0 : this.baselineOffset;\n let textX = pick(this.paddingLeft, this.padding);\n // compensate for alignment\n if (defined(this.widthSetting) &&\n this.bBox &&\n (this.textAlign === 'center' || this.textAlign === 'right')) {\n textX += { center: 0.5, right: 1 }[this.textAlign] * (this.widthSetting - this.bBox.width);\n }\n // update if anything changed\n if (textX !== text.x || textY !== text.y) {\n text.attr('x', textX);\n // #8159 - prevent misplaced data labels in treemap\n // (useHTML: true)\n if (text.hasBoxWidthChanged) {\n this.bBox = text.getBBox(true);\n }\n if (typeof textY !== 'undefined') {\n text.attr('y', textY);\n }\n }\n // record current values\n text.x = textX;\n text.y = textY;\n }\n }\n widthSetter(value) {\n // width:auto => null\n this.widthSetting = isNumber(value) ? value : void 0;\n }\n getPaddedWidth() {\n const padding = this.padding;\n const paddingLeft = pick(this.paddingLeft, padding);\n const paddingRight = pick(this.paddingRight, padding);\n return ((this.widthSetting || this.bBox.width || 0) +\n paddingLeft +\n paddingRight);\n }\n xSetter(value) {\n this.x = value; // for animation getter\n if (this.alignFactor) {\n value -= this.alignFactor * this.getPaddedWidth();\n // Force animation even when setting to the same value (#7898)\n this['forceAnimate:x'] = true;\n }\n this.xSetting = Math.round(value);\n this.attr('translateX', this.xSetting);\n }\n ySetter(value) {\n this.ySetting = this.y = Math.round(value);\n this.attr('translateY', this.ySetting);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n SVGLabel.emptyBBox = {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n /**\n * For labels, these CSS properties are applied to the `text` node directly.\n *\n * @private\n * @name Highcharts.SVGLabel#textProps\n * @type {Array}\n */\n SVGLabel.textProps = [\n 'color', 'direction', 'fontFamily', 'fontSize', 'fontStyle',\n 'fontWeight', 'lineHeight', 'textAlign', 'textDecoration',\n 'textOutline', 'textOverflow', 'whiteSpace', 'width'\n ];\n /* *\n *\n * Default Export\n *\n * */\n\n return SVGLabel;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/Symbols.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, isNumber, pick } = U;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable require-jsdoc, valid-jsdoc */\n function arc(cx, cy, w, h, options) {\n const arc = [];\n if (options) {\n const start = options.start || 0, rx = pick(options.r, w), ry = pick(options.r, h || w), proximity = 0.001, fullCircle = (Math.abs((options.end || 0) - start - 2 * Math.PI) <\n proximity), \n // Substract a small number to prevent cos and sin of start\n // and end from becoming equal on 360 arcs (related: #1561)\n end = (options.end || 0) - proximity, innerRadius = options.innerR, open = pick(options.open, fullCircle), cosStart = Math.cos(start), sinStart = Math.sin(start), cosEnd = Math.cos(end), sinEnd = Math.sin(end), \n // Proximity takes care of rounding errors around PI (#6971)\n longArc = pick(options.longArc, end - start - Math.PI < proximity ? 0 : 1);\n let arcSegment = [\n 'A',\n rx,\n ry,\n 0,\n longArc,\n pick(options.clockwise, 1),\n cx + rx * cosEnd,\n cy + ry * sinEnd\n ];\n arcSegment.params = { start, end, cx, cy }; // Memo for border radius\n arc.push([\n 'M',\n cx + rx * cosStart,\n cy + ry * sinStart\n ], arcSegment);\n if (defined(innerRadius)) {\n arcSegment = [\n 'A',\n innerRadius,\n innerRadius,\n 0,\n longArc,\n // Clockwise - opposite to the outer arc clockwise\n defined(options.clockwise) ? 1 - options.clockwise : 0,\n cx + innerRadius * cosStart,\n cy + innerRadius * sinStart\n ];\n // Memo for border radius\n arcSegment.params = {\n start: end,\n end: start,\n cx,\n cy\n };\n arc.push(open ?\n [\n 'M',\n cx + innerRadius * cosEnd,\n cy + innerRadius * sinEnd\n ] : [\n 'L',\n cx + innerRadius * cosEnd,\n cy + innerRadius * sinEnd\n ], arcSegment);\n }\n if (!open) {\n arc.push(['Z']);\n }\n }\n return arc;\n }\n /**\n * Callout shape used for default tooltips.\n */\n function callout(x, y, w, h, options) {\n const arrowLength = 6, halfDistance = 6, r = Math.min((options && options.r) || 0, w, h), safeDistance = r + halfDistance, anchorX = options && options.anchorX, anchorY = options && options.anchorY || 0;\n const path = roundedRect(x, y, w, h, { r });\n if (!isNumber(anchorX)) {\n return path;\n }\n // Anchor on right side\n if (x + anchorX >= w) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(3, 1, ['L', x + w, anchorY - halfDistance], ['L', x + w + arrowLength, anchorY], ['L', x + w, anchorY + halfDistance], ['L', x + w, y + h - r]);\n // Simple connector\n }\n else {\n path.splice(3, 1, ['L', x + w, h / 2], ['L', anchorX, anchorY], ['L', x + w, h / 2], ['L', x + w, y + h - r]);\n }\n // Anchor on left side\n }\n else if (x + anchorX <= 0) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(7, 1, ['L', x, anchorY + halfDistance], ['L', x - arrowLength, anchorY], ['L', x, anchorY - halfDistance], ['L', x, y + r]);\n // Simple connector\n }\n else {\n path.splice(7, 1, ['L', x, h / 2], ['L', anchorX, anchorY], ['L', x, h / 2], ['L', x, y + r]);\n }\n }\n else if ( // replace bottom\n anchorY &&\n anchorY > h &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(5, 1, ['L', anchorX + halfDistance, y + h], ['L', anchorX, y + h + arrowLength], ['L', anchorX - halfDistance, y + h], ['L', x + r, y + h]);\n }\n else if ( // replace top\n anchorY &&\n anchorY < 0 &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(1, 1, ['L', anchorX - halfDistance, y], ['L', anchorX, y - arrowLength], ['L', anchorX + halfDistance, y], ['L', w - r, y]);\n }\n return path;\n }\n function circle(x, y, w, h) {\n // Return a full arc\n return arc(x + w / 2, y + h / 2, w / 2, h / 2, {\n start: Math.PI * 0.5,\n end: Math.PI * 2.5,\n open: false\n });\n }\n function diamond(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h / 2],\n ['L', x + w / 2, y + h],\n ['L', x, y + h / 2],\n ['Z']\n ];\n }\n // #15291\n function rect(x, y, w, h, options) {\n if (options && options.r) {\n return roundedRect(x, y, w, h, options);\n }\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function roundedRect(x, y, w, h, options) {\n const r = (options === null || options === void 0 ? void 0 : options.r) || 0;\n return [\n ['M', x + r, y],\n ['L', x + w - r, y],\n ['A', r, r, 0, 0, 1, x + w, y + r],\n ['L', x + w, y + h - r],\n ['A', r, r, 0, 0, 1, x + w - r, y + h],\n ['L', x + r, y + h],\n ['A', r, r, 0, 0, 1, x, y + h - r],\n ['L', x, y + r],\n ['A', r, r, 0, 0, 1, x + r, y],\n ['Z'] // top-left corner\n ];\n }\n function triangle(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function triangleDown(x, y, w, h) {\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w / 2, y + h],\n ['Z']\n ];\n }\n const Symbols = {\n arc,\n callout,\n circle,\n diamond,\n rect,\n roundedRect,\n square: rect,\n triangle,\n 'triangle-down': triangleDown\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return Symbols;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/TextBuilder.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (AST, H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { doc, SVG_NS, win } = H;\n const { attr, extend, fireEvent, isString, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG Text Builder\n * @private\n * @class\n * @name Highcharts.TextBuilder\n */\n class TextBuilder {\n constructor(svgElement) {\n const textStyles = svgElement.styles;\n this.renderer = svgElement.renderer;\n this.svgElement = svgElement;\n this.width = svgElement.textWidth;\n this.textLineHeight = textStyles && textStyles.lineHeight;\n this.textOutline = textStyles && textStyles.textOutline;\n this.ellipsis = Boolean(textStyles && textStyles.textOverflow === 'ellipsis');\n this.noWrap = Boolean(textStyles && textStyles.whiteSpace === 'nowrap');\n }\n /**\n * Build an SVG representation of the pseudo HTML given in the object's\n * svgElement.\n *\n * @private\n *\n * @return {void}.\n */\n buildSVG() {\n const wrapper = this.svgElement, textNode = wrapper.element, renderer = wrapper.renderer, textStr = pick(wrapper.textStr, '').toString(), hasMarkup = textStr.indexOf('<') !== -1, childNodes = textNode.childNodes, tempParent = !wrapper.added && renderer.box, regexMatchBreaks = //g, \n // The buildText code is quite heavy, so if we're not changing\n // something that affects the text, skip it (#6113).\n textCache = [\n textStr,\n this.ellipsis,\n this.noWrap,\n this.textLineHeight,\n this.textOutline,\n wrapper.getStyle('font-size'),\n this.width\n ].join(',');\n if (textCache === wrapper.textCache) {\n return;\n }\n wrapper.textCache = textCache;\n delete wrapper.actualWidth;\n // Remove old text\n for (let i = childNodes.length; i--;) {\n textNode.removeChild(childNodes[i]);\n }\n // Simple strings, add text directly and return\n if (!hasMarkup &&\n !this.ellipsis &&\n !this.width &&\n !wrapper.textPath &&\n (textStr.indexOf(' ') === -1 ||\n (this.noWrap && !regexMatchBreaks.test(textStr)))) {\n textNode.appendChild(doc.createTextNode(this.unescapeEntities(textStr)));\n // Complex strings, add more logic\n }\n else if (textStr !== '') {\n if (tempParent) {\n // attach it to the DOM to read offset width and font size\n tempParent.appendChild(textNode);\n }\n // Step 1. Parse the markup safely and directly into a tree\n // structure.\n const ast = new AST(textStr);\n // Step 2. Do as many as we can of the modifications to the tree\n // structure before it is added to the DOM\n this.modifyTree(ast.nodes);\n ast.addToDOM(textNode);\n // Step 3. Some modifications can't be done until the structure is\n // in the DOM, because we need to read computed metrics.\n this.modifyDOM();\n // Add title if an ellipsis was added\n if (this.ellipsis &&\n (textNode.textContent || '').indexOf('\\u2026') !== -1) {\n wrapper.attr('title', this.unescapeEntities(wrapper.textStr || '', ['<', '>']) // #7179\n );\n }\n if (tempParent) {\n tempParent.removeChild(textNode);\n }\n }\n // Apply the text outline\n if (isString(this.textOutline) && wrapper.applyTextOutline) {\n wrapper.applyTextOutline(this.textOutline);\n }\n }\n /**\n * Modify the DOM of the generated SVG structure. This function only does\n * operations that cannot be done until the elements are attached to the\n * DOM, like doing layout based on rendered metrics of the added elements.\n *\n * @private\n *\n */\n modifyDOM() {\n const wrapper = this.svgElement;\n const x = attr(wrapper.element, 'x');\n wrapper.firstLineMetrics = void 0;\n // Remove empty tspans (including breaks) from the beginning because\n // SVG's getBBox doesn't count empty lines. The use case is tooltip\n // where the header is empty. By doing this in the DOM rather than in\n // the AST, we can inspect the textContent directly and don't have to\n // recurse down to look for valid content.\n let firstChild;\n while ((firstChild = wrapper.element.firstChild)) {\n if (/^[\\s\\u200B]*$/.test(firstChild.textContent || ' ')) {\n wrapper.element.removeChild(firstChild);\n }\n else {\n break;\n }\n }\n // Modify hard line breaks by applying the rendered line height\n [].forEach.call(wrapper.element.querySelectorAll('tspan.highcharts-br'), (br, i) => {\n if (br.nextSibling && br.previousSibling) { // #5261\n if (i === 0 && br.previousSibling.nodeType === 1) {\n wrapper.firstLineMetrics = wrapper.renderer\n .fontMetrics(br.previousSibling);\n }\n attr(br, {\n // Since the break is inserted in front of the next\n // line, we need to use the next sibling for the line\n // height\n dy: this.getLineHeight(br.nextSibling),\n x\n });\n }\n });\n // Constrain the line width, either by ellipsis or wrapping\n const width = this.width || 0;\n if (!width) {\n return;\n }\n // Insert soft line breaks into each text node\n const modifyTextNode = (textNode, parentElement) => {\n const text = textNode.textContent || '';\n const words = text\n .replace(/([^\\^])-/g, '$1- ') // Split on hyphens\n // .trim()\n .split(' '); // #1273\n const hasWhiteSpace = !this.noWrap && (words.length > 1 || wrapper.element.childNodes.length > 1);\n const dy = this.getLineHeight(parentElement);\n let lineNo = 0;\n let startAt = wrapper.actualWidth;\n if (this.ellipsis) {\n if (text) {\n this.truncate(textNode, text, void 0, 0, \n // Target width\n Math.max(0, \n // Substract the font face to make room for the\n // ellipsis itself\n width - 0.8 * dy), \n // Build the text to test for\n (text, currentIndex) => text.substring(0, currentIndex) + '\\u2026');\n }\n }\n else if (hasWhiteSpace) {\n const lines = [];\n // Remove preceding siblings in order to make the text length\n // calculation correct in the truncate function\n const precedingSiblings = [];\n while (parentElement.firstChild &&\n parentElement.firstChild !== textNode) {\n precedingSiblings.push(parentElement.firstChild);\n parentElement.removeChild(parentElement.firstChild);\n }\n while (words.length) {\n // Apply the previous line\n if (words.length && !this.noWrap && lineNo > 0) {\n lines.push(textNode.textContent || '');\n textNode.textContent = words.join(' ')\n .replace(/- /g, '-');\n }\n // For each line, truncate the remaining\n // words into the line length.\n this.truncate(textNode, void 0, words, lineNo === 0 ? (startAt || 0) : 0, width, \n // Build the text to test for\n (t, currentIndex) => words\n .slice(0, currentIndex)\n .join(' ')\n .replace(/- /g, '-'));\n startAt = wrapper.actualWidth;\n lineNo++;\n }\n // Reinsert the preceding child nodes\n precedingSiblings.forEach((childNode) => {\n parentElement.insertBefore(childNode, textNode);\n });\n // Insert the previous lines before the original text node\n lines.forEach((line) => {\n // Insert the line\n parentElement.insertBefore(doc.createTextNode(line), textNode);\n // Insert a break\n const br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B'; // zero-width space\n attr(br, { dy, x });\n parentElement.insertBefore(br, textNode);\n });\n }\n };\n // Recurse down the DOM tree and handle line breaks for each text node\n const modifyChildren = ((node) => {\n const childNodes = [].slice.call(node.childNodes);\n childNodes.forEach((childNode) => {\n if (childNode.nodeType === win.Node.TEXT_NODE) {\n modifyTextNode(childNode, node);\n }\n else {\n // Reset word-wrap width readings after hard breaks\n if (childNode.className.baseVal\n .indexOf('highcharts-br') !== -1) {\n wrapper.actualWidth = 0;\n }\n // Recurse down to child node\n modifyChildren(childNode);\n }\n });\n });\n modifyChildren(wrapper.element);\n }\n /**\n * Get the rendered line height of a , or pure text node.\n *\n * @param {DOMElementType|Text} node The node to check for\n *\n * @return {number} The rendered line height\n */\n getLineHeight(node) {\n // If the node is a text node, use its parent\n const element = (node.nodeType === win.Node.TEXT_NODE) ?\n node.parentElement :\n node;\n return this.textLineHeight ?\n parseInt(this.textLineHeight.toString(), 10) :\n this.renderer.fontMetrics(element || this.svgElement.element).h;\n }\n /**\n * Transform a pseudo HTML AST node tree into an SVG structure. We do as\n * much heavy lifting as we can here, before doing the final processing in\n * the modifyDOM function. The original data is mutated.\n *\n * @private\n *\n * @param {ASTNode[]} nodes The AST nodes\n *\n */\n modifyTree(nodes) {\n const modifyChild = (node, i) => {\n const { attributes = {}, children, style = {}, tagName } = node, styledMode = this.renderer.styledMode;\n // Apply styling to text tags\n if (tagName === 'b' || tagName === 'strong') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-strong';\n }\n else {\n style.fontWeight = 'bold';\n }\n }\n else if (tagName === 'i' || tagName === 'em') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-emphasized';\n }\n else {\n style.fontStyle = 'italic';\n }\n }\n // Modify styling\n if (style && style.color) {\n style.fill = style.color;\n }\n // Handle breaks\n if (tagName === 'br') {\n attributes['class'] = 'highcharts-br'; // eslint-disable-line dot-notation\n node.textContent = '\\u200B'; // zero-width space\n // Trim whitespace off the beginning of new lines\n const nextNode = nodes[i + 1];\n if (nextNode && nextNode.textContent) {\n nextNode.textContent =\n nextNode.textContent.replace(/^ +/gm, '');\n }\n // If an anchor has direct text node children, the text is unable to\n // wrap because there is no `getSubStringLength` function on the\n // element. Therefore we need to wrap the child text node or nodes\n // in a tspan. #16173.\n }\n else if (tagName === 'a' &&\n children &&\n children.some((child) => child.tagName === '#text')) {\n node.children = [{ children, tagName: 'tspan' }];\n }\n if (tagName !== '#text' && tagName !== 'a') {\n node.tagName = 'tspan';\n }\n extend(node, { attributes, style });\n // Recurse\n if (children) {\n children\n .filter((c) => c.tagName !== '#text')\n .forEach(modifyChild);\n }\n };\n nodes.forEach(modifyChild);\n fireEvent(this.svgElement, 'afterModifyTree', { nodes });\n }\n /*\n * Truncate the text node contents to a given length. Used when the css\n * width is set. If the `textOverflow` is `ellipsis`, the text is truncated\n * character by character to the given length. If not, the text is\n * word-wrapped line by line.\n */\n truncate(textNode, text, words, startAt, width, getString) {\n const svgElement = this.svgElement;\n const { renderer, rotation } = svgElement;\n // Cache the lengths to avoid checking the same twice\n const lengths = [];\n // Word wrap cannot be truncated to shorter than one word, ellipsis\n // text can be completely blank.\n let minIndex = words ? 1 : 0;\n let maxIndex = (text || words || '').length;\n let currentIndex = maxIndex;\n let str;\n let actualWidth;\n const getSubStringLength = function (charEnd, concatenatedEnd) {\n // charEnd is used when finding the character-by-character\n // break for ellipsis, concatenatedEnd is used for word-by-word\n // break for word wrapping.\n const end = concatenatedEnd || charEnd;\n const parentNode = textNode.parentNode;\n if (parentNode && typeof lengths[end] === 'undefined') {\n // Modern browsers\n if (parentNode.getSubStringLength) {\n // Fails with DOM exception on unit-tests/legend/members\n // of unknown reason. Desired width is 0, text content\n // is \"5\" and end is 1.\n try {\n lengths[end] = startAt +\n parentNode.getSubStringLength(0, words ? end + 1 : end);\n }\n catch (e) {\n '';\n }\n }\n }\n return lengths[end];\n };\n svgElement.rotation = 0; // discard rotation when computing box\n actualWidth = getSubStringLength(textNode.textContent.length);\n if (startAt + actualWidth > width) {\n // Do a binary search for the index where to truncate the text\n while (minIndex <= maxIndex) {\n currentIndex = Math.ceil((minIndex + maxIndex) / 2);\n // When checking words for word-wrap, we need to build the\n // string and measure the subStringLength at the concatenated\n // word length.\n if (words) {\n str = getString(words, currentIndex);\n }\n actualWidth = getSubStringLength(currentIndex, str && str.length - 1);\n if (minIndex === maxIndex) {\n // Complete\n minIndex = maxIndex + 1;\n }\n else if (actualWidth > width) {\n // Too large. Set max index to current.\n maxIndex = currentIndex - 1;\n }\n else {\n // Within width. Set min index to current.\n minIndex = currentIndex;\n }\n }\n // If max index was 0 it means the shortest possible text was also\n // too large. For ellipsis that means only the ellipsis, while for\n // word wrap it means the whole first word.\n if (maxIndex === 0) {\n // Remove ellipsis\n textNode.textContent = '';\n // If the new text length is one less than the original, we don't\n // need the ellipsis\n }\n else if (!(text && maxIndex === text.length - 1)) {\n textNode.textContent = str || getString(text || words, currentIndex);\n }\n }\n // When doing line wrapping, prepare for the next line by removing the\n // items from this line.\n if (words) {\n words.splice(0, currentIndex);\n }\n svgElement.actualWidth = actualWidth;\n svgElement.rotation = rotation; // Apply rotation again.\n }\n /*\n * Un-escape HTML entities based on the public `renderer.escapes` list\n *\n * @private\n *\n * @param {string} inputStr The string to unescape\n * @param {Array} [except] Exceptions\n *\n * @return {string} The processed string\n */\n unescapeEntities(inputStr, except) {\n objectEach(this.renderer.escapes, function (value, key) {\n if (!except || except.indexOf(value) === -1) {\n inputStr = inputStr.toString().replace(new RegExp(value, 'g'), key);\n }\n });\n return inputStr;\n }\n }\n\n return TextBuilder;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGLabel.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Renderer/SVG/TextBuilder.js'], _modules['Core/Utilities.js']], function (AST, Color, H, RendererRegistry, SVGElement, SVGLabel, Symbols, TextBuilder, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { charts, deg2rad, doc, isFirefox, isMS, isWebKit, noop, SVG_NS, symbolSizes, win } = H;\n const { addEvent, attr, createElement, css, defined, destroyObjectProperties, extend, isArray, isNumber, isObject, isString, merge, pick, pInt, uniqueKey } = U;\n /* *\n *\n * Variables\n *\n * */\n let hasInternalReferenceBug;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Allows direct access to the Highcharts rendering layer in order to draw\n * primitive shapes like circles, rectangles, paths or text directly on a chart,\n * or independent from any chart. The SVGRenderer represents a wrapper object\n * for SVG in modern browsers.\n *\n * An existing chart's renderer can be accessed through {@link Chart.renderer}.\n * The renderer can also be used completely decoupled from a chart.\n *\n * @sample highcharts/members/renderer-on-chart\n * Annotating a chart programmatically.\n * @sample highcharts/members/renderer-basic\n * Independent SVG drawing.\n *\n * @example\n * // Use directly without a chart object.\n * let renderer = new Highcharts.Renderer(parentNode, 600, 400);\n *\n * @class\n * @name Highcharts.SVGRenderer\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode.\n * If it does, it will avoid setting presentational attributes in\n * some cases, but not when set explicitly through `.attr` and `.css`\n * etc.\n */\n class SVGRenderer {\n /* *\n *\n * Constructors\n *\n * */\n constructor(container, width, height, style, forExport, allowHTML, styledMode) {\n /* *\n *\n * Properties\n *\n * */\n this.alignedObjects = void 0;\n /**\n * The root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#box\n * @type {Highcharts.SVGDOMElement}\n */\n this.box = void 0;\n /**\n * The wrapper for the root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#boxWrapper\n * @type {Highcharts.SVGElement}\n */\n this.boxWrapper = void 0;\n this.cache = void 0;\n this.cacheKeys = void 0;\n this.chartIndex = void 0;\n /**\n * A pointer to the `defs` node of the root SVG.\n *\n * @name Highcharts.SVGRenderer#defs\n * @type {Highcharts.SVGElement}\n */\n this.defs = void 0;\n this.globalAnimation = void 0;\n this.gradients = void 0;\n this.height = void 0;\n this.imgCount = void 0;\n this.style = void 0;\n /**\n * Page url used for internal references.\n *\n * @private\n * @name Highcharts.SVGRenderer#url\n * @type {string}\n */\n this.url = void 0;\n this.width = void 0;\n this.init(container, width, height, style, forExport, allowHTML, styledMode);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the SVGRenderer. Overridable initializer function that takes\n * the same parameters as the constructor.\n *\n * @function Highcharts.SVGRenderer#init\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode. If it\n * does, it will avoid setting presentational attributes in some cases, but\n * not when set explicitly through `.attr` and `.css` etc.\n */\n init(container, width, height, style, forExport, allowHTML, styledMode) {\n const renderer = this, boxWrapper = renderer\n .createElement('svg')\n .attr({\n version: '1.1',\n 'class': 'highcharts-root'\n }), element = boxWrapper.element;\n if (!styledMode) {\n boxWrapper.css(this.getStyle(style));\n }\n container.appendChild(element);\n // Always use ltr on the container, otherwise text-anchor will be\n // flipped and text appear outside labels, buttons, tooltip etc (#3482)\n attr(container, 'dir', 'ltr');\n // For browsers other than IE, add the namespace attribute (#1978)\n if (container.innerHTML.indexOf('xmlns') === -1) {\n attr(element, 'xmlns', this.SVG_NS);\n }\n this.box = element;\n this.boxWrapper = boxWrapper;\n renderer.alignedObjects = [];\n this.url = this.getReferenceURL();\n // Add description\n const desc = this.createElement('desc').add();\n desc.element.appendChild(doc.createTextNode('Created with Highcharts 11.1.0'));\n renderer.defs = this.createElement('defs').add();\n renderer.allowHTML = allowHTML;\n renderer.forExport = forExport;\n renderer.styledMode = styledMode;\n renderer.gradients = {}; // Object where gradient SvgElements are stored\n renderer.cache = {}; // Cache for numerical bounding boxes\n renderer.cacheKeys = [];\n renderer.imgCount = 0;\n renderer.rootFontSize = boxWrapper.getStyle('font-size');\n renderer.setSize(width, height, false);\n // Issue 110 workaround:\n // In Firefox, if a div is positioned by percentage, its pixel position\n // may land between pixels. The container itself doesn't display this,\n // but an SVG element inside this container will be drawn at subpixel\n // precision. In order to draw sharp lines, this must be compensated\n // for. This doesn't seem to work inside iframes though (like in\n // jsFiddle).\n let subPixelFix, rect;\n if (isFirefox && container.getBoundingClientRect) {\n subPixelFix = function () {\n css(container, { left: 0, top: 0 });\n rect = container.getBoundingClientRect();\n css(container, {\n left: (Math.ceil(rect.left) - rect.left) + 'px',\n top: (Math.ceil(rect.top) - rect.top) + 'px'\n });\n };\n // run the fix now\n subPixelFix();\n // run it on resize\n renderer.unSubPixelFix = addEvent(win, 'resize', subPixelFix);\n }\n }\n /**\n * General method for adding a definition to the SVG `defs` tag. Can be used\n * for gradients, fills, filters etc. Styled mode only. A hook for adding\n * general definitions to the SVG's defs tag. Definitions can be referenced\n * from the CSS by its `id`. Read more in\n * [gradients, shadows and patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns).\n * Styled mode only.\n *\n * @function Highcharts.SVGRenderer#definition\n *\n * @param {Highcharts.ASTNode} def\n * A serialized form of an SVG definition, including children.\n *\n * @return {Highcharts.SVGElement}\n * The inserted node.\n */\n definition(def) {\n const ast = new AST([def]);\n return ast.addToDOM(this.defs.element);\n }\n /**\n * Get the prefix needed for internal URL references to work in certain\n * cases. Some older browser versions had a bug where internal url\n * references in SVG attributes, on the form `url(#some-id)`, would fail if\n * a base tag was present in the page. There were also issues with\n * `history.pushState` related to this prefix.\n *\n * Related issues: #24, #672, #1070, #5244.\n *\n * The affected browsers are:\n * - Chrome <= 53 (May 2018)\n * - Firefox <= 51 (January 2017)\n * - Safari/Mac <= 12.1 (2018 or 2019)\n * - Safari/iOS <= 13\n *\n * @todo Remove this hack when time has passed. All the affected browsers\n * are evergreens, so it is increasingly unlikely that users are affected by\n * the bug.\n *\n * @return {string}\n * The prefix to use. An empty string for modern browsers.\n */\n getReferenceURL() {\n if ((isFirefox || isWebKit) &&\n doc.getElementsByTagName('base').length) {\n // Detect if a clip path is taking effect by performing a hit test\n // outside the clipped area. If the hit element is the rectangle\n // that was supposed to be clipped, the bug is present. This only\n // has to be performed once per page load, so we store the result\n // locally in the module.\n if (!defined(hasInternalReferenceBug)) {\n const id = uniqueKey();\n const ast = new AST([{\n tagName: 'svg',\n attributes: {\n width: 8,\n height: 8\n },\n children: [{\n tagName: 'defs',\n children: [{\n tagName: 'clipPath',\n attributes: {\n id\n },\n children: [{\n tagName: 'rect',\n attributes: {\n width: 4,\n height: 4\n }\n }]\n }]\n }, {\n tagName: 'rect',\n attributes: {\n id: 'hitme',\n width: 8,\n height: 8,\n 'clip-path': `url(#${id})`,\n fill: 'rgba(0,0,0,0.001)'\n }\n }]\n }]);\n const svg = ast.addToDOM(doc.body);\n css(svg, {\n position: 'fixed',\n top: 0,\n left: 0,\n zIndex: 9e5\n });\n const hitElement = doc.elementFromPoint(6, 6);\n hasInternalReferenceBug = (hitElement && hitElement.id) === 'hitme';\n doc.body.removeChild(svg);\n }\n if (hasInternalReferenceBug) {\n return win.location.href\n .split('#')[0] // remove the hash\n .replace(/<[^>]*>/g, '') // wing cut HTML\n // escape parantheses and quotes\n .replace(/([\\('\\)])/g, '\\\\$1')\n // replace spaces (needed for Safari only)\n .replace(/ /g, '%20');\n }\n }\n return '';\n }\n /**\n * Get the global style setting for the renderer.\n *\n * @private\n * @function Highcharts.SVGRenderer#getStyle\n *\n * @param {Highcharts.CSSObject} style\n * Style settings.\n *\n * @return {Highcharts.CSSObject}\n * The style settings mixed with defaults.\n */\n getStyle(style) {\n this.style = extend({\n fontFamily: 'Helvetica, Arial, sans-serif',\n fontSize: '1rem'\n }, style);\n return this.style;\n }\n /**\n * Apply the global style on the renderer, mixed with the default styles.\n *\n * @function Highcharts.SVGRenderer#setStyle\n *\n * @param {Highcharts.CSSObject} style\n * CSS to apply.\n */\n setStyle(style) {\n this.boxWrapper.css(this.getStyle(style));\n }\n /**\n * Detect whether the renderer is hidden. This happens when one of the\n * parent elements has `display: none`. Used internally to detect when we\n * needto render preliminarily in another div to get the text bounding boxes\n * right.\n *\n * @function Highcharts.SVGRenderer#isHidden\n *\n * @return {boolean}\n * True if it is hidden.\n */\n isHidden() {\n return !this.boxWrapper.getBBox().width;\n }\n /**\n * Destroys the renderer and its allocated members.\n *\n * @function Highcharts.SVGRenderer#destroy\n *\n * @return {null}\n * Pass through value.\n */\n destroy() {\n const renderer = this, rendererDefs = renderer.defs;\n renderer.box = null;\n renderer.boxWrapper = renderer.boxWrapper.destroy();\n // Call destroy on all gradient elements\n destroyObjectProperties(renderer.gradients || {});\n renderer.gradients = null;\n renderer.defs = rendererDefs.destroy();\n // Remove sub pixel fix handler (#982)\n if (renderer.unSubPixelFix) {\n renderer.unSubPixelFix();\n }\n renderer.alignedObjects = null;\n return null;\n }\n /**\n * Create a wrapper for an SVG element. Serves as a factory for\n * {@link SVGElement}, but this function is itself mostly called from\n * primitive factories like {@link SVGRenderer#path}, {@link\n * SVGRenderer#rect} or {@link SVGRenderer#text}.\n *\n * @function Highcharts.SVGRenderer#createElement\n *\n * @param {string} nodeName\n * The node name, for example `rect`, `g` etc.\n *\n * @return {Highcharts.SVGElement}\n * The generated SVGElement.\n */\n createElement(nodeName) {\n const wrapper = new this.Element();\n wrapper.init(this, nodeName);\n return wrapper;\n }\n /**\n * Get converted radial gradient attributes according to the radial\n * reference. Used internally from the {@link SVGElement#colorGradient}\n * function.\n *\n * @private\n * @function Highcharts.SVGRenderer#getRadialAttr\n */\n getRadialAttr(radialReference, gradAttr) {\n return {\n cx: (radialReference[0] - radialReference[2] / 2) +\n (gradAttr.cx || 0) * radialReference[2],\n cy: (radialReference[1] - radialReference[2] / 2) +\n (gradAttr.cy || 0) * radialReference[2],\n r: (gradAttr.r || 0) * radialReference[2]\n };\n }\n /**\n * Create a drop shadow definition and return its id\n *\n * @private\n * @function Highcharts.SVGRenderer#shadowDefinition\n *\n * @param {boolean|Highcharts.ShadowOptionsObject} [shadowOptions] The\n * shadow options. If `true`, the default options are applied\n */\n shadowDefinition(shadowOptions) {\n const id = [\n `highcharts-drop-shadow-${this.chartIndex}`,\n ...Object.keys(shadowOptions)\n .map((key) => shadowOptions[key])\n ].join('-').replace(/[^a-z0-9\\-]/g, ''), options = merge({\n color: '#000000',\n offsetX: 1,\n offsetY: 1,\n opacity: 0.15,\n width: 5\n }, shadowOptions);\n if (!this.defs.element.querySelector(`#${id}`)) {\n this.definition({\n tagName: 'filter',\n attributes: {\n id\n },\n children: [{\n tagName: 'feDropShadow',\n attributes: {\n dx: options.offsetX,\n dy: options.offsetY,\n 'flood-color': options.color,\n // Tuned and modified to keep a preserve compatibility\n // with the old settings\n 'flood-opacity': Math.min(options.opacity * 5, 1),\n stdDeviation: options.width / 2\n }\n }]\n });\n }\n return id;\n }\n /**\n * Parse a simple HTML string into SVG tspans. Called internally when text\n * is set on an SVGElement. The function supports a subset of HTML tags, CSS\n * text features like `width`, `text-overflow`, `white-space`, and also\n * attributes like `href` and `style`.\n *\n * @private\n * @function Highcharts.SVGRenderer#buildText\n *\n * @param {Highcharts.SVGElement} wrapper\n * The parent SVGElement.\n */\n buildText(wrapper) {\n new TextBuilder(wrapper).buildSVG();\n }\n /**\n * Returns white for dark colors and black for bright colors, based on W3C's\n * definition of [Relative luminance](\n * https://www.w3.org/WAI/GL/wiki/Relative_luminance).\n *\n * @function Highcharts.SVGRenderer#getContrast\n *\n * @param {Highcharts.ColorString} color\n * The color to get the contrast for.\n *\n * @return {Highcharts.ColorString}\n * The contrast color, either `#000000` or `#FFFFFF`.\n */\n getContrast(color) {\n // #6216, #17273\n const rgba = Color.parse(color).rgba\n .map((b8) => {\n const c = b8 / 255;\n return c <= 0.03928 ?\n c / 12.92 :\n Math.pow((c + 0.055) / 1.055, 2.4);\n });\n // Relative luminance\n const l = 0.2126 * rgba[0] + 0.7152 * rgba[1] + 0.0722 * rgba[2];\n // Use white or black based on which provides more contrast\n return 1.05 / (l + 0.05) > (l + 0.05) / 0.05 ? '#FFFFFF' : '#000000';\n }\n /**\n * Create a button with preset states.\n *\n * @function Highcharts.SVGRenderer#button\n *\n * @param {string} text\n * The text or HTML to draw.\n *\n * @param {number} x\n * The x position of the button's left side.\n *\n * @param {number} y\n * The y position of the button's top side.\n *\n * @param {Highcharts.EventCallbackFunction} callback\n * The function to execute on button click or touch.\n *\n * @param {Highcharts.SVGAttributes} [theme]\n * SVG attributes for the normal state.\n *\n * @param {Highcharts.SVGAttributes} [hoverState]\n * SVG attributes for the hover state.\n *\n * @param {Highcharts.SVGAttributes} [selectState]\n * SVG attributes for the pressed state.\n *\n * @param {Highcharts.SVGAttributes} [disabledState]\n * SVG attributes for the disabled state.\n *\n * @param {Highcharts.SymbolKeyValue} [shape=rect]\n * The shape type.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @return {Highcharts.SVGElement}\n * The button element.\n */\n button(text, x, y, callback, theme = {}, hoverState, selectState, disabledState, shape, useHTML) {\n const label = this.label(text, x, y, shape, void 0, void 0, useHTML, void 0, 'button'), styledMode = this.styledMode, states = theme.states || {};\n let curState = 0;\n theme = merge(theme);\n delete theme.states;\n const normalStyle = merge({\n color: \"#333333\" /* Palette.neutralColor80 */,\n cursor: 'pointer',\n fontSize: '0.8em',\n fontWeight: 'normal'\n }, theme.style);\n delete theme.style;\n // Remove stylable attributes. Pass in the ButtonThemeObject and get the\n // SVGAttributes subset back.\n let normalState = AST.filterUserAttributes(theme);\n // Default, non-stylable attributes\n label.attr(merge({ padding: 8, r: 2 }, normalState));\n // Presentational. The string type is a mistake, it is just for\n // compliance with SVGAttribute and is not used in button theme.\n let hoverStyle, selectStyle, disabledStyle;\n if (!styledMode) {\n // Normal state - prepare the attributes\n normalState = merge({\n fill: \"#f7f7f7\" /* Palette.neutralColor3 */,\n stroke: \"#cccccc\" /* Palette.neutralColor20 */,\n 'stroke-width': 1\n }, normalState);\n // Hover state\n hoverState = merge(normalState, {\n fill: \"#e6e6e6\" /* Palette.neutralColor10 */\n }, AST.filterUserAttributes(hoverState || states.hover || {}));\n hoverStyle = hoverState.style;\n delete hoverState.style;\n // Pressed state\n selectState = merge(normalState, {\n fill: \"#e6e9ff\" /* Palette.highlightColor10 */,\n style: {\n color: \"#000000\" /* Palette.neutralColor100 */,\n fontWeight: 'bold'\n }\n }, AST.filterUserAttributes(selectState || states.select || {}));\n selectStyle = selectState.style;\n delete selectState.style;\n // Disabled state\n disabledState = merge(normalState, {\n style: {\n color: \"#cccccc\" /* Palette.neutralColor20 */\n }\n }, AST.filterUserAttributes(disabledState || states.disabled || {}));\n disabledStyle = disabledState.style;\n delete disabledState.style;\n }\n // Add the events. IE9 and IE10 need mouseover and mouseout to function\n // (#667).\n addEvent(label.element, isMS ? 'mouseover' : 'mouseenter', function () {\n if (curState !== 3) {\n label.setState(1);\n }\n });\n addEvent(label.element, isMS ? 'mouseout' : 'mouseleave', function () {\n if (curState !== 3) {\n label.setState(curState);\n }\n });\n label.setState = function (state) {\n // Hover state is temporary, don't record it\n if (state !== 1) {\n label.state = curState = state;\n }\n // Update visuals\n label\n .removeClass(/highcharts-button-(normal|hover|pressed|disabled)/)\n .addClass('highcharts-button-' +\n ['normal', 'hover', 'pressed', 'disabled'][state || 0]);\n if (!styledMode) {\n label\n .attr([\n normalState,\n hoverState,\n selectState,\n disabledState\n ][state || 0]);\n const css = [\n normalStyle,\n hoverStyle,\n selectStyle,\n disabledStyle\n ][state || 0];\n if (isObject(css)) {\n label.css(css);\n }\n }\n };\n // Presentational attributes\n if (!styledMode) {\n label\n .attr(normalState)\n .css(extend({ cursor: 'default' }, normalStyle));\n // HTML labels don't need to handle pointer events because click and\n // mouseenter/mouseleave is bound to the underlying element.\n // Should this be reconsidered, we need more complex logic to share\n // events between the and its
counterpart, and avoid\n // triggering mouseenter/mouseleave when hovering from one to the\n // other (#17440).\n if (useHTML) {\n label.text.css({ pointerEvents: 'none' });\n }\n }\n return label\n .on('touchstart', (e) => e.stopPropagation())\n .on('click', function (e) {\n if (curState !== 3) {\n callback.call(label, e);\n }\n });\n }\n /**\n * Make a straight line crisper by not spilling out to neighbour pixels.\n *\n * @function Highcharts.SVGRenderer#crispLine\n *\n * @param {Highcharts.SVGPathArray} points\n * The original points on the format `[['M', 0, 0], ['L', 100, 0]]`.\n *\n * @param {number} width\n * The width of the line.\n *\n * @param {string} [roundingFunction=round]\n * The rounding function name on the `Math` object, can be one of\n * `round`, `floor` or `ceil`.\n *\n * @return {Highcharts.SVGPathArray}\n * The original points array, but modified to render crisply.\n */\n crispLine(points, width, roundingFunction = 'round') {\n const start = points[0];\n const end = points[1];\n // Normalize to a crisp line\n if (defined(start[1]) && start[1] === end[1]) {\n // Substract due to #1129. Now bottom and left axis gridlines behave\n // the same.\n start[1] = end[1] =\n Math[roundingFunction](start[1]) - (width % 2 / 2);\n }\n if (defined(start[2]) && start[2] === end[2]) {\n start[2] = end[2] =\n Math[roundingFunction](start[2]) + (width % 2 / 2);\n }\n return points;\n }\n /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @sample highcharts/members/renderer-path-on-chart/\n * Draw a path in a chart\n * @sample highcharts/members/renderer-path/\n * Draw a path independent from a chart\n *\n * @example\n * let path = renderer.path(['M', 10, 10, 'L', 30, 30, 'z'])\n * .attr({ stroke: '#ff00ff' })\n * .add();\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGPathArray} [path]\n * An SVG path definition in array form.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n *\n */ /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n path(path) {\n const attribs = (this.styledMode ? {} : {\n fill: 'none'\n });\n if (isArray(path)) {\n attribs.d = path;\n }\n else if (isObject(path)) { // attributes\n extend(attribs, path);\n }\n return this.createElement('path').attr(attribs);\n }\n /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @sample highcharts/members/renderer-circle/\n * Drawing a circle\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {number} [x]\n * The center x position.\n *\n * @param {number} [y]\n * The center y position.\n *\n * @param {number} [r]\n * The radius.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n circle(x, y, r) {\n const attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ? {} : { x: x, y: y, r: r }), wrapper = this.createElement('circle');\n // Setting x or y translates to cx and cy\n wrapper.xSetter = wrapper.ySetter = function (value, key, element) {\n element.setAttribute('c' + key, value);\n };\n return wrapper.attr(attribs);\n }\n /**\n * Draw and return an arc.\n *\n * @sample highcharts/members/renderer-arc/\n * Drawing an arc\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {number} [x=0]\n * Center X position.\n *\n * @param {number} [y=0]\n * Center Y position.\n *\n * @param {number} [r=0]\n * The outer radius' of the arc.\n *\n * @param {number} [innerR=0]\n * Inner radius like used in donut charts.\n *\n * @param {number} [start=0]\n * The starting angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @param {number} [end=0]\n * The ending angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return an arc. Overloaded function that takes arguments object.\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {Highcharts.SVGAttributes} attribs\n * Initial SVG attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n arc(x, y, r, innerR, start, end) {\n let options;\n if (isObject(x)) {\n options = x;\n y = options.y;\n r = options.r;\n innerR = options.innerR;\n start = options.start;\n end = options.end;\n x = options.x;\n }\n else {\n options = { innerR, start, end };\n }\n // Arcs are defined as symbols for the ability to set\n // attributes in attr and animate\n const arc = this.symbol('arc', x, y, r, r, options);\n arc.r = r; // #959\n return arc;\n }\n /**\n * Draw and return a rectangle.\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {number} [x]\n * Left position.\n *\n * @param {number} [y]\n * Top position.\n *\n * @param {number} [width]\n * Width of the rectangle.\n *\n * @param {number} [height]\n * Height of the rectangle.\n *\n * @param {number} [r]\n * Border corner radius.\n *\n * @param {number} [strokeWidth]\n * A stroke width can be supplied to allow crisp drawing.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return a rectangle.\n *\n * @sample highcharts/members/renderer-rect-on-chart/\n * Draw a rectangle in a chart\n * @sample highcharts/members/renderer-rect/\n * Draw a rectangle independent from a chart\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {Highcharts.SVGAttributes} [attributes]\n * General SVG attributes for the rectangle.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n rect(x, y, width, height, r, strokeWidth) {\n const attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ?\n {} :\n {\n x,\n y,\n r,\n width: Math.max(width || 0, 0),\n height: Math.max(height || 0, 0)\n }), wrapper = this.createElement('rect');\n if (!this.styledMode) {\n if (typeof strokeWidth !== 'undefined') {\n attribs['stroke-width'] = strokeWidth;\n extend(attribs, wrapper.crisp(attribs));\n }\n attribs.fill = 'none';\n }\n wrapper.rSetter = function (value, _key, element) {\n wrapper.r = value;\n attr(element, {\n rx: value,\n ry: value\n });\n };\n wrapper.rGetter = function () {\n return wrapper.r || 0;\n };\n return wrapper.attr(attribs);\n }\n /**\n * Draw and return a rectangle with advanced corner rounding options.\n *\n * @function Highcharts.SVGRenderer#roundedRect\n *\n * @param {Highcharts.SVGAttributes} attribs\n * Attributes\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n roundedRect(attribs) {\n return this.symbol('roundedRect').attr(attribs);\n }\n /**\n * Resize the {@link SVGRenderer#box} and re-align all aligned child\n * elements.\n *\n * @sample highcharts/members/renderer-g/\n * Show and hide grouped objects\n *\n * @function Highcharts.SVGRenderer#setSize\n *\n * @param {number} width\n * The new pixel width.\n *\n * @param {number} height\n * The new pixel height.\n *\n * @param {boolean|Partial} [animate=true]\n * Whether and how to animate.\n */\n setSize(width, height, animate) {\n const renderer = this;\n renderer.width = width;\n renderer.height = height;\n renderer.boxWrapper.animate({\n width: width,\n height: height\n }, {\n step: function () {\n this.attr({\n viewBox: '0 0 ' + this.attr('width') + ' ' +\n this.attr('height')\n });\n },\n duration: pick(animate, true) ? void 0 : 0\n });\n renderer.alignElements();\n }\n /**\n * Create and return an svg group element. Child\n * {@link Highcharts.SVGElement} objects are added to the group by using the\n * group as the first parameter in {@link Highcharts.SVGElement#add|add()}.\n *\n * @function Highcharts.SVGRenderer#g\n *\n * @param {string} [name]\n * The group will be given a class name of `highcharts-{name}`. This\n * can be used for styling and scripting.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n g(name) {\n const elem = this.createElement('g');\n return name ?\n elem.attr({ 'class': 'highcharts-' + name }) :\n elem;\n }\n /**\n * Display an image.\n *\n * @sample highcharts/members/renderer-image-on-chart/\n * Add an image in a chart\n * @sample highcharts/members/renderer-image/\n * Add an image independent of a chart\n *\n * @function Highcharts.SVGRenderer#image\n *\n * @param {string} href\n * The image source.\n *\n * @param {number} [x]\n * The X position.\n *\n * @param {number} [y]\n * The Y position.\n *\n * @param {number} [width]\n * The image width. If omitted, it defaults to the image file width.\n *\n * @param {number} [height]\n * The image height. If omitted it defaults to the image file\n * height.\n *\n * @param {Function} [onload]\n * Event handler for image load.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n image(href, x, y, width, height, onload) {\n const attribs = { preserveAspectRatio: 'none' };\n // Optional properties (#11756)\n if (isNumber(x)) {\n attribs.x = x;\n }\n if (isNumber(y)) {\n attribs.y = y;\n }\n if (isNumber(width)) {\n attribs.width = width;\n }\n if (isNumber(height)) {\n attribs.height = height;\n }\n const elemWrapper = this.createElement('image').attr(attribs), onDummyLoad = function (e) {\n elemWrapper.attr({ href });\n onload.call(elemWrapper, e);\n };\n // Add load event if supplied\n if (onload) {\n // We have to use a dummy HTML image since IE support for SVG image\n // load events is very buggy. First set a transparent src, wait for\n // dummy to load, and then add the real src to the SVG image.\n elemWrapper.attr({\n /* eslint-disable-next-line max-len */\n href: 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=='\n });\n const dummy = new win.Image();\n addEvent(dummy, 'load', onDummyLoad);\n dummy.src = href;\n if (dummy.complete) {\n onDummyLoad({});\n }\n }\n else {\n elemWrapper.attr({ href });\n }\n return elemWrapper;\n }\n /**\n * Draw a symbol out of pre-defined shape paths from\n * {@link SVGRenderer#symbols}.\n * It is used in Highcharts for point makers, which cake a `symbol` option,\n * and label and button backgrounds like in the tooltip and stock flags.\n *\n * @function Highcharts.SVGRenderer#symbol\n *\n * @param {string} symbol\n * The symbol name.\n *\n * @param {number} [x]\n * The X coordinate for the top left position.\n *\n * @param {number} [y]\n * The Y coordinate for the top left position.\n *\n * @param {number} [width]\n * The pixel width.\n *\n * @param {number} [height]\n * The pixel height.\n *\n * @param {Highcharts.SymbolOptionsObject} [options]\n * Additional options, depending on the actual symbol drawn.\n *\n * @return {Highcharts.SVGElement}\n * SVG symbol.\n */\n symbol(symbol, x, y, width, height, options) {\n const ren = this, imageRegex = /^url\\((.*?)\\)$/, isImage = imageRegex.test(symbol), sym = (!isImage && (this.symbols[symbol] ? symbol : 'circle')), \n // get the symbol definition function\n symbolFn = (sym && this.symbols[sym]);\n let obj, path, imageSrc, centerImage;\n if (symbolFn) {\n // Check if there's a path defined for this symbol\n if (typeof x === 'number') {\n path = symbolFn.call(this.symbols, Math.round(x || 0), Math.round(y || 0), width || 0, height || 0, options);\n }\n obj = this.path(path);\n if (!ren.styledMode) {\n obj.attr('fill', 'none');\n }\n // expando properties for use in animate and attr\n extend(obj, {\n symbolName: (sym || void 0),\n x: x,\n y: y,\n width: width,\n height: height\n });\n if (options) {\n extend(obj, options);\n }\n // Image symbols\n }\n else if (isImage) {\n imageSrc = symbol.match(imageRegex)[1];\n // Create the image synchronously, add attribs async\n const img = obj = this.image(imageSrc);\n // The image width is not always the same as the symbol width. The\n // image may be centered within the symbol, as is the case when\n // image shapes are used as label backgrounds, for example in flags.\n img.imgwidth = pick(options && options.width, symbolSizes[imageSrc] && symbolSizes[imageSrc].width);\n img.imgheight = pick(options && options.height, symbolSizes[imageSrc] && symbolSizes[imageSrc].height);\n /**\n * Set the size and position\n */\n centerImage = (obj) => obj.attr({\n width: obj.width,\n height: obj.height\n });\n /**\n * Width and height setters that take both the image's physical size\n * and the label size into consideration, and translates the image\n * to center within the label.\n */\n ['width', 'height'].forEach(function (key) {\n img[key + 'Setter'] = function (value, key) {\n this[key] = value;\n const { alignByTranslate, element, width, height, imgwidth, imgheight } = this;\n let imgSize = this['img' + key];\n if (defined(imgSize)) {\n let scale = 1;\n // Scale and center the image within its container.\n // The name `backgroundSize` is taken from the CSS spec,\n // but the value `within` is made up. Other possible\n // values in the spec, `cover` and `contain`, can be\n // implemented if needed.\n if (options &&\n options.backgroundSize === 'within' &&\n width &&\n height) {\n scale = Math.min(width / imgwidth, height / imgheight);\n imgSize = Math.round(imgSize * scale);\n // Update both width and height to keep the ratio\n // correct (#17315)\n attr(element, {\n width: Math.round(imgwidth * scale),\n height: Math.round(imgheight * scale)\n });\n }\n else if (element) {\n element.setAttribute(key, imgSize);\n }\n if (!alignByTranslate) {\n this.translate(((width || 0) - (imgwidth * scale)) / 2, ((height || 0) - (imgheight * scale)) / 2);\n }\n }\n };\n });\n if (defined(x)) {\n img.attr({\n x: x,\n y: y\n });\n }\n img.isImg = true;\n if (defined(img.imgwidth) && defined(img.imgheight)) {\n centerImage(img);\n }\n else {\n // Initialize image to be 0 size so export will still function\n // if there's no cached sizes.\n img.attr({ width: 0, height: 0 });\n // Create a dummy JavaScript image to get the width and height.\n createElement('img', {\n onload: function () {\n const chart = charts[ren.chartIndex];\n // Special case for SVGs on IE11, the width is not\n // accessible until the image is part of the DOM\n // (#2854).\n if (this.width === 0) {\n css(this, {\n position: 'absolute',\n top: '-999em'\n });\n doc.body.appendChild(this);\n }\n // Center the image\n symbolSizes[imageSrc] = {\n width: this.width,\n height: this.height\n };\n img.imgwidth = this.width;\n img.imgheight = this.height;\n if (img.element) {\n centerImage(img);\n }\n // Clean up after #2854 workaround.\n if (this.parentNode) {\n this.parentNode.removeChild(this);\n }\n // Fire the load event when all external images are\n // loaded\n ren.imgCount--;\n if (!ren.imgCount && chart && !chart.hasLoaded) {\n chart.onload();\n }\n },\n src: imageSrc\n });\n this.imgCount++;\n }\n }\n return obj;\n }\n /**\n * Define a clipping rectangle. The clipping rectangle is later applied\n * to {@link SVGElement} objects through the {@link SVGElement#clip}\n * function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @function Highcharts.SVGRenderer#clipRect\n *\n * @param {number} [x]\n *\n * @param {number} [y]\n *\n * @param {number} [width]\n *\n * @param {number} [height]\n *\n * @return {Highcharts.ClipRectElement}\n * A clipping rectangle.\n */\n clipRect(x, y, width, height) {\n const \n // Add a hyphen at the end to avoid confusion in testing indexes\n // -1 and -10, -11 etc (#6550)\n id = uniqueKey() + '-', clipPath = this.createElement('clipPath').attr({\n id: id\n }).add(this.defs), wrapper = this.rect(x, y, width, height, 0).add(clipPath);\n wrapper.id = id;\n wrapper.clipPath = clipPath;\n wrapper.count = 0;\n return wrapper;\n }\n /**\n * Draw text. The text can contain a subset of HTML, like spans and anchors\n * and some basic text styling of these. For more advanced features like\n * border and background, use {@link Highcharts.SVGRenderer#label} instead.\n * To update the text after render, run `text.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Annotate the chart freely\n * @sample highcharts/members/renderer-on-chart/\n * Annotate with a border and in response to the data\n * @sample highcharts/members/renderer-text/\n * Formatted text\n *\n * @function Highcharts.SVGRenderer#text\n *\n * @param {string} [str]\n * The text of (subset) HTML to draw.\n *\n * @param {number} [x]\n * The x position of the text's lower left corner.\n *\n * @param {number} [y]\n * The y position of the text's lower left corner.\n *\n * @param {boolean} [useHTML=false]\n * Use HTML to render the text.\n *\n * @return {Highcharts.SVGElement}\n * The text object.\n */\n text(str, x, y, useHTML) {\n const renderer = this, attribs = {};\n if (useHTML && (renderer.allowHTML || !renderer.forExport)) {\n return renderer.html(str, x, y);\n }\n attribs.x = Math.round(x || 0); // X always needed for line-wrap logic\n if (y) {\n attribs.y = Math.round(y);\n }\n if (defined(str)) {\n attribs.text = str;\n }\n const wrapper = renderer.createElement('text').attr(attribs);\n if (!useHTML || (renderer.forExport && !renderer.allowHTML)) {\n wrapper.xSetter = function (value, key, element) {\n const tspans = element.getElementsByTagName('tspan'), parentVal = element.getAttribute(key);\n for (let i = 0, tspan; i < tspans.length; i++) {\n tspan = tspans[i];\n // If the x values are equal, the tspan represents a line\n // break\n if (tspan.getAttribute(key) === parentVal) {\n tspan.setAttribute(key, value);\n }\n }\n element.setAttribute(key, value);\n };\n }\n return wrapper;\n }\n /**\n * Utility to return the baseline offset and total line height from the font\n * size.\n *\n * @function Highcharts.SVGRenderer#fontMetrics\n *\n * @param {Highcharts.SVGElement|Highcharts.SVGDOMElement|number} [element]\n * The element to inspect for a current font size. If a number is\n * given, it's used as a fall back for direct font size in pixels.\n *\n * @return {Highcharts.FontMetricsObject}\n * The font metrics.\n */\n fontMetrics(element) {\n const f = pInt(SVGElement.prototype.getStyle.call(element, 'font-size') || 0);\n // Empirical values found by comparing font size and bounding box\n // height. Applies to the default font family.\n // https://jsfiddle.net/highcharts/7xvn7/\n const h = f < 24 ? f + 3 : Math.round(f * 1.2), b = Math.round(h * 0.8);\n return {\n // Line height\n h,\n // Baseline\n b,\n // Font size\n f\n };\n }\n /**\n * Correct X and Y positioning of a label for rotation (#1764).\n *\n * @private\n * @function Highcharts.SVGRenderer#rotCorr\n */\n rotCorr(baseline, rotation, alterY) {\n let y = baseline;\n if (rotation && alterY) {\n y = Math.max(y * Math.cos(rotation * deg2rad), 4);\n }\n return {\n x: (-baseline / 3) * Math.sin(rotation * deg2rad),\n y: y\n };\n }\n /**\n * Compatibility function to convert the legacy one-dimensional path array\n * into an array of segments.\n *\n * It is used in maps to parse the `path` option, and in SVGRenderer.dSetter\n * to support legacy paths from demos.\n *\n * @private\n * @function Highcharts.SVGRenderer#pathToSegments\n */\n pathToSegments(path) {\n const ret = [];\n const segment = [];\n const commandLength = {\n A: 8,\n C: 7,\n H: 2,\n L: 3,\n M: 3,\n Q: 5,\n S: 5,\n T: 3,\n V: 2\n };\n // Short, non-typesafe parsing of the one-dimensional array. It splits\n // the path on any string. This is not type checked against the tuple\n // types, but is shorter, and doesn't require specific checks for any\n // command type in SVG.\n for (let i = 0; i < path.length; i++) {\n // Command skipped, repeat previous or insert L/l for M/m\n if (isString(segment[0]) &&\n isNumber(path[i]) &&\n segment.length === commandLength[(segment[0].toUpperCase())]) {\n path.splice(i, 0, segment[0].replace('M', 'L').replace('m', 'l'));\n }\n // Split on string\n if (typeof path[i] === 'string') {\n if (segment.length) {\n ret.push(segment.slice(0));\n }\n segment.length = 0;\n }\n segment.push(path[i]);\n }\n ret.push(segment.slice(0));\n return ret;\n /*\n // Fully type-safe version where each tuple type is checked. The\n // downside is filesize and a lack of flexibility for unsupported\n // commands\n const ret: SVGPath = [],\n commands = {\n A: 7,\n C: 6,\n H: 1,\n L: 2,\n M: 2,\n Q: 4,\n S: 4,\n T: 2,\n V: 1,\n Z: 0\n };\n\n let i = 0,\n lastI = 0,\n lastCommand;\n\n while (i < path.length) {\n const item = path[i];\n\n let command;\n\n if (typeof item === 'string') {\n command = item;\n i += 1;\n } else {\n command = lastCommand || 'M';\n }\n\n // Upper case\n const commandUC = command.toUpperCase();\n\n if (commandUC in commands) {\n\n // No numeric parameters\n if (command === 'Z' || command === 'z') {\n ret.push([command]);\n\n // One numeric parameter\n } else {\n const val0 = path[i];\n if (typeof val0 === 'number') {\n\n // Horizontal line to\n if (command === 'H' || command === 'h') {\n ret.push([command, val0]);\n i += 1;\n\n // Vertical line to\n } else if (command === 'V' || command === 'v') {\n ret.push([command, val0]);\n i += 1;\n\n // Two numeric parameters\n } else {\n const val1 = path[i + 1];\n if (typeof val1 === 'number') {\n // lineTo\n if (command === 'L' || command === 'l') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // moveTo\n } else if (command === 'M' || command === 'm') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Smooth quadratic bezier\n } else if (command === 'T' || command === 't') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Four numeric parameters\n } else {\n const val2 = path[i + 2],\n val3 = path[i + 3];\n if (\n typeof val2 === 'number' &&\n typeof val3 === 'number'\n ) {\n // Quadratic bezier to\n if (\n command === 'Q' ||\n command === 'q'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Smooth cubic bezier to\n } else if (\n command === 'S' ||\n command === 's'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Six numeric parameters\n } else {\n const val4 = path[i + 4],\n val5 = path[i + 5];\n\n if (\n typeof val4 === 'number' &&\n typeof val5 === 'number'\n ) {\n // Curve to\n if (\n command === 'C' ||\n command === 'c'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5\n ]);\n i += 6;\n\n // Seven numeric parameters\n } else {\n const val6 = path[i + 6];\n\n // Arc to\n if (\n typeof val6 ===\n 'number' &&\n (\n command === 'A' ||\n command === 'a'\n )\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5,\n val6\n ]);\n i += 7;\n\n }\n\n }\n }\n }\n }\n }\n }\n\n }\n }\n }\n }\n\n // An unmarked command following a moveTo is a lineTo\n lastCommand = command === 'M' ? 'L' : command;\n\n if (i === lastI) {\n break;\n }\n lastI = i;\n }\n return ret;\n */\n }\n /**\n * Draw a label, which is an extended text element with support for border\n * and background. Highcharts creates a `g` element with a text and a `path`\n * or `rect` inside, to make it behave somewhat like a HTML div. Border and\n * background are set through `stroke`, `stroke-width` and `fill` attributes\n * using the {@link Highcharts.SVGElement#attr|attr} method. To update the\n * text after render, run `label.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-label-on-chart/\n * A label on the chart\n *\n * @function Highcharts.SVGRenderer#label\n *\n * @param {string} str\n * The initial text string or (subset) HTML to render.\n *\n * @param {number} x\n * The x position of the label's left side.\n *\n * @param {number} [y]\n * The y position of the label's top side or baseline, depending on\n * the `baseline` parameter.\n *\n * @param {string} [shape='rect']\n * The shape of the label's border/background, if any. Defaults to\n * `rect`. Other possible values are `callout` or other shapes\n * defined in {@link Highcharts.SVGRenderer#symbols}.\n *\n * @param {number} [anchorX]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {number} [anchorY]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @param {boolean} [baseline=false]\n * Whether to position the label relative to the text baseline,\n * like {@link Highcharts.SVGRenderer#text|renderer.text}, or to the\n * upper border of the rectangle.\n *\n * @param {string} [className]\n * Class name for the group.\n *\n * @return {Highcharts.SVGElement}\n * The generated label.\n */\n label(str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n return new SVGLabel(this, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className);\n }\n /**\n * Re-align all aligned elements.\n *\n * @private\n * @function Highcharts.SVGRenderer#alignElements\n */\n alignElements() {\n this.alignedObjects.forEach((el) => el.align());\n }\n }\n extend(SVGRenderer.prototype, {\n /**\n * A pointer to the renderer's associated Element class.\n *\n * @name Highcharts.SVGRenderer#Element\n * @type {Highcharts.SVGElement}\n */\n Element: SVGElement,\n SVG_NS,\n /**\n * A collection of characters mapped to HTML entities. When `useHTML` on an\n * element is true, these entities will be rendered correctly by HTML. In\n * the SVG pseudo-HTML, they need to be unescaped back to simple characters,\n * so for example `<` will render as `<`.\n *\n * @example\n * // Add support for unescaping quotes\n * Highcharts.SVGRenderer.prototype.escapes['\"'] = '"';\n *\n * @name Highcharts.SVGRenderer#escapes\n * @type {Highcharts.Dictionary}\n */\n escapes: {\n '&': '&',\n '<': '<',\n '>': '>',\n \"'\": ''',\n '\"': '"'\n },\n /**\n * An extendable collection of functions for defining symbol paths.\n *\n * @name Highcharts.SVGRenderer#symbols\n * @type {Highcharts.SymbolDictionary}\n */\n symbols: Symbols,\n /**\n * Dummy function for plugins, called every time the renderer is updated.\n * Prior to Highcharts 5, this was used for the canvg renderer.\n *\n * @deprecated\n * @function Highcharts.SVGRenderer#draw\n */\n draw: noop\n });\n /* *\n *\n * Registry\n *\n * */\n RendererRegistry.registerRendererType('svg', SVGRenderer, true);\n /* *\n *\n * Export Default\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A clipping rectangle that can be applied to one or more {@link SVGElement}\n * instances. It is instanciated with the {@link SVGRenderer#clipRect} function\n * and applied with the {@link SVGElement#clip} function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @typedef {Highcharts.SVGElement} Highcharts.ClipRectElement\n */\n /**\n * The font metrics.\n *\n * @interface Highcharts.FontMetricsObject\n */ /**\n * The baseline relative to the top of the box.\n *\n * @name Highcharts.FontMetricsObject#b\n * @type {number}\n */ /**\n * The font size.\n *\n * @name Highcharts.FontMetricsObject#f\n * @type {number}\n */ /**\n * The line height.\n *\n * @name Highcharts.FontMetricsObject#h\n * @type {number}\n */\n /**\n * An object containing `x` and `y` properties for the position of an element.\n *\n * @interface Highcharts.PositionObject\n */ /**\n * X position of the element.\n * @name Highcharts.PositionObject#x\n * @type {number}\n */ /**\n * Y position of the element.\n * @name Highcharts.PositionObject#y\n * @type {number}\n */\n /**\n * A rectangle.\n *\n * @interface Highcharts.RectangleObject\n */ /**\n * Height of the rectangle.\n * @name Highcharts.RectangleObject#height\n * @type {number}\n */ /**\n * Width of the rectangle.\n * @name Highcharts.RectangleObject#width\n * @type {number}\n */ /**\n * Horizontal position of the rectangle.\n * @name Highcharts.RectangleObject#x\n * @type {number}\n */ /**\n * Vertical position of the rectangle.\n * @name Highcharts.RectangleObject#y\n * @type {number}\n */\n /**\n * The shadow options.\n *\n * @interface Highcharts.ShadowOptionsObject\n */ /**\n * The shadow color.\n * @name Highcharts.ShadowOptionsObject#color\n * @type {Highcharts.ColorString|undefined}\n * @default #000000\n */ /**\n * The horizontal offset from the element.\n *\n * @name Highcharts.ShadowOptionsObject#offsetX\n * @type {number|undefined}\n * @default 1\n */ /**\n * The vertical offset from the element.\n * @name Highcharts.ShadowOptionsObject#offsetY\n * @type {number|undefined}\n * @default 1\n */ /**\n * The shadow opacity.\n *\n * @name Highcharts.ShadowOptionsObject#opacity\n * @type {number|undefined}\n * @default 0.15\n */ /**\n * The shadow width or distance from the element.\n * @name Highcharts.ShadowOptionsObject#width\n * @type {number|undefined}\n * @default 3\n */\n /**\n * @interface Highcharts.SizeObject\n */ /**\n * @name Highcharts.SizeObject#height\n * @type {number}\n */ /**\n * @name Highcharts.SizeObject#width\n * @type {number}\n */\n /**\n * Array of path commands, that will go into the `d` attribute of an SVG\n * element.\n *\n * @typedef {Array<(Array|Array|Array|Array|Array|Array)>} Highcharts.SVGPathArray\n */\n /**\n * Possible path commands in an SVG path array. Valid values are `A`, `C`, `H`,\n * `L`, `M`, `Q`, `S`, `T`, `V`, `Z`.\n *\n * @typedef {string} Highcharts.SVGPathCommand\n * @validvalue [\"a\",\"c\",\"h\",\"l\",\"m\",\"q\",\"s\",\"t\",\"v\",\"z\",\"A\",\"C\",\"H\",\"L\",\"M\",\"Q\",\"S\",\"T\",\"V\",\"Z\"]\n */\n /**\n * An extendable collection of functions for defining symbol paths. Symbols are\n * used internally for point markers, button and label borders and backgrounds,\n * or custom shapes. Extendable by adding to {@link SVGRenderer#symbols}.\n *\n * @interface Highcharts.SymbolDictionary\n */ /**\n * @name Highcharts.SymbolDictionary#[key:string]\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#arc\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#callout\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#circle\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#diamond\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#square\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#triangle\n * @type {Function|undefined}\n */\n /**\n * Can be one of `arc`, `callout`, `circle`, `diamond`, `square`, `triangle`,\n * and `triangle-down`. Symbols are used internally for point markers, button\n * and label borders and backgrounds, or custom shapes. Extendable by adding to\n * {@link SVGRenderer#symbols}.\n *\n * @typedef {\"arc\"|\"callout\"|\"circle\"|\"diamond\"|\"square\"|\"triangle\"|\"triangle-down\"} Highcharts.SymbolKeyValue\n */\n /**\n * Additional options, depending on the actual symbol drawn.\n *\n * @interface Highcharts.SymbolOptionsObject\n */ /**\n * The anchor X position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorX\n * @type {number|undefined}\n */ /**\n * The anchor Y position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorY\n * @type {number|undefined}\n */ /**\n * The end angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#end\n * @type {number|undefined}\n */ /**\n * Whether to draw `arc` symbol open or closed.\n *\n * @name Highcharts.SymbolOptionsObject#open\n * @type {boolean|undefined}\n */ /**\n * The radius of an `arc` symbol, or the border radius for the `callout` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#r\n * @type {number|undefined}\n */ /**\n * The start angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#start\n * @type {number|undefined}\n */\n (''); // keeps doclets above in transpiled file\n\n return SVGRenderer;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLElement.js', [_modules['Core/Globals.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (H, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isFirefox, isMS, isWebKit, win } = H;\n const { css, defined, extend, pick, pInt } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n class HTMLElement extends SVGElement {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Modifies SVGElement to support HTML elements.\n * @private\n */\n static compose(SVGElementClass) {\n if (U.pushUnique(composedMembers, SVGElementClass)) {\n const htmlElementProto = HTMLElement.prototype, svgElementProto = SVGElementClass.prototype;\n svgElementProto.getSpanCorrection = htmlElementProto\n .getSpanCorrection;\n svgElementProto.htmlCss = htmlElementProto.htmlCss;\n svgElementProto.htmlGetBBox = htmlElementProto.htmlGetBBox;\n svgElementProto.htmlUpdateTransform = htmlElementProto\n .htmlUpdateTransform;\n svgElementProto.setSpanRotation = htmlElementProto.setSpanRotation;\n }\n return SVGElementClass;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the correction in X and Y positioning as the element is rotated.\n * @private\n */\n getSpanCorrection(width, baseline, alignCorrection) {\n this.xCorr = -width * alignCorrection;\n this.yCorr = -baseline;\n }\n /**\n * Apply CSS to HTML elements. This is used in text within SVG rendering.\n * @private\n */\n htmlCss(styles) {\n const wrapper = this, element = wrapper.element, \n // When setting or unsetting the width style, we need to update\n // transform (#8809)\n isSettingWidth = (element.tagName === 'SPAN' &&\n styles &&\n 'width' in styles), textWidth = pick(isSettingWidth && styles.width, void 0);\n let doTransform;\n if (isSettingWidth) {\n delete styles.width;\n wrapper.textWidth = textWidth;\n doTransform = true;\n }\n if (styles && styles.textOverflow === 'ellipsis') {\n styles.whiteSpace = 'nowrap';\n styles.overflow = 'hidden';\n }\n wrapper.styles = extend(wrapper.styles, styles);\n css(wrapper.element, styles);\n // Now that all styles are applied, to the transform\n if (doTransform) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n }\n /**\n * useHTML method for calculating the bounding box based on offsets.\n */\n htmlGetBBox() {\n const wrapper = this, element = wrapper.element;\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: element.offsetWidth,\n height: element.offsetHeight\n };\n }\n /**\n * @private\n */\n htmlUpdateTransform() {\n // aligning non added elements is expensive\n if (!this.added) {\n this.alignOnAdd = true;\n return;\n }\n const wrapper = this, renderer = wrapper.renderer, elem = wrapper.element, translateX = wrapper.translateX || 0, translateY = wrapper.translateY || 0, x = wrapper.x || 0, y = wrapper.y || 0, align = wrapper.textAlign || 'left', alignCorrection = {\n left: 0, center: 0.5, right: 1\n }[align], styles = wrapper.styles, whiteSpace = styles && styles.whiteSpace;\n /** @private */\n function getTextPxLength() {\n if (wrapper.textPxLength) {\n return wrapper.textPxLength;\n }\n // Reset multiline/ellipsis in order to read width (#4928,\n // #5417)\n css(elem, {\n width: '',\n whiteSpace: whiteSpace || 'nowrap'\n });\n return elem.offsetWidth;\n }\n // apply translate\n css(elem, {\n marginLeft: translateX,\n marginTop: translateY\n });\n if (elem.tagName === 'SPAN') {\n const rotation = wrapper.rotation, textWidth = wrapper.textWidth && pInt(wrapper.textWidth), currentTextTransform = [\n rotation,\n align,\n elem.innerHTML,\n wrapper.textWidth,\n wrapper.textAlign\n ].join(',');\n let baseline, hasBoxWidthChanged = false;\n // Update textWidth. Use the memoized textPxLength if possible, to\n // avoid the getTextPxLength function using elem.offsetWidth.\n // Calling offsetWidth affects rendering time as it forces layout\n // (#7656).\n if (textWidth !== wrapper.oldTextWidth) { // #983, #1254\n const textPxLength = getTextPxLength();\n if (((textWidth > wrapper.oldTextWidth) ||\n textPxLength > textWidth) && (\n // Only set the width if the text is able to word-wrap,\n // or text-overflow is ellipsis (#9537)\n /[ \\-]/.test(elem.textContent || elem.innerText) ||\n elem.style.textOverflow === 'ellipsis')) {\n css(elem, {\n width: (textPxLength > textWidth) || rotation ?\n textWidth + 'px' :\n 'auto',\n display: 'block',\n whiteSpace: whiteSpace || 'normal' // #3331\n });\n wrapper.oldTextWidth = textWidth;\n hasBoxWidthChanged = true; // #8159\n }\n }\n wrapper.hasBoxWidthChanged = hasBoxWidthChanged; // #8159\n // Do the calculations and DOM access only if properties changed\n if (currentTextTransform !== wrapper.cTT) {\n baseline = renderer.fontMetrics(elem).b;\n // Renderer specific handling of span rotation, but only if we\n // have something to update.\n if (defined(rotation) &&\n ((rotation !== (wrapper.oldRotation || 0)) ||\n (align !== wrapper.oldAlign))) {\n wrapper.setSpanRotation(rotation, alignCorrection, baseline);\n }\n wrapper.getSpanCorrection(\n // Avoid elem.offsetWidth if we can, it affects rendering\n // time heavily (#7656)\n ((!defined(rotation) && wrapper.textPxLength) || // #7920\n elem.offsetWidth), baseline, alignCorrection, rotation, align);\n }\n // apply position with correction\n css(elem, {\n left: (x + (wrapper.xCorr || 0)) + 'px',\n top: (y + (wrapper.yCorr || 0)) + 'px'\n });\n // record current text transform\n wrapper.cTT = currentTextTransform;\n wrapper.oldRotation = rotation;\n wrapper.oldAlign = align;\n }\n }\n /**\n * Set the rotation of an individual HTML span.\n * @private\n */\n setSpanRotation(rotation, alignCorrection, baseline) {\n const getTransformKey = () => (isMS &&\n !/Edge/.test(win.navigator.userAgent) ?\n '-ms-transform' :\n isWebKit ?\n '-webkit-transform' :\n isFirefox ?\n 'MozTransform' :\n win.opera ?\n '-o-transform' :\n void 0);\n const rotationStyle = {}, cssTransformKey = getTransformKey();\n if (cssTransformKey) {\n rotationStyle[cssTransformKey] = rotationStyle.transform =\n 'rotate(' + rotation + 'deg)';\n rotationStyle[cssTransformKey + (isFirefox ? 'Origin' : '-origin')] = rotationStyle.transformOrigin =\n (alignCorrection * 100) + '% ' + baseline + 'px';\n css(this.element, rotationStyle);\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLElement;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (AST, SVGElement, SVGRenderer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { attr, createElement, extend, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n // Extend SvgRenderer for useHTML option.\n class HTMLRenderer extends SVGRenderer {\n /* *\n *\n * Static Functions\n *\n * */\n /** @private */\n static compose(SVGRendererClass) {\n if (U.pushUnique(composedMembers, SVGRendererClass)) {\n const htmlRendererProto = HTMLRenderer.prototype, svgRendererProto = SVGRendererClass.prototype;\n svgRendererProto.html = htmlRendererProto.html;\n }\n return SVGRendererClass;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create HTML text node. This is used by the SVG renderer through the\n * useHTML option.\n *\n * @private\n * @function Highcharts.SVGRenderer#html\n *\n * @param {string} str\n * The text of (subset) HTML to draw.\n *\n * @param {number} x\n * The x position of the text's lower left corner.\n *\n * @param {number} y\n * The y position of the text's lower left corner.\n *\n * @return {Highcharts.HTMLDOMElement}\n * HTML element.\n */\n html(str, x, y) {\n const wrapper = this.createElement('span'), element = wrapper.element, renderer = wrapper.renderer, addSetters = function (gWrapper, style) {\n // These properties are set as attributes on the SVG group, and\n // as identical CSS properties on the div. (#3542)\n ['opacity', 'visibility'].forEach(function (prop) {\n gWrapper[prop + 'Setter'] = function (value, key, elem) {\n const styleObject = gWrapper.div ?\n gWrapper.div.style :\n style;\n SVGElement.prototype[prop + 'Setter']\n .call(this, value, key, elem);\n if (styleObject) {\n styleObject[key] = value;\n }\n };\n });\n gWrapper.addedSetters = true;\n };\n // Text setter\n wrapper.textSetter = function (value) {\n if (value !== this.textStr) {\n delete this.bBox;\n delete this.oldTextWidth;\n AST.setElementHTML(this.element, pick(value, ''));\n this.textStr = value;\n wrapper.doTransform = true;\n }\n };\n addSetters(wrapper, wrapper.element.style);\n // Various setters which rely on update transform\n wrapper.xSetter =\n wrapper.ySetter =\n wrapper.alignSetter =\n wrapper.rotationSetter =\n function (value, key) {\n if (key === 'align') {\n // Do not overwrite the SVGElement.align method.\n wrapper.alignValue = wrapper.textAlign = value;\n }\n else {\n wrapper[key] = value;\n }\n wrapper.doTransform = true;\n };\n // Runs at the end of .attr()\n wrapper.afterSetters = function () {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.htmlUpdateTransform();\n this.doTransform = false;\n }\n };\n // Set the default attributes\n wrapper\n .attr({\n text: str,\n x: Math.round(x),\n y: Math.round(y)\n })\n .css({\n position: 'absolute'\n });\n if (!renderer.styledMode) {\n wrapper.css({\n fontFamily: this.style.fontFamily,\n fontSize: this.style.fontSize\n });\n }\n // Keep the whiteSpace style outside the wrapper.styles collection\n element.style.whiteSpace = 'nowrap';\n // Use the HTML specific .css method\n wrapper.css = wrapper.htmlCss;\n wrapper.add = function (svgGroupWrapper) {\n const container = renderer.box.parentNode, parents = [];\n let htmlGroup, parentGroup;\n this.parentGroup = svgGroupWrapper;\n // Create a mock group to hold the HTML elements\n if (svgGroupWrapper) {\n htmlGroup = svgGroupWrapper.div;\n if (!htmlGroup) {\n // Read the parent chain into an array and read from top\n // down\n parentGroup = svgGroupWrapper;\n while (parentGroup) {\n parents.push(parentGroup);\n // Move up to the next parent group\n parentGroup = parentGroup.parentGroup;\n }\n // Ensure dynamically updating position when any parent\n // is translated\n parents.reverse().forEach(function (parentGroup) {\n const cls = attr(parentGroup.element, 'class');\n /**\n * Common translate setter for X and Y on the HTML\n * group. Reverted the fix for #6957 du to\n * positioning problems and offline export (#7254,\n * #7280, #7529)\n * @private\n * @param {*} value\n * @param {string} key\n */\n function translateSetter(value, key) {\n parentGroup[key] = value;\n if (key === 'translateX') {\n htmlGroupStyle.left = value + 'px';\n }\n else {\n htmlGroupStyle.top = value + 'px';\n }\n parentGroup.doTransform = true;\n }\n // Create a HTML div and append it to the parent div\n // to emulate the SVG group structure\n const parentGroupStyles = parentGroup.styles || {};\n htmlGroup =\n parentGroup.div =\n parentGroup.div || createElement('div', cls ? { className: cls } : void 0, {\n position: 'absolute',\n left: (parentGroup.translateX || 0) + 'px',\n top: (parentGroup.translateY || 0) + 'px',\n display: parentGroup.display,\n opacity: parentGroup.opacity,\n visibility: parentGroup.visibility\n // the top group is appended to container\n }, htmlGroup || container);\n // Shortcut\n const htmlGroupStyle = htmlGroup.style;\n // Set listeners to update the HTML div's position\n // whenever the SVG group position is changed.\n extend(parentGroup, {\n // (#7287) Pass htmlGroup to use\n // the related group\n classSetter: (function (htmlGroup) {\n return function (value) {\n this.element.setAttribute('class', value);\n htmlGroup.className = value;\n };\n }(htmlGroup)),\n // Extend the parent group's css function by\n // updating the shadow div counterpart with the same\n // style.\n css: function (styles) {\n wrapper.css.call(parentGroup, styles);\n [\n // #6794\n 'cursor',\n // #5595, #18821\n 'pointerEvents'\n ].forEach((prop) => {\n if (styles[prop]) {\n htmlGroupStyle[prop] = styles[prop];\n }\n });\n return parentGroup;\n },\n on: function () {\n if (parents[0].div) { // #6418\n wrapper.on.apply({\n element: parents[0].div,\n onEvents: parentGroup.onEvents\n }, arguments);\n }\n return parentGroup;\n },\n translateXSetter: translateSetter,\n translateYSetter: translateSetter\n });\n if (!parentGroup.addedSetters) {\n addSetters(parentGroup);\n }\n // Apply pre-existing style\n parentGroup.css(parentGroupStyles);\n });\n }\n }\n else {\n htmlGroup = container;\n }\n htmlGroup.appendChild(element);\n wrapper.added = true;\n if (wrapper.alignOnAdd) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n };\n return wrapper;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLRenderer;\n });\n _registerModule(_modules, 'Core/Axis/AxisDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var AxisDefaults;\n (function (AxisDefaults) {\n /* *\n *\n * Constants\n *\n * */\n /**\n * The X axis or category axis. Normally this is the horizontal axis,\n * though if the chart is inverted this is the vertical axis. In case of\n * multiple axes, the xAxis node is an array of configuration objects.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden, but it is used behind the scenes to\n * control features like zooming and panning. Zooming is in effect the same\n * as setting the extremes of one of the exes.\n *\n * @type {*|Array<*>}\n * @optionparent xAxis\n */\n AxisDefaults.defaultXAxisOptions = {\n /**\n * When using multiple axis, the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks, as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy, it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in an Axis options are set to false,\n * then the `alignTicks ` will be disabled for the Axis.\n *\n * Disabled for logarithmic axes.\n *\n * @product highcharts highstock gantt\n */\n alignTicks: true,\n /**\n * Whether to allow decimals in this axis' ticks. When counting\n * integers, like persons or hits on a web page, decimals should\n * be avoided in the labels. By default, decimals are allowed on small\n * scale axes.\n *\n * @see [minTickInterval](#xAxis.minTickInterval)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-true/\n * True by default\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-false/\n * False\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 2.0\n */\n allowDecimals: void 0,\n /**\n * When using an alternate grid color, a band is painted across the\n * plot area between every other grid line.\n *\n * @sample {highcharts} highcharts/yaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n * @sample {highstock} stock/xaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n *\n * @type {Highcharts.ColorType}\n * @apioption xAxis.alternateGridColor\n */\n /**\n * An array defining breaks in the axis, the sections defined will be\n * left out and all the points shifted closer to each other.\n *\n * @productdesc {highcharts}\n * Requires that the broken-axis.js module is loaded.\n *\n * @sample {highcharts} highcharts/axisbreak/break-simple/\n * Simple break\n * @sample {highcharts|highstock} highcharts/axisbreak/break-visualized/\n * Advanced with callback\n * @sample {highstock} stock/demo/intraday-breaks/\n * Break on nights and weekends\n *\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks\n */\n /**\n * A number indicating how much space should be left between the start\n * and the end of the break. The break size is given in axis units,\n * so for instance on a `datetime` axis, a break size of 3600000 would\n * indicate the equivalent of an hour.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.breakSize\n */\n /**\n * The point where the break starts.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.from\n */\n /**\n * Defines an interval after which the break appears again. By default\n * the breaks do not repeat.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.repeat\n */\n /**\n * The point where the break ends.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.to\n */\n /**\n * If categories are present for the xAxis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also\n * be extracted by giving each point a [name](#series.data) and setting\n * axis [type](#xAxis.type) to `category`. However, if you have multiple\n * series, best practice remains defining the `categories` array.\n *\n * Example: `categories: ['Apples', 'Bananas', 'Oranges']`\n *\n * @sample {highcharts} highcharts/demo/line-labels/\n * With\n * @sample {highcharts} highcharts/xaxis/categories/\n * Without\n *\n * @type {Array}\n * @product highcharts gantt\n * @apioption xAxis.categories\n */\n /**\n * The highest allowed value for automatically computed axis extremes.\n *\n * @see [floor](#xAxis.floor)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.ceiling\n */\n /**\n * A class name that opens for styling the axis by CSS, especially in\n * Highcharts styled mode. The class name is applied to group elements\n * for the grid, axis elements and labels.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/css/axis/\n * Multiple axes with separate styling\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.className\n */\n /**\n * Configure a crosshair that follows either the mouse pointer or the\n * hovered point.\n *\n * In styled mode, the crosshairs are styled in the\n * `.highcharts-crosshair`, `.highcharts-crosshair-thin` or\n * `.highcharts-xaxis-category` classes.\n *\n * @productdesc {highstock}\n * In Highcharts stock, by default, the crosshair is enabled on the\n * X axis and disabled on the Y axis.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Crosshair on both axes, with y axis label\n * @sample {highmaps} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n *\n * @declare Highcharts.AxisCrosshairOptions\n * @type {boolean|*}\n * @default false\n * @since 4.1\n * @apioption xAxis.crosshair\n */\n /**\n * The value on a perpendicular axis where this axis should cross. This\n * is typically used on mathematical plots where the axes cross at 0.\n * When `crossing` is set, space will not be reserved at the sides of\n * the chart for axis labels and title, so those may be clipped. In this\n * case it is better to place the axes without the `crossing` option.\n *\n * @type {number}\n * @sample highcharts/xaxis/crossing\n * Function plot with axes crossing at 0\n * @since 11.0.1\n * @apioption xAxis.crossing\n */\n /**\n * A class name for the crosshair, especially as a hook for styling.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.crosshair.className\n */\n /**\n * The color of the crosshair. Defaults to `#cccccc` for numeric and\n * datetime axes, and `rgba(204,214,235,0.25)` for category axes, where\n * the crosshair by default highlights the whole category.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {Highcharts.ColorType}\n * @default #cccccc\n * @since 4.1\n * @apioption xAxis.crosshair.color\n */\n /**\n * The dash style for the crosshair. See\n * [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n * for possible values.\n *\n * @sample {highcharts|highmaps} highcharts/xaxis/crosshair-dotted/\n * Dotted crosshair\n * @sample {highstock} stock/xaxis/crosshair-dashed/\n * Dashed X axis crosshair\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 4.1\n * @apioption xAxis.crosshair.dashStyle\n */\n /**\n * A label on the axis next to the crosshair.\n *\n * In styled mode, the label is styled with the\n * `.highcharts-crosshair-label` class.\n *\n * @sample {highstock} stock/xaxis/crosshair-label/\n * Crosshair labels\n * @sample {highstock} highcharts/css/crosshair-label/\n * Style mode\n *\n * @declare Highcharts.AxisCrosshairLabelOptions\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label\n */\n /**\n * Alignment of the label compared to the axis. Defaults to `\"left\"` for\n * right-side axes, `\"right\"` for left-side axes and `\"center\"` for\n * horizontal axes.\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.align\n */\n /**\n * The background color for the label. Defaults to the related series\n * color, or `#666666` if that is not available.\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.backgroundColor\n */\n /**\n * The border color for the crosshair label\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderColor\n */\n /**\n * The border corner radius of the crosshair label.\n *\n * @type {number}\n * @default 3\n * @since 2.1.10\n * @product highstock\n * @apioption xAxis.crosshair.label.borderRadius\n */\n /**\n * The border width for the crosshair label.\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderWidth\n */\n /**\n * Flag to enable crosshair's label.\n *\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Enabled label for yAxis' crosshair\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.enabled\n */\n /**\n * A format string for the crosshair label. Defaults to `{value}` for\n * numeric axes and `{value:%b %d, %Y}` for datetime axes.\n *\n * @type {string}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.format\n */\n /**\n * Formatter function for the label text.\n *\n * @type {Highcharts.XAxisCrosshairLabelFormatterCallbackFunction}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.formatter\n */\n /**\n * Padding inside the crosshair label.\n *\n * @type {number}\n * @default 8\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.padding\n */\n /**\n * The shape to use for the label box.\n *\n * @type {string}\n * @default callout\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.shape\n */\n /**\n * Text styles for the crosshair label.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"white\", \"fontWeight\": \"normal\", \"fontSize\": \"11px\", \"textAlign\": \"center\"}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.style\n */\n /**\n * Whether the crosshair should snap to the point or follow the pointer\n * independent of points.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/crosshair-snap-false/\n * True by default\n * @sample {highmaps} maps/demo/latlon-advanced/\n * Snap is false\n *\n * @type {boolean}\n * @default true\n * @since 4.1\n * @apioption xAxis.crosshair.snap\n */\n /**\n * The pixel width of the crosshair. Defaults to 1 for numeric or\n * datetime axes, and for one category width for category axes.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highstock} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {number}\n * @default 1\n * @since 4.1\n * @apioption xAxis.crosshair.width\n */\n /**\n * The Z index of the crosshair. Higher Z indices allow drawing the\n * crosshair on top of the series or behind the grid lines.\n *\n * @type {number}\n * @default 2\n * @since 4.1\n * @apioption xAxis.crosshair.zIndex\n */\n /**\n * Whether to pan axis. If `chart.panning` is enabled, the option\n * allows to disable panning on an individual axis.\n */\n panningEnabled: true,\n /**\n * The Z index for the axis group.\n */\n zIndex: 2,\n /**\n * Whether to zoom axis. If `chart.zoomType` is set, the option allows\n * to disable zooming on an individual axis.\n *\n * @sample {highcharts} highcharts/xaxis/zoomenabled/\n * Zoom enabled is false\n */\n zoomEnabled: true,\n /**\n * For a datetime axis, the scale will automatically adjust to the\n * appropriate unit. This member gives the default string\n * representations used for each unit. For intermediate values,\n * different units may be used, for example the `day` unit can be used\n * on midnight and `hour` unit be used for intermediate values on the\n * same axis.\n *\n * For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * Defaults to:\n * ```js\n * {\n * millisecond: '%H:%M:%S.%L',\n * second: '%H:%M:%S',\n * minute: '%H:%M',\n * hour: '%H:%M',\n * day: '%e. %b',\n * week: '%e. %b',\n * month: '%b \\'%y',\n * year: '%Y'\n * }\n * ```\n *\n * @sample {highcharts} highcharts/xaxis/datetimelabelformats/\n * Different day format on X axis\n * @sample {highstock} stock/xaxis/datetimelabelformats/\n * More information in x axis labels\n *\n * @declare Highcharts.AxisDateTimeLabelFormatsOptions\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n millisecond: {\n main: '%H:%M:%S.%L',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n second: {\n main: '%H:%M:%S',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n minute: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n hour: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n day: {\n main: '%e %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n week: {\n main: '%e %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n month: {\n main: '%b \\'%y'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n year: {\n main: '%Y'\n }\n },\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `endOnTick` is always `false` when the navigator\n * is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False\n *\n * @since 1.2.0\n */\n endOnTick: false,\n /**\n * Event handlers for the axis.\n *\n * @type {*}\n * @apioption xAxis.events\n */\n /**\n * An event fired after the breaks have rendered.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-event/\n * AfterBreak Event\n *\n * @type {Highcharts.AxisEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @apioption xAxis.events.afterBreaks\n */\n /**\n * As opposed to the `setExtremes` event, this event fires after the\n * final min and max values are computed and corrected for `minRange`.\n *\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function, containing\n * common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in axis values. The actual data extremes are found in\n * `event.dataMin` and `event.dataMax`.\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 2.3\n * @context Highcharts.Axis\n * @apioption xAxis.events.afterSetExtremes\n */\n /**\n * An event fired when a break from this axis occurs on a point.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-visualized/\n * Visualization of a Break\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointBreak\n */\n /**\n * An event fired when a point falls inside a break from this axis.\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @product highcharts highstock gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointInBreak\n */\n /**\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function,\n * containing common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in data values. When an axis is zoomed all the way out from\n * the \"Reset zoom\" button, `event.min` and `event.max` are null, and\n * the new extremes are set based on `this.dataMin` and `this.dataMax`.\n *\n * @sample {highstock} stock/xaxis/events-setextremes/\n * Log new extremes on x axis\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Axis\n * @apioption xAxis.events.setExtremes\n */\n /**\n * The lowest allowed value for automatically computed axis extremes.\n *\n * @see [ceiling](#yAxis.ceiling)\n *\n * @sample {highcharts} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n * @sample {highstock} stock/demo/lazy-loading/\n * Prevent negative stock price on Y axis\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.floor\n */\n /**\n * The dash or dot style of the grid lines. For possible values, see\n * [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/gridlinedashstyle/\n * Long dashes\n * @sample {highstock} stock/xaxis/gridlinedashstyle/\n * Long dashes\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n gridLineDashStyle: 'Solid',\n /**\n * The Z index of the grid lines.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/gridzindex/\n * A Z index of 4 renders the grid above the graph\n *\n * @product highcharts highstock gantt\n */\n gridZIndex: 1,\n /**\n * An id for the axis. This can be used after render time to get\n * a pointer to the axis object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/xaxis/id/\n * Get the object\n * @sample {highstock} stock/xaxis/id/\n * Get the object\n *\n * @type {string}\n * @since 1.2.0\n * @apioption xAxis.id\n */\n /**\n * The axis labels show the number or category for each tick.\n *\n * Since v8.0.0: Labels are animated in categorized x-axis with\n * updating data if `tickInterval` and `step` is set to 1.\n *\n * @productdesc {highmaps}\n * X and Y axis labels are by default disabled in Highmaps, but the\n * functionality is inherited from Highcharts and used on `colorAxis`,\n * and can be enabled on X and Y axes too.\n */\n labels: {\n /**\n * What part of the string the given position is anchored to.\n * If `left`, the left side of the string is at the axis position.\n * Can be one of `\"left\"`, `\"center\"` or `\"right\"`. Defaults to\n * an intelligent guess based on which side of the chart the axis\n * is on and the rotation of the label.\n *\n * @see [reserveSpace](#xAxis.labels.reserveSpace)\n *\n * @sample {highcharts} highcharts/xaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/xaxis/labels-align-right/\n * Right\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.labels.align\n */\n /**\n * Whether to allow the axis labels to overlap. When false,\n * overlapping labels are hidden.\n *\n * @sample {highcharts} highcharts/xaxis/labels-allowoverlap-true/\n * X axis labels overlap enabled\n *\n * @type {boolean}\n * @default false\n * @apioption xAxis.labels.allowOverlap\n */\n /**\n * For horizontal axes, the allowed degrees of label rotation\n * to prevent overlapping labels. If there is enough space,\n * labels are not rotated. As the chart gets narrower, it\n * will start rotating the labels -45 degrees, then remove\n * every second label and try again with rotations 0 and -45 etc.\n * Set it to `undefined` to disable rotation, which will\n * cause the labels to word-wrap if possible. Defaults to `[-45]``\n * on bottom and top axes, `undefined` on left and right axes.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-default/\n * Default auto rotation of 0 or -45\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-0-90/\n * Custom graded auto rotation\n *\n * @type {Array}\n * @default undefined\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.labels.autoRotation\n */\n autoRotation: void 0,\n /**\n * When each category width is more than this many pixels, we don't\n * apply auto rotation. Instead, we lay out the axis label with word\n * wrap. A lower limit makes sense when the label contains multiple\n * short words that don't extend the available horizontal space for\n * each label.\n *\n * @sample {highcharts} highcharts/xaxis/labels-autorotationlimit/\n * Lower limit\n *\n * @since 4.1.5\n * @product highcharts gantt\n */\n autoRotationLimit: 80,\n /**\n * The label's pixel distance from the perimeter of the plot area.\n * On cartesian charts, this is overridden if the `labels.y` setting\n * is set.\n *\n * @sample {highcharts} highcharts/yaxis/labels-distance/\n * Polar chart, labels centered under the arc\n *\n * @type {number}\n * @product highcharts gantt\n */\n distance: 15,\n /**\n * Enable or disable the axis labels.\n *\n * @sample {highcharts} highcharts/xaxis/labels-enabled/\n * X axis labels disabled\n * @sample {highstock} stock/xaxis/labels-enabled/\n * X axis labels disabled\n *\n */\n enabled: true,\n /**\n * A format string for the axis label. The context is available as\n * format string variables. For example, you can use `{text}` to\n * insert the default formatted text. The recommended way of adding\n * units for the label is using `text`, for example `{text} km`.\n *\n * To add custom numeric or datetime formatting, use `{value}` with\n * formatting, for example `{value:.1f}` or `{value:%Y-%m-%d}`.\n *\n * See\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for more examples of formatting.\n *\n * The default value is not specified due to the dynamic\n * nature of the default implementation.\n *\n * @sample {highcharts|highstock} highcharts/yaxis/labels-format/\n * Add units to Y axis label\n * @sample {highcharts} highcharts/xaxis/labels-format-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-format-custom/\n * Custom number format\n *\n * @type {string}\n * @since 3.0\n * @apioption xAxis.labels.format\n */\n /**\n * Callback JavaScript function to format the label. The value\n * is given by `this.value`. Additional properties for `this` are\n * `axis`, `chart`, `isFirst`, `isLast` and `text` which holds the\n * value of the default formatter.\n *\n * Defaults to a built in function returning a formatted string\n * depending on whether the axis is `category`, `datetime`,\n * `numeric` or other.\n *\n * @sample {highcharts} highcharts/xaxis/labels-formatter-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-formatter-extended/\n * Modified numeric labels\n * @sample {highstock} stock/xaxis/labels-formatter/\n * Added units on Y axis\n *\n * @type {Highcharts.AxisLabelsFormatterCallbackFunction}\n * @apioption xAxis.labels.formatter\n */\n /**\n * The number of pixels to indent the labels per level in a treegrid\n * axis.\n *\n * @sample gantt/treegrid-axis/demo\n * Indentation 10px by default.\n * @sample gantt/treegrid-axis/indentation-0px\n * Indentation set to 0px.\n *\n * @product gantt\n */\n indentation: 10,\n /**\n * Horizontal axis only. When `staggerLines` is not set,\n * `maxStaggerLines` defines how many lines the axis is allowed to\n * add to automatically avoid overlapping X labels. Set to `1` to\n * disable overlap detection.\n *\n * @deprecated\n * @type {number}\n * @default 5\n * @since 1.3.3\n * @apioption xAxis.labels.maxStaggerLines\n */\n /**\n * How to handle overflowing labels on horizontal axis. If set to\n * `\"allow\"`, it will not be aligned at all. By default it\n * `\"justify\"` labels inside the chart area. If there is room to\n * move it, it will be aligned to the edge, else it will be removed.\n *\n * @since 2.2.5\n * @validvalue [\"allow\", \"justify\"]\n */\n overflow: 'justify',\n /**\n * The pixel padding for axis labels, to ensure white space between\n * them.\n *\n * @product highcharts gantt\n */\n padding: 5,\n /**\n * Whether to reserve space for the labels. By default, space is\n * reserved for the labels in these cases:\n *\n * * On all horizontal axes.\n * * On vertical axes if `label.align` is `right` on a left-side\n * axis or `left` on a right-side axis.\n * * On vertical axes if `label.align` is `center`.\n *\n * This can be turned off when for example the labels are rendered\n * inside the plot area instead of outside.\n *\n * @see [labels.align](#xAxis.labels.align)\n *\n * @sample {highcharts} highcharts/xaxis/labels-reservespace/\n * No reserved space, labels inside plot\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {boolean}\n * @since 4.1.10\n * @product highcharts highstock gantt\n * @apioption xAxis.labels.reserveSpace\n */\n reserveSpace: void 0,\n /**\n * Rotation of the labels in degrees. When `undefined`, the\n * `autoRotation` option takes precedence.\n *\n * @sample {highcharts} highcharts/xaxis/labels-rotation/\n * X axis labels rotated 90°\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.labels.rotation\n */\n rotation: void 0,\n /**\n * Horizontal axes only. The number of lines to spread the labels\n * over to make room or tighter labels. 0 disables staggering.\n *\n * @sample {highcharts} highcharts/xaxis/labels-staggerlines/\n * Show labels over two lines\n * @sample {highstock} stock/xaxis/labels-staggerlines/\n * Show labels over two lines\n *\n * @since 2.1\n */\n staggerLines: 0,\n /**\n * To show only every _n_'th label on the axis, set the step to _n_.\n * Setting the step to 2 shows every other label.\n *\n * By default, when 0, the step is calculated automatically to avoid\n * overlap. To prevent this, set it to 1\\. This usually only\n * happens on a category axis, and is often a sign that you have\n * chosen the wrong axis type.\n *\n * Read more at\n * [Axis docs](https://www.highcharts.com/docs/chart-concepts/axes)\n * => What axis should I use?\n *\n * @sample {highcharts} highcharts/xaxis/labels-step/\n * Showing only every other axis label on a categorized\n * x-axis\n * @sample {highcharts} highcharts/xaxis/labels-step-auto/\n * Auto steps on a category axis\n *\n * @since 2.1\n */\n step: 0,\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n */\n useHTML: false,\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis. Overrides the `labels.distance` option.\n *\n * @type {number}\n * @apioption xAxis.labels.x\n */\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. Overrides the `labels.distance` option.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * X axis labels placed on grid lines\n *\n * @type {number}\n * @apioption xAxis.labels.y\n */\n /**\n * The Z index for the axis labels.\n */\n zIndex: 7,\n /**\n * CSS styles for the label. Use `whiteSpace: 'nowrap'` to prevent\n * wrapping of category labels. Use `textOverflow: 'none'` to\n * prevent ellipsis (dots).\n *\n * In styled mode, the labels are styled with the\n * `.highcharts-axis-labels` class.\n *\n * @sample {highcharts} highcharts/xaxis/labels-style/\n * Red X axis labels\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '0.8em'\n }\n },\n /**\n * The left position as the horizontal axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the plot width, offset from plot area\n * left.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.left\n */\n /**\n * The top position as the vertical axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the plot height, offset from plot area top.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.top\n */\n /**\n * Index of another axis that this axis is linked to. When an axis is\n * linked to a master axis, it will take the same extremes as\n * the master, but as assigned by min or max or by setExtremes.\n * It can be used to show additional info, or to ease reading the\n * chart by duplicating the scales.\n *\n * @sample {highcharts} highcharts/xaxis/linkedto/\n * Different string formats of the same date\n * @sample {highcharts} highcharts/yaxis/linkedto/\n * Y values on both sides\n *\n * @type {number}\n * @since 2.0.2\n * @product highcharts highstock gantt\n * @apioption xAxis.linkedTo\n */\n /**\n * The maximum value of the axis. If `null`, the max value is\n * automatically calculated.\n *\n * If the [endOnTick](#yAxis.endOnTick) option is true, the `max` value\n * might be rounded up.\n *\n * If a [tickAmount](#yAxis.tickAmount) is set, the axis may be extended\n * beyond the set max in order to reach the given number of ticks. The\n * same may happen in a chart with multiple axes, determined by [chart.\n * alignTicks](#chart), where a `tickAmount` is applied internally.\n *\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/xaxis/min-max/\n * Fixed min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.max\n */\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding/\n * Max padding of 0.25 on y axis\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n */\n maxPadding: 0.01,\n /**\n * Deprecated. Use `minRange` instead.\n *\n * @deprecated\n * @type {number}\n * @product highcharts highstock\n * @apioption xAxis.maxZoom\n */\n /**\n * The minimum value of the axis. If `null` the min value is\n * automatically calculated.\n *\n * If the [startOnTick](#yAxis.startOnTick) option is true (default),\n * the `min` value might be rounded down.\n *\n * The automatically calculated minimum value is also affected by\n * [floor](#yAxis.floor), [softMin](#yAxis.softMin),\n * [minPadding](#yAxis.minPadding), [minRange](#yAxis.minRange)\n * as well as [series.threshold](#plotOptions.series.threshold)\n * and [series.softThreshold](#plotOptions.series.softThreshold).\n *\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/xaxis/min-max/\n * Set min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.min\n */\n /**\n * The dash or dot style of the minor grid lines. For possible values,\n * see [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n * @sample {highstock} stock/xaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n minorGridLineDashStyle: 'Solid',\n /**\n * Specific tick interval in axis units for the minor ticks. On a linear\n * axis, if `\"auto\"`, the minor tick interval is calculated as a fifth\n * of the tickInterval. If `null` or `undefined`, minor ticks are not\n * shown.\n *\n * On logarithmic axes, the unit is the power of the value. For example,\n * setting the minorTickInterval to 1 puts one tick on each of 0.1, 1,\n * 10, 100 etc. Setting the minorTickInterval to 0.1 produces 9 ticks\n * between 1 and 10, 10 and 100 etc.\n *\n * If user settings dictate minor ticks to become too dense, they don't\n * make sense, and will be ignored to prevent performance problems.\n *\n * @sample {highcharts} highcharts/yaxis/minortickinterval-null/\n * Null by default\n * @sample {highcharts} highcharts/yaxis/minortickinterval-5/\n * 5 units\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log-auto/\n * \"auto\"\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log/\n * 0.1\n * @sample {highstock} stock/demo/basic-line/\n * Null by default\n * @sample {highstock} stock/xaxis/minortickinterval-auto/\n * \"auto\"\n *\n * @type {number|string|null}\n * @apioption xAxis.minorTickInterval\n */\n /**\n * The pixel length of the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minorticklength/\n * 10px on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * 10px on Y axis\n */\n minorTickLength: 2,\n /**\n * The position of the minor tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/yaxis/minortickposition-outside/\n * Outside by default\n * @sample {highcharts} highcharts/yaxis/minortickposition-inside/\n * Inside\n * @sample {highstock} stock/xaxis/minorticks/\n * Inside\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n minorTickPosition: 'outside',\n /**\n * Enable or disable minor ticks. The interval between the minor ticks\n * can be controlled either by the\n * [minorTicksPerMajor](#xAxis.minorTicksPerMajor) setting, or as an\n * absolute [minorTickInterval](#xAxis.minorTickInterval) value.\n *\n * On a logarithmic axis, minor ticks are laid out based on a best\n * guess, attempting to enter an approximate number of minor ticks\n * between each major tick based on\n * [minorTicksPerMajor](#xAxis.minorTicksPerMajor).\n *\n * Prior to v6.0.0, ticks were enabled in auto layout by setting\n * `minorTickInterval` to `\"auto\"`.\n *\n * @productdesc {highcharts} On axes using\n * [categories](#xAxis.categories), minor ticks are not supported.\n *\n * @sample {highcharts} highcharts/yaxis/minorticks-true/ Enabled on\n * linear Y axis\n *\n * @type {boolean}\n * @default false\n * @since 6.0.0\n * @apioption xAxis.minorTicks\n */\n /**\n * The number of minor ticks per major tick. Works for `linear`,\n * `logarithmic` and `datetime` axes.\n *\n * @sample {highcharts} highcharts/yaxis/minortickspermajor/\n * 2 minor ticks per major tick on Y axis\n *\n * @type {number}\n */\n minorTicksPerMajor: 5,\n /**\n * The pixel width of the minor tick mark.\n *\n * @sample {highcharts} highcharts/yaxis/minortickwidth/\n * 3px width\n * @sample {highstock} stock/xaxis/minorticks/\n * 1px width\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.minorTickWidth\n */\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a min extreme\n * is set using `axis.setExtremes()`, the minPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.01,\n /**\n * The minimum range to display on this axis. The entire axis will not\n * be allowed to span over a smaller interval than this. For example,\n * for a datetime axis the main unit is milliseconds. If minRange is\n * set to 3600000, you can't zoom in more than to one hour.\n *\n * The default minRange for the x axis is five times the smallest\n * interval between any of the data points.\n *\n * On a logarithmic axis, the unit for the minimum range is the power.\n * So a minRange of 1 means that the axis can be zoomed to 10-100,\n * 100-1000, 1000-10000 etc.\n *\n * **Note**: The `minPadding`, `maxPadding`, `startOnTick` and\n * `endOnTick` settings also affect how the extremes of the axis\n * are computed.\n *\n * @sample {highcharts} highcharts/xaxis/minrange/\n * Minimum range of 5\n * @sample {highstock} stock/xaxis/minrange/\n * Max zoom of 6 months overrides user selections\n *\n * @type {number}\n * @apioption xAxis.minRange\n */\n /**\n * The minimum tick interval allowed in axis values. For example on\n * zooming in on an axis with daily data, this can be used to prevent\n * the axis from showing hours. Defaults to the closest distance between\n * two points on the axis.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption xAxis.minTickInterval\n */\n /**\n * The distance in pixels from the plot area to the axis line.\n * A positive offset moves the axis with it's line, labels and ticks\n * away from the plot area. This is typically used when two or more\n * axes are displayed on the same side of the plot. With multiple\n * axes the offset is dynamically adjusted to avoid collision, this\n * can be overridden by setting offset explicitly.\n *\n * @sample {highcharts} highcharts/yaxis/offset/\n * Y axis offset of 70\n * @sample {highcharts} highcharts/yaxis/offset-centered/\n * Axes positioned in the center of the plot\n * @sample {highstock} stock/xaxis/offset/\n * Y axis offset by 70 px\n *\n * @type {number}\n */\n offset: void 0,\n /**\n * Whether to display the axis on the opposite side of the normal. The\n * normal is on the left side for vertical axes and bottom for\n * horizontal, so the opposite sides will be right and top respectively.\n * This is typically used with dual or multiple axes.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @default {highcharts|highstock|highmaps} false\n * @default {gantt} true\n */\n opposite: false,\n /**\n * In an ordinal axis, the points are equally spaced in the chart\n * regardless of the actual time or x distance between them. This means\n * that missing data periods (e.g. nights or weekends for a stock chart)\n * will not take up space in the chart.\n * Having `ordinal: false` will show any gaps created by the `gapSize`\n * setting proportionate to their duration.\n *\n * In stock charts the X axis is ordinal by default, unless\n * the boost module is used and at least one of the series' data length\n * exceeds the [boostThreshold](#series.line.boostThreshold).\n *\n * For an ordinal axis, `minPadding` and `maxPadding` are ignored. Use\n * [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highstock} stock/xaxis/ordinal-true/\n * True by default\n * @sample {highstock} stock/xaxis/ordinal-false/\n * False\n *\n * @see [overscroll](#xAxis.overscroll)\n *\n * @type {boolean}\n * @default true\n * @since 1.1\n * @product highstock\n * @apioption xAxis.ordinal\n */\n /**\n * Additional range on the right side of the xAxis. Works similar to\n * `xAxis.maxPadding`, but value is set in milliseconds. Can be set for\n * both main `xAxis` and the navigator's `xAxis`.\n *\n * @sample {highstock} stock/xaxis/overscroll/\n * One minute overscroll with live data\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @product highstock\n * @apioption xAxis.overscroll\n */\n /**\n * Refers to the index in the [panes](#panes) array. Used for circular\n * gauges and polar charts. When the option is not set then first pane\n * will be used.\n *\n * @sample highcharts/demo/gauge-vu-meter\n * Two gauges with different center\n *\n * @type {number}\n * @product highcharts\n * @apioption xAxis.pane\n */\n /**\n * The zoomed range to display when only defining one or none of `min`\n * or `max`. For example, to show the latest month, a range of one month\n * can be set.\n *\n * @sample {highstock} stock/xaxis/range/\n * Setting a zoomed range when the rangeSelector is disabled\n *\n * @type {number}\n * @product highstock\n * @apioption xAxis.range\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin. If the chart is inverted, the x axis is reversed by\n * default.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default undefined\n * @apioption xAxis.reversed\n */\n reversed: void 0,\n /**\n * This option determines how stacks should be ordered within a group.\n * For example reversed xAxis also reverses stacks, so first series\n * comes last in a group. To keep order like for non-reversed xAxis\n * enable this option.\n *\n * @sample {highcharts} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n * @sample {highstock} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n *\n * @since 6.1.1\n * @product highcharts highstock\n */\n reversedStacks: false,\n /**\n * An optional scrollbar to display on the X axis in response to\n * limiting the minimum and maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar are\n * replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/heatmap-scrollbars/\n * Heatmap with both scrollbars\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @apioption xAxis.scrollbar\n */\n /**\n * Whether to show the axis line and title when the axis has no data.\n *\n * @sample {highcharts} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n * @sample {highstock} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n *\n * @since 1.1\n */\n showEmpty: true,\n /**\n * Whether to show the first tick label.\n *\n * @sample {highcharts} highcharts/xaxis/showfirstlabel-false/\n * Set to false on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n */\n showFirstLabel: true,\n /**\n * Whether to show the last tick label. Defaults to `true` on cartesian\n * charts, and `false` on polar charts.\n *\n * @sample {highcharts} highcharts/xaxis/showlastlabel-true/\n * Set to true on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n *\n * @type {boolean}\n * @default undefined\n * @product highcharts highstock gantt\n */\n showLastLabel: true,\n /**\n * A soft maximum for the axis. If the series data maximum is less than\n * this, the axis will stay at this maximum, but if the series data\n * maximum is higher, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMin\n */\n /**\n * For datetime axes, this decides where to put the tick between weeks.\n * 0 = Sunday, 1 = Monday.\n *\n * @sample {highcharts} highcharts/xaxis/startofweek-monday/\n * Monday by default\n * @sample {highcharts} highcharts/xaxis/startofweek-sunday/\n * Sunday\n * @sample {highstock} stock/xaxis/startofweek-1\n * Monday by default\n * @sample {highstock} stock/xaxis/startofweek-0\n * Sunday\n *\n * @product highcharts highstock gantt\n */\n startOfWeek: 1,\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `minPadding` option to control the axis start.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `startOnTick` is always `false` when\n * the navigator is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n *\n * @since 1.2.0\n */\n startOnTick: false,\n /**\n * The amount of ticks to draw on the axis. This opens up for aligning\n * the ticks of multiple charts or panes within a chart. This option\n * overrides the `tickPixelInterval` option.\n *\n * This option only has an effect on linear axes. Datetime, logarithmic\n * or category axes are not affected.\n *\n * @sample {highcharts} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n * @sample {highstock} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.tickAmount\n */\n /**\n * The interval of the tick marks in axis units. When `undefined`, the\n * tick interval is computed to approximately follow the\n * [tickPixelInterval](#xAxis.tickPixelInterval) on linear and datetime\n * axes. On categorized axes, a `undefined` tickInterval will default to\n * 1, one category. Note that datetime axes are based on milliseconds,\n * so for example an interval of one day is expressed as\n * `24 * 3600 * 1000`.\n *\n * On logarithmic axes, the tickInterval is based on powers, so a\n * tickInterval of 1 means one tick on each of 0.1, 1, 10, 100 etc. A\n * tickInterval of 2 means a tick of 0.1, 10, 1000 etc. A tickInterval\n * of 0.2 puts a tick on 0.1, 0.2, 0.4, 0.6, 0.8, 1, 2, 4, 6, 8, 10, 20,\n * 40 etc.\n *\n *\n * If the tickInterval is too dense for labels to be drawn, Highcharts\n * may remove ticks.\n *\n * If the chart has multiple axes, the [alignTicks](#chart.alignTicks)\n * option may interfere with the `tickInterval` setting.\n *\n * @see [tickPixelInterval](#xAxis.tickPixelInterval)\n * @see [tickPositions](#xAxis.tickPositions)\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickinterval-5/\n * Tick interval of 5 on a linear axis\n * @sample {highstock} stock/xaxis/tickinterval/\n * Tick interval of 0.01 on Y axis\n *\n * @type {number}\n * @apioption xAxis.tickInterval\n */\n /**\n * The pixel length of the main tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/ticklength/\n * 20 px tick length on the X axis\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n */\n tickLength: 10,\n /**\n * If tickInterval is `null` this option sets the approximate pixel\n * interval of the tick marks. Not applicable to categorized axis.\n *\n * The tick interval is also influenced by the [minTickInterval](\n * #xAxis.minTickInterval) option, that, by default prevents ticks from\n * being denser than the data points.\n *\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpixelinterval-50/\n * 50 px on X axis\n * @sample {highstock} stock/xaxis/tickpixelinterval/\n * 200 px on X axis\n */\n tickPixelInterval: 100,\n /**\n * For categorized axes only. If `on` the tick mark is placed in the\n * center of the category, if `between` the tick mark is placed between\n * categories. The default is `between` if the `tickInterval` is 1, else\n * `on`.\n *\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-between/\n * \"between\" by default\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-on/\n * \"on\"\n *\n * @product highcharts gantt\n * @validvalue [\"on\", \"between\"]\n */\n tickmarkPlacement: 'between',\n /**\n * The position of the major tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/xaxis/tickposition-outside/\n * \"outside\" by default\n * @sample {highcharts} highcharts/xaxis/tickposition-inside/\n * \"inside\"\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n tickPosition: 'outside',\n /**\n * A callback function returning array defining where the ticks are\n * laid out on the axis. This overrides the default behaviour of\n * [tickPixelInterval](#xAxis.tickPixelInterval) and [tickInterval](\n * #xAxis.tickInterval). The automatic tick positions are accessible\n * through `this.tickPositions` and can be modified by the callback.\n *\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Highcharts.AxisTickPositionerCallbackFunction}\n * @apioption xAxis.tickPositioner\n */\n /**\n * An array defining where the ticks are laid out on the axis. This\n * overrides the default behaviour of [tickPixelInterval](\n * #xAxis.tickPixelInterval) and [tickInterval](#xAxis.tickInterval).\n *\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Array}\n * @apioption xAxis.tickPositions\n */\n /**\n * The pixel width of the major tick marks. Defaults to 0 on category\n * axes, otherwise 1.\n *\n * In styled mode, the stroke width is given in the `.highcharts-tick`\n * class, but in order for the element to be generated on category axes,\n * the option must be explicitly set to 1.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/\n * 10 px width\n * @sample {highcharts} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n * @sample {highstock} highcharts/css/axis-grid/\n * Styled mode\n *\n * @type {undefined|number}\n * @default {highstock} 1\n * @default {highmaps} 0\n * @apioption xAxis.tickWidth\n */\n /**\n * The axis title, showing next to the axis line.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden by default, but adding an axis title\n * is still possible. X axis and Y axis titles will appear at the bottom\n * and left by default.\n */\n title: {\n /**\n * Alignment of the title relative to the axis values. Possible\n * values are \"low\", \"middle\" or \"high\".\n *\n * @sample {highcharts} highcharts/xaxis/title-align-low/\n * \"low\"\n * @sample {highcharts} highcharts/xaxis/title-align-center/\n * \"middle\" by default\n * @sample {highcharts} highcharts/xaxis/title-align-high/\n * \"high\"\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the Y axis title on top of the axis\n * @sample {highstock} stock/xaxis/title-align/\n * Aligned to \"high\" value\n *\n * @type {Highcharts.AxisTitleAlignValue}\n */\n align: 'middle',\n /**\n * Deprecated. Set the `text` to `undefined` to disable the title.\n *\n * @deprecated\n * @type {boolean}\n * @product highcharts\n * @apioption xAxis.title.enabled\n */\n /**\n * The pixel distance between the axis labels or line and the title.\n * Defaults to 0 for horizontal axes, 10 for vertical\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @apioption xAxis.title.margin\n */\n /**\n * The distance of the axis title from the axis line. By default,\n * this distance is computed from the offset width of the labels,\n * the labels' distance from the axis and the title's margin.\n * However when the offset option is set, it overrides all this.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the axis title on top of the axis\n * @sample {highstock} highcharts/yaxis/title-offset/\n * Place the axis title on top of the Y axis\n *\n * @type {number}\n * @since 2.2.0\n * @apioption xAxis.title.offset\n */\n /**\n * Whether to reserve space for the title when laying out the axis.\n *\n * @type {boolean}\n * @default true\n * @since 5.0.11\n * @product highcharts highstock gantt\n * @apioption xAxis.title.reserveSpace\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 0,\n /**\n * The actual text of the axis title. It can contain basic HTML tags\n * like `b`, `i` and `span` with style.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n * @sample {highstock} stock/xaxis/title-text/\n * Titles for both axes\n *\n * @type {string|null}\n * @apioption xAxis.title.text\n */\n /**\n * Alignment of the text, can be `\"left\"`, `\"right\"` or `\"center\"`.\n * Default alignment depends on the\n * [title.align](xAxis.title.align):\n *\n * Horizontal axes:\n * - for `align` = `\"low\"`, `textAlign` is set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"`, `textAlign` is set to `right`\n *\n * Vertical axes:\n * - for `align` = `\"low\"` and `opposite` = `true`, `textAlign` is\n * set to `right`\n * - for `align` = `\"low\"` and `opposite` = `false`, `textAlign` is\n * set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"` and `opposite` = `true` `textAlign` is\n * set to `left`\n * - for `align` = `\"high\"` and `opposite` = `false` `textAlign` is\n * set to `right`\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.title.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the axis title.\n *\n * @product highcharts highstock gantt\n */\n useHTML: false,\n /**\n * Horizontal pixel offset of the title position.\n *\n * @since 4.1.6\n * @product highcharts highstock gantt\n */\n x: 0,\n /**\n * Vertical pixel offset of the title position.\n *\n * @product highcharts highstock gantt\n */\n y: 0,\n /**\n * CSS styles for the title. If the title text is longer than the\n * axis length, it will wrap to multiple lines by default. This can\n * be customized by setting `textOverflow: 'ellipsis'`, by\n * setting a specific `width` or by setting `whiteSpace: 'nowrap'`.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-title` class.\n *\n * @sample {highcharts} highcharts/xaxis/title-style/\n * Red\n * @sample {highcharts} highcharts/css/axis/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /** @internal */\n fontSize: '0.8em'\n }\n },\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`\n * or `category`. In a datetime axis, the numbers are given in\n * milliseconds, and tick marks are placed on appropriate values like\n * full hours or days. In a category axis, the\n * [point names](#series.line.data.name) of the chart's series are used\n * for categories, if not a [categories](#xAxis.categories) array is\n * defined.\n *\n * @sample {highcharts} highcharts/xaxis/type-linear/\n * Linear\n * @sample {highcharts} highcharts/yaxis/type-log/\n * Logarithmic\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/xaxis/type-log-both/\n * Logarithmic on two axes\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n *\n * @type {Highcharts.AxisTypeValue}\n * @product highcharts gantt\n */\n type: 'linear',\n /**\n * If there are multiple axes on the same side of the chart, the pixel\n * margin between the axes. Defaults to 0 on vertical axes, 15 on\n * horizontal axes.\n *\n * @type {number}\n * @since 7.0.3\n * @apioption xAxis.margin\n */\n /**\n * Applies only when the axis `type` is `category`. When `uniqueNames`\n * is true, points are placed on the X axis according to their names.\n * If the same point name is repeated in the same or another series,\n * the point is placed on the same X position as other points of the\n * same name. When `uniqueNames` is false, the points are laid out in\n * increasing X positions regardless of their names, and the X axis\n * category will take the name of the last point in each position.\n *\n * @sample {highcharts} highcharts/xaxis/uniquenames-true/\n * True by default\n * @sample {highcharts} highcharts/xaxis/uniquenames-false/\n * False\n *\n * @since 4.2.7\n * @product highcharts gantt\n */\n uniqueNames: true,\n /**\n * Datetime axis only. An array determining what time intervals the\n * ticks are allowed to fall on. Each array item is an array where the\n * first value is the time unit and the second value another array of\n * allowed multiples.\n *\n * Defaults to:\n * ```js\n * units: [[\n * 'millisecond', // unit name\n * [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n * ], [\n * 'second',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'minute',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'hour',\n * [1, 2, 3, 4, 6, 8, 12]\n * ], [\n * 'day',\n * [1, 2]\n * ], [\n * 'week',\n * [1, 2]\n * ], [\n * 'month',\n * [1, 2, 3, 4, 6]\n * ], [\n * 'year',\n * null\n * ]]\n * ```\n *\n * @sample {highcharts} highcharts/xaxis/units/\n * Axis units demonstrated\n *\n * @type {Array|null)>>}\n * @product highcharts highstock gantt\n * @apioption xAxis.units\n */\n /**\n * Whether axis, including axis title, line, ticks and labels, should\n * be visible.\n *\n * @since 4.1.9\n * @product highcharts highstock gantt\n */\n visible: true,\n /**\n * Color of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-minor-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #f2f2f2\n */\n minorGridLineColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * Width of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinewidth/\n * 2px lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinewidth/\n * 2px lines from Y axis\n */\n minorGridLineWidth: 1,\n /**\n * Color for the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minortickcolor/\n * Black tick marks on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * Black tick marks on Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #999999\n */\n minorTickColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The color of the line marking the axis itself.\n *\n * In styled mode, the line stroke is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A red line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linecolor/\n * A red line on X axis\n *\n * @type {Highcharts.ColorType}\n */\n lineColor: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * The width of the line marking the axis itself.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A 1px line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linewidth/\n * A 2px line on X axis\n *\n * @default {highcharts|highstock} 1\n * @default {highmaps} 0\n */\n lineWidth: 1,\n /**\n * Color of the grid lines extending the ticks across the plot area.\n *\n * In styled mode, the stroke is given in the `.highcharts-grid-line`\n * class.\n *\n * @productdesc {highmaps}\n * In Highmaps, the grid lines are hidden by default.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinecolor/\n * Green lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinecolor/\n * Green lines\n *\n * @type {Highcharts.ColorType}\n * @default #e6e6e6\n */\n gridLineColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n /**\n * The width of the grid lines extending the ticks across the plot area.\n * Defaults to 1 on the Y axis and 0 on the X axis, except for 3d\n * charts.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinewidth/\n * 2px lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinewidth/\n * 2px lines\n *\n * @type {number}\n * @apioption xAxis.gridLineWidth\n */\n gridLineWidth: void 0,\n /**\n * The height as the vertical axis. If it's a number, it is\n * interpreted as pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the total plot height.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.height\n */\n /**\n * The width as the horizontal axis. If it's a number, it is interpreted\n * as pixels.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the total plot width.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.width\n */\n /**\n * Color for the main tick marks.\n *\n * In styled mode, the stroke is given in the `.highcharts-tick`\n * class.\n *\n * @sample {highcharts} highcharts/xaxis/tickcolor/\n * Red ticks on X axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @type {Highcharts.ColorType}\n */\n tickColor: \"#333333\" /* Palette.neutralColor80 */\n // tickWidth: 1\n };\n /**\n * The Y axis or value axis. Normally this is the vertical axis,\n * though if the chart is inverted this is the horizontal axis.\n * In case of multiple axes, the yAxis node is an array of\n * configuration objects.\n *\n * See [the Axis object](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @excluding currentDateIndicator,ordinal,overscroll\n * @optionparent yAxis\n */\n AxisDefaults.defaultYAxisOptions = {\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`,\n * `category` or `treegrid`. Defaults to `treegrid` for Gantt charts,\n * `linear` for other chart types.\n *\n * In a datetime axis, the numbers are given in milliseconds, and tick\n * marks are placed on appropriate values, like full hours or days. In a\n * category or treegrid axis, the [point names](#series.line.data.name)\n * of the chart's series are used for categories, if a\n * [categories](#xAxis.categories) array is not defined.\n *\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n * @sample {gantt} gantt/treegrid-axis/demo\n * Treegrid axis\n *\n * @type {Highcharts.AxisTypeValue}\n * @default {highcharts} linear\n * @default {gantt} treegrid\n * @product highcharts gantt\n * @apioption yAxis.type\n */\n /**\n * The height of the Y axis. If it's a number, it is interpreted as\n * pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the total plot height.\n *\n * @see [yAxis.top](#yAxis.top)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.height\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the maximum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max colors\n *\n * @type {Highcharts.ColorType}\n * @default #003399\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.maxColor\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the minimum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max color\n *\n * @type {Highcharts.ColorType}\n * @default #e6ebf5\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.minColor\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} true\n * @apioption yAxis.reversed\n */\n /**\n * If `true`, the first series in a stack will be drawn on top in a\n * positive, non-reversed Y axis. If `false`, the first series is in\n * the base of the stack.\n *\n * @sample {highcharts} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n * @sample {highstock} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n *\n * @type {boolean}\n * @default true\n * @since 3.0.10\n * @product highcharts highstock\n * @apioption yAxis.reversedStacks\n */\n reversedStacks: true,\n /**\n * Solid gauge series only. Color stops for the solid gauge. Use this\n * in cases where a linear gradient between a `minColor` and `maxColor`\n * is not sufficient. The stops is an array of tuples, where the first\n * item is a float between 0 and 1 assigning the relative position in\n * the gradient, and the second item is the color.\n *\n * For solid gauges, the Y axis also inherits the concept of\n * [data classes](https://api.highcharts.com/highmaps#colorAxis.dataClasses)\n * from the Highmaps color axis.\n *\n * @sample {highcharts} highcharts/demo/gauge-solid/\n * Gauge with stops\n *\n * @see [minColor](#yAxis.minColor)\n * @see [maxColor](#yAxis.maxColor)\n *\n * @type {Array>}\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.stops\n */\n /**\n * The pixel width of the major tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/ 10 px width\n * @sample {highstock} stock/xaxis/ticks/ Formatted ticks on X axis\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption yAxis.tickWidth\n */\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n */\n endOnTick: true,\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `maxPadding`,\n * so if the data is tangent to the threshold, `maxPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding-02/\n * Max padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n maxPadding: 0.05,\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `minPadding`,\n * so if the data is tangent to the threshold, `minPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.05,\n /**\n * @productdesc {highstock}\n * In Highcharts Stock 1.x, the Y axis was placed\n * on the left side by default.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @type {boolean}\n * @default {highstock} true\n * @default {highcharts} false\n * @product highstock highcharts gantt\n * @apioption yAxis.opposite\n */\n /**\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n */\n tickPixelInterval: 72,\n /**\n * Whether to show the last tick label.\n *\n * @productdesc {highcharts|gantt}\n * Defaults to `true` on cartesian charts, and `false` on polar charts.\n *\n * @productdesc {highstock}\n * Defaults to `true` for categorized yAxis and `false` for other types\n * of yAxis.\n *\n * @default undefined\n */\n showLastLabel: true,\n /**\n * @extends xAxis.labels\n */\n labels: {\n /**\n * The label's pixel distance from the perimeter of the plot area.\n * On cartesian charts, this is overridden if the `labels.y` setting\n * is set.\n *\n * On polar charts, if it's a percentage string, it is interpreted\n * the same as [series.radius](#plotOptions.gauge.radius), so the\n * label can be aligned under the gauge's shape.\n *\n * @sample {highcharts} highcharts/yaxis/labels-distance/\n * Polar chart, labels centered under the arc\n *\n * @type {number|string}\n * @product highcharts\n * @apioption yAxis.labels.distance\n */\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. For polar and radial axis consider the use\n * of the [distance](#yAxis.labels.distance) option.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n * @default {highcharts} 3\n * @default {highstock} -2\n * @default {highmaps} 3\n * @apioption yAxis.labels.y\n */\n /**\n * What part of the string the given position is anchored to. Can\n * be one of `\"left\"`, `\"center\"` or `\"right\"`. The exact position\n * also depends on the `labels.x` setting.\n *\n * Angular gauges and solid gauges defaults to `\"center\"`.\n * Solid gauges with two labels have additional option `\"auto\"`\n * for automatic horizontal and vertical alignment.\n *\n * @sample {highcharts} highcharts/yaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge labels auto aligned\n *\n * @type {Highcharts.AlignValue}\n * @default {highstock} right\n * @apioption yAxis.labels.align\n */\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis. Defaults to -15 for left axis, 15 for\n * right axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n */\n x: void 0\n },\n /**\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.max\n */\n /**\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.min\n */\n /**\n * An optional scrollbar to display on the Y axis in response to\n * limiting the minimum an maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar\n * are replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Scrollbar on the Y axis\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @excluding height\n * @apioption yAxis.scrollbar\n */\n /**\n * Enable the scrollbar on the Y axis.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Enabled on Y axis\n *\n * @type {boolean}\n * @default false\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.enabled\n */\n /**\n * Pixel margin between the scrollbar and the axis elements.\n *\n * @type {number}\n * @default 10\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.margin\n */\n /* eslint-disable highcharts/doclet-apioption-last */\n /**\n * Defines the position of the scrollbar. By default, it is positioned\n * on the opposite of the main axis (right side of the chart).\n * However, in the case of RTL languages could be set to `false`\n * which positions the scrollbar on the left.\n *\n * Works only for vertical axes.\n * This means yAxis in a non-inverted chart and xAxis in the inverted.\n *\n * @sample stock/yaxis/scrollbar-opposite/\n * A scrollbar not on the opposite side\n *\n * @type {boolean}\n * @default true\n * @since 9.3.0\n *\n * @apioption yAxis.scrollbar.opposite\n * @apioption xAxis.scrollbar.opposite\n *\n */\n /* eslint-enable highcharts/doclet-apioption-last */\n /**\n * Whether to show the scrollbar when it is fully zoomed out at max\n * range. Setting it to `false` on the Y axis makes the scrollbar stay\n * hidden until the user zooms in, like common in browsers.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.showFull\n */\n /**\n * The width of a vertical scrollbar or height of a horizontal\n * scrollbar. Defaults to 20 on touch devices.\n *\n * @type {number}\n * @default 14\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.size\n */\n /**\n * Z index of the scrollbar elements.\n *\n * @type {number}\n * @default 3\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.zIndex\n */\n /**\n * A soft maximum for the axis. If the series data maximum is less\n * than this, the axis will stay at this maximum, but if the series\n * data maximum is higher, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMin\n */\n /**\n * Defines the horizontal alignment of the stack total label. Can be one\n * of `\"left\"`, `\"center\"` or `\"right\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-left/\n * Aligned to the left\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-center/\n * Aligned in center\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-right/\n * Aligned to the right\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.align\n */\n /**\n * A format string for the data label. Available variables are the same\n * as for `formatter`.\n *\n * @type {string}\n * @default {total}\n * @since 3.0.2\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.format\n */\n /**\n * Rotation of the labels in degrees.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-rotation/\n * Labels rotated 45°\n *\n * @type {number}\n * @default 0\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.rotation\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed with regards to the stack, `textAlign`\n * determines how the text is aligned against its anchor point. Possible\n * values are `\"left\"`, `\"center\"` and `\"right\"`. The default value is\n * calculated at runtime and depends on orientation and whether the\n * stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-textalign-left/\n * Label in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.useHTML\n */\n /**\n * Defines the vertical alignment of the stack total label. Can be one\n * of `\"top\"`, `\"middle\"` or `\"bottom\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-top/\n * Vertically aligned top\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-middle/\n * Vertically aligned middle\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-bottom/\n * Vertically aligned bottom\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.verticalAlign\n */\n /**\n * The x position offset of the label relative to the left of the\n * stacked bar. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-x/\n * Stack total labels with x offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.x\n */\n /**\n * The y position offset of the label relative to the tick position\n * on the axis. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-y/\n * Stack total labels with y offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.y\n */\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `maxPadding` option to control the axis start.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n startOnTick: true,\n title: {\n /**\n * The pixel distance between the axis labels and the title.\n * Positive values are outside the axis line, negative are inside.\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @default 40\n * @apioption yAxis.title.margin\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 270,\n /**\n * The actual text of the axis title. Horizontal texts can contain\n * HTML, but rotated texts are painted using vector techniques and\n * must be clean text. The Y axis title is disabled by setting the\n * `text` option to `undefined`.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n *\n * @type {string|null}\n * @default {highcharts} Values\n * @default {highstock} undefined\n * @product highcharts highstock gantt\n */\n text: 'Values'\n },\n /**\n * The top position of the Y axis. If it's a number, it is interpreted\n * as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the plot height, offset from plot area top.\n *\n * @see [yAxis.height](#yAxis.height)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.top\n */\n /**\n * The stack labels show the total value for each bar in a stacked\n * column or bar chart. The label will be placed on top of positive\n * columns and below negative columns. In case of an inverted column\n * chart or a bar chart the label is placed to the right of positive\n * bars and to the left of negative bars.\n *\n * @product highcharts\n */\n stackLabels: {\n /**\n * Enable or disable the initial animation when a series is\n * displayed for the `stackLabels`. The animation can also be set as\n * a configuration object. Please note that this option only\n * applies to the initial animation.\n * For other animations, see [chart.animation](#chart.animation)\n * and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds.\n * Set to `0` renders stackLabel immediately.\n * As `undefined` inherits defer time from the [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation.defer\n */\n /**\n * Allow the stack labels to overlap.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-allowoverlap-false/\n * Default false\n *\n * @since 5.0.13\n * @product highcharts\n */\n allowOverlap: false,\n /**\n * The background color or gradient for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.backgroundColor\n */\n /**\n * The border color for the stack label. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderColor\n */\n /**\n * The border radius in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderRadius\n */\n /**\n * The border width in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderWidth\n */\n /**\n * Enable or disable the stack total labels.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled/\n * Enabled stack total labels\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled-waterfall/\n * Enabled stack labels in waterfall chart\n *\n * @since 2.1.5\n * @product highcharts\n */\n enabled: false,\n /**\n * Whether to hide stack labels that are outside the plot area.\n * By default, the stack label is moved\n * inside the plot area according to the\n * [overflow](/highcharts/#yAxis/stackLabels/overflow)\n * option.\n *\n * @type {boolean}\n * @since 7.1.3\n */\n crop: true,\n /**\n * How to handle stack total labels that flow outside the plot area.\n * The default is set to `\"justify\"`,\n * which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display stack labels outside the plot area,\n * set `crop` to `false` and `overflow` to `\"allow\"`.\n *\n * @sample highcharts/yaxis/stacklabels-overflow/\n * Stack labels flows outside the plot area.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @since 7.1.3\n */\n overflow: 'justify',\n /* eslint-disable valid-jsdoc */\n /**\n * Callback JavaScript function to format the label. The value is\n * given by `this.total`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-formatter/\n * Added units to stack total value\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 2.1.5\n * @product highcharts\n */\n formatter: function () {\n const { numberFormatter } = this.axis.chart;\n /* eslint-enable valid-jsdoc */\n return numberFormatter(this.total || 0, -1);\n },\n /**\n * CSS styles for the label.\n *\n * In styled mode, the styles are set in the\n * `.highcharts-stack-label` class.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-style/\n * Red stack total labels\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1.5\n * @product highcharts\n */\n style: {\n /** @internal */\n color: \"#000000\" /* Palette.neutralColor100 */,\n /** @internal */\n fontSize: '0.7em',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n textOutline: '1px contrast'\n }\n },\n gridLineWidth: 1,\n lineWidth: 0\n // tickWidth: 0\n };\n /**\n * The Z axis or depth axis for 3D plots.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @sample {highcharts} highcharts/3d/scatter-zaxis-categories/\n * Z-Axis with Categories\n * @sample {highcharts} highcharts/3d/scatter-zaxis-grid/\n * Z-Axis with styling\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @since 5.0.0\n * @product highcharts\n * @excluding breaks, crosshair, height, left, lineColor, lineWidth,\n * nameToX, showEmpty, top, width\n * @apioption zAxis\n */\n // This variable extends the defaultOptions for left axes.\n AxisDefaults.defaultLeftAxisOptions = {\n title: {\n rotation: 270\n }\n };\n // This variable extends the defaultOptions for right axes.\n AxisDefaults.defaultRightAxisOptions = {\n title: {\n rotation: 90\n }\n };\n // This variable extends the defaultOptions for bottom axes.\n AxisDefaults.defaultBottomAxisOptions = {\n labels: {\n autoRotation: [-45]\n // overflow: undefined,\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n // This variable extends the defaultOptions for top axes.\n AxisDefaults.defaultTopAxisOptions = {\n labels: {\n autoRotation: [-45]\n // overflow: undefined\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n })(AxisDefaults || (AxisDefaults = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return AxisDefaults;\n });\n _registerModule(_modules, 'Core/Foundation.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, isFunction, objectEach, removeEvent } = U;\n /* *\n *\n * Class Namespace\n *\n * */\n var Foundation;\n (function (Foundation) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Register event options. If an event handler is set on the options, it\n * should be subject to Chart.update, Axis.update and Series.update. This is\n * contrary to general handlers that are set directly using addEvent either\n * on the class or on the instance. #6538, #6943, #10861.\n * @private\n */\n function registerEventOptions(component, options) {\n // A lookup over those events that are added by _options_ (not\n // programmatically). These are updated through .update()\n component.eventOptions = component.eventOptions || {};\n // Register event listeners\n objectEach(options.events, function (event, eventType) {\n // If event does not exist, or is changed by the .update()\n // function\n if (component.eventOptions[eventType] !== event) {\n // Remove existing if set by option\n if (component.eventOptions[eventType]) {\n removeEvent(component, eventType, component.eventOptions[eventType]);\n delete component.eventOptions[eventType];\n }\n if (isFunction(event)) {\n component.eventOptions[eventType] = event;\n addEvent(component, eventType, event, {\n order: 0 // #14080 fire those events as firsts\n });\n }\n }\n });\n }\n Foundation.registerEventOptions = registerEventOptions;\n })(Foundation || (Foundation = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return Foundation;\n });\n _registerModule(_modules, 'Core/Axis/Tick.js', [_modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (F, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { deg2rad } = H;\n const { clamp, correctFloat, defined, destroyObjectProperties, extend, fireEvent, isNumber, merge, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Tick class.\n *\n * @class\n * @name Highcharts.Tick\n *\n * @param {Highcharts.Axis} axis\n * The axis of the tick.\n *\n * @param {number} pos\n * The position of the tick on the axis in terms of axis values.\n *\n * @param {string} [type]\n * The type of tick, either 'minor' or an empty string\n *\n * @param {boolean} [noLabel=false]\n * Whether to disable the label or not. Defaults to false.\n *\n * @param {Object} [parameters]\n * Optional parameters for the tick.\n */\n class Tick {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis, pos, type, noLabel, parameters) {\n this.isNew = true;\n this.isNewLabel = true;\n /**\n * The related axis of the tick.\n * @name Highcharts.Tick#axis\n * @type {Highcharts.Axis}\n */\n this.axis = axis;\n /**\n * The logical position of the tick on the axis in terms of axis values.\n * @name Highcharts.Tick#pos\n * @type {number}\n */\n this.pos = pos;\n /**\n * The tick type, which can be `\"minor\"`, or an empty string.\n * @name Highcharts.Tick#type\n * @type {string}\n */\n this.type = type || '';\n this.parameters = parameters || {};\n /**\n * The mark offset of the tick on the axis. Usually `undefined`, numeric\n * for grid axes.\n * @name Highcharts.Tick#tickmarkOffset\n * @type {number|undefined}\n */\n this.tickmarkOffset = this.parameters.tickmarkOffset;\n this.options = this.parameters.options;\n fireEvent(this, 'init');\n if (!type && !noLabel) {\n this.addLabel();\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Write the tick label.\n *\n * @private\n * @function Highcharts.Tick#addLabel\n */\n addLabel() {\n const tick = this, axis = tick.axis, options = axis.options, chart = axis.chart, categories = axis.categories, log = axis.logarithmic, names = axis.names, pos = tick.pos, labelOptions = pick(tick.options && tick.options.labels, options.labels), tickPositions = axis.tickPositions, isFirst = pos === tickPositions[0], isLast = pos === tickPositions[tickPositions.length - 1], animateLabels = (!labelOptions.step || labelOptions.step === 1) &&\n axis.tickInterval === 1, tickPositionInfo = tickPositions.info;\n let label = tick.label, dateTimeLabelFormat, dateTimeLabelFormats, i;\n // The context value\n let value = this.parameters.category || (categories ?\n pick(categories[pos], names[pos], pos) :\n pos);\n if (log && isNumber(value)) {\n value = correctFloat(log.lin2log(value));\n }\n // Set the datetime label format. If a higher rank is set for this\n // position, use that. If not, use the general format.\n if (axis.dateTime) {\n if (tickPositionInfo) {\n dateTimeLabelFormats = chart.time.resolveDTLFormat(options.dateTimeLabelFormats[(!options.grid &&\n tickPositionInfo.higherRanks[pos]) ||\n tickPositionInfo.unitName]);\n dateTimeLabelFormat = dateTimeLabelFormats.main;\n }\n else if (isNumber(value)) { // #1441\n dateTimeLabelFormat = axis.dateTime.getXDateFormat(value, options.dateTimeLabelFormats ||\n {});\n }\n }\n // set properties for access in render method\n /**\n * True if the tick is the first one on the axis.\n * @name Highcharts.Tick#isFirst\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isFirst = isFirst;\n /**\n * True if the tick is the last one on the axis.\n * @name Highcharts.Tick#isLast\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isLast = isLast;\n // Get the string\n const ctx = {\n axis,\n chart,\n dateTimeLabelFormat: dateTimeLabelFormat,\n isFirst,\n isLast,\n pos,\n tick: tick,\n tickPositionInfo,\n value\n };\n // Fire an event that allows modifying the context for use in\n // `labels.format` and `labels.formatter`.\n fireEvent(this, 'labelFormat', ctx);\n // Label formatting. When `labels.format` is given, we first run the\n // defaultFormatter and append the result to the context as `text`.\n // Handy for adding prefix or suffix while keeping default number\n // formatting.\n const labelFormatter = (ctx) => {\n if (labelOptions.formatter) {\n return labelOptions.formatter.call(ctx, ctx);\n }\n if (labelOptions.format) {\n ctx.text = axis.defaultLabelFormatter.call(ctx, ctx);\n return F.format(labelOptions.format, ctx, chart);\n }\n return axis.defaultLabelFormatter.call(ctx, ctx);\n };\n const str = labelFormatter.call(ctx, ctx);\n // Set up conditional formatting based on the format list if existing.\n const list = dateTimeLabelFormats && dateTimeLabelFormats.list;\n if (list) {\n tick.shortenLabel = function () {\n for (i = 0; i < list.length; i++) {\n extend(ctx, { dateTimeLabelFormat: list[i] });\n label.attr({\n text: labelFormatter.call(ctx, ctx)\n });\n if (label.getBBox().width <\n axis.getSlotWidth(tick) - 2 *\n labelOptions.padding) {\n return;\n }\n }\n label.attr({\n text: ''\n });\n };\n }\n else {\n // #15692\n tick.shortenLabel = void 0;\n }\n // Call only after first render\n if (animateLabels && axis._addedPlotLB) {\n tick.moveLabel(str, labelOptions);\n }\n // First call\n if (!defined(label) && !tick.movedLabel) {\n /**\n * The rendered text label of the tick.\n * @name Highcharts.Tick#label\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.label = label = tick.createLabel({ x: 0, y: 0 }, str, labelOptions);\n // Base value to detect change for new calls to getBBox\n tick.rotation = 0;\n // update\n }\n else if (label && label.textStr !== str && !animateLabels) {\n // When resetting text, also reset the width if dynamically set\n // (#8809)\n if (label.textWidth &&\n !labelOptions.style.width &&\n !label.styles.width) {\n label.css({ width: null });\n }\n label.attr({ text: str });\n label.textPxLength = label.getBBox().width;\n }\n }\n /**\n * Render and return the label of the tick.\n *\n * @private\n * @function Highcharts.Tick#createLabel\n */\n createLabel(xy, str, labelOptions) {\n const axis = this.axis, chart = axis.chart, label = defined(str) && labelOptions.enabled ?\n chart.renderer\n .text(str, xy.x, xy.y, labelOptions.useHTML)\n .add(axis.labelGroup) :\n null;\n // Un-rotated length\n if (label) {\n // Without position absolute, IE export sometimes is wrong\n if (!chart.styledMode) {\n label.css(merge(labelOptions.style));\n }\n label.textPxLength = label.getBBox().width;\n }\n return label;\n }\n /**\n * Destructor for the tick prototype\n *\n * @private\n * @function Highcharts.Tick#destroy\n */\n destroy() {\n destroyObjectProperties(this, this.axis);\n }\n /**\n * Gets the x and y positions for ticks in terms of pixels.\n *\n * @private\n * @function Highcharts.Tick#getPosition\n *\n * @param {boolean} horiz\n * Whether the tick is on an horizontal axis or not.\n *\n * @param {number} tickPos\n * Position of the tick.\n *\n * @param {number} tickmarkOffset\n * Tickmark offset for all ticks.\n *\n * @param {boolean} [old]\n * Whether the axis has changed or not.\n *\n * @return {Highcharts.PositionObject}\n * The tick position.\n *\n * @emits Highcharts.Tick#event:afterGetPosition\n */\n getPosition(horiz, tickPos, tickmarkOffset, old) {\n const axis = this.axis, chart = axis.chart, cHeight = (old && chart.oldChartHeight) || chart.chartHeight, pos = {\n x: horiz ?\n correctFloat(axis.translate(tickPos + tickmarkOffset, void 0, void 0, old) +\n axis.transB) :\n (axis.left +\n axis.offset +\n (axis.opposite ?\n (((old && chart.oldChartWidth) ||\n chart.chartWidth) -\n axis.right -\n axis.left) :\n 0)),\n y: horiz ?\n (cHeight -\n axis.bottom +\n axis.offset -\n (axis.opposite ? axis.height : 0)) :\n correctFloat(cHeight -\n axis.translate(tickPos + tickmarkOffset, void 0, void 0, old) -\n axis.transB)\n };\n // Chrome workaround for #10516\n pos.y = clamp(pos.y, -1e5, 1e5);\n fireEvent(this, 'afterGetPosition', { pos: pos });\n return pos;\n }\n /**\n * Get the x, y position of the tick label\n * @private\n */\n getLabelPosition(x, y, label, horiz, labelOptions, tickmarkOffset, index, step) {\n const axis = this.axis, transA = axis.transA, reversed = ( // #7911\n axis.isLinked && axis.linkedParent ?\n axis.linkedParent.reversed :\n axis.reversed), staggerLines = axis.staggerLines, rotCorr = axis.tickRotCorr || { x: 0, y: 0 }, \n // Adjust for label alignment if we use reserveSpace: true (#5286)\n labelOffsetCorrection = (!horiz && !axis.reserveSpaceDefault ?\n -axis.labelOffset * (axis.labelAlign === 'center' ? 0.5 : 1) :\n 0), distance = labelOptions.distance, pos = {};\n let yOffset, line;\n if (axis.side === 0) {\n yOffset = label.rotation ? -distance : -label.getBBox().height;\n }\n else if (axis.side === 2) {\n yOffset = rotCorr.y + distance;\n }\n else {\n // #3140, #3140\n yOffset = Math.cos(label.rotation * deg2rad) *\n (rotCorr.y - label.getBBox(false, 0).height / 2);\n }\n if (defined(labelOptions.y)) {\n yOffset = axis.side === 0 && axis.horiz ?\n labelOptions.y + yOffset :\n labelOptions.y;\n }\n x = x +\n pick(labelOptions.x, [0, 1, 0, -1][axis.side] * distance) +\n labelOffsetCorrection +\n rotCorr.x -\n (tickmarkOffset && horiz ?\n tickmarkOffset * transA * (reversed ? -1 : 1) :\n 0);\n y = y + yOffset - (tickmarkOffset && !horiz ?\n tickmarkOffset * transA * (reversed ? 1 : -1) : 0);\n // Correct for staggered labels\n if (staggerLines) {\n line = (index / (step || 1) % staggerLines);\n if (axis.opposite) {\n line = staggerLines - line - 1;\n }\n y += line * (axis.labelOffset / staggerLines);\n }\n pos.x = x;\n pos.y = Math.round(y);\n fireEvent(this, 'afterGetLabelPosition', { pos: pos, tickmarkOffset: tickmarkOffset, index: index });\n return pos;\n }\n /**\n * Get the offset height or width of the label\n *\n * @private\n * @function Highcharts.Tick#getLabelSize\n */\n getLabelSize() {\n return this.label ?\n this.label.getBBox()[this.axis.horiz ? 'height' : 'width'] :\n 0;\n }\n /**\n * Extendible method to return the path of the marker\n * @private\n */\n getMarkPath(x, y, tickLength, tickWidth, horiz, renderer) {\n return renderer.crispLine([[\n 'M',\n x,\n y\n ], [\n 'L',\n x + (horiz ? 0 : -tickLength),\n y + (horiz ? tickLength : 0)\n ]], tickWidth);\n }\n /**\n * Handle the label overflow by adjusting the labels to the left and right\n * edge, or hide them if they collide into the neighbour label.\n *\n * @private\n * @function Highcharts.Tick#handleOverflow\n */\n handleOverflow(xy) {\n const tick = this, axis = this.axis, labelOptions = axis.options.labels, pxPos = xy.x, chartWidth = axis.chart.chartWidth, spacing = axis.chart.spacing, leftBound = pick(axis.labelLeft, Math.min(axis.pos, spacing[3])), rightBound = pick(axis.labelRight, Math.max(!axis.isRadial ? axis.pos + axis.len : 0, chartWidth - spacing[1])), label = this.label, rotation = this.rotation, factor = {\n left: 0,\n center: 0.5,\n right: 1\n }[axis.labelAlign || label.attr('align')], labelWidth = label.getBBox().width, slotWidth = axis.getSlotWidth(tick), xCorrection = factor, css = {};\n let modifiedSlotWidth = slotWidth, goRight = 1, leftPos, rightPos, textWidth;\n // Check if the label overshoots the chart spacing box. If it does, move\n // it. If it now overshoots the slotWidth, add ellipsis.\n if (!rotation && labelOptions.overflow === 'justify') {\n leftPos = pxPos - factor * labelWidth;\n rightPos = pxPos + (1 - factor) * labelWidth;\n if (leftPos < leftBound) {\n modifiedSlotWidth =\n xy.x + modifiedSlotWidth * (1 - factor) - leftBound;\n }\n else if (rightPos > rightBound) {\n modifiedSlotWidth =\n rightBound - xy.x + modifiedSlotWidth * factor;\n goRight = -1;\n }\n modifiedSlotWidth = Math.min(slotWidth, modifiedSlotWidth); // #4177\n if (modifiedSlotWidth < slotWidth && axis.labelAlign === 'center') {\n xy.x += (goRight *\n (slotWidth -\n modifiedSlotWidth -\n xCorrection * (slotWidth - Math.min(labelWidth, modifiedSlotWidth))));\n }\n // If the label width exceeds the available space, set a text width\n // to be picked up below. Also, if a width has been set before, we\n // need to set a new one because the reported labelWidth will be\n // limited by the box (#3938).\n if (labelWidth > modifiedSlotWidth ||\n (axis.autoRotation && (label.styles || {}).width)) {\n textWidth = modifiedSlotWidth;\n }\n // Add ellipsis to prevent rotated labels to be clipped against the edge\n // of the chart\n }\n else if (rotation < 0 &&\n pxPos - factor * labelWidth < leftBound) {\n textWidth = Math.round(pxPos / Math.cos(rotation * deg2rad) - leftBound);\n }\n else if (rotation > 0 &&\n pxPos + factor * labelWidth > rightBound) {\n textWidth = Math.round((chartWidth - pxPos) /\n Math.cos(rotation * deg2rad));\n }\n if (textWidth) {\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else {\n css.width = Math.floor(textWidth) + 'px';\n if (!(labelOptions.style || {}).textOverflow) {\n css.textOverflow = 'ellipsis';\n }\n label.css(css);\n }\n }\n }\n /**\n * Try to replace the label if the same one already exists.\n *\n * @private\n * @function Highcharts.Tick#moveLabel\n */\n moveLabel(str, labelOptions) {\n const tick = this, label = tick.label, axis = tick.axis;\n let moved = false, labelPos;\n if (label && label.textStr === str) {\n tick.movedLabel = label;\n moved = true;\n delete tick.label;\n }\n else { // Find a label with the same string\n objectEach(axis.ticks, function (currentTick) {\n if (!moved &&\n !currentTick.isNew &&\n currentTick !== tick &&\n currentTick.label &&\n currentTick.label.textStr === str) {\n tick.movedLabel = currentTick.label;\n moved = true;\n currentTick.labelPos = tick.movedLabel.xy;\n delete currentTick.label;\n }\n });\n }\n // Create new label if the actual one is moved\n if (!moved && (tick.labelPos || label)) {\n labelPos = tick.labelPos || label.xy;\n tick.movedLabel = tick.createLabel(labelPos, str, labelOptions);\n if (tick.movedLabel) {\n tick.movedLabel.attr({ opacity: 0 });\n }\n }\n }\n /**\n * Put everything in place\n *\n * @private\n * @param {number} index\n *\n * @param {boolean} [old]\n * Use old coordinates to prepare an animation into new position\n *\n * @param {number} [opacity]\n */\n render(index, old, opacity) {\n const tick = this, axis = tick.axis, horiz = axis.horiz, pos = tick.pos, tickmarkOffset = pick(tick.tickmarkOffset, axis.tickmarkOffset), xy = tick.getPosition(horiz, pos, tickmarkOffset, old), x = xy.x, y = xy.y, reverseCrisp = ((horiz && x === axis.pos + axis.len) ||\n (!horiz && y === axis.pos)) ? -1 : 1; // #1480, #1687\n const labelOpacity = pick(opacity, tick.label && tick.label.newOpacity, // #15528\n 1);\n opacity = pick(opacity, 1);\n this.isActive = true;\n // Create the grid line\n this.renderGridLine(old, opacity, reverseCrisp);\n // create the tick mark\n this.renderMark(xy, opacity, reverseCrisp);\n // the label is created on init - now move it into place\n this.renderLabel(xy, old, labelOpacity, index);\n tick.isNew = false;\n fireEvent(this, 'afterRender');\n }\n /**\n * Renders the gridLine.\n *\n * @private\n * @function Highcharts.Tick#renderGridLine\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the grid line\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n renderGridLine(old, opacity, reverseCrisp) {\n const tick = this, axis = tick.axis, options = axis.options, attribs = {}, pos = tick.pos, type = tick.type, tickmarkOffset = pick(tick.tickmarkOffset, axis.tickmarkOffset), renderer = axis.chart.renderer;\n let gridLine = tick.gridLine, gridLinePath, gridLineWidth = options.gridLineWidth, gridLineColor = options.gridLineColor, dashStyle = options.gridLineDashStyle;\n if (tick.type === 'minor') {\n gridLineWidth = options.minorGridLineWidth;\n gridLineColor = options.minorGridLineColor;\n dashStyle = options.minorGridLineDashStyle;\n }\n if (!gridLine) {\n if (!axis.chart.styledMode) {\n attribs.stroke = gridLineColor;\n attribs['stroke-width'] = gridLineWidth || 0;\n attribs.dashstyle = dashStyle;\n }\n if (!type) {\n attribs.zIndex = 1;\n }\n if (old) {\n opacity = 0;\n }\n /**\n * The rendered grid line of the tick.\n * @name Highcharts.Tick#gridLine\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.gridLine = gridLine = renderer.path()\n .attr(attribs)\n .addClass('highcharts-' + (type ? type + '-' : '') + 'grid-line')\n .add(axis.gridGroup);\n }\n if (gridLine) {\n gridLinePath = axis.getPlotLinePath({\n value: pos + tickmarkOffset,\n lineWidth: gridLine.strokeWidth() * reverseCrisp,\n force: 'pass',\n old: old,\n acrossPanes: false // #18025\n });\n // If the parameter 'old' is set, the current call will be followed\n // by another call, therefore do not do any animations this time\n if (gridLinePath) {\n gridLine[old || tick.isNew ? 'attr' : 'animate']({\n d: gridLinePath,\n opacity: opacity\n });\n }\n }\n }\n /**\n * Renders the tick mark.\n *\n * @private\n * @function Highcharts.Tick#renderMark\n * @param {Highcharts.PositionObject} xy The position vector of the mark\n * @param {number} opacity The opacity of the mark\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n renderMark(xy, opacity, reverseCrisp) {\n const tick = this, axis = tick.axis, options = axis.options, renderer = axis.chart.renderer, type = tick.type, tickSize = axis.tickSize(type ? type + 'Tick' : 'tick'), x = xy.x, y = xy.y, tickWidth = pick(options[type !== 'minor' ? 'tickWidth' : 'minorTickWidth'], !type && axis.isXAxis ? 1 : 0), // X axis defaults to 1\n tickColor = options[type !== 'minor' ? 'tickColor' : 'minorTickColor'];\n let mark = tick.mark;\n const isNewMark = !mark;\n if (tickSize) {\n // negate the length\n if (axis.opposite) {\n tickSize[0] = -tickSize[0];\n }\n // First time, create it\n if (!mark) {\n /**\n * The rendered mark of the tick.\n * @name Highcharts.Tick#mark\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.mark = mark = renderer.path()\n .addClass('highcharts-' + (type ? type + '-' : '') + 'tick')\n .add(axis.axisGroup);\n if (!axis.chart.styledMode) {\n mark.attr({\n stroke: tickColor,\n 'stroke-width': tickWidth\n });\n }\n }\n mark[isNewMark ? 'attr' : 'animate']({\n d: tick.getMarkPath(x, y, tickSize[0], mark.strokeWidth() * reverseCrisp, axis.horiz, renderer),\n opacity: opacity\n });\n }\n }\n /**\n * Renders the tick label.\n * Note: The label should already be created in init(), so it should only\n * have to be moved into place.\n *\n * @private\n * @function Highcharts.Tick#renderLabel\n * @param {Highcharts.PositionObject} xy The position vector of the label\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the label\n * @param {number} index The index of the tick\n */\n renderLabel(xy, old, opacity, index) {\n const tick = this, axis = tick.axis, horiz = axis.horiz, options = axis.options, label = tick.label, labelOptions = options.labels, step = labelOptions.step, tickmarkOffset = pick(tick.tickmarkOffset, axis.tickmarkOffset), x = xy.x, y = xy.y;\n let show = true;\n if (label && isNumber(x)) {\n label.xy = xy = tick.getLabelPosition(x, y, label, horiz, labelOptions, tickmarkOffset, index, step);\n // Apply show first and show last. If the tick is both first and\n // last, it is a single centered tick, in which case we show the\n // label anyway (#2100).\n if ((tick.isFirst &&\n !tick.isLast &&\n !options.showFirstLabel) ||\n (tick.isLast &&\n !tick.isFirst &&\n !options.showLastLabel)) {\n show = false;\n // Handle label overflow and show or hide accordingly\n }\n else if (horiz &&\n !labelOptions.step &&\n !labelOptions.rotation &&\n !old &&\n opacity !== 0) {\n tick.handleOverflow(xy);\n }\n // apply step\n if (step && index % step) {\n // show those indices dividable by step\n show = false;\n }\n // Set the new position, and show or hide\n if (show && isNumber(xy.y)) {\n xy.opacity = opacity;\n label[tick.isNewLabel ? 'attr' : 'animate'](xy).show(true);\n tick.isNewLabel = false;\n }\n else {\n label.hide(); // #1338, #15863\n tick.isNewLabel = true;\n }\n }\n }\n /**\n * Replace labels with the moved ones to perform animation. Additionally\n * destroy unused labels.\n *\n * @private\n * @function Highcharts.Tick#replaceMovedLabel\n */\n replaceMovedLabel() {\n const tick = this, label = tick.label, axis = tick.axis;\n // Animate and destroy\n if (label && !tick.isNew) {\n label.animate({ opacity: 0 }, void 0, label.destroy);\n delete tick.label;\n }\n axis.isDirty = true;\n tick.label = tick.movedLabel;\n delete tick.movedLabel;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Optional parameters for the tick.\n * @private\n * @interface Highcharts.TickParametersObject\n */ /**\n * Set category for the tick.\n * @name Highcharts.TickParametersObject#category\n * @type {string|undefined}\n */ /**\n * @name Highcharts.TickParametersObject#options\n * @type {Highcharts.Dictionary|undefined}\n */ /**\n * Set tickmarkOffset for the tick.\n * @name Highcharts.TickParametersObject#tickmarkOffset\n * @type {number|undefined}\n */\n /**\n * Additonal time tick information.\n *\n * @interface Highcharts.TimeTicksInfoObject\n * @extends Highcharts.TimeNormalizedObject\n */ /**\n * @name Highcharts.TimeTicksInfoObject#higherRanks\n * @type {Array}\n */ /**\n * @name Highcharts.TimeTicksInfoObject#totalRange\n * @type {number}\n */\n (''); // keeps doclets above in JS file\n\n return Tick;\n });\n _registerModule(_modules, 'Core/Axis/Axis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/AxisDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Utilities.js']], function (A, AxisDefaults, Color, D, F, H, Tick, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject } = A;\n const { defaultOptions } = D;\n const { registerEventOptions } = F;\n const { deg2rad } = H;\n const { arrayMax, arrayMin, clamp, correctFloat, defined, destroyObjectProperties, erase, error, extend, fireEvent, getClosestDistance, insertItem, isArray, isNumber, isString, merge, normalizeTickInterval, objectEach, pick, relativeLength, removeEvent, splat, syncTimeout } = U;\n const getNormalizedTickInterval = (axis, tickInterval) => normalizeTickInterval(tickInterval, void 0, void 0, pick(axis.options.allowDecimals, \n // If the tick interval is greather than 0.5, avoid decimals, as\n // linear axes are often used to render discrete values (#3363). If\n // a tick amount is set, allow decimals by default, as it increases\n // the chances for a good fit.\n tickInterval < 0.5 || axis.tickAmount !== void 0), !!axis.tickAmount);\n /* *\n *\n * Class\n *\n * */\n /**\n * Create a new axis object. Called internally when instanciating a new chart or\n * adding axes by {@link Highcharts.Chart#addAxis}.\n *\n * A chart can have from 0 axes (pie chart) to multiples. In a normal, single\n * series cartesian chart, there is one X axis and one Y axis.\n *\n * The X axis or axes are referenced by {@link Highcharts.Chart.xAxis}, which is\n * an array of Axis objects. If there is only one axis, it can be referenced\n * through `chart.xAxis[0]`, and multiple axes have increasing indices. The same\n * pattern goes for Y axes.\n *\n * If you need to get the axes from a series object, use the `series.xAxis` and\n * `series.yAxis` properties. These are not arrays, as one series can only be\n * associated to one X and one Y axis.\n *\n * A third way to reference the axis programmatically is by `id`. Add an `id` in\n * the axis configuration options, and get the axis by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the axes are given in options.xAxis and\n * options.yAxis.\n *\n * @class\n * @name Highcharts.Axis\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options\n */\n class Axis {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, userOptions, coll) {\n this.alternateBands = void 0;\n this.bottom = void 0;\n this.chart = void 0;\n this.closestPointRange = void 0;\n this.coll = void 0;\n this.eventOptions = void 0;\n this.hasNames = void 0;\n this.hasVisibleSeries = void 0;\n this.height = void 0;\n this.index = void 0;\n this.isLinked = void 0;\n this.labelEdge = void 0; // @todo\n this.labelFormatter = void 0;\n this.left = void 0;\n this.len = void 0;\n this.max = void 0;\n this.maxLabelLength = void 0;\n this.min = void 0;\n this.minorTickInterval = void 0;\n this.minorTicks = void 0;\n this.minPixelPadding = void 0;\n this.names = void 0;\n this.offset = void 0;\n this.options = void 0;\n this.overlap = void 0;\n this.paddedTicks = void 0;\n this.plotLinesAndBands = void 0;\n this.plotLinesAndBandsGroups = void 0;\n this.pointRange = void 0;\n this.pointRangePadding = void 0;\n this.pos = void 0;\n this.positiveValuesOnly = void 0;\n this.right = void 0;\n this.series = void 0;\n this.side = void 0;\n this.tickAmount = void 0;\n this.tickInterval = void 0;\n this.tickmarkOffset = void 0;\n this.tickPositions = void 0;\n this.tickRotCorr = void 0;\n this.ticks = void 0;\n this.top = void 0;\n this.transA = void 0;\n this.transB = void 0;\n this.translationSlope = void 0;\n this.userOptions = void 0;\n this.visible = void 0;\n this.width = void 0;\n this.zoomEnabled = void 0;\n this.init(chart, userOptions, coll);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Overrideable function to initialize the axis.\n *\n * @see {@link Axis}\n *\n * @function Highcharts.Axis#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterInit\n * @emits Highcharts.Axis#event:init\n */\n init(chart, userOptions, coll = this.coll) {\n const isXAxis = coll === 'xAxis', axis = this;\n /**\n * The Chart that the axis belongs to.\n *\n * @name Highcharts.Axis#chart\n * @type {Highcharts.Chart}\n */\n axis.chart = chart;\n /**\n * Whether the axis is horizontal.\n *\n * @name Highcharts.Axis#horiz\n * @type {boolean|undefined}\n */\n axis.horiz = axis.isZAxis || (chart.inverted ? !isXAxis : isXAxis);\n /**\n * Whether the axis is the x-axis.\n *\n * @name Highcharts.Axis#isXAxis\n * @type {boolean|undefined}\n */\n axis.isXAxis = isXAxis;\n /**\n * The collection where the axis belongs, for example `xAxis`, `yAxis`\n * or `colorAxis`. Corresponds to properties on Chart, for example\n * {@link Chart.xAxis}.\n *\n * @name Highcharts.Axis#coll\n * @type {string}\n */\n axis.coll = coll;\n fireEvent(this, 'init', { userOptions: userOptions });\n // Needed in setOptions\n axis.opposite = pick(userOptions.opposite, axis.opposite);\n /**\n * The side on which the axis is rendered. 0 is top, 1 is right, 2\n * is bottom and 3 is left.\n *\n * @name Highcharts.Axis#side\n * @type {number}\n */\n axis.side = pick(userOptions.side, axis.side, (axis.horiz ?\n (axis.opposite ? 0 : 2) : // top : bottom\n (axis.opposite ? 1 : 3)) // right : left\n );\n /**\n * Current options for the axis after merge of defaults and user's\n * options.\n *\n * @name Highcharts.Axis#options\n * @type {Highcharts.AxisOptions}\n */\n axis.setOptions(userOptions);\n const options = this.options, labelsOptions = options.labels, type = options.type;\n /**\n * User's options for this axis without defaults.\n *\n * @name Highcharts.Axis#userOptions\n * @type {Highcharts.AxisOptions}\n */\n axis.userOptions = userOptions;\n axis.minPixelPadding = 0;\n /**\n * Whether the axis is reversed. Based on the `axis.reversed`,\n * option, but inverted charts have reversed xAxis by default.\n *\n * @name Highcharts.Axis#reversed\n * @type {boolean}\n */\n axis.reversed = pick(options.reversed, axis.reversed);\n axis.visible = options.visible;\n axis.zoomEnabled = options.zoomEnabled;\n // Initial categories\n axis.hasNames =\n type === 'category' || options.categories === true;\n /**\n * If categories are present for the axis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also be extracted by giving each\n * point a name and setting axis type to `category`. However, if you\n * have multiple series, best practice remains defining the `categories`\n * array.\n *\n * @see [xAxis.categories](/highcharts/xAxis.categories)\n *\n * @name Highcharts.Axis#categories\n * @type {Array}\n * @readonly\n */\n axis.categories = options.categories || (axis.hasNames ? [] : void 0);\n if (!axis.names) { // Preserve on update (#3830)\n axis.names = [];\n axis.names.keys = {};\n }\n // Placeholder for plotlines and plotbands groups\n axis.plotLinesAndBandsGroups = {};\n // Shorthand types\n axis.positiveValuesOnly = !!axis.logarithmic;\n // Flag, if axis is linked to another axis\n axis.isLinked = defined(options.linkedTo);\n /**\n * List of major ticks mapped by postition on axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#ticks\n * @type {Highcharts.Dictionary}\n */\n axis.ticks = {};\n axis.labelEdge = [];\n /**\n * List of minor ticks mapped by position on the axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#minorTicks\n * @type {Highcharts.Dictionary}\n */\n axis.minorTicks = {};\n // List of plotLines/Bands\n axis.plotLinesAndBands = [];\n // Alternate bands\n axis.alternateBands = {};\n // Axis metrics\n axis.len = 0;\n axis.minRange = axis.userMinRange = options.minRange || options.maxZoom;\n axis.range = options.range;\n axis.offset = options.offset || 0;\n /**\n * The maximum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#max\n * @type {number|null}\n */\n axis.max = null;\n /**\n * The minimum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#min\n * @type {number|null}\n */\n axis.min = null;\n /**\n * The processed crosshair options.\n *\n * @name Highcharts.Axis#crosshair\n * @type {boolean|Highcharts.AxisCrosshairOptions}\n */\n const crosshair = pick(options.crosshair, splat(chart.options.tooltip.crosshairs)[isXAxis ? 0 : 1]);\n axis.crosshair = crosshair === true ? {} : crosshair;\n // Register. Don't add it again on Axis.update().\n if (chart.axes.indexOf(axis) === -1) { //\n if (isXAxis) { // #2713\n chart.axes.splice(chart.xAxis.length, 0, axis);\n }\n else {\n chart.axes.push(axis);\n }\n insertItem(this, chart[this.coll]);\n }\n chart.orderItems(axis.coll);\n /**\n * All series associated to the axis.\n *\n * @name Highcharts.Axis#series\n * @type {Array}\n */\n axis.series = axis.series || []; // populated by Series\n // Reversed axis\n if (chart.inverted &&\n !axis.isZAxis &&\n isXAxis &&\n typeof axis.reversed === 'undefined') {\n axis.reversed = true;\n }\n axis.labelRotation = isNumber(labelsOptions.rotation) ?\n labelsOptions.rotation :\n void 0;\n // Register event listeners\n registerEventOptions(axis, options);\n fireEvent(this, 'afterInit');\n }\n /**\n * Merge and set options.\n *\n * @private\n * @function Highcharts.Axis#setOptions\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterSetOptions\n */\n setOptions(userOptions) {\n this.options = merge(AxisDefaults.defaultXAxisOptions, (this.coll === 'yAxis') && AxisDefaults.defaultYAxisOptions, [\n AxisDefaults.defaultTopAxisOptions,\n AxisDefaults.defaultRightAxisOptions,\n AxisDefaults.defaultBottomAxisOptions,\n AxisDefaults.defaultLeftAxisOptions\n ][this.side], merge(\n // if set in setOptions (#1053):\n defaultOptions[this.coll], userOptions));\n fireEvent(this, 'afterSetOptions', { userOptions: userOptions });\n }\n /**\n * The default label formatter. The context is a special config object for\n * the label. In apps, use the\n * [labels.formatter](https://api.highcharts.com/highcharts/xAxis.labels.formatter)\n * instead, except when a modification is needed.\n *\n * @function Highcharts.Axis#defaultLabelFormatter\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n * Formatter context of axis label.\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} [ctx]\n * Formatter context of axis label.\n *\n * @return {string}\n * The formatted label content.\n */\n defaultLabelFormatter(ctx) {\n const axis = this.axis, chart = this.chart, { numberFormatter } = chart, value = isNumber(this.value) ? this.value : NaN, time = axis.chart.time, categories = axis.categories, dateTimeLabelFormat = this.dateTimeLabelFormat, lang = defaultOptions.lang, numericSymbols = lang.numericSymbols, numSymMagnitude = lang.numericSymbolMagnitude || 1000, \n // make sure the same symbol is added for all labels on a linear\n // axis\n numericSymbolDetector = axis.logarithmic ?\n Math.abs(value) :\n axis.tickInterval;\n let i = numericSymbols && numericSymbols.length, multi, ret;\n if (categories) {\n ret = `${this.value}`;\n }\n else if (dateTimeLabelFormat) { // datetime axis\n ret = time.dateFormat(dateTimeLabelFormat, value);\n }\n else if (i && numericSymbolDetector >= 1000) {\n // Decide whether we should add a numeric symbol like k (thousands)\n // or M (millions). If we are to enable this in tooltip or other\n // places as well, we can move this logic to the numberFormatter and\n // enable it by a parameter.\n while (i-- && typeof ret === 'undefined') {\n multi = Math.pow(numSymMagnitude, i + 1);\n if (\n // Only accept a numeric symbol when the distance is more\n // than a full unit. So for example if the symbol is k, we\n // don't accept numbers like 0.5k.\n numericSymbolDetector >= multi &&\n // Accept one decimal before the symbol. Accepts 0.5k but\n // not 0.25k. How does this work with the previous?\n (value * 10) % multi === 0 &&\n numericSymbols[i] !== null &&\n value !== 0) { // #5480\n ret = numberFormatter(value / multi, -1) + numericSymbols[i];\n }\n }\n }\n if (typeof ret === 'undefined') {\n if (Math.abs(value) >= 10000) { // add thousands separators\n ret = numberFormatter(value, -1);\n }\n else { // small numbers\n ret = numberFormatter(value, -1, void 0, ''); // #2466\n }\n }\n return ret;\n }\n /**\n * Get the minimum and maximum for the series of each axis. The function\n * analyzes the axis series and updates `this.dataMin` and `this.dataMax`.\n *\n * @private\n * @function Highcharts.Axis#getSeriesExtremes\n *\n * @emits Highcharts.Axis#event:afterGetSeriesExtremes\n * @emits Highcharts.Axis#event:getSeriesExtremes\n */\n getSeriesExtremes() {\n const axis = this, chart = axis.chart;\n let xExtremes;\n fireEvent(this, 'getSeriesExtremes', null, function () {\n axis.hasVisibleSeries = false;\n // Reset properties in case we're redrawing (#3353)\n axis.dataMin = axis.dataMax = axis.threshold = null;\n axis.softThreshold = !axis.isXAxis;\n // Loop through this axis' series\n axis.series.forEach(function (series) {\n if (series.visible ||\n !chart.options.chart.ignoreHiddenSeries) {\n const seriesOptions = series.options;\n let xData, threshold = seriesOptions.threshold, seriesDataMin, seriesDataMax;\n axis.hasVisibleSeries = true;\n // Validate threshold in logarithmic axes\n if (axis.positiveValuesOnly && threshold <= 0) {\n threshold = null;\n }\n // Get dataMin and dataMax for X axes\n if (axis.isXAxis) {\n xData = series.xData;\n if (xData && xData.length) {\n xData = axis.logarithmic ?\n xData.filter((x) => x > 0) :\n xData;\n xExtremes = series.getXExtremes(xData);\n // If xData contains values which is not numbers,\n // then filter them out. To prevent performance hit,\n // we only do this after we have already found\n // seriesDataMin because in most cases all data is\n // valid. #5234.\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n if (!isNumber(seriesDataMin) &&\n // #5010:\n !(seriesDataMin instanceof Date)) {\n xData = xData.filter(isNumber);\n xExtremes = series.getXExtremes(xData);\n // Do it again with valid data\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n }\n if (xData.length) {\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n }\n // Get dataMin and dataMax for Y axes, as well as handle\n // stacking and processed data\n }\n else {\n // Get this particular series extremes\n const dataExtremes = series.applyExtremes();\n // Get the dataMin and dataMax so far. If percentage is\n // used, the min and max are always 0 and 100. If\n // seriesDataMin and seriesDataMax is null, then series\n // doesn't have active y data, we continue with nulls\n if (isNumber(dataExtremes.dataMin)) {\n seriesDataMin = dataExtremes.dataMin;\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n }\n if (isNumber(dataExtremes.dataMax)) {\n seriesDataMax = dataExtremes.dataMax;\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n // Adjust to threshold\n if (defined(threshold)) {\n axis.threshold = threshold;\n }\n // If any series has a hard threshold, it takes\n // precedence\n if (!seriesOptions.softThreshold ||\n axis.positiveValuesOnly) {\n axis.softThreshold = false;\n }\n }\n }\n });\n });\n fireEvent(this, 'afterGetSeriesExtremes');\n }\n /**\n * Translate from axis value to pixel position on the chart, or back. Use\n * the `toPixels` and `toValue` functions in applications.\n *\n * @private\n * @function Highcharts.Axis#translate\n */\n translate(val, backwards, cvsCoord, old, handleLog, pointPlacement) {\n const axis = (this.linkedParent || this), // #1417\n localMin = (old && axis.old ? axis.old.min : axis.min);\n if (!isNumber(localMin)) {\n return NaN;\n }\n const minPixelPadding = axis.minPixelPadding, doPostTranslate = (axis.isOrdinal ||\n axis.brokenAxis && axis.brokenAxis.hasBreaks ||\n (axis.logarithmic && handleLog)) && axis.lin2val;\n let sign = 1, cvsOffset = 0, localA = old && axis.old ? axis.old.transA : axis.transA, returnValue = 0;\n if (!localA) {\n localA = axis.transA;\n }\n // In vertical axes, the canvas coordinates start from 0 at the top like\n // in SVG.\n if (cvsCoord) {\n sign *= -1; // canvas coordinates inverts the value\n cvsOffset = axis.len;\n }\n // Handle reversed axis\n if (axis.reversed) {\n sign *= -1;\n cvsOffset -= sign * (axis.sector || axis.len);\n }\n // From pixels to value\n if (backwards) { // reverse translation\n val = val * sign + cvsOffset;\n val -= minPixelPadding;\n // from chart pixel to value:\n returnValue = val / localA + localMin;\n if (doPostTranslate) { // log, ordinal and broken axis\n returnValue = axis.lin2val(returnValue);\n }\n // From value to pixels\n }\n else {\n if (doPostTranslate) { // log, ordinal and broken axis\n val = axis.val2lin(val);\n }\n const value = sign * (val - localMin) * localA;\n returnValue = (!axis.isRadial ? correctFloat(value) : value) +\n cvsOffset +\n (sign * minPixelPadding) +\n (isNumber(pointPlacement) ? localA * pointPlacement : 0);\n }\n return returnValue;\n }\n /**\n * Translate a value in terms of axis units into pixels within the chart.\n *\n * @function Highcharts.Axis#toPixels\n *\n * @param {number} value\n * A value in terms of axis units.\n *\n * @param {boolean} paneCoordinates\n * Whether to return the pixel coordinate relative to the chart or just the\n * axis/pane itself.\n *\n * @return {number}\n * Pixel position of the value on the chart or axis.\n */\n toPixels(value, paneCoordinates) {\n return this.translate(value, false, !this.horiz, void 0, true) +\n (paneCoordinates ? 0 : this.pos);\n }\n /**\n * Translate a pixel position along the axis to a value in terms of axis\n * units.\n *\n * @function Highcharts.Axis#toValue\n *\n * @param {number} pixel\n * The pixel value coordinate.\n *\n * @param {boolean} [paneCoordinates=false]\n * Whether the input pixel is relative to the chart or just the axis/pane\n * itself.\n *\n * @return {number}\n * The axis value.\n */\n toValue(pixel, paneCoordinates) {\n return this.translate(pixel - (paneCoordinates ? 0 : this.pos), true, !this.horiz, void 0, true);\n }\n /**\n * Create the path for a plot line that goes from the given value on\n * this axis, across the plot to the opposite side. Also used internally for\n * grid lines and crosshairs.\n *\n * @function Highcharts.Axis#getPlotLinePath\n *\n * @param {Highcharts.AxisPlotLinePathOptionsObject} options\n * Options for the path.\n *\n * @return {Highcharts.SVGPathArray|null}\n * The SVG path definition for the plot line.\n */\n getPlotLinePath(options) {\n const axis = this, chart = axis.chart, axisLeft = axis.left, axisTop = axis.top, old = options.old, value = options.value, lineWidth = options.lineWidth, cHeight = (old && chart.oldChartHeight) || chart.chartHeight, cWidth = (old && chart.oldChartWidth) || chart.chartWidth, transB = axis.transB;\n let translatedValue = options.translatedValue, force = options.force, x1, y1, x2, y2, skip;\n // eslint-disable-next-line valid-jsdoc\n /**\n * Check if x is between a and b. If not, either move to a/b\n * or skip, depending on the force parameter.\n * @private\n */\n function between(x, a, b) {\n if (force !== 'pass' && (x < a || x > b)) {\n if (force) {\n x = clamp(x, a, b);\n }\n else {\n skip = true;\n }\n }\n return x;\n }\n const evt = {\n value: value,\n lineWidth: lineWidth,\n old: old,\n force: force,\n acrossPanes: options.acrossPanes,\n translatedValue: translatedValue\n };\n fireEvent(this, 'getPlotLinePath', evt, function (e) {\n translatedValue = pick(translatedValue, axis.translate(value, void 0, void 0, old));\n // Keep the translated value within sane bounds, and avoid Infinity\n // to fail the isNumber test (#7709).\n translatedValue = clamp(translatedValue, -1e5, 1e5);\n x1 = x2 = Math.round(translatedValue + transB);\n y1 = y2 = Math.round(cHeight - translatedValue - transB);\n if (!isNumber(translatedValue)) { // no min or max\n skip = true;\n force = false; // #7175, don't force it when path is invalid\n }\n else if (axis.horiz) {\n y1 = axisTop;\n y2 = cHeight - axis.bottom;\n x1 = x2 = between(x1, axisLeft, axisLeft + axis.width);\n }\n else {\n x1 = axisLeft;\n x2 = cWidth - axis.right;\n y1 = y2 = between(y1, axisTop, axisTop + axis.height);\n }\n e.path = skip && !force ?\n null :\n chart.renderer.crispLine([['M', x1, y1], ['L', x2, y2]], lineWidth || 1);\n });\n return evt.path;\n }\n /**\n * Internal function to get the tick positions of a linear axis to round\n * values like whole tens or every five.\n *\n * @function Highcharts.Axis#getLinearTickPositions\n *\n * @param {number} tickInterval\n * The normalized tick interval.\n *\n * @param {number} min\n * Axis minimum.\n *\n * @param {number} max\n * Axis maximum.\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n getLinearTickPositions(tickInterval, min, max) {\n const roundedMin = correctFloat(Math.floor(min / tickInterval) * tickInterval), roundedMax = correctFloat(Math.ceil(max / tickInterval) * tickInterval), tickPositions = [];\n let pos, lastPos, precision;\n // When the precision is higher than what we filter out in\n // correctFloat, skip it (#6183).\n if (correctFloat(roundedMin + tickInterval) === roundedMin) {\n precision = 20;\n }\n // For single points, add a tick regardless of the relative position\n // (#2662, #6274)\n if (this.single) {\n return [min];\n }\n // Populate the intermediate values\n pos = roundedMin;\n while (pos <= roundedMax) {\n // Place the tick on the rounded value\n tickPositions.push(pos);\n // Always add the raw tickInterval, not the corrected one.\n pos = correctFloat(pos + tickInterval, precision);\n // If the interval is not big enough in the current min - max range\n // to actually increase the loop variable, we need to break out to\n // prevent endless loop. Issue #619\n if (pos === lastPos) {\n break;\n }\n // Record the last value\n lastPos = pos;\n }\n return tickPositions;\n }\n /**\n * Resolve the new minorTicks/minorTickInterval options into the legacy\n * loosely typed minorTickInterval option.\n *\n * @function Highcharts.Axis#getMinorTickInterval\n *\n * @return {number|\"auto\"|null}\n * Legacy option\n */\n getMinorTickInterval() {\n const options = this.options;\n if (options.minorTicks === true) {\n return pick(options.minorTickInterval, 'auto');\n }\n if (options.minorTicks === false) {\n return null;\n }\n return options.minorTickInterval;\n }\n /**\n * Internal function to return the minor tick positions. For logarithmic\n * axes, the same logic as for major ticks is reused.\n *\n * @function Highcharts.Axis#getMinorTickPositions\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n getMinorTickPositions() {\n const axis = this, options = axis.options, tickPositions = axis.tickPositions, minorTickInterval = axis.minorTickInterval, pointRangePadding = axis.pointRangePadding || 0, min = axis.min - pointRangePadding, // #1498\n max = axis.max + pointRangePadding, // #1498\n range = max - min;\n let minorTickPositions = [], pos;\n // If minor ticks get too dense, they are hard to read, and may cause\n // long running script. So we don't draw them.\n if (range && range / minorTickInterval < axis.len / 3) { // #3875\n const logarithmic = axis.logarithmic;\n if (logarithmic) {\n // For each interval in the major ticks, compute the minor ticks\n // separately.\n this.paddedTicks.forEach(function (_pos, i, paddedTicks) {\n if (i) {\n minorTickPositions.push.apply(minorTickPositions, logarithmic.getLogTickPositions(minorTickInterval, paddedTicks[i - 1], paddedTicks[i], true));\n }\n });\n }\n else if (axis.dateTime &&\n this.getMinorTickInterval() === 'auto') { // #1314\n minorTickPositions = minorTickPositions.concat(axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(minorTickInterval), min, max, options.startOfWeek));\n }\n else {\n for (pos = min + (tickPositions[0] - min) % minorTickInterval; pos <= max; pos += minorTickInterval) {\n // Very, very, tight grid lines (#5771)\n if (pos === minorTickPositions[0]) {\n break;\n }\n minorTickPositions.push(pos);\n }\n }\n }\n if (minorTickPositions.length !== 0) {\n axis.trimTicks(minorTickPositions); // #3652 #3743 #1498 #6330\n }\n return minorTickPositions;\n }\n /**\n * Adjust the min and max for the minimum range. Keep in mind that the\n * series data is not yet processed, so we don't have information on data\n * cropping and grouping, or updated `axis.pointRange` or\n * `series.pointRange`. The data can't be processed until we have finally\n * established min and max.\n *\n * @private\n * @function Highcharts.Axis#adjustForMinRange\n */\n adjustForMinRange() {\n const axis = this, options = axis.options, logarithmic = axis.logarithmic;\n let min = axis.min, max = axis.max, zoomOffset, spaceAvailable, closestDataRange, minArgs, maxArgs, minRange;\n // Set the automatic minimum range based on the closest point distance\n if (axis.isXAxis &&\n typeof axis.minRange === 'undefined' &&\n !logarithmic) {\n if (defined(options.min) ||\n defined(options.max) ||\n defined(options.floor) ||\n defined(options.ceiling)) {\n axis.minRange = null; // don't do this again\n }\n else {\n // Find the closest distance between raw data points, as opposed\n // to closestPointRange that applies to processed points\n // (cropped and grouped)\n closestDataRange = getClosestDistance(axis.series.map((s) => { var _a; \n // If xIncrement, we only need to measure the two first\n // points to get the distance. Saves processing time.\n return (s.xIncrement ? (_a = s.xData) === null || _a === void 0 ? void 0 : _a.slice(0, 2) : s.xData) || []; })) || 0;\n axis.minRange = Math.min(closestDataRange * 5, axis.dataMax - axis.dataMin);\n }\n }\n // if minRange is exceeded, adjust\n if (max - min < axis.minRange) {\n spaceAvailable =\n axis.dataMax - axis.dataMin >=\n axis.minRange;\n minRange = axis.minRange;\n zoomOffset = (minRange - max + min) / 2;\n // if min and max options have been set, don't go beyond it\n minArgs = [\n min - zoomOffset,\n pick(options.min, min - zoomOffset)\n ];\n // If space is available, stay within the data range\n if (spaceAvailable) {\n minArgs[2] = logarithmic ?\n logarithmic.log2lin(axis.dataMin) :\n axis.dataMin;\n }\n min = arrayMax(minArgs);\n maxArgs = [\n min + minRange,\n pick(options.max, min + minRange)\n ];\n // If space is availabe, stay within the data range\n if (spaceAvailable) {\n maxArgs[2] = logarithmic ?\n logarithmic.log2lin(axis.dataMax) :\n axis.dataMax;\n }\n max = arrayMin(maxArgs);\n // now if the max is adjusted, adjust the min back\n if (max - min < minRange) {\n minArgs[0] = max - minRange;\n minArgs[1] = pick(options.min, max - minRange);\n min = arrayMax(minArgs);\n }\n }\n // Record modified extremes\n axis.min = min;\n axis.max = max;\n }\n /**\n * Find the closestPointRange across all series, including the single data\n * series.\n *\n * @private\n * @function Highcharts.Axis#getClosest\n */\n getClosest() {\n let closestSingleDistance, closestDistance;\n if (this.categories) {\n closestDistance = 1;\n }\n else {\n const singleXs = [];\n this.series.forEach(function (series) {\n var _a;\n const seriesClosest = series.closestPointRange, visible = series.visible ||\n !series.chart.options.chart.ignoreHiddenSeries;\n if (((_a = series.xData) === null || _a === void 0 ? void 0 : _a.length) === 1) {\n singleXs.push(series.xData[0]);\n }\n else if (!series.noSharedTooltip &&\n defined(seriesClosest) &&\n visible) {\n closestDistance = defined(closestDistance) ?\n Math.min(closestDistance, seriesClosest) :\n seriesClosest;\n }\n });\n if (singleXs.length) {\n singleXs.sort((a, b) => a - b);\n closestSingleDistance = getClosestDistance([singleXs]);\n }\n }\n if (closestSingleDistance && closestDistance) {\n return Math.min(closestSingleDistance, closestDistance);\n }\n return closestSingleDistance || closestDistance;\n }\n /**\n * When a point name is given and no x, search for the name in the existing\n * categories, or if categories aren't provided, search names or create a\n * new category (#2522).\n *\n * @private\n * @function Highcharts.Axis#nameToX\n *\n * @param {Highcharts.Point} point\n * The point to inspect.\n *\n * @return {number}\n * The X value that the point is given.\n */\n nameToX(point) {\n const explicitCategories = isArray(this.options.categories), names = explicitCategories ? this.categories : this.names;\n let nameX = point.options.x, x;\n point.series.requireSorting = false;\n if (!defined(nameX)) {\n nameX = this.options.uniqueNames && names ?\n (explicitCategories ?\n names.indexOf(point.name) :\n pick(names.keys[point.name], -1)) :\n point.series.autoIncrement();\n }\n if (nameX === -1) { // Not found in currenct categories\n if (!explicitCategories && names) {\n x = names.length;\n }\n }\n else {\n x = nameX;\n }\n // Write the last point's name to the names array\n if (typeof x !== 'undefined') {\n this.names[x] = point.name;\n // Backwards mapping is much faster than array searching (#7725)\n this.names.keys[point.name] = x;\n }\n else if (point.x) {\n x = point.x; // #17438\n }\n return x;\n }\n /**\n * When changes have been done to series data, update the axis.names.\n *\n * @private\n * @function Highcharts.Axis#updateNames\n */\n updateNames() {\n const axis = this, names = this.names, i = names.length;\n if (i > 0) {\n Object.keys(names.keys).forEach(function (key) {\n delete (names.keys)[key];\n });\n names.length = 0;\n this.minRange = this.userMinRange; // Reset\n (this.series || []).forEach(function (series) {\n // Reset incrementer (#5928)\n series.xIncrement = null;\n // When adding a series, points are not yet generated\n if (!series.points || series.isDirtyData) {\n // When we're updating the series with data that is longer\n // than it was, and cropThreshold is passed, we need to make\n // sure that the axis.max is increased _before_ running the\n // premature processData. Otherwise this early iteration of\n // processData will crop the points to axis.max, and the\n // names array will be too short (#5857).\n axis.max = Math.max(axis.max, series.xData.length - 1);\n series.processData();\n series.generatePoints();\n }\n series.data.forEach(function (point, i) {\n let x;\n if (point &&\n point.options &&\n typeof point.name !== 'undefined' // #9562\n ) {\n x = axis.nameToX(point);\n if (typeof x !== 'undefined' && x !== point.x) {\n point.x = x;\n series.xData[i] = x;\n }\n }\n });\n });\n }\n }\n /**\n * Update translation information.\n *\n * @private\n * @function Highcharts.Axis#setAxisTranslation\n *\n * @emits Highcharts.Axis#event:afterSetAxisTranslation\n */\n setAxisTranslation() {\n const axis = this, range = axis.max - axis.min, linkedParent = axis.linkedParent, hasCategories = !!axis.categories, isXAxis = axis.isXAxis;\n let pointRange = axis.axisPointRange || 0, closestPointRange, minPointOffset = 0, pointRangePadding = 0, ordinalCorrection, transA = axis.transA;\n // Adjust translation for padding. Y axis with categories need to go\n // through the same (#1784).\n if (isXAxis || hasCategories || pointRange) {\n // Get the closest points\n closestPointRange = axis.getClosest();\n if (linkedParent) {\n minPointOffset = linkedParent.minPointOffset;\n pointRangePadding = linkedParent.pointRangePadding;\n }\n else {\n axis.series.forEach(function (series) {\n const seriesPointRange = hasCategories ?\n 1 :\n (isXAxis ?\n pick(series.options.pointRange, closestPointRange, 0) :\n (axis.axisPointRange || 0)), // #2806\n pointPlacement = series.options.pointPlacement;\n pointRange = Math.max(pointRange, seriesPointRange);\n if (!axis.single || hasCategories) {\n // TODO: series should internally set x- and y-\n // pointPlacement to simplify this logic.\n const isPointPlacementAxis = series.is('xrange') ?\n !isXAxis :\n isXAxis;\n // minPointOffset is the value padding to the left of\n // the axis in order to make room for points with a\n // pointRange, typically columns. When the\n // pointPlacement option is 'between' or 'on', this\n // padding does not apply.\n minPointOffset = Math.max(minPointOffset, isPointPlacementAxis && isString(pointPlacement) ?\n 0 :\n seriesPointRange / 2);\n // Determine the total padding needed to the length of\n // the axis to make room for the pointRange. If the\n // series' pointPlacement is 'on', no padding is added.\n pointRangePadding = Math.max(pointRangePadding, isPointPlacementAxis && pointPlacement === 'on' ?\n 0 :\n seriesPointRange);\n }\n });\n }\n // Record minPointOffset and pointRangePadding\n ordinalCorrection = (axis.ordinal && axis.ordinal.slope && closestPointRange) ?\n axis.ordinal.slope / closestPointRange :\n 1; // #988, #1853\n axis.minPointOffset = minPointOffset =\n minPointOffset * ordinalCorrection;\n axis.pointRangePadding =\n pointRangePadding = pointRangePadding * ordinalCorrection;\n // pointRange means the width reserved for each point, like in a\n // column chart\n axis.pointRange = Math.min(pointRange, axis.single && hasCategories ? 1 : range);\n // closestPointRange means the closest distance between points. In\n // columns it is mostly equal to pointRange, but in lines pointRange\n // is 0 while closestPointRange is some other value\n if (isXAxis && closestPointRange) {\n axis.closestPointRange = closestPointRange;\n }\n }\n // Secondary values\n axis.translationSlope = axis.transA = transA =\n axis.staticScale ||\n axis.len / ((range + pointRangePadding) || 1);\n // Translation addend\n axis.transB = axis.horiz ? axis.left : axis.bottom;\n axis.minPixelPadding = transA * minPointOffset;\n fireEvent(this, 'afterSetAxisTranslation');\n }\n /**\n * @private\n * @function Highcharts.Axis#minFromRange\n */\n minFromRange() {\n const axis = this;\n return axis.max - axis.range;\n }\n /**\n * Set the tick positions to round values and optionally extend the extremes\n * to the nearest tick.\n *\n * @private\n * @function Highcharts.Axis#setTickInterval\n *\n * @param {boolean} secondPass\n * TO-DO: parameter description\n *\n * @emits Highcharts.Axis#event:foundExtremes\n */\n setTickInterval(secondPass) {\n const axis = this, chart = axis.chart, log = axis.logarithmic, options = axis.options, isXAxis = axis.isXAxis, isLinked = axis.isLinked, tickPixelIntervalOption = options.tickPixelInterval, categories = axis.categories, softThreshold = axis.softThreshold;\n let maxPadding = options.maxPadding, minPadding = options.minPadding, length, linkedParentExtremes, \n // Only non-negative tickInterval is valid, #12961\n tickIntervalOption = isNumber(options.tickInterval) && options.tickInterval >= 0 ?\n options.tickInterval : void 0, threshold = isNumber(axis.threshold) ? axis.threshold : null, thresholdMin, thresholdMax, hardMin, hardMax;\n if (!axis.dateTime && !categories && !isLinked) {\n this.getTickAmount();\n }\n // Min or max set either by zooming/setExtremes or initial options\n hardMin = pick(axis.userMin, options.min);\n hardMax = pick(axis.userMax, options.max);\n // Linked axis gets the extremes from the parent axis\n if (isLinked) {\n axis.linkedParent = chart[axis.coll][options.linkedTo];\n linkedParentExtremes = axis.linkedParent.getExtremes();\n axis.min = pick(linkedParentExtremes.min, linkedParentExtremes.dataMin);\n axis.max = pick(linkedParentExtremes.max, linkedParentExtremes.dataMax);\n if (options.type !== axis.linkedParent.options.type) {\n // Can't link axes of different type\n error(11, 1, chart);\n }\n // Initial min and max from the extreme data values\n }\n else {\n // Adjust to hard threshold\n if (softThreshold && defined(threshold)) {\n if (axis.dataMin >= threshold) {\n thresholdMin = threshold;\n minPadding = 0;\n }\n else if (axis.dataMax <= threshold) {\n thresholdMax = threshold;\n maxPadding = 0;\n }\n }\n axis.min = pick(hardMin, thresholdMin, axis.dataMin);\n axis.max = pick(hardMax, thresholdMax, axis.dataMax);\n }\n if (log) {\n if (axis.positiveValuesOnly &&\n !secondPass &&\n Math.min(axis.min, pick(axis.dataMin, axis.min)) <= 0) { // #978\n // Can't plot negative values on log axis\n error(10, 1, chart);\n }\n // The correctFloat cures #934, float errors on full tens. But it\n // was too aggressive for #4360 because of conversion back to lin,\n // therefore use precision 15.\n axis.min = correctFloat(log.log2lin(axis.min), 16);\n axis.max = correctFloat(log.log2lin(axis.max), 16);\n }\n // handle zoomed range\n if (axis.range && defined(axis.max)) {\n // #618, #6773:\n axis.userMin = axis.min = hardMin =\n Math.max(axis.dataMin, axis.minFromRange());\n axis.userMax = hardMax = axis.max;\n axis.range = null; // don't use it when running setExtremes\n }\n // Hook for Highcharts Stock Scroller.\n // Consider combining with beforePadding.\n fireEvent(axis, 'foundExtremes');\n // Hook for adjusting this.min and this.max. Used by bubble series.\n if (axis.beforePadding) {\n axis.beforePadding();\n }\n // Adjust min and max for the minimum range\n axis.adjustForMinRange();\n // Handle options for floor, ceiling, softMin and softMax (#6359)\n if (!isNumber(axis.userMin)) {\n if (isNumber(options.softMin) && options.softMin < axis.min) {\n axis.min = hardMin = options.softMin; // #6894\n }\n }\n if (!isNumber(axis.userMax)) {\n if (isNumber(options.softMax) && options.softMax > axis.max) {\n axis.max = hardMax = options.softMax; // #6894\n }\n }\n // Pad the values to get clear of the chart's edges. To avoid\n // tickInterval taking the padding into account, we do this after\n // computing tick interval (#1337).\n if (!categories &&\n !axis.axisPointRange &&\n !(axis.stacking && axis.stacking.usePercentage) &&\n !isLinked &&\n defined(axis.min) &&\n defined(axis.max)) {\n length = axis.max - axis.min;\n if (length) {\n if (!defined(hardMin) && minPadding) {\n axis.min -= length * minPadding;\n }\n if (!defined(hardMax) && maxPadding) {\n axis.max += length * maxPadding;\n }\n }\n }\n if (!isNumber(axis.userMin) && isNumber(options.floor)) {\n axis.min = Math.max(axis.min, options.floor);\n }\n if (!isNumber(axis.userMax) && isNumber(options.ceiling)) {\n axis.max = Math.min(axis.max, options.ceiling);\n }\n // When the threshold is soft, adjust the extreme value only if the data\n // extreme and the padded extreme land on either side of the threshold.\n // For example, a series of [0, 1, 2, 3] would make the yAxis add a tick\n // for -1 because of the default minPadding and startOnTick options.\n // This is prevented by the softThreshold option.\n if (softThreshold && defined(axis.dataMin)) {\n threshold = threshold || 0;\n if (!defined(hardMin) &&\n axis.min < threshold &&\n axis.dataMin >= threshold) {\n axis.min = axis.options.minRange ?\n Math.min(threshold, axis.max -\n axis.minRange) :\n threshold;\n }\n else if (!defined(hardMax) &&\n axis.max > threshold &&\n axis.dataMax <= threshold) {\n axis.max = axis.options.minRange ?\n Math.max(threshold, axis.min +\n axis.minRange) :\n threshold;\n }\n }\n // If min is bigger than highest, or if max less than lowest value, the\n // chart should not render points. (#14417)\n if (isNumber(axis.min) &&\n isNumber(axis.max) &&\n !this.chart.polar &&\n (axis.min > axis.max)) {\n if (defined(axis.options.min)) {\n axis.max = axis.min;\n }\n else if (defined(axis.options.max)) {\n axis.min = axis.max;\n }\n }\n // get tickInterval\n if (axis.min === axis.max ||\n typeof axis.min === 'undefined' ||\n typeof axis.max === 'undefined') {\n axis.tickInterval = 1;\n }\n else if (isLinked &&\n axis.linkedParent &&\n !tickIntervalOption &&\n tickPixelIntervalOption ===\n axis.linkedParent.options.tickPixelInterval) {\n axis.tickInterval = tickIntervalOption =\n axis.linkedParent.tickInterval;\n }\n else {\n axis.tickInterval = pick(tickIntervalOption, this.tickAmount ?\n ((axis.max - axis.min) /\n Math.max(this.tickAmount - 1, 1)) :\n void 0, \n // For categoried axis, 1 is default, for linear axis use\n // tickPix\n categories ?\n 1 :\n // don't let it be more than the data range\n (axis.max - axis.min) *\n tickPixelIntervalOption /\n Math.max(axis.len, tickPixelIntervalOption));\n }\n // Now we're finished detecting min and max, crop and group series data.\n // This is in turn needed in order to find tick positions in ordinal\n // axes.\n if (isXAxis && !secondPass) {\n const hasExtremesChanged = axis.min !==\n (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n // First process all series assigned to that axis.\n axis.series.forEach(function (series) {\n // Allows filtering out points outside the plot area.\n series.forceCrop = (series.forceCropping &&\n series.forceCropping());\n series.processData(hasExtremesChanged);\n });\n // Then apply grouping if needed. The hasExtremesChanged helps to\n // decide if the data grouping should be skipped in the further\n // calculations #16319.\n fireEvent(this, 'postProcessData', { hasExtremesChanged });\n }\n // set the translation factor used in translate function\n axis.setAxisTranslation();\n // hook for ordinal axes and radial axes\n fireEvent(this, 'initialAxisTranslation');\n // In column-like charts, don't cramp in more ticks than there are\n // points (#1943, #4184)\n if (axis.pointRange && !tickIntervalOption) {\n axis.tickInterval = Math.max(axis.pointRange, axis.tickInterval);\n }\n // Before normalizing the tick interval, handle minimum tick interval.\n // This applies only if tickInterval is not defined.\n const minTickInterval = pick(options.minTickInterval, \n // In datetime axes, don't go below the data interval, except when\n // there are scatter-like series involved (#13369).\n axis.dateTime &&\n !axis.series.some((s) => s.noSharedTooltip) ?\n axis.closestPointRange : 0);\n if (!tickIntervalOption && axis.tickInterval < minTickInterval) {\n axis.tickInterval = minTickInterval;\n }\n // For linear axes, normalize the interval\n if (!axis.dateTime && !axis.logarithmic && !tickIntervalOption) {\n axis.tickInterval = getNormalizedTickInterval(axis, axis.tickInterval);\n }\n // Prevent ticks from getting so close that we can't draw the labels\n if (!this.tickAmount) {\n axis.tickInterval = axis.unsquish();\n }\n this.setTickPositions();\n }\n /**\n * Now we have computed the normalized tickInterval, get the tick positions.\n *\n * @private\n * @function Highcharts.Axis#setTickPositions\n *\n * @emits Highcharts.Axis#event:afterSetTickPositions\n */\n setTickPositions() {\n const axis = this, options = this.options, tickPositionsOption = options.tickPositions, tickPositioner = options.tickPositioner, minorTickIntervalOption = this.getMinorTickInterval(), hasVerticalPanning = this.hasVerticalPanning(), isColorAxis = this.coll === 'colorAxis', startOnTick = ((isColorAxis || !hasVerticalPanning) && options.startOnTick), endOnTick = ((isColorAxis || !hasVerticalPanning) && options.endOnTick);\n let tickPositions = [], tickPositionerResult;\n // Set the tickmarkOffset\n this.tickmarkOffset = (this.categories &&\n options.tickmarkPlacement === 'between' &&\n this.tickInterval === 1) ? 0.5 : 0; // #3202\n // get minorTickInterval\n this.minorTickInterval =\n minorTickIntervalOption === 'auto' &&\n this.tickInterval ?\n this.tickInterval / options.minorTicksPerMajor :\n minorTickIntervalOption;\n // When there is only one point, or all points have the same value on\n // this axis, then min and max are equal and tickPositions.length is 0\n // or 1. In this case, add some padding in order to center the point,\n // but leave it with one tick. #1337.\n this.single =\n this.min === this.max &&\n defined(this.min) &&\n !this.tickAmount &&\n (\n // Data is on integer (#6563)\n parseInt(this.min, 10) === this.min ||\n // Between integers and decimals are not allowed (#6274)\n options.allowDecimals !== false);\n /**\n * Contains the current positions that are laid out on the axis. The\n * positions are numbers in terms of axis values. In a category axis\n * they are integers, in a datetime axis they are also integers, but\n * designating milliseconds.\n *\n * This property is read only - for modifying the tick positions, use\n * the `tickPositioner` callback or [axis.tickPositions(\n * https://api.highcharts.com/highcharts/xAxis.tickPositions) option\n * instead.\n *\n * @name Highcharts.Axis#tickPositions\n * @type {Highcharts.AxisTickPositionsArray|undefined}\n */\n if (tickPositionsOption) {\n // Find the tick positions. Work on a copy (#1565)\n tickPositions = tickPositionsOption.slice();\n }\n else if (isNumber(this.min) && isNumber(this.max)) {\n // Too many ticks (#6405). Create a friendly warning and provide two\n // ticks so at least we can show the data series.\n if ((!axis.ordinal || !axis.ordinal.positions) &&\n ((this.max - this.min) /\n this.tickInterval >\n Math.max(2 * this.len, 200))) {\n tickPositions = [this.min, this.max];\n error(19, false, this.chart);\n }\n else if (axis.dateTime) {\n tickPositions = axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(this.tickInterval, options.units), this.min, this.max, options.startOfWeek, axis.ordinal && axis.ordinal.positions, this.closestPointRange, true);\n }\n else if (axis.logarithmic) {\n tickPositions = axis.logarithmic.getLogTickPositions(this.tickInterval, this.min, this.max);\n }\n else {\n const startingTickInterval = this.tickInterval;\n let adjustedTickInterval = startingTickInterval;\n while (adjustedTickInterval <= startingTickInterval * 2) {\n tickPositions = this.getLinearTickPositions(this.tickInterval, this.min, this.max);\n // If there are more tick positions than the set tickAmount,\n // increase the tickInterval and continue until it fits.\n // (#17100)\n if (this.tickAmount &&\n tickPositions.length > this.tickAmount) {\n this.tickInterval = getNormalizedTickInterval(this, adjustedTickInterval *= 1.1);\n }\n else {\n break;\n }\n }\n }\n // Too dense ticks, keep only the first and last (#4477)\n if (tickPositions.length > this.len) {\n tickPositions = [\n tickPositions[0],\n tickPositions[tickPositions.length - 1]\n ];\n // Reduce doubled value (#7339)\n if (tickPositions[0] === tickPositions[1]) {\n tickPositions.length = 1;\n }\n }\n // Run the tick positioner callback, that allows modifying auto tick\n // positions.\n if (tickPositioner) {\n // Make it available to the positioner\n this.tickPositions = tickPositions;\n tickPositionerResult = tickPositioner.apply(axis, [this.min, this.max]);\n if (tickPositionerResult) {\n tickPositions = tickPositionerResult;\n }\n }\n }\n this.tickPositions = tickPositions;\n // Reset min/max or remove extremes based on start/end on tick\n this.paddedTicks = tickPositions.slice(0); // Used for logarithmic minor\n this.trimTicks(tickPositions, startOnTick, endOnTick);\n if (!this.isLinked && isNumber(this.min) && isNumber(this.max)) {\n // Substract half a unit (#2619, #2846, #2515, #3390), but not in\n // case of multiple ticks (#6897)\n if (this.single &&\n tickPositions.length < 2 &&\n !this.categories &&\n !this.series.some((s) => (s.is('heatmap') && s.options.pointPlacement === 'between'))) {\n this.min -= 0.5;\n this.max += 0.5;\n }\n if (!tickPositionsOption && !tickPositionerResult) {\n this.adjustTickAmount();\n }\n }\n fireEvent(this, 'afterSetTickPositions');\n }\n /**\n * Handle startOnTick and endOnTick by either adapting to padding min/max or\n * rounded min/max. Also handle single data points.\n *\n * @private\n * @function Highcharts.Axis#trimTicks\n *\n * @param {Array} tickPositions\n * TO-DO: parameter description\n *\n * @param {boolean} [startOnTick]\n * TO-DO: parameter description\n *\n * @param {boolean} [endOnTick]\n * TO-DO: parameter description\n */\n trimTicks(tickPositions, startOnTick, endOnTick) {\n const roundedMin = tickPositions[0], roundedMax = tickPositions[tickPositions.length - 1], minPointOffset = (!this.isOrdinal && this.minPointOffset) || 0; // (#12716)\n fireEvent(this, 'trimTicks');\n if (!this.isLinked) {\n if (startOnTick && roundedMin !== -Infinity) { // #6502\n this.min = roundedMin;\n }\n else {\n while (this.min - minPointOffset > tickPositions[0]) {\n tickPositions.shift();\n }\n }\n if (endOnTick) {\n this.max = roundedMax;\n }\n else {\n while (this.max + minPointOffset <\n tickPositions[tickPositions.length - 1]) {\n tickPositions.pop();\n }\n }\n // If no tick are left, set one tick in the middle (#3195)\n if (tickPositions.length === 0 &&\n defined(roundedMin) &&\n !this.options.tickPositions) {\n tickPositions.push((roundedMax + roundedMin) / 2);\n }\n }\n }\n /**\n * Check if there are multiple axes in the same pane.\n *\n * @private\n * @function Highcharts.Axis#alignToOthers\n *\n * @return {boolean|undefined}\n * True if there are other axes.\n */\n alignToOthers() {\n const axis = this, alignedAxes = [this], options = axis.options, alignThresholds = (this.coll === 'yAxis' &&\n this.chart.options.chart.alignThresholds), thresholdAlignments = [];\n let hasOther;\n axis.thresholdAlignment = void 0;\n if ((\n // Only if alignTicks or alignThresholds is true\n (this.chart.options.chart.alignTicks !== false &&\n options.alignTicks) || (alignThresholds)) &&\n // Disabled when startOnTick or endOnTick are false (#7604)\n options.startOnTick !== false &&\n options.endOnTick !== false &&\n // Don't try to align ticks on a log axis, they are not evenly\n // spaced (#6021)\n !axis.logarithmic) {\n // Get a key identifying which pane the axis belongs to\n const getKey = (axis) => {\n const { horiz, options } = axis;\n return [\n horiz ? options.left : options.top,\n options.width,\n options.height,\n options.pane\n ].join(',');\n };\n const thisKey = getKey(this);\n this.chart[this.coll].forEach(function (otherAxis) {\n const { series } = otherAxis;\n if (\n // #4442\n series.length &&\n series.some((s) => s.visible) &&\n otherAxis !== axis &&\n getKey(otherAxis) === thisKey) {\n hasOther = true; // #4201\n alignedAxes.push(otherAxis);\n }\n });\n }\n if (hasOther && alignThresholds) {\n // Handle alignThresholds. The `thresholdAlignments` array keeps\n // records of where each axis in the group wants its threshold, from\n // 0 which is on `axis.min`, to 1 which is on `axis.max`.\n alignedAxes.forEach((otherAxis) => {\n const threshAlign = otherAxis.getThresholdAlignment(axis);\n if (isNumber(threshAlign)) {\n thresholdAlignments.push(threshAlign);\n }\n });\n // For each of the axes in the group, record the average\n // `thresholdAlignment`.\n const thresholdAlignment = thresholdAlignments.length > 1 ?\n thresholdAlignments.reduce((sum, n) => (sum += n), 0) / thresholdAlignments.length :\n void 0;\n alignedAxes.forEach((axis) => {\n axis.thresholdAlignment = thresholdAlignment;\n });\n }\n return hasOther;\n }\n /**\n * Where the axis wants its threshold, from 0 which is on `axis.min`, to 1 which\n * is on `axis.max`.\n *\n * @private\n * @function Highcharts.Axis#getThresholdAlignment\n */\n getThresholdAlignment(callerAxis) {\n if (!isNumber(this.dataMin) ||\n (this !== callerAxis &&\n this.series.some((s) => (s.isDirty || s.isDirtyData)))) {\n this.getSeriesExtremes();\n }\n if (isNumber(this.threshold)) {\n let thresholdAlignment = clamp(((this.threshold - (this.dataMin || 0)) /\n ((this.dataMax || 0) - (this.dataMin || 0))), 0, 1);\n if (this.options.reversed) {\n thresholdAlignment = 1 - thresholdAlignment;\n }\n return thresholdAlignment;\n }\n }\n /**\n * Find the max ticks of either the x and y axis collection, and record it\n * in `this.tickAmount`.\n *\n * @private\n * @function Highcharts.Axis#getTickAmount\n */\n getTickAmount() {\n const axis = this, options = this.options, tickPixelInterval = options.tickPixelInterval;\n let tickAmount = options.tickAmount;\n if (!defined(options.tickInterval) &&\n !tickAmount &&\n this.len < tickPixelInterval &&\n !this.isRadial &&\n !axis.logarithmic &&\n options.startOnTick &&\n options.endOnTick) {\n tickAmount = 2;\n }\n if (!tickAmount && this.alignToOthers()) {\n // Add 1 because 4 tick intervals require 5 ticks (including first\n // and last)\n tickAmount = Math.ceil(this.len / tickPixelInterval) + 1;\n }\n // For tick amounts of 2 and 3, compute five ticks and remove the\n // intermediate ones. This prevents the axis from adding ticks that are\n // too far away from the data extremes.\n if (tickAmount < 4) {\n this.finalTickAmt = tickAmount;\n tickAmount = 5;\n }\n this.tickAmount = tickAmount;\n }\n /**\n * When using multiple axes, adjust the number of ticks to match the highest\n * number of ticks in that group.\n *\n * @private\n * @function Highcharts.Axis#adjustTickAmount\n */\n adjustTickAmount() {\n const axis = this, { finalTickAmt, max, min, options, tickPositions, tickAmount, thresholdAlignment } = axis, currentTickAmount = tickPositions && tickPositions.length, threshold = pick(axis.threshold, axis.softThreshold ? 0 : null);\n let len, i, tickInterval = axis.tickInterval, thresholdTickIndex;\n const \n // Extend the tickPositions by appending a position\n append = () => tickPositions.push(correctFloat(tickPositions[tickPositions.length - 1] +\n tickInterval)), \n // Extend the tickPositions by prepending a position\n prepend = () => tickPositions.unshift(correctFloat(tickPositions[0] - tickInterval));\n // If `thresholdAlignment` is a number, it means the `alignThresholds`\n // option is true. The `thresholdAlignment` is a scalar value between 0\n // and 1 for where the threshold should be relative to `axis.min` and\n // `axis.max`. Now that we know the tick amount, convert this to the\n // tick index. Unless `thresholdAlignment` is exactly 0 or 1, avoid the\n // first or last tick because that would lead to series being clipped.\n if (isNumber(thresholdAlignment)) {\n thresholdTickIndex = thresholdAlignment < 0.5 ?\n Math.ceil(thresholdAlignment * (tickAmount - 1)) :\n Math.floor(thresholdAlignment * (tickAmount - 1));\n if (options.reversed) {\n thresholdTickIndex = tickAmount - 1 - thresholdTickIndex;\n }\n }\n if (axis.hasData() && isNumber(min) && isNumber(max)) { // #14769\n // Adjust extremes and translation to the modified tick positions\n const adjustExtremes = () => {\n axis.transA *= (currentTickAmount - 1) / (tickAmount - 1);\n // Do not crop when ticks are not extremes (#9841)\n axis.min = options.startOnTick ?\n tickPositions[0] :\n Math.min(min, tickPositions[0]);\n axis.max = options.endOnTick ?\n tickPositions[tickPositions.length - 1] :\n Math.max(max, tickPositions[tickPositions.length - 1]);\n };\n // When the axis is subject to the alignThresholds option. Use\n // axis.threshold because the local threshold includes the\n // `softThreshold`.\n if (isNumber(thresholdTickIndex) && isNumber(axis.threshold)) {\n // Throw away the previously computed tickPositions and start\n // from scratch with only the threshold itself, then add ticks\n // below the threshold first, then fill up above the threshold.\n // If we are not able to fill up to axis.max, double the\n // tickInterval and run again.\n while (tickPositions[thresholdTickIndex] !== threshold ||\n tickPositions.length !== tickAmount ||\n tickPositions[0] > min ||\n tickPositions[tickPositions.length - 1] < max) {\n tickPositions.length = 0;\n tickPositions.push(axis.threshold);\n while (tickPositions.length < tickAmount) {\n if (\n // Start by prepending positions until the threshold\n // is at the required index...\n tickPositions[thresholdTickIndex] === void 0 ||\n tickPositions[thresholdTickIndex] > axis.threshold) {\n prepend();\n }\n else {\n // ... then append positions until we have the\n // required length\n append();\n }\n }\n // Safety vent\n if (tickInterval > axis.tickInterval * 8) {\n break;\n }\n tickInterval *= 2;\n }\n adjustExtremes();\n }\n else if (currentTickAmount < tickAmount) {\n while (tickPositions.length < tickAmount) {\n // Extend evenly for both sides unless we're on the\n // threshold (#3965)\n if (tickPositions.length % 2 || min === threshold) {\n append();\n }\n else {\n prepend();\n }\n }\n adjustExtremes();\n }\n // The finalTickAmt property is set in getTickAmount\n if (defined(finalTickAmt)) {\n i = len = tickPositions.length;\n while (i--) {\n if (\n // Remove every other tick\n (finalTickAmt === 3 && i % 2 === 1) ||\n // Remove all but first and last\n (finalTickAmt <= 2 && i > 0 && i < len - 1)) {\n tickPositions.splice(i, 1);\n }\n }\n axis.finalTickAmt = void 0;\n }\n }\n }\n /**\n * Set the scale based on data min and max, user set min and max or options.\n *\n * @private\n * @function Highcharts.Axis#setScale\n *\n * @emits Highcharts.Axis#event:afterSetScale\n */\n setScale() {\n const axis = this;\n let isDirtyData = false, isXAxisDirty = false;\n axis.series.forEach(function (series) {\n isDirtyData = isDirtyData || series.isDirtyData || series.isDirty;\n // When x axis is dirty, we need new data extremes for y as\n // well:\n isXAxisDirty = (isXAxisDirty ||\n (series.xAxis && series.xAxis.isDirty) ||\n false);\n });\n // set the new axisLength\n axis.setAxisSize();\n const isDirtyAxisLength = axis.len !== (axis.old && axis.old.len);\n // do we really need to go through all this?\n if (isDirtyAxisLength ||\n isDirtyData ||\n isXAxisDirty ||\n axis.isLinked ||\n axis.forceRedraw ||\n axis.userMin !== (axis.old && axis.old.userMin) ||\n axis.userMax !== (axis.old && axis.old.userMax) ||\n axis.alignToOthers()) {\n if (axis.stacking) {\n axis.stacking.resetStacks();\n axis.stacking.buildStacks();\n }\n axis.forceRedraw = false;\n // #18066 delete minRange property to ensure that it will be\n // calculated again after dirty data in series\n if (!axis.userMinRange) {\n axis.minRange = void 0;\n }\n // get data extremes if needed\n axis.getSeriesExtremes();\n // get fixed positions based on tickInterval\n axis.setTickInterval();\n // Mark as dirty if it is not already set to dirty and extremes have\n // changed. #595.\n if (!axis.isDirty) {\n axis.isDirty =\n isDirtyAxisLength ||\n axis.min !== (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n }\n }\n else if (axis.stacking) {\n axis.stacking.cleanStacks();\n }\n // Recalculate panning state object, when the data\n // has changed. It is required when vertical panning is enabled.\n if (isDirtyData && axis.panningState) {\n axis.panningState.isDirty = true;\n }\n fireEvent(this, 'afterSetScale');\n }\n /**\n * Set the minimum and maximum of the axes after render time. If the\n * `startOnTick` and `endOnTick` options are true, the minimum and maximum\n * values are rounded off to the nearest tick. To prevent this, these\n * options can be set to false before calling setExtremes. Also, setExtremes\n * will not allow a range lower than the `minRange` option, which by default\n * is the range of five points.\n *\n * @sample highcharts/members/axis-setextremes/\n * Set extremes from a button\n * @sample highcharts/members/axis-setextremes-datetime/\n * Set extremes on a datetime axis\n * @sample highcharts/members/axis-setextremes-off-ticks/\n * Set extremes off ticks\n * @sample stock/members/axis-setextremes/\n * Set extremes in Highcharts Stock\n *\n * @function Highcharts.Axis#setExtremes\n *\n * @param {number} [newMin]\n * The new minimum value.\n *\n * @param {number} [newMax]\n * The new maximum value.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}\n *\n * @param {boolean|Partial} [animation=true]\n * Enable or modify animations.\n *\n * @param {*} [eventArguments]\n * Arguments to be accessed in event handler.\n *\n * @emits Highcharts.Axis#event:setExtremes\n */\n setExtremes(newMin, newMax, redraw, animation, eventArguments) {\n const axis = this, chart = axis.chart;\n redraw = pick(redraw, true); // defaults to true\n axis.series.forEach(function (serie) {\n delete serie.kdTree;\n });\n // Extend the arguments with min and max\n eventArguments = extend(eventArguments, {\n min: newMin,\n max: newMax\n });\n // Fire the event\n fireEvent(axis, 'setExtremes', eventArguments, function () {\n axis.userMin = newMin;\n axis.userMax = newMax;\n axis.eventArgs = eventArguments;\n if (redraw) {\n chart.redraw(animation);\n }\n });\n }\n /**\n * Overridable method for zooming chart. Pulled out in a separate method to\n * allow overriding in stock charts.\n *\n * @private\n * @function Highcharts.Axis#zoom\n */\n zoom(newMin, newMax) {\n const axis = this, dataMin = this.dataMin, dataMax = this.dataMax, options = this.options, min = Math.min(dataMin, pick(options.min, dataMin)), max = Math.max(dataMax, pick(options.max, dataMax)), evt = {\n newMin: newMin,\n newMax: newMax\n };\n fireEvent(this, 'zoom', evt, function (e) {\n // Use e.newMin and e.newMax - event handlers may have altered them\n let newMin = e.newMin, newMax = e.newMax;\n if (newMin !== axis.min || newMax !== axis.max) { // #5790\n // Prevent pinch zooming out of range. Check for defined is for\n // #1946. #1734.\n if (!axis.allowZoomOutside) {\n // #6014, sometimes newMax will be smaller than min (or\n // newMin will be larger than max).\n if (defined(dataMin)) {\n if (newMin < min) {\n newMin = min;\n }\n if (newMin > max) {\n newMin = max;\n }\n }\n if (defined(dataMax)) {\n if (newMax < min) {\n newMax = min;\n }\n if (newMax > max) {\n newMax = max;\n }\n }\n }\n // In full view, displaying the reset zoom button is not\n // required\n axis.displayBtn = (typeof newMin !== 'undefined' ||\n typeof newMax !== 'undefined');\n // Do it\n axis.setExtremes(newMin, newMax, false, void 0, { trigger: 'zoom' });\n }\n e.zoomed = true;\n });\n return evt.zoomed;\n }\n /**\n * Update the axis metrics.\n *\n * @private\n * @function Highcharts.Axis#setAxisSize\n */\n setAxisSize() {\n const chart = this.chart, options = this.options, \n // [top, right, bottom, left]\n offsets = options.offsets || [0, 0, 0, 0], horiz = this.horiz, \n // Check for percentage based input values. Rounding fixes problems\n // with column overflow and plot line filtering (#4898, #4899)\n width = this.width = Math.round(relativeLength(pick(options.width, chart.plotWidth - offsets[3] + offsets[1]), chart.plotWidth)), height = this.height = Math.round(relativeLength(pick(options.height, chart.plotHeight - offsets[0] + offsets[2]), chart.plotHeight)), top = this.top = Math.round(relativeLength(pick(options.top, chart.plotTop + offsets[0]), chart.plotHeight, chart.plotTop)), left = this.left = Math.round(relativeLength(pick(options.left, chart.plotLeft + offsets[3]), chart.plotWidth, chart.plotLeft));\n // Expose basic values to use in Series object and navigator\n this.bottom = chart.chartHeight - height - top;\n this.right = chart.chartWidth - width - left;\n // Direction agnostic properties\n this.len = Math.max(horiz ? width : height, 0); // Math.max fixes #905\n this.pos = horiz ? left : top; // distance from SVG origin\n }\n /**\n * Get the current extremes for the axis.\n *\n * @sample highcharts/members/axis-getextremes/\n * Report extremes by click on a button\n *\n * @function Highcharts.Axis#getExtremes\n *\n * @return {Highcharts.ExtremesObject}\n * An object containing extremes information.\n */\n getExtremes() {\n const axis = this, log = axis.logarithmic;\n return {\n min: log ?\n correctFloat(log.lin2log(axis.min)) :\n axis.min,\n max: log ?\n correctFloat(log.lin2log(axis.max)) :\n axis.max,\n dataMin: axis.dataMin,\n dataMax: axis.dataMax,\n userMin: axis.userMin,\n userMax: axis.userMax\n };\n }\n /**\n * Get the zero plane either based on zero or on the min or max value.\n * Used in bar and area plots.\n *\n * @function Highcharts.Axis#getThreshold\n *\n * @param {number} threshold\n * The threshold in axis values.\n *\n * @return {number}\n * The translated threshold position in terms of pixels, and corrected to\n * stay within the axis bounds.\n */\n getThreshold(threshold) {\n const axis = this, log = axis.logarithmic, realMin = log ? log.lin2log(axis.min) : axis.min, realMax = log ? log.lin2log(axis.max) : axis.max;\n if (threshold === null || threshold === -Infinity) {\n threshold = realMin;\n }\n else if (threshold === Infinity) {\n threshold = realMax;\n }\n else if (realMin > threshold) {\n threshold = realMin;\n }\n else if (realMax < threshold) {\n threshold = realMax;\n }\n return axis.translate(threshold, 0, 1, 0, 1);\n }\n /**\n * Compute auto alignment for the axis label based on which side the axis is\n * on and the given rotation for the label.\n *\n * @private\n * @function Highcharts.Axis#autoLabelAlign\n *\n * @param {number} rotation\n * The rotation in degrees as set by either the `rotation` or `autoRotation`\n * options.\n *\n * @return {Highcharts.AlignValue}\n * Can be `\"center\"`, `\"left\"` or `\"right\"`.\n */\n autoLabelAlign(rotation) {\n const angle = (pick(rotation, 0) - (this.side * 90) + 720) % 360, evt = { align: 'center' };\n fireEvent(this, 'autoLabelAlign', evt, function (e) {\n if (angle > 15 && angle < 165) {\n e.align = 'right';\n }\n else if (angle > 195 && angle < 345) {\n e.align = 'left';\n }\n });\n return evt.align;\n }\n /**\n * Get the tick length and width for the axis based on axis options.\n *\n * @private\n * @function Highcharts.Axis#tickSize\n *\n * @param {string} [prefix]\n * 'tick' or 'minorTick'\n *\n * @return {Array|undefined}\n * An array of tickLength and tickWidth\n */\n tickSize(prefix) {\n const options = this.options, tickWidth = pick(options[prefix === 'tick' ? 'tickWidth' : 'minorTickWidth'], \n // Default to 1 on linear and datetime X axes\n prefix === 'tick' && this.isXAxis && !this.categories ? 1 : 0);\n let tickLength = options[prefix === 'tick' ? 'tickLength' : 'minorTickLength'], tickSize;\n if (tickWidth && tickLength) {\n // Negate the length\n if (options[prefix + 'Position'] === 'inside') {\n tickLength = -tickLength;\n }\n tickSize = [tickLength, tickWidth];\n }\n const e = { tickSize };\n fireEvent(this, 'afterTickSize', e);\n return e.tickSize;\n }\n /**\n * Return the size of the labels.\n *\n * @private\n * @function Highcharts.Axis#labelMetrics\n */\n labelMetrics() {\n const renderer = this.chart.renderer, ticks = this.ticks, tick = ticks[Object.keys(ticks)[0]] || {};\n return this.chart.renderer.fontMetrics(tick.label ||\n tick.movedLabel ||\n renderer.box);\n }\n /**\n * Prevent the ticks from getting so close we can't draw the labels. On a\n * horizontal axis, this is handled by rotating the labels, removing ticks\n * and adding ellipsis. On a vertical axis remove ticks and add ellipsis.\n *\n * @private\n * @function Highcharts.Axis#unsquish\n */\n unsquish() {\n const labelOptions = this.options.labels, horiz = this.horiz, tickInterval = this.tickInterval, slotSize = this.len / (((this.categories ? 1 : 0) +\n this.max -\n this.min) /\n tickInterval), rotationOption = labelOptions.rotation, \n // We don't know the actual rendered line height at this point, but\n // it defaults to 0.75em\n lineHeight = this.labelMetrics().h * 0.75, range = Math.max(this.max - this.min, 0), \n // Return the multiple of tickInterval that is needed to avoid\n // collision\n getStep = function (spaceNeeded) {\n let step = spaceNeeded / (slotSize || 1);\n step = step > 1 ? Math.ceil(step) : 1;\n // Guard for very small or negative angles (#9835)\n if (step * tickInterval > range &&\n spaceNeeded !== Infinity &&\n slotSize !== Infinity &&\n range) {\n step = Math.ceil(range / tickInterval);\n }\n return correctFloat(step * tickInterval);\n };\n let newTickInterval = tickInterval, rotation, bestScore = Number.MAX_VALUE, autoRotation;\n if (horiz) {\n if (!labelOptions.staggerLines) {\n if (isNumber(rotationOption)) {\n autoRotation = [rotationOption];\n }\n else if (slotSize < labelOptions.autoRotationLimit) {\n autoRotation = labelOptions.autoRotation;\n }\n }\n if (autoRotation) {\n let step, score;\n // Loop over the given autoRotation options, and determine which\n // gives the best score. The best score is that with the lowest\n // number of steps and a rotation closest to horizontal.\n for (const rot of autoRotation) {\n if (rot === rotationOption ||\n (rot && rot >= -90 && rot <= 90)) { // #3891\n step = getStep(Math.abs(lineHeight / Math.sin(deg2rad * rot)));\n score = step + Math.abs(rot / 360);\n if (score < bestScore) {\n bestScore = score;\n rotation = rot;\n newTickInterval = step;\n }\n }\n }\n }\n }\n else { // #4411\n newTickInterval = getStep(lineHeight);\n }\n this.autoRotation = autoRotation;\n this.labelRotation = pick(rotation, isNumber(rotationOption) ? rotationOption : 0);\n return labelOptions.step ? tickInterval : newTickInterval;\n }\n /**\n * Get the general slot width for labels/categories on this axis. This may\n * change between the pre-render (from Axis.getOffset) and the final tick\n * rendering and placement.\n *\n * @private\n * @function Highcharts.Axis#getSlotWidth\n *\n * @param {Highcharts.Tick} [tick] Optionally, calculate the slot width\n * basing on tick label. It is used in highcharts-3d module, where the slots\n * has different widths depending on perspective angles.\n *\n * @return {number}\n * The pixel width allocated to each axis label.\n */\n getSlotWidth(tick) {\n // #5086, #1580, #1931\n const chart = this.chart, horiz = this.horiz, labelOptions = this.options.labels, slotCount = Math.max(this.tickPositions.length - (this.categories ? 0 : 1), 1), marginLeft = chart.margin[3];\n // Used by grid axis\n if (tick && isNumber(tick.slotWidth)) { // #13221, can be 0\n return tick.slotWidth;\n }\n if (horiz && labelOptions.step < 2) {\n if (labelOptions.rotation) { // #4415\n return 0;\n }\n return ((this.staggerLines || 1) * this.len) / slotCount;\n }\n if (!horiz) {\n // #7028\n const cssWidth = labelOptions.style.width;\n if (cssWidth !== void 0) {\n return parseInt(String(cssWidth), 10);\n }\n if (marginLeft) {\n return marginLeft - chart.spacing[3];\n }\n }\n // Last resort, a fraction of the available size\n return chart.chartWidth * 0.33;\n }\n /**\n * Render the axis labels and determine whether ellipsis or rotation need to\n * be applied.\n *\n * @private\n * @function Highcharts.Axis#renderUnsquish\n */\n renderUnsquish() {\n const chart = this.chart, renderer = chart.renderer, tickPositions = this.tickPositions, ticks = this.ticks, labelOptions = this.options.labels, labelStyleOptions = labelOptions.style, horiz = this.horiz, slotWidth = this.getSlotWidth(), innerWidth = Math.max(1, Math.round(slotWidth - 2 * labelOptions.padding)), attr = {}, labelMetrics = this.labelMetrics(), textOverflowOption = labelStyleOptions.textOverflow;\n let commonWidth, commonTextOverflow, maxLabelLength = 0, label, i, pos;\n // Set rotation option unless it is \"auto\", like in gauges\n if (!isString(labelOptions.rotation)) {\n // #4443\n attr.rotation = labelOptions.rotation || 0;\n }\n // Get the longest label length\n tickPositions.forEach(function (tickPosition) {\n const tick = ticks[tickPosition];\n // Replace label - sorting animation\n if (tick.movedLabel) {\n tick.replaceMovedLabel();\n }\n if (tick &&\n tick.label &&\n tick.label.textPxLength > maxLabelLength) {\n maxLabelLength = tick.label.textPxLength;\n }\n });\n this.maxLabelLength = maxLabelLength;\n // Handle auto rotation on horizontal axis\n if (this.autoRotation) {\n // Apply rotation only if the label is too wide for the slot, and\n // the label is wider than its height.\n if (maxLabelLength > innerWidth &&\n maxLabelLength > labelMetrics.h) {\n attr.rotation = this.labelRotation;\n }\n else {\n this.labelRotation = 0;\n }\n // Handle word-wrap or ellipsis on vertical axis\n }\n else if (slotWidth) {\n // For word-wrap or ellipsis\n commonWidth = innerWidth;\n if (!textOverflowOption) {\n commonTextOverflow = 'clip';\n // On vertical axis, only allow word wrap if there is room\n // for more lines.\n i = tickPositions.length;\n while (!horiz && i--) {\n pos = tickPositions[i];\n label = ticks[pos].label;\n if (label) {\n // Reset ellipsis in order to get the correct\n // bounding box (#4070)\n if (label.styles &&\n label.styles.textOverflow === 'ellipsis') {\n label.css({ textOverflow: 'clip' });\n // Set the correct width in order to read\n // the bounding box height (#4678, #5034)\n }\n else if (label.textPxLength > slotWidth) {\n label.css({ width: slotWidth + 'px' });\n }\n if (label.getBBox().height > (this.len / tickPositions.length -\n (labelMetrics.h - labelMetrics.f))) {\n label.specificTextOverflow = 'ellipsis';\n }\n }\n }\n }\n }\n // Add ellipsis if the label length is significantly longer than ideal\n if (attr.rotation) {\n commonWidth = (maxLabelLength > chart.chartHeight * 0.5 ?\n chart.chartHeight * 0.33 :\n maxLabelLength);\n if (!textOverflowOption) {\n commonTextOverflow = 'ellipsis';\n }\n }\n // Set the explicit or automatic label alignment\n this.labelAlign = labelOptions.align ||\n this.autoLabelAlign(this.labelRotation);\n if (this.labelAlign) {\n attr.align = this.labelAlign;\n }\n // Apply general and specific CSS\n tickPositions.forEach(function (pos) {\n const tick = ticks[pos], label = tick && tick.label, widthOption = labelStyleOptions.width, css = {};\n if (label) {\n // This needs to go before the CSS in old IE (#4502)\n label.attr(attr);\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else if (commonWidth &&\n !widthOption &&\n // Setting width in this case messes with the bounding box\n // (#7975)\n labelStyleOptions.whiteSpace !== 'nowrap' &&\n (\n // Speed optimizing, #7656\n commonWidth < label.textPxLength ||\n // Resetting CSS, #4928\n label.element.tagName === 'SPAN')) {\n css.width = commonWidth + 'px';\n if (!textOverflowOption) {\n css.textOverflow = (label.specificTextOverflow ||\n commonTextOverflow);\n }\n label.css(css);\n // Reset previously shortened label (#8210)\n }\n else if (label.styles &&\n label.styles.width &&\n !css.width &&\n !widthOption) {\n label.css({ width: null });\n }\n delete label.specificTextOverflow;\n tick.rotation = attr.rotation;\n }\n }, this);\n // Note: Why is this not part of getLabelPosition?\n this.tickRotCorr = renderer.rotCorr(labelMetrics.b, this.labelRotation || 0, this.side !== 0);\n }\n /**\n * Return true if the axis has associated data.\n *\n * @function Highcharts.Axis#hasData\n *\n * @return {boolean}\n * True if the axis has associated visible series and those series have\n * either valid data points or explicit `min` and `max` settings.\n */\n hasData() {\n return this.series.some(function (s) {\n return s.hasData();\n }) ||\n (this.options.showEmpty &&\n defined(this.min) &&\n defined(this.max));\n }\n /**\n * Adds the title defined in axis.options.title.\n *\n * @function Highcharts.Axis#addTitle\n *\n * @param {boolean} [display]\n * Whether or not to display the title.\n */\n addTitle(display) {\n const axis = this, renderer = axis.chart.renderer, horiz = axis.horiz, opposite = axis.opposite, options = axis.options, axisTitleOptions = options.title, styledMode = axis.chart.styledMode;\n let textAlign;\n if (!axis.axisTitle) {\n textAlign = axisTitleOptions.textAlign;\n if (!textAlign) {\n textAlign = (horiz ? {\n low: 'left',\n middle: 'center',\n high: 'right'\n } : {\n low: opposite ? 'right' : 'left',\n middle: 'center',\n high: opposite ? 'left' : 'right'\n })[axisTitleOptions.align];\n }\n axis.axisTitle = renderer\n .text(axisTitleOptions.text || '', 0, 0, axisTitleOptions.useHTML)\n .attr({\n zIndex: 7,\n rotation: axisTitleOptions.rotation,\n align: textAlign\n })\n .addClass('highcharts-axis-title');\n // #7814, don't mutate style option\n if (!styledMode) {\n axis.axisTitle.css(merge(axisTitleOptions.style));\n }\n axis.axisTitle.add(axis.axisGroup);\n axis.axisTitle.isNew = true;\n }\n // Max width defaults to the length of the axis\n if (!styledMode &&\n !axisTitleOptions.style.width &&\n !axis.isRadial) {\n axis.axisTitle.css({\n width: axis.len + 'px'\n });\n }\n // hide or show the title depending on whether showEmpty is set\n axis.axisTitle[display ? 'show' : 'hide'](display);\n }\n /**\n * Generates a tick for initial positioning.\n *\n * @private\n * @function Highcharts.Axis#generateTick\n *\n * @param {number} pos\n * The tick position in axis values.\n *\n * @param {number} [i]\n * The index of the tick in {@link Axis.tickPositions}.\n */\n generateTick(pos) {\n const axis = this, ticks = axis.ticks;\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n else {\n ticks[pos].addLabel(); // update labels depending on tick interval\n }\n }\n /**\n * Render the tick labels to a preliminary position to get their sizes\n *\n * @private\n * @function Highcharts.Axis#getOffset\n *\n * @emits Highcharts.Axis#event:afterGetOffset\n */\n getOffset() {\n const axis = this, { chart, horiz, options, side, ticks, tickPositions, coll, axisParent // Used in color axis\n } = axis, renderer = chart.renderer, invertedSide = (chart.inverted && !axis.isZAxis ?\n [1, 0, 3, 2][side] :\n side), hasData = axis.hasData(), axisTitleOptions = options.title, labelOptions = options.labels, hasCrossing = isNumber(options.crossing), axisOffset = chart.axisOffset, clipOffset = chart.clipOffset, directionFactor = [-1, 1, 1, -1][side], className = options.className;\n let showAxis, titleOffset = 0, titleOffsetOption, titleMargin = 0, labelOffset = 0, // reset\n labelOffsetPadded, lineHeightCorrection;\n // For reuse in Axis.render\n axis.showAxis = showAxis = hasData || options.showEmpty;\n // Set/reset staggerLines\n axis.staggerLines = (axis.horiz && labelOptions.staggerLines) || void 0;\n // Create the axisGroup and gridGroup elements on first iteration\n if (!axis.axisGroup) {\n const createGroup = (name, suffix, zIndex) => renderer.g(name)\n .attr({ zIndex })\n .addClass(`highcharts-${coll.toLowerCase()}${suffix} ` +\n (this.isRadial ? `highcharts-radial-axis${suffix} ` : '') +\n (className || ''))\n .add(axisParent);\n axis.gridGroup = createGroup('grid', '-grid', options.gridZIndex);\n axis.axisGroup = createGroup('axis', '', options.zIndex);\n axis.labelGroup = createGroup('axis-labels', '-labels', labelOptions.zIndex);\n }\n if (hasData || axis.isLinked) {\n // Generate ticks\n tickPositions.forEach(function (pos) {\n // i is not used here, but may be used in overrides\n axis.generateTick(pos);\n });\n axis.renderUnsquish();\n // Left side must be align: right and right side must\n // have align: left for labels\n axis.reserveSpaceDefault = (side === 0 ||\n side === 2 ||\n { 1: 'left', 3: 'right' }[side] === axis.labelAlign);\n if (pick(labelOptions.reserveSpace, hasCrossing ? false : null, axis.labelAlign === 'center' ? true : null, axis.reserveSpaceDefault)) {\n tickPositions.forEach(function (pos) {\n // get the highest offset\n labelOffset = Math.max(ticks[pos].getLabelSize(), labelOffset);\n });\n }\n if (axis.staggerLines) {\n labelOffset *= axis.staggerLines;\n }\n axis.labelOffset = labelOffset * (axis.opposite ? -1 : 1);\n }\n else { // doesn't have data\n objectEach(ticks, function (tick, n) {\n tick.destroy();\n delete ticks[n];\n });\n }\n if (axisTitleOptions &&\n axisTitleOptions.text &&\n axisTitleOptions.enabled !== false) {\n axis.addTitle(showAxis);\n if (showAxis &&\n !hasCrossing &&\n axisTitleOptions.reserveSpace !== false) {\n axis.titleOffset = titleOffset =\n axis.axisTitle.getBBox()[horiz ? 'height' : 'width'];\n titleOffsetOption = axisTitleOptions.offset;\n titleMargin = defined(titleOffsetOption) ?\n 0 :\n pick(axisTitleOptions.margin, horiz ? 5 : 10);\n }\n }\n // Render the axis line\n axis.renderLine();\n // handle automatic or user set offset\n axis.offset = directionFactor * pick(options.offset, axisOffset[side] ? axisOffset[side] + (options.margin || 0) : 0);\n axis.tickRotCorr = axis.tickRotCorr || { x: 0, y: 0 }; // polar\n if (side === 0) {\n lineHeightCorrection = -axis.labelMetrics().h;\n }\n else if (side === 2) {\n lineHeightCorrection = axis.tickRotCorr.y;\n }\n else {\n lineHeightCorrection = 0;\n }\n // Find the padded label offset\n labelOffsetPadded = Math.abs(labelOffset) + titleMargin;\n if (labelOffset) {\n labelOffsetPadded -= lineHeightCorrection;\n labelOffsetPadded += directionFactor * (horiz ?\n pick(labelOptions.y, axis.tickRotCorr.y +\n directionFactor * labelOptions.distance) :\n pick(labelOptions.x, directionFactor * labelOptions.distance));\n }\n axis.axisTitleMargin = pick(titleOffsetOption, labelOffsetPadded);\n if (axis.getMaxLabelDimensions) {\n axis.maxLabelDimensions = axis.getMaxLabelDimensions(ticks, tickPositions);\n }\n // Due to GridAxis.tickSize, tickSize should be calculated after ticks\n // has rendered.\n if (coll !== 'colorAxis') {\n const tickSize = this.tickSize('tick');\n axisOffset[side] = Math.max(axisOffset[side], (axis.axisTitleMargin || 0) + titleOffset +\n directionFactor * axis.offset, labelOffsetPadded, // #3027\n tickPositions && tickPositions.length && tickSize ?\n tickSize[0] + directionFactor * axis.offset :\n 0 // #4866\n );\n // Decide the clipping needed to keep the graph inside\n // the plot area and axis lines\n const clip = !axis.axisLine || options.offset ?\n 0 :\n // #4308, #4371:\n Math.floor(axis.axisLine.strokeWidth() / 2) * 2;\n clipOffset[invertedSide] =\n Math.max(clipOffset[invertedSide], clip);\n }\n fireEvent(this, 'afterGetOffset');\n }\n /**\n * Internal function to get the path for the axis line. Extended for polar\n * charts.\n *\n * @function Highcharts.Axis#getLinePath\n *\n * @param {number} lineWidth\n * The line width in pixels.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n getLinePath(lineWidth) {\n const chart = this.chart, opposite = this.opposite, offset = this.offset, horiz = this.horiz, lineLeft = this.left + (opposite ? this.width : 0) + offset, lineTop = chart.chartHeight - this.bottom -\n (opposite ? this.height : 0) + offset;\n if (opposite) {\n lineWidth *= -1; // crispify the other way - #1480, #1687\n }\n return chart.renderer\n .crispLine([\n [\n 'M',\n horiz ?\n this.left :\n lineLeft,\n horiz ?\n lineTop :\n this.top\n ],\n [\n 'L',\n horiz ?\n chart.chartWidth - this.right :\n lineLeft,\n horiz ?\n lineTop :\n chart.chartHeight - this.bottom\n ]\n ], lineWidth);\n }\n /**\n * Render the axis line. Called internally when rendering and redrawing the\n * axis.\n *\n * @function Highcharts.Axis#renderLine\n */\n renderLine() {\n if (!this.axisLine) {\n this.axisLine = this.chart.renderer.path()\n .addClass('highcharts-axis-line')\n .add(this.axisGroup);\n if (!this.chart.styledMode) {\n this.axisLine.attr({\n stroke: this.options.lineColor,\n 'stroke-width': this.options.lineWidth,\n zIndex: 7\n });\n }\n }\n }\n /**\n * Position the axis title.\n *\n * @private\n * @function Highcharts.Axis#getTitlePosition\n *\n * @return {Highcharts.PositionObject}\n * X and Y positions for the title.\n */\n getTitlePosition(axisTitle) {\n // compute anchor points for each of the title align options\n const horiz = this.horiz, axisLeft = this.left, axisTop = this.top, axisLength = this.len, axisTitleOptions = this.options.title, margin = horiz ? axisLeft : axisTop, opposite = this.opposite, offset = this.offset, xOption = axisTitleOptions.x, yOption = axisTitleOptions.y, fontMetrics = this.chart.renderer.fontMetrics(axisTitle), \n // The part of a multiline text that is below the baseline of the\n // first line. Subtract 1 to preserve pixel-perfectness from the\n // old behaviour (v5.0.12), where only one line was allowed.\n textHeightOvershoot = axisTitle ? Math.max(axisTitle.getBBox(false, 0).height - fontMetrics.h - 1, 0) : 0, \n // the position in the length direction of the axis\n alongAxis = ({\n low: margin + (horiz ? 0 : axisLength),\n middle: margin + axisLength / 2,\n high: margin + (horiz ? axisLength : 0)\n })[axisTitleOptions.align], \n // the position in the perpendicular direction of the axis\n offAxis = (horiz ? axisTop + this.height : axisLeft) +\n (horiz ? 1 : -1) * // horizontal axis reverses the margin\n (opposite ? -1 : 1) * // so does opposite axes\n (this.axisTitleMargin || 0) +\n [\n -textHeightOvershoot,\n textHeightOvershoot,\n fontMetrics.f,\n -textHeightOvershoot // left\n ][this.side], titlePosition = {\n x: horiz ?\n alongAxis + xOption :\n offAxis + (opposite ? this.width : 0) + offset + xOption,\n y: horiz ?\n offAxis + yOption - (opposite ? this.height : 0) + offset :\n alongAxis + yOption\n };\n fireEvent(this, 'afterGetTitlePosition', { titlePosition: titlePosition });\n return titlePosition;\n }\n /**\n * Render a minor tick into the given position. If a minor tick already\n * exists in this position, move it.\n *\n * @function Highcharts.Axis#renderMinorTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n renderMinorTick(pos, slideIn) {\n const axis = this;\n const minorTicks = axis.minorTicks;\n if (!minorTicks[pos]) {\n minorTicks[pos] = new Tick(axis, pos, 'minor');\n }\n // Render new ticks in old position\n if (slideIn && minorTicks[pos].isNew) {\n minorTicks[pos].render(null, true);\n }\n minorTicks[pos].render(null, false, 1);\n }\n /**\n * Render a major tick into the given position. If a tick already exists\n * in this position, move it.\n *\n * @function Highcharts.Axis#renderTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {number} i\n * The tick index.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n renderTick(pos, i, slideIn) {\n const axis = this, isLinked = axis.isLinked, ticks = axis.ticks;\n // Linked axes need an extra check to find out if\n if (!isLinked ||\n (pos >= axis.min && pos <= axis.max) ||\n (axis.grid && axis.grid.isColumn)) {\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n // NOTE this seems like overkill. Could be handled in tick.render by\n // setting old position in attr, then set new position in animate.\n // render new ticks in old position\n if (slideIn && ticks[pos].isNew) {\n // Start with negative opacity so that it is visible from\n // halfway into the animation\n ticks[pos].render(i, true, -1);\n }\n ticks[pos].render(i);\n }\n }\n /**\n * Render the axis.\n *\n * @private\n * @function Highcharts.Axis#render\n *\n * @emits Highcharts.Axis#event:afterRender\n */\n render() {\n const axis = this, chart = axis.chart, log = axis.logarithmic, renderer = chart.renderer, options = axis.options, isLinked = axis.isLinked, tickPositions = axis.tickPositions, axisTitle = axis.axisTitle, ticks = axis.ticks, minorTicks = axis.minorTicks, alternateBands = axis.alternateBands, stackLabelOptions = options.stackLabels, alternateGridColor = options.alternateGridColor, crossing = options.crossing, tickmarkOffset = axis.tickmarkOffset, axisLine = axis.axisLine, showAxis = axis.showAxis, animation = animObject(renderer.globalAnimation);\n let from, to;\n // Reset\n axis.labelEdge.length = 0;\n axis.overlap = false;\n // Mark all elements inActive before we go over and mark the active ones\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n objectEach(coll, function (tick) {\n tick.isActive = false;\n });\n });\n // Crossing\n if (isNumber(crossing)) {\n const otherAxis = this.isXAxis ? chart.yAxis[0] : chart.xAxis[0], directionFactor = [1, -1, -1, 1][this.side];\n if (otherAxis) {\n let px = otherAxis.toPixels(crossing, true);\n if (axis.horiz) {\n px = otherAxis.len - px;\n }\n axis.offset = directionFactor * px;\n }\n }\n // If the series has data draw the ticks. Else only the line and title\n if (axis.hasData() || isLinked) {\n const slideInTicks = axis.chart.hasRendered &&\n axis.old && isNumber(axis.old.min);\n // minor ticks\n if (axis.minorTickInterval && !axis.categories) {\n axis.getMinorTickPositions().forEach(function (pos) {\n axis.renderMinorTick(pos, slideInTicks);\n });\n }\n // Major ticks. Pull out the first item and render it last so that\n // we can get the position of the neighbour label. #808.\n if (tickPositions.length) { // #1300\n tickPositions.forEach(function (pos, i) {\n axis.renderTick(pos, i, slideInTicks);\n });\n // In a categorized axis, the tick marks are displayed\n // between labels. So we need to add a tick mark and\n // grid line at the left edge of the X axis.\n if (tickmarkOffset && (axis.min === 0 || axis.single)) {\n if (!ticks[-1]) {\n ticks[-1] = new Tick(axis, -1, null, true);\n }\n ticks[-1].render(-1);\n }\n }\n // alternate grid color\n if (alternateGridColor) {\n tickPositions.forEach(function (pos, i) {\n to = typeof tickPositions[i + 1] !== 'undefined' ?\n tickPositions[i + 1] + tickmarkOffset :\n axis.max - tickmarkOffset;\n if (i % 2 === 0 &&\n pos < axis.max &&\n to <= axis.max + (chart.polar ?\n -tickmarkOffset :\n tickmarkOffset)) { // #2248, #4660\n if (!alternateBands[pos]) {\n // Should be imported from PlotLineOrBand.js, but\n // the dependency cycle with axis is a problem\n alternateBands[pos] = new H.PlotLineOrBand(axis);\n }\n from = pos + tickmarkOffset; // #949\n alternateBands[pos].options = {\n from: log ? log.lin2log(from) : from,\n to: log ? log.lin2log(to) : to,\n color: alternateGridColor,\n className: 'highcharts-alternate-grid'\n };\n alternateBands[pos].render();\n alternateBands[pos].isActive = true;\n }\n });\n }\n // custom plot lines and bands\n if (!axis._addedPlotLB) { // only first time\n axis._addedPlotLB = true;\n (options.plotLines || [])\n .concat(options.plotBands || [])\n .forEach(function (plotLineOptions) {\n axis\n .addPlotBandOrLine(plotLineOptions);\n });\n }\n } // end if hasData\n // Remove inactive ticks\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n const forDestruction = [], delay = animation.duration, destroyInactiveItems = function () {\n let i = forDestruction.length;\n while (i--) {\n // When resizing rapidly, the same items\n // may be destroyed in different timeouts,\n // or the may be reactivated\n if (coll[forDestruction[i]] &&\n !coll[forDestruction[i]].isActive) {\n coll[forDestruction[i]].destroy();\n delete coll[forDestruction[i]];\n }\n }\n };\n objectEach(coll, function (tick, pos) {\n if (!tick.isActive) {\n // Render to zero opacity\n tick.render(pos, false, 0);\n tick.isActive = false;\n forDestruction.push(pos);\n }\n });\n // When the objects are finished fading out, destroy them\n syncTimeout(destroyInactiveItems, coll === alternateBands ||\n !chart.hasRendered ||\n !delay ?\n 0 :\n delay);\n });\n // Set the axis line path\n if (axisLine) {\n axisLine[axisLine.isPlaced ? 'animate' : 'attr']({\n d: this.getLinePath(axisLine.strokeWidth())\n });\n axisLine.isPlaced = true;\n // Show or hide the line depending on options.showEmpty\n axisLine[showAxis ? 'show' : 'hide'](showAxis);\n }\n if (axisTitle && showAxis) {\n axisTitle[axisTitle.isNew ? 'attr' : 'animate'](axis.getTitlePosition(axisTitle));\n axisTitle.isNew = false;\n }\n // Stacked totals:\n if (stackLabelOptions && stackLabelOptions.enabled && axis.stacking) {\n axis.stacking.renderStackTotals();\n }\n // End stacked totals\n // Record old scaling for updating/animation\n axis.old = {\n len: axis.len,\n max: axis.max,\n min: axis.min,\n transA: axis.transA,\n userMax: axis.userMax,\n userMin: axis.userMin\n };\n axis.isDirty = false;\n fireEvent(this, 'afterRender');\n }\n /**\n * Redraw the axis to reflect changes in the data or axis extremes. Called\n * internally from Highcharts.Chart#redraw.\n *\n * @private\n * @function Highcharts.Axis#redraw\n */\n redraw() {\n if (this.visible) {\n // render the axis\n this.render();\n // move plot lines and bands\n this.plotLinesAndBands.forEach(function (plotLine) {\n plotLine.render();\n });\n }\n // mark associated series as dirty and ready for redraw\n this.series.forEach(function (series) {\n series.isDirty = true;\n });\n }\n /**\n * Returns an array of axis properties, that should be untouched during\n * reinitialization.\n *\n * @private\n * @function Highcharts.Axis#getKeepProps\n */\n getKeepProps() {\n return (this.keepProps || Axis.keepProps);\n }\n /**\n * Destroys an Axis instance. See {@link Axis#remove} for the API endpoint\n * to fully remove the axis.\n *\n * @private\n * @function Highcharts.Axis#destroy\n *\n * @param {boolean} [keepEvents]\n * Whether to preserve events, used internally in Axis.update.\n */\n destroy(keepEvents) {\n const axis = this, plotLinesAndBands = axis.plotLinesAndBands, eventOptions = this.eventOptions;\n fireEvent(this, 'destroy', { keepEvents: keepEvents });\n // Remove the events\n if (!keepEvents) {\n removeEvent(axis);\n }\n // Destroy collections\n [axis.ticks, axis.minorTicks, axis.alternateBands].forEach(function (coll) {\n destroyObjectProperties(coll);\n });\n if (plotLinesAndBands) {\n let i = plotLinesAndBands.length;\n while (i--) { // #1975\n plotLinesAndBands[i].destroy();\n }\n }\n // Destroy elements\n ['axisLine', 'axisTitle', 'axisGroup',\n 'gridGroup', 'labelGroup', 'cross', 'scrollbar'].forEach(function (prop) {\n if (axis[prop]) {\n axis[prop] = axis[prop].destroy();\n }\n });\n // Destroy each generated group for plotlines and plotbands\n for (const plotGroup in axis.plotLinesAndBandsGroups) { // eslint-disable-line guard-for-in\n axis.plotLinesAndBandsGroups[plotGroup] =\n axis.plotLinesAndBandsGroups[plotGroup].destroy();\n }\n // Delete all properties and fall back to the prototype.\n objectEach(axis, function (val, key) {\n if (axis.getKeepProps().indexOf(key) === -1) {\n delete axis[key];\n }\n });\n this.eventOptions = eventOptions;\n }\n /**\n * Internal function to draw a crosshair.\n *\n * @function Highcharts.Axis#drawCrosshair\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments from the modified pointer event, extended with\n * `chartX` and `chartY`\n *\n * @param {Highcharts.Point} [point]\n * The Point object if the crosshair snaps to points.\n *\n * @emits Highcharts.Axis#event:afterDrawCrosshair\n * @emits Highcharts.Axis#event:drawCrosshair\n */\n drawCrosshair(e, point) {\n const options = this.crosshair, snap = pick(options && options.snap, true), chart = this.chart;\n let path, pos, categorized, graphic = this.cross, crossOptions;\n fireEvent(this, 'drawCrosshair', { e: e, point: point });\n // Use last available event when updating non-snapped crosshairs without\n // mouse interaction (#5287)\n if (!e) {\n e = this.cross && this.cross.e;\n }\n if (\n // Disabled in options\n !options ||\n // Snap\n ((defined(point) || !snap) === false)) {\n this.hideCrosshair();\n }\n else {\n // Get the path\n if (!snap) {\n pos = e &&\n (this.horiz ?\n e.chartX - this.pos :\n this.len - e.chartY + this.pos);\n }\n else if (defined(point)) {\n // #3834\n pos = pick(this.coll !== 'colorAxis' ?\n point.crosshairPos : // 3D axis extension\n null, this.isXAxis ?\n point.plotX :\n this.len - point.plotY);\n }\n if (defined(pos)) {\n crossOptions = {\n // value, only used on radial\n value: point && (this.isXAxis ?\n point.x :\n pick(point.stackY, point.y)),\n translatedValue: pos\n };\n if (chart.polar) {\n // Additional information required for crosshairs in\n // polar chart\n extend(crossOptions, {\n isCrosshair: true,\n chartX: e && e.chartX,\n chartY: e && e.chartY,\n point: point\n });\n }\n path = this.getPlotLinePath(crossOptions) ||\n null; // #3189\n }\n if (!defined(path)) {\n this.hideCrosshair();\n return;\n }\n categorized = this.categories && !this.isRadial;\n // Draw the cross\n if (!graphic) {\n this.cross = graphic = chart.renderer\n .path()\n .addClass('highcharts-crosshair highcharts-crosshair-' +\n (categorized ? 'category ' : 'thin ') +\n (options.className || ''))\n .attr({\n zIndex: pick(options.zIndex, 2)\n })\n .add();\n // Presentational attributes\n if (!chart.styledMode) {\n graphic.attr({\n stroke: options.color ||\n (categorized ?\n Color\n .parse(\"#ccd3ff\" /* Palette.highlightColor20 */)\n .setOpacity(0.25)\n .get() :\n \"#cccccc\" /* Palette.neutralColor20 */),\n 'stroke-width': pick(options.width, 1)\n }).css({\n 'pointer-events': 'none'\n });\n if (options.dashStyle) {\n graphic.attr({\n dashstyle: options.dashStyle\n });\n }\n }\n }\n graphic.show().attr({\n d: path\n });\n if (categorized && !options.width) {\n graphic.attr({\n 'stroke-width': this.transA\n });\n }\n this.cross.e = e;\n }\n fireEvent(this, 'afterDrawCrosshair', { e: e, point: point });\n }\n /**\n * Hide the crosshair if visible.\n *\n * @function Highcharts.Axis#hideCrosshair\n */\n hideCrosshair() {\n if (this.cross) {\n this.cross.hide();\n }\n fireEvent(this, 'afterHideCrosshair');\n }\n /**\n * Check whether the chart has vertical panning ('y' or 'xy' type).\n *\n * @private\n * @function Highcharts.Axis#hasVerticalPanning\n */\n hasVerticalPanning() {\n const panningOptions = this.chart.options.chart.panning;\n return Boolean(panningOptions &&\n panningOptions.enabled && // #14624\n /y/.test(panningOptions.type));\n }\n /**\n * Update an axis object with a new set of options. The options are merged\n * with the existing options, so only new or altered options need to be\n * specified.\n *\n * @sample highcharts/members/axis-update/\n * Axis update demo\n *\n * @function Highcharts.Axis#update\n *\n * @param {Highcharts.AxisOptions} options\n * The new options that will be merged in with existing options on the axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n update(options, redraw) {\n const chart = this.chart;\n options = merge(this.userOptions, options);\n this.destroy(true);\n this.init(chart, options);\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n }\n /**\n * Remove the axis from the chart.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Axis#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart following the remove.\n */\n remove(redraw) {\n const chart = this.chart, coll = this.coll, axisSeries = this.series;\n let i = axisSeries.length;\n // Remove associated series (#2687)\n while (i--) {\n if (axisSeries[i]) {\n axisSeries[i].remove(false);\n }\n }\n // Remove the axis\n erase(chart.axes, this);\n erase(chart[coll] || [], this);\n chart.orderItems(coll);\n this.destroy();\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n }\n /**\n * Update the axis title by options after render time.\n *\n * @sample highcharts/members/axis-settitle/\n * Set a new Y axis title\n *\n * @function Highcharts.Axis#setTitle\n *\n * @param {Highcharts.AxisTitleOptions} titleOptions\n * The additional title options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after setting the title.\n */\n setTitle(titleOptions, redraw) {\n this.update({ title: titleOptions }, redraw);\n }\n /**\n * Set new axis categories and optionally redraw.\n *\n * @sample highcharts/members/axis-setcategories/\n * Set categories by click on a button\n *\n * @function Highcharts.Axis#setCategories\n *\n * @param {Array} categories\n * The new categories.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n */\n setCategories(categories, redraw) {\n this.update({ categories: categories }, redraw);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Axis.defaultOptions = AxisDefaults.defaultXAxisOptions;\n // Properties to survive after destroy, needed for Axis.update (#4317,\n // #5773, #5881).\n Axis.keepProps = [\n 'coll',\n 'extKey',\n 'hcEvents',\n 'names',\n 'series',\n 'userMax',\n 'userMin'\n ];\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for the path on the Axis to be calculated.\n * @interface Highcharts.AxisPlotLinePathOptionsObject\n */ /**\n * Axis value.\n * @name Highcharts.AxisPlotLinePathOptionsObject#value\n * @type {number|undefined}\n */ /**\n * Line width used for calculation crisp line coordinates. Defaults to 1.\n * @name Highcharts.AxisPlotLinePathOptionsObject#lineWidth\n * @type {number|undefined}\n */ /**\n * If `false`, the function will return null when it falls outside the axis\n * bounds. If `true`, the function will return a path aligned to the plot area\n * sides if it falls outside. If `pass`, it will return a path outside.\n * @name Highcharts.AxisPlotLinePathOptionsObject#force\n * @type {string|boolean|undefined}\n */ /**\n * Used in Highcharts Stock. When `true`, plot paths\n * (crosshair, plotLines, gridLines)\n * will be rendered on all axes when defined on the first axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#acrossPanes\n * @type {boolean|undefined}\n */ /**\n * Use old coordinates (for resizing and rescaling).\n * If not set, defaults to `false`.\n * @name Highcharts.AxisPlotLinePathOptionsObject#old\n * @type {boolean|undefined}\n */ /**\n * If given, return the plot line path of a pixel position on the axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#translatedValue\n * @type {number|undefined}\n */ /**\n * Used in Polar axes. Reverse the positions for concatenation of polygonal\n * plot bands\n * @name Highcharts.AxisPlotLinePathOptionsObject#reverse\n * @type {boolean|undefined}\n */\n /**\n * Options for crosshairs on axes.\n *\n * @product highstock\n *\n * @typedef {Highcharts.XAxisCrosshairOptions|Highcharts.YAxisCrosshairOptions} Highcharts.AxisCrosshairOptions\n */\n /**\n * @typedef {\"navigator\"|\"pan\"|\"rangeSelectorButton\"|\"rangeSelectorInput\"|\"scrollbar\"|\"traverseUpButton\"|\"zoom\"} Highcharts.AxisExtremesTriggerValue\n */\n /**\n * @callback Highcharts.AxisEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n */\n /**\n * @callback Highcharts.AxisLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} ctx\n *\n * @return {string}\n */\n /**\n * @interface Highcharts.AxisLabelsFormatterContextObject\n */ /**\n * The axis item of the label\n * @name Highcharts.AxisLabelsFormatterContextObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The chart instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#chart\n * @type {Highcharts.Chart}\n */ /**\n * Default formatting of date/time labels.\n * @name Highcharts.AxisLabelsFormatterContextObject#dateTimeLabelFormat\n * @type {string|undefined}\n */ /**\n * Whether the label belongs to the first tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isFirst\n * @type {boolean}\n */ /**\n * Whether the label belongs to the last tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isLast\n * @type {boolean}\n */ /**\n * The position on the axis in terms of axis values. For category axes, a\n * zero-based index. For datetime axes, the JavaScript time in milliseconds\n * since 1970.\n * @name Highcharts.AxisLabelsFormatterContextObject#pos\n * @type {number}\n */ /**\n * The preformatted text as the result of the default formatting. For example\n * dates will be formatted as strings, and numbers with language-specific comma\n * separators, thousands separators and numeric symbols like `k` or `M`.\n * @name Highcharts.AxisLabelsFormatterContextObject#text\n * @type {string|undefined}\n */ /**\n * The Tick instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#tick\n * @type {Highcharts.Tick}\n */ /**\n * This can be either a numeric value or a category string.\n * @name Highcharts.AxisLabelsFormatterContextObject#value\n * @type {number|string}\n */\n /**\n * Options for axes.\n *\n * @typedef {Highcharts.XAxisOptions|Highcharts.YAxisOptions|Highcharts.ZAxisOptions} Highcharts.AxisOptions\n */\n /**\n * @callback Highcharts.AxisPointBreakEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisPointBreakEventObject} evt\n */\n /**\n * @interface Highcharts.AxisPointBreakEventObject\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#brk\n * @type {Highcharts.Dictionary}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#point\n * @type {Highcharts.Point}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#type\n * @type {\"pointBreak\"|\"pointInBreak\"}\n */\n /**\n * @callback Highcharts.AxisSetExtremesEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisSetExtremesEventObject} evt\n */\n /**\n * @interface Highcharts.AxisSetExtremesEventObject\n * @extends Highcharts.ExtremesObject\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#trigger\n * @type {Highcharts.AxisExtremesTriggerValue|string}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#type\n * @type {\"setExtremes\"}\n */\n /**\n * @callback Highcharts.AxisTickPositionerCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @return {Highcharts.AxisTickPositionsArray}\n */\n /**\n * @interface Highcharts.AxisTickPositionsArray\n * @augments Array\n */\n /**\n * @typedef {\"high\"|\"low\"|\"middle\"} Highcharts.AxisTitleAlignValue\n */\n /**\n * @typedef {Highcharts.XAxisTitleOptions|Highcharts.YAxisTitleOptions|Highcharts.ZAxisTitleOptions} Highcharts.AxisTitleOptions\n */\n /**\n * @typedef {\"linear\"|\"logarithmic\"|\"datetime\"|\"category\"|\"treegrid\"} Highcharts.AxisTypeValue\n */\n /**\n * The returned object literal from the {@link Highcharts.Axis#getExtremes}\n * function.\n *\n * @interface Highcharts.ExtremesObject\n */ /**\n * The maximum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMax\n * @type {number}\n */ /**\n * The minimum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMin\n * @type {number}\n */ /**\n * The maximum axis value, either automatic or set manually. If the `max` option\n * is not set, `maxPadding` is 0 and `endOnTick` is false, this value will be\n * the same as `dataMax`.\n * @name Highcharts.ExtremesObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually. If the `min` option\n * is not set, `minPadding` is 0 and `startOnTick` is false, this value will be\n * the same as `dataMin`.\n * @name Highcharts.ExtremesObject#min\n * @type {number}\n */ /**\n * The user defined maximum, either from the `max` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMax\n * @type {number|undefined}\n */ /**\n * The user defined minimum, either from the `min` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMin\n * @type {number|undefined}\n */\n /**\n * Formatter function for the text of a crosshair label.\n *\n * @callback Highcharts.XAxisCrosshairLabelFormatterCallbackFunction\n *\n * @param {Highcharts.Axis} this\n * Axis context\n *\n * @param {number} value\n * Y value of the data point\n *\n * @return {string}\n */\n ''; // keeps doclets above in JS file\n\n return Axis;\n });\n _registerModule(_modules, 'Core/Axis/DateTimeAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, getMagnitude, normalizeTickInterval, timeUnits } = U;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DateTimeAxis;\n (function (DateTimeAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis class with date and time support.\n * @private\n */\n function compose(AxisClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('dateTime');\n const axisProto = AxisClass.prototype;\n axisProto.getTimeTicks = getTimeTicks;\n addEvent(AxisClass, 'init', onInit);\n }\n return AxisClass;\n }\n DateTimeAxis.compose = compose;\n /**\n * Set the tick positions to a time unit that makes sense, for example\n * on the first of each month or on every Monday. Return an array with\n * the time positions. Used in datetime axes as well as for grouping\n * data on a datetime axis.\n *\n * @private\n * @function Highcharts.Axis#getTimeTicks\n * @param {Highcharts.TimeNormalizeObject} normalizedInterval\n * The interval in axis values (ms) and thecount.\n * @param {number} min\n * The minimum in axis values.\n * @param {number} max\n * The maximum in axis values.\n */\n function getTimeTicks() {\n return this.chart.time.getTimeTicks.apply(this.chart.time, arguments);\n }\n /**\n * @private\n */\n function onInit(e) {\n const axis = this;\n const options = e.userOptions;\n if (options.type !== 'datetime') {\n axis.dateTime = void 0;\n return;\n }\n if (!axis.dateTime) {\n axis.dateTime = new Additions(axis);\n }\n }\n /* *\n *\n * Classes\n *\n * */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get a normalized tick interval for dates. Returns a configuration\n * object with unit range (interval), count and name. Used to prepare\n * data for `getTimeTicks`. Previously this logic was part of\n * getTimeTicks, but as `getTimeTicks` now runs of segments in stock\n * charts, the normalizing logic was extracted in order to prevent it\n * for running over again for each segment having the same interval.\n * #662, #697.\n * @private\n */\n normalizeTimeTickInterval(tickInterval, unitsOption) {\n const units = (unitsOption || [[\n // unit name\n 'millisecond',\n // allowed multiples\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500]\n ], [\n 'second',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'minute',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'hour',\n [1, 2, 3, 4, 6, 8, 12]\n ], [\n 'day',\n [1, 2]\n ], [\n 'week',\n [1, 2]\n ], [\n 'month',\n [1, 2, 3, 4, 6]\n ], [\n 'year',\n null\n ]]);\n let unit = units[units.length - 1], // default unit is years\n interval = timeUnits[unit[0]], multiples = unit[1], i;\n // loop through the units to find the one that best fits the\n // tickInterval\n for (i = 0; i < units.length; i++) {\n unit = units[i];\n interval = timeUnits[unit[0]];\n multiples = unit[1];\n if (units[i + 1]) {\n // lessThan is in the middle between the highest multiple\n // and the next unit.\n const lessThan = (interval *\n multiples[multiples.length - 1] +\n timeUnits[units[i + 1][0]]) / 2;\n // break and keep the current unit\n if (tickInterval <= lessThan) {\n break;\n }\n }\n }\n // prevent 2.5 years intervals, though 25, 250 etc. are allowed\n if (interval === timeUnits.year && tickInterval < 5 * interval) {\n multiples = [1, 2, 5];\n }\n // get the count\n const count = normalizeTickInterval(tickInterval / interval, multiples, unit[0] === 'year' ? // #1913, #2360\n Math.max(getMagnitude(tickInterval / interval), 1) :\n 1);\n return {\n unitRange: interval,\n count: count,\n unitName: unit[0]\n };\n }\n /**\n * Get the best date format for a specific X value based on the closest\n * point range on the axis.\n *\n * @private\n */\n getXDateFormat(x, dateTimeLabelFormats) {\n const { axis } = this, time = axis.chart.time;\n return axis.closestPointRange ?\n time.getDateFormat(axis.closestPointRange, x, axis.options.startOfWeek, dateTimeLabelFormats) ||\n // #2546, 2581\n time.resolveDTLFormat(dateTimeLabelFormats.year).main :\n time.resolveDTLFormat(dateTimeLabelFormats.day).main;\n }\n }\n DateTimeAxis.Additions = Additions;\n })(DateTimeAxis || (DateTimeAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return DateTimeAxis;\n });\n _registerModule(_modules, 'Core/Axis/LogarithmicAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, normalizeTickInterval, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n */\n var LogarithmicAxis;\n (function (LogarithmicAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Provides logarithmic support for axes.\n * @private\n */\n function compose(AxisClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('logarithmic');\n addEvent(AxisClass, 'init', onInit);\n addEvent(AxisClass, 'afterInit', onAfterInit);\n }\n return AxisClass;\n }\n LogarithmicAxis.compose = compose;\n /**\n * @private\n */\n function onInit(e) {\n const axis = this;\n const options = e.userOptions;\n let logarithmic = axis.logarithmic;\n if (options.type !== 'logarithmic') {\n axis.logarithmic = void 0;\n }\n else {\n if (!logarithmic) {\n logarithmic = axis.logarithmic = new Additions(axis);\n }\n }\n }\n /**\n * @private\n */\n function onAfterInit() {\n const axis = this;\n const log = axis.logarithmic;\n // extend logarithmic axis\n if (log) {\n axis.lin2val = function (num) {\n return log.lin2log(num);\n };\n axis.val2lin = function (num) {\n return log.log2lin(num);\n };\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Provides logarithmic support for axes.\n * @private\n * @class\n */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the tick positions of a logarithmic axis.\n */\n getLogTickPositions(interval, min, max, minor) {\n const log = this;\n const axis = log.axis;\n const axisLength = axis.len;\n const options = axis.options;\n // Since we use this method for both major and minor ticks,\n // use a local variable and return the result\n let positions = [];\n // Reset\n if (!minor) {\n log.minorAutoInterval = void 0;\n }\n // First case: All ticks fall on whole logarithms: 1, 10, 100 etc.\n if (interval >= 0.5) {\n interval = Math.round(interval);\n positions = axis.getLinearTickPositions(interval, min, max);\n // Second case: We need intermediary ticks. For example\n // 1, 2, 4, 6, 8, 10, 20, 40 etc.\n }\n else if (interval >= 0.08) {\n const roundedMin = Math.floor(min);\n let intermediate, i, j, len, pos, lastPos, break2;\n if (interval > 0.3) {\n intermediate = [1, 2, 4];\n // 0.2 equals five minor ticks per 1, 10, 100 etc\n }\n else if (interval > 0.15) {\n intermediate = [1, 2, 4, 6, 8];\n }\n else { // 0.1 equals ten minor ticks per 1, 10, 100 etc\n intermediate = [1, 2, 3, 4, 5, 6, 7, 8, 9];\n }\n for (i = roundedMin; i < max + 1 && !break2; i++) {\n len = intermediate.length;\n for (j = 0; j < len && !break2; j++) {\n pos = log.log2lin(log.lin2log(i) * intermediate[j]);\n // #1670, lastPos is #3113\n if (pos > min &&\n (!minor || lastPos <= max) &&\n typeof lastPos !== 'undefined') {\n positions.push(lastPos);\n }\n if (lastPos > max) {\n break2 = true;\n }\n lastPos = pos;\n }\n }\n // Third case: We are so deep in between whole logarithmic values,\n // that we might as well handle the tick positions like a linear\n // axis. For example 1.01, 1.02, 1.03, 1.04.\n }\n else {\n const realMin = log.lin2log(min), realMax = log.lin2log(max), tickIntervalOption = minor ?\n axis.getMinorTickInterval() :\n options.tickInterval, filteredTickIntervalOption = tickIntervalOption === 'auto' ?\n null :\n tickIntervalOption, tickPixelIntervalOption = options.tickPixelInterval / (minor ? 5 : 1), totalPixelLength = minor ?\n axisLength / axis.tickPositions.length :\n axisLength;\n interval = pick(filteredTickIntervalOption, log.minorAutoInterval, (realMax - realMin) *\n tickPixelIntervalOption / (totalPixelLength || 1));\n interval = normalizeTickInterval(interval);\n positions = axis.getLinearTickPositions(interval, realMin, realMax).map(log.log2lin);\n if (!minor) {\n log.minorAutoInterval = interval / 5;\n }\n }\n // Set the axis-level tickInterval variable\n if (!minor) {\n axis.tickInterval = interval;\n }\n return positions;\n }\n lin2log(num) {\n return Math.pow(10, num);\n }\n log2lin(num) {\n return Math.log(num) / Math.LN10;\n }\n }\n LogarithmicAxis.Additions = Additions;\n })(LogarithmicAxis || (LogarithmicAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LogarithmicAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { erase, extend, isNumber } = U;\n /* *\n *\n * Composition\n *\n * */\n var PlotLineOrBandAxis;\n (function (PlotLineOrBandAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let PlotLineOrBandClass;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add a plot band after render time.\n *\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#addPlotBand\n *\n * @param {Highcharts.AxisPlotBandsOptions} options\n * A configuration object for the plot band, as defined in\n * [xAxis.plotBands](https://api.highcharts.com/highcharts/xAxis.plotBands).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot band.\n */\n function addPlotBand(options) {\n return this.addPlotBandOrLine(options, 'plotBands');\n }\n /**\n * Add a plot band or plot line after render time. Called from\n * addPlotBand and addPlotLine internally.\n *\n * @private\n * @function Highcharts.Axis#addPlotBandOrLine\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n */\n function addPlotBandOrLine(options, coll) {\n const userOptions = this.userOptions;\n let obj = new PlotLineOrBandClass(this, options);\n if (this.visible) {\n obj = obj.render();\n }\n if (obj) { // #2189\n if (!this._addedPlotLB) {\n this._addedPlotLB = true;\n (userOptions.plotLines || [])\n .concat(userOptions.plotBands || [])\n .forEach((plotLineOptions) => {\n this.addPlotBandOrLine(plotLineOptions);\n });\n }\n // Add it to the user options for exporting and Axis.update\n if (coll) {\n // Workaround Microsoft/TypeScript issue #32693\n const updatedOptions = (userOptions[coll] || []);\n updatedOptions.push(options);\n userOptions[coll] = updatedOptions;\n }\n this.plotLinesAndBands.push(obj);\n }\n return obj;\n }\n /**\n * Add a plot line after render time.\n *\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#addPlotLine\n *\n * @param {Highcharts.AxisPlotLinesOptions} options\n * A configuration object for the plot line, as defined in\n * [xAxis.plotLines](https://api.highcharts.com/highcharts/xAxis.plotLines).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot line.\n */\n function addPlotLine(options) {\n return this.addPlotBandOrLine(options, 'plotLines');\n }\n /**\n * @private\n */\n function compose(PlotLineOrBandType, AxisClass) {\n if (!PlotLineOrBandClass) {\n PlotLineOrBandClass = PlotLineOrBandType;\n }\n if (U.pushUnique(composedMembers, AxisClass)) {\n extend(AxisClass.prototype, {\n addPlotBand,\n addPlotLine,\n addPlotBandOrLine,\n getPlotBandPath,\n removePlotBand,\n removePlotLine,\n removePlotBandOrLine\n });\n }\n return AxisClass;\n }\n PlotLineOrBandAxis.compose = compose;\n /**\n * Internal function to create the SVG path definition for a plot band.\n *\n * @function Highcharts.Axis#getPlotBandPath\n *\n * @param {number} from\n * The axis value to start from.\n *\n * @param {number} to\n * The axis value to end on.\n *\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n function getPlotBandPath(from, to, options = this.options) {\n const toPath = this.getPlotLinePath({\n value: to,\n force: true,\n acrossPanes: options.acrossPanes\n }), result = [], horiz = this.horiz, outside = !isNumber(this.min) ||\n !isNumber(this.max) ||\n (from < this.min && to < this.min) ||\n (from > this.max && to > this.max);\n let path = this.getPlotLinePath({\n value: from,\n force: true,\n acrossPanes: options.acrossPanes\n }), i, \n // #4964 check if chart is inverted or plotband is on yAxis\n plus = 1, isFlat;\n if (path && toPath) {\n // Flat paths don't need labels (#3836)\n if (outside) {\n isFlat = path.toString() === toPath.toString();\n plus = 0;\n }\n // Go over each subpath - for panes in Highcharts Stock\n for (i = 0; i < path.length; i += 2) {\n const pathStart = path[i], pathEnd = path[i + 1], toPathStart = toPath[i], toPathEnd = toPath[i + 1];\n // Type checking all affected path segments. Consider\n // something smarter.\n if ((pathStart[0] === 'M' || pathStart[0] === 'L') &&\n (pathEnd[0] === 'M' || pathEnd[0] === 'L') &&\n (toPathStart[0] === 'M' || toPathStart[0] === 'L') &&\n (toPathEnd[0] === 'M' || toPathEnd[0] === 'L')) {\n // Add 1 pixel when coordinates are the same\n if (horiz && toPathStart[1] === pathStart[1]) {\n toPathStart[1] += plus;\n toPathEnd[1] += plus;\n }\n else if (!horiz && toPathStart[2] === pathStart[2]) {\n toPathStart[2] += plus;\n toPathEnd[2] += plus;\n }\n result.push(['M', pathStart[1], pathStart[2]], ['L', pathEnd[1], pathEnd[2]], ['L', toPathEnd[1], toPathEnd[2]], ['L', toPathStart[1], toPathStart[2]], ['Z']);\n }\n result.isFlat = isFlat;\n }\n }\n else { // outside the axis area\n path = null;\n }\n return result;\n }\n /**\n * Remove a plot band by its id.\n *\n * @sample highcharts/members/axis-removeplotband/\n * Remove plot band by id\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#removePlotBand\n *\n * @param {string} id\n * The plot band's `id` as given in the original configuration\n * object or in the `addPlotBand` option.\n */\n function removePlotBand(id) {\n this.removePlotBandOrLine(id);\n }\n /**\n * Remove a plot band or plot line from the chart by id. Called\n * internally from `removePlotBand` and `removePlotLine`.\n * @private\n * @function Highcharts.Axis#removePlotBandOrLine\n */\n function removePlotBandOrLine(id) {\n const plotLinesAndBands = this.plotLinesAndBands, options = this.options, userOptions = this.userOptions;\n if (plotLinesAndBands) { // #15639\n let i = plotLinesAndBands.length;\n while (i--) {\n if (plotLinesAndBands[i].id === id) {\n plotLinesAndBands[i].destroy();\n }\n }\n ([\n options.plotLines || [],\n userOptions.plotLines || [],\n options.plotBands || [],\n userOptions.plotBands || []\n ]).forEach(function (arr) {\n i = arr.length;\n while (i--) {\n if ((arr[i] || {}).id === id) {\n erase(arr, arr[i]);\n }\n }\n });\n }\n }\n /**\n * Remove a plot line by its id.\n *\n * @sample highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#removePlotLine\n *\n * @param {string} id\n * The plot line's `id` as given in the original configuration\n * object or in the `addPlotLine` option.\n */\n function removePlotLine(id) {\n this.removePlotBandOrLine(id);\n }\n })(PlotLineOrBandAxis || (PlotLineOrBandAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return PlotLineOrBandAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBand.js', [_modules['Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js'], _modules['Core/Utilities.js']], function (PlotLineOrBandAxis, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { arrayMax, arrayMin, defined, destroyObjectProperties, erase, fireEvent, merge, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The object wrapper for plot lines and plot bands\n *\n * @class\n * @name Highcharts.PlotLineOrBand\n *\n * @param {Highcharts.Axis} axis\n * Related axis.\n *\n * @param {Highcharts.AxisPlotLinesOptions|Highcharts.AxisPlotBandsOptions} [options]\n * Options to use.\n */\n class PlotLineOrBand {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AxisClass) {\n return PlotLineOrBandAxis.compose(PlotLineOrBand, AxisClass);\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(axis, options) {\n this.axis = axis;\n if (options) {\n this.options = options;\n this.id = options.id;\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Render the plot line or plot band. If it is already existing,\n * move it.\n * @private\n * @function Highcharts.PlotLineOrBand#render\n */\n render() {\n fireEvent(this, 'render');\n const plotLine = this, axis = plotLine.axis, horiz = axis.horiz, log = axis.logarithmic, options = plotLine.options, color = options.color, zIndex = pick(options.zIndex, 0), events = options.events, groupAttribs = {}, renderer = axis.chart.renderer;\n let optionsLabel = options.label, label = plotLine.label, to = options.to, from = options.from, value = options.value, svgElem = plotLine.svgElem, path = [], group;\n const isBand = defined(from) && defined(to), isLine = defined(value), isNew = !svgElem, attribs = {\n 'class': 'highcharts-plot-' + (isBand ? 'band ' : 'line ') +\n (options.className || '')\n };\n let groupName = isBand ? 'bands' : 'lines';\n // logarithmic conversion\n if (log) {\n from = log.log2lin(from);\n to = log.log2lin(to);\n value = log.log2lin(value);\n }\n // Set the presentational attributes\n if (!axis.chart.styledMode) {\n if (isLine) {\n attribs.stroke = color || \"#999999\" /* Palette.neutralColor40 */;\n attribs['stroke-width'] = pick(options.width, 1);\n if (options.dashStyle) {\n attribs.dashstyle =\n options.dashStyle;\n }\n }\n else if (isBand) { // plot band\n attribs.fill = color || \"#e6e9ff\" /* Palette.highlightColor10 */;\n if (options.borderWidth) {\n attribs.stroke = options.borderColor;\n attribs['stroke-width'] = options.borderWidth;\n }\n }\n }\n // Grouping and zIndex\n groupAttribs.zIndex = zIndex;\n groupName += '-' + zIndex;\n group = axis.plotLinesAndBandsGroups[groupName];\n if (!group) {\n axis.plotLinesAndBandsGroups[groupName] = group =\n renderer.g('plot-' + groupName)\n .attr(groupAttribs).add();\n }\n // Create the path\n if (isNew) {\n /**\n * SVG element of the plot line or band.\n *\n * @name Highcharts.PlotLineOrBand#svgElem\n * @type {Highcharts.SVGElement}\n */\n plotLine.svgElem = svgElem = renderer\n .path()\n .attr(attribs)\n .add(group);\n }\n // Set the path or return\n if (isLine) {\n path = axis.getPlotLinePath({\n value: value,\n lineWidth: svgElem.strokeWidth(),\n acrossPanes: options.acrossPanes\n });\n }\n else if (isBand) { // plot band\n path = axis.getPlotBandPath(from, to, options);\n }\n else {\n return;\n }\n // common for lines and bands\n // Add events only if they were not added before.\n if (!plotLine.eventsAdded && events) {\n objectEach(events, function (event, eventType) {\n svgElem.on(eventType, function (e) {\n events[eventType].apply(plotLine, [e]);\n });\n });\n plotLine.eventsAdded = true;\n }\n if ((isNew || !svgElem.d) && path && path.length) {\n svgElem.attr({ d: path });\n }\n else if (svgElem) {\n if (path) {\n svgElem.show();\n svgElem.animate({ d: path });\n }\n else if (svgElem.d) {\n svgElem.hide();\n if (label) {\n plotLine.label = label = label.destroy();\n }\n }\n }\n // the plot band/line label\n if (optionsLabel &&\n (defined(optionsLabel.text) || defined(optionsLabel.formatter)) &&\n path &&\n path.length &&\n axis.width > 0 &&\n axis.height > 0 &&\n !path.isFlat) {\n // apply defaults\n optionsLabel = merge({\n align: horiz && isBand && 'center',\n x: horiz ? !isBand && 4 : 10,\n verticalAlign: !horiz && isBand && 'middle',\n y: horiz ? isBand ? 16 : 10 : isBand ? 6 : -4,\n rotation: horiz && !isBand && 90\n }, optionsLabel);\n this.renderLabel(optionsLabel, path, isBand, zIndex);\n }\n else if (label) { // move out of sight\n label.hide();\n }\n // chainable\n return plotLine;\n }\n /**\n * Render and align label for plot line or band.\n * @private\n * @function Highcharts.PlotLineOrBand#renderLabel\n */\n renderLabel(optionsLabel, path, isBand, zIndex) {\n const plotLine = this, axis = plotLine.axis, renderer = axis.chart.renderer;\n let label = plotLine.label;\n // add the SVG element\n if (!label) {\n /**\n * SVG element of the label.\n *\n * @name Highcharts.PlotLineOrBand#label\n * @type {Highcharts.SVGElement}\n */\n plotLine.label = label = renderer\n .text(this.getLabelText(optionsLabel), 0, 0, optionsLabel.useHTML)\n .attr({\n align: optionsLabel.textAlign || optionsLabel.align,\n rotation: optionsLabel.rotation,\n 'class': 'highcharts-plot-' + (isBand ? 'band' : 'line') +\n '-label ' + (optionsLabel.className || ''),\n zIndex\n })\n .add();\n if (!axis.chart.styledMode) {\n label.css(merge({\n fontSize: '0.8em',\n textOverflow: 'ellipsis'\n }, optionsLabel.style));\n }\n }\n // get the bounding box and align the label\n // #3000 changed to better handle choice between plotband or plotline\n const xBounds = path.xBounds ||\n [path[0][1], path[1][1], (isBand ? path[2][1] : path[0][1])];\n const yBounds = path.yBounds ||\n [path[0][2], path[1][2], (isBand ? path[2][2] : path[0][2])];\n const x = arrayMin(xBounds);\n const y = arrayMin(yBounds);\n label.align(optionsLabel, false, {\n x,\n y,\n width: arrayMax(xBounds) - x,\n height: arrayMax(yBounds) - y\n });\n if (!label.alignValue || label.alignValue === 'left') {\n const width = optionsLabel.clip ?\n axis.width : axis.chart.chartWidth;\n label.css({\n width: (label.rotation === 90 ?\n axis.height - (label.alignAttr.y - axis.top) :\n width - (label.alignAttr.x - axis.left)) + 'px'\n });\n }\n label.show(true);\n }\n /**\n * Get label's text content.\n * @private\n * @function Highcharts.PlotLineOrBand#getLabelText\n */\n getLabelText(optionsLabel) {\n return defined(optionsLabel.formatter) ?\n optionsLabel.formatter\n .call(this) :\n optionsLabel.text;\n }\n /**\n * Remove the plot line or band.\n *\n * @function Highcharts.PlotLineOrBand#destroy\n */\n destroy() {\n // remove it from the lookup\n erase(this.axis.plotLinesAndBands, this);\n delete this.axis;\n destroyObjectProperties(this);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Options for plot bands on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsOptions|Highcharts.YAxisPlotBandsOptions|Highcharts.ZAxisPlotBandsOptions} Highcharts.AxisPlotBandsOptions\n */\n /**\n * Options for plot band labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsLabelOptions|Highcharts.YAxisPlotBandsLabelOptions|Highcharts.ZAxisPlotBandsLabelOptions} Highcharts.AxisPlotBandsLabelOptions\n */\n /**\n * Options for plot lines on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesOptions|Highcharts.YAxisPlotLinesOptions|Highcharts.ZAxisPlotLinesOptions} Highcharts.AxisPlotLinesOptions\n */\n /**\n * Options for plot line labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesLabelOptions|Highcharts.YAxisPlotLinesLabelOptions|Highcharts.ZAxisPlotLinesLabelOptions} Highcharts.AxisPlotLinesLabelOptions\n */\n ('');\n /* *\n *\n * API Options\n *\n * */\n /**\n * An array of colored bands stretching across the plot area marking an\n * interval on the axis.\n *\n * In styled mode, the plot bands are styled by the `.highcharts-plot-band`\n * class in addition to the `className` option.\n *\n * @productdesc {highcharts}\n * In a gauge, a plot band on the Y axis (value axis) will stretch along the\n * perimeter of the gauge.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands\n */\n /**\n * Flag to decide if plotBand should be rendered across all panes.\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotBands.acrossPanes\n */\n /**\n * Border color for the plot band. Also requires `borderWidth` to be set.\n *\n * @type {Highcharts.ColorString}\n * @apioption xAxis.plotBands.borderColor\n */\n /**\n * Border width for the plot band. Also requires `borderColor` to be set.\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.plotBands.borderWidth\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-band`,\n * to apply to each individual band.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotBands.className\n */\n /**\n * The color of the plot band.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Color band\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #e6e9ff\n * @apioption xAxis.plotBands.color\n */\n /**\n * An object defining mouse events for the plot band. Supported properties\n * are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotBands.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseover\n */\n /**\n * The start position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.from\n */\n /**\n * An id used for identifying the plot band in Axis.removePlotBand.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n * @sample {highstock} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n *\n * @type {string}\n * @apioption xAxis.plotBands.id\n */\n /**\n * The end position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.to\n */\n /**\n * The z index of the plot band within the chart, relative to other\n * elements. Using the same z index as another element may give\n * unpredictable results, as the last rendered element will be on top.\n * Values from 0 to 20 make sense.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex-above-series/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotBands.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @since 2.1\n * @apioption xAxis.plotBands.label.align\n */\n /**\n * Rotation of the text label in degrees .\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @apioption xAxis.plotBands.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-band-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotBands.label.style\n */\n /**\n * The string text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotBands.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotBands.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotBands.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot band. Can be one of\n * \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-verticalalign/\n * Vertically centered label\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @since 2.1\n * @apioption xAxis.plotBands.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-y/\n * Label on x axis\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.y\n */\n /**\n * An array of lines stretching across the plot area, marking a specific\n * value on one of the axes.\n *\n * In styled mode, the plot lines are styled by the\n * `.highcharts-plot-line` class in addition to the `className` option.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Basic plot line\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge plot line\n * @apioption xAxis.plotLines\n */\n /**\n * Flag to decide if plotLine should be rendered across all panes.\n *\n * @sample {highstock} stock/xaxis/plotlines-acrosspanes/\n * Plot lines on different panes\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotLines.acrossPanes\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-line`,\n * to apply to each individual line.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotLines.className\n */\n /**\n * The color of the line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * A red line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.ColorString}\n * @default #999999\n * @apioption xAxis.plotLines.color\n */\n /**\n * The dashing or dot style for the plot line. For possible values see\n * [this overview](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-dashstyle/\n * Dash and dot pattern\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 1.2\n * @apioption xAxis.plotLines.dashStyle\n */\n /**\n * An object defining mouse events for the plot line. Supported\n * properties are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotLines.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseover\n */\n /**\n * An id used for identifying the plot line in Axis.removePlotLine.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n *\n * @type {string}\n * @apioption xAxis.plotLines.id\n */\n /**\n * The position of the line in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Between two categories on X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotLines.value\n */\n /**\n * The width or thickness of the plot line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * 2px wide line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @default 2\n * @apioption xAxis.plotLines.width\n */\n /**\n * The z index of the plot line within the chart.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-behind/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above-all/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotLines.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @apioption xAxis.plotLines.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.AlignValue}\n * @default left\n * @since 2.1\n * @apioption xAxis.plotLines.label.align\n */\n /**\n * Whether to hide labels that are outside the plot area.\n *\n * @type {boolean}\n * @default false\n * @since 10.3.3\n * @apioption xAxis.plotLines.labels.clip\n */\n /**\n * Callback JavaScript function to format the label. Useful properties like\n * the value of plot line or the range of plot band (`from` & `to`\n * properties) can be found in `this.options` object.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-plotbands-label-formatter\n * Label formatters for plot line and plot band.\n * @type {Highcharts.FormatterCallbackFunction}\n * @apioption xAxis.plotLines.label.formatter\n */\n /**\n * Rotation of the text label in degrees. Defaults to 0 for horizontal plot\n * lines and 90 for vertical lines.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Slanted text\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-line-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotLines.label.style\n */\n /**\n * The text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotLines.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-textalign/\n * Text label in bottom position\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotLines.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotLines.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot line. Can be\n * one of \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Vertically centered label\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default {highcharts} top\n * @default {highstock} top\n * @since 2.1\n * @apioption xAxis.plotLines.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-y/\n * Label below the plot line\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.y\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotBands\n * @apioption yAxis.plotBands\n */\n /**\n * In a gauge chart, this option determines the inner radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n * By default, the inner radius is controlled by the [thickness](\n * #yAxis.plotBands.thickness) option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.innerRadius\n */\n /**\n * In a gauge chart, this option determines the outer radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 100%\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.outerRadius\n */\n /**\n * In a gauge chart, this option sets the width of the plot band\n * stretching along the perimeter. It can be given as a percentage\n * string, like `\"10%\"`, or as a pixel number, like `10`. The default\n * value 10 is the same as the default [tickLength](#yAxis.tickLength),\n * thus making the plot band act as a background for the tick markers.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 10\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.thickness\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotLines\n * @apioption yAxis.plotLines\n */\n (''); // keeps doclets above in JS file\n\n return PlotLineOrBand;\n });\n _registerModule(_modules, 'Core/Tooltip.js', [_modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (F, H, R, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = F;\n const { doc, isSafari } = H;\n const { distribute } = R;\n const { addEvent, clamp, css, discardElement, extend, fireEvent, isArray, isNumber, isString, merge, pick, splat, syncTimeout } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Tooltip of a chart.\n *\n * @class\n * @name Highcharts.Tooltip\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n class Tooltip {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allowShared = true;\n this.container = void 0;\n this.crosshairs = [];\n this.distance = 0;\n this.isHidden = true;\n this.isSticky = false;\n this.now = {};\n this.options = {};\n this.outside = false;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Build the body (lines) of the tooltip by iterating over the items and\n * returning one entry for each item, abstracting this functionality allows\n * to easily overwrite and extend it.\n *\n * @private\n * @function Highcharts.Tooltip#bodyFormatter\n */\n bodyFormatter(items) {\n return items.map(function (item) {\n const tooltipOptions = item.series.tooltipOptions;\n return (tooltipOptions[(item.point.formatPrefix || 'point') + 'Formatter'] ||\n item.point.tooltipFormatter).call(item.point, tooltipOptions[(item.point.formatPrefix || 'point') + 'Format'] || '');\n });\n }\n /**\n * Destroy the single tooltips in a split tooltip.\n * If the tooltip is active then it is not destroyed, unless forced to.\n *\n * @private\n * @function Highcharts.Tooltip#cleanSplit\n *\n * @param {boolean} [force]\n * Force destroy all tooltips.\n */\n cleanSplit(force) {\n this.chart.series.forEach(function (series) {\n const tt = series && series.tt;\n if (tt) {\n if (!tt.isActive || force) {\n series.tt = tt.destroy();\n }\n else {\n tt.isActive = false;\n }\n }\n });\n }\n /**\n * In case no user defined formatter is given, this will be used. Note that\n * the context here is an object holding point, series, x, y etc.\n *\n * @function Highcharts.Tooltip#defaultFormatter\n *\n * @param {Highcharts.Tooltip} tooltip\n *\n * @return {string|Array}\n * Returns a string (single tooltip and shared)\n * or an array of strings (split tooltip)\n */\n defaultFormatter(tooltip) {\n const items = this.points || splat(this);\n let s;\n // Build the header\n s = [tooltip.tooltipFooterHeaderFormatter(items[0])];\n // build the values\n s = s.concat(tooltip.bodyFormatter(items));\n // footer\n s.push(tooltip.tooltipFooterHeaderFormatter(items[0], true));\n return s;\n }\n /**\n * Removes and destroys the tooltip and its elements.\n *\n * @function Highcharts.Tooltip#destroy\n */\n destroy() {\n // Destroy and clear local variables\n if (this.label) {\n this.label = this.label.destroy();\n }\n if (this.split) {\n this.cleanSplit(true);\n if (this.tt) {\n this.tt = this.tt.destroy();\n }\n }\n if (this.renderer) {\n this.renderer = this.renderer.destroy();\n discardElement(this.container);\n }\n U.clearTimeout(this.hideTimer);\n U.clearTimeout(this.tooltipTimeout);\n }\n /**\n * Extendable method to get the anchor position of the tooltip\n * from a point or set of points\n *\n * @private\n * @function Highcharts.Tooltip#getAnchor\n */\n getAnchor(points, mouseEvent) {\n const chart = this.chart, pointer = chart.pointer, inverted = chart.inverted, plotTop = chart.plotTop, plotLeft = chart.plotLeft;\n let ret;\n points = splat(points);\n // If reversedStacks are false the tooltip position should be taken from\n // the last point (#17948)\n if (points[0].series &&\n points[0].series.yAxis &&\n !points[0].series.yAxis.options.reversedStacks) {\n points = points.slice().reverse();\n }\n // When tooltip follows mouse, relate the position to the mouse\n if (this.followPointer && mouseEvent) {\n if (typeof mouseEvent.chartX === 'undefined') {\n mouseEvent = pointer.normalize(mouseEvent);\n }\n ret = [\n mouseEvent.chartX - plotLeft,\n mouseEvent.chartY - plotTop\n ];\n // Some series types use a specificly calculated tooltip position for\n // each point\n }\n else if (points[0].tooltipPos) {\n ret = points[0].tooltipPos;\n // Calculate the average position and adjust for axis positions\n }\n else {\n let chartX = 0, chartY = 0;\n points.forEach(function (point) {\n const pos = point.pos(true);\n if (pos) {\n chartX += pos[0];\n chartY += pos[1];\n }\n });\n chartX /= points.length;\n chartY /= points.length;\n // When shared, place the tooltip next to the mouse (#424)\n if (this.shared && points.length > 1 && mouseEvent) {\n if (inverted) {\n chartX = mouseEvent.chartX;\n }\n else {\n chartY = mouseEvent.chartY;\n }\n }\n // Use the average position for multiple points\n ret = [chartX - plotLeft, chartY - plotTop];\n }\n return ret.map(Math.round);\n }\n /**\n * Get the CSS class names for the tooltip's label. Styles the label\n * by `colorIndex` or user-defined CSS.\n *\n * @function Highcharts.Tooltip#getClassName\n *\n * @return {string}\n * The class names.\n */\n getClassName(point, isSplit, isHeader) {\n const options = this.options, series = point.series, seriesOptions = series.options;\n return [\n options.className,\n 'highcharts-label',\n isHeader && 'highcharts-tooltip-header',\n isSplit ? 'highcharts-tooltip-box' : 'highcharts-tooltip',\n !isHeader && 'highcharts-color-' + pick(point.colorIndex, series.colorIndex),\n (seriesOptions && seriesOptions.className)\n ].filter(isString).join(' ');\n }\n /**\n * Creates the Tooltip label element if it does not exist, then returns it.\n *\n * @function Highcharts.Tooltip#getLabel\n *\n * @return {Highcharts.SVGElement}\n * Tooltip label\n */\n getLabel() {\n const tooltip = this, styledMode = this.chart.styledMode, options = this.options, doSplit = this.split && this.allowShared, pointerEvents = (options.style.pointerEvents ||\n (this.shouldStickOnContact() ? 'auto' : 'none'));\n let container, renderer = this.chart.renderer;\n // If changing from a split tooltip to a non-split tooltip, we must\n // destroy it in order to get the SVG right. #13868.\n if (this.label) {\n const wasSplit = !this.label.hasClass('highcharts-label');\n if ((!doSplit && wasSplit) || (doSplit && !wasSplit)) {\n this.destroy();\n }\n }\n if (!this.label) {\n if (this.outside) {\n const chartStyle = this.chart.options.chart.style, Renderer = RendererRegistry.getRendererType();\n /**\n * Reference to the tooltip's container, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#container\n * @type {Highcharts.HTMLDOMElement|undefined}\n */\n this.container = container = H.doc.createElement('div');\n container.className = 'highcharts-tooltip-container';\n css(container, {\n position: 'absolute',\n top: '1px',\n pointerEvents,\n zIndex: Math.max(this.options.style.zIndex || 0, (chartStyle && chartStyle.zIndex || 0) + 3)\n });\n H.doc.body.appendChild(container);\n /**\n * Reference to the tooltip's renderer, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#renderer\n * @type {Highcharts.SVGRenderer|undefined}\n */\n this.renderer = renderer = new Renderer(container, 0, 0, chartStyle, void 0, void 0, renderer.styledMode);\n }\n // Create the label\n if (doSplit) {\n this.label = renderer.g('tooltip');\n }\n else {\n this.label = renderer\n .label('', 0, 0, options.shape, void 0, void 0, options.useHTML, void 0, 'tooltip')\n .attr({\n padding: options.padding,\n r: options.borderRadius\n });\n if (!styledMode) {\n this.label\n .attr({\n fill: options.backgroundColor,\n 'stroke-width': options.borderWidth || 0\n })\n // #2301, #2657\n .css(options.style)\n .css({ pointerEvents });\n }\n }\n // Split tooltip use updateTooltipContainer to position the tooltip\n // container.\n if (tooltip.outside) {\n const label = this.label;\n const { xSetter, ySetter } = label;\n label.xSetter = function (value) {\n xSetter.call(label, tooltip.distance);\n container.style.left = value + 'px';\n };\n label.ySetter = function (value) {\n ySetter.call(label, tooltip.distance);\n container.style.top = value + 'px';\n };\n }\n this.label\n .attr({ zIndex: 8 })\n .shadow(options.shadow)\n .add();\n }\n return this.label;\n }\n /**\n * Get the total area available area to place the tooltip\n *\n * @private\n */\n getPlayingField() {\n const { body, documentElement } = doc, { chart, distance, outside } = this;\n return {\n width: outside ?\n // Substract distance to prevent scrollbars\n Math.max(body.scrollWidth, documentElement.scrollWidth, body.offsetWidth, documentElement.offsetWidth, documentElement.clientWidth) - 2 * distance :\n chart.chartWidth,\n height: outside ?\n Math.max(body.scrollHeight, documentElement.scrollHeight, body.offsetHeight, documentElement.offsetHeight, documentElement.clientHeight) :\n chart.chartHeight\n };\n }\n /**\n * Place the tooltip in a chart without spilling over and not covering the\n * point itself.\n *\n * @function Highcharts.Tooltip#getPosition\n *\n * @param {number} boxWidth\n * Width of the tooltip box.\n *\n * @param {number} boxHeight\n * Height of the tooltip box.\n *\n * @param {Highcharts.Point} point\n * Tooltip related point.\n *\n * @return {Highcharts.PositionObject}\n * Recommended position of the tooltip.\n */\n getPosition(boxWidth, boxHeight, point) {\n const chart = this.chart, distance = this.distance, ret = {}, \n // Don't use h if chart isn't inverted (#7242) ???\n h = (chart.inverted && point.h) || 0, // #4117 ???\n outside = this.outside, playingField = this.getPlayingField(), outerWidth = playingField.width, outerHeight = playingField.height, chartPosition = chart.pointer.getChartPosition(), scaleX = (val) => ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleX), scaleY = (val) => ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleY), \n // Build parameter arrays for firstDimension()/secondDimension()\n buildDimensionArray = (dim) => {\n const isX = dim === 'x';\n return [\n dim,\n isX ? outerWidth : outerHeight,\n isX ? boxWidth : boxHeight\n ].concat(outside ? [\n // If we are using tooltip.outside, we need to scale the\n // position to match scaling of the container in case there\n // is a transform/zoom on the container. #11329\n isX ? scaleX(boxWidth) : scaleY(boxHeight),\n isX ? chartPosition.left - distance +\n scaleX(point.plotX + chart.plotLeft) :\n chartPosition.top - distance +\n scaleY(point.plotY + chart.plotTop),\n 0,\n isX ? outerWidth : outerHeight\n ] : [\n // Not outside, no scaling is needed\n isX ? boxWidth : boxHeight,\n isX ? point.plotX + chart.plotLeft :\n point.plotY + chart.plotTop,\n isX ? chart.plotLeft : chart.plotTop,\n isX ? chart.plotLeft + chart.plotWidth :\n chart.plotTop + chart.plotHeight\n ]);\n };\n let first = buildDimensionArray('y'), second = buildDimensionArray('x'), swapped;\n // Handle negative points or reversed axis (#13780)\n let flipped = !!point.negative;\n if (!chart.polar &&\n chart.hoverSeries &&\n chart.hoverSeries.yAxis &&\n chart.hoverSeries.yAxis.reversed) {\n flipped = !flipped;\n }\n // The far side is right or bottom\n const preferFarSide = !this.followPointer &&\n pick(point.ttBelow, !chart.inverted === flipped), // #4984\n /*\n * Handle the preferred dimension. When the preferred dimension is\n * tooltip on top or bottom of the point, it will look for space\n * there.\n *\n * @private\n */\n firstDimension = function (dim, outerSize, innerSize, scaledInnerSize, // #11329\n point, min, max) {\n const scaledDist = outside ?\n (dim === 'y' ? scaleY(distance) : scaleX(distance)) :\n distance, scaleDiff = (innerSize - scaledInnerSize) / 2, roomLeft = scaledInnerSize < point - distance, roomRight = point + distance + scaledInnerSize < outerSize, alignedLeft = point - scaledDist - innerSize + scaleDiff, alignedRight = point + scaledDist - scaleDiff;\n if (preferFarSide && roomRight) {\n ret[dim] = alignedRight;\n }\n else if (!preferFarSide && roomLeft) {\n ret[dim] = alignedLeft;\n }\n else if (roomLeft) {\n ret[dim] = Math.min(max - scaledInnerSize, alignedLeft - h < 0 ? alignedLeft : alignedLeft - h);\n }\n else if (roomRight) {\n ret[dim] = Math.max(min, alignedRight + h + innerSize > outerSize ?\n alignedRight :\n alignedRight + h);\n }\n else {\n return false;\n }\n }, \n /*\n * Handle the secondary dimension. If the preferred dimension is\n * tooltip on top or bottom of the point, the second dimension is to\n * align the tooltip above the point, trying to align center but\n * allowing left or right align within the chart box.\n *\n * @private\n */\n secondDimension = function (dim, outerSize, innerSize, scaledInnerSize, // #11329\n point) {\n let retVal;\n // Too close to the edge, return false and swap dimensions\n if (point < distance || point > outerSize - distance) {\n retVal = false;\n // Align left/top\n }\n else if (point < innerSize / 2) {\n ret[dim] = 1;\n // Align right/bottom\n }\n else if (point > outerSize - scaledInnerSize / 2) {\n ret[dim] = outerSize - scaledInnerSize - 2;\n // Align center\n }\n else {\n ret[dim] = point - innerSize / 2;\n }\n return retVal;\n }, \n /*\n * Swap the dimensions\n */\n swap = function (count) {\n const temp = first;\n first = second;\n second = temp;\n swapped = count;\n }, run = function () {\n if (firstDimension.apply(0, first) !== false) {\n if (secondDimension.apply(0, second) === false &&\n !swapped) {\n swap(true);\n run();\n }\n }\n else if (!swapped) {\n swap(true);\n run();\n }\n else {\n ret.x = ret.y = 0;\n }\n };\n // Under these conditions, prefer the tooltip on the side of the point\n if (chart.inverted || this.len > 1) {\n swap();\n }\n run();\n return ret;\n }\n /**\n * Hides the tooltip with a fade out animation.\n *\n * @function Highcharts.Tooltip#hide\n *\n * @param {number} [delay]\n * The fade out in milliseconds. If no value is provided the value\n * of the tooltip.hideDelay option is used. A value of 0 disables\n * the fade out animation.\n */\n hide(delay) {\n const tooltip = this;\n // disallow duplicate timers (#1728, #1766)\n U.clearTimeout(this.hideTimer);\n delay = pick(delay, this.options.hideDelay);\n if (!this.isHidden) {\n this.hideTimer = syncTimeout(function () {\n // If there is a delay, do fadeOut with the default duration. If\n // the hideDelay is 0, we assume no animation is wanted, so we\n // pass 0 duration. #12994.\n tooltip.getLabel().fadeOut(delay ? void 0 : delay);\n tooltip.isHidden = true;\n }, delay);\n }\n }\n /**\n * Initialize tooltip.\n *\n * @private\n * @function Highcharts.Tooltip#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n init(chart, options) {\n /**\n * Chart of the tooltip.\n *\n * @readonly\n * @name Highcharts.Tooltip#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n /**\n * Used tooltip options.\n *\n * @readonly\n * @name Highcharts.Tooltip#options\n * @type {Highcharts.TooltipOptions}\n */\n this.options = options;\n /**\n * List of crosshairs.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#crosshairs\n * @type {Array}\n */\n this.crosshairs = [];\n /**\n * Current values of x and y when animating.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#now\n * @type {Highcharts.PositionObject}\n */\n this.now = { x: 0, y: 0 };\n /**\n * Tooltips are initially hidden.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#isHidden\n * @type {boolean}\n */\n this.isHidden = true;\n /**\n * True, if the tooltip is split into one label per series, with the\n * header close to the axis.\n *\n * @readonly\n * @name Highcharts.Tooltip#split\n * @type {boolean|undefined}\n */\n this.split = options.split && !chart.inverted && !chart.polar;\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events.\n *\n * @readonly\n * @name Highcharts.Tooltip#shared\n * @type {boolean|undefined}\n */\n this.shared = options.shared || this.split;\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (false), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area.\n *\n * @readonly\n * @name Highcharts.Tooltip#outside\n * @type {boolean}\n *\n * @todo\n * Split tooltip does not support outside in the first iteration. Should\n * not be too complicated to implement.\n */\n this.outside = pick(options.outside, Boolean(chart.scrollablePixelsX || chart.scrollablePixelsY));\n }\n shouldStickOnContact(pointerEvent) {\n return !!(!this.followPointer &&\n this.options.stickOnContact &&\n (!pointerEvent || this.chart.pointer.inClass(pointerEvent.target, 'highcharts-tooltip')));\n }\n /**\n * Moves the tooltip with a soft animation to a new position.\n *\n * @private\n * @function Highcharts.Tooltip#move\n *\n * @param {number} x\n *\n * @param {number} y\n *\n * @param {number} anchorX\n *\n * @param {number} anchorY\n */\n move(x, y, anchorX, anchorY) {\n const tooltip = this, now = tooltip.now, animate = tooltip.options.animation !== false &&\n !tooltip.isHidden &&\n // When we get close to the target position, abort animation and\n // land on the right place (#3056)\n (Math.abs(x - now.x) > 1 || Math.abs(y - now.y) > 1), skipAnchor = tooltip.followPointer || tooltip.len > 1;\n // Get intermediate values for animation\n extend(now, {\n x: animate ? (2 * now.x + x) / 3 : x,\n y: animate ? (now.y + y) / 2 : y,\n anchorX: skipAnchor ?\n void 0 :\n animate ? (2 * now.anchorX + anchorX) / 3 : anchorX,\n anchorY: skipAnchor ?\n void 0 :\n animate ? (now.anchorY + anchorY) / 2 : anchorY\n });\n // Move to the intermediate value\n tooltip.getLabel().attr(now);\n tooltip.drawTracker();\n // Run on next tick of the mouse tracker\n if (animate) {\n // Never allow two timeouts\n U.clearTimeout(this.tooltipTimeout);\n // Set the fixed interval ticking for the smooth tooltip\n this.tooltipTimeout = setTimeout(function () {\n // The interval function may still be running during destroy,\n // so check that the chart is really there before calling.\n if (tooltip) {\n tooltip.move(x, y, anchorX, anchorY);\n }\n }, 32);\n }\n }\n /**\n * Refresh the tooltip's text and position.\n *\n * @function Highcharts.Tooltip#refresh\n *\n * @param {Highcharts.Point|Array} pointOrPoints\n * Either a point or an array of points.\n *\n * @param {Highcharts.PointerEventObject} [mouseEvent]\n * Mouse event, that is responsible for the refresh and should be\n * used for the tooltip update.\n */\n refresh(pointOrPoints, mouseEvent) {\n const tooltip = this, chart = this.chart, options = tooltip.options, pointer = chart.pointer, points = splat(pointOrPoints), point = points[0], pointConfig = [], formatString = options.format, formatter = options.formatter || tooltip.defaultFormatter, shared = tooltip.shared, styledMode = chart.styledMode;\n let formatterContext = {};\n if (!options.enabled || !point.series) { // #16820\n return;\n }\n U.clearTimeout(this.hideTimer);\n // A switch saying if this specific tooltip configuration allows shared\n // or split modes\n tooltip.allowShared = !(!isArray(pointOrPoints) &&\n pointOrPoints.series &&\n pointOrPoints.series.noSharedTooltip);\n // get the reference point coordinates (pie charts use tooltipPos)\n tooltip.followPointer = (!tooltip.split && point.series.tooltipOptions.followPointer);\n const anchor = tooltip.getAnchor(pointOrPoints, mouseEvent), x = anchor[0], y = anchor[1];\n // shared tooltip, array is sent over\n if (shared && tooltip.allowShared) {\n pointer.applyInactiveState(points);\n // Now set hover state for the choosen ones:\n points.forEach(function (item) {\n item.setState('hover');\n pointConfig.push(item.getLabelConfig());\n });\n formatterContext = point.getLabelConfig();\n formatterContext.points = pointConfig;\n // single point tooltip\n }\n else {\n formatterContext = point.getLabelConfig();\n }\n this.len = pointConfig.length; // #6128\n const text = isString(formatString) ?\n format(formatString, formatterContext, chart) :\n formatter.call(formatterContext, tooltip);\n // register the current series\n const currentSeries = point.series;\n this.distance = pick(currentSeries.tooltipOptions.distance, 16);\n // update the inner HTML\n if (text === false) {\n this.hide();\n }\n else {\n // update text\n if (tooltip.split && tooltip.allowShared) { // #13868\n this.renderSplit(text, points);\n }\n else {\n let checkX = x;\n let checkY = y;\n if (mouseEvent && pointer.isDirectTouch) {\n checkX = mouseEvent.chartX - chart.plotLeft;\n checkY = mouseEvent.chartY - chart.plotTop;\n }\n // #11493, #13095\n if (chart.polar ||\n currentSeries.options.clip === false ||\n points.some((p) => // #16004\n pointer.isDirectTouch || // ##17929\n p.series.shouldShowTooltip(checkX, checkY))) {\n const label = tooltip.getLabel();\n // Prevent the tooltip from flowing over the chart box\n // (#6659)\n if (!options.style.width || styledMode) {\n label.css({\n width: (this.outside ?\n this.getPlayingField() :\n chart.spacingBox).width + 'px'\n });\n }\n label.attr({\n text: text && text.join ?\n text.join('') :\n text\n });\n // Set the stroke color of the box to reflect the point\n label.addClass(tooltip.getClassName(point), true);\n if (!styledMode) {\n label.attr({\n stroke: (options.borderColor ||\n point.color ||\n currentSeries.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n tooltip.updatePosition({\n plotX: x,\n plotY: y,\n negative: point.negative,\n ttBelow: point.ttBelow,\n h: anchor[2] || 0\n });\n }\n else {\n tooltip.hide();\n return;\n }\n }\n // show it\n if (tooltip.isHidden && tooltip.label) {\n tooltip.label.attr({\n opacity: 1\n }).show();\n }\n tooltip.isHidden = false;\n }\n fireEvent(this, 'refresh');\n }\n /**\n * Render the split tooltip. Loops over each point's text and adds\n * a label next to the point, then uses the distribute function to\n * find best non-overlapping positions.\n *\n * @private\n * @function Highcharts.Tooltip#renderSplit\n *\n * @param {string|Array<(boolean|string)>} labels\n *\n * @param {Array} points\n */\n renderSplit(labels, points) {\n const tooltip = this;\n const { chart, chart: { chartWidth, chartHeight, plotHeight, plotLeft, plotTop, pointer, scrollablePixelsY = 0, scrollablePixelsX, scrollingContainer: { scrollLeft, scrollTop } = { scrollLeft: 0, scrollTop: 0 }, styledMode }, distance, options, options: { positioner } } = tooltip;\n // The area which the tooltip should be limited to. Limit to scrollable\n // plot area if enabled, otherwise limit to the chart container. If\n // outside is true it should be the whole viewport\n const bounds = (tooltip.outside &&\n typeof scrollablePixelsX !== 'number') ?\n doc.documentElement.getBoundingClientRect() : {\n left: scrollLeft,\n right: scrollLeft + chartWidth,\n top: scrollTop,\n bottom: scrollTop + chartHeight\n };\n const tooltipLabel = tooltip.getLabel();\n const ren = this.renderer || chart.renderer;\n const headerTop = Boolean(chart.xAxis[0] && chart.xAxis[0].opposite);\n const { left: chartLeft, top: chartTop } = pointer.getChartPosition();\n let distributionBoxTop = plotTop + scrollTop;\n let headerHeight = 0;\n let adjustedPlotHeight = plotHeight - scrollablePixelsY;\n /**\n * Calculates the anchor position for the partial tooltip\n *\n * @private\n * @param {Highcharts.Point} point The point related to the tooltip\n * @return {Object} Returns an object with anchorX and anchorY\n */\n function getAnchor(point) {\n const { isHeader, plotX = 0, plotY = 0, series } = point;\n let anchorX;\n let anchorY;\n if (isHeader) {\n // Set anchorX to plotX\n anchorX = plotLeft + plotX;\n // Set anchorY to center of visible plot area.\n anchorY = plotTop + plotHeight / 2;\n }\n else {\n const { xAxis, yAxis } = series;\n // Set anchorX to plotX. Limit to within xAxis.\n anchorX = xAxis.pos + clamp(plotX, -distance, xAxis.len + distance);\n // Set anchorY, limit to the scrollable plot area\n if (series.shouldShowTooltip(0, yAxis.pos - plotTop + plotY, {\n ignoreX: true\n })) {\n anchorY = yAxis.pos + plotY;\n }\n }\n // Limit values to plot area\n anchorX = clamp(anchorX, bounds.left - distance, bounds.right + distance);\n return { anchorX, anchorY };\n }\n /**\n * Calculates the position of the partial tooltip\n *\n * @private\n * @param {number} anchorX\n * The partial tooltip anchor x position\n *\n * @param {number} anchorY\n * The partial tooltip anchor y position\n *\n * @param {boolean|undefined} isHeader\n * Whether the partial tooltip is a header\n *\n * @param {number} boxWidth\n * Width of the partial tooltip\n *\n * @return {Highcharts.PositionObject}\n * Returns the partial tooltip x and y position\n */\n function defaultPositioner(anchorX, anchorY, isHeader, boxWidth, alignedLeft = true) {\n let y;\n let x;\n if (isHeader) {\n y = headerTop ? 0 : adjustedPlotHeight;\n x = clamp(anchorX - (boxWidth / 2), bounds.left, bounds.right - boxWidth - (tooltip.outside ? chartLeft : 0));\n }\n else {\n y = anchorY - distributionBoxTop;\n x = alignedLeft ?\n anchorX - boxWidth - distance :\n anchorX + distance;\n x = clamp(x, alignedLeft ? x : bounds.left, bounds.right);\n }\n // NOTE: y is relative to distributionBoxTop\n return { x, y };\n }\n /**\n * Updates the attributes and styling of the partial tooltip. Creates a\n * new partial tooltip if it does not exists.\n *\n * @private\n * @param {Highcharts.SVGElement|undefined} partialTooltip\n * The partial tooltip to update\n * @param {Highcharts.Point} point\n * The point related to the partial tooltip\n * @param {boolean|string} str The text for the partial tooltip\n * @return {Highcharts.SVGElement} Returns the updated partial tooltip\n */\n function updatePartialTooltip(partialTooltip, point, str) {\n var _a;\n let tt = partialTooltip;\n const { isHeader, series } = point;\n if (!tt) {\n const attribs = {\n padding: options.padding,\n r: options.borderRadius\n };\n if (!styledMode) {\n attribs.fill = options.backgroundColor;\n attribs['stroke-width'] = (_a = options.borderWidth) !== null && _a !== void 0 ? _a : 1;\n }\n tt = ren\n .label('', 0, 0, (options[isHeader ? 'headerShape' : 'shape']), void 0, void 0, options.useHTML)\n .addClass(tooltip.getClassName(point, true, isHeader))\n .attr(attribs)\n .add(tooltipLabel);\n }\n tt.isActive = true;\n tt.attr({\n text: str\n });\n if (!styledMode) {\n tt.css(options.style)\n .attr({\n stroke: (options.borderColor ||\n point.color ||\n series.color ||\n \"#333333\" /* Palette.neutralColor80 */)\n });\n }\n return tt;\n }\n // Graceful degradation for legacy formatters\n if (isString(labels)) {\n labels = [false, labels];\n }\n // Create the individual labels for header and points, ignore footer\n let boxes = labels.slice(0, points.length + 1).reduce(function (boxes, str, i) {\n if (str !== false && str !== '') {\n const point = (points[i - 1] ||\n {\n // Item 0 is the header. Instead of this, we could also\n // use the crosshair label\n isHeader: true,\n plotX: points[0].plotX,\n plotY: plotHeight,\n series: {}\n });\n const isHeader = point.isHeader;\n // Store the tooltip label referance on the series\n const owner = isHeader ? tooltip : point.series;\n const tt = owner.tt = updatePartialTooltip(owner.tt, point, str.toString());\n // Get X position now, so we can move all to the other side in\n // case of overflow\n const bBox = tt.getBBox();\n const boxWidth = bBox.width + tt.strokeWidth();\n if (isHeader) {\n headerHeight = bBox.height;\n adjustedPlotHeight += headerHeight;\n if (headerTop) {\n distributionBoxTop -= headerHeight;\n }\n }\n const { anchorX, anchorY } = getAnchor(point);\n if (typeof anchorY === 'number') {\n const size = bBox.height + 1;\n const boxPosition = (positioner ?\n positioner.call(tooltip, boxWidth, size, point) :\n defaultPositioner(anchorX, anchorY, isHeader, boxWidth));\n boxes.push({\n // 0-align to the top, 1-align to the bottom\n align: positioner ? 0 : void 0,\n anchorX,\n anchorY,\n boxWidth,\n point,\n rank: pick(boxPosition.rank, isHeader ? 1 : 0),\n size,\n target: boxPosition.y,\n tt,\n x: boxPosition.x\n });\n }\n else {\n // Hide tooltips which anchorY is outside the visible plot\n // area\n tt.isActive = false;\n }\n }\n return boxes;\n }, []);\n // Realign the tooltips towards the right if there is not enough space\n // to the left and there is space to to the right\n if (!positioner && boxes.some((box) => {\n // Always realign if the beginning of a label is outside bounds\n const { outside } = tooltip;\n const boxStart = (outside ? chartLeft : 0) + box.anchorX;\n if (boxStart < bounds.left &&\n boxStart + box.boxWidth < bounds.right) {\n return true;\n }\n // Otherwise, check if there is more space available to the right\n return boxStart < (chartLeft - bounds.left) + box.boxWidth &&\n bounds.right - boxStart > boxStart;\n })) {\n boxes = boxes.map((box) => {\n const { x, y } = defaultPositioner(box.anchorX, box.anchorY, box.point.isHeader, box.boxWidth, false);\n return extend(box, {\n target: y,\n x\n });\n });\n }\n // Clean previous run (for missing points)\n tooltip.cleanSplit();\n // Distribute and put in place\n distribute(boxes, adjustedPlotHeight);\n const boxExtremes = {\n left: chartLeft,\n right: chartLeft\n };\n // Get the extremes from series tooltips\n boxes.forEach(function (box) {\n const { x, boxWidth, isHeader } = box;\n if (!isHeader) {\n if (tooltip.outside && chartLeft + x < boxExtremes.left) {\n boxExtremes.left = chartLeft + x;\n }\n if (!isHeader &&\n tooltip.outside &&\n boxExtremes.left + boxWidth > boxExtremes.right) {\n boxExtremes.right = chartLeft + x;\n }\n }\n });\n boxes.forEach(function (box) {\n const { x, anchorX, anchorY, pos, point: { isHeader } } = box;\n const attributes = {\n visibility: typeof pos === 'undefined' ? 'hidden' : 'inherit',\n x,\n /* NOTE: y should equal pos to be consistent with !split\n * tooltip, but is currently relative to plotTop. Is left as is\n * to avoid breaking change. Remove distributionBoxTop to make\n * it consistent.\n */\n y: (pos || 0) + distributionBoxTop,\n anchorX,\n anchorY\n };\n // Handle left-aligned tooltips overflowing the chart area\n if (tooltip.outside && x < anchorX) {\n const offset = chartLeft - boxExtremes.left;\n // Skip this if there is no overflow\n if (offset > 0) {\n if (!isHeader) {\n attributes.x = x + offset;\n attributes.anchorX = anchorX + offset;\n }\n if (isHeader) {\n attributes.x = (boxExtremes.right - boxExtremes.left) / 2;\n attributes.anchorX = anchorX + offset;\n }\n }\n }\n // Put the label in place\n box.tt.attr(attributes);\n });\n /* If we have a seperate tooltip container, then update the necessary\n * container properties.\n * Test that tooltip has its own container and renderer before executing\n * the operation.\n */\n const { container, outside, renderer } = tooltip;\n if (outside && container && renderer) {\n // Set container size to fit the bounds\n const { width, height, x, y } = tooltipLabel.getBBox();\n renderer.setSize(width + x, height + y, false);\n // Position the tooltip container to the chart container\n container.style.left = boxExtremes.left + 'px';\n container.style.top = chartTop + 'px';\n }\n // Workaround for #18927, artefacts left by the shadows of split\n // tooltips in Safari v16 (2023). Check again with later versions if we\n // can remove this.\n if (isSafari) {\n tooltipLabel.attr({\n // Force a redraw of the whole group by chaning the opacity\n // slightly\n opacity: tooltipLabel.opacity === 1 ? 0.999 : 1\n });\n }\n }\n /**\n * If the `stickOnContact` option is active, this will add a tracker shape.\n *\n * @private\n * @function Highcharts.Tooltip#drawTracker\n */\n drawTracker() {\n const tooltip = this;\n if (!this.shouldStickOnContact()) {\n if (tooltip.tracker) {\n tooltip.tracker = tooltip.tracker.destroy();\n }\n return;\n }\n const chart = tooltip.chart;\n const label = tooltip.label;\n const points = tooltip.shared ? chart.hoverPoints : chart.hoverPoint;\n if (!label || !points) {\n return;\n }\n const box = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n // Combine anchor and tooltip\n const anchorPos = this.getAnchor(points);\n const labelBBox = label.getBBox();\n anchorPos[0] += chart.plotLeft - label.translateX;\n anchorPos[1] += chart.plotTop - label.translateY;\n // When the mouse pointer is between the anchor point and the label,\n // the label should stick.\n box.x = Math.min(0, anchorPos[0]);\n box.y = Math.min(0, anchorPos[1]);\n box.width = (anchorPos[0] < 0 ?\n Math.max(Math.abs(anchorPos[0]), (labelBBox.width - anchorPos[0])) :\n Math.max(Math.abs(anchorPos[0]), labelBBox.width));\n box.height = (anchorPos[1] < 0 ?\n Math.max(Math.abs(anchorPos[1]), (labelBBox.height - Math.abs(anchorPos[1]))) :\n Math.max(Math.abs(anchorPos[1]), labelBBox.height));\n if (tooltip.tracker) {\n tooltip.tracker.attr(box);\n }\n else {\n tooltip.tracker = label.renderer\n .rect(box)\n .addClass('highcharts-tracker')\n .add(label);\n if (!chart.styledMode) {\n tooltip.tracker.attr({\n fill: 'rgba(0,0,0,0)'\n });\n }\n }\n }\n /**\n * @private\n */\n styledModeFormat(formatString) {\n return formatString\n .replace('style=\"font-size: 0.8em\"', 'class=\"highcharts-header\"')\n .replace(/style=\"color:{(point|series)\\.color}\"/g, 'class=\"highcharts-color-{$1.colorIndex} ' +\n '{series.options.className} ' +\n '{point.options.className}\"');\n }\n /**\n * Format the footer/header of the tooltip\n * #3397: abstraction to enable formatting of footer and header\n *\n * @private\n * @function Highcharts.Tooltip#tooltipFooterHeaderFormatter\n */\n tooltipFooterHeaderFormatter(labelConfig, isFooter) {\n const series = labelConfig.series, tooltipOptions = series.tooltipOptions, xAxis = series.xAxis, dateTime = xAxis && xAxis.dateTime, e = {\n isFooter: isFooter,\n labelConfig: labelConfig\n };\n let xDateFormat = tooltipOptions.xDateFormat, formatString = tooltipOptions[isFooter ? 'footerFormat' : 'headerFormat'];\n fireEvent(this, 'headerFormatter', e, function (e) {\n // Guess the best date format based on the closest point distance\n // (#568, #3418)\n if (dateTime && !xDateFormat && isNumber(labelConfig.key)) {\n xDateFormat = dateTime.getXDateFormat(labelConfig.key, tooltipOptions.dateTimeLabelFormats);\n }\n // Insert the footer date format if any\n if (dateTime && xDateFormat) {\n ((labelConfig.point && labelConfig.point.tooltipDateKeys) ||\n ['key']).forEach(function (key) {\n formatString = formatString.replace('{point.' + key + '}', '{point.' + key + ':' + xDateFormat + '}');\n });\n }\n // Replace default header style with class name\n if (series.chart.styledMode) {\n formatString = this.styledModeFormat(formatString);\n }\n e.text = format(formatString, {\n point: labelConfig,\n series: series\n }, this.chart);\n });\n return e.text;\n }\n /**\n * Updates the tooltip with the provided tooltip options.\n *\n * @function Highcharts.Tooltip#update\n *\n * @param {Highcharts.TooltipOptions} options\n * The tooltip options to update.\n */\n update(options) {\n this.destroy();\n this.init(this.chart, merge(true, this.options, options));\n }\n /**\n * Find the new position and perform the move\n *\n * @private\n * @function Highcharts.Tooltip#updatePosition\n *\n * @param {Highcharts.Point} point\n */\n updatePosition(point) {\n const { chart, distance, options } = this, pointer = chart.pointer, label = this.getLabel(), \n // Needed for outside: true (#11688)\n { left, top, scaleX, scaleY } = pointer.getChartPosition(), pos = (options.positioner || this.getPosition).call(this, label.width, label.height, point);\n let anchorX = (point.plotX || 0) + chart.plotLeft, anchorY = (point.plotY || 0) + chart.plotTop, pad;\n // Set the renderer size dynamically to prevent document size to change\n if (this.outside) {\n // Corrects positions, occurs with tooltip positioner (#16944)\n if (options.positioner) {\n pos.x += left - distance;\n pos.y += top - distance;\n }\n pad = (options.borderWidth || 0) + 2 * distance;\n this.renderer.setSize(label.width + pad, label.height + pad, false);\n // Anchor and tooltip container need scaling if chart container has\n // scale transform/css zoom. #11329.\n if (scaleX !== 1 || scaleY !== 1) {\n css(this.container, {\n transform: `scale(${scaleX}, ${scaleY})`\n });\n anchorX *= scaleX;\n anchorY *= scaleY;\n }\n anchorX += left - pos.x;\n anchorY += top - pos.y;\n }\n // do the move\n this.move(Math.round(pos.x), Math.round(pos.y || 0), // can be undefined (#3977)\n anchorX, anchorY);\n }\n }\n /* *\n *\n * Class namespace\n *\n * */\n (function (Tooltip) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(PointerClass) {\n if (U.pushUnique(composedMembers, PointerClass)) {\n addEvent(PointerClass, 'afterInit', function () {\n const chart = this.chart;\n if (chart.options.tooltip) {\n /**\n * Tooltip object for points of series.\n *\n * @name Highcharts.Chart#tooltip\n * @type {Highcharts.Tooltip}\n */\n chart.tooltip = new Tooltip(chart, chart.options.tooltip);\n }\n });\n }\n }\n Tooltip.compose = compose;\n })(Tooltip || (Tooltip = {}));\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback function to format the text of the tooltip from scratch.\n *\n * In case of single or shared tooltips, a string should be be returned. In case\n * of splitted tooltips, it should return an array where the first item is the\n * header, and subsequent items are mapped to the points. Return `false` to\n * disable tooltip for a specific point on series.\n *\n * @callback Highcharts.TooltipFormatterCallbackFunction\n *\n * @param {Highcharts.TooltipFormatterContextObject} this\n * Context to format\n *\n * @param {Highcharts.Tooltip} tooltip\n * The tooltip instance\n *\n * @return {false|string|Array<(string|null|undefined)>|null|undefined}\n * Formatted text or false\n */\n /**\n * Configuration for the tooltip formatters.\n *\n * @interface Highcharts.TooltipFormatterContextObject\n * @extends Highcharts.PointLabelObject\n */ /**\n * Array of points in shared tooltips.\n * @name Highcharts.TooltipFormatterContextObject#points\n * @type {Array|undefined}\n */\n /**\n * A callback function to place the tooltip in a specific position.\n *\n * @callback Highcharts.TooltipPositionerCallbackFunction\n *\n * @param {Highcharts.Tooltip} this\n * Tooltip context of the callback.\n *\n * @param {number} labelWidth\n * Width of the tooltip.\n *\n * @param {number} labelHeight\n * Height of the tooltip.\n *\n * @param {Highcharts.TooltipPositionerPointObject} point\n * Point information for positioning a tooltip.\n *\n * @return {Highcharts.PositionObject}\n * New position for the tooltip.\n */\n /**\n * Point information for positioning a tooltip.\n *\n * @interface Highcharts.TooltipPositionerPointObject\n * @extends Highcharts.Point\n */ /**\n * If `tooltip.split` option is enabled and positioner is called for each of the\n * boxes separately, this property indicates the call on the xAxis header, which\n * is not a point itself.\n * @name Highcharts.TooltipPositionerPointObject#isHeader\n * @type {boolean}\n */ /**\n * The reference point relative to the plot area. Add chart.plotLeft to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotX\n * @type {number}\n */ /**\n * The reference point relative to the plot area. Add chart.plotTop to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotY\n * @type {number}\n */\n /**\n * @typedef {\"callout\"|\"circle\"|\"square\"} Highcharts.TooltipShapeValue\n */\n ''; // keeps doclets above in JS file\n\n return Tooltip;\n });\n _registerModule(_modules, 'Core/Series/Point.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/Templating.js'], _modules['Core/Utilities.js']], function (AST, A, D, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject } = A;\n const { defaultOptions } = D;\n const { format } = F;\n const { addEvent, defined, erase, extend, fireEvent, getNestedProperty, isArray, isFunction, isNumber, isObject, merge, objectEach, pick, syncTimeout, removeEvent, uniqueKey } = U;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * The Point object. The point objects are generated from the `series.data`\n * configuration objects or raw numbers. They can be accessed from the\n * `Series.points` array. Other ways to instantiate points are through {@link\n * Highcharts.Series#addPoint} or {@link Highcharts.Series#setData}.\n *\n * @class\n * @name Highcharts.Point\n */\n class Point {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n /**\n * For categorized axes this property holds the category name for the\n * point. For other axes it holds the X value.\n *\n * @name Highcharts.Point#category\n * @type {number|string}\n */\n this.category = void 0;\n this.destroyed = false;\n this.formatPrefix = 'point';\n this.id = void 0;\n this.isNull = false;\n /**\n * The name of the point. The name can be given as the first position of the\n * point configuration array, or as a `name` property in the configuration:\n *\n * @example\n * // Array config\n * data: [\n * ['John', 1],\n * ['Jane', 2]\n * ]\n *\n * // Object config\n * data: [{\n * name: 'John',\n * y: 1\n * }, {\n * name: 'Jane',\n * y: 2\n * }]\n *\n * @name Highcharts.Point#name\n * @type {string}\n */\n this.name = void 0;\n /**\n * The point's options as applied in the initial configuration, or\n * extended through `Point.update`.\n *\n * In TypeScript you have to extend `PointOptionsObject` via an\n * additional interface to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @name Highcharts.Point#options\n * @type {Highcharts.PointOptionsObject}\n */\n this.options = void 0;\n /**\n * The percentage for points in a stacked series, pies or gauges.\n *\n * @name Highcharts.Point#percentage\n * @type {number|undefined}\n */\n this.percentage = void 0;\n this.selected = false;\n /**\n * The series object associated with the point.\n *\n * @name Highcharts.Point#series\n * @type {Highcharts.Series}\n */\n this.series = void 0;\n /**\n * The attributes of the rendered SVG shape like in `column` or `pie`\n * series.\n *\n * @readonly\n * @name Highcharts.Point#shapeArgs\n * @type {Readonly|undefined}\n */\n this.shapeArgs = void 0;\n /**\n * The total of values in either a stack for stacked series, or a pie in a\n * pie series.\n *\n * @name Highcharts.Point#total\n * @type {number|undefined}\n */\n this.total = void 0;\n /**\n * For certain series types, like pie charts, where individual points can\n * be shown or hidden.\n *\n * @name Highcharts.Point#visible\n * @type {boolean}\n * @default true\n */\n this.visible = true;\n this.x = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Animate SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#animateBeforeDestroy\n */\n animateBeforeDestroy() {\n const point = this, animateParams = { x: point.startXPos, opacity: 0 }, graphicalProps = point.getGraphicalProps();\n graphicalProps.singular.forEach(function (prop) {\n const isDataLabel = prop === 'dataLabel';\n point[prop] = point[prop].animate(isDataLabel ? {\n x: point[prop].startXPos,\n y: point[prop].startYPos,\n opacity: 0\n } : animateParams);\n });\n graphicalProps.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item.element) {\n item.animate(extend({ x: point.startXPos }, (item.startYPos ? {\n x: item.startXPos,\n y: item.startYPos\n } : {})));\n }\n });\n });\n }\n /**\n * Apply the options containing the x and y data and possible some extra\n * properties. Called on point init or from point.update.\n *\n * @private\n * @function Highcharts.Point#applyOptions\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options as defined in series.data.\n *\n * @param {number} [x]\n * Optionally, the x value.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n */\n applyOptions(options, x) {\n const point = this, series = point.series, pointValKey = series.options.pointValKey || series.pointValKey;\n options = Point.prototype.optionsToObject.call(this, options);\n // copy options directly to point\n extend(point, options);\n point.options = point.options ?\n extend(point.options, options) :\n options;\n // Since options are copied into the Point instance, some accidental\n // options must be shielded (#5681)\n if (options.group) {\n delete point.group;\n }\n if (options.dataLabels) {\n delete point.dataLabels;\n }\n /**\n * The y value of the point.\n * @name Highcharts.Point#y\n * @type {number|undefined}\n */\n // For higher dimension series types. For instance, for ranges, point.y\n // is mapped to point.low.\n if (pointValKey) {\n point.y = Point.prototype.getNestedProperty.call(point, pointValKey);\n }\n point.isNull = this.isValid && !this.isValid();\n point.formatPrefix = point.isNull ? 'null' : 'point'; // #9233, #10874\n // The point is initially selected by options (#5777)\n if (point.selected) {\n point.state = 'select';\n }\n /**\n * The x value of the point.\n * @name Highcharts.Point#x\n * @type {number}\n */\n // If no x is set by now, get auto incremented value. All points must\n // have an x value, however the y value can be null to create a gap in\n // the series\n if ('name' in point &&\n typeof x === 'undefined' &&\n series.xAxis &&\n series.xAxis.hasNames) {\n point.x = series.xAxis.nameToX(point);\n }\n if (typeof point.x === 'undefined' && series) {\n if (typeof x === 'undefined') {\n point.x = series.autoIncrement();\n }\n else {\n point.x = x;\n }\n }\n else if (isNumber(options.x) && series.options.relativeXValue) {\n point.x = series.autoIncrement(options.x);\n }\n return point;\n }\n /**\n * Destroy a point to clear memory. Its reference still stays in\n * `series.data`.\n *\n * @private\n * @function Highcharts.Point#destroy\n */\n destroy() {\n if (!this.destroyed) {\n const point = this, series = point.series, chart = series.chart, dataSorting = series.options.dataSorting, hoverPoints = chart.hoverPoints, globalAnimation = point.series.chart.renderer.globalAnimation, animation = animObject(globalAnimation);\n /**\n * Allow to call after animation.\n * @private\n */\n const destroyPoint = () => {\n // Remove all events and elements\n if (point.graphic ||\n point.graphics ||\n point.dataLabel ||\n point.dataLabels) {\n removeEvent(point);\n point.destroyElements();\n }\n for (const prop in point) { // eslint-disable-line guard-for-in\n delete point[prop];\n }\n };\n if (point.legendItem) {\n // pies have legend items\n chart.legend.destroyItem(point);\n }\n if (hoverPoints) {\n point.setState();\n erase(hoverPoints, point);\n if (!hoverPoints.length) {\n chart.hoverPoints = null;\n }\n }\n if (point === chart.hoverPoint) {\n point.onMouseOut();\n }\n // Remove properties after animation\n if (!dataSorting || !dataSorting.enabled) {\n destroyPoint();\n }\n else {\n this.animateBeforeDestroy();\n syncTimeout(destroyPoint, animation.duration);\n }\n chart.pointCount--;\n }\n this.destroyed = true;\n }\n /**\n * Destroy SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#destroyElements\n * @param {Highcharts.Dictionary} [kinds]\n */\n destroyElements(kinds) {\n const point = this, props = point.getGraphicalProps(kinds);\n props.singular.forEach(function (prop) {\n point[prop] = point[prop].destroy();\n });\n props.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item && item.element) {\n item.destroy();\n }\n });\n delete point[plural];\n });\n }\n /**\n * Fire an event on the Point object.\n *\n * @private\n * @function Highcharts.Point#firePointEvent\n *\n * @param {string} eventType\n * Type of the event.\n *\n * @param {Highcharts.Dictionary|Event} [eventArgs]\n * Additional event arguments.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * Default event handler.\n *\n * @emits Highcharts.Point#event:*\n */\n firePointEvent(eventType, eventArgs, defaultFunction) {\n const point = this, series = this.series, seriesOptions = series.options;\n // load event handlers on demand to save time on mouseover/out\n if (seriesOptions.point.events[eventType] ||\n (point.options &&\n point.options.events &&\n point.options.events[eventType])) {\n point.importEvents();\n }\n // add default handler if in selection mode\n if (eventType === 'click' && seriesOptions.allowPointSelect) {\n defaultFunction = function (event) {\n // Control key is for Windows, meta (= Cmd key) for Mac, Shift\n // for Opera.\n if (point.select) { // #2911\n point.select(null, event.ctrlKey || event.metaKey || event.shiftKey);\n }\n };\n }\n fireEvent(point, eventType, eventArgs, defaultFunction);\n }\n /**\n * Get the CSS class names for individual points. Used internally where the\n * returned value is set on every point.\n *\n * @function Highcharts.Point#getClassName\n *\n * @return {string}\n * The class names.\n */\n getClassName() {\n const point = this;\n return 'highcharts-point' +\n (point.selected ? ' highcharts-point-select' : '') +\n (point.negative ? ' highcharts-negative' : '') +\n (point.isNull ? ' highcharts-null-point' : '') +\n (typeof point.colorIndex !== 'undefined' ?\n ' highcharts-color-' + point.colorIndex : '') +\n (point.options.className ? ' ' + point.options.className : '') +\n (point.zone && point.zone.className ? ' ' +\n point.zone.className.replace('highcharts-negative', '') : '');\n }\n /**\n * Get props of all existing graphical point elements.\n *\n * @private\n * @function Highcharts.Point#getGraphicalProps\n */\n getGraphicalProps(kinds) {\n const point = this, props = [], graphicalProps = { singular: [], plural: [] };\n let prop, i;\n kinds = kinds || { graphic: 1, dataLabel: 1 };\n if (kinds.graphic) {\n props.push('graphic');\n }\n if (kinds.dataLabel) {\n props.push('dataLabel', 'dataLabelPath', 'dataLabelUpper', 'connector');\n }\n i = props.length;\n while (i--) {\n prop = props[i];\n if (point[prop]) {\n graphicalProps.singular.push(prop);\n }\n }\n [\n 'graphic',\n 'dataLabel',\n 'connector'\n ].forEach(function (prop) {\n const plural = prop + 's';\n if (kinds[prop] && point[plural]) {\n graphicalProps.plural.push(plural);\n }\n });\n return graphicalProps;\n }\n /**\n * Return the configuration hash needed for the data label and tooltip\n * formatters.\n *\n * @function Highcharts.Point#getLabelConfig\n *\n * @return {Highcharts.PointLabelObject}\n * Abstract object used in formatters and formats.\n */\n getLabelConfig() {\n return {\n x: this.category,\n y: this.y,\n color: this.color,\n colorIndex: this.colorIndex,\n key: this.name || this.category,\n series: this.series,\n point: this,\n percentage: this.percentage,\n total: this.total || this.stackTotal\n };\n }\n /**\n * Returns the value of the point property for a given value.\n * @private\n */\n getNestedProperty(key) {\n if (!key) {\n return;\n }\n if (key.indexOf('custom.') === 0) {\n return getNestedProperty(key, this.options);\n }\n return this[key];\n }\n /**\n * In a series with `zones`, return the zone that the point belongs to.\n *\n * @function Highcharts.Point#getZone\n *\n * @return {Highcharts.SeriesZonesOptionsObject}\n * The zone item.\n */\n getZone() {\n const series = this.series, zones = series.zones, zoneAxis = series.zoneAxis || 'y';\n let zone, i = 0;\n zone = zones[i];\n while (this[zoneAxis] >= zone.value) {\n zone = zones[++i];\n }\n // For resetting or reusing the point (#8100)\n if (!this.nonZonedColor) {\n this.nonZonedColor = this.color;\n }\n if (zone && zone.color && !this.options.color) {\n this.color = zone.color;\n }\n else {\n this.color = this.nonZonedColor;\n }\n return zone;\n }\n /**\n * Utility to check if point has new shape type. Used in column series and\n * all others that are based on column series.\n * @private\n */\n hasNewShapeType() {\n const point = this;\n const oldShapeType = point.graphic &&\n (point.graphic.symbolName || point.graphic.element.nodeName);\n return oldShapeType !== this.shapeType;\n }\n /**\n * Initialize the point. Called internally based on the `series.data`\n * option.\n *\n * @function Highcharts.Point#init\n *\n * @param {Highcharts.Series} series\n * The series object containing this point.\n *\n * @param {Highcharts.PointOptionsType} options\n * The data in either number, array or object format.\n *\n * @param {number} [x]\n * Optionally, the X value of the point.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n *\n * @emits Highcharts.Point#event:afterInit\n */\n init(series, options, x) {\n this.series = series;\n this.applyOptions(options, x);\n // Add a unique ID to the point if none is assigned\n this.id = defined(this.id) ? this.id : uniqueKey();\n this.resolveColor();\n series.chart.pointCount++;\n fireEvent(this, 'afterInit');\n return this;\n }\n /**\n * Determine if point is valid.\n * @private\n * @function Highcharts.Point#isValid\n */\n isValid() {\n return this.x !== null && isNumber(this.y);\n }\n /**\n * Transform number or array configs into objects. Also called for object\n * configs. Used internally to unify the different configuration formats for\n * points. For example, a simple number `10` in a line series will be\n * transformed to `{ y: 10 }`, and an array config like `[1, 10]` in a\n * scatter series will be transformed to `{ x: 1, y: 10 }`.\n *\n * @deprecated\n * @function Highcharts.Point#optionsToObject\n *\n * @param {Highcharts.PointOptionsType} options\n * Series data options.\n *\n * @return {Highcharts.Dictionary<*>}\n * Transformed point options.\n */\n optionsToObject(options) {\n const series = this.series, keys = series.options.keys, pointArrayMap = keys || series.pointArrayMap || ['y'], valueCount = pointArrayMap.length;\n let ret = {}, firstItemType, i = 0, j = 0;\n if (isNumber(options) || options === null) {\n ret[pointArrayMap[0]] = options;\n }\n else if (isArray(options)) {\n // with leading x value\n if (!keys && options.length > valueCount) {\n firstItemType = typeof options[0];\n if (firstItemType === 'string') {\n ret.name = options[0];\n }\n else if (firstItemType === 'number') {\n ret.x = options[0];\n }\n i++;\n }\n while (j < valueCount) {\n // Skip undefined positions for keys\n if (!keys || typeof options[i] !== 'undefined') {\n if (pointArrayMap[j].indexOf('.') > 0) {\n // Handle nested keys, e.g. ['color.pattern.image']\n // Avoid function call unless necessary.\n Point.prototype.setNestedProperty(ret, options[i], pointArrayMap[j]);\n }\n else {\n ret[pointArrayMap[j]] = options[i];\n }\n }\n i++;\n j++;\n }\n }\n else if (typeof options === 'object') {\n ret = options;\n // This is the fastest way to detect if there are individual point\n // dataLabels that need to be considered in drawDataLabels. These\n // can only occur in object configs.\n if (options.dataLabels) {\n series._hasPointLabels = true;\n }\n // Same approach as above for markers\n if (options.marker) {\n series._hasPointMarkers = true;\n }\n }\n return ret;\n }\n /**\n * Get the pixel position of the point relative to the plot area.\n * @private\n * @function Highcharts.Point#pos\n */\n pos(chartCoordinates, plotY = this.plotY) {\n if (!this.destroyed) {\n const { plotX, series } = this, { chart, xAxis, yAxis } = series;\n let posX = 0, posY = 0;\n if (isNumber(plotX) && isNumber(plotY)) {\n if (chartCoordinates) {\n posX = xAxis ? xAxis.pos : chart.plotLeft;\n posY = yAxis ? yAxis.pos : chart.plotTop;\n }\n return chart.inverted && xAxis && yAxis ?\n [yAxis.len - plotY + posY, xAxis.len - plotX + posX] :\n [plotX + posX, plotY + posY];\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Point#resolveColor\n */\n resolveColor() {\n const series = this.series, optionsChart = series.chart.options.chart, styledMode = series.chart.styledMode;\n let color, colors, colorCount = optionsChart.colorCount, colorIndex;\n // remove points nonZonedColor for later recalculation\n delete this.nonZonedColor;\n if (series.options.colorByPoint) {\n if (!styledMode) {\n colors = series.options.colors || series.chart.options.colors;\n color = colors[series.colorCounter];\n colorCount = colors.length;\n }\n colorIndex = series.colorCounter;\n series.colorCounter++;\n // loop back to zero\n if (series.colorCounter === colorCount) {\n series.colorCounter = 0;\n }\n }\n else {\n if (!styledMode) {\n color = series.color;\n }\n colorIndex = series.colorIndex;\n }\n /**\n * The point's current color index, used in styled mode instead of\n * `color`. The color index is inserted in class names used for styling.\n *\n * @name Highcharts.Point#colorIndex\n * @type {number|undefined}\n */\n this.colorIndex = pick(this.options.colorIndex, colorIndex);\n /**\n * The point's current color.\n *\n * @name Highcharts.Point#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */\n this.color = pick(this.options.color, color);\n }\n /**\n * Set a value in an object, on the property defined by key. The key\n * supports nested properties using dot notation. The function modifies the\n * input object and does not make a copy.\n *\n * @function Highcharts.Point#setNestedProperty\n *\n * @param {T} object\n * The object to set the value on.\n *\n * @param {*} value\n * The value to set.\n *\n * @param {string} key\n * Key to the property to set.\n *\n * @return {T}\n * The modified object.\n */\n setNestedProperty(object, value, key) {\n const nestedKeys = key.split('.');\n nestedKeys.reduce(function (result, key, i, arr) {\n const isLastKey = arr.length - 1 === i;\n result[key] = (isLastKey ?\n value :\n isObject(result[key], true) ?\n result[key] :\n {});\n return result[key];\n }, object);\n return object;\n }\n shouldDraw() {\n return !this.isNull;\n }\n /**\n * Extendable method for formatting each point's tooltip line.\n *\n * @function Highcharts.Point#tooltipFormatter\n *\n * @param {string} pointFormat\n * The point format.\n *\n * @return {string}\n * A string to be concatenated in to the common tooltip text.\n */\n tooltipFormatter(pointFormat) {\n // Insert options for valueDecimals, valuePrefix, and valueSuffix\n const series = this.series, seriesTooltipOptions = series.tooltipOptions, valueDecimals = pick(seriesTooltipOptions.valueDecimals, ''), valuePrefix = seriesTooltipOptions.valuePrefix || '', valueSuffix = seriesTooltipOptions.valueSuffix || '';\n // Replace default point style with class name\n if (series.chart.styledMode) {\n pointFormat =\n series.chart.tooltip.styledModeFormat(pointFormat);\n }\n // Loop over the point array map and replace unformatted values with\n // sprintf formatting markup\n (series.pointArrayMap || ['y']).forEach(function (key) {\n key = '{point.' + key; // without the closing bracket\n if (valuePrefix || valueSuffix) {\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), valuePrefix + key + '}' + valueSuffix);\n }\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), key + ':,.' + valueDecimals + 'f}');\n });\n return format(pointFormat, {\n point: this,\n series: this.series\n }, series.chart);\n }\n /**\n * Update point with new options (typically x/y data) and optionally redraw\n * the series.\n *\n * @sample highcharts/members/point-update-column/\n * Update column value\n * @sample highcharts/members/point-update-pie/\n * Update pie slice\n * @sample maps/members/point-update/\n * Update map area value in Highmaps\n *\n * @function Highcharts.Point#update\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. Point options are handled as described under\n * the `series.type.data` item for each series type. For example\n * for a line series, if options is a single number, the point will\n * be given that number as the marin y value. If it is an array, it\n * will be interpreted as x and y values respectively. If it is an\n * object, advanced options are applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is updated. If doing\n * more operations on the chart, it is best practice to set\n * `redraw` to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @emits Highcharts.Point#event:update\n */\n update(options, redraw, animation, runEvent) {\n const point = this, series = point.series, graphic = point.graphic, chart = series.chart, seriesOptions = series.options;\n let i;\n redraw = pick(redraw, true);\n /**\n * @private\n */\n function update() {\n point.applyOptions(options);\n // Update visuals, #4146\n // Handle mock graphic elements for a11y, #12718\n const hasMockGraphic = graphic && point.hasMockGraphic;\n const shouldDestroyGraphic = point.y === null ?\n !hasMockGraphic :\n hasMockGraphic;\n if (graphic && shouldDestroyGraphic) {\n point.graphic = graphic.destroy();\n delete point.hasMockGraphic;\n }\n if (isObject(options, true)) {\n // Destroy so we can get new elements\n if (graphic && graphic.element) {\n // \"null\" is also a valid symbol\n if (options &&\n options.marker &&\n typeof options.marker.symbol !== 'undefined') {\n point.graphic = graphic.destroy();\n }\n }\n if (options && options.dataLabels && point.dataLabel) {\n point.dataLabel = point.dataLabel.destroy(); // #2468\n }\n if (point.connector) {\n point.connector = point.connector.destroy(); // #7243\n }\n }\n // record changes in the parallel arrays\n i = point.index;\n series.updateParallelArrays(point, i);\n // Record the options to options.data. If the old or the new config\n // is an object, use point options, otherwise use raw options\n // (#4701, #4916).\n seriesOptions.data[i] = (isObject(seriesOptions.data[i], true) ||\n isObject(options, true)) ?\n point.options :\n pick(options, seriesOptions.data[i]);\n // redraw\n series.isDirty = series.isDirtyData = true;\n if (!series.fixedBox && series.hasCartesianSeries) { // #1906, #2320\n chart.isDirtyBox = true;\n }\n if (seriesOptions.legendType === 'point') { // #1831, #1885\n chart.isDirtyLegend = true;\n }\n if (redraw) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of doing the update\n if (runEvent === false) { // When called from setData\n update();\n }\n else {\n point.firePointEvent('update', { options: options }, update);\n }\n }\n /**\n * Remove a point and optionally redraw the series and if necessary the axes\n *\n * @sample highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n * @sample highcharts/members/point-remove/\n * Remove pie slice\n * @sample maps/members/point-remove/\n * Remove selected points in Highmaps\n *\n * @function Highcharts.Point#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call. When\n * doing more operations on the chart, for example running\n * `point.remove()` in a loop, it is best practice to set `redraw`\n * to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=false]\n * Whether to apply animation, and optionally animation\n * configuration.\n */\n remove(redraw, animation) {\n this.series.removePoint(this.series.data.indexOf(this), redraw, animation);\n }\n /**\n * Toggle the selection status of a point.\n *\n * @see Highcharts.Chart#getSelectedPoints\n *\n * @sample highcharts/members/point-select/\n * Select a point from a button\n * @sample highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample maps/series/data-id/\n * Select a point in Highmaps\n *\n * @function Highcharts.Point#select\n *\n * @param {boolean} [selected]\n * When `true`, the point is selected. When `false`, the point is\n * unselected. When `null` or `undefined`, the selection state is toggled.\n *\n * @param {boolean} [accumulate=false]\n * When `true`, the selection is added to other selected points.\n * When `false`, other selected points are deselected. Internally in\n * Highcharts, when\n * [allowPointSelect](https://api.highcharts.com/highcharts/plotOptions.series.allowPointSelect)\n * is `true`, selected points are accumulated on Control, Shift or Cmd\n * clicking the point.\n *\n * @emits Highcharts.Point#event:select\n * @emits Highcharts.Point#event:unselect\n */\n select(selected, accumulate) {\n const point = this, series = point.series, chart = series.chart;\n selected = pick(selected, !point.selected);\n this.selectedStaging = selected;\n // fire the event with the default handler\n point.firePointEvent(selected ? 'select' : 'unselect', { accumulate: accumulate }, function () {\n /**\n * Whether the point is selected or not.\n *\n * @see Point#select\n * @see Chart#getSelectedPoints\n *\n * @name Highcharts.Point#selected\n * @type {boolean}\n */\n point.selected = point.options.selected = selected;\n series.options.data[series.data.indexOf(point)] =\n point.options;\n point.setState(selected && 'select');\n // unselect all other points unless Ctrl or Cmd + click\n if (!accumulate) {\n chart.getSelectedPoints().forEach(function (loopPoint) {\n const loopSeries = loopPoint.series;\n if (loopPoint.selected && loopPoint !== point) {\n loopPoint.selected = loopPoint.options.selected =\n false;\n loopSeries.options.data[loopSeries.data.indexOf(loopPoint)] = loopPoint.options;\n // Programatically selecting a point should restore\n // normal state, but when click happened on other\n // point, set inactive state to match other points\n loopPoint.setState(chart.hoverPoints &&\n loopSeries.options.inactiveOtherPoints ?\n 'inactive' : '');\n loopPoint.firePointEvent('unselect');\n }\n });\n }\n });\n delete this.selectedStaging;\n }\n /**\n * Runs on mouse over the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOver\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments.\n */\n onMouseOver(e) {\n const point = this, series = point.series, chart = series.chart, pointer = chart.pointer;\n e = e ?\n pointer.normalize(e) :\n // In cases where onMouseOver is called directly without an event\n pointer.getChartCoordinatesFromPoint(point, chart.inverted);\n pointer.runPointActions(e, point);\n }\n /**\n * Runs on mouse out from the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOut\n * @emits Highcharts.Point#event:mouseOut\n */\n onMouseOut() {\n const point = this, chart = point.series.chart;\n point.firePointEvent('mouseOut');\n if (!point.series.options.inactiveOtherPoints) {\n (chart.hoverPoints || []).forEach(function (p) {\n p.setState();\n });\n }\n chart.hoverPoints = chart.hoverPoint = null;\n }\n /**\n * Import events from the series' and point's options. Only do it on\n * demand, to save processing time on hovering.\n *\n * @private\n * @function Highcharts.Point#importEvents\n */\n importEvents() {\n if (!this.hasImportedEvents) {\n const point = this, options = merge(point.series.options.point, point.options), events = options.events;\n point.events = events;\n objectEach(events, function (event, eventType) {\n if (isFunction(event)) {\n addEvent(point, eventType, event);\n }\n });\n this.hasImportedEvents = true;\n }\n }\n /**\n * Set the point's state.\n *\n * @function Highcharts.Point#setState\n *\n * @param {Highcharts.PointStateValue|\"\"} [state]\n * The new state, can be one of `'hover'`, `'select'`, `'inactive'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [move]\n * State for animation.\n *\n * @emits Highcharts.Point#event:afterSetState\n */\n setState(state, move) {\n const point = this, series = point.series, previousState = point.state, stateOptions = (series.options.states[state || 'normal'] ||\n {}), markerOptions = (defaultOptions.plotOptions[series.type].marker &&\n series.options.marker), normalDisabled = (markerOptions && markerOptions.enabled === false), markerStateOptions = ((markerOptions &&\n markerOptions.states &&\n markerOptions.states[state || 'normal']) || {}), stateDisabled = markerStateOptions.enabled === false, pointMarker = point.marker || {}, chart = series.chart, hasMarkers = (markerOptions && series.markerAttribs);\n let halo = series.halo, markerAttribs, pointAttribs, pointAttribsAnimation, stateMarkerGraphic = series.stateMarkerGraphic, newSymbol;\n state = state || ''; // empty string\n if (\n // already has this state\n (state === point.state && !move) ||\n // selected points don't respond to hover\n (point.selected && state !== 'select') ||\n // series' state options is disabled\n (stateOptions.enabled === false) ||\n // general point marker's state options is disabled\n (state && (stateDisabled ||\n (normalDisabled &&\n markerStateOptions.enabled === false))) ||\n // individual point marker's state options is disabled\n (state &&\n pointMarker.states &&\n pointMarker.states[state] &&\n pointMarker.states[state].enabled === false) // #1610\n ) {\n return;\n }\n point.state = state;\n if (hasMarkers) {\n markerAttribs = series.markerAttribs(point, state);\n }\n // Apply hover styles to the existing point\n // Prevent from mocked null points (#14966)\n if (point.graphic && !point.hasMockGraphic) {\n if (previousState) {\n point.graphic.removeClass('highcharts-point-' + previousState);\n }\n if (state) {\n point.graphic.addClass('highcharts-point-' + state);\n }\n if (!chart.styledMode) {\n pointAttribs = series.pointAttribs(point, state);\n pointAttribsAnimation = pick(chart.options.chart.animation, stateOptions.animation);\n const opacity = pointAttribs.opacity;\n // Some inactive points (e.g. slices in pie) should apply\n // opacity also for their labels\n if (series.options.inactiveOtherPoints && isNumber(opacity)) {\n (point.dataLabels || []).forEach(function (label) {\n if (label &&\n !label.hasClass('highcharts-data-label-hidden')) {\n label.animate({ opacity }, pointAttribsAnimation);\n }\n });\n if (point.connector) {\n point.connector.animate({ opacity }, pointAttribsAnimation);\n }\n }\n point.graphic.animate(pointAttribs, pointAttribsAnimation);\n }\n if (markerAttribs) {\n point.graphic.animate(markerAttribs, pick(\n // Turn off globally:\n chart.options.chart.animation, markerStateOptions.animation, markerOptions.animation));\n }\n // Zooming in from a range with no markers to a range with markers\n if (stateMarkerGraphic) {\n stateMarkerGraphic.hide();\n }\n }\n else {\n // if a graphic is not applied to each point in the normal state,\n // create a shared graphic for the hover state\n if (state && markerStateOptions) {\n newSymbol = pointMarker.symbol || series.symbol;\n // If the point has another symbol than the previous one, throw\n // away the state marker graphic and force a new one (#1459)\n if (stateMarkerGraphic &&\n stateMarkerGraphic.currentSymbol !== newSymbol) {\n stateMarkerGraphic = stateMarkerGraphic.destroy();\n }\n // Add a new state marker graphic\n if (markerAttribs) {\n if (!stateMarkerGraphic) {\n if (newSymbol) {\n series.stateMarkerGraphic = stateMarkerGraphic =\n chart.renderer\n .symbol(newSymbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height)\n .add(series.markerGroup);\n stateMarkerGraphic.currentSymbol = newSymbol;\n }\n // Move the existing graphic\n }\n else {\n stateMarkerGraphic[move ? 'animate' : 'attr']({\n x: markerAttribs.x,\n y: markerAttribs.y\n });\n }\n }\n if (!chart.styledMode && stateMarkerGraphic &&\n point.state !== 'inactive') {\n stateMarkerGraphic.attr(series.pointAttribs(point, state));\n }\n }\n if (stateMarkerGraphic) {\n stateMarkerGraphic[state && point.isInside ? 'show' : 'hide'](); // #2450\n stateMarkerGraphic.element.point = point; // #4310\n stateMarkerGraphic.addClass(point.getClassName(), true);\n }\n }\n // Show me your halo\n const haloOptions = stateOptions.halo;\n const markerGraphic = (point.graphic || stateMarkerGraphic);\n const markerVisibility = (markerGraphic && markerGraphic.visibility || 'inherit');\n if (haloOptions &&\n haloOptions.size &&\n markerGraphic &&\n markerVisibility !== 'hidden' &&\n !point.isCluster) {\n if (!halo) {\n series.halo = halo = chart.renderer.path()\n // #5818, #5903, #6705\n .add(markerGraphic.parentGroup);\n }\n halo.show()[move ? 'animate' : 'attr']({\n d: point.haloPath(haloOptions.size)\n });\n halo.attr({\n 'class': 'highcharts-halo highcharts-color-' +\n pick(point.colorIndex, series.colorIndex) +\n (point.className ? ' ' + point.className : ''),\n 'visibility': markerVisibility,\n 'zIndex': -1 // #4929, #8276\n });\n halo.point = point; // #6055\n if (!chart.styledMode) {\n halo.attr(extend({\n 'fill': point.color || series.color,\n 'fill-opacity': haloOptions.opacity\n }, AST.filterUserAttributes(haloOptions.attributes || {})));\n }\n }\n else if (halo && halo.point && halo.point.haloPath) {\n // Animate back to 0 on the current halo point (#6055)\n halo.animate({ d: halo.point.haloPath(0) }, null, \n // Hide after unhovering. The `complete` callback runs in the\n // halo's context (#7681).\n halo.hide);\n }\n fireEvent(point, 'afterSetState', { state });\n }\n /**\n * Get the path definition for the halo, which is usually a shadow-like\n * circle around the currently hovered point.\n *\n * @function Highcharts.Point#haloPath\n *\n * @param {number} size\n * The radius of the circular halo.\n *\n * @return {Highcharts.SVGPathArray}\n * The path definition.\n */\n haloPath(size) {\n const pos = this.pos();\n return pos ? this.series.chart.renderer.symbols.circle(Math.floor(pos[0]) - size, pos[1] - size, size * 2, size * 2) : [];\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Function callback when a series point is clicked. Return false to cancel the\n * action.\n *\n * @callback Highcharts.PointClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point where the event occured.\n *\n * @param {Highcharts.PointClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series point.\n *\n * @interface Highcharts.PointClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Clicked point.\n * @name Highcharts.PointClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Configuration for the data label and tooltip formatters.\n *\n * @interface Highcharts.PointLabelObject\n */ /**\n * The point's current color.\n * @name Highcharts.PointLabelObject#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * The point's current color index, used in styled mode instead of `color`. The\n * color index is inserted in class names used for styling.\n * @name Highcharts.PointLabelObject#colorIndex\n * @type {number}\n */ /**\n * The name of the related point.\n * @name Highcharts.PointLabelObject#key\n * @type {string|undefined}\n */ /**\n * The percentage for related points in a stacked series or pies.\n * @name Highcharts.PointLabelObject#percentage\n * @type {number}\n */ /**\n * The related point. The point name, if defined, is available through\n * `this.point.name`.\n * @name Highcharts.PointLabelObject#point\n * @type {Highcharts.Point}\n */ /**\n * The related series. The series name is available through `this.series.name`.\n * @name Highcharts.PointLabelObject#series\n * @type {Highcharts.Series}\n */ /**\n * The total of values in either a stack for stacked series, or a pie in a pie\n * series.\n * @name Highcharts.PointLabelObject#total\n * @type {number|undefined}\n */ /**\n * For categorized axes this property holds the category name for the point. For\n * other axes it holds the X value.\n * @name Highcharts.PointLabelObject#x\n * @type {number|string|undefined}\n */ /**\n * The y value of the point.\n * @name Highcharts.PointLabelObject#y\n * @type {number|null|undefined}\n */\n /**\n * Gets fired when the mouse leaves the area close to the point.\n *\n * @callback Highcharts.PointMouseOutCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the area close to the point.\n *\n * @callback Highcharts.PointMouseOverCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * The generic point options for all series.\n *\n * In TypeScript you have to extend `PointOptionsObject` with an additional\n * declaration to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @interface Highcharts.PointOptionsObject\n */\n /**\n * Possible option types for a data point. Use `null` to indicate a gap.\n *\n * @typedef {number|string|Highcharts.PointOptionsObject|Array<(number|string|null)>|null} Highcharts.PointOptionsType\n */\n /**\n * Gets fired when the point is removed using the `.remove()` method.\n *\n * @callback Highcharts.PointRemoveCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the point state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.PointStateValue\n */\n /**\n * Gets fired when the point is updated programmatically through the `.update()`\n * method.\n *\n * @callback Highcharts.PointUpdateCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointUpdateEventObject} event\n * Event that occured.\n */\n /**\n * Information about the update event.\n *\n * @interface Highcharts.PointUpdateEventObject\n * @extends global.Event\n */ /**\n * Options data of the update event.\n * @name Highcharts.PointUpdateEventObject#options\n * @type {Highcharts.PointOptionsType}\n */\n /**\n * @interface Highcharts.PointEventsOptionsObject\n */ /**\n * Fires when the point is selected either programmatically or following a click\n * on the point. One parameter, `event`, is passed to the function. Returning\n * `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#select\n * @type {Highcharts.PointSelectCallbackFunction|undefined}\n */ /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point. One parameter, `event`, is passed to the function.\n * Returning `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#unselect\n * @type {Highcharts.PointUnselectCallbackFunction|undefined}\n */\n /**\n * Information about the select/unselect event.\n *\n * @interface Highcharts.PointInteractionEventObject\n * @extends global.Event\n */ /**\n * @name Highcharts.PointInteractionEventObject#accumulate\n * @type {boolean}\n */\n /**\n * Gets fired when the point is selected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointSelectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointUnselectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n ''; // keeps doclets above in JS file.\n\n return Point;\n });\n _registerModule(_modules, 'Core/Pointer.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { charts, noop } = H;\n const { addEvent, attr, css, defined, extend, find, fireEvent, isNumber, isObject, objectEach, offset, pick, splat } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The mouse and touch tracker object. Each {@link Chart} item has one\n * associated Pointer item that can be accessed from the {@link Chart.pointer}\n * property.\n *\n * @class\n * @name Highcharts.Pointer\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and tooltip\n * structures.\n */\n class Pointer {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, options) {\n this.lastValidTouch = {};\n this.pinchDown = [];\n this.runChartClick = false;\n this.eventsToUnbind = [];\n this.chart = chart;\n this.hasDragged = false;\n this.options = options;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set inactive state to all series that are not currently hovered,\n * or, if `inactiveOtherPoints` is set to true, set inactive state to\n * all points within that series.\n *\n * @private\n * @function Highcharts.Pointer#applyInactiveState\n *\n * @param {Array} points\n * Currently hovered points\n */\n applyInactiveState(points) {\n let activeSeries = [], series;\n // Get all active series from the hovered points\n (points || []).forEach(function (item) {\n series = item.series;\n // Include itself\n activeSeries.push(series);\n // Include parent series\n if (series.linkedParent) {\n activeSeries.push(series.linkedParent);\n }\n // Include all child series\n if (series.linkedSeries) {\n activeSeries = activeSeries.concat(series.linkedSeries);\n }\n // Include navigator series\n if (series.navigatorSeries) {\n activeSeries.push(series.navigatorSeries);\n }\n });\n // Now loop over all series, filtering out active series\n this.chart.series.forEach(function (inactiveSeries) {\n if (activeSeries.indexOf(inactiveSeries) === -1) {\n // Inactive series\n inactiveSeries.setState('inactive', true);\n }\n else if (inactiveSeries.options.inactiveOtherPoints) {\n // Active series, but other points should be inactivated\n inactiveSeries.setAllPointsToState('inactive');\n }\n });\n }\n /**\n * Destroys the Pointer object and disconnects DOM events.\n *\n * @function Highcharts.Pointer#destroy\n */\n destroy() {\n const pointer = this;\n this.eventsToUnbind.forEach((unbind) => unbind());\n this.eventsToUnbind = [];\n if (!H.chartCount) {\n if (Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = Pointer.unbindDocumentMouseUp();\n }\n if (Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = (Pointer.unbindDocumentTouchEnd());\n }\n }\n // memory and CPU leak\n clearInterval(pointer.tooltipTimeout);\n objectEach(pointer, function (_val, prop) {\n pointer[prop] = void 0;\n });\n }\n /**\n * Calculate attrs for selection marker.\n * @private\n * @function Highcharts.Pointer#getSelectionMarkerAttrs\n * @emits getSelectionMarkerAttrs\n */\n getSelectionMarkerAttrs(chartX, chartY) {\n const e = {\n args: { chartX, chartY },\n attrs: {},\n shapeType: 'rect'\n };\n fireEvent(this, 'getSelectionMarkerAttrs', e, (e) => {\n const { chart, mouseDownX = 0, mouseDownY = 0, zoomHor, zoomVert } = this, attrs = e.attrs;\n let size;\n attrs.x = chart.plotLeft;\n attrs.y = chart.plotTop;\n attrs.width = zoomHor ? 1 : chart.plotWidth;\n attrs.height = zoomVert ? 1 : chart.plotHeight;\n // Adjust the width of the selection marker\n if (zoomHor) {\n size = chartX - mouseDownX;\n attrs.width = Math.abs(size);\n attrs.x = (size > 0 ? 0 : size) + mouseDownX;\n }\n // Adjust the height of the selection marker\n if (zoomVert) {\n size = chartY - mouseDownY;\n attrs.height = Math.abs(size);\n attrs.y = (size > 0 ? 0 : size) + mouseDownY;\n }\n });\n return e;\n }\n /**\n * Perform a drag operation in response to a mousemove event while the mouse\n * is down.\n * @private\n * @function Highcharts.Pointer#drag\n */\n drag(e) {\n const chart = this.chart, chartOptions = chart.options.chart, plotLeft = chart.plotLeft, plotTop = chart.plotTop, plotWidth = chart.plotWidth, plotHeight = chart.plotHeight, mouseDownX = (this.mouseDownX || 0), mouseDownY = (this.mouseDownY || 0), panningEnabled = isObject(chartOptions.panning) ?\n chartOptions.panning && chartOptions.panning.enabled :\n chartOptions.panning, panKey = (chartOptions.panKey && e[chartOptions.panKey + 'Key']);\n let chartX = e.chartX, chartY = e.chartY, clickedInside, selectionMarker = this.selectionMarker;\n // If the device supports both touch and mouse (like IE11), and we are\n // touch-dragging inside the plot area, don't handle the mouse event.\n // #4339.\n if (selectionMarker && selectionMarker.touch) {\n return;\n }\n // If the mouse is outside the plot area, adjust to coordinates\n // inside to prevent the selection marker from going outside\n if (chartX < plotLeft) {\n chartX = plotLeft;\n }\n else if (chartX > plotLeft + plotWidth) {\n chartX = plotLeft + plotWidth;\n }\n if (chartY < plotTop) {\n chartY = plotTop;\n }\n else if (chartY > plotTop + plotHeight) {\n chartY = plotTop + plotHeight;\n }\n // determine if the mouse has moved more than 10px\n this.hasDragged = Math.sqrt(Math.pow(mouseDownX - chartX, 2) +\n Math.pow(mouseDownY - chartY, 2));\n if (this.hasDragged > 10) {\n clickedInside = chart.isInsidePlot(mouseDownX - plotLeft, mouseDownY - plotTop, {\n visiblePlotOnly: true\n });\n const { shapeType, attrs } = this.getSelectionMarkerAttrs(chartX, chartY);\n // make a selection\n if ((chart.hasCartesianSeries || chart.mapView) &&\n (this.zoomX || this.zoomY) &&\n clickedInside &&\n !panKey) {\n if (!selectionMarker) {\n this.selectionMarker = selectionMarker =\n chart.renderer[shapeType]();\n selectionMarker\n .attr({\n 'class': 'highcharts-selection-marker',\n zIndex: 7\n })\n .add();\n if (!chart.styledMode) {\n selectionMarker.attr({\n fill: chartOptions.selectionMarkerFill ||\n color(\"#334eff\" /* Palette.highlightColor80 */)\n .setOpacity(0.25).get()\n });\n }\n }\n }\n if (selectionMarker) {\n selectionMarker.attr(attrs);\n }\n // panning\n if (clickedInside &&\n !selectionMarker &&\n panningEnabled) {\n chart.pan(e, chartOptions.panning);\n }\n }\n }\n /**\n * Start a drag operation.\n * @private\n * @function Highcharts.Pointer#dragStart\n */\n dragStart(e) {\n const chart = this.chart;\n // Record the start position\n chart.mouseIsDown = e.type;\n chart.cancelClick = false;\n chart.mouseDownX = this.mouseDownX = e.chartX;\n chart.mouseDownY = this.mouseDownY = e.chartY;\n }\n /**\n * Get selection box to calculate extremes\n * @private\n * @function Highcharts.Pointer#getSelectionBox\n * @emits getSelectionBox\n */\n getSelectionBox(marker) {\n const e = {\n args: { marker },\n result: {}\n };\n fireEvent(this, 'getSelectionBox', e, (e) => {\n e.result = {\n x: marker.attr ? +marker.attr('x') : marker.x,\n y: marker.attr ? +marker.attr('y') : marker.y,\n width: marker.attr ? marker.attr('width') : marker.width,\n height: marker.attr ? marker.attr('height') : marker.height\n };\n });\n return e.result;\n }\n /**\n * On mouse up or touch end across the entire document, drop the selection.\n * @private\n * @function Highcharts.Pointer#drop\n */\n drop(e) {\n const pointer = this, chart = this.chart, hasPinched = this.hasPinched;\n if (this.selectionMarker) {\n const { x, y, width, height } = this.getSelectionBox(this.selectionMarker);\n const selectionData = {\n originalEvent: e,\n xAxis: [],\n yAxis: [],\n x,\n y,\n width,\n height\n };\n // Start by false runZoom, unless when we have a mapView, in\n // which case the zoom will be handled in the selection event.\n let runZoom = Boolean(chart.mapView);\n // a selection has been made\n if (this.hasDragged || hasPinched) {\n // record each axis' min and max\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled &&\n defined(axis.min) &&\n (hasPinched ||\n pointer[{\n xAxis: 'zoomX',\n yAxis: 'zoomY'\n }[axis.coll]]) &&\n isNumber(x) &&\n isNumber(y) &&\n isNumber(width) &&\n isNumber(height)) { // #859, #3569\n const horiz = axis.horiz, minPixelPadding = e.type === 'touchend' ?\n axis.minPixelPadding :\n 0, // #1207, #3075\n selectionMin = axis.toValue((horiz ? x : y) + minPixelPadding), selectionMax = axis.toValue((horiz ? x + width : y + height) -\n minPixelPadding);\n selectionData[axis.coll].push({\n axis: axis,\n // Min/max for reversed axes\n min: Math.min(selectionMin, selectionMax),\n max: Math.max(selectionMin, selectionMax)\n });\n runZoom = true;\n }\n });\n if (runZoom) {\n fireEvent(chart, 'selection', selectionData, function (args) {\n chart.zoom(extend(args, hasPinched ?\n { animation: false } :\n null));\n });\n }\n }\n if (isNumber(chart.index)) {\n this.selectionMarker = this.selectionMarker.destroy();\n }\n // Reset scaling preview\n if (hasPinched) {\n this.scaleGroups();\n }\n }\n // Reset all. Check isNumber because it may be destroyed on mouse up\n // (#877)\n if (chart && isNumber(chart.index)) {\n css(chart.container, { cursor: chart._cursor });\n chart.cancelClick = this.hasDragged > 10; // #370\n chart.mouseIsDown = this.hasDragged = this.hasPinched = false;\n this.pinchDown = [];\n }\n }\n /**\n * Finds the closest point to a set of coordinates, using the k-d-tree\n * algorithm.\n *\n * @function Highcharts.Pointer#findNearestKDPoint\n *\n * @param {Array} series\n * All the series to search in.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} e\n * The pointer event object, containing chart coordinates of the pointer.\n *\n * @return {Highcharts.Point|undefined}\n * The point closest to given coordinates.\n */\n findNearestKDPoint(series, shared, e) {\n let closest;\n /** @private */\n function sort(p1, p2) {\n const isCloserX = p1.distX - p2.distX, isCloser = p1.dist - p2.dist, isAbove = ((p2.series.group && p2.series.group.zIndex) -\n (p1.series.group && p1.series.group.zIndex));\n let result;\n // We have two points which are not in the same place on xAxis\n // and shared tooltip:\n if (isCloserX !== 0 && shared) { // #5721\n result = isCloserX;\n // Points are not exactly in the same place on x/yAxis:\n }\n else if (isCloser !== 0) {\n result = isCloser;\n // The same xAxis and yAxis position, sort by z-index:\n }\n else if (isAbove !== 0) {\n result = isAbove;\n // The same zIndex, sort by array index:\n }\n else {\n result =\n p1.series.index > p2.series.index ?\n -1 :\n 1;\n }\n return result;\n }\n series.forEach(function (s) {\n const noSharedTooltip = s.noSharedTooltip && shared, compareX = (!noSharedTooltip &&\n s.options.findNearestPointBy.indexOf('y') < 0), point = s.searchPoint(e, compareX);\n if ( // Check that we actually found a point on the series.\n isObject(point, true) && point.series &&\n // Use the new point if it is closer.\n (!isObject(closest, true) ||\n (sort(closest, point) > 0))) {\n closest = point;\n }\n });\n return closest;\n }\n /**\n * @private\n * @function Highcharts.Pointer#getChartCoordinatesFromPoint\n */\n getChartCoordinatesFromPoint(point, inverted) {\n const series = point.series, xAxis = series.xAxis, yAxis = series.yAxis, shapeArgs = point.shapeArgs;\n if (xAxis && yAxis) {\n let x = pick(point.clientX, point.plotX);\n let y = point.plotY || 0;\n if (point.isNode &&\n shapeArgs &&\n isNumber(shapeArgs.x) &&\n isNumber(shapeArgs.y)) {\n x = shapeArgs.x;\n y = shapeArgs.y;\n }\n return inverted ? {\n chartX: yAxis.len + yAxis.pos - y,\n chartY: xAxis.len + xAxis.pos - x\n } : {\n chartX: x + xAxis.pos,\n chartY: y + yAxis.pos\n };\n }\n if (shapeArgs && shapeArgs.x && shapeArgs.y) {\n // E.g. pies do not have axes\n return {\n chartX: shapeArgs.x,\n chartY: shapeArgs.y\n };\n }\n }\n /**\n * Return the cached chartPosition if it is available on the Pointer,\n * otherwise find it. Running offset is quite expensive, so it should be\n * avoided when we know the chart hasn't moved.\n *\n * @function Highcharts.Pointer#getChartPosition\n *\n * @return {Highcharts.ChartPositionObject}\n * The offset of the chart container within the page\n */\n getChartPosition() {\n if (this.chartPosition) {\n return this.chartPosition;\n }\n const { container } = this.chart;\n const pos = offset(container);\n this.chartPosition = {\n left: pos.left,\n top: pos.top,\n scaleX: 1,\n scaleY: 1\n };\n const offsetWidth = container.offsetWidth;\n const offsetHeight = container.offsetHeight;\n // #13342 - tooltip was not visible in Chrome, when chart\n // updates height.\n if (offsetWidth > 2 && // #13342\n offsetHeight > 2 // #13342\n ) {\n this.chartPosition.scaleX = pos.width / offsetWidth;\n this.chartPosition.scaleY = pos.height / offsetHeight;\n }\n return this.chartPosition;\n }\n /**\n * Get the click position in terms of axis values.\n *\n * @function Highcharts.Pointer#getCoordinates\n *\n * @param {Highcharts.PointerEventObject} e\n * Pointer event, extended with `chartX` and `chartY` properties.\n *\n * @return {Highcharts.PointerAxisCoordinatesObject}\n * Axis coordinates.\n */\n getCoordinates(e) {\n const coordinates = {\n xAxis: [],\n yAxis: []\n };\n this.chart.axes.forEach(function (axis) {\n coordinates[axis.isXAxis ? 'xAxis' : 'yAxis'].push({\n axis: axis,\n value: axis.toValue(e[axis.horiz ? 'chartX' : 'chartY'])\n });\n });\n return coordinates;\n }\n /**\n * Calculates what is the current hovered point/points and series.\n *\n * @private\n * @function Highcharts.Pointer#getHoverData\n *\n * @param {Highcharts.Point|undefined} existingHoverPoint\n * The point currently being hovered.\n *\n * @param {Highcharts.Series|undefined} existingHoverSeries\n * The series currently being hovered.\n *\n * @param {Array} series\n * All the series in the chart.\n *\n * @param {boolean} isDirectTouch\n * Is the pointer directly hovering the point.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The triggering event, containing chart coordinates of the pointer.\n *\n * @return {Object}\n * Object containing resulting hover data: hoverPoint, hoverSeries, and\n * hoverPoints.\n */\n getHoverData(existingHoverPoint, existingHoverSeries, series, isDirectTouch, shared, e) {\n const hoverPoints = [], useExisting = !!(isDirectTouch && existingHoverPoint), filter = function (s) {\n return (s.visible &&\n !(!shared && s.directTouch) && // #3821\n pick(s.options.enableMouseTracking, true));\n };\n let hoverSeries = existingHoverSeries, \n // Which series to look in for the hover point\n searchSeries, \n // Parameters needed for beforeGetHoverData event.\n eventArgs = {\n chartX: e ? e.chartX : void 0,\n chartY: e ? e.chartY : void 0,\n shared: shared\n };\n // Find chart.hoverPane and update filter method in polar.\n fireEvent(this, 'beforeGetHoverData', eventArgs);\n const notSticky = hoverSeries && !hoverSeries.stickyTracking;\n searchSeries = notSticky ?\n // Only search on hovered series if it has stickyTracking false\n [hoverSeries] :\n // Filter what series to look in.\n series.filter((s) => s.stickyTracking &&\n (eventArgs.filter || filter)(s));\n // Use existing hovered point or find the one closest to coordinates.\n const hoverPoint = useExisting || !e ?\n existingHoverPoint :\n this.findNearestKDPoint(searchSeries, shared, e);\n // Assign hover series\n hoverSeries = hoverPoint && hoverPoint.series;\n // If we have a hoverPoint, assign hoverPoints.\n if (hoverPoint) {\n // When tooltip is shared, it displays more than one point\n if (shared && !hoverSeries.noSharedTooltip) {\n searchSeries = series.filter(function (s) {\n return eventArgs.filter ?\n eventArgs.filter(s) : filter(s) && !s.noSharedTooltip;\n });\n // Get all points with the same x value as the hoverPoint\n searchSeries.forEach(function (s) {\n let point = find(s.points, function (p) {\n return p.x === hoverPoint.x && !p.isNull;\n });\n if (isObject(point)) {\n /*\n * Boost returns a minimal point. Convert it to a usable\n * point for tooltip and states.\n */\n if (s.boosted && s.boost) {\n point = s.boost.getPoint(point);\n }\n hoverPoints.push(point);\n }\n });\n }\n else {\n hoverPoints.push(hoverPoint);\n }\n }\n // Check whether the hoverPoint is inside pane we are hovering over.\n eventArgs = { hoverPoint: hoverPoint };\n fireEvent(this, 'afterGetHoverData', eventArgs);\n return {\n hoverPoint: eventArgs.hoverPoint,\n hoverSeries: hoverSeries,\n hoverPoints: hoverPoints\n };\n }\n /**\n * @private\n * @function Highcharts.Pointer#getPointFromEvent\n */\n getPointFromEvent(e) {\n let target = e.target, point;\n while (target && !point) {\n point = target.point;\n target = target.parentNode;\n }\n return point;\n }\n /**\n * @private\n * @function Highcharts.Pointer#onTrackerMouseOut\n */\n onTrackerMouseOut(e) {\n const chart = this.chart;\n const relatedTarget = e.relatedTarget;\n const series = chart.hoverSeries;\n this.isDirectTouch = false;\n if (series &&\n relatedTarget &&\n !series.stickyTracking &&\n !this.inClass(relatedTarget, 'highcharts-tooltip') &&\n (!this.inClass(relatedTarget, 'highcharts-series-' + series.index) || // #2499, #4465, #5553\n !this.inClass(relatedTarget, 'highcharts-tracker'))) {\n series.onMouseOut();\n }\n }\n /**\n * Utility to detect whether an element has, or has a parent with, a\n * specific class name. Used on detection of tracker objects and on deciding\n * whether hovering the tooltip should cause the active series to mouse out.\n *\n * @function Highcharts.Pointer#inClass\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The element to investigate.\n *\n * @param {string} className\n * The class name to look for.\n *\n * @return {boolean|undefined}\n * True if either the element or one of its parents has the given class\n * name.\n */\n inClass(element, className) {\n let elem = element, elemClassName;\n while (elem) {\n elemClassName = attr(elem, 'class');\n if (elemClassName) {\n if (elemClassName.indexOf(className) !== -1) {\n return true;\n }\n if (elemClassName.indexOf('highcharts-container') !== -1) {\n return false;\n }\n }\n elem = elem.parentElement;\n }\n }\n /**\n * Initialize the Pointer.\n *\n * @private\n * @function Highcharts.Pointer#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and\n * tooltip structures.\n */\n init(chart, options) {\n // Store references\n this.options = options;\n this.chart = chart;\n // Do we need to handle click on a touch device?\n this.runChartClick = Boolean(options.chart.events && options.chart.events.click);\n this.pinchDown = [];\n this.lastValidTouch = {};\n this.setDOMEvents();\n fireEvent(this, 'afterInit');\n }\n /**\n * Takes a browser event object and extends it with custom Highcharts\n * properties `chartX` and `chartY` in order to work on the internal\n * coordinate system.\n *\n * On map charts, the properties `lon` and `lat` are added to the event\n * object given that the chart has projection information.\n *\n * @function Highcharts.Pointer#normalize\n *\n * @param {global.MouseEvent|global.PointerEvent|global.TouchEvent} e\n * Event object in standard browsers.\n *\n * @param {Highcharts.OffsetObject} [chartPosition]\n * Additional chart offset.\n *\n * @return {Highcharts.PointerEventObject}\n * A browser event with extended properties `chartX` and `chartY`.\n */\n normalize(e, chartPosition) {\n const touches = e.touches;\n // iOS (#2757)\n const ePos = (touches ?\n touches.length ?\n touches.item(0) :\n (pick(// #13534\n touches.changedTouches, e.changedTouches))[0] :\n e);\n // Get mouse position\n if (!chartPosition) {\n chartPosition = this.getChartPosition();\n }\n let chartX = ePos.pageX - chartPosition.left, chartY = ePos.pageY - chartPosition.top;\n // #11329 - when there is scaling on a parent element, we need to take\n // this into account\n chartX /= chartPosition.scaleX;\n chartY /= chartPosition.scaleY;\n return extend(e, {\n chartX: Math.round(chartX),\n chartY: Math.round(chartY)\n });\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerClick\n */\n onContainerClick(e) {\n const chart = this.chart;\n const hoverPoint = chart.hoverPoint;\n const pEvt = this.normalize(e);\n const plotLeft = chart.plotLeft;\n const plotTop = chart.plotTop;\n if (!chart.cancelClick) {\n // On tracker click, fire the series and point events. #783, #1583\n if (hoverPoint &&\n this.inClass(pEvt.target, 'highcharts-tracker')) {\n // the series click event\n fireEvent(hoverPoint.series, 'click', extend(pEvt, {\n point: hoverPoint\n }));\n // the point click event\n if (chart.hoverPoint) { // it may be destroyed (#1844)\n hoverPoint.firePointEvent('click', pEvt);\n }\n // When clicking outside a tracker, fire a chart event\n }\n else {\n extend(pEvt, this.getCoordinates(pEvt));\n // fire a click event in the chart\n if (chart.isInsidePlot(pEvt.chartX - plotLeft, pEvt.chartY - plotTop, {\n visiblePlotOnly: true\n })) {\n fireEvent(chart, 'click', pEvt);\n }\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerMouseDown\n */\n onContainerMouseDown(e) {\n const isPrimaryButton = ((e.buttons || e.button) & 1) === 1;\n e = this.normalize(e);\n // #11635, Firefox does not reliably fire move event after click scroll\n if (H.isFirefox &&\n e.button !== 0) {\n this.onContainerMouseMove(e);\n }\n // #11635, limiting to primary button\n if (typeof e.button === 'undefined' ||\n isPrimaryButton) {\n this.zoomOption(e);\n // #295, #13737 solve conflict between container drag and chart zoom\n if (isPrimaryButton &&\n e.preventDefault) {\n e.preventDefault();\n }\n this.dragStart(e);\n }\n }\n /**\n * When mouse leaves the container, hide the tooltip.\n * @private\n * @function Highcharts.Pointer#onContainerMouseLeave\n */\n onContainerMouseLeave(e) {\n const chart = charts[pick(Pointer.hoverChartIndex, -1)];\n e = this.normalize(e);\n // #4886, MS Touch end fires mouseleave but with no related target\n if (chart &&\n e.relatedTarget &&\n !this.inClass(e.relatedTarget, 'highcharts-tooltip')) {\n chart.pointer.reset();\n // Also reset the chart position, used in #149 fix\n chart.pointer.chartPosition = void 0;\n }\n }\n /**\n * When mouse enters the container, delete pointer's chartPosition.\n * @private\n * @function Highcharts.Pointer#onContainerMouseEnter\n */\n onContainerMouseEnter(e) {\n delete this.chartPosition;\n }\n /**\n * The mousemove, touchmove and touchstart event handler\n * @private\n * @function Highcharts.Pointer#onContainerMouseMove\n */\n onContainerMouseMove(e) {\n const chart = this.chart, tooltip = chart.tooltip, pEvt = this.normalize(e);\n this.setHoverChartIndex();\n if (chart.mouseIsDown === 'mousedown' || this.touchSelect(pEvt)) {\n this.drag(pEvt);\n }\n // Show the tooltip and run mouse over events (#977)\n if (!chart.openMenu &&\n (this.inClass(pEvt.target, 'highcharts-tracker') ||\n chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n })) &&\n // If the tooltip has stickOnContact enabled, do nothing. This\n // applies regardless of any combinations of the `split` and\n // `useHTML` options.\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt))) {\n if (this.inClass(pEvt.target, 'highcharts-no-tooltip')) {\n this.reset(false, 0);\n }\n else {\n this.runPointActions(pEvt);\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentTouchEnd\n */\n onDocumentTouchEnd(e) {\n const hoverChart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart) {\n hoverChart.pointer.drop(e);\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchMove\n */\n onContainerTouchMove(e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseMove(e);\n }\n else {\n this.touch(e);\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchStart\n */\n onContainerTouchStart(e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseDown(e);\n }\n else {\n this.zoomOption(e);\n this.touch(e, true);\n }\n }\n /**\n * Special handler for mouse move that will hide the tooltip when the mouse\n * leaves the plotarea. Issue #149 workaround. The mouseleave event does not\n * always fire.\n * @private\n * @function Highcharts.Pointer#onDocumentMouseMove\n */\n onDocumentMouseMove(e) {\n const chart = this.chart;\n const tooltip = chart.tooltip;\n const chartPosition = this.chartPosition;\n const pEvt = this.normalize(e, chartPosition);\n // If we're outside, hide the tooltip\n if (chartPosition &&\n !chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n }) &&\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt)) &&\n !this.inClass(pEvt.target, 'highcharts-tracker')) {\n this.reset();\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentMouseUp\n */\n onDocumentMouseUp(e) {\n const chart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (chart) {\n chart.pointer.drop(e);\n }\n }\n /**\n * Handle touch events with two touches\n * @private\n * @function Highcharts.Pointer#pinch\n */\n pinch(e) {\n const self = this, chart = self.chart, pinchDown = self.pinchDown, touches = (e.touches || []), touchesLength = touches.length, lastValidTouch = self.lastValidTouch, hasZoom = self.hasZoom, transform = {}, fireClickEvent = touchesLength === 1 && ((self.inClass(e.target, 'highcharts-tracker') &&\n chart.runTrackerClick) ||\n self.runChartClick), clip = {}, tooltip = self.chart.tooltip, followTouchMove = touchesLength === 1 &&\n pick((tooltip && tooltip.options.followTouchMove), true);\n let selectionMarker = self.selectionMarker;\n // Don't initiate panning until the user has pinched. This prevents us\n // from blocking page scrolling as users scroll down a long page\n // (#4210).\n if (touchesLength > 1) {\n self.initiated = true;\n }\n else if (followTouchMove) {\n // #16119: Prevent blocking scroll when single-finger panning is\n // not enabled\n self.initiated = false;\n }\n // On touch devices, only proceed to trigger click if a handler is\n // defined\n if (hasZoom &&\n self.initiated &&\n !fireClickEvent &&\n e.cancelable !== false) {\n e.preventDefault();\n }\n // Normalize each touch\n [].map.call(touches, function (e) {\n return self.normalize(e);\n });\n // Register the touch start position\n if (e.type === 'touchstart') {\n [].forEach.call(touches, function (e, i) {\n pinchDown[i] = { chartX: e.chartX, chartY: e.chartY };\n });\n lastValidTouch.x = [pinchDown[0].chartX, pinchDown[1] &&\n pinchDown[1].chartX];\n lastValidTouch.y = [pinchDown[0].chartY, pinchDown[1] &&\n pinchDown[1].chartY];\n // Identify the data bounds in pixels\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled) {\n const bounds = chart.bounds[axis.horiz ? 'h' : 'v'], minPixelPadding = axis.minPixelPadding, min = axis.toPixels(Math.min(pick(axis.options.min, axis.dataMin), axis.dataMin)), max = axis.toPixels(Math.max(pick(axis.options.max, axis.dataMax), axis.dataMax)), absMin = Math.min(min, max), absMax = Math.max(min, max);\n // Store the bounds for use in the touchmove handler\n bounds.min = Math.min(axis.pos, absMin - minPixelPadding);\n bounds.max = Math.max(axis.pos + axis.len, absMax + minPixelPadding);\n }\n });\n self.res = true; // reset on next move\n // Optionally move the tooltip on touchmove\n }\n else if (followTouchMove) {\n this.runPointActions(self.normalize(e));\n // Event type is touchmove, handle panning and pinching\n }\n else if (pinchDown.length) { // can be 0 when releasing, if touchend\n // fires first\n fireEvent(chart, 'touchpan', { originalEvent: e }, () => {\n // Set the marker\n if (!selectionMarker) {\n // @todo It's a mock object, so maybe we need a separate\n // interface\n self.selectionMarker = selectionMarker = extend({\n destroy: noop,\n touch: true\n }, chart.plotBox);\n }\n self.pinchTranslate(pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n self.hasPinched = hasZoom;\n // Scale and translate the groups to provide visual feedback\n // during pinching\n self.scaleGroups(transform, clip);\n });\n if (self.res) {\n self.res = false;\n this.reset(false, 0);\n }\n }\n }\n /**\n * Run translation operations\n * @private\n * @function Highcharts.Pointer#pinchTranslate\n */\n pinchTranslate(pinchDown, touches, transform, selectionMarker, clip, lastValidTouch) {\n if (this.zoomHor) {\n this.pinchTranslateDirection(true, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n if (this.zoomVert) {\n this.pinchTranslateDirection(false, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n }\n /**\n * Run translation operations for each direction (horizontal and vertical)\n * independently.\n * @private\n * @function Highcharts.Pointer#pinchTranslateDirection\n */\n pinchTranslateDirection(horiz, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch, forcedScale) {\n const chart = this.chart, xy = horiz ? 'x' : 'y', XY = horiz ? 'X' : 'Y', sChartXY = ('chart' + XY), wh = horiz ? 'width' : 'height', plotLeftTop = chart['plot' + (horiz ? 'Left' : 'Top')], inverted = chart.inverted, bounds = chart.bounds[horiz ? 'h' : 'v'], singleTouch = pinchDown.length === 1, touch0Start = pinchDown[0][sChartXY], touch1Start = !singleTouch && pinchDown[1][sChartXY], setScale = function () {\n // Don't zoom if fingers are too close on this axis\n if (typeof touch1Now === 'number' &&\n Math.abs(touch0Start - touch1Start) > 20) {\n scale = forcedScale ||\n Math.abs(touch0Now - touch1Now) /\n Math.abs(touch0Start - touch1Start);\n }\n clipXY = ((plotLeftTop - touch0Now) / scale) + touch0Start;\n selectionWH = chart['plot' + (horiz ? 'Width' : 'Height')] / scale;\n };\n let selectionWH, selectionXY, clipXY, scale = forcedScale || 1, touch0Now = touches[0][sChartXY], touch1Now = !singleTouch && touches[1][sChartXY], outOfBounds;\n // Set the scale, first pass\n setScale();\n // The clip position (x or y) is altered if out of bounds, the selection\n // position is not\n selectionXY = clipXY;\n // Out of bounds\n if (selectionXY < bounds.min) {\n selectionXY = bounds.min;\n outOfBounds = true;\n }\n else if (selectionXY + selectionWH > bounds.max) {\n selectionXY = bounds.max - selectionWH;\n outOfBounds = true;\n }\n // Is the chart dragged off its bounds, determined by dataMin and\n // dataMax?\n if (outOfBounds) {\n // Modify the touchNow position in order to create an elastic drag\n // movement. This indicates to the user that the chart is responsive\n // but can't be dragged further.\n touch0Now -= 0.8 * (touch0Now - lastValidTouch[xy][0]);\n if (typeof touch1Now === 'number') {\n touch1Now -= 0.8 * (touch1Now - lastValidTouch[xy][1]);\n }\n // Set the scale, second pass to adapt to the modified touchNow\n // positions\n setScale();\n }\n else {\n lastValidTouch[xy] = [touch0Now, touch1Now];\n }\n // Set geometry for clipping, selection and transformation\n if (!inverted) {\n clip[xy] = clipXY - plotLeftTop;\n clip[wh] = selectionWH;\n }\n const scaleKey = inverted ?\n (horiz ? 'scaleY' : 'scaleX') : 'scale' + XY;\n const transformScale = inverted ? 1 / scale : scale;\n selectionMarker[wh] = selectionWH;\n selectionMarker[xy] = selectionXY;\n transform[scaleKey] = scale;\n transform['translate' + XY] = (transformScale * plotLeftTop) +\n (touch0Now - (transformScale * touch0Start));\n }\n /**\n * Reset the tracking by hiding the tooltip, the hover series state and the\n * hover point\n *\n * @function Highcharts.Pointer#reset\n *\n * @param {boolean} [allowMove]\n * Instead of destroying the tooltip altogether, allow moving it if\n * possible.\n *\n * @param {number} [delay]\n */\n reset(allowMove, delay) {\n const pointer = this, chart = pointer.chart, hoverSeries = chart.hoverSeries, hoverPoint = chart.hoverPoint, hoverPoints = chart.hoverPoints, tooltip = chart.tooltip, tooltipPoints = tooltip && tooltip.shared ?\n hoverPoints :\n hoverPoint;\n // Check if the points have moved outside the plot area (#1003, #4736,\n // #5101)\n if (allowMove && tooltipPoints) {\n splat(tooltipPoints).forEach(function (point) {\n if (point.series.isCartesian &&\n typeof point.plotX === 'undefined') {\n allowMove = false;\n }\n });\n }\n // Just move the tooltip, #349\n if (allowMove) {\n if (tooltip && tooltipPoints && splat(tooltipPoints).length) {\n tooltip.refresh(tooltipPoints);\n if (tooltip.shared && hoverPoints) { // #8284\n hoverPoints.forEach(function (point) {\n point.setState(point.state, true);\n if (point.series.isCartesian) {\n if (point.series.xAxis.crosshair) {\n point.series.xAxis\n .drawCrosshair(null, point);\n }\n if (point.series.yAxis.crosshair) {\n point.series.yAxis\n .drawCrosshair(null, point);\n }\n }\n });\n }\n else if (hoverPoint) { // #2500\n hoverPoint.setState(hoverPoint.state, true);\n chart.axes.forEach(function (axis) {\n if (axis.crosshair &&\n hoverPoint.series[axis.coll] === axis) {\n axis.drawCrosshair(null, hoverPoint);\n }\n });\n }\n }\n // Full reset\n }\n else {\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n if (hoverSeries) {\n hoverSeries.onMouseOut();\n }\n if (tooltip) {\n tooltip.hide(delay);\n }\n if (pointer.unDocMouseMove) {\n pointer.unDocMouseMove = pointer.unDocMouseMove();\n }\n // Remove crosshairs\n chart.axes.forEach(function (axis) {\n axis.hideCrosshair();\n });\n pointer.hoverX = chart.hoverPoints = chart.hoverPoint = null;\n }\n }\n /**\n * With line type charts with a single tracker, get the point closest to the\n * mouse. Run Point.onMouseOver and display tooltip for the point or points.\n *\n * @private\n * @function Highcharts.Pointer#runPointActions\n *\n * @emits Highcharts.Point#event:mouseOut\n * @emits Highcharts.Point#event:mouseOver\n */\n runPointActions(e, p, force) {\n const pointer = this, chart = pointer.chart, series = chart.series, tooltip = (chart.tooltip && chart.tooltip.options.enabled ?\n chart.tooltip :\n void 0), shared = (tooltip ?\n tooltip.shared :\n false);\n let hoverPoint = p || chart.hoverPoint, hoverSeries = hoverPoint && hoverPoint.series || chart.hoverSeries;\n const // onMouseOver or already hovering a series with directTouch\n isDirectTouch = (!e || e.type !== 'touchmove') && (!!p || ((hoverSeries && hoverSeries.directTouch) &&\n pointer.isDirectTouch)), hoverData = this.getHoverData(hoverPoint, hoverSeries, series, isDirectTouch, shared, e);\n // Update variables from hoverData.\n hoverPoint = hoverData.hoverPoint;\n hoverSeries = hoverData.hoverSeries;\n const points = hoverData.hoverPoints, followPointer = hoverSeries &&\n hoverSeries.tooltipOptions.followPointer &&\n !hoverSeries.tooltipOptions.split, useSharedTooltip = (shared &&\n hoverSeries &&\n !hoverSeries.noSharedTooltip);\n // Refresh tooltip for kdpoint if new hover point or tooltip was hidden\n // #3926, #4200\n if (hoverPoint &&\n (force ||\n hoverPoint !== chart.hoverPoint ||\n (tooltip && tooltip.isHidden))) {\n (chart.hoverPoints || []).forEach(function (p) {\n if (points.indexOf(p) === -1) {\n p.setState();\n }\n });\n // Set normal state to previous series\n if (chart.hoverSeries !== hoverSeries) {\n hoverSeries.onMouseOver();\n }\n pointer.applyInactiveState(points);\n // Do mouseover on all points (#3919, #3985, #4410, #5622)\n (points || []).forEach(function (p) {\n p.setState('hover');\n });\n // If tracking is on series in stead of on each point,\n // fire mouseOver on hover point. // #4448\n if (chart.hoverPoint) {\n chart.hoverPoint.firePointEvent('mouseOut');\n }\n // Hover point may have been destroyed in the event handlers (#7127)\n if (!hoverPoint.series) {\n return;\n }\n /**\n * Contains all hovered points.\n *\n * @name Highcharts.Chart#hoverPoints\n * @type {Array|null}\n */\n chart.hoverPoints = points;\n /**\n * Contains the original hovered point.\n *\n * @name Highcharts.Chart#hoverPoint\n * @type {Highcharts.Point|null}\n */\n chart.hoverPoint = hoverPoint;\n /**\n * Hover state should not be lost when axis is updated (#12569)\n * Axis.update runs pointer.reset which uses chart.hoverPoint.state\n * to apply state which does not exist in hoverPoint yet.\n * The mouseOver event should be triggered when hoverPoint\n * is correct.\n */\n hoverPoint.firePointEvent('mouseOver', void 0, () => {\n // Draw tooltip if necessary\n if (tooltip && hoverPoint) {\n tooltip.refresh(useSharedTooltip ? points : hoverPoint, e);\n }\n });\n // Update positions (regardless of kdpoint or hoverPoint)\n }\n else if (followPointer && tooltip && !tooltip.isHidden) {\n const anchor = tooltip.getAnchor([{}], e);\n if (chart.isInsidePlot(anchor[0], anchor[1], {\n visiblePlotOnly: true\n })) {\n tooltip.updatePosition({ plotX: anchor[0], plotY: anchor[1] });\n }\n }\n // Start the event listener to pick up the tooltip and crosshairs\n if (!pointer.unDocMouseMove) {\n pointer.unDocMouseMove = addEvent(chart.container.ownerDocument, 'mousemove', function (e) {\n const chart = charts[Pointer.hoverChartIndex];\n if (chart) {\n chart.pointer.onDocumentMouseMove(e);\n }\n });\n pointer.eventsToUnbind.push(pointer.unDocMouseMove);\n }\n // Issues related to crosshair #4927, #5269 #5066, #5658\n chart.axes.forEach(function drawAxisCrosshair(axis) {\n const snap = pick((axis.crosshair || {}).snap, true);\n let point;\n if (snap) {\n point = chart.hoverPoint; // #13002\n if (!point || point.series[axis.coll] !== axis) {\n point = find(points, (p) => p.series && p.series[axis.coll] === axis);\n }\n }\n // Axis has snapping crosshairs, and one of the hover points belongs\n // to axis. Always call drawCrosshair when it is not snap.\n if (point || !snap) {\n axis.drawCrosshair(e, point);\n // Axis has snapping crosshairs, but no hover point belongs to axis\n }\n else {\n axis.hideCrosshair();\n }\n });\n }\n /**\n * Scale series groups to a certain scale and translation.\n * @private\n * @function Highcharts.Pointer#scaleGroups\n */\n scaleGroups(attribs, clip) {\n const chart = this.chart;\n // Scale each series\n chart.series.forEach(function (series) {\n const seriesAttribs = attribs || series.getPlotBox(); // #1701\n if (series.group &&\n ((series.xAxis && series.xAxis.zoomEnabled) ||\n chart.mapView)) {\n series.group.attr(seriesAttribs);\n if (series.markerGroup) {\n series.markerGroup.attr(seriesAttribs);\n series.markerGroup.clip(clip ? chart.clipRect : null);\n }\n if (series.dataLabelsGroup) {\n series.dataLabelsGroup.attr(seriesAttribs);\n }\n }\n });\n // Clip\n chart.clipRect.attr(clip || chart.clipBox);\n }\n /**\n * Set the JS DOM events on the container and document. This method should\n * contain a one-to-one assignment between methods and their handlers. Any\n * advanced logic should be moved to the handler reflecting the event's\n * name.\n * @private\n * @function Highcharts.Pointer#setDOMEvents\n */\n setDOMEvents() {\n const container = this.chart.container, ownerDoc = container.ownerDocument;\n container.onmousedown = this.onContainerMouseDown.bind(this);\n container.onmousemove = this.onContainerMouseMove.bind(this);\n container.onclick = this.onContainerClick.bind(this);\n this.eventsToUnbind.push(addEvent(container, 'mouseenter', this.onContainerMouseEnter.bind(this)));\n this.eventsToUnbind.push(addEvent(container, 'mouseleave', this.onContainerMouseLeave.bind(this)));\n if (!Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = addEvent(ownerDoc, 'mouseup', this.onDocumentMouseUp.bind(this));\n }\n // In case we are dealing with overflow, reset the chart position when\n // scrolling parent elements\n let parent = this.chart.renderTo.parentElement;\n while (parent && parent.tagName !== 'BODY') {\n this.eventsToUnbind.push(addEvent(parent, 'scroll', () => {\n delete this.chartPosition;\n }));\n parent = parent.parentElement;\n }\n if (H.hasTouch) {\n this.eventsToUnbind.push(addEvent(container, 'touchstart', this.onContainerTouchStart.bind(this), { passive: false }));\n this.eventsToUnbind.push(addEvent(container, 'touchmove', this.onContainerTouchMove.bind(this), { passive: false }));\n if (!Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = addEvent(ownerDoc, 'touchend', this.onDocumentTouchEnd.bind(this), { passive: false });\n }\n }\n }\n /**\n * Sets the index of the hovered chart and leaves the previous hovered\n * chart, to reset states like tooltip.\n * @private\n * @function Highcharts.Pointer#setHoverChartIndex\n */\n setHoverChartIndex() {\n const chart = this.chart;\n const hoverChart = H.charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart &&\n hoverChart !== chart) {\n hoverChart.pointer.onContainerMouseLeave({ relatedTarget: chart.container });\n }\n if (!hoverChart ||\n !hoverChart.mouseIsDown) {\n Pointer.hoverChartIndex = chart.index;\n }\n }\n /**\n * General touch handler shared by touchstart and touchmove.\n * @private\n * @function Highcharts.Pointer#touch\n */\n touch(e, start) {\n const chart = this.chart;\n let hasMoved, pinchDown, isInside;\n this.setHoverChartIndex();\n if (e.touches.length === 1) {\n e = this.normalize(e);\n isInside = chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop, {\n visiblePlotOnly: true\n });\n if (isInside && !chart.openMenu) {\n // Run mouse events and display tooltip etc\n if (start) {\n this.runPointActions(e);\n }\n // Android fires touchmove events after the touchstart even if\n // the finger hasn't moved, or moved only a pixel or two. In iOS\n // however, the touchmove doesn't fire unless the finger moves\n // more than ~4px. So we emulate this behaviour in Android by\n // checking how much it moved, and cancelling on small\n // distances. #3450.\n if (e.type === 'touchmove') {\n pinchDown = this.pinchDown;\n hasMoved = pinchDown[0] ? Math.sqrt(// #5266\n Math.pow(pinchDown[0].chartX - e.chartX, 2) +\n Math.pow(pinchDown[0].chartY - e.chartY, 2)) >= 4 : false;\n }\n if (pick(hasMoved, true)) {\n this.pinch(e);\n }\n }\n else if (start) {\n // Hide the tooltip on touching outside the plot area (#1203)\n this.reset();\n }\n }\n else if (e.touches.length === 2) {\n this.pinch(e);\n }\n }\n /**\n * Returns true if the chart is set up for zooming by single touch and the\n * event is capable\n * @private\n * @function Highcharts.Pointer#touchSelect\n */\n touchSelect(e) {\n return Boolean(this.chart.zooming.singleTouch &&\n e.touches &&\n e.touches.length === 1);\n }\n /**\n * Resolve the zoomType option, this is reset on all touch start and mouse\n * down events.\n * @private\n * @function Highcharts.Pointer#zoomOption\n */\n zoomOption(e) {\n const chart = this.chart, options = chart.options.chart, inverted = chart.inverted;\n let zoomType = chart.zooming.type || '', zoomX, zoomY;\n // Look for the pinchType option\n if (/touch/.test(e.type)) {\n zoomType = pick(chart.zooming.pinchType, zoomType);\n }\n this.zoomX = zoomX = /x/.test(zoomType);\n this.zoomY = zoomY = /y/.test(zoomType);\n this.zoomHor = (zoomX && !inverted) || (zoomY && inverted);\n this.zoomVert = (zoomY && !inverted) || (zoomX && inverted);\n this.hasZoom = zoomX || zoomY;\n }\n }\n /* *\n *\n * Class Namespace\n *\n * */\n (function (Pointer) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedEvents = [];\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'beforeRender', function () {\n /**\n * The Pointer that keeps track of mouse and touch\n * interaction.\n *\n * @memberof Highcharts.Chart\n * @name pointer\n * @type {Highcharts.Pointer}\n * @instance\n */\n this.pointer = new Pointer(this, this.options);\n });\n }\n }\n Pointer.compose = compose;\n /**\n * @private\n */\n function dissolve() {\n for (let i = 0, iEnd = composedEvents.length; i < iEnd; ++i) {\n composedEvents[i]();\n }\n composedEvents.length = 0;\n }\n Pointer.dissolve = dissolve;\n })(Pointer || (Pointer = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Chart position and scale.\n *\n * @interface Highcharts.ChartPositionObject\n */ /**\n * @name Highcharts.ChartPositionObject#left\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#top\n * @type {number}\n */\n /**\n * One position in relation to an axis.\n *\n * @interface Highcharts.PointerAxisCoordinateObject\n */ /**\n * Related axis.\n *\n * @name Highcharts.PointerAxisCoordinateObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value.\n *\n * @name Highcharts.PointerAxisCoordinateObject#value\n * @type {number}\n */\n /**\n * Positions in terms of axis values.\n *\n * @interface Highcharts.PointerAxisCoordinatesObject\n */ /**\n * Positions on the x-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#xAxis\n * @type {Array}\n */ /**\n * Positions on the y-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#yAxis\n * @type {Array}\n */\n /**\n * Pointer coordinates.\n *\n * @interface Highcharts.PointerCoordinatesObject\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartX\n * @type {number}\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartY\n * @type {number}\n */\n /**\n * A native browser mouse or touch event, extended with position information\n * relative to the {@link Chart.container}.\n *\n * @interface Highcharts.PointerEventObject\n * @extends global.PointerEvent\n */ /**\n * The X coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartX\n * @type {number}\n */ /**\n * The Y coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartY\n * @type {number}\n */\n /**\n * Axis-specific data of a selection.\n *\n * @interface Highcharts.SelectDataObject\n */ /**\n * The selected Axis.\n * @name Highcharts.SelectDataObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The maximum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#min\n * @type {number}\n */\n /**\n * Object for select events.\n * The primary axes are `xAxis[0]` and `yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.SelectEventObject\n */ /**\n * The related browser event.\n * @name Highcharts.SelectEventObject#originalEvent\n * @type {global.Event}\n */ /**\n * Indicates a reset event to restore default state.\n * @name Highcharts.SelectEventObject#resetSelection\n * @type {boolean|undefined}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#xAxis\n * @type {Array}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#yAxis\n * @type {Array}\n */\n ''; // keeps doclets above in JS file\n\n return Pointer;\n });\n _registerModule(_modules, 'Core/Legend/Legend.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Core/Series/Point.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Utilities.js']], function (A, F, H, Point, R, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject, setAnimation } = A;\n const { format } = F;\n const { marginNames } = H;\n const { distribute } = R;\n const { addEvent, createElement, css, defined, discardElement, find, fireEvent, isNumber, merge, pick, relativeLength, stableSort, syncTimeout } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The overview of the chart's series. The legend object is instanciated\n * internally in the chart constructor, and is available from the `chart.legend`\n * property. Each chart has only one legend.\n *\n * @class\n * @name Highcharts.Legend\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n class Legend {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allItems = [];\n this.box = void 0;\n this.contentGroup = void 0;\n this.display = false;\n this.group = void 0;\n this.initialItemY = 0;\n this.itemHeight = 0;\n this.itemMarginBottom = 0;\n this.itemMarginTop = 0;\n this.itemX = 0;\n this.itemY = 0;\n this.lastItemY = 0;\n this.lastLineHeight = 0;\n this.legendHeight = 0;\n this.legendWidth = 0;\n this.maxItemWidth = 0;\n this.maxLegendWidth = 0;\n this.offsetWidth = 0;\n this.options = void 0;\n this.padding = 0;\n this.pages = [];\n this.proximate = false;\n this.scrollGroup = void 0;\n this.symbolHeight = 0;\n this.symbolWidth = 0;\n this.titleHeight = 0;\n this.totalItemWidth = 0;\n this.widthOption = 0;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the legend.\n *\n * @private\n * @function Highcharts.Legend#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n init(chart, options) {\n /**\n * Chart of this legend.\n *\n * @readonly\n * @name Highcharts.Legend#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n this.setOptions(options);\n if (options.enabled) {\n // Render it\n this.render();\n // move checkboxes\n addEvent(this.chart, 'endResize', function () {\n this.legend.positionCheckboxes();\n });\n // On Legend.init and Legend.update, make sure that proximate layout\n // events are either added or removed (#18362).\n addEvent(this.chart, 'render', () => {\n if (this.proximate) {\n this.proximatePositions();\n this.positionItems();\n }\n });\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#setOptions\n * @param {Highcharts.LegendOptions} options\n */\n setOptions(options) {\n const padding = pick(options.padding, 8);\n /**\n * Legend options.\n *\n * @readonly\n * @name Highcharts.Legend#options\n * @type {Highcharts.LegendOptions}\n */\n this.options = options;\n if (!this.chart.styledMode) {\n this.itemStyle = options.itemStyle;\n this.itemHiddenStyle = merge(this.itemStyle, options.itemHiddenStyle);\n }\n this.itemMarginTop = options.itemMarginTop;\n this.itemMarginBottom = options.itemMarginBottom;\n this.padding = padding;\n this.initialItemY = padding - 5; // 5 is pixels above the text\n this.symbolWidth = pick(options.symbolWidth, 16);\n this.pages = [];\n this.proximate = options.layout === 'proximate' && !this.chart.inverted;\n // #12705: baseline has to be reset on every update\n this.baseline = void 0;\n }\n /**\n * Update the legend with new options. Equivalent to running `chart.update`\n * with a legend configuration option.\n *\n * @sample highcharts/legend/legend-update/\n * Legend update\n *\n * @function Highcharts.Legend#update\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after. Whether to redraw the chart.\n *\n * @emits Highcharts.Legends#event:afterUpdate\n */\n update(options, redraw) {\n const chart = this.chart;\n this.setOptions(merge(true, this.options, options));\n this.destroy();\n chart.isDirtyLegend = chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n fireEvent(this, 'afterUpdate');\n }\n /**\n * Set the colors for the legend item.\n *\n * @private\n * @function Highcharts.Legend#colorizeItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * A Series or Point instance\n * @param {boolean} [visible=false]\n * Dimmed or colored\n *\n * @todo\n * Make events official: Fires the event `afterColorizeItem`.\n */\n colorizeItem(item, visible) {\n const { group, label, line, symbol } = item.legendItem || {};\n if (group) {\n group[visible ? 'removeClass' : 'addClass']('highcharts-legend-item-hidden');\n }\n if (!this.chart.styledMode) {\n const { itemHiddenStyle } = this, hiddenColor = itemHiddenStyle.color, symbolColor = visible ?\n (item.color || hiddenColor) :\n hiddenColor, markerOptions = item.options && item.options.marker;\n let symbolAttr = { fill: symbolColor };\n label === null || label === void 0 ? void 0 : label.css(merge(visible ? this.itemStyle : itemHiddenStyle));\n line === null || line === void 0 ? void 0 : line.attr({ stroke: symbolColor });\n if (symbol) {\n // Apply marker options\n if (markerOptions && symbol.isMarker) { // #585\n symbolAttr = item.pointAttribs();\n if (!visible) {\n // #6769\n symbolAttr.stroke = symbolAttr.fill = hiddenColor;\n }\n }\n symbol.attr(symbolAttr);\n }\n }\n fireEvent(this, 'afterColorizeItem', { item, visible });\n }\n /**\n * @private\n * @function Highcharts.Legend#positionItems\n */\n positionItems() {\n // Now that the legend width and height are established, put the items\n // in the final position\n this.allItems.forEach(this.positionItem, this);\n if (!this.chart.isResizing) {\n this.positionCheckboxes();\n }\n }\n /**\n * Position the legend item.\n *\n * @private\n * @function Highcharts.Legend#positionItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to position\n */\n positionItem(item) {\n const legend = this, { group, x = 0, y = 0 } = item.legendItem || {}, options = legend.options, symbolPadding = options.symbolPadding, ltr = !options.rtl, checkbox = item.checkbox;\n if (group && group.element) {\n const attribs = {\n translateX: ltr ?\n x :\n legend.legendWidth - x - 2 * symbolPadding - 4,\n translateY: y\n };\n const complete = () => {\n fireEvent(this, 'afterPositionItem', { item });\n };\n group[defined(group.translateY) ? 'animate' : 'attr'](attribs, void 0, complete);\n }\n if (checkbox) {\n checkbox.x = x;\n checkbox.y = y;\n }\n }\n /**\n * Destroy a single legend item, used internally on removing series items.\n *\n * @private\n * @function Highcharts.Legend#destroyItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to remove\n */\n destroyItem(item) {\n const checkbox = item.checkbox, legendItem = item.legendItem || {};\n // destroy SVG elements\n for (const key of ['group', 'label', 'line', 'symbol']) {\n if (legendItem[key]) {\n legendItem[key] = legendItem[key].destroy();\n }\n }\n if (checkbox) {\n discardElement(checkbox);\n }\n item.legendItem = void 0;\n }\n /**\n * Destroy the legend. Used internally. To reflow objects, `chart.redraw`\n * must be called after destruction.\n *\n * @private\n * @function Highcharts.Legend#destroy\n */\n destroy() {\n const legend = this;\n // Destroy items\n for (const item of this.getAllItems()) {\n this.destroyItem(item);\n }\n // Destroy legend elements\n for (const key of [\n 'clipRect',\n 'up',\n 'down',\n 'pager',\n 'nav',\n 'box',\n 'title',\n 'group'\n ]) {\n if (legend[key]) {\n legend[key] = legend[key].destroy();\n }\n }\n this.display = null; // Reset in .render on update.\n }\n /**\n * Position the checkboxes after the width is determined.\n *\n * @private\n * @function Highcharts.Legend#positionCheckboxes\n */\n positionCheckboxes() {\n const alignAttr = this.group && this.group.alignAttr, clipHeight = this.clipHeight || this.legendHeight, titleHeight = this.titleHeight;\n let translateY;\n if (alignAttr) {\n translateY = alignAttr.translateY;\n this.allItems.forEach(function (item) {\n const checkbox = item.checkbox;\n let top;\n if (checkbox) {\n top = translateY + titleHeight + checkbox.y +\n (this.scrollOffset || 0) + 3;\n css(checkbox, {\n left: (alignAttr.translateX + item.checkboxOffset +\n checkbox.x - 20) + 'px',\n top: top + 'px',\n display: this.proximate || (top > translateY - 6 &&\n top < translateY + clipHeight - 6) ?\n '' :\n 'none'\n });\n }\n }, this);\n }\n }\n /**\n * Render the legend title on top of the legend.\n *\n * @private\n * @function Highcharts.Legend#renderTitle\n */\n renderTitle() {\n const options = this.options, padding = this.padding, titleOptions = options.title;\n let bBox, titleHeight = 0;\n if (titleOptions.text) {\n if (!this.title) {\n /**\n * SVG element of the legend title.\n *\n * @readonly\n * @name Highcharts.Legend#title\n * @type {Highcharts.SVGElement}\n */\n this.title = this.chart.renderer.label(titleOptions.text, padding - 3, padding - 4, void 0, void 0, void 0, options.useHTML, void 0, 'legend-title')\n .attr({ zIndex: 1 });\n if (!this.chart.styledMode) {\n this.title.css(titleOptions.style);\n }\n this.title.add(this.group);\n }\n // Set the max title width (#7253)\n if (!titleOptions.width) {\n this.title.css({\n width: this.maxLegendWidth + 'px'\n });\n }\n bBox = this.title.getBBox();\n titleHeight = bBox.height;\n this.offsetWidth = bBox.width; // #1717\n this.contentGroup.attr({ translateY: titleHeight });\n }\n this.titleHeight = titleHeight;\n }\n /**\n * Set the legend item text.\n *\n * @function Highcharts.Legend#setText\n * @param {Highcharts.Point|Highcharts.Series} item\n * The item for which to update the text in the legend.\n */\n setText(item) {\n const options = this.options;\n item.legendItem.label.attr({\n text: options.labelFormat ?\n format(options.labelFormat, item, this.chart) :\n options.labelFormatter.call(item)\n });\n }\n /**\n * Render a single specific legend item. Called internally from the `render`\n * function.\n *\n * @private\n * @function Highcharts.Legend#renderItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to render.\n */\n renderItem(item) {\n const legend = this, legendItem = item.legendItem = item.legendItem || {}, chart = legend.chart, renderer = chart.renderer, options = legend.options, horizontal = options.layout === 'horizontal', symbolWidth = legend.symbolWidth, symbolPadding = options.symbolPadding || 0, itemStyle = legend.itemStyle, itemHiddenStyle = legend.itemHiddenStyle, itemDistance = horizontal ? pick(options.itemDistance, 20) : 0, ltr = !options.rtl, isSeries = !item.series, series = !isSeries && item.series.drawLegendSymbol ?\n item.series :\n item, seriesOptions = series.options, showCheckbox = (legend.createCheckboxForItem) &&\n seriesOptions &&\n seriesOptions.showCheckbox, useHTML = options.useHTML, itemClassName = item.options.className;\n let label = legendItem.label, \n // full width minus text width\n itemExtraWidth = symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (!label) { // generate it once, later move it\n // Generate the group box, a group to hold the symbol and text. Text\n // is to be appended in Legend class.\n legendItem.group = renderer\n .g('legend-item')\n .addClass('highcharts-' + series.type + '-series ' +\n 'highcharts-color-' + item.colorIndex +\n (itemClassName ? ' ' + itemClassName : '') +\n (isSeries ?\n ' highcharts-series-' + item.index :\n ''))\n .attr({ zIndex: 1 })\n .add(legend.scrollGroup);\n // Generate the list item text and add it to the group\n legendItem.label = label = renderer.text('', ltr ?\n symbolWidth + symbolPadding :\n -symbolPadding, legend.baseline || 0, useHTML);\n if (!chart.styledMode) {\n // merge to prevent modifying original (#1021)\n label.css(merge(item.visible ?\n itemStyle :\n itemHiddenStyle));\n }\n label\n .attr({\n align: ltr ? 'left' : 'right',\n zIndex: 2\n })\n .add(legendItem.group);\n // Get the baseline for the first item - the font size is equal for\n // all\n if (!legend.baseline) {\n legend.fontMetrics = renderer.fontMetrics(label);\n legend.baseline =\n legend.fontMetrics.f + 3 + legend.itemMarginTop;\n label.attr('y', legend.baseline);\n legend.symbolHeight =\n pick(options.symbolHeight, legend.fontMetrics.f);\n if (options.squareSymbol) {\n legend.symbolWidth = pick(options.symbolWidth, Math.max(legend.symbolHeight, 16));\n itemExtraWidth = legend.symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (ltr) {\n label.attr('x', legend.symbolWidth + symbolPadding);\n }\n }\n }\n // Draw the legend symbol inside the group box\n series.drawLegendSymbol(legend, item);\n if (legend.setItemEvents) {\n legend.setItemEvents(item, label, useHTML);\n }\n }\n // Add the HTML checkbox on top\n if (showCheckbox && !item.checkbox && legend.createCheckboxForItem) {\n legend.createCheckboxForItem(item);\n }\n // Colorize the items\n legend.colorizeItem(item, item.visible);\n // Take care of max width and text overflow (#6659)\n if (chart.styledMode || !itemStyle.width) {\n label.css({\n width: ((options.itemWidth ||\n legend.widthOption ||\n chart.spacingBox.width) - itemExtraWidth) + 'px'\n });\n }\n // Always update the text\n legend.setText(item);\n // calculate the positions for the next line\n const bBox = label.getBBox();\n const fontMetricsH = (legend.fontMetrics && legend.fontMetrics.h) || 0;\n item.itemWidth = item.checkboxOffset =\n options.itemWidth ||\n legendItem.labelWidth ||\n bBox.width + itemExtraWidth;\n legend.maxItemWidth = Math.max(legend.maxItemWidth, item.itemWidth);\n legend.totalItemWidth += item.itemWidth;\n legend.itemHeight = item.itemHeight = Math.round(legendItem.labelHeight ||\n // use bBox for multiline (#16398)\n (bBox.height > fontMetricsH * 1.5 ? bBox.height : fontMetricsH));\n }\n /**\n * Get the position of the item in the layout. We now know the\n * maxItemWidth from the previous loop.\n *\n * @private\n * @function Highcharts.Legend#layoutItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n */\n layoutItem(item) {\n const options = this.options, padding = this.padding, horizontal = options.layout === 'horizontal', itemHeight = item.itemHeight, itemMarginBottom = this.itemMarginBottom, itemMarginTop = this.itemMarginTop, itemDistance = horizontal ? pick(options.itemDistance, 20) : 0, maxLegendWidth = this.maxLegendWidth, itemWidth = (options.alignColumns &&\n this.totalItemWidth > maxLegendWidth) ?\n this.maxItemWidth :\n item.itemWidth, legendItem = item.legendItem || {};\n // If the item exceeds the width, start a new line\n if (horizontal &&\n this.itemX - padding + itemWidth > maxLegendWidth) {\n this.itemX = padding;\n if (this.lastLineHeight) { // Not for the first line (#10167)\n this.itemY += (itemMarginTop +\n this.lastLineHeight +\n itemMarginBottom);\n }\n this.lastLineHeight = 0; // reset for next line (#915, #3976)\n }\n // Set the edge positions\n this.lastItemY = itemMarginTop + this.itemY + itemMarginBottom;\n this.lastLineHeight = Math.max(// #915\n itemHeight, this.lastLineHeight);\n // cache the position of the newly generated or reordered items\n legendItem.x = this.itemX;\n legendItem.y = this.itemY;\n // advance\n if (horizontal) {\n this.itemX += itemWidth;\n }\n else {\n this.itemY +=\n itemMarginTop + itemHeight + itemMarginBottom;\n this.lastLineHeight = itemHeight;\n }\n // the width of the widest item\n this.offsetWidth = this.widthOption || Math.max((horizontal ? this.itemX - padding - (item.checkbox ?\n // decrease by itemDistance only when no checkbox #4853\n 0 :\n itemDistance) : itemWidth) + padding, this.offsetWidth);\n }\n /**\n * Get all items, which is one item per series for most series and one\n * item per point for pie series and its derivatives. Fires the event\n * `afterGetAllItems`.\n *\n * @private\n * @function Highcharts.Legend#getAllItems\n * @return {Array<(Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series)>}\n * The current items in the legend.\n * @emits Highcharts.Legend#event:afterGetAllItems\n */\n getAllItems() {\n let allItems = [];\n this.chart.series.forEach(function (series) {\n const seriesOptions = series && series.options;\n // Handle showInLegend. If the series is linked to another series,\n // defaults to false.\n if (series && pick(seriesOptions.showInLegend, !defined(seriesOptions.linkedTo) ? void 0 : false, true)) {\n // Use points or series for the legend item depending on\n // legendType\n allItems = allItems.concat((series.legendItem || {}).labels ||\n (seriesOptions.legendType === 'point' ?\n series.data :\n series));\n }\n });\n fireEvent(this, 'afterGetAllItems', { allItems });\n return allItems;\n }\n /**\n * Get a short, three letter string reflecting the alignment and layout.\n *\n * @private\n * @function Highcharts.Legend#getAlignment\n * @return {string}\n * The alignment, empty string if floating\n */\n getAlignment() {\n const options = this.options;\n // Use the first letter of each alignment option in order to detect\n // the side. (#4189 - use charAt(x) notation instead of [x] for IE7)\n if (this.proximate) {\n return options.align.charAt(0) + 'tv';\n }\n return options.floating ? '' : (options.align.charAt(0) +\n options.verticalAlign.charAt(0) +\n options.layout.charAt(0));\n }\n /**\n * Adjust the chart margins by reserving space for the legend on only one\n * side of the chart. If the position is set to a corner, top or bottom is\n * reserved for horizontal legends and left or right for vertical ones.\n *\n * @private\n * @function Highcharts.Legend#adjustMargins\n * @param {Array} margin\n * @param {Array} spacing\n */\n adjustMargins(margin, spacing) {\n const chart = this.chart, options = this.options, alignment = this.getAlignment();\n if (alignment) {\n ([\n /(lth|ct|rth)/,\n /(rtv|rm|rbv)/,\n /(rbh|cb|lbh)/,\n /(lbv|lm|ltv)/\n ]).forEach(function (alignments, side) {\n if (alignments.test(alignment) && !defined(margin[side])) {\n // Now we have detected on which side of the chart we should\n // reserve space for the legend\n chart[marginNames[side]] = Math.max(chart[marginNames[side]], (chart.legend[(side + 1) % 2 ? 'legendHeight' : 'legendWidth'] +\n [1, -1, -1, 1][side] * options[(side % 2) ? 'x' : 'y'] +\n pick(options.margin, 12) +\n spacing[side] +\n (chart.titleOffset[side] || 0)));\n }\n });\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#proximatePositions\n */\n proximatePositions() {\n const chart = this.chart, boxes = [], alignLeft = this.options.align === 'left';\n this.allItems.forEach(function (item) {\n let lastPoint, height, useFirstPoint = alignLeft, target, top;\n if (item.yAxis) {\n if (item.xAxis.options.reversed) {\n useFirstPoint = !useFirstPoint;\n }\n if (item.points) {\n lastPoint = find(useFirstPoint ?\n item.points :\n item.points.slice(0).reverse(), function (item) {\n return isNumber(item.plotY);\n });\n }\n height = this.itemMarginTop +\n item.legendItem.label.getBBox().height +\n this.itemMarginBottom;\n top = item.yAxis.top - chart.plotTop;\n if (item.visible) {\n target = lastPoint ?\n lastPoint.plotY :\n item.yAxis.height;\n target += top - 0.3 * height;\n }\n else {\n target = top + item.yAxis.height;\n }\n boxes.push({\n target: target,\n size: height,\n item\n });\n }\n }, this);\n let legendItem;\n for (const box of distribute(boxes, chart.plotHeight)) {\n legendItem = box.item.legendItem || {};\n if (isNumber(box.pos)) {\n legendItem.y = chart.plotTop - chart.spacing[0] + box.pos;\n }\n }\n }\n /**\n * Render the legend. This method can be called both before and after\n * `chart.render`. If called after, it will only rearrange items instead\n * of creating new ones. Called internally on initial render and after\n * redraws.\n *\n * @private\n * @function Highcharts.Legend#render\n */\n render() {\n const legend = this, chart = legend.chart, renderer = chart.renderer, options = legend.options, padding = legend.padding, \n // add each series or point\n allItems = legend.getAllItems();\n let display, legendWidth, legendHeight, legendGroup = legend.group, allowedWidth, box = legend.box;\n legend.itemX = padding;\n legend.itemY = legend.initialItemY;\n legend.offsetWidth = 0;\n legend.lastItemY = 0;\n legend.widthOption = relativeLength(options.width, chart.spacingBox.width - padding);\n // Compute how wide the legend is allowed to be\n allowedWidth = chart.spacingBox.width - 2 * padding - options.x;\n if (['rm', 'lm'].indexOf(legend.getAlignment().substring(0, 2)) > -1) {\n allowedWidth /= 2;\n }\n legend.maxLegendWidth = legend.widthOption || allowedWidth;\n if (!legendGroup) {\n /**\n * SVG group of the legend.\n *\n * @readonly\n * @name Highcharts.Legend#group\n * @type {Highcharts.SVGElement}\n */\n legend.group = legendGroup = renderer\n .g('legend')\n .addClass(options.className || '')\n .attr({ zIndex: 7 })\n .add();\n legend.contentGroup = renderer\n .g()\n .attr({ zIndex: 1 }) // above background\n .add(legendGroup);\n legend.scrollGroup = renderer\n .g()\n .add(legend.contentGroup);\n }\n legend.renderTitle();\n // sort by legendIndex\n stableSort(allItems, (a, b) => ((a.options && a.options.legendIndex) || 0) -\n ((b.options && b.options.legendIndex) || 0));\n // reversed legend\n if (options.reversed) {\n allItems.reverse();\n }\n /**\n * All items for the legend, which is an array of series for most series\n * and an array of points for pie series and its derivatives.\n *\n * @readonly\n * @name Highcharts.Legend#allItems\n * @type {Array<(Highcharts.Point|Highcharts.Series)>}\n */\n legend.allItems = allItems;\n legend.display = display = !!allItems.length;\n // Render the items. First we run a loop to set the text and properties\n // and read all the bounding boxes. The next loop computes the item\n // positions based on the bounding boxes.\n legend.lastLineHeight = 0;\n legend.maxItemWidth = 0;\n legend.totalItemWidth = 0;\n legend.itemHeight = 0;\n allItems.forEach(legend.renderItem, legend);\n allItems.forEach(legend.layoutItem, legend);\n // Get the box\n legendWidth = (legend.widthOption || legend.offsetWidth) + padding;\n legendHeight = legend.lastItemY + legend.lastLineHeight +\n legend.titleHeight;\n legendHeight = legend.handleOverflow(legendHeight);\n legendHeight += padding;\n // Draw the border and/or background\n if (!box) {\n /**\n * SVG element of the legend box.\n *\n * @readonly\n * @name Highcharts.Legend#box\n * @type {Highcharts.SVGElement}\n */\n legend.box = box = renderer.rect()\n .addClass('highcharts-legend-box')\n .attr({\n r: options.borderRadius\n })\n .add(legendGroup);\n }\n // Presentational\n if (!chart.styledMode) {\n box\n .attr({\n stroke: options.borderColor,\n 'stroke-width': options.borderWidth || 0,\n fill: options.backgroundColor || 'none'\n })\n .shadow(options.shadow);\n }\n if (legendWidth > 0 && legendHeight > 0) {\n box[box.placed ? 'animate' : 'attr'](box.crisp.call({}, {\n x: 0,\n y: 0,\n width: legendWidth,\n height: legendHeight\n }, box.strokeWidth()));\n }\n // hide the border if no items\n legendGroup[display ? 'show' : 'hide']();\n // Open for responsiveness\n if (chart.styledMode && legendGroup.getStyle('display') === 'none') {\n legendWidth = legendHeight = 0;\n }\n legend.legendWidth = legendWidth;\n legend.legendHeight = legendHeight;\n if (display) {\n legend.align();\n }\n if (!this.proximate) {\n this.positionItems();\n }\n fireEvent(this, 'afterRender');\n }\n /**\n * Align the legend to chart's box.\n *\n * @private\n * @function Highcharts.align\n * @param {Highcharts.BBoxObject} alignTo\n */\n align(alignTo = this.chart.spacingBox) {\n const chart = this.chart, options = this.options;\n // If aligning to the top and the layout is horizontal, adjust for\n // the title (#7428)\n let y = alignTo.y;\n if (/(lth|ct|rth)/.test(this.getAlignment()) &&\n chart.titleOffset[0] > 0) {\n y += chart.titleOffset[0];\n }\n else if (/(lbh|cb|rbh)/.test(this.getAlignment()) &&\n chart.titleOffset[2] > 0) {\n y -= chart.titleOffset[2];\n }\n if (y !== alignTo.y) {\n alignTo = merge(alignTo, { y });\n }\n if (!chart.hasRendered) {\n // Avoid animation when adjusting alignment for responsiveness and\n // colorAxis label layout\n this.group.placed = false;\n }\n this.group.align(merge(options, {\n width: this.legendWidth,\n height: this.legendHeight,\n verticalAlign: this.proximate ? 'top' : options.verticalAlign\n }), true, alignTo);\n }\n /**\n * Set up the overflow handling by adding navigation with up and down arrows\n * below the legend.\n *\n * @private\n * @function Highcharts.Legend#handleOverflow\n */\n handleOverflow(legendHeight) {\n const legend = this, chart = this.chart, renderer = chart.renderer, options = this.options, optionsY = options.y, alignTop = options.verticalAlign === 'top', padding = this.padding, maxHeight = options.maxHeight, navOptions = options.navigation, animation = pick(navOptions.animation, true), arrowSize = navOptions.arrowSize || 12, pages = this.pages, allItems = this.allItems, clipToHeight = function (height) {\n if (typeof height === 'number') {\n clipRect.attr({\n height: height\n });\n }\n else if (clipRect) { // Reset (#5912)\n legend.clipRect = clipRect.destroy();\n legend.contentGroup.clip();\n }\n // useHTML\n if (legend.contentGroup.div) {\n legend.contentGroup.div.style.clip = height ?\n 'rect(' + padding + 'px,9999px,' +\n (padding + height) + 'px,0)' :\n 'auto';\n }\n }, addTracker = function (key) {\n legend[key] = renderer\n .circle(0, 0, arrowSize * 1.3)\n .translate(arrowSize / 2, arrowSize / 2)\n .add(nav);\n if (!chart.styledMode) {\n legend[key].attr('fill', 'rgba(0,0,0,0.0001)');\n }\n return legend[key];\n };\n let clipHeight, lastY, legendItem, spaceHeight = (chart.spacingBox.height +\n (alignTop ? -optionsY : optionsY) - padding), nav = this.nav, clipRect = this.clipRect;\n // Adjust the height\n if (options.layout === 'horizontal' &&\n options.verticalAlign !== 'middle' &&\n !options.floating) {\n spaceHeight /= 2;\n }\n if (maxHeight) {\n spaceHeight = Math.min(spaceHeight, maxHeight);\n }\n // Reset the legend height and adjust the clipping rectangle\n pages.length = 0;\n if (legendHeight &&\n spaceHeight > 0 &&\n legendHeight > spaceHeight &&\n navOptions.enabled !== false) {\n this.clipHeight = clipHeight =\n Math.max(spaceHeight - 20 - this.titleHeight - padding, 0);\n this.currentPage = pick(this.currentPage, 1);\n this.fullHeight = legendHeight;\n // Fill pages with Y positions so that the top of each a legend item\n // defines the scroll top for each page (#2098)\n allItems.forEach((item, i) => {\n legendItem = item.legendItem || {};\n const y = legendItem.y || 0, h = Math.round(legendItem.label.getBBox().height);\n let len = pages.length;\n if (!len || (y - pages[len - 1] > clipHeight &&\n (lastY || y) !== pages[len - 1])) {\n pages.push(lastY || y);\n len++;\n }\n // Keep track of which page each item is on\n legendItem.pageIx = len - 1;\n if (lastY) {\n (allItems[i - 1].legendItem || {}).pageIx = len - 1;\n }\n // add the last page if needed (#2617, #13683)\n if (\n // check the last item\n i === allItems.length - 1 &&\n // if adding next page is needed (#18768)\n y + h - pages[len - 1] > clipHeight &&\n y > pages[len - 1]) {\n pages.push(y);\n legendItem.pageIx = len;\n }\n if (y !== lastY) {\n lastY = y;\n }\n });\n // Only apply clipping if needed. Clipping causes blurred legend in\n // PDF export (#1787)\n if (!clipRect) {\n clipRect = legend.clipRect =\n renderer.clipRect(0, padding - 2, 9999, 0);\n legend.contentGroup.clip(clipRect);\n }\n clipToHeight(clipHeight);\n // Add navigation elements\n if (!nav) {\n this.nav = nav = renderer.g()\n .attr({ zIndex: 1 })\n .add(this.group);\n this.up = renderer\n .symbol('triangle', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('upTracker')\n .on('click', function () {\n legend.scroll(-1, animation);\n });\n this.pager = renderer.text('', 15, 10)\n .addClass('highcharts-legend-navigation');\n if (!chart.styledMode && navOptions.style) {\n this.pager.css(navOptions.style);\n }\n this.pager.add(nav);\n this.down = renderer\n .symbol('triangle-down', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('downTracker')\n .on('click', function () {\n legend.scroll(1, animation);\n });\n }\n // Set initial position\n legend.scroll(0);\n legendHeight = spaceHeight;\n // Reset\n }\n else if (nav) {\n clipToHeight();\n this.nav = nav.destroy(); // #6322\n this.scrollGroup.attr({\n translateY: 1\n });\n this.clipHeight = 0; // #1379\n }\n return legendHeight;\n }\n /**\n * Scroll the legend by a number of pages.\n *\n * @private\n * @function Highcharts.Legend#scroll\n *\n * @param {number} scrollBy\n * The number of pages to scroll.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation.\n *\n */\n scroll(scrollBy, animation) {\n const chart = this.chart, pages = this.pages, pageCount = pages.length, clipHeight = this.clipHeight, navOptions = this.options.navigation, pager = this.pager, padding = this.padding;\n let currentPage = this.currentPage + scrollBy;\n // When resizing while looking at the last page\n if (currentPage > pageCount) {\n currentPage = pageCount;\n }\n if (currentPage > 0) {\n if (typeof animation !== 'undefined') {\n setAnimation(animation, chart);\n }\n this.nav.attr({\n translateX: padding,\n translateY: clipHeight + this.padding + 7 + this.titleHeight,\n visibility: 'inherit'\n });\n [this.up, this.upTracker].forEach(function (elem) {\n elem.attr({\n 'class': currentPage === 1 ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n });\n pager.attr({\n text: currentPage + '/' + pageCount\n });\n [this.down, this.downTracker].forEach(function (elem) {\n elem.attr({\n // adjust to text width\n x: 18 + this.pager.getBBox().width,\n 'class': currentPage === pageCount ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n }, this);\n if (!chart.styledMode) {\n this.up\n .attr({\n fill: currentPage === 1 ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.upTracker\n .css({\n cursor: currentPage === 1 ? 'default' : 'pointer'\n });\n this.down\n .attr({\n fill: currentPage === pageCount ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.downTracker\n .css({\n cursor: currentPage === pageCount ?\n 'default' :\n 'pointer'\n });\n }\n this.scrollOffset = -pages[currentPage - 1] + this.initialItemY;\n this.scrollGroup.animate({\n translateY: this.scrollOffset\n });\n this.currentPage = currentPage;\n this.positionCheckboxes();\n // Fire event after scroll animation is complete\n const animOptions = animObject(pick(animation, chart.renderer.globalAnimation, true));\n syncTimeout(() => {\n fireEvent(this, 'afterScroll', { currentPage });\n }, animOptions.duration);\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#setItemEvents\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @param {Highcharts.SVGElement} legendLabel\n * @param {boolean} [useHTML=false]\n * @emits Highcharts.Point#event:legendItemClick\n * @emits Highcharts.Series#event:legendItemClick\n */\n setItemEvents(item, legendLabel, useHTML) {\n const legend = this, legendItem = item.legendItem || {}, boxWrapper = legend.chart.renderer.boxWrapper, isPoint = item instanceof Point, activeClass = 'highcharts-legend-' +\n (isPoint ? 'point' : 'series') + '-active', styledMode = legend.chart.styledMode, \n // When `useHTML`, the symbol is rendered in other group, so\n // we need to apply events listeners to both places\n legendElements = useHTML ?\n [legendLabel, legendItem.symbol] :\n [legendItem.group];\n const setOtherItemsState = (state) => {\n legend.allItems.forEach((otherItem) => {\n if (item !== otherItem) {\n [otherItem]\n .concat(otherItem.linkedSeries || [])\n .forEach((otherItem) => {\n otherItem.setState(state, !isPoint);\n });\n }\n });\n };\n // Set the events on the item group, or in case of useHTML, the item\n // itself (#1249)\n for (const element of legendElements) {\n if (element) {\n element\n .on('mouseover', function () {\n if (item.visible) {\n setOtherItemsState('inactive');\n }\n item.setState('hover');\n // A CSS class to dim or hide other than the hovered\n // series.\n // Works only if hovered series is visible (#10071).\n if (item.visible) {\n boxWrapper.addClass(activeClass);\n }\n if (!styledMode) {\n legendLabel.css(legend.options.itemHoverStyle);\n }\n })\n .on('mouseout', function () {\n if (!legend.chart.styledMode) {\n legendLabel.css(merge(item.visible ?\n legend.itemStyle :\n legend.itemHiddenStyle));\n }\n setOtherItemsState('');\n // A CSS class to dim or hide other than the hovered\n // series.\n boxWrapper.removeClass(activeClass);\n item.setState();\n })\n .on('click', function (event) {\n const strLegendItemClick = 'legendItemClick', fnLegendItemClick = function () {\n if (item.setVisible) {\n item.setVisible();\n }\n // Reset inactive state\n setOtherItemsState(item.visible ? 'inactive' : '');\n };\n // A CSS class to dim or hide other than the hovered\n // series. Event handling in iOS causes the activeClass\n // to be added prior to click in some cases (#7418).\n boxWrapper.removeClass(activeClass);\n // Pass over the click/touch event. #4.\n event = {\n browserEvent: event\n };\n // click the name or symbol\n if (item.firePointEvent) { // point\n item.firePointEvent(strLegendItemClick, event, fnLegendItemClick);\n }\n else {\n fireEvent(item, strLegendItemClick, event, fnLegendItemClick);\n }\n });\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#createCheckboxForItem\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @emits Highcharts.Series#event:checkboxClick\n */\n createCheckboxForItem(item) {\n const legend = this;\n item.checkbox = createElement('input', {\n type: 'checkbox',\n className: 'highcharts-legend-checkbox',\n checked: item.selected,\n defaultChecked: item.selected // required by IE7\n }, legend.options.itemCheckboxStyle, legend.chart.container);\n addEvent(item.checkbox, 'click', function (event) {\n const target = event.target;\n fireEvent(item.series || item, 'checkboxClick', {\n checked: target.checked,\n item: item\n }, function () {\n item.select();\n });\n });\n }\n }\n /* *\n *\n * Class Namespace\n *\n * */\n (function (Legend) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'beforeMargins', function () {\n /**\n * The legend contains an interactive overview over chart items,\n * usually individual series or points depending on the series\n * type. The color axis and bubble legend are also rendered in\n * the chart legend.\n *\n * @name Highcharts.Chart#legend\n * @type {Highcharts.Legend}\n */\n this.legend = new Legend(this, this.options.legend);\n });\n }\n }\n Legend.compose = compose;\n })(Legend || (Legend = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @interface Highcharts.LegendItemObject\n */ /**\n * @name Highcharts.LegendItemObject#item\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#line\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#symbol\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * Gets fired when the legend item belonging to a point is clicked. The default\n * action is to toggle the visibility of the point. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.PointLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point on which the event occured.\n *\n * @param {Highcharts.PointLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.PointLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.PointLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the point.\n * @name Highcharts.PointLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related point.\n * @name Highcharts.PointLegendItemClickEventObject#target\n * @type {Highcharts.Point}\n */ /**\n * Event type.\n * @name Highcharts.PointLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n /**\n * Series color as used by the legend and some series types.\n * @name Highcharts.Series#color\n * @type {Highcharts.ColorType|undefined}\n */ /**\n * Legend data for the series.\n * @name Highcharts.Series#legendItem\n * @type {Highcharts.LegendItemObject|undefined}\n * @since 10.3.0\n */\n /**\n * Gets fired when the legend item belonging to a series is clicked. The default\n * action is to toggle the visibility of the series. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesLegendItemClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n (''); // keeps doclets above in JS file\n\n return Legend;\n });\n _registerModule(_modules, 'Core/Legend/LegendSymbol.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { extend, merge, pick } = U;\n /* *\n *\n * Namespace\n *\n * */\n var LegendSymbol;\n (function (LegendSymbol) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.lineMarker\n *\n * @param {Highcharts.Legend} legend\n * The legend object.\n */\n function lineMarker(legend, item) {\n const legendItem = this.legendItem = this.legendItem || {}, options = this.options, symbolWidth = legend.symbolWidth, symbolHeight = legend.symbolHeight, generalRadius = symbolHeight / 2, renderer = this.chart.renderer, legendItemGroup = legendItem.group, verticalCenter = legend.baseline -\n Math.round(legend.fontMetrics.b * 0.3);\n let attr = {}, legendSymbol, markerOptions = options.marker, lineSizer = 0;\n // Draw the line\n if (!this.chart.styledMode) {\n attr = {\n 'stroke-width': Math.min(options.lineWidth || 0, 24)\n };\n if (options.dashStyle) {\n attr.dashstyle = options.dashStyle;\n }\n else if (options.linecap !== 'square') {\n attr['stroke-linecap'] = 'round';\n }\n }\n legendItem.line = renderer\n .path()\n .addClass('highcharts-graph')\n .attr(attr)\n .add(legendItemGroup);\n if (attr['stroke-linecap']) {\n lineSizer = Math.min(legendItem.line.strokeWidth(), symbolWidth) / 2;\n }\n if (symbolWidth) {\n legendItem.line\n .attr({\n d: [\n ['M', lineSizer, verticalCenter],\n ['L', symbolWidth - lineSizer, verticalCenter]\n ]\n });\n }\n // Draw the marker\n if (markerOptions && markerOptions.enabled !== false && symbolWidth) {\n // Do not allow the marker to be larger than the symbolHeight\n let radius = Math.min(pick(markerOptions.radius, generalRadius), generalRadius);\n // Restrict symbol markers size\n if (this.symbol.indexOf('url') === 0) {\n markerOptions = merge(markerOptions, {\n width: symbolHeight,\n height: symbolHeight\n });\n radius = 0;\n }\n legendItem.symbol = legendSymbol = renderer\n .symbol(this.symbol, (symbolWidth / 2) - radius, verticalCenter - radius, 2 * radius, 2 * radius, extend({ context: 'legend' }, markerOptions))\n .addClass('highcharts-point')\n .add(legendItemGroup);\n legendSymbol.isMarker = true;\n }\n }\n LegendSymbol.lineMarker = lineMarker;\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.rectangle\n *\n * @param {Highcharts.Legend} legend\n * The legend object\n *\n * @param {Highcharts.Point|Highcharts.Series} item\n * The series (this) or point\n */\n function rectangle(legend, item) {\n const legendItem = item.legendItem || {}, options = legend.options, symbolHeight = legend.symbolHeight, square = options.squareSymbol, symbolWidth = square ? symbolHeight : legend.symbolWidth;\n legendItem.symbol = this.chart.renderer\n .rect(square ? (legend.symbolWidth - symbolHeight) / 2 : 0, legend.baseline - symbolHeight + 1, // #3988\n symbolWidth, symbolHeight, pick(legend.options.symbolRadius, symbolHeight / 2))\n .addClass('highcharts-point')\n .attr({\n zIndex: 3\n })\n .add(legendItem.group);\n }\n LegendSymbol.rectangle = rectangle;\n })(LegendSymbol || (LegendSymbol = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LegendSymbol;\n });\n _registerModule(_modules, 'Core/Series/SeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n const seriesDefaults = {\n // base series options\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * Pixel width of the graph line.\n *\n * @see In styled mode, the line stroke-width can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-general/\n * On all series\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-specific/\n * On one single series\n *\n * @product highcharts highstock\n */\n lineWidth: 1,\n /**\n * For some series, there is a limit that shuts down animation\n * by default when the total number of points in the chart is too high.\n * For example, for a column chart and its derivatives, animation does\n * not run if there is more than 250 points totally. To disable this\n * cap, set `animationLimit` to `Infinity`. This option works if animation\n * is fired on individual points, not on a group of points like e.g. during\n * the initial animation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animationlimit/\n * Animation limit on updating individual points\n *\n * @type {number}\n * @apioption plotOptions.series.animationLimit\n */\n /**\n * Allow this series' points to be selected by clicking on the graphic\n * (columns, point markers, pie slices, map areas etc).\n *\n * The selected points can be handled by point select and unselect\n * events, or collectively by the [getSelectedPoints\n * ](/class-reference/Highcharts.Chart#getSelectedPoints) function.\n *\n * And alternative way of selecting points is through dragging.\n *\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-pie/\n * Pie\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @since 1.2.0\n *\n * @private\n */\n allowPointSelect: false,\n /**\n * When true, each point or column edge is rounded to its nearest pixel\n * in order to render sharp on screen. In some cases, when there are a\n * lot of densely packed columns, this leads to visible difference\n * in column widths or distance between columns. In these cases,\n * setting `crisp` to `false` may look better, even though each column\n * is rendered blurry.\n *\n * @sample {highcharts} highcharts/plotoptions/column-crisp-false/\n * Crisp is false\n *\n * @since 5.0.10\n * @product highcharts highstock gantt\n *\n * @private\n */\n crisp: true,\n /**\n * If true, a checkbox is displayed next to the legend item to allow\n * selecting the series. The state of the checkbox is determined by\n * the `selected` option.\n *\n * @productdesc {highmaps}\n * Note that if a `colorAxis` is defined, the color axis is represented\n * in the legend, not the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showcheckbox-true/\n * Show select box\n *\n * @since 1.2.0\n *\n * @private\n */\n showCheckbox: false,\n /**\n * Enable or disable the initial animation when a series is displayed.\n * The animation can also be set as a configuration object. Please\n * note that this option only applies to the initial animation of the\n * series itself. For other animations, see [chart.animation](\n * #chart.animation) and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds. (Defaults to\n * `1000`)\n *\n * - `easing`: Can be a string reference to an easing function set on\n * the `Math` object or a function. See the _Custom easing function_\n * demo below. (Defaults to `easeInOutSine`)\n *\n * Due to poor performance, animation is disabled in old IE browsers\n * for several chart types.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animation-disabled/\n * Animation disabled\n * @sample {highcharts} highcharts/plotoptions/series-animation-slower/\n * Slower animation\n * @sample {highcharts} highcharts/plotoptions/series-animation-easing/\n * Custom easing function\n * @sample {highstock} stock/plotoptions/animation-slower/\n * Slower animation\n * @sample {highstock} stock/plotoptions/animation-easing/\n * Custom easing function\n * @sample {highmaps} maps/plotoptions/series-animation-true/\n * Animation enabled on map series\n * @sample {highmaps} maps/plotoptions/mapbubble-animation-false/\n * Disabled on mapbubble series\n *\n * @type {boolean|Highcharts.AnimationOptionsObject}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n *\n * @private\n */\n animation: {\n /** @ignore-option */\n duration: 1000\n },\n /**\n * An additional class name to apply to the series' graphical elements.\n * This option does not replace default class names of the graphical\n * element. Changes to the series' color will also be reflected in a\n * chart's legend and tooltip.\n *\n * @sample {highcharts} highcharts/css/point-series-classname\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.className\n */\n /**\n * Disable this option to allow series rendering in the whole plotting\n * area.\n *\n * **Note:** Clipping should be always enabled when\n * [chart.zoomType](#chart.zoomType) is set\n *\n * @sample {highcharts} highcharts/plotoptions/series-clip/\n * Disabled clipping\n *\n * @default true\n * @type {boolean}\n * @since 3.0.0\n * @apioption plotOptions.series.clip\n */\n /**\n * The main color of the series. In line type series it applies to the\n * line and the point markers unless otherwise specified. In bar type\n * series it applies to the bars unless a color is specified per point.\n * The default value is pulled from the `options.colors` array.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @productdesc {highmaps}\n * In maps, the series color is rarely used, as most choropleth maps use\n * the color to denote the value of each point. The series color can\n * however be used in a map with multiple series holding categorized\n * data.\n *\n * @sample {highcharts} highcharts/plotoptions/series-color-general/\n * General plot option\n * @sample {highcharts} highcharts/plotoptions/series-color-specific/\n * One specific series\n * @sample {highcharts} highcharts/plotoptions/series-color-area/\n * Area color\n * @sample {highcharts} highcharts/series/infographic/\n * Pattern fill\n * @sample {highmaps} maps/demo/category-map/\n * Category map by multiple series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.color\n */\n /**\n * Styled mode only. A specific color index to use for the series, so its\n * graphic representations are given the class name `highcharts-color-{n}`.\n *\n * Since v11, CSS variables on the form `--highcharts-color-{n}` make\n * changing the color scheme very convenient.\n *\n * @sample {highcharts} highcharts/css/colorindex/ Series and point color\n * index\n *\n * @type {number}\n * @since 5.0.0\n * @apioption plotOptions.series.colorIndex\n */\n /**\n * Whether to connect a graph line across null points, or render a gap\n * between the two points on either side of the null.\n *\n * In stacked area chart, if `connectNulls` is set to true,\n * null points are interpreted as 0.\n *\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.connectNulls\n */\n /**\n * You can set the cursor to \"pointer\" if you have click events attached\n * to the series, to signal to the user that the points and lines can\n * be clicked.\n *\n * In styled mode, the series cursor can be set with the same classes\n * as listed under [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-cursor-line/\n * On line graph\n * @sample {highcharts} highcharts/plotoptions/series-cursor-column/\n * On columns\n * @sample {highcharts} highcharts/plotoptions/series-cursor-scatter/\n * On scatter markers\n * @sample {highstock} stock/plotoptions/cursor/\n * Pointer on a line graph\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @type {string|Highcharts.CursorValue}\n * @apioption plotOptions.series.cursor\n */\n /**\n * A reserved subspace to store options and values for customized\n * functionality. Here you can add additional data for your own event\n * callbacks and formatter callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption plotOptions.series.custom\n */\n /**\n * Name of the dash style to use for the graph, or for some series types\n * the outline of each shape.\n *\n * In styled mode, the\n * [stroke dash-array](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/series-dashstyle/)\n * can be set with the same classes as listed under\n * [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle/\n * Chart suitable for printing in black and white\n * @sample {highstock} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} maps/plotoptions/series-dashstyle/\n * Dotted borders on a map\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 2.1\n * @apioption plotOptions.series.dashStyle\n */\n /**\n * A description of the series to add to the screen reader information\n * about the series.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption plotOptions.series.description\n */\n /**\n * Options for the series data sorting.\n *\n * @type {Highcharts.DataSortingOptionsObject}\n * @since 8.0.0\n * @product highcharts highstock\n * @apioption plotOptions.series.dataSorting\n */\n /**\n * Enable or disable data sorting for the series. Use [xAxis.reversed](\n * #xAxis.reversed) to change the sorting order.\n *\n * @sample {highcharts} highcharts/datasorting/animation/\n * Data sorting in scatter-3d\n * @sample {highcharts} highcharts/datasorting/labels-animation/\n * Axis labels animation\n * @sample {highcharts} highcharts/datasorting/dependent-sorting/\n * Dependent series sorting\n * @sample {highcharts} highcharts/datasorting/independent-sorting/\n * Independent series sorting\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.enabled\n */\n /**\n * Whether to allow matching points by name in an update. If this option\n * is disabled, points will be matched by order.\n *\n * @sample {highcharts} highcharts/datasorting/match-by-name/\n * Enabled match by name\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.matchByName\n */\n /**\n * Determines what data value should be used to sort by.\n *\n * @sample {highcharts} highcharts/datasorting/sort-key/\n * Sort key as `z` value\n *\n * @type {string}\n * @since 8.0.0\n * @default y\n * @apioption plotOptions.series.dataSorting.sortKey\n */\n /**\n * Enable or disable the mouse tracking for a specific series. This\n * includes point tooltips and click events on graphs and points. For\n * large datasets it improves performance.\n *\n * @sample {highcharts} highcharts/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n * @sample {highmaps} maps/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.enableMouseTracking\n */\n enableMouseTracking: true,\n /**\n * Whether to use the Y extremes of the total chart width or only the\n * zoomed area when zooming in on parts of the X axis. By default, the\n * Y axis adjusts to the min and max of the visible data. Cartesian\n * series only.\n *\n * @type {boolean}\n * @default false\n * @since 4.1.6\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.getExtremesFromAll\n */\n /**\n * An array specifying which option maps to which key in the data point\n * array. This makes it convenient to work with unstructured data arrays\n * from different sources.\n *\n * @see [series.data](#series.line.data)\n *\n * @sample {highcharts|highstock} highcharts/series/data-keys/\n * An extended data array with keys\n * @sample {highcharts|highstock} highcharts/series/data-nested-keys/\n * Nested keys used to access object properties\n *\n * @type {Array}\n * @since 4.1.6\n * @apioption plotOptions.series.keys\n */\n /**\n * The line cap used for line ends and line joins on the graph.\n *\n * @sample highcharts/series-line/linecap/\n * Line cap comparison\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @product highcharts highstock\n * @apioption plotOptions.series.linecap\n */\n /**\n * The [id](#series.id) of another series to link to. Additionally,\n * the value can be \":previous\" to link to the previous series. When\n * two series are linked, only the first one appears in the legend.\n * Toggling the visibility of this also toggles the linked series.\n *\n * If master series uses data sorting and linked series does not have\n * its own sorting definition, the linked series will be sorted in the\n * same order as the master one.\n *\n * @sample {highcharts|highstock} highcharts/demo/arearange-line/\n * Linked series\n *\n * @type {string}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.linkedTo\n */\n /**\n * Options for the corresponding navigator series if `showInNavigator`\n * is `true` for this series. Available options are the same as any\n * series, documented at [plotOptions](#plotOptions.series) and\n * [series](#series).\n *\n * These options are merged with options in [navigator.series](\n * #navigator.series), and will take precedence if the same option is\n * defined both places.\n *\n * @see [navigator.series](#navigator.series)\n *\n * @type {Highcharts.PlotSeriesOptions}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.navigatorOptions\n */\n /**\n * The color for the parts of the graph or points that are below the\n * [threshold](#plotOptions.series.threshold). Note that `zones` takes\n * precedence over the negative color. Using `negativeColor` is\n * equivalent to applying a zone with value of 0.\n *\n * @see In styled mode, a negative color is applied by setting this option\n * to `true` combined with the `.highcharts-negative` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highcharts} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Styled mode\n * @sample {highstock} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highstock} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highmaps} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highmaps} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @apioption plotOptions.series.negativeColor\n */\n /**\n * Same as\n * [accessibility.point.descriptionFormat](#accessibility.point.descriptionFormat),\n * but for an individual series. Overrides the chart wide configuration.\n *\n * @type {Function}\n * @since 11.1.0\n * @apioption plotOptions.series.pointDescriptionFormat\n */\n /**\n * Same as\n * [accessibility.series.descriptionFormatter](#accessibility.series.descriptionFormatter),\n * but for an individual series. Overrides the chart wide configuration.\n *\n * @type {Function}\n * @since 5.0.12\n * @apioption plotOptions.series.pointDescriptionFormatter\n */\n /**\n * If no x values are given for the points in a series, `pointInterval`\n * defines the interval of the x values. For example, if a series\n * contains one value every decade starting from year 0, set\n * `pointInterval` to `10`. In true `datetime` axes, the `pointInterval`\n * is set in milliseconds.\n *\n * It can be also be combined with `pointIntervalUnit` to draw irregular\n * time intervals.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point, and the `pointInterval` is added x times to the `pointStart`\n * setting.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime X axis\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 1\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointInterval\n */\n /**\n * On datetime series, this allows for setting the\n * [pointInterval](#plotOptions.series.pointInterval) to irregular time\n * units, `day`, `month` and `year`. A day is usually the same as 24\n * hours, but `pointIntervalUnit` also takes the DST crossover into\n * consideration when dealing with local time. Combine this option with\n * `pointInterval` to draw weeks, quarters, 6 months, 10 years etc.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n * @sample {highstock} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n *\n * @type {string}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @validvalue [\"day\", \"month\", \"year\"]\n * @apioption plotOptions.series.pointIntervalUnit\n */\n /**\n * Possible values: `\"on\"`, `\"between\"`, `number`.\n *\n * In a column chart, when pointPlacement is `\"on\"`, the point will not\n * create any padding of the X axis. In a polar column chart this means\n * that the first column points directly north. If the pointPlacement is\n * `\"between\"`, the columns will be laid out between ticks. This is\n * useful for example for visualising an amount between two points in\n * time or in a certain sector of a polar chart.\n *\n * Since Highcharts 3.0.2, the point placement can also be numeric,\n * where 0 is on the axis value, -0.5 is between this value and the\n * previous, and 0.5 is between this value and the next. Unlike the\n * textual options, numeric point placement options won't affect axis\n * padding.\n *\n * Note that pointPlacement needs a [pointRange](\n * #plotOptions.series.pointRange) to work. For column series this is\n * computed, but for line-type series it needs to be set.\n *\n * For the `xrange` series type and gantt charts, if the Y axis is a\n * category axis, the `pointPlacement` applies to the Y axis rather than\n * the (typically datetime) X axis.\n *\n * Defaults to `undefined` in cartesian charts, `\"between\"` in polar\n * charts.\n *\n * @see [xAxis.tickmarkPlacement](#xAxis.tickmarkPlacement)\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-between/\n * Between in a column chart\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-numeric/\n * Numeric placement for custom layout\n * @sample {highcharts|highstock} maps/plotoptions/heatmap-pointplacement/\n * Placement in heatmap\n *\n * @type {string|number}\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointPlacement\n */\n /**\n * If no x values are given for the points in a series, pointStart\n * defines on what value to start. For example, if a series contains one\n * yearly value starting from 1945, set pointStart to 1945.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point. The x value from the point options is multiplied by\n * `pointInterval` and added to `pointStart` to produce a modified x\n * value.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-linear/\n * Linear\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointStart\n */\n /**\n * When true, X values in the data set are relative to the current\n * `pointStart`, `pointInterval` and `pointIntervalUnit` settings. This\n * allows compression of the data for datasets with irregular X values.\n *\n * The real X values are computed on the formula `f(x) = ax + b`, where\n * `a` is the `pointInterval` (optionally with a time unit given by\n * `pointIntervalUnit`), and `b` is the `pointStart`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative X value\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative X value\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.relativeXValue\n */\n /**\n * Whether to select the series initially. If `showCheckbox` is true,\n * the checkbox next to the series name in the legend will be checked\n * for a selected series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-selected/\n * One out of two series selected\n *\n * @type {boolean}\n * @default false\n * @since 1.2.0\n * @apioption plotOptions.series.selected\n */\n /**\n * Whether to apply a drop shadow to the graph line. Since 2.3 the\n * shadow can be an object configuration containing `color`, `offsetX`,\n * `offsetY`, `opacity` and `width`.\n *\n * Note that in some cases, like stacked columns or other dense layouts, the\n * series may cast shadows on each other. In that case, the\n * `chart.seriesGroupShadow` allows applying a common drop shadow to the\n * whole series group.\n *\n * @sample {highcharts} highcharts/plotoptions/series-shadow/\n * Shadow enabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption plotOptions.series.shadow\n */\n /**\n * Whether to display this particular series or series type in the\n * legend. Standalone series are shown in legend by default, and linked\n * series are not. Since v7.2.0 it is possible to show series that use\n * colorAxis by setting this option to `true`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @type {boolean}\n * @apioption plotOptions.series.showInLegend\n */\n /**\n * Whether or not to show the series in the navigator. Takes precedence\n * over [navigator.baseSeries](#navigator.baseSeries) if defined.\n *\n * @type {boolean}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.showInNavigator\n */\n /**\n * If set to `true`, the accessibility module will skip past the points\n * in this series for keyboard navigation.\n *\n * @type {boolean}\n * @since 5.0.12\n * @apioption plotOptions.series.skipKeyboardNavigation\n */\n /**\n * Whether to stack the values of each series on top of each other.\n * Possible values are `undefined` to disable, `\"normal\"` to stack by\n * value or `\"percent\"`.\n *\n * When stacking is enabled, data must be sorted\n * in ascending X order.\n *\n * Some stacking options are related to specific series types. In the\n * streamgraph series type, the stacking option is set to `\"stream\"`.\n * The second one is `\"overlap\"`, which only applies to waterfall\n * series.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts} highcharts/plotoptions/series-stacking-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-normal-stacking\n * Waterfall with normal stacking\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-overlap-stacking\n * Waterfall with overlap stacking\n * @sample {highstock} stock/plotoptions/stacking/\n * Area\n *\n * @type {string}\n * @product highcharts highstock\n * @validvalue [\"normal\", \"overlap\", \"percent\", \"stream\"]\n * @apioption plotOptions.series.stacking\n */\n /**\n * Whether to apply steps to the line. Possible values are `left`,\n * `center` and `right`.\n *\n * @sample {highcharts} highcharts/plotoptions/line-step/\n * Different step line options\n * @sample {highcharts} highcharts/plotoptions/area-step/\n * Stepped, stacked area\n * @sample {highstock} stock/plotoptions/line-step/\n * Step line\n *\n * @type {string}\n * @since 1.2.5\n * @product highcharts highstock\n * @validvalue [\"left\", \"center\", \"right\"]\n * @apioption plotOptions.series.step\n */\n /**\n * The threshold, also called zero level or base level. For line type\n * series this is only used in conjunction with\n * [negativeColor](#plotOptions.series.negativeColor).\n *\n * @see [softThreshold](#plotOptions.series.softThreshold).\n *\n * @type {number|null}\n * @default 0\n * @since 3.0\n * @product highcharts highstock\n * @apioption plotOptions.series.threshold\n */\n /**\n * Set the initial visibility of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-visible/\n * Two series, one hidden and one visible\n * @sample {highstock} stock/plotoptions/series-visibility/\n * Hidden series\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.visible\n */\n /**\n * Defines the Axis on which the zones are applied.\n *\n * @see [zones](#plotOptions.series.zones)\n *\n * @sample {highcharts} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n * @sample {highstock} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n *\n * @type {string}\n * @default y\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zoneAxis\n */\n /**\n * General event handlers for the series items. These event hooks can\n * also be attached to the series at run time using the\n * `Highcharts.addEvent` function.\n *\n * @declare Highcharts.SeriesEventsOptionsObject\n *\n * @private\n */\n events: {},\n /**\n * Fires after the series has finished its initial animation, or in case\n * animation is disabled, immediately as the series is displayed.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n * @sample {highstock} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n *\n * @type {Highcharts.SeriesAfterAnimateCallbackFunction}\n * @since 4.0\n * @product highcharts highstock gantt\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.afterAnimate\n */\n /**\n * Fires when the checkbox next to the series' name in the legend is\n * clicked. One parameter, `event`, is passed to the function. The state\n * of the checkbox is found by `event.checked`. The checked item is\n * found by `event.item`. Return `false` to prevent the default action\n * which is to toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Highcharts.SeriesCheckboxClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.checkboxClick\n */\n /**\n * Fires when the series is clicked. One parameter, `event`, is passed\n * to the function, containing common event information. Additionally,\n * `event.point` holds a pointer to the nearest point on the graph.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-click/\n * Alert click info\n * @sample {highstock} stock/plotoptions/series-events-click/\n * Alert click info\n * @sample {highmaps} maps/plotoptions/series-events-click/\n * Display click info in subtitle\n *\n * @type {Highcharts.SeriesClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.click\n */\n /**\n * Fires when the series is hidden after chart generation time, either\n * by clicking the legend item or by calling `.hide()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-hide/\n * Alert when the series is hidden by clicking the legend item\n *\n * @type {Highcharts.SeriesHideCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.hide\n */\n /**\n * Fires when the legend item belonging to the series is clicked. One\n * parameter, `event`, is passed to the function. The default action\n * is to toggle the visibility of the series. This can be prevented\n * by returning `false` or calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-legenditemclick/\n * Confirm hiding and showing\n *\n * @type {Highcharts.SeriesLegendItemClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.legendItemClick\n */\n /**\n * Fires when the mouse leaves the graph. One parameter, `event`, is\n * passed to the function, containing common event information. If the\n * [stickyTracking](#plotOptions.series) option is true, `mouseOut`\n * doesn't happen before the mouse enters another graph or leaves the\n * plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOutCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOut\n */\n /**\n * Fires when the mouse enters the graph. One parameter, `event`, is\n * passed to the function, containing common event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOverCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOver\n */\n /**\n * Fires when the series is shown after chart generation time, either\n * by clicking the legend item or by calling `.show()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-show/\n * Alert when the series is shown by clicking the legend item.\n *\n * @type {Highcharts.SeriesShowCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.show\n */\n /**\n * Options for the point markers of line and scatter-like series. Properties\n * like `fillColor`, `lineColor` and `lineWidth` define the visual\n * appearance of the markers. The `symbol` option defines the shape. Other\n * series types, like column series, don't have markers, but have visual\n * options on the series level instead.\n *\n * In styled mode, the markers can be styled with the `.highcharts-point`,\n * `.highcharts-point-hover` and `.highcharts-point-select` class names.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n *\n * @sample {highmaps} maps/demo/mappoint-mapmarker\n * Using the mapmarker symbol for points\n *\n * @private\n */\n marker: {\n /**\n * Enable or disable the point marker. If `undefined`, the markers\n * are hidden when the data is dense, and shown for more widespread\n * data points.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled/\n * Disabled markers\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled-false/\n * Disabled in normal state but enabled on hover\n * @sample {highstock} stock/plotoptions/series-marker/\n * Enabled markers\n *\n * @type {boolean}\n * @default {highcharts} undefined\n * @default {highstock} false\n * @apioption plotOptions.series.marker.enabled\n */\n /**\n * The threshold for how dense the point markers should be before\n * they are hidden, given that `enabled` is not defined. The number\n * indicates the horizontal distance between the two closest points\n * in the series, as multiples of the `marker.radius`. In other\n * words, the default value of 2 means points are hidden if\n * overlapping horizontally.\n *\n * @sample highcharts/plotoptions/series-marker-enabledthreshold\n * A higher threshold\n *\n * @since 6.0.5\n */\n enabledThreshold: 2,\n /**\n * The fill color of the point marker. When `undefined`, the series'\n * or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * White fill\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.fillColor\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `width` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.height\n */\n /**\n * The color of the point marker's outline. When `undefined`, the\n * series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * Inherit from series color (undefined)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * 2px blue marker\n */\n lineWidth: 0,\n /**\n * The radius of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-radius/\n * Bigger markers\n *\n * @default {highstock} 2\n * @default {highcharts} 4\n *\n */\n radius: 4,\n /**\n * A predefined shape or symbol for the marker. When undefined, the\n * symbol is pulled from options.symbols. Other possible values are\n * `'circle'`, `'square'`,`'diamond'`, `'triangle'` and\n * `'triangle-down'`.\n *\n * Additionally, the URL to a graphic can be given on this form:\n * `'url(graphic.png)'`. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export\n * server.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols`. The callback is then\n * used by its method name, as shown in the demo.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n * @sample {highstock} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n * @sample {highmaps} maps/demo/mappoint-mapmarker\n * Using the mapmarker symbol for points\n *\n * @type {string}\n * @apioption plotOptions.series.marker.symbol\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `height` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.width\n */\n /**\n * States for a single point marker.\n *\n * @declare Highcharts.PointStatesOptionsObject\n */\n states: {\n /**\n * The normal state of a single point marker. Currently only\n * used for setting animation when returning to normal state\n * from hover.\n *\n * @declare Highcharts.PointStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * The hover state for a single point marker.\n *\n * @declare Highcharts.PointStatesHoverOptionsObject\n */\n hover: {\n /**\n * Animation when hovering over the marker.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 150\n },\n /**\n * Enable or disable the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-enabled/\n * Disabled hover state\n */\n enabled: true,\n /**\n * The fill color of the marker in hover state. When\n * `undefined`, the series' or point's fillColor for normal\n * state is used.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.fillColor\n */\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's lineColor for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linecolor/\n * White fill color, black line color\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.lineColor\n */\n /**\n * The width of the point marker's outline. When\n * `undefined`, the series' or point's lineWidth for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linewidth/\n * 3px line width\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.lineWidth\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2 as per the\n * [radiusPlus](#plotOptions.series.marker.states.hover.radiusPlus)\n * option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-radius/\n * 10px radius\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.radius\n */\n /**\n * The number of pixels to increase the radius of the\n * hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n *\n * @since 4.0.3\n */\n radiusPlus: 2,\n /**\n * The additional line width for a hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n *\n * @since 4.0.3\n */\n lineWidthPlus: 1\n },\n /**\n * The appearance of the point marker when selected. In order to\n * allow a point to be selected, set the\n * `series.allowPointSelect` option to true.\n *\n * @declare Highcharts.PointStatesSelectOptionsObject\n */\n select: {\n /**\n * Enable or disable visible feedback for selection.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-enabled/\n * Disabled select state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.marker.states.select.enabled\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-radius/\n * 10px radius for selected points\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.select.radius\n */\n /**\n * The fill color of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-fillcolor/\n * Solid red discs for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n fillColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linecolor/\n * Red line color for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linewidth/\n * 3px line width for selected points\n */\n lineWidth: 2\n }\n }\n },\n /**\n * Properties for each single point.\n *\n * @declare Highcharts.PlotSeriesPointOptions\n *\n * @private\n */\n point: {\n /**\n * Fires when a point is clicked. One parameter, `event`, is passed\n * to the function, containing common event information.\n *\n * If the `series.allowPointSelect` option is true, the default\n * action for the point's click event is to toggle the point's\n * select state. Returning `false` cancels this action.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click/\n * Click marker to alert values\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-column/\n * Click column\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-url/\n * Go to URL\n * @sample {highmaps} maps/plotoptions/series-point-events-click/\n * Click marker to display values\n * @sample {highmaps} maps/plotoptions/series-point-events-click-url/\n * Go to URL\n *\n * @type {Highcharts.PointClickCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.click\n */\n /**\n * Fires when the mouse leaves the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOutCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOut\n */\n /**\n * Fires when the mouse enters the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * Returning `false` cancels the default behavior, which is to show a\n * tooltip for the point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOverCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOver\n */\n /**\n * Fires when the point is removed using the `.remove()` method. One\n * parameter, `event`, is passed to the function. Returning `false`\n * cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n *\n * @type {Highcharts.PointRemoveCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.remove\n */\n /**\n * Fires when the point is selected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-select/\n * Report the last selected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointSelectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.select\n */\n /**\n * Fires when the point is unselected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function.\n * Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-unselect/\n * Report the last unselected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointUnselectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.unselect\n */\n /**\n * Fires when the point is updated programmatically through the\n * `.update()` method. One parameter, `event`, is passed to the\n * function. The new point options can be accessed through\n * `event.options`. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-update/\n * Confirm point updating\n *\n * @type {Highcharts.PointUpdateCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.update\n */\n /**\n * Events for each single point.\n *\n * @declare Highcharts.PointEventsOptionsObject\n */\n events: {}\n },\n /**\n * Options for the series data labels, appearing next to each data\n * point.\n *\n * Since v6.2.0, multiple data labels can be applied to each single\n * point by defining them as an array of configs.\n *\n * In styled mode, the data labels can be styled with the\n * `.highcharts-data-label-box` and `.highcharts-data-label` class names\n * ([see example](https://www.highcharts.com/samples/highcharts/css/series-datalabels)).\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled\n * Data labels enabled\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-multiple\n * Multiple data labels on a bar series\n * @sample {highcharts} highcharts/css/series-datalabels\n * Styled mode example\n * @sample {highmaps} maps/demo/color-axis\n * Choropleth map with data labels\n * @sample {highmaps} maps/demo/mappoint-datalabels-mapmarker\n * Using data labels as map markers\n *\n * @type {*|Array<*>}\n * @product highcharts highstock highmaps gantt\n *\n * @private\n */\n dataLabels: {\n /**\n * Enable or disable the initial animation when a series is displayed\n * for the `dataLabels`. The animation can also be set as a\n * configuration object. Please note that this option only applies to\n * the initial animation.\n *\n * For other animations, see [chart.animation](#chart.animation) and the\n * animation parameter under the API methods. The following properties\n * are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n *\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds. Set to `0` to render the\n * data labels immediately. As `undefined` inherits defer time from the\n * [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation.defer\n */\n /**\n * The alignment of the data label compared to the point. If `right`,\n * the right side of the label should be touching the point. For points\n * with an extent, like columns, the alignments also dictates how to\n * align it inside the box, as given with the\n * [inside](#plotOptions.column.dataLabels.inside) option. Can be one of\n * `left`, `center` or `right`.\n *\n * @sample {highcharts}\n * highcharts/plotoptions/series-datalabels-align-left/ Left\n * aligned\n * @sample {highcharts}\n * highcharts/plotoptions/bar-datalabels-align-inside-bar/ Data\n * labels inside the bar\n *\n * @type {Highcharts.AlignValue|null}\n */\n align: 'center',\n /**\n * Whether to allow data labels to overlap. To make the labels less\n * sensitive for overlapping, the\n * [dataLabels.padding](#plotOptions.series.dataLabels.padding)\n * can be set to 0.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-allowoverlap-false/\n * Don't allow overlap\n *\n * @type {boolean}\n * @default false\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.allowOverlap\n */\n /**\n * The background color or gradient for the data label. Setting it to\n * `auto` will use the point's color.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/demo/mappoint-datalabels-mapmarker\n * Data labels as map markers\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.backgroundColor\n */\n /**\n * The border color for the data label. Setting it to `auto` will use\n * the point's color. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderColor\n */\n /**\n * The border radius in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderRadius\n */\n /**\n * The border width in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderWidth\n */\n borderWidth: 0,\n /**\n * A class name for the data label. Particularly in styled mode,\n * this can be used to give each series' or point's data label\n * unique styling. In addition to this option, a default color class\n * name is added so that we can give the labels a contrast text\n * shadow.\n *\n * @sample {highcharts} highcharts/css/data-label-contrast/\n * Contrast text shadow\n * @sample {highcharts} highcharts/css/series-datalabels/\n * Styling by CSS\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.dataLabels.className\n */\n /**\n * This options is deprecated.\n * Use [style.color](#plotOptions.series.dataLabels.style) instead.\n *\n * The text color for the data labels. Defaults to `undefined`. For\n * certain series types, like column or map, the data labels can be\n * drawn inside the points. In this case the data label will be\n * drawn with maximum contrast by default. Additionally, it will be\n * given a `text-outline` style with the opposite color, to further\n * increase the contrast. This can be overridden by setting the\n * `text-outline` style to `none` in the `dataLabels.style` option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-color/\n * Red data labels\n * @sample {highmaps} maps/demo/color-axis/\n * White data labels\n *\n * @see [style.color](#plotOptions.series.dataLabels.style)\n *\n * @type {Highcharts.ColorType}\n * @deprecated 10.3\n * @apioption plotOptions.series.dataLabels.color\n */\n /**\n * Whether to hide data labels that are outside the plot area. By\n * default, the data label is moved inside the plot area according\n * to the\n * [overflow](#plotOptions.series.dataLabels.overflow)\n * option.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.3\n * @apioption plotOptions.series.dataLabels.crop\n */\n /**\n * Whether to defer displaying the data labels until the initial\n * series animation has finished. Setting to `false` renders the\n * data label immediately. If set to `true` inherits the defer\n * time set in [plotOptions.series.animation](#plotOptions.series.animation).\n *\n * @since 4.0.0\n * @type {boolean}\n * @product highcharts highstock gantt\n */\n defer: true,\n /**\n * Enable or disable the data labels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled/\n * Data labels enabled\n * @sample {highmaps} maps/demo/color-axis/\n * Data labels enabled\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.enabled\n */\n /**\n * A declarative filter to control of which data labels to display.\n * The declarative filter is designed for use when callback\n * functions are not available, like when the chart options require\n * a pure JSON structure or for use with graphical editors. For\n * programmatic control, use the `formatter` instead, and return\n * `undefined` to disable a single data label.\n *\n * @example\n * filter: {\n * property: 'percentage',\n * operator: '>',\n * value: 4\n * }\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome\n * Data labels filtered by percentage\n *\n * @declare Highcharts.DataLabelsFilterOptionsObject\n * @since 6.0.3\n * @apioption plotOptions.series.dataLabels.filter\n */\n /**\n * The operator to compare by. Can be one of `>`, `<`, `>=`, `<=`,\n * `==`, and `===`.\n *\n * @type {string}\n * @validvalue [\">\", \"<\", \">=\", \"<=\", \"==\", \"===\"]\n * @apioption plotOptions.series.dataLabels.filter.operator\n */\n /**\n * The point property to filter by. Point options are passed\n * directly to properties, additionally there are `y` value,\n * `percentage` and others listed under {@link Highcharts.Point}\n * members.\n *\n * @type {string}\n * @apioption plotOptions.series.dataLabels.filter.property\n */\n /**\n * The value to compare against.\n *\n * @type {number}\n * @apioption plotOptions.series.dataLabels.filter.value\n */\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format-subexpression/\n * Complex logic in the format string\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value in the data label\n *\n * @type {string}\n * @default y\n * @default point.value\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that if a\n * `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n */\n formatter: function () {\n const { numberFormatter } = this.series.chart;\n return typeof this.y !== 'number' ?\n '' : numberFormatter(this.y, -1);\n },\n /**\n * For points with an extent, like columns or map areas, whether to\n * align the data label inside the box or to the actual value point.\n * Defaults to `false` in most cases, `true` in stacked columns.\n *\n * @type {boolean}\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.inside\n */\n /**\n * Format for points with the value of null. Works analogously to\n * [format](#plotOptions.series.dataLabels.format). `nullFormat` can\n * be applied only to series which support displaying null points\n * i.e `heatmap` or `tilemap`. Does not work with series that don't\n * display null points, like `line`, `column`, `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {boolean|string}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormat\n */\n /**\n * Callback JavaScript function that defines formatting for points\n * with the value of null. Works analogously to\n * [formatter](#plotOptions.series.dataLabels.formatter).\n * `nullFormatter` can be applied only to series which support\n * displaying null points i.e `heatmap` or `tilemap`. Does not work\n * with series that don't display null points, like `line`, `column`,\n * `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormatter\n */\n /**\n * How to handle data labels that flow outside the plot area. The\n * default is `\"justify\"`, which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display data labels outside the plot area, set `crop` to\n * `false` and `overflow` to `\"allow\"`.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @default justify\n * @since 3.0.6\n * @apioption plotOptions.series.dataLabels.overflow\n */\n /**\n * When either the `borderWidth` or the `backgroundColor` is set,\n * this is the padding within the box.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @since 2.2.1\n */\n padding: 5,\n /**\n * Aligns data labels relative to points. If `center` alignment is\n * not possible, it defaults to `right`.\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @apioption plotOptions.series.dataLabels.position\n */\n /**\n * Text rotation in degrees. Note that due to a more complex\n * structure, backgrounds, borders and padding will be lost on a\n * rotated data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical labels\n *\n * @type {number}\n * @default 0\n * @apioption plotOptions.series.dataLabels.rotation\n */\n /**\n * The shadow of the box. Works best with `borderWidth` or\n * `backgroundColor`. Since 2.3 the shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity`\n * and `width`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.shadow\n */\n /**\n * The name of a symbol to use for the border around the label.\n * Symbols are predefined functions on the Renderer object.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-shape/\n * A callout for annotations\n *\n * @type {string}\n * @default square\n * @since 4.1.2\n * @apioption plotOptions.series.dataLabels.shape\n */\n /**\n * Styles for the label. The default `color` setting is\n * `\"contrast\"`, which is a pseudo color that Highcharts picks up\n * and applies the maximum contrast to the underlying point item,\n * for example the bar in a bar chart.\n *\n * The `textOutline` is a pseudo property that applies an outline of\n * the given width with the given color, which by default is the\n * maximum contrast to the text. So a bright text color will result\n * in a black text outline for maximum readability on a mixed\n * background. In some cases, especially with grayscale text, the\n * text outline doesn't work well, in which cases it can be disabled\n * by setting it to `\"none\"`. When `useHTML` is true, the\n * `textOutline` will not be picked up. In this, case, the same\n * effect can be acheived through the `text-shadow` CSS property.\n *\n * For some series types, where each point has an extent, like for\n * example tree maps, the data label may overflow the point. There\n * are two strategies for handling overflow. By default, the text\n * will wrap to multiple lines. The other strategy is to set\n * `style.textOverflow` to `ellipsis`, which will keep the text on\n * one line plus it will break inside long words.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-style/\n * Bold labels\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow/\n * Long labels truncated with an ellipsis in a pie\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap/\n * Long labels are wrapped in a pie\n * @sample {highmaps} maps/demo/color-axis/\n * Bold labels\n *\n * @type {Highcharts.CSSObject}\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.style\n */\n style: {\n /** @internal */\n fontSize: '0.7em',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n color: 'contrast',\n /** @internal */\n textOutline: '1px contrast'\n },\n /**\n * Options for a label text which should follow marker's shape.\n * Border and background are disabled for a label that follows a\n * path.\n *\n * **Note:** Only SVG-based renderer supports this option. Setting\n * `useHTML` to true will disable this option.\n *\n * @declare Highcharts.DataLabelsTextPathOptionsObject\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath\n */\n /**\n * Presentation attributes for the text path.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.attributes\n */\n /**\n * Enable or disable `textPath` option for link's or marker's data\n * labels.\n *\n * @type {boolean}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.enabled\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.useHTML\n */\n /**\n * The vertical alignment of a data label. Can be one of `top`,\n * `middle` or `bottom`. The default value depends on the data, for\n * instance in a column chart, the label is above positive values\n * and below negative values.\n *\n * @type {Highcharts.VerticalAlignValue|null}\n * @since 2.3.3\n */\n verticalAlign: 'bottom',\n /**\n * The x position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n * @sample {highcharts} highcharts/plotoptions/bar-datalabels-align-inside-bar/\n * Data labels inside the bar\n */\n x: 0,\n /**\n * The z index of the data labels. Use a `zIndex` of 6 to display it above\n * the series, or use a `zIndex` of 2 to display it behind the series.\n *\n * @type {number}\n * @default 6\n * @since 2.3.5\n * @apioption plotOptions.series.dataLabels.zIndex\n */\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n */\n y: 0\n },\n /**\n * When the series contains less points than the crop threshold, all\n * points are drawn, even if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns), is that animation is performed on\n * updates. On the other hand, when the series contains more points than\n * the crop threshold, the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @since 2.2\n * @product highcharts highstock\n *\n * @private\n */\n cropThreshold: 300,\n /**\n * Opacity of a series parts: line, fill (e.g. area) and dataLabels.\n *\n * @see [states.inactive.opacity](#plotOptions.series.states.inactive.opacity)\n *\n * @since 7.1.0\n *\n * @private\n */\n opacity: 1,\n /**\n * The width of each point on the x axis. For example in a column chart\n * with one value each day, the pointRange would be 1 day (= 24 * 3600\n * * 1000 milliseconds). This is normally computed automatically, but\n * this option can be used to override the automatic value.\n *\n * @product highstock\n *\n * @private\n */\n pointRange: 0,\n /**\n * When this is true, the series will not cause the Y axis to cross\n * the zero plane (or [threshold](#plotOptions.series.threshold) option)\n * unless the data actually crosses the plane.\n *\n * For example, if `softThreshold` is `false`, a series of 0, 1, 2,\n * 3 will make the Y axis show negative values according to the\n * `minPadding` option. If `softThreshold` is `true`, the Y axis starts\n * at 0.\n *\n * @since 4.1.9\n * @product highcharts highstock\n *\n * @private\n */\n softThreshold: true,\n /**\n * @declare Highcharts.SeriesStatesOptionsObject\n *\n * @private\n */\n states: {\n /**\n * The normal state of a series, or for point items in column, pie\n * and similar series. Currently only used for setting animation\n * when returning to normal state from hover.\n *\n * @declare Highcharts.SeriesStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * Options for the hovered series. These settings override the\n * normal state options when a series is moused over or touched.\n *\n * @declare Highcharts.SeriesStatesHoverOptionsObject\n */\n hover: {\n /**\n * Enable separate styles for the hovered series to visualize\n * that the user hovers either the series itself or the legend.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-pie/\n * Pie\n *\n * @type {boolean}\n * @default true\n * @since 1.2\n * @apioption plotOptions.series.states.hover.enabled\n */\n /**\n * Animation setting for hovering the graph in line-type series.\n *\n * @type {boolean|Partial}\n * @since 5.0.8\n * @product highcharts highstock\n */\n animation: {\n /**\n * The duration of the hover animation in milliseconds. By\n * default the hover state animates quickly in, and slowly\n * back to normal.\n *\n * @internal\n */\n duration: 150\n },\n /**\n * Pixel width of the graph line. By default this property is\n * undefined, and the `lineWidthPlus` property dictates how much\n * to increase the linewidth from normal state.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidth/\n * 5px line on hover\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.lineWidth\n */\n /**\n * The additional line width for the graph of a hovered series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n *\n * @since 4.0.3\n * @product highcharts highstock\n */\n lineWidthPlus: 1,\n /**\n * In Highcharts 1.0, the appearance of all markers belonging\n * to the hovered series. For settings on the hover state of the\n * individual point, see\n * [marker.states.hover](#plotOptions.series.marker.states.hover).\n *\n * @deprecated\n *\n * @extends plotOptions.series.marker\n * @excluding states, symbol\n * @product highcharts highstock\n */\n marker: {\n // lineWidth: base + 1,\n // radius: base + 1\n },\n /**\n * Options for the halo appearing around the hovered point in\n * line-type series as well as outside the hovered slice in pie\n * charts. By default the halo is filled by the current point or\n * series color with an opacity of 0.25\\. The halo can be\n * disabled by setting the `halo` option to `null`.\n *\n * In styled mode, the halo is styled with the\n * `.highcharts-halo` class, with colors inherited from\n * `.highcharts-color-{n}`.\n *\n * @sample {highcharts} highcharts/plotoptions/halo/\n * Halo options\n * @sample {highstock} highcharts/plotoptions/halo/\n * Halo options\n *\n * @declare Highcharts.SeriesStatesHoverHaloOptionsObject\n * @type {null|*}\n * @since 4.0\n * @product highcharts highstock\n */\n halo: {\n /**\n * A collection of SVG attributes to override the appearance\n * of the halo, for example `fill`, `stroke` and\n * `stroke-width`.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 4.0\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.halo.attributes\n */\n /**\n * The pixel size of the halo. For point markers this is the\n * radius of the halo. For pie slices it is the width of the\n * halo outside the slice. For bubbles it defaults to 5 and\n * is the width of the halo outside the bubble.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n size: 10,\n /**\n * Opacity for the halo unless a specific fill is overridden\n * using the `attributes` setting. Note that Highcharts is\n * only able to apply opacity to colors of hex or rgb(a)\n * formats.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n opacity: 0.25\n }\n },\n /**\n * Specific options for point in selected states, after being\n * selected by\n * [allowPointSelect](#plotOptions.series.allowPointSelect)\n * or programmatically.\n *\n * @sample maps/plotoptions/series-allowpointselect/\n * Allow point select demo\n *\n * @declare Highcharts.SeriesStatesSelectOptionsObject\n * @extends plotOptions.series.states.hover\n * @excluding brightness\n */\n select: {\n animation: {\n /** @internal */\n duration: 0\n }\n },\n /**\n * The opposite state of a hover for series.\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @declare Highcharts.SeriesStatesInactiveOptionsObject\n */\n inactive: {\n /**\n * Enable or disable the inactive state for a series\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.states.inactive.enabled\n */\n /**\n * The animation for entering the inactive state.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 150\n },\n /**\n * Opacity of series elements (dataLabels, line, area).\n *\n * @type {number}\n */\n opacity: 0.2\n }\n },\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event on a\n * series isn't triggered until the mouse moves over another series, or\n * out of the plot area. When false, the `mouseOut` event on a series is\n * triggered when the mouse leaves the area around the series' graph or\n * markers. This also implies the tooltip when not shared. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series. Defaults to true\n * for line and area type series, but to false for columns, pies etc.\n *\n * **Note:** The boost module will force this option because of\n * technical limitations.\n *\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-true/\n * True by default\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-false/\n * False\n *\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 2.0\n *\n * @private\n */\n stickyTracking: true,\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip), but only\n * the following properties can be defined on a series level.\n *\n * @declare Highcharts.SeriesTooltipOptionsObject\n * @since 2.3\n * @extends tooltip\n * @excluding animation, backgroundColor, borderColor, borderRadius,\n * borderWidth, className, crosshairs, enabled, formatter,\n * headerShape, hideDelay, outside, padding, positioner,\n * shadow, shape, shared, snap, split, stickOnContact,\n * style, useHTML\n * @apioption plotOptions.series.tooltip\n */\n /**\n * When a series contains a data array that is longer than this, only\n * one dimensional arrays of numbers, or two dimensional arrays with\n * x and y values are allowed. Also, only the first point is tested,\n * and the rest are assumed to be the same format. This saves expensive\n * data checking and indexing in long series. Set it to `0` disable.\n *\n * Note:\n * In boost mode turbo threshold is forced. Only array of numbers or\n * two dimensional arrays are allowed.\n *\n * @since 2.2\n * @product highcharts highstock gantt\n *\n * @private\n */\n turboThreshold: 1000,\n /**\n * An array defining zones within a series. Zones can be applied to the\n * X axis, Y axis or Z axis for bubbles, according to the `zoneAxis`\n * option. The zone definitions have to be in ascending order regarding\n * to the value.\n *\n * In styled mode, the color zones are styled with the\n * `.highcharts-zone-{n}` class, or custom classed from the `className`\n * option\n * ([view live demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/color-zones/)).\n *\n * @see [zoneAxis](#plotOptions.series.zoneAxis)\n *\n * @sample {highcharts} highcharts/series/color-zones-simple/\n * Color zones\n * @sample {highstock} highcharts/series/color-zones-simple/\n * Color zones\n *\n * @declare Highcharts.SeriesZonesOptionsObject\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones\n */\n /**\n * Styled mode only. A custom class name for the zone.\n *\n * @sample highcharts/css/color-zones/\n * Zones styled by class name\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.zones.className\n */\n /**\n * Defines the color of the series.\n *\n * @see [series color](#plotOptions.series.color)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.color\n */\n /**\n * A name for the dash style to use for the graph.\n *\n * @see [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n *\n * @sample {highcharts|highstock} highcharts/series/color-zones-dashstyle-dot/\n * Dashed line indicates prognosis\n *\n * @type {Highcharts.DashStyleValue}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.dashStyle\n */\n /**\n * Defines the fill color for the series (in area type series)\n *\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.fillColor\n */\n /**\n * The value up to where the zone extends, if undefined the zones\n * stretches to the last value in the series.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.value\n */\n /**\n * When using dual or multiple color axes, this number defines which\n * colorAxis the particular series is connected to. It refers to\n * either the\n * {@link #colorAxis.id|axis id}\n * or the index of the axis in the colorAxis array, with 0 being the\n * first. Set this option to false to prevent a series from connecting\n * to the default color axis.\n *\n * Since v7.2.0 the option can also be an axis id or an axis index\n * instead of a boolean flag.\n *\n * @sample highcharts/coloraxis/coloraxis-with-pie/\n * Color axis with pie series\n * @sample highcharts/coloraxis/multiple-coloraxis/\n * Multiple color axis\n *\n * @type {number|string|boolean}\n * @default 0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorAxis\n */\n /**\n * Determines what data value should be used to calculate point color\n * if `colorAxis` is used. Requires to set `min` and `max` if some\n * custom point property is used or if approximation for data grouping\n * is set to `'sum'`.\n *\n * @sample highcharts/coloraxis/custom-color-key/\n * Custom color key\n * @sample highcharts/coloraxis/color-key-with-stops/\n * Custom colorKey with color axis stops\n * @sample highcharts/coloraxis/changed-default-color-key/\n * Changed default color key\n *\n * @type {string}\n * @default y\n * @since 7.2.0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorKey\n */\n /**\n * What type of legend symbol to render for this series. Can be one of\n * `lineMarker` or `rectangle`.\n *\n * @validvalue [\"lineMarker\", \"rectangle\"]\n *\n * @sample {highcharts} highcharts/series/legend-symbol/\n * Change the legend symbol\n *\n * @type {string}\n * @default rectangle\n * @since 11.0.1\n * @apioption plotOptions.series.legendSymbol\n */\n /**\n * Determines whether the series should look for the nearest point\n * in both dimensions or just the x-dimension when hovering the series.\n * Defaults to `'xy'` for scatter series and `'x'` for most other\n * series. If the data has duplicate x-values, it is recommended to\n * set this to `'xy'` to allow hovering over all points.\n *\n * Applies only to series types using nearest neighbor search (not\n * direct hover) for tooltip.\n *\n * @sample {highcharts} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highstock} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highmaps} highcharts/series/findnearestpointby/\n * Different hover behaviors\n *\n * @since 5.0.10\n * @validvalue [\"x\", \"xy\"]\n *\n * @private\n */\n findNearestPointBy: 'x'\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return seriesDefaults;\n });\n _registerModule(_modules, 'Core/Series/SeriesRegistry.js', [_modules['Core/Globals.js'], _modules['Core/Defaults.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (H, D, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { extendClass, merge } = U;\n /* *\n *\n * Namespace\n *\n * */\n var SeriesRegistry;\n (function (SeriesRegistry) {\n /* *\n *\n * Properties\n *\n * */\n /**\n * @internal\n * @todo Move `Globals.seriesTypes` code to her.\n */\n SeriesRegistry.seriesTypes = H.seriesTypes;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Registers class pattern of a series.\n *\n * @private\n */\n function registerSeriesType(seriesType, SeriesClass) {\n const defaultPlotOptions = defaultOptions.plotOptions || {}, seriesOptions = SeriesClass.defaultOptions, seriesProto = SeriesClass.prototype;\n seriesProto.type = seriesType;\n if (!seriesProto.pointClass) {\n seriesProto.pointClass = Point;\n }\n if (seriesOptions) {\n defaultPlotOptions[seriesType] = seriesOptions;\n }\n SeriesRegistry.seriesTypes[seriesType] = SeriesClass;\n }\n SeriesRegistry.registerSeriesType = registerSeriesType;\n /**\n * Old factory to create new series prototypes.\n *\n * @deprecated\n * @function Highcharts.seriesType\n *\n * @param {string} type\n * The series type name.\n *\n * @param {string} parent\n * The parent series type name. Use `line` to inherit from the basic\n * {@link Series} object.\n *\n * @param {Highcharts.SeriesOptionsType|Highcharts.Dictionary<*>} options\n * The additional default options that are merged with the parent's options.\n *\n * @param {Highcharts.Dictionary<*>} [props]\n * The properties (functions and primitives) to set on the new prototype.\n *\n * @param {Highcharts.Dictionary<*>} [pointProps]\n * Members for a series-specific extension of the {@link Point} prototype if\n * needed.\n *\n * @return {Highcharts.Series}\n * The newly created prototype as extended from {@link Series} or its\n * derivatives.\n */\n function seriesType(type, parent, options, seriesProto, pointProto) {\n const defaultPlotOptions = defaultOptions.plotOptions || {};\n parent = parent || '';\n // Merge the options\n defaultPlotOptions[type] = merge(defaultPlotOptions[parent], options);\n // Create the class\n registerSeriesType(type, extendClass(SeriesRegistry.seriesTypes[parent] || function () { }, seriesProto));\n SeriesRegistry.seriesTypes[type].prototype.type = type;\n // Create the point class if needed\n if (pointProto) {\n SeriesRegistry.seriesTypes[type].prototype.pointClass = extendClass(Point, pointProto);\n }\n return SeriesRegistry.seriesTypes[type];\n }\n SeriesRegistry.seriesType = seriesType;\n })(SeriesRegistry || (SeriesRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return SeriesRegistry;\n });\n _registerModule(_modules, 'Core/Series/Series.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/Point.js'], _modules['Core/Series/SeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (A, D, F, H, LegendSymbol, Point, SeriesDefaults, SeriesRegistry, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject, setAnimation } = A;\n const { defaultOptions } = D;\n const { registerEventOptions } = F;\n const { hasTouch, svg, win } = H;\n const { seriesTypes } = SeriesRegistry;\n const { addEvent, arrayMax, arrayMin, clamp, correctFloat, defined, diffObjects, erase, error, extend, find, fireEvent, getClosestDistance, getNestedProperty, insertItem, isArray, isNumber, isString, merge, objectEach, pick, removeEvent, splat, syncTimeout } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * This is the base series prototype that all other series types inherit from.\n * A new series is initialized either through the\n * [series](https://api.highcharts.com/highcharts/series)\n * option structure, or after the chart is initialized, through\n * {@link Highcharts.Chart#addSeries}.\n *\n * The object can be accessed in a number of ways. All series and point event\n * handlers give a reference to the `series` object. The chart object has a\n * {@link Highcharts.Chart#series|series} property that is a collection of all\n * the chart's series. The point objects and axis objects also have the same\n * reference.\n *\n * Another way to reference the series programmatically is by `id`. Add an id\n * in the series configuration options, and get the series object by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the series are given in three levels. Options for\n * all series in a chart are given in the\n * [plotOptions.series](https://api.highcharts.com/highcharts/plotOptions.series)\n * object. Then options for all series of a specific type\n * are given in the plotOptions of that type, for example `plotOptions.line`.\n * Next, options for one single series are given in the series array, or as\n * arguments to `chart.addSeries`.\n *\n * The data in the series is stored in various arrays.\n *\n * - First, `series.options.data` contains all the original config options for\n * each point whether added by options or methods like `series.addPoint`.\n *\n * - Next, `series.data` contains those values converted to points, but in case\n * the series data length exceeds the `cropThreshold`, or if the data is\n * grouped, `series.data` doesn't contain all the points. It only contains the\n * points that have been created on demand.\n *\n * - Then there's `series.points` that contains all currently visible point\n * objects. In case of cropping, the cropped-away points are not part of this\n * array. The `series.points` array starts at `series.cropStart` compared to\n * `series.data` and `series.options.data`. If however the series data is\n * grouped, these can't be correlated one to one.\n *\n * - `series.xData` and `series.processedXData` contain clean x values,\n * equivalent to `series.data` and `series.points`.\n *\n * - `series.yData` and `series.processedYData` contain clean y values,\n * equivalent to `series.data` and `series.points`.\n *\n * @class\n * @name Highcharts.Series\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.SeriesOptionsType|object} options\n * The series options.\n */\n class Series {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n this._i = void 0;\n this.chart = void 0;\n this.data = void 0;\n this.eventOptions = void 0;\n this.eventsToUnbind = void 0;\n this.index = void 0;\n this.linkedSeries = void 0;\n this.options = void 0;\n this.points = void 0;\n this.processedXData = void 0;\n this.processedYData = void 0;\n this.tooltipOptions = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zones = void 0;\n /** eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n init(chart, userOptions) {\n fireEvent(this, 'init', { options: userOptions });\n const series = this, chartSeries = chart.series;\n // The 'eventsToUnbind' property moved from prototype into the\n // Series init to avoid reference to the same array between\n // the different series and charts. #12959, #13937\n this.eventsToUnbind = [];\n /**\n * Read only. The chart that the series belongs to.\n *\n * @name Highcharts.Series#chart\n * @type {Highcharts.Chart}\n */\n series.chart = chart;\n /**\n * Read only. The series' type, like \"line\", \"area\", \"column\" etc.\n * The type in the series options anc can be altered using\n * {@link Series#update}.\n *\n * @name Highcharts.Series#type\n * @type {string}\n */\n /**\n * Read only. The series' current options. To update, use\n * {@link Series#update}.\n *\n * @name Highcharts.Series#options\n * @type {Highcharts.SeriesOptionsType}\n */\n series.options = series.setOptions(userOptions);\n const options = series.options;\n series.linkedSeries = [];\n // bind the axes\n series.bindAxes();\n extend(series, {\n /**\n * The series name as given in the options. Defaults to\n * \"Series {n}\".\n *\n * @name Highcharts.Series#name\n * @type {string}\n */\n name: options.name,\n state: '',\n /**\n * Read only. The series' visibility state as set by {@link\n * Series#show}, {@link Series#hide}, or in the initial\n * configuration.\n *\n * @name Highcharts.Series#visible\n * @type {boolean}\n */\n visible: options.visible !== false,\n /**\n * Read only. The series' selected state as set by {@link\n * Highcharts.Series#select}.\n *\n * @name Highcharts.Series#selected\n * @type {boolean}\n */\n selected: options.selected === true // false by default\n });\n registerEventOptions(this, options);\n const events = options.events;\n if ((events && events.click) ||\n (options.point &&\n options.point.events &&\n options.point.events.click) ||\n options.allowPointSelect) {\n chart.runTrackerClick = true;\n }\n series.getColor();\n series.getSymbol();\n // Initialize the parallel data arrays\n series.parallelArrays.forEach(function (key) {\n if (!series[key + 'Data']) {\n series[key + 'Data'] = [];\n }\n });\n // Mark cartesian\n if (series.isCartesian) {\n chart.hasCartesianSeries = true;\n }\n // Get the index and register the series in the chart. The index is\n // one more than the current latest series index (#5960).\n let lastSeries;\n if (chartSeries.length) {\n lastSeries = chartSeries[chartSeries.length - 1];\n }\n series._i = pick(lastSeries && lastSeries._i, -1) + 1;\n series.opacity = series.options.opacity;\n // Insert the series and re-order all series above the insertion\n // point.\n chart.orderItems('series', insertItem(this, chartSeries));\n // Set options for series with sorting and set data later.\n if (options.dataSorting && options.dataSorting.enabled) {\n series.setDataSortingOptions();\n }\n else if (!series.points && !series.data) {\n series.setData(options.data, false);\n }\n fireEvent(this, 'afterInit');\n }\n /**\n * Check whether the series item is itself or inherits from a certain\n * series type.\n *\n * @function Highcharts.Series#is\n * @param {string} type The type of series to check for, can be either\n * featured or custom series types. For example `column`, `pie`,\n * `ohlc` etc.\n *\n * @return {boolean}\n * True if this item is or inherits from the given type.\n */\n is(type) {\n return seriesTypes[type] && this instanceof seriesTypes[type];\n }\n /**\n * Set the xAxis and yAxis properties of cartesian series, and register\n * the series in the `axis.series` array.\n *\n * @private\n * @function Highcharts.Series#bindAxes\n */\n bindAxes() {\n const series = this, seriesOptions = series.options, chart = series.chart;\n let axisOptions;\n fireEvent(this, 'bindAxes', null, function () {\n // repeat for xAxis and yAxis\n (series.axisTypes || []).forEach(function (coll) {\n // loop through the chart's axis objects\n chart[coll].forEach(function (axis) {\n axisOptions = axis.options;\n // apply if the series xAxis or yAxis option mathches\n // the number of the axis, or if undefined, use the\n // first axis\n if (pick(seriesOptions[coll], 0) === axis.index ||\n (typeof seriesOptions[coll] !==\n 'undefined' &&\n seriesOptions[coll] === axisOptions.id)) {\n // register this series in the axis.series lookup\n insertItem(series, axis.series);\n // set this series.xAxis or series.yAxis reference\n /**\n * Read only. The unique xAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#xAxis\n * @type {Highcharts.Axis}\n */\n /**\n * Read only. The unique yAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#yAxis\n * @type {Highcharts.Axis}\n */\n series[coll] = axis;\n // mark dirty for redraw\n axis.isDirty = true;\n }\n });\n // The series needs an X and an Y axis\n if (!series[coll] &&\n series.optionalAxis !== coll) {\n error(18, true, chart);\n }\n });\n });\n fireEvent(this, 'afterBindAxes');\n }\n /**\n * For simple series types like line and column, the data values are\n * held in arrays like xData and yData for quick lookup to find extremes\n * and more. For multidimensional series like bubble and map, this can\n * be extended with arrays like zData and valueData by adding to the\n * `series.parallelArrays` array.\n *\n * @private\n * @function Highcharts.Series#updateParallelArrays\n */\n updateParallelArrays(point, i, iArgs) {\n const series = point.series, fn = isNumber(i) ?\n // Insert the value in the given position\n function (key) {\n const val = key === 'y' && series.toYData ?\n series.toYData(point) :\n point[key];\n series[key + 'Data'][i] = val;\n } :\n // Apply the method specified in i with the following\n // arguments as arguments\n function (key) {\n Array.prototype[i].apply(series[key + 'Data'], iArgs);\n };\n series.parallelArrays.forEach(fn);\n }\n /**\n * Define hasData functions for series. These return true if there\n * are data points on this series within the plot area.\n *\n * @private\n * @function Highcharts.Series#hasData\n */\n hasData() {\n return ((this.visible &&\n typeof this.dataMax !== 'undefined' &&\n typeof this.dataMin !== 'undefined') || ( // #3703\n this.visible &&\n this.yData &&\n this.yData.length > 0) // #9758\n );\n }\n /**\n * Return an auto incremented x value based on the pointStart and\n * pointInterval options. This is only used if an x value is not given\n * for the point that calls autoIncrement.\n *\n * @private\n * @function Highcharts.Series#autoIncrement\n */\n autoIncrement(x) {\n const options = this.options, pointIntervalUnit = options.pointIntervalUnit, relativeXValue = options.relativeXValue, time = this.chart.time;\n let xIncrement = this.xIncrement, date, pointInterval;\n xIncrement = pick(xIncrement, options.pointStart, 0);\n this.pointInterval = pointInterval = pick(this.pointInterval, options.pointInterval, 1);\n if (relativeXValue && isNumber(x)) {\n pointInterval *= x;\n }\n // Added code for pointInterval strings\n if (pointIntervalUnit) {\n date = new time.Date(xIncrement);\n if (pointIntervalUnit === 'day') {\n time.set('Date', date, time.get('Date', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'month') {\n time.set('Month', date, time.get('Month', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'year') {\n time.set('FullYear', date, time.get('FullYear', date) + pointInterval);\n }\n pointInterval = date.getTime() - xIncrement;\n }\n if (relativeXValue && isNumber(x)) {\n return xIncrement + pointInterval;\n }\n this.xIncrement = xIncrement + pointInterval;\n return xIncrement;\n }\n /**\n * Internal function to set properties for series if data sorting is\n * enabled.\n *\n * @private\n * @function Highcharts.Series#setDataSortingOptions\n */\n setDataSortingOptions() {\n const options = this.options;\n extend(this, {\n requireSorting: false,\n sorted: false,\n enabledDataSorting: true,\n allowDG: false\n });\n // To allow unsorted data for column series.\n if (!defined(options.pointRange)) {\n options.pointRange = 1;\n }\n }\n /**\n * Set the series options by merging from the options tree. Called\n * internally on initializing and updating series. This function will\n * not redraw the series. For API usage, use {@link Series#update}.\n * @private\n * @function Highcharts.Series#setOptions\n * @param {Highcharts.SeriesOptionsType} itemOptions\n * The series options.\n * @emits Highcharts.Series#event:afterSetOptions\n */\n setOptions(itemOptions) {\n var _a,\n _b;\n const chart = this.chart, chartOptions = chart.options, plotOptions = chartOptions.plotOptions, userOptions = chart.userOptions || {}, seriesUserOptions = merge(itemOptions), styledMode = chart.styledMode, e = {\n plotOptions: plotOptions,\n userOptions: seriesUserOptions\n };\n let zone;\n fireEvent(this, 'setOptions', e);\n // These may be modified by the event\n const typeOptions = e.plotOptions[this.type], userPlotOptions = (userOptions.plotOptions || {}), userPlotOptionsSeries = userPlotOptions.series || {}, defaultPlotOptionsType = (defaultOptions.plotOptions[this.type] || {}), userPlotOptionsType = userPlotOptions[this.type] || {};\n // use copy to prevent undetected changes (#9762)\n /**\n * Contains series options by the user without defaults.\n * @name Highcharts.Series#userOptions\n * @type {Highcharts.SeriesOptionsType}\n */\n this.userOptions = e.userOptions;\n const options = merge(typeOptions, plotOptions.series, \n // #3881, chart instance plotOptions[type] should trump\n // plotOptions.series\n userPlotOptionsType, seriesUserOptions);\n // The tooltip options are merged between global and series specific\n // options. Importance order asscendingly:\n // globals: (1)tooltip, (2)plotOptions.series,\n // (3)plotOptions[this.type]\n // init userOptions with possible later updates: 4-6 like 1-3 and\n // (7)this series options\n this.tooltipOptions = merge(defaultOptions.tooltip, // 1\n (_a = defaultOptions.plotOptions.series) === null || _a === void 0 ? void 0 : _a.tooltip, // 2\n defaultPlotOptionsType === null || defaultPlotOptionsType === void 0 ? void 0 : defaultPlotOptionsType.tooltip, // 3\n chart.userOptions.tooltip, // 4\n (_b = userPlotOptions.series) === null || _b === void 0 ? void 0 : _b.tooltip, // 5\n userPlotOptionsType.tooltip, // 6\n seriesUserOptions.tooltip // 7\n );\n // When shared tooltip, stickyTracking is true by default,\n // unless user says otherwise.\n this.stickyTracking = pick(seriesUserOptions.stickyTracking, userPlotOptionsType.stickyTracking, userPlotOptionsSeries.stickyTracking, (this.tooltipOptions.shared && !this.noSharedTooltip ?\n true :\n options.stickyTracking));\n // Delete marker object if not allowed (#1125)\n if (typeOptions.marker === null) {\n delete options.marker;\n }\n // Handle color zones\n this.zoneAxis = options.zoneAxis;\n const zones = this.zones = (options.zones || []).slice();\n if ((options.negativeColor || options.negativeFillColor) &&\n !options.zones) {\n zone = {\n value: options[this.zoneAxis + 'Threshold'] ||\n options.threshold ||\n 0,\n className: 'highcharts-negative'\n };\n if (!styledMode) {\n zone.color = options.negativeColor;\n zone.fillColor = options.negativeFillColor;\n }\n zones.push(zone);\n }\n if (zones.length) { // Push one extra zone for the rest\n if (defined(zones[zones.length - 1].value)) {\n zones.push(styledMode ? {} : {\n color: this.color,\n fillColor: this.fillColor\n });\n }\n }\n fireEvent(this, 'afterSetOptions', { options: options });\n return options;\n }\n /**\n * Return series name in \"Series {Number}\" format or the one defined by\n * a user. This method can be simply overridden as series name format\n * can vary (e.g. technical indicators).\n *\n * @function Highcharts.Series#getName\n *\n * @return {string}\n * The series name.\n */\n getName() {\n // #4119\n return pick(this.options.name, 'Series ' + (this.index + 1));\n }\n /**\n * @private\n * @function Highcharts.Series#getCyclic\n */\n getCyclic(prop, value, defaults) {\n const chart = this.chart, indexName = `${prop}Index`, counterName = `${prop}Counter`, len = (\n // Symbol count\n (defaults === null || defaults === void 0 ? void 0 : defaults.length) ||\n // Color count\n chart.options.chart.colorCount);\n let i, setting;\n if (!value) {\n // Pick up either the colorIndex option, or the series.colorIndex\n // after Series.update()\n setting = pick(prop === 'color' ? this.options.colorIndex : void 0, this[indexName]);\n if (defined(setting)) { // after Series.update()\n i = setting;\n }\n else {\n // #6138\n if (!chart.series.length) {\n chart[counterName] = 0;\n }\n i = chart[counterName] % len;\n chart[counterName] += 1;\n }\n if (defaults) {\n value = defaults[i];\n }\n }\n // Set the colorIndex\n if (typeof i !== 'undefined') {\n this[indexName] = i;\n }\n this[prop] = value;\n }\n /**\n * Get the series' color based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getColor\n */\n getColor() {\n if (this.chart.styledMode) {\n this.getCyclic('color');\n }\n else if (this.options.colorByPoint) {\n this.color = \"#cccccc\" /* Palette.neutralColor20 */;\n }\n else {\n this.getCyclic('color', this.options.color ||\n defaultOptions.plotOptions[this.type].color, this.chart.options.colors);\n }\n }\n /**\n * Get all points' instances created for this series.\n *\n * @private\n * @function Highcharts.Series#getPointsCollection\n */\n getPointsCollection() {\n return (this.hasGroupedData ? this.points : this.data) || [];\n }\n /**\n * Get the series' symbol based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getSymbol\n */\n getSymbol() {\n const seriesMarkerOption = this.options.marker;\n this.getCyclic('symbol', seriesMarkerOption.symbol, this.chart.options.symbols);\n }\n /**\n * Finds the index of an existing point that matches the given point\n * options.\n *\n * @private\n * @function Highcharts.Series#findPointIndex\n * @param {Highcharts.PointOptionsObject} optionsObject\n * The options of the point.\n * @param {number} fromIndex\n * The index to start searching from, used for optimizing series with\n * required sorting.\n * @return {number|undefined}\n * Returns the index of a matching point, or undefined if no match is found.\n */\n findPointIndex(optionsObject, fromIndex) {\n const id = optionsObject.id, x = optionsObject.x, oldData = this.points, dataSorting = this.options.dataSorting;\n let matchingPoint, matchedById, pointIndex;\n if (id) {\n const item = this.chart.get(id);\n if (item instanceof Point) {\n matchingPoint = item;\n }\n }\n else if (this.linkedParent ||\n this.enabledDataSorting ||\n this.options.relativeXValue) {\n let matcher = (oldPoint) => !oldPoint.touched &&\n oldPoint.index === optionsObject.index;\n if (dataSorting && dataSorting.matchByName) {\n matcher = (oldPoint) => !oldPoint.touched &&\n oldPoint.name === optionsObject.name;\n }\n else if (this.options.relativeXValue) {\n matcher = (oldPoint) => !oldPoint.touched &&\n oldPoint.options.x === optionsObject.x;\n }\n matchingPoint = find(oldData, matcher);\n // Add unmatched point as a new point\n if (!matchingPoint) {\n return void 0;\n }\n }\n if (matchingPoint) {\n pointIndex = matchingPoint && matchingPoint.index;\n if (typeof pointIndex !== 'undefined') {\n matchedById = true;\n }\n }\n // Search for the same X in the existing data set\n if (typeof pointIndex === 'undefined' && isNumber(x)) {\n pointIndex = this.xData.indexOf(x, fromIndex);\n }\n // Reduce pointIndex if data is cropped\n if (pointIndex !== -1 &&\n typeof pointIndex !== 'undefined' &&\n this.cropped) {\n pointIndex = (pointIndex >= this.cropStart) ?\n pointIndex - this.cropStart : pointIndex;\n }\n if (!matchedById &&\n isNumber(pointIndex) &&\n oldData[pointIndex] && oldData[pointIndex].touched) {\n pointIndex = void 0;\n }\n return pointIndex;\n }\n /**\n * Internal function called from setData. If the point count is the same\n * as it was, or if there are overlapping X values, just run\n * Point.update which is cheaper, allows animation, and keeps references\n * to points. This also allows adding or removing points if the X-es\n * don't match.\n *\n * @private\n * @function Highcharts.Series#updateData\n */\n updateData(data, animation) {\n const options = this.options, dataSorting = options.dataSorting, oldData = this.points, pointsToAdd = [], requireSorting = this.requireSorting, equalLength = data.length === oldData.length;\n let hasUpdatedByKey, i, point, lastIndex, succeeded = true;\n this.xIncrement = null;\n // Iterate the new data\n data.forEach(function (pointOptions, i) {\n const optionsObject = (defined(pointOptions) &&\n this.pointClass.prototype.optionsToObject.call({ series: this }, pointOptions)) || {};\n let pointIndex;\n // Get the x of the new data point\n const x = optionsObject.x, id = optionsObject.id;\n if (id || isNumber(x)) {\n pointIndex = this.findPointIndex(optionsObject, lastIndex);\n // Matching X not found\n // or used already due to ununique x values (#8995),\n // add point (but later)\n if (pointIndex === -1 ||\n typeof pointIndex === 'undefined') {\n pointsToAdd.push(pointOptions);\n // Matching X found, update\n }\n else if (oldData[pointIndex] &&\n pointOptions !== options.data[pointIndex]) {\n oldData[pointIndex].update(pointOptions, false, null, false);\n // Mark it touched, below we will remove all points that\n // are not touched.\n oldData[pointIndex].touched = true;\n // Speed optimize by only searching after last known\n // index. Performs ~20% bettor on large data sets.\n if (requireSorting) {\n lastIndex = pointIndex + 1;\n }\n // Point exists, no changes, don't remove it\n }\n else if (oldData[pointIndex]) {\n oldData[pointIndex].touched = true;\n }\n // If the length is equal and some of the nodes had a\n // match in the same position, we don't want to remove\n // non-matches.\n if (!equalLength ||\n i !== pointIndex ||\n (dataSorting && dataSorting.enabled) ||\n this.hasDerivedData) {\n hasUpdatedByKey = true;\n }\n }\n else {\n // Gather all points that are not matched\n pointsToAdd.push(pointOptions);\n }\n }, this);\n // Remove points that don't exist in the updated data set\n if (hasUpdatedByKey) {\n i = oldData.length;\n while (i--) {\n point = oldData[i];\n if (point && !point.touched && point.remove) {\n point.remove(false, animation);\n }\n }\n // If we did not find keys (ids or x-values), and the length is the\n // same, update one-to-one\n }\n else if (equalLength && (!dataSorting || !dataSorting.enabled)) {\n data.forEach(function (point, i) {\n // .update doesn't exist on a linked, hidden series (#3709)\n // (#10187)\n if (point !== oldData[i].y && !oldData[i].destroyed) {\n oldData[i].update(point, false, null, false);\n }\n });\n // Don't add new points since those configs are used above\n pointsToAdd.length = 0;\n // Did not succeed in updating data\n }\n else {\n succeeded = false;\n }\n oldData.forEach(function (point) {\n if (point) {\n point.touched = false;\n }\n });\n if (!succeeded) {\n return false;\n }\n // Add new points\n pointsToAdd.forEach(function (point) {\n this.addPoint(point, false, null, null, false);\n }, this);\n if (this.xIncrement === null &&\n this.xData &&\n this.xData.length) {\n this.xIncrement = arrayMax(this.xData);\n this.autoIncrement();\n }\n return true;\n }\n /**\n * Apply a new set of data to the series and optionally redraw it. The\n * new data array is passed by reference (except in case of\n * `updatePoints`), and may later be mutated when updating the chart\n * data.\n *\n * Note the difference in behaviour when setting the same amount of\n * points, or a different amount of points, as handled by the\n * `updatePoints` parameter.\n *\n * @sample highcharts/members/series-setdata/\n * Set new data from a button\n * @sample highcharts/members/series-setdata-pie/\n * Set data in a pie\n * @sample stock/members/series-setdata/\n * Set new data in Highcharts Stock\n * @sample maps/members/series-setdata/\n * Set new data in Highmaps\n *\n * @function Highcharts.Series#setData\n *\n * @param {Array} data\n * Takes an array of data in the same format as described under\n * `series.{type}.data` for the given series type, for example a\n * line series would take data in the form described under\n * [series.line.data](https://api.highcharts.com/highcharts/series.line.data).\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If\n * doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw} after.\n *\n * @param {boolean|Partial} [animation]\n * When the updated data is the same length as the existing data,\n * points will be updated by default, and animation visualizes\n * how the points are changed. Set false to disable animation, or\n * a configuration object to set duration or easing.\n *\n * @param {boolean} [updatePoints=true]\n * When this is true, points will be updated instead of replaced\n * whenever possible. This occurs a) when the updated data is the\n * same length as the existing data, b) when points are matched\n * by their id's, or c) when points can be matched by X values.\n * This allows updating with animation and performs better. In\n * this case, the original array is not passed by reference. Set\n * `false` to prevent.\n */\n setData(data, redraw = true, animation, updatePoints) {\n var _a;\n const series = this, oldData = series.points, oldDataLength = (oldData && oldData.length) || 0, options = series.options, chart = series.chart, dataSorting = options.dataSorting, xAxis = series.xAxis, turboThreshold = options.turboThreshold, xData = this.xData, yData = this.yData, pointArrayMap = series.pointArrayMap, valueCount = pointArrayMap && pointArrayMap.length, keys = options.keys;\n let i, pt, updatedData, indexOfX = 0, indexOfY = 1, firstPoint = null, copiedData;\n if (!chart.options.chart.allowMutatingData) { // #4259\n // Remove old reference\n if (options.data) {\n delete series.options.data;\n }\n if (series.userOptions.data) {\n delete series.userOptions.data;\n }\n copiedData = merge(true, data);\n }\n data = copiedData || data || [];\n const dataLength = data.length;\n if (dataSorting && dataSorting.enabled) {\n data = this.sortData(data);\n }\n // First try to run Point.update which is cheaper, allows animation,\n // and keeps references to points.\n if (chart.options.chart.allowMutatingData &&\n updatePoints !== false &&\n dataLength &&\n oldDataLength &&\n !series.cropped &&\n !series.hasGroupedData &&\n series.visible &&\n // Soft updating has no benefit in boost, and causes JS error\n // (#8355)\n !series.boosted) {\n updatedData = this.updateData(data, animation);\n }\n if (!updatedData) {\n // Reset properties\n series.xIncrement = null;\n series.colorCounter = 0; // for series with colorByPoint (#1547)\n // Update parallel arrays\n this.parallelArrays.forEach(function (key) {\n series[key + 'Data'].length = 0;\n });\n // In turbo mode, only one- or twodimensional arrays of numbers\n // are allowed. The first value is tested, and we assume that\n // all the rest are defined the same way. Although the 'for'\n // loops are similar, they are repeated inside each if-else\n // conditional for max performance.\n if (turboThreshold && dataLength > turboThreshold) {\n firstPoint = series.getFirstValidPoint(data);\n if (isNumber(firstPoint)) { // assume all points are numbers\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n // Assume all points are arrays when first point is\n }\n else if (isArray(firstPoint)) {\n if (valueCount) { // [x, low, high] or [x, o, h, l, c]\n if (firstPoint.length === valueCount) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[0];\n yData[i] =\n pt.slice(1, valueCount + 1);\n }\n }\n }\n else { // [x, y]\n if (keys) {\n indexOfX = keys.indexOf('x');\n indexOfY = keys.indexOf('y');\n indexOfX = indexOfX >= 0 ? indexOfX : 0;\n indexOfY = indexOfY >= 0 ? indexOfY : 1;\n }\n if (firstPoint.length === 1) {\n indexOfY = 0;\n }\n if (indexOfX === indexOfY) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i][indexOfY];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[indexOfX];\n yData[i] = pt[indexOfY];\n }\n }\n }\n }\n else {\n // Highcharts expects configs to be numbers or arrays in\n // turbo mode\n error(12, false, chart);\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = { series: series };\n series.pointClass.prototype.applyOptions.apply(pt, [data[i]]);\n series.updateParallelArrays(pt, i);\n }\n }\n // Forgetting to cast strings to numbers is a common caveat when\n // handling CSV or JSON\n if (yData && isString(yData[0])) {\n error(14, true, chart);\n }\n series.data = [];\n series.options.data = series.userOptions.data = data;\n // destroy old points\n i = oldDataLength;\n while (i--) {\n (_a = oldData[i]) === null || _a === void 0 ? void 0 : _a.destroy();\n }\n // reset minRange (#878)\n if (xAxis) {\n xAxis.minRange = xAxis.userMinRange;\n }\n // redraw\n series.isDirty = chart.isDirtyBox = true;\n series.isDirtyData = !!oldData;\n animation = false;\n }\n // Typically for pie series, points need to be processed and\n // generated prior to rendering the legend\n if (options.legendType === 'point') {\n this.processData();\n this.generatePoints();\n }\n if (redraw) {\n chart.redraw(animation);\n }\n }\n /**\n * Internal function to sort series data\n *\n * @private\n * @function Highcharts.Series#sortData\n * @param {Array} data\n * Force data grouping.\n */\n sortData(data) {\n const series = this, options = series.options, dataSorting = options.dataSorting, sortKey = dataSorting.sortKey || 'y', getPointOptionsObject = function (series, pointOptions) {\n return (defined(pointOptions) &&\n series.pointClass.prototype.optionsToObject.call({\n series: series\n }, pointOptions)) || {};\n };\n data.forEach(function (pointOptions, i) {\n data[i] = getPointOptionsObject(series, pointOptions);\n data[i].index = i;\n }, this);\n // Sorting\n const sortedData = data.concat().sort((a, b) => {\n const aValue = getNestedProperty(sortKey, a);\n const bValue = getNestedProperty(sortKey, b);\n return bValue < aValue ? -1 : bValue > aValue ? 1 : 0;\n });\n // Set x value depending on the position in the array\n sortedData.forEach(function (point, i) {\n point.x = i;\n }, this);\n // Set the same x for linked series points if they don't have their\n // own sorting\n if (series.linkedSeries) {\n series.linkedSeries.forEach(function (linkedSeries) {\n const options = linkedSeries.options, seriesData = options.data;\n if ((!options.dataSorting ||\n !options.dataSorting.enabled) &&\n seriesData) {\n seriesData.forEach(function (pointOptions, i) {\n seriesData[i] = getPointOptionsObject(linkedSeries, pointOptions);\n if (data[i]) {\n seriesData[i].x = data[i].x;\n seriesData[i].index = i;\n }\n });\n linkedSeries.setData(seriesData, false);\n }\n });\n }\n return data;\n }\n /**\n * Internal function to process the data by cropping away unused data\n * points if the series is longer than the crop threshold. This saves\n * computing time for large series.\n *\n * @private\n * @function Highcharts.Series#getProcessedData\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n getProcessedData(forceExtremesFromAll) {\n const series = this, xAxis = series.xAxis, options = series.options, cropThreshold = options.cropThreshold, getExtremesFromAll = forceExtremesFromAll ||\n series.getExtremesFromAll ||\n options.getExtremesFromAll, // #4599\n logarithmic = xAxis === null || xAxis === void 0 ? void 0 : xAxis.logarithmic, isCartesian = series.isCartesian;\n let croppedData, cropped, cropStart = 0, xExtremes, min, max, \n // copied during slice operation:\n processedXData = series.xData, processedYData = series.yData, updatingNames = false;\n const dataLength = processedXData.length;\n if (xAxis) {\n // corrected for log axis (#3053)\n xExtremes = xAxis.getExtremes();\n min = xExtremes.min;\n max = xExtremes.max;\n updatingNames = !!(xAxis.categories && !xAxis.names.length);\n }\n // optionally filter out points outside the plot area\n if (isCartesian &&\n series.sorted &&\n !getExtremesFromAll &&\n (!cropThreshold ||\n dataLength > cropThreshold ||\n series.forceCrop)) {\n // it's outside current extremes\n if (processedXData[dataLength - 1] < min ||\n processedXData[0] > max) {\n processedXData = [];\n processedYData = [];\n // only crop if it's actually spilling out\n }\n else if (series.yData && (processedXData[0] < min ||\n processedXData[dataLength - 1] > max)) {\n croppedData = this.cropData(series.xData, series.yData, min, max);\n processedXData = croppedData.xData;\n processedYData = croppedData.yData;\n cropStart = croppedData.start;\n cropped = true;\n }\n }\n // Find the closest distance between processed points\n const closestPointRange = getClosestDistance([\n logarithmic ?\n processedXData.map(logarithmic.log2lin) :\n processedXData\n ], \n // Unsorted data is not supported by the line tooltip, as well as\n // data grouping and navigation in Stock charts (#725) and width\n // calculation of columns (#1900). Avoid warning during the\n // premature processing pass in updateNames (#16104).\n () => (series.requireSorting &&\n !updatingNames &&\n error(15, false, series.chart)));\n return {\n xData: processedXData,\n yData: processedYData,\n cropped: cropped,\n cropStart: cropStart,\n closestPointRange: closestPointRange\n };\n }\n /**\n * Internal function to apply processed data.\n * In Highcharts Stock, this function is extended to provide data grouping.\n *\n * @private\n * @function Highcharts.Series#processData\n * @param {boolean} [force]\n * Force data grouping.\n */\n processData(force) {\n const series = this, xAxis = series.xAxis;\n // If the series data or axes haven't changed, don't go through\n // this. Return false to pass the message on to override methods\n // like in data grouping.\n if (series.isCartesian &&\n !series.isDirty &&\n !xAxis.isDirty &&\n !series.yAxis.isDirty &&\n !force) {\n return false;\n }\n const processedData = series.getProcessedData();\n // Record the properties\n series.cropped = processedData.cropped; // undefined or true\n series.cropStart = processedData.cropStart;\n series.processedXData = processedData.xData;\n series.processedYData = processedData.yData;\n series.closestPointRange = (series.basePointRange = processedData.closestPointRange);\n fireEvent(series, 'afterProcessData');\n }\n /**\n * Iterate over xData and crop values between min and max. Returns\n * object containing crop start/end cropped xData with corresponding\n * part of yData, dataMin and dataMax within the cropped range.\n *\n * @private\n * @function Highcharts.Series#cropData\n */\n cropData(xData, yData, min, max, cropShoulder) {\n const dataLength = xData.length;\n let i, j, cropStart = 0, cropEnd = dataLength;\n // line-type series need one point outside\n cropShoulder = pick(cropShoulder, this.cropShoulder);\n // iterate up to find slice start\n for (i = 0; i < dataLength; i++) {\n if (xData[i] >= min) {\n cropStart = Math.max(0, i - cropShoulder);\n break;\n }\n }\n // proceed to find slice end\n for (j = i; j < dataLength; j++) {\n if (xData[j] > max) {\n cropEnd = j + cropShoulder;\n break;\n }\n }\n return {\n xData: xData.slice(cropStart, cropEnd),\n yData: yData.slice(cropStart, cropEnd),\n start: cropStart,\n end: cropEnd\n };\n }\n /**\n * Generate the data point after the data has been processed by cropping\n * away unused points and optionally grouped in Highcharts Stock.\n *\n * @private\n * @function Highcharts.Series#generatePoints\n */\n generatePoints() {\n const series = this, options = series.options, dataOptions = (series.processedData || options.data), processedXData = series.processedXData, processedYData = series.processedYData, PointClass = series.pointClass, processedDataLength = processedXData.length, cropStart = series.cropStart || 0, hasGroupedData = series.hasGroupedData, keys = options.keys, points = [], groupCropStartIndex = (options.dataGrouping &&\n options.dataGrouping.groupAll ?\n cropStart :\n 0);\n let dataLength, cursor, point, i, data = series.data;\n if (!data && !hasGroupedData) {\n const arr = [];\n arr.length = dataOptions.length;\n data = series.data = arr;\n }\n if (keys && hasGroupedData) {\n // grouped data has already applied keys (#6590)\n series.options.keys = false;\n }\n for (i = 0; i < processedDataLength; i++) {\n cursor = cropStart + i;\n if (!hasGroupedData) {\n point = data[cursor];\n // #970:\n if (!point &&\n typeof dataOptions[cursor] !== 'undefined') {\n data[cursor] = point = (new PointClass()).init(series, dataOptions[cursor], processedXData[i]);\n }\n }\n else {\n // splat the y data in case of ohlc data array\n point = (new PointClass()).init(series, [processedXData[i]].concat(splat(processedYData[i])));\n point.dataGroup = series.groupMap[groupCropStartIndex + i];\n if (point.dataGroup.options) {\n point.options = point.dataGroup.options;\n extend(point, point.dataGroup.options);\n // Collision of props and options (#9770)\n delete point.dataLabels;\n }\n }\n if (point) { // #6279\n /**\n * Contains the point's index in the `Series.points` array.\n *\n * @name Highcharts.Point#index\n * @type {number}\n * @readonly\n */\n // For faster access in Point.update\n point.index = hasGroupedData ?\n (groupCropStartIndex + i) : cursor;\n points[i] = point;\n }\n }\n // restore keys options (#6590)\n series.options.keys = keys;\n // Hide cropped-away points - this only runs when the number of\n // points is above cropThreshold, or when swithching view from\n // non-grouped data to grouped data (#637)\n if (data &&\n (processedDataLength !== (dataLength = data.length) ||\n hasGroupedData)) {\n for (i = 0; i < dataLength; i++) {\n // when has grouped data, clear all points\n if (i === cropStart && !hasGroupedData) {\n i += processedDataLength;\n }\n if (data[i]) {\n data[i].destroyElements();\n data[i].plotX = void 0; // #1003\n }\n }\n }\n /**\n * Read only. An array containing those values converted to points.\n * In case the series data length exceeds the `cropThreshold`, or if\n * the data is grouped, `series.data` doesn't contain all the\n * points. Also, in case a series is hidden, the `data` array may be\n * empty. To access raw values, `series.options.data` will always be\n * up to date. `Series.data` only contains the points that have been\n * created on demand. To modify the data, use\n * {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @see Series.points\n *\n * @name Highcharts.Series#data\n * @type {Array}\n */\n series.data = data;\n /**\n * An array containing all currently visible point objects. In case\n * of cropping, the cropped-away points are not part of this array.\n * The `series.points` array starts at `series.cropStart` compared\n * to `series.data` and `series.options.data`. If however the series\n * data is grouped, these can't be correlated one to one. To modify\n * the data, use {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @name Highcharts.Series#points\n * @type {Array}\n */\n series.points = points;\n fireEvent(this, 'afterGeneratePoints');\n }\n /**\n * Get current X extremes for the visible data.\n *\n * @private\n * @function Highcharts.Series#getXExtremes\n * @param {Array} xData\n * The data to inspect. Defaults to the current data within the visible\n * range.\n */\n getXExtremes(xData) {\n return {\n min: arrayMin(xData),\n max: arrayMax(xData)\n };\n }\n /**\n * Calculate Y extremes for the visible data. The result is returned\n * as an object with `dataMin` and `dataMax` properties.\n *\n * @private\n * @function Highcharts.Series#getExtremes\n * @param {Array} [yData]\n * The data to inspect. Defaults to the current data within the visible\n * range.\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n getExtremes(yData, forceExtremesFromAll) {\n const xAxis = this.xAxis, yAxis = this.yAxis, xData = this.processedXData || this.xData, activeYData = [], \n // Handle X outside the viewed area. This does not work with\n // non-sorted data like scatter (#7639).\n shoulder = this.requireSorting ? this.cropShoulder : 0, positiveValuesOnly = yAxis ? yAxis.positiveValuesOnly : false;\n // #2117, need to compensate for log X axis\n let xExtremes, validValue, withinRange, x, y, i, j, xMin = 0, xMax = 0, activeCounter = 0;\n yData = yData || this.stackedYData || this.processedYData || [];\n const yDataLength = yData.length;\n if (xAxis) {\n xExtremes = xAxis.getExtremes();\n xMin = xExtremes.min;\n xMax = xExtremes.max;\n }\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n // For points within the visible range, including the first\n // point outside the visible range (#7061), consider y extremes.\n validValue = ((isNumber(y) || isArray(y)) &&\n ((y.length || y > 0) || !positiveValuesOnly));\n withinRange = (forceExtremesFromAll ||\n this.getExtremesFromAll ||\n this.options.getExtremesFromAll ||\n this.cropped ||\n !xAxis || // for colorAxis support\n ((xData[i + shoulder] || x) >= xMin &&\n (xData[i - shoulder] || x) <= xMax));\n if (validValue && withinRange) {\n j = y.length;\n if (j) { // array, like ohlc or range data\n while (j--) {\n if (isNumber(y[j])) { // #7380, #11513\n activeYData[activeCounter++] = y[j];\n }\n }\n }\n else {\n activeYData[activeCounter++] = y;\n }\n }\n }\n const dataExtremes = {\n activeYData,\n dataMin: arrayMin(activeYData),\n dataMax: arrayMax(activeYData)\n };\n fireEvent(this, 'afterGetExtremes', { dataExtremes });\n return dataExtremes;\n }\n /**\n * Set the current data extremes as `dataMin` and `dataMax` on the\n * Series item. Use this only when the series properties should be\n * updated.\n *\n * @private\n * @function Highcharts.Series#applyExtremes\n */\n applyExtremes() {\n const dataExtremes = this.getExtremes();\n /**\n * Contains the minimum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMin\n * @type {number|undefined}\n * @readonly\n */\n this.dataMin = dataExtremes.dataMin;\n /**\n * Contains the maximum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMax\n * @type {number|undefined}\n * @readonly\n */\n this.dataMax = dataExtremes.dataMax;\n return dataExtremes;\n }\n /**\n * Find and return the first non null point in the data\n *\n * @private\n * @function Highcharts.Series.getFirstValidPoint\n * @param {Array} data\n * Array of options for points\n */\n getFirstValidPoint(data) {\n const dataLength = data.length;\n let i = 0, firstPoint = null;\n while (firstPoint === null && i < dataLength) {\n firstPoint = data[i];\n i++;\n }\n return firstPoint;\n }\n /**\n * Translate data points from raw data values to chart specific\n * positioning data needed later in the `drawPoints` and `drawGraph`\n * functions. This function can be overridden in plugins and custom\n * series type implementations.\n *\n * @function Highcharts.Series#translate\n *\n * @emits Highcharts.Series#events:translate\n */\n translate() {\n var _a;\n if (!this.processedXData) { // hidden series\n this.processData();\n }\n this.generatePoints();\n const series = this, options = series.options, stacking = options.stacking, xAxis = series.xAxis, categories = xAxis.categories, enabledDataSorting = series.enabledDataSorting, yAxis = series.yAxis, points = series.points, dataLength = points.length, pointPlacement = series.pointPlacementToXValue(), // #7860\n dynamicallyPlaced = Boolean(pointPlacement), threshold = options.threshold, stackThreshold = options.startFromThreshold ? threshold : 0;\n let i, plotX, lastPlotX, stackIndicator, closestPointRangePx = Number.MAX_VALUE;\n /**\n * Plotted coordinates need to be within a limited range. Drawing\n * too far outside the viewport causes various rendering issues\n * (#3201, #3923, #7555).\n * @private\n */\n function limitedRange(val) {\n return clamp(val, -1e5, 1e5);\n }\n // Translate each point\n for (i = 0; i < dataLength; i++) {\n const point = points[i], xValue = point.x;\n let stackItem, stackValues, yValue = point.y, lowValue = point.low;\n const stacks = stacking && ((_a = yAxis.stacking) === null || _a === void 0 ? void 0 : _a.stacks[(series.negStacks &&\n yValue <\n (stackThreshold ? 0 : threshold) ?\n '-' :\n '') + series.stackKey]);\n plotX = xAxis.translate(// #3923\n xValue, false, false, false, true, pointPlacement);\n /**\n * The translated X value for the point in terms of pixels. Relative\n * to the X axis position if the series has one, otherwise relative\n * to the plot area. Depending on the series type this value might\n * not be defined.\n * @name Highcharts.Point#plotX\n * @type {number|undefined}\n */\n point.plotX = isNumber(plotX) ? correctFloat(// #5236\n limitedRange(plotX) // #3923\n ) : void 0;\n // Calculate the bottom y value for stacked series\n if (stacking &&\n series.visible &&\n stacks &&\n stacks[xValue]) {\n stackIndicator = series.getStackIndicator(stackIndicator, xValue, series.index);\n if (!point.isNull && stackIndicator.key) {\n stackItem = stacks[xValue];\n stackValues = stackItem.points[stackIndicator.key];\n }\n if (stackItem && isArray(stackValues)) {\n lowValue = stackValues[0];\n yValue = stackValues[1];\n if (lowValue === stackThreshold &&\n stackIndicator.key === stacks[xValue].base) {\n lowValue = pick(isNumber(threshold) ? threshold : yAxis.min);\n }\n // #1200, #1232\n if (yAxis.positiveValuesOnly &&\n defined(lowValue) &&\n lowValue <= 0) {\n lowValue = void 0;\n }\n point.total = point.stackTotal = pick(stackItem.total);\n point.percentage = defined(point.y) && stackItem.total ?\n (point.y / stackItem.total * 100) : void 0;\n point.stackY = yValue;\n // in case of variwide series (where widths of points are\n // different in most cases), stack labels are positioned\n // wrongly, so the call of the setOffset is omited here and\n // labels are correctly positioned later, at the end of the\n // variwide's translate function (#10962)\n if (!series.irregularWidths) {\n stackItem.setOffset(series.pointXOffset || 0, series.barW || 0, void 0, void 0, void 0, series.xAxis);\n }\n }\n }\n // Set translated yBottom or remove it\n point.yBottom = defined(lowValue) ?\n limitedRange(yAxis.translate(lowValue, false, true, false, true)) :\n void 0;\n // General hook, used for Highcharts Stock compare and cumulative\n if (series.dataModify) {\n yValue = series.dataModify.modifyValue(yValue, i);\n }\n // Set the the plotY value, reset it for redraws #3201, #18422\n let plotY;\n if (isNumber(yValue) && point.plotX !== void 0) {\n plotY = yAxis.translate(yValue, false, true, false, true);\n plotY = isNumber(plotY) ? limitedRange(plotY) : void 0;\n }\n /**\n * The translated Y value for the point in terms of pixels. Relative\n * to the Y axis position if the series has one, otherwise relative\n * to the plot area. Depending on the series type this value might\n * not be defined.\n * @name Highcharts.Point#plotY\n * @type {number|undefined}\n */\n point.plotY = plotY;\n point.isInside = this.isPointInside(point);\n // Set client related positions for mouse tracking\n point.clientX = dynamicallyPlaced ?\n correctFloat(xAxis.translate(xValue, false, false, false, true, pointPlacement)) :\n plotX; // #1514, #5383, #5518\n // Negative points #19028\n point.negative = (point.y || 0) < (threshold || 0);\n // some API data\n point.category = pick(categories && categories[point.x], point.x);\n // Determine auto enabling of markers (#3635, #5099)\n if (!point.isNull && point.visible !== false) {\n if (typeof lastPlotX !== 'undefined') {\n closestPointRangePx = Math.min(closestPointRangePx, Math.abs(plotX - lastPlotX));\n }\n lastPlotX = plotX;\n }\n // Find point zone\n point.zone = this.zones.length ? point.getZone() : void 0;\n // Animate new points with data sorting\n if (!point.graphic && series.group && enabledDataSorting) {\n point.isNew = true;\n }\n }\n series.closestPointRangePx = closestPointRangePx;\n fireEvent(this, 'afterTranslate');\n }\n /**\n * Return the series points with null points filtered out.\n *\n * @function Highcharts.Series#getValidPoints\n *\n * @param {Array} [points]\n * The points to inspect, defaults to {@link Series.points}.\n *\n * @param {boolean} [insideOnly=false]\n * Whether to inspect only the points that are inside the visible view.\n *\n * @param {boolean} [allowNull=false]\n * Whether to allow null points to pass as valid points.\n *\n * @return {Array}\n * The valid points.\n */\n getValidPoints(points, insideOnly, allowNull) {\n const chart = this.chart;\n // #3916, #5029, #5085\n return (points || this.points || []).filter(function (point) {\n const { plotX, plotY } = point, \n // Undefined plotY is treated as null when negative values\n // in log axis (#18422)\n asNull = !allowNull && (point.isNull || !isNumber(plotY));\n if (asNull || (insideOnly && !chart.isInsidePlot(plotX, plotY, { inverted: chart.inverted }))) {\n return false;\n }\n return point.visible !== false;\n });\n }\n /**\n * Get the clipping for the series. Could be called for a series to\n * initiate animating the clip or to set the final clip (only width\n * and x).\n *\n * @private\n * @function Highcharts.Series#getClip\n */\n getClipBox() {\n const { chart, xAxis, yAxis } = this;\n // If no axes on the series, use global clipBox\n const seriesBox = merge(chart.clipBox);\n // Otherwise, use clipBox.width which is corrected for plotBorderWidth\n // and clipOffset\n if (xAxis && xAxis.len !== chart.plotSizeX) {\n seriesBox.width = xAxis.len;\n }\n if (yAxis && yAxis.len !== chart.plotSizeY) {\n seriesBox.height = yAxis.len;\n }\n return seriesBox;\n }\n /**\n * Get the shared clip key, creating it if it doesn't exist.\n *\n * @private\n * @function Highcharts.Series#getSharedClipKey\n */\n getSharedClipKey() {\n this.sharedClipKey = (this.options.xAxis || 0) + ',' +\n (this.options.yAxis || 0);\n return this.sharedClipKey;\n }\n /**\n * Set the clipping for the series. For animated series the clip is later\n * modified.\n *\n * @private\n * @function Highcharts.Series#setClip\n */\n setClip() {\n const { chart, group, markerGroup } = this, sharedClips = chart.sharedClips, renderer = chart.renderer, clipBox = this.getClipBox(), sharedClipKey = this.getSharedClipKey(); // #4526\n let clipRect = sharedClips[sharedClipKey];\n // If a clipping rectangle for the same set of axes does not exist,\n // create it\n if (!clipRect) {\n sharedClips[sharedClipKey] = clipRect = renderer.clipRect(clipBox);\n // When setting chart size, or when the series is rendered again before\n // starting animating, in compliance to a responsive rule\n }\n else {\n clipRect.animate(clipBox);\n }\n if (group) {\n // When clip is false, reset to no clip after animation\n group.clip(this.options.clip === false ? void 0 : clipRect);\n }\n // Unclip temporary animation clip\n if (markerGroup) {\n markerGroup.clip();\n }\n }\n /**\n * Animate in the series. Called internally twice. First with the `init`\n * parameter set to true, which sets up the initial state of the\n * animation. Then when ready, it is called with the `init` parameter\n * undefined, in order to perform the actual animation.\n *\n * @function Highcharts.Series#animate\n *\n * @param {boolean} [init]\n * Initialize the animation.\n */\n animate(init) {\n const { chart, group, markerGroup } = this, inverted = chart.inverted, animation = animObject(this.options.animation), \n // The key for temporary animation clips\n animationClipKey = [\n this.getSharedClipKey(),\n animation.duration,\n animation.easing,\n animation.defer\n ].join(',');\n let animationClipRect = chart.sharedClips[animationClipKey], markerAnimationClipRect = chart.sharedClips[animationClipKey + 'm'];\n // Initialize the animation. Set up the clipping rectangle.\n if (init && group) {\n const clipBox = this.getClipBox();\n // Create temporary animation clips\n if (!animationClipRect) {\n clipBox.width = 0;\n if (inverted) {\n clipBox.x = chart.plotHeight;\n }\n animationClipRect = chart.renderer.clipRect(clipBox);\n chart.sharedClips[animationClipKey] = animationClipRect;\n // The marker clip box. The number 99 is a safe margin to avoid\n // markers being clipped during animation.\n const markerClipBox = {\n x: inverted ? -99 : -99,\n y: inverted ? -99 : -99,\n width: inverted ? chart.plotWidth + 199 : 99,\n height: inverted ? 99 : chart.plotHeight + 199\n };\n markerAnimationClipRect = chart.renderer.clipRect(markerClipBox);\n chart.sharedClips[animationClipKey + 'm'] = markerAnimationClipRect;\n }\n else {\n // When height changes during animation, typically due to\n // responsive settings\n animationClipRect.attr('height', clipBox.height);\n }\n group.clip(animationClipRect);\n if (markerGroup) {\n markerGroup.clip(markerAnimationClipRect);\n }\n // Run the animation\n }\n else if (animationClipRect &&\n // Only first series in this pane\n !animationClipRect.hasClass('highcharts-animating')) {\n const finalBox = this.getClipBox(), step = animation.step;\n // Only do this when there are actually markers\n if (markerGroup && markerGroup.element.childNodes.length) {\n // To provide as smooth animation as possible, update the marker\n // group clipping in steps of the main group animation\n animation.step = function (val, fx) {\n if (step) {\n step.apply(fx, arguments);\n }\n if (fx.prop === 'width' &&\n markerAnimationClipRect &&\n markerAnimationClipRect.element) {\n markerAnimationClipRect.attr(inverted ? 'height' : 'width', val + 99);\n }\n };\n }\n animationClipRect\n .addClass('highcharts-animating')\n .animate(finalBox, animation);\n }\n }\n /**\n * This runs after animation to land on the final plot clipping.\n *\n * @private\n * @function Highcharts.Series#afterAnimate\n *\n * @emits Highcharts.Series#event:afterAnimate\n */\n afterAnimate() {\n this.setClip();\n // Destroy temporary clip rectangles that are no longer in use\n objectEach(this.chart.sharedClips, (clip, key, sharedClips) => {\n if (clip && !this.chart.container.querySelector(`[clip-path=\"url(#${clip.id})\"]`)) {\n clip.destroy();\n delete sharedClips[key];\n }\n });\n this.finishedAnimating = true;\n fireEvent(this, 'afterAnimate');\n }\n /**\n * Draw the markers for line-like series types, and columns or other\n * graphical representation for {@link Point} objects for other series\n * types. The resulting element is typically stored as\n * {@link Point.graphic}, and is created on the first call and updated\n * and moved on subsequent calls.\n *\n * @function Highcharts.Series#drawPoints\n */\n drawPoints(points = this.points) {\n const series = this, chart = series.chart, styledMode = chart.styledMode, { colorAxis, options } = series, seriesMarkerOptions = options.marker, markerGroup = series[series.specialGroup || 'markerGroup'], xAxis = series.xAxis, globallyEnabled = pick(seriesMarkerOptions.enabled, !xAxis || xAxis.isRadial ? true : null, \n // Use larger or equal as radius is null in bubbles (#6321)\n series.closestPointRangePx >= (seriesMarkerOptions.enabledThreshold *\n seriesMarkerOptions.radius));\n let i, point, graphic, verb, pointMarkerOptions, hasPointMarker, markerAttribs;\n if (seriesMarkerOptions.enabled !== false ||\n series._hasPointMarkers) {\n for (i = 0; i < points.length; i++) {\n point = points[i];\n graphic = point.graphic;\n verb = graphic ? 'animate' : 'attr';\n pointMarkerOptions = point.marker || {};\n hasPointMarker = !!point.marker;\n const shouldDrawMarker = ((globallyEnabled &&\n typeof pointMarkerOptions.enabled === 'undefined') || pointMarkerOptions.enabled) && !point.isNull && point.visible !== false;\n // only draw the point if y is defined\n if (shouldDrawMarker) {\n // Shortcuts\n const symbol = pick(pointMarkerOptions.symbol, series.symbol, 'rect');\n markerAttribs = series.markerAttribs(point, (point.selected && 'select'));\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = xAxis.reversed ?\n -(markerAttribs.width || 0) :\n xAxis.width;\n }\n const isInside = point.isInside !== false;\n if (!graphic &&\n isInside &&\n ((markerAttribs.width || 0) > 0 || point.hasImage)) {\n /**\n * SVG graphic representing the point in the chart. In\n * some cases it may be a hidden graphic to improve\n * accessibility.\n *\n * Typically this is a simple shape, like a `rect`\n * for column charts or `path` for line markers, but\n * for some complex series types like boxplot or 3D\n * charts, the graphic may be a `g` element\n * containing other shapes. The graphic is generated\n * the first time {@link Series#drawPoints} runs,\n * and updated and moved on subsequent runs.\n *\n * @see Highcharts.Point#graphics\n *\n * @name Highcharts.Point#graphic\n * @type {Highcharts.SVGElement|undefined}\n */\n point.graphic = graphic = chart.renderer\n .symbol(symbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height, hasPointMarker ?\n pointMarkerOptions :\n seriesMarkerOptions)\n .add(markerGroup);\n // Sliding animation for new points\n if (series.enabledDataSorting &&\n chart.hasRendered) {\n graphic.attr({\n x: point.startXPos\n });\n verb = 'animate';\n }\n }\n if (graphic && verb === 'animate') { // update\n // Since the marker group isn't clipped, each\n // individual marker must be toggled\n graphic[isInside ? 'show' : 'hide'](isInside)\n .animate(markerAttribs);\n }\n // Presentational attributes\n if (graphic) {\n const pointAttr = series.pointAttribs(point, ((styledMode || !point.selected) ?\n void 0 :\n 'select'));\n if (!styledMode) {\n graphic[verb](pointAttr);\n }\n else if (colorAxis) { // #14114\n graphic['css']({\n fill: pointAttr.fill\n });\n }\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n }\n }\n }\n /**\n * Get non-presentational attributes for a point. Used internally for\n * both styled mode and classic. Can be overridden for different series\n * types.\n *\n * @see Series#pointAttribs\n *\n * @function Highcharts.Series#markerAttribs\n *\n * @param {Highcharts.Point} point\n * The Point to inspect.\n *\n * @param {string} [state]\n * The state, can be either `hover`, `select` or undefined.\n *\n * @return {Highcharts.SVGAttributes}\n * A hash containing those attributes that are not settable from CSS.\n */\n markerAttribs(point, state) {\n const seriesOptions = this.options, seriesMarkerOptions = seriesOptions.marker, pointMarkerOptions = point.marker || {}, symbol = (pointMarkerOptions.symbol ||\n seriesMarkerOptions.symbol), attribs = {};\n let seriesStateOptions, pointStateOptions, radius = pick(pointMarkerOptions.radius, seriesMarkerOptions && seriesMarkerOptions.radius);\n // Handle hover and select states\n if (state) {\n seriesStateOptions = seriesMarkerOptions.states[state];\n pointStateOptions = pointMarkerOptions.states &&\n pointMarkerOptions.states[state];\n radius = pick(pointStateOptions && pointStateOptions.radius, seriesStateOptions && seriesStateOptions.radius, radius && radius + (seriesStateOptions && seriesStateOptions.radiusPlus ||\n 0));\n }\n point.hasImage = symbol && symbol.indexOf('url') === 0;\n if (point.hasImage) {\n radius = 0; // and subsequently width and height is not set\n }\n const pos = point.pos();\n if (isNumber(radius) && pos) {\n attribs.x = pos[0] - radius;\n attribs.y = pos[1] - radius;\n if (seriesOptions.crisp) {\n // Math.floor for #1843:\n attribs.x = Math.floor(attribs.x);\n }\n }\n if (radius) {\n attribs.width = attribs.height = 2 * radius;\n }\n return attribs;\n }\n /**\n * Internal function to get presentational attributes for each point.\n * Unlike {@link Series#markerAttribs}, this function should return\n * those attributes that can also be set in CSS. In styled mode,\n * `pointAttribs` won't be called.\n *\n * @private\n * @function Highcharts.Series#pointAttribs\n *\n * @param {Highcharts.Point} [point]\n * The point instance to inspect.\n *\n * @param {string} [state]\n * The point state, can be either `hover`, `select` or 'normal'. If\n * undefined, normal state is assumed.\n *\n * @return {Highcharts.SVGAttributes}\n * The presentational attributes to be set on the point.\n */\n pointAttribs(point, state) {\n const seriesMarkerOptions = this.options.marker, pointOptions = point && point.options, pointMarkerOptions = ((pointOptions && pointOptions.marker) || {}), pointColorOption = pointOptions && pointOptions.color, pointColor = point && point.color, zoneColor = point && point.zone && point.zone.color;\n let seriesStateOptions, pointStateOptions, color = this.color, fill, stroke, strokeWidth = pick(pointMarkerOptions.lineWidth, seriesMarkerOptions.lineWidth), opacity = 1;\n color = (pointColorOption ||\n zoneColor ||\n pointColor ||\n color);\n fill = (pointMarkerOptions.fillColor ||\n seriesMarkerOptions.fillColor ||\n color);\n stroke = (pointMarkerOptions.lineColor ||\n seriesMarkerOptions.lineColor ||\n color);\n // Handle hover and select states\n state = state || 'normal';\n if (state) {\n seriesStateOptions = (seriesMarkerOptions.states[state] || {});\n pointStateOptions = (pointMarkerOptions.states &&\n pointMarkerOptions.states[state]) || {};\n strokeWidth = pick(pointStateOptions.lineWidth, seriesStateOptions.lineWidth, strokeWidth + pick(pointStateOptions.lineWidthPlus, seriesStateOptions.lineWidthPlus, 0));\n fill = (pointStateOptions.fillColor ||\n seriesStateOptions.fillColor ||\n fill);\n stroke = (pointStateOptions.lineColor ||\n seriesStateOptions.lineColor ||\n stroke);\n opacity = pick(pointStateOptions.opacity, seriesStateOptions.opacity, opacity);\n }\n return {\n 'stroke': stroke,\n 'stroke-width': strokeWidth,\n 'fill': fill,\n 'opacity': opacity\n };\n }\n /**\n * Clear DOM objects and free up memory.\n *\n * @private\n * @function Highcharts.Series#destroy\n *\n * @emits Highcharts.Series#event:destroy\n */\n destroy(keepEventsForUpdate) {\n const series = this, chart = series.chart, issue134 = /AppleWebKit\\/533/.test(win.navigator.userAgent), data = series.data || [];\n let destroy, i, point, axis;\n // add event hook\n fireEvent(series, 'destroy', { keepEventsForUpdate });\n // remove events\n this.removeEvents(keepEventsForUpdate);\n // erase from axes\n (series.axisTypes || []).forEach(function (AXIS) {\n axis = series[AXIS];\n if (axis && axis.series) {\n erase(axis.series, series);\n axis.isDirty = axis.forceRedraw = true;\n }\n });\n // remove legend items\n if (series.legendItem) {\n series.chart.legend.destroyItem(series);\n }\n // destroy all points with their elements\n i = data.length;\n while (i--) {\n point = data[i];\n if (point && point.destroy) {\n point.destroy();\n }\n }\n if (series.clips) {\n series.clips.forEach((clip) => clip.destroy());\n }\n // Clear the animation timeout if we are destroying the series\n // during initial animation\n U.clearTimeout(series.animationTimeout);\n // Destroy all SVGElements associated to the series\n objectEach(series, function (val, prop) {\n // Survive provides a hook for not destroying\n if (val instanceof SVGElement && !val.survive) {\n // issue 134 workaround\n destroy = issue134 && prop === 'group' ?\n 'hide' :\n 'destroy';\n val[destroy]();\n }\n });\n // remove from hoverSeries\n if (chart.hoverSeries === series) {\n chart.hoverSeries = void 0;\n }\n erase(chart.series, series);\n chart.orderItems('series');\n // clear all members\n objectEach(series, function (val, prop) {\n if (!keepEventsForUpdate || prop !== 'hcEvents') {\n delete series[prop];\n }\n });\n }\n /**\n * Clip the graphs into zones for colors and styling.\n *\n * @private\n * @function Highcharts.Series#applyZones\n */\n applyZones() {\n const series = this, chart = this.chart, renderer = chart.renderer, zones = this.zones, clips = (this.clips || []), graph = this.graph, area = this.area, plotSizeMax = Math.max(chart.plotWidth, chart.plotHeight), axis = this[(this.zoneAxis || 'y') + 'Axis'], inverted = chart.inverted;\n let translatedFrom, translatedTo, clipAttr, extremes, reversed, horiz, pxRange, pxPosMin, pxPosMax, zoneArea, zoneGraph, ignoreZones = false;\n if (zones.length &&\n (graph || area) &&\n axis &&\n typeof axis.min !== 'undefined') {\n reversed = axis.reversed;\n horiz = axis.horiz;\n // The use of the Color Threshold assumes there are no gaps\n // so it is safe to hide the original graph and area\n // unless it is not waterfall series, then use showLine property\n // to set lines between columns to be visible (#7862)\n if (graph && !this.showLine) {\n graph.hide();\n }\n if (area) {\n area.hide();\n }\n // Create the clips\n extremes = axis.getExtremes();\n zones.forEach(function (threshold, i) {\n translatedFrom = reversed ?\n (horiz ? chart.plotWidth : 0) :\n (horiz ? 0 : (axis.toPixels(extremes.min) || 0));\n translatedFrom = clamp(pick(translatedTo, translatedFrom), 0, plotSizeMax);\n translatedTo = clamp(Math.round(axis.toPixels(pick(threshold.value, extremes.max), true) || 0), 0, plotSizeMax);\n if (ignoreZones) {\n translatedFrom = translatedTo =\n axis.toPixels(extremes.max);\n }\n pxRange = Math.abs(translatedFrom - translatedTo);\n pxPosMin = Math.min(translatedFrom, translatedTo);\n pxPosMax = Math.max(translatedFrom, translatedTo);\n if (axis.isXAxis) {\n clipAttr = {\n x: inverted ? pxPosMax : pxPosMin,\n y: 0,\n width: pxRange,\n height: plotSizeMax\n };\n if (!horiz) {\n clipAttr.x = chart.plotHeight - clipAttr.x;\n }\n }\n else {\n clipAttr = {\n x: 0,\n y: inverted ? pxPosMax : pxPosMin,\n width: plotSizeMax,\n height: pxRange\n };\n if (horiz) {\n clipAttr.y = chart.plotWidth - clipAttr.y;\n }\n }\n if (clips[i]) {\n clips[i].animate(clipAttr);\n }\n else {\n clips[i] = renderer.clipRect(clipAttr);\n }\n // when no data, graph zone is not applied and after setData\n // clip was ignored. As a result, it should be applied each\n // time.\n zoneArea = series['zone-area-' + i];\n zoneGraph = series['zone-graph-' + i];\n if (graph && zoneGraph) {\n zoneGraph.clip(clips[i]);\n }\n if (area && zoneArea) {\n zoneArea.clip(clips[i]);\n }\n // if this zone extends out of the axis, ignore the others\n ignoreZones = threshold.value > extremes.max;\n // Clear translatedTo for indicators\n if (series.resetZones && translatedTo === 0) {\n translatedTo = void 0;\n }\n });\n this.clips = clips;\n }\n else if (series.visible) {\n // If zones were removed, restore graph and area\n if (graph) {\n graph.show();\n }\n if (area) {\n area.show();\n }\n }\n }\n /**\n * General abstraction for creating plot groups like series.group,\n * series.dataLabelsGroup and series.markerGroup. On subsequent calls,\n * the group will only be adjusted to the updated plot size.\n *\n * @private\n * @function Highcharts.Series#plotGroup\n */\n plotGroup(prop, name, visibility, zIndex, parent) {\n let group = this[prop];\n const isNew = !group, attrs = {\n visibility,\n zIndex: zIndex || 0.1 // Pointer logic uses this\n };\n // Avoid setting undefined opacity, or in styled mode\n if (typeof this.opacity !== 'undefined' &&\n !this.chart.styledMode && this.state !== 'inactive' // #13719\n ) {\n attrs.opacity = this.opacity;\n }\n // Generate it on first call\n if (isNew) {\n this[prop] = group = this.chart.renderer\n .g()\n .add(parent);\n }\n // Add the class names, and replace existing ones as response to\n // Series.update (#6660)\n group.addClass(('highcharts-' + name +\n ' highcharts-series-' + this.index +\n ' highcharts-' + this.type + '-series ' +\n (defined(this.colorIndex) ?\n 'highcharts-color-' + this.colorIndex + ' ' :\n '') +\n (this.options.className || '') +\n (group.hasClass('highcharts-tracker') ?\n ' highcharts-tracker' :\n '')), true);\n // Place it on first and subsequent (redraw) calls\n group.attr(attrs)[isNew ? 'attr' : 'animate'](this.getPlotBox(name));\n return group;\n }\n /**\n * Get the translation and scale for the plot area of this series.\n *\n * @function Highcharts.Series#getPlotBox\n */\n getPlotBox(name) {\n let horAxis = this.xAxis, vertAxis = this.yAxis;\n const chart = this.chart, inverted = (chart.inverted &&\n !chart.polar &&\n horAxis &&\n this.invertible !== false &&\n name === 'series');\n // Swap axes for inverted (#2339)\n if (chart.inverted) {\n horAxis = vertAxis;\n vertAxis = this.xAxis;\n }\n return {\n translateX: horAxis ? horAxis.left : chart.plotLeft,\n translateY: vertAxis ? vertAxis.top : chart.plotTop,\n rotation: inverted ? 90 : 0,\n rotationOriginX: inverted ?\n (horAxis.len - vertAxis.len) / 2 :\n 0,\n rotationOriginY: inverted ?\n (horAxis.len + vertAxis.len) / 2 :\n 0,\n scaleX: inverted ? -1 : 1,\n scaleY: 1\n };\n }\n /**\n * Removes the event handlers attached previously with addEvents.\n * @private\n * @function Highcharts.Series#removeEvents\n */\n removeEvents(keepEventsForUpdate) {\n const series = this;\n if (!keepEventsForUpdate) {\n // remove all events\n removeEvent(series);\n }\n if (series.eventsToUnbind.length) {\n // remove only internal events for proper update\n // #12355 - solves problem with multiple destroy events\n series.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n series.eventsToUnbind.length = 0;\n }\n }\n /**\n * Render the graph and markers. Called internally when first rendering\n * and later when redrawing the chart. This function can be extended in\n * plugins, but normally shouldn't be called directly.\n *\n * @function Highcharts.Series#render\n *\n * @emits Highcharts.Series#event:afterRender\n */\n render() {\n const series = this, chart = series.chart, options = series.options, animOptions = animObject(options.animation), visibility = series.visible ?\n 'inherit' : 'hidden', // #2597\n zIndex = options.zIndex, hasRendered = series.hasRendered, chartSeriesGroup = chart.seriesGroup, inverted = chart.inverted;\n let animDuration = (!series.finishedAnimating) ?\n animOptions.duration : 0;\n fireEvent(this, 'render');\n // the group\n const group = series.plotGroup('group', 'series', visibility, zIndex, chartSeriesGroup);\n series.markerGroup = series.plotGroup('markerGroup', 'markers', visibility, zIndex, chartSeriesGroup);\n // Initial clipping, applies to columns etc. (#3839).\n if (options.clip !== false) {\n series.setClip();\n }\n // Initialize the animation\n if (series.animate && animDuration) {\n series.animate(true);\n }\n // Draw the graph if any\n if (series.drawGraph) {\n series.drawGraph();\n series.applyZones();\n }\n // Draw the points\n if (series.visible) {\n series.drawPoints();\n }\n // Draw the data labels\n if (series.drawDataLabels) {\n series.drawDataLabels();\n }\n // In pie charts, slices are added to the DOM, but actual rendering\n // is postponed until labels reserved their space\n if (series.redrawPoints) {\n series.redrawPoints();\n }\n // Draw the mouse tracking area\n if (series.drawTracker &&\n options.enableMouseTracking) {\n series.drawTracker();\n }\n // Run the animation\n if (series.animate && animDuration) {\n series.animate();\n }\n // Call the afterAnimate function on animation complete (but don't\n // overwrite the animation.complete option which should be available\n // to the user).\n if (!hasRendered) {\n // Additional time if defer is defined before afterAnimate\n // will be triggered\n if (animDuration && animOptions.defer) {\n animDuration += animOptions.defer;\n }\n series.animationTimeout = syncTimeout(function () {\n series.afterAnimate();\n }, animDuration || 0);\n }\n // Means data is in accordance with what you see\n series.isDirty = false;\n // (See #322) series.isDirty = series.isDirtyData = false; // means\n // data is in accordance with what you see\n series.hasRendered = true;\n fireEvent(series, 'afterRender');\n }\n /**\n * Redraw the series. This function is called internally from\n * `chart.redraw` and normally shouldn't be called directly.\n * @private\n * @function Highcharts.Series#redraw\n */\n redraw() {\n // Cache it here as it is set to false in render, but used after\n const wasDirty = this.isDirty || this.isDirtyData;\n this.translate();\n this.render();\n if (wasDirty) { // #3868, #3945\n delete this.kdTree;\n }\n }\n /**\n * Find the nearest point from a pointer event. This applies to series that\n * use k-d-trees to get the nearest point. Native pointer events must be\n * normalized using `Pointer.normalize`, that adds `chartX` and `chartY`\n * properties.\n *\n * @sample highcharts/demo/synchronized-charts\n * Synchronized charts with tooltips\n *\n * @function Highcharts.Series#searchPoint\n *\n * @param {Highcharts.PointerEvent} e\n * The normalized pointer event\n * @param {boolean} [compareX=false]\n * Search only by the X value, not Y\n *\n * @return {Point|undefined}\n * The closest point to the pointer event\n */\n searchPoint(e, compareX) {\n const series = this, xAxis = series.xAxis, yAxis = series.yAxis, inverted = series.chart.inverted;\n return this.searchKDTree({\n clientX: inverted ?\n xAxis.len - e.chartY + xAxis.pos :\n e.chartX - xAxis.pos,\n plotY: inverted ?\n yAxis.len - e.chartX + yAxis.pos :\n e.chartY - yAxis.pos\n }, compareX, e);\n }\n /**\n * Build the k-d-tree that is used by mouse and touch interaction to get\n * the closest point. Line-like series typically have a one-dimensional\n * tree where points are searched along the X axis, while scatter-like\n * series typically search in two dimensions, X and Y.\n *\n * @private\n * @function Highcharts.Series#buildKDTree\n */\n buildKDTree(e) {\n // Prevent multiple k-d-trees from being built simultaneously\n // (#6235)\n this.buildingKdTree = true;\n const series = this, dimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Internal function\n * @private\n */\n function _kdtree(points, depth, dimensions) {\n const length = points && points.length;\n let axis, median;\n if (length) {\n // alternate between the axis\n axis = series.kdAxisArray[depth % dimensions];\n // sort point array\n points.sort(function (a, b) {\n return a[axis] - b[axis];\n });\n median = Math.floor(length / 2);\n // build and return nod\n return {\n point: points[median],\n left: _kdtree(points.slice(0, median), depth + 1, dimensions),\n right: _kdtree(points.slice(median + 1), depth + 1, dimensions)\n };\n }\n }\n /**\n * Start the recursive build process with a clone of the points\n * array and null points filtered out. (#3873)\n * @private\n */\n function startRecursive() {\n series.kdTree = _kdtree(series.getValidPoints(null, \n // For line-type series restrict to plot area, but\n // column-type series not (#3916, #4511)\n !series.directTouch), dimensions, dimensions);\n series.buildingKdTree = false;\n }\n delete series.kdTree;\n // For testing tooltips, don't build async. Also if touchstart, we\n // may be dealing with click events on mobile, so don't delay\n // (#6817).\n syncTimeout(startRecursive, series.options.kdNow || (e && e.type === 'touchstart') ? 0 : 1);\n }\n /**\n * @private\n * @function Highcharts.Series#searchKDTree\n */\n searchKDTree(point, compareX, e) {\n const series = this, kdX = this.kdAxisArray[0], kdY = this.kdAxisArray[1], kdComparer = compareX ? 'distX' : 'dist', kdDimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Set the one and two dimensional distance on the point object.\n * @private\n */\n function setDistance(p1, p2) {\n const x = (defined(p1[kdX]) &&\n defined(p2[kdX])) ?\n Math.pow(p1[kdX] - p2[kdX], 2) :\n null, y = (defined(p1[kdY]) &&\n defined(p2[kdY])) ?\n Math.pow(p1[kdY] - p2[kdY], 2) :\n null, r = (x || 0) + (y || 0);\n p2.dist = defined(r) ? Math.sqrt(r) : Number.MAX_VALUE;\n p2.distX = defined(x) ? Math.sqrt(x) : Number.MAX_VALUE;\n }\n /**\n * @private\n */\n function _search(search, tree, depth, dimensions) {\n const point = tree.point, axis = series.kdAxisArray[depth % dimensions];\n let nPoint1, nPoint2, ret = point;\n setDistance(search, point);\n // Pick side based on distance to splitting point\n const tdist = search[axis] - point[axis], sideA = tdist < 0 ? 'left' : 'right', sideB = tdist < 0 ? 'right' : 'left';\n // End of tree\n if (tree[sideA]) {\n nPoint1 = _search(search, tree[sideA], depth + 1, dimensions);\n ret = (nPoint1[kdComparer] <\n ret[kdComparer] ?\n nPoint1 :\n point);\n }\n if (tree[sideB]) {\n // compare distance to current best to splitting point to\n // decide whether to check side B or not\n if (Math.sqrt(tdist * tdist) < ret[kdComparer]) {\n nPoint2 = _search(search, tree[sideB], depth + 1, dimensions);\n ret = (nPoint2[kdComparer] <\n ret[kdComparer] ?\n nPoint2 :\n ret);\n }\n }\n return ret;\n }\n if (!this.kdTree && !this.buildingKdTree) {\n this.buildKDTree(e);\n }\n if (this.kdTree) {\n return _search(point, this.kdTree, kdDimensions, kdDimensions);\n }\n }\n /**\n * @private\n * @function Highcharts.Series#pointPlacementToXValue\n */\n pointPlacementToXValue() {\n const { options: { pointPlacement, pointRange }, xAxis: axis } = this;\n let factor = pointPlacement;\n // Point placement is relative to each series pointRange (#5889)\n if (factor === 'between') {\n factor = axis.reversed ? -0.5 : 0.5; // #11955\n }\n return isNumber(factor) ?\n factor * (pointRange || axis.pointRange) :\n 0;\n }\n /**\n * @private\n * @function Highcharts.Series#isPointInside\n */\n isPointInside(point) {\n const { chart, xAxis, yAxis } = this, isInside = (typeof point.plotY !== 'undefined' &&\n typeof point.plotX !== 'undefined' &&\n point.plotY >= 0 &&\n point.plotY <= (yAxis ? yAxis.len : chart.plotHeight) &&\n point.plotX >= 0 &&\n point.plotX <= (xAxis ? xAxis.len : chart.plotWidth));\n return isInside;\n }\n /**\n * Draw the tracker object that sits above all data labels and markers to\n * track mouse events on the graph or points. For the line type charts\n * the tracker uses the same graphPath, but with a greater stroke width\n * for better control.\n * @private\n */\n drawTracker() {\n const series = this, options = series.options, trackByArea = options.trackByArea, trackerPath = [].concat(trackByArea ?\n series.areaPath :\n series.graphPath), \n // trackerPathLength = trackerPath.length,\n chart = series.chart, pointer = chart.pointer, renderer = chart.renderer, snap = chart.options.tooltip.snap, tracker = series.tracker, onMouseOver = function (e) {\n if (options.enableMouseTracking &&\n chart.hoverSeries !== series) {\n series.onMouseOver();\n }\n }, \n /*\n * Empirical lowest possible opacities for TRACKER_FILL for an\n * element to stay invisible but clickable\n * IE9: 0.00000000001 (unlimited)\n * IE10: 0.0001 (exporting only)\n * FF: 0.00000000001 (unlimited)\n * Chrome: 0.000001\n * Safari: 0.000001\n * Opera: 0.00000000001 (unlimited)\n */\n TRACKER_FILL = 'rgba(192,192,192,' + (svg ? 0.0001 : 0.002) + ')';\n let i;\n // Draw the tracker\n if (tracker) {\n tracker.attr({ d: trackerPath });\n }\n else if (series.graph) { // create\n series.tracker = renderer.path(trackerPath)\n .attr({\n visibility: series.visible ? 'inherit' : 'hidden',\n zIndex: 2\n })\n .addClass(trackByArea ?\n 'highcharts-tracker-area' :\n 'highcharts-tracker-line')\n .add(series.group);\n if (!chart.styledMode) {\n series.tracker.attr({\n 'stroke-linecap': 'round',\n 'stroke-linejoin': 'round',\n stroke: TRACKER_FILL,\n fill: trackByArea ? TRACKER_FILL : 'none',\n 'stroke-width': series.graph.strokeWidth() +\n (trackByArea ? 0 : 2 * snap)\n });\n }\n // The tracker is added to the series group, which is clipped, but\n // is covered by the marker group. So the marker group also needs to\n // capture events.\n [\n series.tracker,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (tracker) {\n if (tracker) {\n tracker.addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (options.cursor && !chart.styledMode) {\n tracker.css({ cursor: options.cursor });\n }\n if (hasTouch) {\n tracker.on('touchstart', onMouseOver);\n }\n }\n });\n }\n fireEvent(this, 'afterDrawTracker');\n }\n /**\n * Add a point to the series after render time. The point can be added at\n * the end, or by giving it an X value, to the start or in the middle of the\n * series.\n *\n * @sample highcharts/members/series-addpoint-append/\n * Append point\n * @sample highcharts/members/series-addpoint-append-and-shift/\n * Append and shift\n * @sample highcharts/members/series-addpoint-x-and-y/\n * Both X and Y values given\n * @sample highcharts/members/series-addpoint-pie/\n * Append pie slice\n * @sample stock/members/series-addpoint/\n * Append 100 points in Highcharts Stock\n * @sample stock/members/series-addpoint-shift/\n * Append and shift in Highcharts Stock\n * @sample maps/members/series-addpoint/\n * Add a point in Highmaps\n *\n * @function Highcharts.Series#addPoint\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. If options is a single number, a point with\n * that y value is appended to the series. If it is an array, it will\n * be interpreted as x and y values respectively. If it is an\n * object, advanced options as outlined under `series.data` are\n * applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When adding\n * more than one point, it is highly recommended that the redraw\n * option be set to false, and instead {@link Chart#redraw} is\n * explicitly called after the adding of points is finished.\n * Otherwise, the chart will redraw after adding each point.\n *\n * @param {boolean} [shift=false]\n * If true, a point is shifted off the start of the series as one is\n * appended to the end.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `addPoint` event.\n *\n * @emits Highcharts.Series#event:addPoint\n */\n addPoint(options, redraw, shift, animation, withEvent) {\n const series = this, seriesOptions = series.options, data = series.data, chart = series.chart, xAxis = series.xAxis, names = xAxis && xAxis.hasNames && xAxis.names, dataOptions = seriesOptions.data, xData = series.xData;\n let isInTheMiddle, i;\n // Optional redraw, defaults to true\n redraw = pick(redraw, true);\n // Get options and push the point to xData, yData and series.options. In\n // series.generatePoints the Point instance will be created on demand\n // and pushed to the series.data array.\n const point = { series: series };\n series.pointClass.prototype.applyOptions.apply(point, [options]);\n const x = point.x;\n // Get the insertion point\n i = xData.length;\n if (series.requireSorting && x < xData[i - 1]) {\n isInTheMiddle = true;\n while (i && xData[i - 1] > x) {\n i--;\n }\n }\n // Insert undefined item\n series.updateParallelArrays(point, 'splice', [i, 0, 0]);\n // Update it\n series.updateParallelArrays(point, i);\n if (names && point.name) {\n names[x] = point.name;\n }\n dataOptions.splice(i, 0, options);\n if (isInTheMiddle ||\n // When processedData is present we need to splice an empty slot\n // into series.data, otherwise generatePoints won't pick it up.\n series.processedData) {\n series.data.splice(i, 0, null);\n series.processData();\n }\n // Generate points to be added to the legend (#1329)\n if (seriesOptions.legendType === 'point') {\n series.generatePoints();\n }\n // Shift the first point off the parallel arrays\n if (shift) {\n if (data[0] && (data[0].remove)) {\n data[0].remove(false);\n }\n else {\n data.shift();\n series.updateParallelArrays(point, 'shift');\n dataOptions.shift();\n }\n }\n // Fire event\n if (withEvent !== false) {\n fireEvent(series, 'addPoint', { point: point });\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw(animation); // Animation is set anyway on redraw, #5665\n }\n }\n /**\n * Remove a point from the series. Unlike the\n * {@link Highcharts.Point#remove} method, this can also be done on a point\n * that is not instanciated because it is outside the view or subject to\n * Highcharts Stock data grouping.\n *\n * @sample highcharts/members/series-removepoint/\n * Remove cropped point\n *\n * @function Highcharts.Series#removePoint\n *\n * @param {number} i\n * The index of the point in the {@link Highcharts.Series.data|data}\n * array.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When\n * removing more than one point, it is highly recommended that the\n * `redraw` option be set to `false`, and instead {@link\n * Highcharts.Chart#redraw} is explicitly called after the adding of\n * points is finished.\n *\n * @param {boolean|Partial} [animation]\n * Whether and optionally how the series should be animated.\n *\n * @emits Highcharts.Point#event:remove\n */\n removePoint(i, redraw, animation) {\n const series = this, data = series.data, point = data[i], points = series.points, chart = series.chart, remove = function () {\n if (points && points.length === data.length) { // #4935\n points.splice(i, 1);\n }\n data.splice(i, 1);\n series.options.data.splice(i, 1);\n series.updateParallelArrays(point || { series: series }, 'splice', [i, 1]);\n if (point) {\n point.destroy();\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw();\n }\n };\n setAnimation(animation, chart);\n redraw = pick(redraw, true);\n // Fire the event with a default handler of removing the point\n if (point) {\n point.firePointEvent('remove', null, remove);\n }\n else {\n remove();\n }\n }\n /**\n * Remove a series and optionally redraw the chart.\n *\n * @sample highcharts/members/series-remove/\n * Remove first series from a button\n *\n * @function Highcharts.Series#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `remove` event.\n *\n * @emits Highcharts.Series#event:remove\n */\n remove(redraw, animation, withEvent, keepEvents) {\n const series = this, chart = series.chart;\n /**\n * @private\n */\n function remove() {\n // Destroy elements\n series.destroy(keepEvents);\n // Redraw\n chart.isDirtyLegend = chart.isDirtyBox = true;\n chart.linkSeries(keepEvents);\n if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of removing the point\n if (withEvent !== false) {\n fireEvent(series, 'remove', null, remove);\n }\n else {\n remove();\n }\n }\n /**\n * Update the series with a new set of options. For a clean and precise\n * handling of new options, all methods and elements from the series are\n * removed, and it is initialized from scratch. Therefore, this method is\n * more performance expensive than some other utility methods like {@link\n * Series#setData} or {@link Series#setVisible}.\n *\n * Note that `Series.update` may mutate the passed `data` options.\n *\n * @sample highcharts/members/series-update/\n * Updating series options\n * @sample maps/members/series-update/\n * Update series options in Highmaps\n *\n * @function Highcharts.Series#update\n *\n * @param {Highcharts.SeriesOptionsType} options\n * New options that will be merged with the series' existing options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to\n * false and call {@link Chart#redraw} after.\n *\n * @emits Highcharts.Series#event:update\n * @emits Highcharts.Series#event:afterUpdate\n */\n update(options, redraw) {\n options = diffObjects(options, this.userOptions);\n fireEvent(this, 'update', { options: options });\n const series = this, chart = series.chart, \n // must use user options when changing type because series.options\n // is merged in with type specific plotOptions\n oldOptions = series.userOptions, initialType = series.initialType || series.type, plotOptions = chart.options.plotOptions, initialSeriesProto = seriesTypes[initialType].prototype, groups = [\n 'group',\n 'markerGroup',\n 'dataLabelsGroup',\n 'transformGroup'\n ], \n // Animation must be enabled when calling update before the initial\n // animation has first run. This happens when calling update\n // directly after chart initialization, or when applying responsive\n // rules (#6912).\n animation = series.finishedAnimating && { animation: false }, kinds = {};\n let seriesOptions, n, preserve = [\n 'colorIndex',\n 'eventOptions',\n 'navigatorSeries',\n 'symbolIndex',\n 'baseSeries'\n ], newType = (options.type ||\n oldOptions.type ||\n chart.options.chart.type);\n const keepPoints = !(\n // Indicators, histograms etc recalculate the data. It should be\n // possible to omit this.\n this.hasDerivedData ||\n // New type requires new point classes\n (newType && newType !== this.type) ||\n // New options affecting how the data points are built\n typeof options.pointStart !== 'undefined' ||\n typeof options.pointInterval !== 'undefined' ||\n typeof options.relativeXValue !== 'undefined' ||\n options.joinBy ||\n options.mapData || // #11636\n // Changes to data grouping requires new points in new group\n series.hasOptionChanged('dataGrouping') ||\n series.hasOptionChanged('pointStart') ||\n series.hasOptionChanged('pointInterval') ||\n series.hasOptionChanged('pointIntervalUnit') ||\n series.hasOptionChanged('keys'));\n newType = newType || initialType;\n if (keepPoints) {\n preserve.push('data', 'isDirtyData', 'points', 'processedData', // #17057\n 'processedXData', 'processedYData', 'xIncrement', 'cropped', '_hasPointMarkers', '_hasPointLabels', 'clips', // #15420\n // Networkgraph (#14397)\n 'nodes', 'layout', \n // Treemap\n 'level', \n // Map specific, consider moving it to series-specific preserve-\n // properties (#10617)\n 'mapMap', 'mapData', 'minY', 'maxY', 'minX', 'maxX');\n if (options.visible !== false) {\n preserve.push('area', 'graph');\n }\n series.parallelArrays.forEach(function (key) {\n preserve.push(key + 'Data');\n });\n if (options.data) {\n // setData uses dataSorting options so we need to update them\n // earlier\n if (options.dataSorting) {\n extend(series.options.dataSorting, options.dataSorting);\n }\n this.setData(options.data, false);\n }\n }\n // Do the merge, with some forced options\n options = merge(oldOptions, animation, {\n // When oldOptions.index is null it should't be cleared.\n // Otherwise navigator series will have wrong indexes (#10193).\n index: typeof oldOptions.index === 'undefined' ?\n series.index : oldOptions.index,\n pointStart: pick(\n // when updating from blank (#7933)\n (plotOptions &&\n plotOptions.series &&\n plotOptions.series.pointStart), oldOptions.pointStart, \n // when updating after addPoint\n series.xData[0])\n }, (!keepPoints && { data: series.options.data }), options);\n // Merge does not merge arrays, but replaces them. Since points were\n // updated, `series.options.data` has correct merged options, use it:\n if (keepPoints && options.data) {\n options.data = series.options.data;\n }\n // Make sure preserved properties are not destroyed (#3094)\n preserve = groups.concat(preserve);\n preserve.forEach(function (prop) {\n preserve[prop] = series[prop];\n delete series[prop];\n });\n let casting = false;\n if (seriesTypes[newType]) {\n casting = newType !== series.type;\n // Destroy the series and delete all properties, it will be\n // reinserted within the `init` call below\n series.remove(false, false, false, true);\n if (casting) {\n // Modern browsers including IE11\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(series, seriesTypes[newType].prototype);\n // Legacy (IE < 11)\n }\n else {\n const ownEvents = Object.hasOwnProperty.call(series, 'hcEvents') && series.hcEvents;\n for (n in initialSeriesProto) { // eslint-disable-line guard-for-in\n series[n] = void 0;\n }\n // Reinsert all methods and properties from the new type\n // prototype (#2270, #3719).\n extend(series, seriesTypes[newType].prototype);\n // The events are tied to the prototype chain, don't copy if\n // they're not the series' own\n if (ownEvents) {\n series.hcEvents = ownEvents;\n }\n else {\n delete series.hcEvents;\n }\n }\n }\n }\n else {\n error(17, true, chart, { missingModuleFor: newType });\n }\n // Re-register groups (#3094) and other preserved properties\n preserve.forEach(function (prop) {\n series[prop] = preserve[prop];\n });\n series.init(chart, options);\n // Remove particular elements of the points. Check `series.options`\n // because we need to consider the options being set on plotOptions as\n // well.\n if (keepPoints && this.points) {\n seriesOptions = series.options;\n // What kind of elements to destroy\n if (seriesOptions.visible === false) {\n kinds.graphic = 1;\n kinds.dataLabel = 1;\n }\n else if (!series._hasPointLabels) {\n const { marker, dataLabels } = seriesOptions, oldMarker = oldOptions.marker || {};\n // If the marker got disabled or changed its symbol, width or\n // height - destroy\n if (marker && (marker.enabled === false ||\n oldMarker.symbol !== marker.symbol || // #10870, #15946\n oldMarker.height !== marker.height || // #16274\n oldMarker.width !== marker.width // #16274\n )) {\n kinds.graphic = 1;\n }\n if (dataLabels &&\n dataLabels.enabled === false) {\n kinds.dataLabel = 1;\n }\n }\n for (const point of this.points) {\n if (point && point.series) {\n point.resolveColor();\n // Destroy elements in order to recreate based on updated\n // series options.\n if (Object.keys(kinds).length) {\n point.destroyElements(kinds);\n }\n if (seriesOptions.showInLegend === false &&\n point.legendItem) {\n chart.legend.destroyItem(point);\n }\n }\n }\n }\n series.initialType = initialType;\n chart.linkSeries(); // Links are lost in series.remove (#3028)\n // #15383: Fire updatedData if the type has changed to keep linked\n // series such as indicators updated\n if (casting && series.linkedSeries.length) {\n series.isDirtyData = true;\n }\n fireEvent(this, 'afterUpdate');\n if (pick(redraw, true)) {\n chart.redraw(keepPoints ? void 0 : false);\n }\n }\n /**\n * Used from within series.update\n * @private\n */\n setName(name) {\n this.name = this.options.name = this.userOptions.name = name;\n this.chart.isDirtyLegend = true;\n }\n /**\n * Check if the option has changed.\n * @private\n */\n hasOptionChanged(optionName) {\n const chart = this.chart, option = this.options[optionName], plotOptions = chart.options.plotOptions, oldOption = this.userOptions[optionName];\n if (oldOption) {\n return option !== oldOption;\n }\n return option !==\n pick(plotOptions &&\n plotOptions[this.type] &&\n plotOptions[this.type][optionName], plotOptions &&\n plotOptions.series &&\n plotOptions.series[optionName], option);\n }\n /**\n * Runs on mouse over the series graphical items.\n *\n * @function Highcharts.Series#onMouseOver\n * @emits Highcharts.Series#event:mouseOver\n */\n onMouseOver() {\n const series = this, chart = series.chart, hoverSeries = chart.hoverSeries, pointer = chart.pointer;\n pointer.setHoverChartIndex();\n // set normal state to previous series\n if (hoverSeries && hoverSeries !== series) {\n hoverSeries.onMouseOut();\n }\n // trigger the event, but to save processing time,\n // only if defined\n if (series.options.events.mouseOver) {\n fireEvent(series, 'mouseOver');\n }\n // hover this\n series.setState('hover');\n /**\n * Contains the original hovered series.\n *\n * @name Highcharts.Chart#hoverSeries\n * @type {Highcharts.Series|null}\n */\n chart.hoverSeries = series;\n }\n /**\n * Runs on mouse out of the series graphical items.\n *\n * @function Highcharts.Series#onMouseOut\n *\n * @emits Highcharts.Series#event:mouseOut\n */\n onMouseOut() {\n // trigger the event only if listeners exist\n const series = this, options = series.options, chart = series.chart, tooltip = chart.tooltip, hoverPoint = chart.hoverPoint;\n // #182, set to null before the mouseOut event fires\n chart.hoverSeries = null;\n // trigger mouse out on the point, which must be in this series\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n // fire the mouse out event\n if (series && options.events.mouseOut) {\n fireEvent(series, 'mouseOut');\n }\n // hide the tooltip\n if (tooltip &&\n !series.stickyTracking &&\n (!tooltip.shared || series.noSharedTooltip)) {\n tooltip.hide();\n }\n // Reset all inactive states\n chart.series.forEach(function (s) {\n s.setState('', true);\n });\n }\n /**\n * Set the state of the series. Called internally on mouse interaction\n * operations, but it can also be called directly to visually\n * highlight a series.\n *\n * @function Highcharts.Series#setState\n *\n * @param {Highcharts.SeriesStateValue|\"\"} [state]\n * The new state, can be either `'hover'`, `'inactive'`, `'select'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [inherit]\n * Determines if state should be inherited by points too.\n */\n setState(state, inherit) {\n const series = this, options = series.options, graph = series.graph, inactiveOtherPoints = options.inactiveOtherPoints, stateOptions = options.states, \n // By default a quick animation to hover/inactive,\n // slower to un-hover\n stateAnimation = pick((stateOptions[state || 'normal'] &&\n stateOptions[state || 'normal'].animation), series.chart.options.chart.animation);\n let attribs, lineWidth = options.lineWidth, i = 0, opacity = options.opacity;\n state = state || '';\n if (series.state !== state) {\n // Toggle class names\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (group) {\n if (group) {\n // Old state\n if (series.state) {\n group.removeClass('highcharts-series-' + series.state);\n }\n // New state\n if (state) {\n group.addClass('highcharts-series-' + state);\n }\n }\n });\n series.state = state;\n if (!series.chart.styledMode) {\n if (stateOptions[state] &&\n stateOptions[state].enabled === false) {\n return;\n }\n if (state) {\n lineWidth = (stateOptions[state].lineWidth ||\n lineWidth + (stateOptions[state].lineWidthPlus || 0)); // #4035\n opacity = pick(stateOptions[state].opacity, opacity);\n }\n if (graph && !graph.dashstyle && isNumber(lineWidth)) {\n attribs = {\n 'stroke-width': lineWidth\n };\n // Animate the graph stroke-width.\n graph.animate(attribs, stateAnimation);\n while (series['zone-graph-' + i]) {\n series['zone-graph-' + i].animate(attribs, stateAnimation);\n i = i + 1;\n }\n }\n // For some types (pie, networkgraph, sankey) opacity is\n // resolved on a point level\n if (!inactiveOtherPoints) {\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup,\n series.labelBySeries\n ].forEach(function (group) {\n if (group) {\n group.animate({\n opacity: opacity\n }, stateAnimation);\n }\n });\n }\n }\n }\n // Don't loop over points on a series that doesn't apply inactive state\n // to siblings markers (e.g. line, column)\n if (inherit && inactiveOtherPoints && series.points) {\n series.setAllPointsToState(state || void 0);\n }\n }\n /**\n * Set the state for all points in the series.\n *\n * @function Highcharts.Series#setAllPointsToState\n *\n * @private\n *\n * @param {string} [state]\n * Can be either `hover` or undefined to set to normal state.\n */\n setAllPointsToState(state) {\n this.points.forEach(function (point) {\n if (point.setState) {\n point.setState(state);\n }\n });\n }\n /**\n * Show or hide the series.\n *\n * @function Highcharts.Series#setVisible\n *\n * @param {boolean} [visible]\n * True to show the series, false to hide. If undefined, the visibility is\n * toggled.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw|chart.redraw()} after.\n *\n * @emits Highcharts.Series#event:hide\n * @emits Highcharts.Series#event:show\n */\n setVisible(vis, redraw) {\n const series = this, chart = series.chart, ignoreHiddenSeries = chart.options.chart.ignoreHiddenSeries, oldVisibility = series.visible;\n // if called without an argument, toggle visibility\n series.visible =\n vis =\n series.options.visible =\n series.userOptions.visible =\n typeof vis === 'undefined' ? !oldVisibility : vis; // #5618\n const showOrHide = vis ? 'show' : 'hide';\n // show or hide elements\n [\n 'group',\n 'dataLabelsGroup',\n 'markerGroup',\n 'tracker',\n 'tt'\n ].forEach(function (key) {\n if (series[key]) {\n series[key][showOrHide]();\n }\n });\n // hide tooltip (#1361)\n if (chart.hoverSeries === series ||\n (chart.hoverPoint && chart.hoverPoint.series) === series) {\n series.onMouseOut();\n }\n if (series.legendItem) {\n chart.legend.colorizeItem(series, vis);\n }\n // rescale or adapt to resized chart\n series.isDirty = true;\n // in a stack, all other series are affected\n if (series.options.stacking) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.options.stacking && otherSeries.visible) {\n otherSeries.isDirty = true;\n }\n });\n }\n // show or hide linked series\n series.linkedSeries.forEach(function (otherSeries) {\n otherSeries.setVisible(vis, false);\n });\n if (ignoreHiddenSeries) {\n chart.isDirtyBox = true;\n }\n fireEvent(series, showOrHide);\n if (redraw !== false) {\n chart.redraw();\n }\n }\n /**\n * Show the series if hidden.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#show\n * @emits Highcharts.Series#event:show\n */\n show() {\n this.setVisible(true);\n }\n /**\n * Hide the series if visible. If the\n * [chart.ignoreHiddenSeries](https://api.highcharts.com/highcharts/chart.ignoreHiddenSeries)\n * option is true, the chart is redrawn without this series.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#hide\n * @emits Highcharts.Series#event:hide\n */\n hide() {\n this.setVisible(false);\n }\n /**\n * Select or unselect the series. This means its\n * {@link Highcharts.Series.selected|selected}\n * property is set, the checkbox in the legend is toggled and when selected,\n * the series is returned by the {@link Highcharts.Chart#getSelectedSeries}\n * function.\n *\n * @sample highcharts/members/series-select/\n * Select a series from a button\n *\n * @function Highcharts.Series#select\n *\n * @param {boolean} [selected]\n * True to select the series, false to unselect. If undefined, the selection\n * state is toggled.\n *\n * @emits Highcharts.Series#event:select\n * @emits Highcharts.Series#event:unselect\n */\n select(selected) {\n const series = this;\n series.selected =\n selected =\n this.options.selected = (typeof selected === 'undefined' ?\n !series.selected :\n selected);\n if (series.checkbox) {\n series.checkbox.checked = selected;\n }\n fireEvent(series, selected ? 'select' : 'unselect');\n }\n /**\n * Checks if a tooltip should be shown for a given point.\n *\n * @private\n */\n shouldShowTooltip(plotX, plotY, options = {}) {\n options.series = this;\n options.visiblePlotOnly = true;\n return this.chart.isInsidePlot(plotX, plotY, options);\n }\n /**\n * Draws the legend symbol based on the legendSymbol user option.\n *\n * @private\n */\n drawLegendSymbol(legend, item) {\n var _a;\n (_a = LegendSymbol[this.options.legendSymbol || 'rectangle']) === null || _a === void 0 ? void 0 : _a.call(this, legend, item);\n }\n }\n Series.defaultOptions = SeriesDefaults;\n /**\n * Registry of all available series types.\n *\n * @name Highcharts.Series.types\n * @type {Highcharts.Dictionary}\n */\n Series.types = SeriesRegistry.seriesTypes;\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Registers a series class to be accessible via `Series.types`.\n *\n * @function Highcharts.Series.registerType\n *\n * @param {string} seriesType\n * The series type as an identifier string in lower case.\n *\n * @param {Function} SeriesClass\n * The series class as a class pattern or a constructor function with\n * prototype.\n */\n Series.registerType = SeriesRegistry.registerSeriesType;\n extend(Series.prototype, {\n axisTypes: ['xAxis', 'yAxis'],\n coll: 'series',\n colorCounter: 0,\n cropShoulder: 1,\n directTouch: false,\n isCartesian: true,\n kdAxisArray: ['clientX', 'plotY'],\n // each point's x and y values are stored in this.xData and this.yData:\n parallelArrays: ['x', 'y'],\n pointClass: Point,\n requireSorting: true,\n // requires the data to be sorted:\n sorted: true\n });\n /* *\n *\n * Registry\n *\n * */\n SeriesRegistry.series = Series;\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * This is a placeholder type of the possible series options for\n * [Highcharts](../highcharts/series), [Highcharts Stock](../highstock/series),\n * [Highmaps](../highmaps/series), and [Gantt](../gantt/series).\n *\n * In TypeScript is this dynamically generated to reference all possible types\n * of series options.\n *\n * @ignore-declaration\n * @typedef {Highcharts.SeriesOptions|Highcharts.Dictionary<*>} Highcharts.SeriesOptionsType\n */\n /**\n * Options for `dataSorting`.\n *\n * @interface Highcharts.DataSortingOptionsObject\n * @since 8.0.0\n */ /**\n * Enable or disable data sorting for the series.\n * @name Highcharts.DataSortingOptionsObject#enabled\n * @type {boolean|undefined}\n */ /**\n * Whether to allow matching points by name in an update.\n * @name Highcharts.DataSortingOptionsObject#matchByName\n * @type {boolean|undefined}\n */ /**\n * Determines what data value should be used to sort by.\n * @name Highcharts.DataSortingOptionsObject#sortKey\n * @type {string|undefined}\n */\n /**\n * Function callback when a series has been animated.\n *\n * @callback Highcharts.SeriesAfterAnimateCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesAfterAnimateEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding completed animation of a series.\n *\n * @interface Highcharts.SeriesAfterAnimateEventObject\n */ /**\n * Animated series.\n * @name Highcharts.SeriesAfterAnimateEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesAfterAnimateEventObject#type\n * @type {\"afterAnimate\"}\n */\n /**\n * Function callback when the checkbox next to the series' name in the legend is\n * clicked.\n *\n * @callback Highcharts.SeriesCheckboxClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesCheckboxClickEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding check of a series box.\n *\n * @interface Highcharts.SeriesCheckboxClickEventObject\n */ /**\n * Whether the box has been checked.\n * @name Highcharts.SeriesCheckboxClickEventObject#checked\n * @type {boolean}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#item\n * @type {Highcharts.Series}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Function callback when a series is clicked. Return false to cancel toogle\n * actions.\n *\n * @callback Highcharts.SeriesClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series.\n *\n * @interface Highcharts.SeriesClickEventObject\n * @extends global.Event\n */ /**\n * Nearest point on the graph.\n * @name Highcharts.SeriesClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Gets fired when the series is hidden after chart generation time, either by\n * clicking the legend item or by calling `.hide()`.\n *\n * @callback Highcharts.SeriesHideCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin` of a line\n * graph.\n *\n * @typedef {\"butt\"|\"round\"|\"square\"|string} Highcharts.SeriesLinecapValue\n */\n /**\n * Gets fired when the legend item belonging to the series is clicked. The\n * default action is to toggle the visibility of the series. This can be\n * prevented by returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {global.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Gets fired when the mouse leaves the graph.\n *\n * @callback Highcharts.SeriesMouseOutCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the graph.\n *\n * @callback Highcharts.SeriesMouseOverCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Translation and scale for the plot area of a series.\n *\n * @interface Highcharts.SeriesPlotBoxObject\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateY\n * @type {number}\n */\n /**\n * Gets fired when the series is shown after chart generation time, either by\n * clicking the legend item or by calling `.show()`.\n *\n * @callback Highcharts.SeriesShowCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the series state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.SeriesStateValue\n */\n ''; // detach doclets above\n /* *\n *\n * API Options\n *\n * */\n /**\n * Series options for specific data and the data itself. In TypeScript you\n * have to cast the series options to specific series types, to get all\n * possible options for a series.\n *\n * @example\n * // TypeScript example\n * Highcharts.chart('container', {\n * series: [{\n * color: '#06C',\n * data: [[0, 1], [2, 3]]\n * } as Highcharts.SeriesLineOptions ]\n * });\n *\n * @type {Array<*>}\n * @apioption series\n */\n /**\n * An id for the series. This can be used after render time to get a pointer\n * to the series object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @type {string}\n * @since 1.2.0\n * @apioption series.id\n */\n /**\n * The index of the series in the chart, affecting the internal index in the\n * `chart.series` array, the visible Z index as well as the order in the\n * legend.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption series.index\n */\n /**\n * The sequential index of the series in the legend.\n *\n * @see [legend.reversed](#legend.reversed),\n * [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts|highstock} highcharts/series/legendindex/\n * Legend in opposite order\n *\n * @type {number}\n * @apioption series.legendIndex\n */\n /**\n * The name of the series as shown in the legend, tooltip etc.\n *\n * @sample {highcharts} highcharts/series/name/\n * Series name\n * @sample {highmaps} maps/demo/category-map/\n * Series name\n *\n * @type {string}\n * @apioption series.name\n */\n /**\n * This option allows grouping series in a stacked chart. The stack option\n * can be a string or anything else, as long as the grouped series' stack\n * options match each other after conversion into a string.\n *\n * @sample {highcharts} highcharts/series/stack/\n * Stacked and grouped columns\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highstock\n * @apioption series.stack\n */\n /**\n * The type of series, for example `line` or `column`. By default, the\n * series type is inherited from [chart.type](#chart.type), so unless the\n * chart is a combination of series types, there is no need to set it on the\n * series level.\n *\n * @sample {highcharts} highcharts/series/type/\n * Line and column in the same chart\n * @sample highcharts/series/type-dynamic/\n * Dynamic types with button selector\n * @sample {highmaps} maps/demo/mapline-mappoint/\n * Multiple types in the same map\n *\n * @type {string}\n * @apioption series.type\n */\n /**\n * When using dual or multiple x axes, this number defines which xAxis the\n * particular series is connected to. It refers to either the\n * {@link #xAxis.id|axis id}\n * or the index of the axis in the xAxis array, with 0 being the first.\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.xAxis\n */\n /**\n * When using dual or multiple y axes, this number defines which yAxis the\n * particular series is connected to. It refers to either the\n * {@link #yAxis.id|axis id}\n * or the index of the axis in the yAxis array, with 0 being the first.\n *\n * @sample {highcharts} highcharts/series/yaxis/\n * Apply the column series to the secondary Y axis\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.yAxis\n */\n /**\n * Define the visual z index of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highcharts} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n * @sample {highstock} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highstock} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.zIndex\n */\n ''; // include precedent doclets in transpilat\n\n return Series;\n });\n _registerModule(_modules, 'Core/Chart/Chart.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Templating.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js'], _modules['Core/Renderer/HTML/AST.js']], function (A, Axis, D, Templating, Foundation, H, RendererRegistry, Series, SeriesRegistry, SVGRenderer, Time, U, AST) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animate, animObject, setAnimation } = A;\n const { defaultOptions, defaultTime } = D;\n const { numberFormat } = Templating;\n const { registerEventOptions } = Foundation;\n const { charts, doc, marginNames, svg, win } = H;\n const { seriesTypes } = SeriesRegistry;\n const { addEvent, attr, createElement, css, defined, diffObjects, discardElement, erase, error, extend, find, fireEvent, getStyle, isArray, isNumber, isObject, isString, merge, objectEach, pick, pInt, relativeLength, removeEvent, splat, syncTimeout, uniqueKey } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Chart class. The recommended constructor is {@link Highcharts#chart}.\n *\n * @example\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * })\n *\n * @class\n * @name Highcharts.Chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images\n * are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n */\n class Chart {\n /**\n * Factory function for basic charts.\n *\n * @example\n * // Render a chart in to div#container\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * });\n *\n * @function Highcharts.chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images are\n * loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {Highcharts.Chart}\n * Returns the Chart object.\n */\n static chart(a, b, c) {\n return new Chart(a, b, c);\n }\n constructor(a, b, c) {\n this.axes = void 0;\n this.axisOffset = void 0;\n this.bounds = void 0;\n this.chartHeight = void 0;\n this.chartWidth = void 0;\n this.clipBox = void 0;\n this.colorCounter = void 0;\n this.container = void 0;\n this.eventOptions = void 0;\n this.index = void 0;\n this.isResizing = void 0;\n this.labelCollectors = void 0;\n this.margin = void 0;\n this.numberFormatter = void 0;\n this.options = void 0;\n this.plotBox = void 0;\n this.plotHeight = void 0;\n this.plotLeft = void 0;\n this.plotTop = void 0;\n this.plotWidth = void 0;\n this.pointCount = void 0;\n this.pointer = void 0;\n this.renderer = void 0;\n this.renderTo = void 0;\n this.series = void 0;\n this.sharedClips = {};\n this.spacing = void 0;\n this.spacingBox = void 0;\n this.symbolCounter = void 0;\n this.time = void 0;\n this.titleOffset = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zooming = void 0;\n this.getArgs(a, b, c);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Handle the arguments passed to the constructor.\n *\n * @private\n * @function Highcharts.Chart#getArgs\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n getArgs(a, b, c) {\n // Remove the optional first argument, renderTo, and\n // set it on this.\n if (isString(a) || a.nodeName) {\n this.renderTo = a;\n this.init(b, c);\n }\n else {\n this.init(a, b);\n }\n }\n /**\n * Function setting zoom options after chart init and after chart update.\n * Offers support for deprecated options.\n *\n * @private\n * @function Highcharts.Chart#setZoomOptions\n */\n setZoomOptions() {\n const chart = this, options = chart.options.chart, zooming = options.zooming;\n chart.zooming = Object.assign(Object.assign({}, zooming), { type: pick(options.zoomType, zooming.type), key: pick(options.zoomKey, zooming.key), pinchType: pick(options.pinchType, zooming.pinchType), singleTouch: pick(options.zoomBySingleTouch, zooming.singleTouch, false), resetButton: merge(zooming.resetButton, options.resetZoomButton) });\n }\n /**\n * Overridable function that initializes the chart. The constructor's\n * arguments are passed on directly.\n *\n * @function Highcharts.Chart#init\n *\n * @param {Highcharts.Options} userOptions\n * Custom options.\n *\n * @param {Function} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded.\n *\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n init(userOptions, callback) {\n // Fire the event with a default function\n fireEvent(this, 'init', { args: arguments }, function () {\n const options = merge(defaultOptions, userOptions), // do the merge\n optionsChart = options.chart;\n /**\n * The original options given to the constructor or a chart factory\n * like {@link Highcharts.chart} and {@link Highcharts.stockChart}.\n * The original options are shallow copied to avoid mutation. The\n * copy, `chart.userOptions`, may later be mutated to reflect\n * updated options throughout the lifetime of the chart.\n *\n * For collections, like `series`, `xAxis` and `yAxis`, the chart\n * user options should always be reflected by the item user option,\n * so for example the following should always be true:\n *\n * `chart.xAxis[0].userOptions === chart.userOptions.xAxis[0]`\n *\n * @name Highcharts.Chart#userOptions\n * @type {Highcharts.Options}\n */\n this.userOptions = extend({}, userOptions);\n this.margin = [];\n this.spacing = [];\n // Pixel data bounds for touch zoom\n this.bounds = { h: {}, v: {} };\n // An array of functions that returns labels that should be\n // considered for anti-collision\n this.labelCollectors = [];\n this.callback = callback;\n this.isResizing = 0;\n /**\n * The options structure for the chart after merging\n * {@link #defaultOptions} and {@link #userOptions}. It contains\n * members for the sub elements like series, legend, tooltip etc.\n *\n * @name Highcharts.Chart#options\n * @type {Highcharts.Options}\n */\n this.options = options;\n /**\n * All the axes in the chart.\n *\n * @see Highcharts.Chart.xAxis\n * @see Highcharts.Chart.yAxis\n *\n * @name Highcharts.Chart#axes\n * @type {Array}\n */\n this.axes = [];\n /**\n * All the current series in the chart.\n *\n * @name Highcharts.Chart#series\n * @type {Array}\n */\n this.series = [];\n /**\n * The `Time` object associated with the chart. Since v6.0.5,\n * time settings can be applied individually for each chart. If\n * no individual settings apply, the `Time` object is shared by\n * all instances.\n *\n * @name Highcharts.Chart#time\n * @type {Highcharts.Time}\n */\n this.time =\n userOptions.time && Object.keys(userOptions.time).length ?\n new Time(userOptions.time) :\n H.time;\n /**\n * Callback function to override the default function that formats\n * all the numbers in the chart. Returns a string with the formatted\n * number.\n *\n * @name Highcharts.Chart#numberFormatter\n * @type {Highcharts.NumberFormatterCallbackFunction}\n */\n this.numberFormatter = optionsChart.numberFormatter || numberFormat;\n /**\n * Whether the chart is in styled mode, meaning all presentational\n * attributes are avoided.\n *\n * @name Highcharts.Chart#styledMode\n * @type {boolean}\n */\n this.styledMode = optionsChart.styledMode;\n this.hasCartesianSeries = optionsChart.showAxes;\n const chart = this;\n /**\n * Index position of the chart in the {@link Highcharts#charts}\n * property.\n *\n * @name Highcharts.Chart#index\n * @type {number}\n * @readonly\n */\n chart.index = charts.length; // Add the chart to the global lookup\n charts.push(chart);\n H.chartCount++;\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n /**\n * A collection of the X axes in the chart.\n *\n * @name Highcharts.Chart#xAxis\n * @type {Array}\n */\n chart.xAxis = [];\n /**\n * A collection of the Y axes in the chart.\n *\n * @name Highcharts.Chart#yAxis\n * @type {Array}\n *\n * @todo\n * Make events official: Fire the event `afterInit`.\n */\n chart.yAxis = [];\n chart.pointCount = chart.colorCounter = chart.symbolCounter = 0;\n this.setZoomOptions();\n // Fire after init but before first render, before axes and series\n // have been initialized.\n fireEvent(chart, 'afterInit');\n chart.firstRender();\n });\n }\n /**\n * Internal function to unitialize an individual series.\n *\n * @private\n * @function Highcharts.Chart#initSeries\n */\n initSeries(options) {\n const chart = this, optionsChart = chart.options.chart, type = (options.type ||\n optionsChart.type), SeriesClass = seriesTypes[type];\n // No such series type\n if (!SeriesClass) {\n error(17, true, chart, { missingModuleFor: type });\n }\n const series = new SeriesClass();\n if (typeof series.init === 'function') {\n series.init(chart, options);\n }\n return series;\n }\n /**\n * Internal function to set data for all series with enabled sorting.\n *\n * @private\n * @function Highcharts.Chart#setSeriesData\n */\n setSeriesData() {\n this.getSeriesOrderByLinks().forEach(function (series) {\n // We need to set data for series with sorting after series init\n if (!series.points && !series.data && series.enabledDataSorting) {\n series.setData(series.options.data, false);\n }\n });\n }\n /**\n * Sort and return chart series in order depending on the number of linked\n * series.\n *\n * @private\n * @function Highcharts.Series#getSeriesOrderByLinks\n */\n getSeriesOrderByLinks() {\n return this.series.concat().sort(function (a, b) {\n if (a.linkedSeries.length || b.linkedSeries.length) {\n return b.linkedSeries.length - a.linkedSeries.length;\n }\n return 0;\n });\n }\n /**\n * Order all series or axes above a given index. When series or axes are\n * added and ordered by configuration, only the last series is handled\n * (#248, #1123, #2456, #6112). This function is called on series and axis\n * initialization and destroy.\n *\n * @private\n * @function Highcharts.Chart#orderItems\n * @param {string} coll The collection name\n * @param {number} [fromIndex=0]\n * If this is given, only the series above this index are handled.\n */\n orderItems(coll, fromIndex = 0) {\n const collection = this[coll], \n // Item options should be reflected in chart.options.series,\n // chart.options.yAxis etc\n optionsArray = this.options[coll] = splat(this.options[coll])\n .slice(), userOptionsArray = this.userOptions[coll] = this.userOptions[coll] ?\n splat(this.userOptions[coll]).slice() :\n [];\n if (this.hasRendered) {\n // Remove all above index\n optionsArray.splice(fromIndex);\n userOptionsArray.splice(fromIndex);\n }\n if (collection) {\n for (let i = fromIndex, iEnd = collection.length; i < iEnd; ++i) {\n const item = collection[i];\n if (item) {\n /**\n * Contains the series' index in the `Chart.series` array.\n *\n * @name Highcharts.Series#index\n * @type {number}\n * @readonly\n */\n item.index = i;\n if (item instanceof Series) {\n item.name = item.getName();\n }\n if (!item.options.isInternal) {\n optionsArray[i] = item.options;\n userOptionsArray[i] = item.userOptions;\n }\n }\n }\n }\n }\n /**\n * Check whether a given point is within the plot area.\n *\n * @function Highcharts.Chart#isInsidePlot\n *\n * @param {number} plotX\n * Pixel x relative to the plot area.\n *\n * @param {number} plotY\n * Pixel y relative to the plot area.\n *\n * @param {Highcharts.ChartIsInsideOptionsObject} [options]\n * Options object.\n *\n * @return {boolean}\n * Returns true if the given point is inside the plot area.\n */\n isInsidePlot(plotX, plotY, options = {}) {\n const { inverted, plotBox, plotLeft, plotTop, scrollablePlotBox } = this;\n let scrollLeft = 0, scrollTop = 0;\n if (options.visiblePlotOnly && this.scrollingContainer) {\n ({ scrollLeft, scrollTop } = this.scrollingContainer);\n }\n const series = options.series, box = (options.visiblePlotOnly && scrollablePlotBox) || plotBox, x = options.inverted ? plotY : plotX, y = options.inverted ? plotX : plotY, e = {\n x,\n y,\n isInsidePlot: true,\n options\n };\n if (!options.ignoreX) {\n const xAxis = (series &&\n (inverted && !this.polar ? series.yAxis : series.xAxis)) || {\n pos: plotLeft,\n len: Infinity\n };\n const chartX = options.paneCoordinates ?\n xAxis.pos + x : plotLeft + x;\n if (!(chartX >= Math.max(scrollLeft + plotLeft, xAxis.pos) &&\n chartX <= Math.min(scrollLeft + plotLeft + box.width, xAxis.pos + xAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n if (!options.ignoreY && e.isInsidePlot) {\n const yAxis = (!inverted && options.axis &&\n !options.axis.isXAxis && options.axis) || (series && (inverted ? series.xAxis : series.yAxis)) || {\n pos: plotTop,\n len: Infinity\n };\n const chartY = options.paneCoordinates ?\n yAxis.pos + y : plotTop + y;\n if (!(chartY >= Math.max(scrollTop + plotTop, yAxis.pos) &&\n chartY <= Math.min(scrollTop + plotTop + box.height, yAxis.pos + yAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n fireEvent(this, 'afterIsInsidePlot', e);\n return e.isInsidePlot;\n }\n /**\n * Redraw the chart after changes have been done to the data, axis extremes\n * chart size or chart elements. All methods for updating axes, series or\n * points have a parameter for redrawing the chart. This is `true` by\n * default. But in many cases you want to do more than one operation on the\n * chart before redrawing, for example add a number of points. In those\n * cases it is a waste of resources to redraw the chart for each new point\n * added. So you add the points and call `chart.redraw()` after.\n *\n * @function Highcharts.Chart#redraw\n *\n * @param {boolean|Partial} [animation]\n * If or how to apply animation to the redraw. When `undefined`, it applies\n * the animation that is set in the `chart.animation` option.\n *\n * @emits Highcharts.Chart#event:afterSetExtremes\n * @emits Highcharts.Chart#event:beforeRedraw\n * @emits Highcharts.Chart#event:predraw\n * @emits Highcharts.Chart#event:redraw\n * @emits Highcharts.Chart#event:render\n * @emits Highcharts.Chart#event:updatedData\n */\n redraw(animation) {\n fireEvent(this, 'beforeRedraw');\n const chart = this, axes = chart.hasCartesianSeries ? chart.axes : chart.colorAxis || [], series = chart.series, pointer = chart.pointer, legend = chart.legend, legendUserOptions = chart.userOptions.legend, renderer = chart.renderer, isHiddenChart = renderer.isHidden(), afterRedraw = [];\n let hasDirtyStacks, hasStackedSeries, i, isDirtyBox = chart.isDirtyBox, redrawLegend = chart.isDirtyLegend, serie;\n renderer.rootFontSize = renderer.boxWrapper.getStyle('font-size');\n // Handle responsive rules, not only on resize (#6130)\n if (chart.setResponsive) {\n chart.setResponsive(false);\n }\n // Set the global animation. When chart.hasRendered is not true, the\n // redraw call comes from a responsive rule and animation should not\n // occur.\n setAnimation(chart.hasRendered ? animation : false, chart);\n if (isHiddenChart) {\n chart.temporaryDisplay();\n }\n // Adjust title layout (reflow multiline text)\n chart.layOutTitles(false);\n // link stacked series\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking || serie.options.centerInCategory) {\n hasStackedSeries = true;\n if (serie.isDirty) {\n hasDirtyStacks = true;\n break;\n }\n }\n }\n if (hasDirtyStacks) { // mark others as dirty\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking) {\n serie.isDirty = true;\n }\n }\n }\n // Handle updated data in the series\n series.forEach(function (serie) {\n if (serie.isDirty) {\n if (serie.options.legendType === 'point') {\n if (typeof serie.updateTotals === 'function') {\n serie.updateTotals();\n }\n redrawLegend = true;\n }\n else if (legendUserOptions &&\n (legendUserOptions.labelFormatter ||\n legendUserOptions.labelFormat)) {\n redrawLegend = true; // #2165\n }\n }\n if (serie.isDirtyData) {\n fireEvent(serie, 'updatedData');\n }\n });\n // handle added or removed series\n if (redrawLegend && legend && legend.options.enabled) {\n // draw legend graphics\n legend.render();\n chart.isDirtyLegend = false;\n }\n // reset stacks\n if (hasStackedSeries) {\n chart.getStacks();\n }\n // set axes scales\n axes.forEach(function (axis) {\n axis.updateNames();\n axis.setScale();\n });\n chart.getMargins(); // #3098\n // If one axis is dirty, all axes must be redrawn (#792, #2169)\n axes.forEach(function (axis) {\n if (axis.isDirty) {\n isDirtyBox = true;\n }\n });\n // redraw axes\n axes.forEach(function (axis) {\n // Fire 'afterSetExtremes' only if extremes are set\n const key = axis.min + ',' + axis.max;\n if (axis.extKey !== key) { // #821, #4452\n axis.extKey = key;\n // prevent a recursive call to chart.redraw() (#1119)\n afterRedraw.push(function () {\n fireEvent(axis, 'afterSetExtremes', extend(axis.eventArgs, axis.getExtremes())); // #747, #751\n delete axis.eventArgs;\n });\n }\n if (isDirtyBox || hasStackedSeries) {\n axis.redraw();\n }\n });\n // the plot areas size has changed\n if (isDirtyBox) {\n chart.drawChartBox();\n }\n // Fire an event before redrawing series, used by the boost module to\n // clear previous series renderings.\n fireEvent(chart, 'predraw');\n // redraw affected series\n series.forEach(function (serie) {\n if ((isDirtyBox || serie.isDirty) && serie.visible) {\n serie.redraw();\n }\n // Set it here, otherwise we will have unlimited 'updatedData' calls\n // for a hidden series after setData(). Fixes #6012\n serie.isDirtyData = false;\n });\n // move tooltip or reset\n if (pointer) {\n pointer.reset(true);\n }\n // redraw if canvas\n renderer.draw();\n // Fire the events\n fireEvent(chart, 'redraw');\n fireEvent(chart, 'render');\n if (isHiddenChart) {\n chart.temporaryDisplay(true);\n }\n // Fire callbacks that are put on hold until after the redraw\n afterRedraw.forEach(function (callback) {\n callback.call();\n });\n }\n /**\n * Get an axis, series or point object by `id` as given in the configuration\n * options. Returns `undefined` if no item is found.\n *\n * @sample highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @function Highcharts.Chart#get\n *\n * @param {string} id\n * The id as given in the configuration options.\n *\n * @return {Highcharts.Axis|Highcharts.Series|Highcharts.Point|undefined}\n * The retrieved item.\n */\n get(id) {\n const series = this.series;\n /**\n * @private\n */\n function itemById(item) {\n return (item.id === id ||\n (item.options && item.options.id === id));\n }\n let ret = \n // Search axes\n find(this.axes, itemById) ||\n // Search series\n find(this.series, itemById);\n // Search points\n for (let i = 0; !ret && i < series.length; i++) {\n ret = find(series[i].points || [], itemById);\n }\n return ret;\n }\n /**\n * Create the Axis instances based on the config options.\n *\n * @private\n * @function Highcharts.Chart#getAxes\n * @emits Highcharts.Chart#event:afterGetAxes\n * @emits Highcharts.Chart#event:getAxes\n */\n getAxes() {\n const options = this.options;\n fireEvent(this, 'getAxes');\n for (const coll of ['xAxis', 'yAxis']) {\n const arr = options[coll] = splat(options[coll] || {});\n for (const axisOptions of arr) {\n // eslint-disable-next-line no-new\n new Axis(this, axisOptions, coll);\n }\n }\n fireEvent(this, 'afterGetAxes');\n }\n /**\n * Returns an array of all currently selected points in the chart. Points\n * can be selected by clicking or programmatically by the\n * {@link Highcharts.Point#select}\n * function.\n *\n * @sample highcharts/plotoptions/series-allowpointselect-line/\n * Get selected points\n *\n * @function Highcharts.Chart#getSelectedPoints\n *\n * @return {Array}\n * The currently selected points.\n */\n getSelectedPoints() {\n return this.series.reduce((acc, series) => {\n // For one-to-one points inspect series.data in order to retrieve\n // points outside the visible range (#6445). For grouped data,\n // inspect the generated series.points.\n series.getPointsCollection()\n .forEach((point) => {\n if (pick(point.selectedStaging, point.selected)) {\n acc.push(point);\n }\n });\n return acc;\n }, []);\n }\n /**\n * Returns an array of all currently selected series in the chart. Series\n * can be selected either programmatically by the\n * {@link Highcharts.Series#select}\n * function or by checking the checkbox next to the legend item if\n * [series.showCheckBox](https://api.highcharts.com/highcharts/plotOptions.series.showCheckbox)\n * is true.\n *\n * @sample highcharts/members/chart-getselectedseries/\n * Get selected series\n *\n * @function Highcharts.Chart#getSelectedSeries\n *\n * @return {Array}\n * The currently selected series.\n */\n getSelectedSeries() {\n return this.series.filter(function (serie) {\n return serie.selected;\n });\n }\n /**\n * Set a new title or subtitle for the chart.\n *\n * @sample highcharts/members/chart-settitle/\n * Set title text and styles\n *\n * @function Highcharts.Chart#setTitle\n *\n * @param {Highcharts.TitleOptions} [titleOptions]\n * New title options. The title text itself is set by the\n * `titleOptions.text` property.\n *\n * @param {Highcharts.SubtitleOptions} [subtitleOptions]\n * New subtitle options. The subtitle text itself is set by the\n * `subtitleOptions.text` property.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart or wait for a later call to\n * `chart.redraw()`.\n */\n setTitle(titleOptions, subtitleOptions, redraw) {\n this.applyDescription('title', titleOptions);\n this.applyDescription('subtitle', subtitleOptions);\n // The initial call also adds the caption. On update, chart.update will\n // relay to Chart.setCaption.\n this.applyDescription('caption', void 0);\n this.layOutTitles(redraw);\n }\n /**\n * Apply a title, subtitle or caption for the chart\n *\n * @private\n * @function Highcharts.Chart#applyDescription\n * @param name {string}\n * Either title, subtitle or caption\n * @param {Highcharts.TitleOptions|Highcharts.SubtitleOptions|Highcharts.CaptionOptions|undefined} explicitOptions\n * The options to set, will be merged with default options.\n */\n applyDescription(name, explicitOptions) {\n const chart = this;\n // Merge default options with explicit options\n const options = this.options[name] = merge(this.options[name], explicitOptions);\n let elem = this[name];\n if (elem && explicitOptions) {\n this[name] = elem = elem.destroy(); // remove old\n }\n if (options && !elem) {\n elem = this.renderer.text(options.text, 0, 0, options.useHTML)\n .attr({\n align: options.align,\n 'class': 'highcharts-' + name,\n zIndex: options.zIndex || 4\n })\n .add();\n // Update methods, relay to `applyDescription`\n elem.update = function (updateOptions, redraw) {\n chart.applyDescription(name, updateOptions);\n chart.layOutTitles(redraw);\n };\n // Presentational\n if (!this.styledMode) {\n elem.css(extend(name === 'title' ? {\n // #2944\n fontSize: this.options.isStock ? '1em' : '1.2em'\n } : {}, options.style));\n }\n /**\n * The chart title. The title has an `update` method that allows\n * modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @sample highcharts/members/title-update/\n * Updating titles\n *\n * @name Highcharts.Chart#title\n * @type {Highcharts.TitleObject}\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @name Highcharts.Chart#subtitle\n * @type {Highcharts.SubtitleObject}\n */\n this[name] = elem;\n }\n }\n /**\n * Internal function to lay out the chart title, subtitle and caption, and\n * cache the full offset height for use in `getMargins`. The result is\n * stored in `this.titleOffset`.\n *\n * @private\n * @function Highcharts.Chart#layOutTitles\n *\n * @param {boolean} [redraw=true]\n * @emits Highcharts.Chart#event:afterLayOutTitles\n */\n layOutTitles(redraw = true) {\n const titleOffset = [0, 0, 0], renderer = this.renderer, spacingBox = this.spacingBox;\n // Lay out the title and the subtitle respectively\n ['title', 'subtitle', 'caption'].forEach(function (key) {\n const title = this[key], titleOptions = (this.options[key]), verticalAlign = titleOptions.verticalAlign || 'top', offset = key === 'title' ?\n verticalAlign === 'top' ? -3 : 0 :\n // Floating subtitle (#6574)\n verticalAlign === 'top' ? titleOffset[0] + 2 : 0;\n if (title) {\n title\n .css({\n width: (titleOptions.width ||\n spacingBox.width + (titleOptions.widthAdjust || 0)) + 'px'\n });\n const baseline = renderer.fontMetrics(title).b, \n // Skip the cache for HTML (#3481, #11666)\n height = Math.round(title.getBBox(titleOptions.useHTML).height);\n title.align(extend({\n y: verticalAlign === 'bottom' ?\n baseline :\n offset + baseline,\n height\n }, titleOptions), false, 'spacingBox');\n if (!titleOptions.floating) {\n if (verticalAlign === 'top') {\n titleOffset[0] = Math.ceil(titleOffset[0] +\n height);\n }\n else if (verticalAlign === 'bottom') {\n titleOffset[2] = Math.ceil(titleOffset[2] +\n height);\n }\n }\n }\n }, this);\n // Handle title.margin and caption.margin\n if (titleOffset[0] &&\n (this.options.title.verticalAlign || 'top') === 'top') {\n titleOffset[0] += this.options.title.margin;\n }\n if (titleOffset[2] &&\n this.options.caption.verticalAlign === 'bottom') {\n titleOffset[2] += this.options.caption.margin;\n }\n const requiresDirtyBox = (!this.titleOffset ||\n this.titleOffset.join(',') !== titleOffset.join(','));\n // Used in getMargins\n this.titleOffset = titleOffset;\n fireEvent(this, 'afterLayOutTitles');\n if (!this.isDirtyBox && requiresDirtyBox) {\n this.isDirtyBox = this.isDirtyLegend = requiresDirtyBox;\n // Redraw if necessary (#2719, #2744)\n if (this.hasRendered && redraw && this.isDirtyBox) {\n this.redraw();\n }\n }\n }\n /**\n * Internal function to get the available size of the container element\n *\n * @private\n * @function Highcharts.Chart#getContainerBox\n */\n getContainerBox() {\n return {\n width: getStyle(this.renderTo, 'width', true) || 0,\n height: getStyle(this.renderTo, 'height', true) || 0\n };\n }\n /**\n * Internal function to get the chart width and height according to options\n * and container size. Sets {@link Chart.chartWidth} and\n * {@link Chart.chartHeight}.\n *\n * @private\n * @function Highcharts.Chart#getChartSize\n */\n getChartSize() {\n const chart = this, optionsChart = chart.options.chart, widthOption = optionsChart.width, heightOption = optionsChart.height, containerBox = chart.getContainerBox();\n /**\n * The current pixel width of the chart.\n *\n * @name Highcharts.Chart#chartWidth\n * @type {number}\n */\n chart.chartWidth = Math.max(// #1393\n 0, widthOption || containerBox.width || 600 // #1460\n );\n /**\n * The current pixel height of the chart.\n *\n * @name Highcharts.Chart#chartHeight\n * @type {number}\n */\n chart.chartHeight = Math.max(0, relativeLength(heightOption, chart.chartWidth) ||\n (containerBox.height > 1 ? containerBox.height : 400));\n chart.containerBox = containerBox;\n }\n /**\n * If the renderTo element has no offsetWidth, most likely one or more of\n * its parents are hidden. Loop up the DOM tree to temporarily display the\n * parents, then save the original display properties, and when the true\n * size is retrieved, reset them. Used on first render and on redraws.\n *\n * @private\n * @function Highcharts.Chart#temporaryDisplay\n *\n * @param {boolean} [revert]\n * Revert to the saved original styles.\n */\n temporaryDisplay(revert) {\n let node = this.renderTo, tempStyle;\n if (!revert) {\n while (node && node.style) {\n // When rendering to a detached node, it needs to be temporarily\n // attached in order to read styling and bounding boxes (#5783,\n // #7024).\n if (!doc.body.contains(node) && !node.parentNode) {\n node.hcOrigDetached = true;\n doc.body.appendChild(node);\n }\n if (getStyle(node, 'display', false) === 'none' ||\n node.hcOricDetached) {\n node.hcOrigStyle = {\n display: node.style.display,\n height: node.style.height,\n overflow: node.style.overflow\n };\n tempStyle = {\n display: 'block',\n overflow: 'hidden'\n };\n if (node !== this.renderTo) {\n tempStyle.height = 0;\n }\n css(node, tempStyle);\n // If it still doesn't have an offset width after setting\n // display to block, it probably has an !important priority\n // #2631, 6803\n if (!node.offsetWidth) {\n node.style.setProperty('display', 'block', 'important');\n }\n }\n node = node.parentNode;\n if (node === doc.body) {\n break;\n }\n }\n }\n else {\n while (node && node.style) {\n if (node.hcOrigStyle) {\n css(node, node.hcOrigStyle);\n delete node.hcOrigStyle;\n }\n if (node.hcOrigDetached) {\n doc.body.removeChild(node);\n node.hcOrigDetached = false;\n }\n node = node.parentNode;\n }\n }\n }\n /**\n * Set the {@link Chart.container|chart container's} class name, in\n * addition to `highcharts-container`.\n *\n * @function Highcharts.Chart#setClassName\n *\n * @param {string} [className]\n * The additional class name.\n */\n setClassName(className) {\n this.container.className = 'highcharts-container ' + (className || '');\n }\n /**\n * Get the containing element, determine the size and create the inner\n * container div to hold the chart.\n *\n * @private\n * @function Highcharts.Chart#afterGetContainer\n * @emits Highcharts.Chart#event:afterGetContainer\n */\n getContainer() {\n const chart = this, options = chart.options, optionsChart = options.chart, indexAttrName = 'data-highcharts-chart', containerId = uniqueKey();\n let containerStyle, renderTo = chart.renderTo;\n if (!renderTo) {\n chart.renderTo = renderTo =\n optionsChart.renderTo;\n }\n if (isString(renderTo)) {\n chart.renderTo = renderTo =\n doc.getElementById(renderTo);\n }\n // Display an error if the renderTo is wrong\n if (!renderTo) {\n error(13, true, chart);\n }\n // If the container already holds a chart, destroy it. The check for\n // hasRendered is there because web pages that are saved to disk from\n // the browser, will preserve the data-highcharts-chart attribute and\n // the SVG contents, but not an interactive chart. So in this case,\n // charts[oldChartIndex] will point to the wrong chart if any (#2609).\n const oldChartIndex = pInt(attr(renderTo, indexAttrName));\n if (isNumber(oldChartIndex) &&\n charts[oldChartIndex] &&\n charts[oldChartIndex].hasRendered) {\n charts[oldChartIndex].destroy();\n }\n // Make a reference to the chart from the div\n attr(renderTo, indexAttrName, chart.index);\n // remove previous chart\n renderTo.innerHTML = AST.emptyHTML;\n // If the container doesn't have an offsetWidth, it has or is a child of\n // a node that has display:none. We need to temporarily move it out to a\n // visible state to determine the size, else the legend and tooltips\n // won't render properly. The skipClone option is used in sparklines as\n // a micro optimization, saving about 1-2 ms each chart.\n if (!optionsChart.skipClone && !renderTo.offsetWidth) {\n chart.temporaryDisplay();\n }\n // get the width and height\n chart.getChartSize();\n const chartWidth = chart.chartWidth;\n const chartHeight = chart.chartHeight;\n // Allow table cells and flex-boxes to shrink without the chart blocking\n // them out (#6427)\n css(renderTo, { overflow: 'hidden' });\n // Create the inner container\n if (!chart.styledMode) {\n containerStyle = extend({\n position: 'relative',\n // needed for context menu (avoidscrollbars) and content\n // overflow in IE\n overflow: 'hidden',\n width: chartWidth + 'px',\n height: chartHeight + 'px',\n textAlign: 'left',\n lineHeight: 'normal',\n zIndex: 0,\n '-webkit-tap-highlight-color': 'rgba(0,0,0,0)',\n userSelect: 'none',\n 'touch-action': 'manipulation',\n outline: 'none'\n }, optionsChart.style || {});\n }\n /**\n * The containing HTML element of the chart. The container is\n * dynamically inserted into the element given as the `renderTo`\n * parameter in the {@link Highcharts#chart} constructor.\n *\n * @name Highcharts.Chart#container\n * @type {Highcharts.HTMLDOMElement}\n */\n const container = createElement('div', {\n id: containerId\n }, containerStyle, renderTo);\n chart.container = container;\n // cache the cursor (#1650)\n chart._cursor = container.style.cursor;\n // Initialize the renderer\n const Renderer = optionsChart.renderer || !svg ?\n RendererRegistry.getRendererType(optionsChart.renderer) :\n SVGRenderer;\n /**\n * The renderer instance of the chart. Each chart instance has only one\n * associated renderer.\n *\n * @name Highcharts.Chart#renderer\n * @type {Highcharts.SVGRenderer}\n */\n chart.renderer = new Renderer(container, chartWidth, chartHeight, void 0, optionsChart.forExport, options.exporting && options.exporting.allowHTML, chart.styledMode);\n chart.containerBox = chart.getContainerBox();\n // Set the initial animation from the options\n setAnimation(void 0, chart);\n chart.setClassName(optionsChart.className);\n if (!chart.styledMode) {\n chart.renderer.setStyle(optionsChart.style);\n }\n else {\n // Initialize definitions\n for (const key in options.defs) { // eslint-disable-line guard-for-in\n this.renderer.definition(options.defs[key]);\n }\n }\n // Add a reference to the charts index\n chart.renderer.chartIndex = chart.index;\n fireEvent(this, 'afterGetContainer');\n }\n /**\n * Calculate margins by rendering axis labels in a preliminary position.\n * Title, subtitle and legend have already been rendered at this stage, but\n * will be moved into their final positions.\n *\n * @private\n * @function Highcharts.Chart#getMargins\n * @emits Highcharts.Chart#event:getMargins\n */\n getMargins(skipAxes) {\n const { spacing, margin, titleOffset } = this;\n this.resetMargins();\n // Adjust for title and subtitle\n if (titleOffset[0] && !defined(margin[0])) {\n this.plotTop = Math.max(this.plotTop, titleOffset[0] + spacing[0]);\n }\n if (titleOffset[2] && !defined(margin[2])) {\n this.marginBottom = Math.max(this.marginBottom, titleOffset[2] + spacing[2]);\n }\n // Adjust for legend\n if (this.legend && this.legend.display) {\n this.legend.adjustMargins(margin, spacing);\n }\n fireEvent(this, 'getMargins');\n if (!skipAxes) {\n this.getAxisMargins();\n }\n }\n /**\n * @private\n * @function Highcharts.Chart#getAxisMargins\n */\n getAxisMargins() {\n const chart = this, \n // [top, right, bottom, left]\n axisOffset = chart.axisOffset = [0, 0, 0, 0], colorAxis = chart.colorAxis, margin = chart.margin, getOffset = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.getOffset();\n }\n });\n };\n // pre-render axes to get labels offset width\n if (chart.hasCartesianSeries) {\n getOffset(chart.axes);\n }\n else if (colorAxis && colorAxis.length) {\n getOffset(colorAxis);\n }\n // Add the axis offsets\n marginNames.forEach(function (m, side) {\n if (!defined(margin[side])) {\n chart[m] += axisOffset[side];\n }\n });\n chart.setChartSize();\n }\n /**\n * Return the current options of the chart, but only those that differ from\n * default options. Items that can be either an object or an array of\n * objects, like `series`, `xAxis` and `yAxis`, are always returned as\n * array.\n *\n * @sample highcharts/members/chart-getoptions\n *\n * @function Highcharts.Chart#getOptions\n *\n * @since 11.1.0\n */\n getOptions() {\n return diffObjects(this.userOptions, defaultOptions);\n }\n /**\n * Reflows the chart to its container. By default, the Resize Observer is\n * attached to the chart's div which allows to reflows the chart\n * automatically to its container, as per the\n * [chart.reflow](https://api.highcharts.com/highcharts/chart.reflow)\n * option.\n *\n * @sample highcharts/chart/events-container/\n * Pop up and reflow\n *\n * @function Highcharts.Chart#reflow\n *\n * @param {global.Event} [e]\n * Event arguments. Used primarily when the function is called\n * internally as a response to window resize.\n */\n reflow(e) {\n const chart = this, optionsChart = chart.options.chart, hasUserSize = (defined(optionsChart.width) &&\n defined(optionsChart.height)), oldBox = chart.containerBox, containerBox = chart.getContainerBox();\n delete chart.pointer.chartPosition;\n // Width and height checks for display:none. Target is doc in Opera\n // and win in Firefox, Chrome and IE9.\n if (!hasUserSize &&\n !chart.isPrinting &&\n oldBox &&\n // When fired by resize observer inside hidden container\n containerBox.width) {\n if (containerBox.width !== oldBox.width ||\n containerBox.height !== oldBox.height) {\n U.clearTimeout(chart.reflowTimeout);\n // When called from window.resize, e is set, else it's called\n // directly (#2224)\n chart.reflowTimeout = syncTimeout(function () {\n // Set size, it may have been destroyed in the meantime\n // (#1257)\n if (chart.container) {\n chart.setSize(void 0, void 0, false);\n }\n }, e ? 100 : 0);\n }\n chart.containerBox = containerBox;\n }\n }\n /**\n * Toggle the event handlers necessary for auto resizing, depending on the\n * `chart.reflow` option.\n *\n * @private\n * @function Highcharts.Chart#setReflow\n */\n setReflow() {\n const chart = this;\n const runReflow = (e) => {\n var _a;\n if (((_a = chart.options) === null || _a === void 0 ? void 0 : _a.chart.reflow) && chart.hasLoaded) {\n chart.reflow(e);\n }\n };\n if (typeof ResizeObserver === 'function') {\n (new ResizeObserver(runReflow)).observe(chart.renderTo);\n // Fallback for more legacy browser versions.\n }\n else {\n const unbind = addEvent(win, 'resize', runReflow);\n addEvent(this, 'destroy', unbind);\n }\n }\n /**\n * Resize the chart to a given width and height. In order to set the width\n * only, the height argument may be skipped. To set the height only, pass\n * `undefined` for the width.\n *\n * @sample highcharts/members/chart-setsize-button/\n * Test resizing from buttons\n * @sample highcharts/members/chart-setsize-jquery-resizable/\n * Add a jQuery UI resizable\n * @sample stock/members/chart-setsize/\n * Highcharts Stock with UI resizable\n *\n * @function Highcharts.Chart#setSize\n *\n * @param {number|null} [width]\n * The new pixel width of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value (when\n * setting height only), or `null` to adapt to the width of the\n * containing element.\n *\n * @param {number|null} [height]\n * The new pixel height of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value, or `null`\n * in order to adapt to the height of the containing element.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation. When `undefined`, it applies\n * the animation that is set in the `chart.animation` option.\n *\n *\n * @emits Highcharts.Chart#event:endResize\n * @emits Highcharts.Chart#event:resize\n */\n setSize(width, height, animation) {\n const chart = this, renderer = chart.renderer;\n // Handle the isResizing counter\n chart.isResizing += 1;\n // set the animation for the current process\n setAnimation(animation, chart);\n const globalAnimation = renderer.globalAnimation;\n chart.oldChartHeight = chart.chartHeight;\n chart.oldChartWidth = chart.chartWidth;\n if (typeof width !== 'undefined') {\n chart.options.chart.width = width;\n }\n if (typeof height !== 'undefined') {\n chart.options.chart.height = height;\n }\n chart.getChartSize();\n // Resize the container with the global animation applied if enabled\n // (#2503)\n if (!chart.styledMode) {\n (globalAnimation ? animate : css)(chart.container, {\n width: chart.chartWidth + 'px',\n height: chart.chartHeight + 'px'\n }, globalAnimation);\n }\n chart.setChartSize(true);\n renderer.setSize(chart.chartWidth, chart.chartHeight, globalAnimation);\n // handle axes\n chart.axes.forEach(function (axis) {\n axis.isDirty = true;\n axis.setScale();\n });\n chart.isDirtyLegend = true; // force legend redraw\n chart.isDirtyBox = true; // force redraw of plot and chart border\n chart.layOutTitles(); // #2857\n chart.getMargins();\n chart.redraw(globalAnimation);\n chart.oldChartHeight = null;\n fireEvent(chart, 'resize');\n // Fire endResize and set isResizing back. If animation is disabled,\n // fire without delay\n syncTimeout(function () {\n if (chart) {\n fireEvent(chart, 'endResize', null, function () {\n chart.isResizing -= 1;\n });\n }\n }, animObject(globalAnimation).duration);\n }\n /**\n * Set the public chart properties. This is done before and after the\n * pre-render to determine margin sizes.\n *\n * @private\n * @function Highcharts.Chart#setChartSize\n * @emits Highcharts.Chart#event:afterSetChartSize\n */\n setChartSize(skipAxes) {\n const chart = this, inverted = chart.inverted, renderer = chart.renderer, chartWidth = chart.chartWidth, chartHeight = chart.chartHeight, optionsChart = chart.options.chart, spacing = chart.spacing, clipOffset = chart.clipOffset;\n let plotLeft, plotTop, plotWidth, plotHeight;\n /**\n * The current left position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotLeft\n * @type {number}\n */\n chart.plotLeft = plotLeft = Math.round(chart.plotLeft);\n /**\n * The current top position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotTop\n * @type {number}\n */\n chart.plotTop = plotTop = Math.round(chart.plotTop);\n /**\n * The current width of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotWidth\n * @type {number}\n */\n chart.plotWidth = plotWidth = Math.max(0, Math.round(chartWidth - plotLeft - chart.marginRight));\n /**\n * The current height of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotHeight\n * @type {number}\n */\n chart.plotHeight = plotHeight = Math.max(0, Math.round(chartHeight - plotTop - chart.marginBottom));\n chart.plotSizeX = inverted ? plotHeight : plotWidth;\n chart.plotSizeY = inverted ? plotWidth : plotHeight;\n chart.plotBorderWidth = optionsChart.plotBorderWidth || 0;\n // Set boxes used for alignment\n chart.spacingBox = renderer.spacingBox = {\n x: spacing[3],\n y: spacing[0],\n width: chartWidth - spacing[3] - spacing[1],\n height: chartHeight - spacing[0] - spacing[2]\n };\n chart.plotBox = renderer.plotBox = {\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n };\n const plotBorderWidth = 2 * Math.floor(chart.plotBorderWidth / 2), clipX = Math.ceil(Math.max(plotBorderWidth, clipOffset[3]) / 2), clipY = Math.ceil(Math.max(plotBorderWidth, clipOffset[0]) / 2);\n chart.clipBox = {\n x: clipX,\n y: clipY,\n width: Math.floor(chart.plotSizeX -\n Math.max(plotBorderWidth, clipOffset[1]) / 2 -\n clipX),\n height: Math.max(0, Math.floor(chart.plotSizeY -\n Math.max(plotBorderWidth, clipOffset[2]) / 2 -\n clipY))\n };\n if (!skipAxes) {\n chart.axes.forEach(function (axis) {\n axis.setAxisSize();\n axis.setAxisTranslation();\n });\n renderer.alignElements();\n }\n fireEvent(chart, 'afterSetChartSize', { skipAxes: skipAxes });\n }\n /**\n * Initial margins before auto size margins are applied.\n *\n * @private\n * @function Highcharts.Chart#resetMargins\n */\n resetMargins() {\n fireEvent(this, 'resetMargins');\n const chart = this, chartOptions = chart.options.chart;\n // Create margin and spacing array\n ['margin', 'spacing'].forEach(function splashArrays(target) {\n const value = chartOptions[target], values = isObject(value) ? value : [value, value, value, value];\n [\n 'Top',\n 'Right',\n 'Bottom',\n 'Left'\n ].forEach(function (sideName, side) {\n chart[target][side] = pick(chartOptions[target + sideName], values[side]);\n });\n });\n // Set margin names like chart.plotTop, chart.plotLeft,\n // chart.marginRight, chart.marginBottom.\n marginNames.forEach(function (m, side) {\n chart[m] = pick(chart.margin[side], chart.spacing[side]);\n });\n chart.axisOffset = [0, 0, 0, 0]; // top, right, bottom, left\n chart.clipOffset = [0, 0, 0, 0];\n }\n /**\n * Internal function to draw or redraw the borders and backgrounds for chart\n * and plot area.\n *\n * @private\n * @function Highcharts.Chart#drawChartBox\n * @emits Highcharts.Chart#event:afterDrawChartBox\n */\n drawChartBox() {\n const chart = this, optionsChart = chart.options.chart, renderer = chart.renderer, chartWidth = chart.chartWidth, chartHeight = chart.chartHeight, styledMode = chart.styledMode, plotBGImage = chart.plotBGImage, chartBackgroundColor = optionsChart.backgroundColor, plotBackgroundColor = optionsChart.plotBackgroundColor, plotBackgroundImage = optionsChart.plotBackgroundImage, plotLeft = chart.plotLeft, plotTop = chart.plotTop, plotWidth = chart.plotWidth, plotHeight = chart.plotHeight, plotBox = chart.plotBox, clipRect = chart.clipRect, clipBox = chart.clipBox;\n let chartBackground = chart.chartBackground, plotBackground = chart.plotBackground, plotBorder = chart.plotBorder, chartBorderWidth, mgn, bgAttr, verb = 'animate';\n // Chart area\n if (!chartBackground) {\n chart.chartBackground = chartBackground = renderer.rect()\n .addClass('highcharts-background')\n .add();\n verb = 'attr';\n }\n if (!styledMode) {\n // Presentational\n chartBorderWidth = optionsChart.borderWidth || 0;\n mgn = chartBorderWidth + (optionsChart.shadow ? 8 : 0);\n bgAttr = {\n fill: chartBackgroundColor || 'none'\n };\n if (chartBorderWidth || chartBackground['stroke-width']) { // #980\n bgAttr.stroke = optionsChart.borderColor;\n bgAttr['stroke-width'] = chartBorderWidth;\n }\n chartBackground\n .attr(bgAttr)\n .shadow(optionsChart.shadow);\n }\n else {\n chartBorderWidth = mgn = chartBackground.strokeWidth();\n }\n chartBackground[verb]({\n x: mgn / 2,\n y: mgn / 2,\n width: chartWidth - mgn - chartBorderWidth % 2,\n height: chartHeight - mgn - chartBorderWidth % 2,\n r: optionsChart.borderRadius\n });\n // Plot background\n verb = 'animate';\n if (!plotBackground) {\n verb = 'attr';\n chart.plotBackground = plotBackground = renderer.rect()\n .addClass('highcharts-plot-background')\n .add();\n }\n plotBackground[verb](plotBox);\n if (!styledMode) {\n // Presentational attributes for the background\n plotBackground\n .attr({\n fill: plotBackgroundColor || 'none'\n })\n .shadow(optionsChart.plotShadow);\n // Create the background image\n if (plotBackgroundImage) {\n if (!plotBGImage) {\n chart.plotBGImage = renderer.image(plotBackgroundImage, plotLeft, plotTop, plotWidth, plotHeight).add();\n }\n else {\n if (plotBackgroundImage !== plotBGImage.attr('href')) {\n plotBGImage.attr('href', plotBackgroundImage);\n }\n plotBGImage.animate(plotBox);\n }\n }\n }\n // Plot clip\n if (!clipRect) {\n chart.clipRect = renderer.clipRect(clipBox);\n }\n else {\n clipRect.animate({\n width: clipBox.width,\n height: clipBox.height\n });\n }\n // Plot area border\n verb = 'animate';\n if (!plotBorder) {\n verb = 'attr';\n chart.plotBorder = plotBorder = renderer.rect()\n .addClass('highcharts-plot-border')\n .attr({\n zIndex: 1 // Above the grid\n })\n .add();\n }\n if (!styledMode) {\n // Presentational\n plotBorder.attr({\n stroke: optionsChart.plotBorderColor,\n 'stroke-width': optionsChart.plotBorderWidth || 0,\n fill: 'none'\n });\n }\n plotBorder[verb](plotBorder.crisp({\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n }, -plotBorder.strokeWidth())); // #3282 plotBorder should be negative;\n // reset\n chart.isDirtyBox = false;\n fireEvent(this, 'afterDrawChartBox');\n }\n /**\n * Detect whether a certain chart property is needed based on inspecting its\n * options and series. This mainly applies to the chart.inverted property,\n * and in extensions to the chart.angular and chart.polar properties.\n *\n * @private\n * @function Highcharts.Chart#propFromSeries\n */\n propFromSeries() {\n const chart = this, optionsChart = chart.options.chart, seriesOptions = chart.options.series;\n let i, klass, value;\n /**\n * The flag is set to `true` if a series of the chart is inverted.\n *\n * @name Highcharts.Chart#inverted\n * @type {boolean|undefined}\n */\n ['inverted', 'angular', 'polar'].forEach(function (key) {\n // The default series type's class\n klass = seriesTypes[optionsChart.type];\n // Get the value from available chart-wide properties\n value =\n // It is set in the options:\n optionsChart[key] ||\n // The default series class:\n (klass && klass.prototype[key]);\n // requires it\n // 4. Check if any the chart's series require it\n i = seriesOptions && seriesOptions.length;\n while (!value && i--) {\n klass = seriesTypes[seriesOptions[i].type];\n if (klass && klass.prototype[key]) {\n value = true;\n }\n }\n // Set the chart property\n chart[key] = value;\n });\n }\n /**\n * Internal function to link two or more series together, based on the\n * `linkedTo` option. This is done from `Chart.render`, and after\n * `Chart.addSeries` and `Series.remove`.\n *\n * @private\n * @function Highcharts.Chart#linkSeries\n * @emits Highcharts.Chart#event:afterLinkSeries\n */\n linkSeries(isUpdating) {\n const chart = this, chartSeries = chart.series;\n // Reset links\n chartSeries.forEach(function (series) {\n series.linkedSeries.length = 0;\n });\n // Apply new links\n chartSeries.forEach(function (series) {\n let linkedTo = series.options.linkedTo;\n if (isString(linkedTo)) {\n if (linkedTo === ':previous') {\n linkedTo = chart.series[series.index - 1];\n }\n else {\n linkedTo = chart.get(linkedTo);\n }\n // #3341 avoid mutual linking\n if (linkedTo && linkedTo.linkedParent !== series) {\n linkedTo.linkedSeries.push(series);\n series.linkedParent = linkedTo;\n if (linkedTo.enabledDataSorting) {\n series.setDataSortingOptions();\n }\n series.visible = pick(series.options.visible, linkedTo.options.visible, series.visible); // #3879\n }\n }\n });\n fireEvent(this, 'afterLinkSeries', { isUpdating });\n }\n /**\n * Render series for the chart.\n *\n * @private\n * @function Highcharts.Chart#renderSeries\n */\n renderSeries() {\n this.series.forEach(function (serie) {\n serie.translate();\n serie.render();\n });\n }\n /**\n * Render all graphics for the chart. Runs internally on initialization.\n *\n * @private\n * @function Highcharts.Chart#render\n */\n render() {\n const chart = this, axes = chart.axes, colorAxis = chart.colorAxis, renderer = chart.renderer, renderAxes = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.render();\n }\n });\n };\n let correction = 0; // correction for X axis labels\n // Title\n chart.setTitle();\n // Fire an event before the margins are computed. This is where the\n // legend is assigned.\n fireEvent(chart, 'beforeMargins');\n // Get stacks\n if (chart.getStacks) {\n chart.getStacks();\n }\n // Get chart margins\n chart.getMargins(true);\n chart.setChartSize();\n // Record preliminary dimensions for later comparison\n const tempWidth = chart.plotWidth;\n axes.some(function (axis) {\n if (axis.horiz &&\n axis.visible &&\n axis.options.labels.enabled &&\n axis.series.length) {\n // 21 is the most common correction for X axis labels\n correction = 21;\n return true;\n }\n });\n // use Math.max to prevent negative plotHeight\n chart.plotHeight = Math.max(chart.plotHeight - correction, 0);\n const tempHeight = chart.plotHeight;\n // Get margins by pre-rendering axes\n axes.forEach(function (axis) {\n axis.setScale();\n });\n chart.getAxisMargins();\n // If the plot area size has changed significantly, calculate tick\n // positions again\n const redoHorizontal = tempWidth / chart.plotWidth > 1.1;\n // Height is more sensitive, use lower threshold\n const redoVertical = tempHeight / chart.plotHeight > 1.05;\n if (redoHorizontal || redoVertical) {\n axes.forEach(function (axis) {\n if ((axis.horiz && redoHorizontal) ||\n (!axis.horiz && redoVertical)) {\n // update to reflect the new margins\n axis.setTickInterval(true);\n }\n });\n chart.getMargins(); // second pass to check for new labels\n }\n // Draw the borders and backgrounds\n chart.drawChartBox();\n // Axes\n if (chart.hasCartesianSeries) {\n renderAxes(axes);\n }\n else if (colorAxis && colorAxis.length) {\n renderAxes(colorAxis);\n }\n // The series\n if (!chart.seriesGroup) {\n chart.seriesGroup = renderer.g('series-group')\n .attr({ zIndex: 3 })\n .shadow(chart.options.chart.seriesGroupShadow)\n .add();\n }\n chart.renderSeries();\n // Credits\n chart.addCredits();\n // Handle responsiveness\n if (chart.setResponsive) {\n chart.setResponsive();\n }\n // Set flag\n chart.hasRendered = true;\n }\n /**\n * Set a new credits label for the chart.\n *\n * @sample highcharts/credits/credits-update/\n * Add and update credits\n *\n * @function Highcharts.Chart#addCredits\n *\n * @param {Highcharts.CreditsOptions} [credits]\n * A configuration object for the new credits.\n */\n addCredits(credits) {\n const chart = this, creds = merge(true, this.options.credits, credits);\n if (creds.enabled && !this.credits) {\n /**\n * The chart's credits label. The label has an `update` method that\n * allows setting new options as per the\n * [credits options set](https://api.highcharts.com/highcharts/credits).\n *\n * @name Highcharts.Chart#credits\n * @type {Highcharts.SVGElement}\n */\n this.credits = this.renderer.text(creds.text + (this.mapCredits || ''), 0, 0)\n .addClass('highcharts-credits')\n .on('click', function () {\n if (creds.href) {\n win.location.href = creds.href;\n }\n })\n .attr({\n align: creds.position.align,\n zIndex: 8\n });\n if (!chart.styledMode) {\n this.credits.css(creds.style);\n }\n this.credits\n .add()\n .align(creds.position);\n // Dynamically update\n this.credits.update = function (options) {\n chart.credits = chart.credits.destroy();\n chart.addCredits(options);\n };\n }\n }\n /**\n * Remove the chart and purge memory. This method is called internally\n * before adding a second chart into the same container, as well as on\n * window unload to prevent leaks.\n *\n * @sample highcharts/members/chart-destroy/\n * Destroy the chart from a button\n * @sample stock/members/chart-destroy/\n * Destroy with Highcharts Stock\n *\n * @function Highcharts.Chart#destroy\n *\n * @emits Highcharts.Chart#event:destroy\n */\n destroy() {\n const chart = this, axes = chart.axes, series = chart.series, container = chart.container, parentNode = container && container.parentNode;\n let i;\n // fire the chart.destoy event\n fireEvent(chart, 'destroy');\n // Delete the chart from charts lookup array\n if (chart.renderer.forExport) {\n erase(charts, chart); // #6569\n }\n else {\n charts[chart.index] = void 0;\n }\n H.chartCount--;\n chart.renderTo.removeAttribute('data-highcharts-chart');\n // remove events\n removeEvent(chart);\n // ==== Destroy collections:\n // Destroy axes\n i = axes.length;\n while (i--) {\n axes[i] = axes[i].destroy();\n }\n // Destroy scroller & scroller series before destroying base series\n if (this.scroller && this.scroller.destroy) {\n this.scroller.destroy();\n }\n // Destroy each series\n i = series.length;\n while (i--) {\n series[i] = series[i].destroy();\n }\n // ==== Destroy chart properties:\n [\n 'title', 'subtitle', 'chartBackground', 'plotBackground',\n 'plotBGImage', 'plotBorder', 'seriesGroup', 'clipRect', 'credits',\n 'pointer', 'rangeSelector', 'legend', 'resetZoomButton', 'tooltip',\n 'renderer'\n ].forEach(function (name) {\n const prop = chart[name];\n if (prop && prop.destroy) {\n chart[name] = prop.destroy();\n }\n });\n // Remove container and all SVG, check container as it can break in IE\n // when destroyed before finished loading\n if (container) {\n container.innerHTML = AST.emptyHTML;\n removeEvent(container);\n if (parentNode) {\n discardElement(container);\n }\n }\n // clean it all up\n objectEach(chart, function (val, key) {\n delete chart[key];\n });\n }\n /**\n * Prepare for first rendering after all data are loaded.\n *\n * @private\n * @function Highcharts.Chart#firstRender\n * @emits Highcharts.Chart#event:beforeRender\n */\n firstRender() {\n const chart = this, options = chart.options;\n // Create the container\n chart.getContainer();\n chart.resetMargins();\n chart.setChartSize();\n // Set the common chart properties (mainly invert) from the given series\n chart.propFromSeries();\n // get axes\n chart.getAxes();\n // Initialize the series\n const series = isArray(options.series) ? options.series : [];\n options.series = []; // Avoid mutation\n series.forEach(\n // #9680\n function (serieOptions) {\n chart.initSeries(serieOptions);\n });\n chart.linkSeries();\n chart.setSeriesData();\n // Run an event after axes and series are initialized, but before\n // render. At this stage, the series data is indexed and cached in the\n // xData and yData arrays, so we can access those before rendering. Used\n // in Highcharts Stock.\n fireEvent(chart, 'beforeRender');\n chart.render();\n chart.pointer.getChartPosition(); // #14973\n // Fire the load event if there are no external images\n if (!chart.renderer.imgCount && !chart.hasLoaded) {\n chart.onload();\n }\n // If the chart was rendered outside the top container, put it back in\n // (#3679)\n chart.temporaryDisplay(true);\n }\n /**\n * Internal function that runs on chart load, async if any images are loaded\n * in the chart. Runs the callbacks and triggers the `load` and `render`\n * events.\n *\n * @private\n * @function Highcharts.Chart#onload\n * @emits Highcharts.Chart#event:load\n * @emits Highcharts.Chart#event:render\n */\n onload() {\n // Run callbacks, first the ones registered by modules, then user's one\n this.callbacks.concat([this.callback]).forEach(function (fn) {\n // Chart destroyed in its own callback (#3600)\n if (fn && typeof this.index !== 'undefined') {\n fn.apply(this, [this]);\n }\n }, this);\n fireEvent(this, 'load');\n fireEvent(this, 'render');\n // Set up auto resize, check for not destroyed (#6068)\n if (defined(this.index)) {\n this.setReflow();\n }\n this.warnIfA11yModuleNotLoaded();\n // Don't run again\n this.hasLoaded = true;\n }\n /**\n * Emit console warning if the a11y module is not loaded.\n */\n warnIfA11yModuleNotLoaded() {\n const { options, title } = this;\n if (options && !this.accessibility) {\n // Make chart behave as an image with the title as alt text\n this.renderer.boxWrapper.attr({\n role: 'img',\n 'aria-label': ((title && title.element.textContent) || ''\n // #17753, < is not allowed in SVG attributes\n ).replace(/} [animation]\n * Whether to apply animation, and optionally animation\n * configuration. When `undefined`, it applies the animation that is\n * set in the `chart.animation` option.\n *\n * @return {Highcharts.Series}\n * The newly created series object.\n *\n * @emits Highcharts.Chart#event:addSeries\n * @emits Highcharts.Chart#event:afterAddSeries\n */\n addSeries(options, redraw, animation) {\n const chart = this;\n let series;\n if (options) { // <- not necessary\n redraw = pick(redraw, true); // defaults to true\n fireEvent(chart, 'addSeries', { options: options }, function () {\n series = chart.initSeries(options);\n chart.isDirtyLegend = true;\n chart.linkSeries();\n if (series.enabledDataSorting) {\n // We need to call `setData` after `linkSeries`\n series.setData(options.data, false);\n }\n fireEvent(chart, 'afterAddSeries', { series: series });\n if (redraw) {\n chart.redraw(animation);\n }\n });\n }\n return series;\n }\n /**\n * Add an axis to the chart after render time. Note that this method should\n * never be used when adding data synchronously at chart render time, as it\n * adds expense to the calculations and rendering. When adding data at the\n * same time as the chart is initialized, add the axis as a configuration\n * option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addAxis\n *\n * @param {Highcharts.AxisOptions} options\n * The axis options.\n *\n * @param {boolean} [isX=false]\n * Whether it is an X axis or a value axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation in the redraw. When\n * `undefined`, it applies the animation that is set in the\n * `chart.animation` option.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n addAxis(options, isX, redraw, animation) {\n return this.createAxis(isX ? 'xAxis' : 'yAxis', { axis: options, redraw: redraw, animation: animation });\n }\n /**\n * Add a color axis to the chart after render time. Note that this method\n * should never be used when adding data synchronously at chart render time,\n * as it adds expense to the calculations and rendering. When adding data at\n * the same time as the chart is initialized, add the axis as a\n * configuration option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addColorAxis\n *\n * @param {Highcharts.ColorAxisOptions} options\n * The axis options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation in the redraw. When\n * `undefined`, it applies the animation that is set in the\n * `chart.animation` option.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n addColorAxis(options, redraw, animation) {\n return this.createAxis('colorAxis', { axis: options, redraw: redraw, animation: animation });\n }\n /**\n * Factory for creating different axis types.\n *\n * @private\n * @function Highcharts.Chart#createAxis\n *\n * @param {string} coll\n * An axis type.\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n createAxis(coll, options) {\n const axis = new Axis(this, options.axis, coll);\n if (pick(options.redraw, true)) {\n this.redraw(options.animation);\n }\n return axis;\n }\n /**\n * Dim the chart and show a loading text or symbol. Options for the loading\n * screen are defined in {@link\n * https://api.highcharts.com/highcharts/loading|the loading options}.\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample highcharts/members/chart-showloading/\n * Apply different text labels\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#showLoading\n *\n * @param {string} [str]\n * An optional text to show in the loading label instead of the\n * default one. The default text is set in\n * [lang.loading](https://api.highcharts.com/highcharts/lang.loading).\n */\n showLoading(str) {\n const chart = this, options = chart.options, loadingOptions = options.loading, setLoadingSize = function () {\n if (loadingDiv) {\n css(loadingDiv, {\n left: chart.plotLeft + 'px',\n top: chart.plotTop + 'px',\n width: chart.plotWidth + 'px',\n height: chart.plotHeight + 'px'\n });\n }\n };\n let loadingDiv = chart.loadingDiv, loadingSpan = chart.loadingSpan;\n // create the layer at the first call\n if (!loadingDiv) {\n chart.loadingDiv = loadingDiv = createElement('div', {\n className: 'highcharts-loading highcharts-loading-hidden'\n }, null, chart.container);\n }\n if (!loadingSpan) {\n chart.loadingSpan = loadingSpan = createElement('span', { className: 'highcharts-loading-inner' }, null, loadingDiv);\n addEvent(chart, 'redraw', setLoadingSize); // #1080\n }\n loadingDiv.className = 'highcharts-loading';\n // Update text\n AST.setElementHTML(loadingSpan, pick(str, options.lang.loading, ''));\n if (!chart.styledMode) {\n // Update visuals\n css(loadingDiv, extend(loadingOptions.style, {\n zIndex: 10\n }));\n css(loadingSpan, loadingOptions.labelStyle);\n // Show it\n if (!chart.loadingShown) {\n css(loadingDiv, {\n opacity: 0,\n display: ''\n });\n animate(loadingDiv, {\n opacity: loadingOptions.style.opacity || 0.5\n }, {\n duration: loadingOptions.showDuration || 0\n });\n }\n }\n chart.loadingShown = true;\n setLoadingSize();\n }\n /**\n * Hide the loading layer.\n *\n * @see Highcharts.Chart#showLoading\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#hideLoading\n */\n hideLoading() {\n const options = this.options, loadingDiv = this.loadingDiv;\n if (loadingDiv) {\n loadingDiv.className =\n 'highcharts-loading highcharts-loading-hidden';\n if (!this.styledMode) {\n animate(loadingDiv, {\n opacity: 0\n }, {\n duration: options.loading.hideDuration || 100,\n complete: function () {\n css(loadingDiv, { display: 'none' });\n }\n });\n }\n }\n this.loadingShown = false;\n }\n /**\n * A generic function to update any element of the chart. Elements can be\n * enabled and disabled, moved, re-styled, re-formatted etc.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](https://api.highcharts.com/highcharts/xAxis),\n * [yAxis](https://api.highcharts.com/highcharts/yAxis) or\n * [series](https://api.highcharts.com/highcharts/series). For these\n * collections, an `id` option is used to map the new option set to an\n * existing object. If an existing object of the same id is not found, the\n * corresponding item is updated. So for example, running `chart.update`\n * with a series item without an id, will cause the existing chart's series\n * with the same index in the series array to be updated. When the\n * `oneToOne` parameter is true, `chart.update` will also take care of\n * adding and removing items from the collection. Read more under the\n * parameter description below.\n *\n * Note that when changing series data, `chart.update` may mutate the passed\n * data options.\n *\n * See also the\n * [responsive option set](https://api.highcharts.com/highcharts/responsive).\n * Switching between `responsive.rules` basically runs `chart.update` under\n * the hood.\n *\n * @sample highcharts/members/chart-update/\n * Update chart geometry\n *\n * @function Highcharts.Chart#update\n *\n * @param {Highcharts.Options} options\n * A configuration object for the new chart options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n *\n * @param {boolean} [oneToOne=false]\n * When `true`, the `series`, `xAxis`, `yAxis` and `annotations`\n * collections will be updated one to one, and items will be either\n * added or removed to match the new updated options. For example,\n * if the chart has two series and we call `chart.update` with a\n * configuration containing three series, one will be added. If we\n * call `chart.update` with one series, one will be removed. Setting\n * an empty `series` array will remove all series, but leaving out\n * the`series` property will leave all series untouched. If the\n * series have id's, the new series options will be matched by id,\n * and the remaining ones removed.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration. When `undefined`, it applies the animation that is\n * set in the `chart.animation` option.\n *\n * @emits Highcharts.Chart#event:update\n * @emits Highcharts.Chart#event:afterUpdate\n */\n update(options, redraw, oneToOne, animation) {\n const chart = this, adders = {\n credits: 'addCredits',\n title: 'setTitle',\n subtitle: 'setSubtitle',\n caption: 'setCaption'\n }, isResponsiveOptions = options.isResponsiveOptions, itemsForRemoval = [];\n let updateAllAxes, updateAllSeries, runSetSize;\n fireEvent(chart, 'update', { options: options });\n // If there are responsive rules in action, undo the responsive rules\n // before we apply the updated options and replay the responsive rules\n // on top from the chart.redraw function (#9617).\n if (!isResponsiveOptions) {\n chart.setResponsive(false, true);\n }\n options = diffObjects(options, chart.options);\n chart.userOptions = merge(chart.userOptions, options);\n // If the top-level chart option is present, some special updates are\n // required\n const optionsChart = options.chart;\n if (optionsChart) {\n merge(true, chart.options.chart, optionsChart);\n // Add support for deprecated zooming options like zoomType, #17861\n this.setZoomOptions();\n // Setter function\n if ('className' in optionsChart) {\n chart.setClassName(optionsChart.className);\n }\n if ('inverted' in optionsChart ||\n 'polar' in optionsChart ||\n 'type' in optionsChart) {\n // Parse options.chart.inverted and options.chart.polar together\n // with the available series.\n chart.propFromSeries();\n updateAllAxes = true;\n }\n if ('alignTicks' in optionsChart) { // #6452\n updateAllAxes = true;\n }\n if ('events' in optionsChart) {\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n }\n objectEach(optionsChart, function (val, key) {\n if (chart.propsRequireUpdateSeries.indexOf('chart.' + key) !==\n -1) {\n updateAllSeries = true;\n }\n // Only dirty box\n if (chart.propsRequireDirtyBox.indexOf(key) !== -1) {\n chart.isDirtyBox = true;\n }\n // Chart setSize\n if (chart.propsRequireReflow.indexOf(key) !== -1) {\n if (isResponsiveOptions) {\n chart.isDirtyBox = true;\n }\n else {\n runSetSize = true;\n }\n }\n });\n if (!chart.styledMode && optionsChart.style) {\n chart.renderer.setStyle(chart.options.chart.style || {});\n }\n }\n // Moved up, because tooltip needs updated plotOptions (#6218)\n if (!chart.styledMode && options.colors) {\n this.options.colors = options.colors;\n }\n if (options.time) {\n // Maintaining legacy global time. If the chart is instanciated\n // first with global time, then updated with time options, we need\n // to create a new Time instance to avoid mutating the global time\n // (#10536).\n if (this.time === defaultTime) {\n this.time = new Time(options.time);\n }\n // If we're updating, the time class is different from other chart\n // classes (chart.legend, chart.tooltip etc) in that it doesn't know\n // about the chart. The other chart[something].update functions also\n // set the chart.options[something]. For the time class however we\n // need to update the chart options separately. #14230.\n merge(true, chart.options.time, options.time);\n }\n // Some option stuctures correspond one-to-one to chart objects that\n // have update methods, for example\n // options.credits => chart.credits\n // options.legend => chart.legend\n // options.title => chart.title\n // options.tooltip => chart.tooltip\n // options.subtitle => chart.subtitle\n // options.mapNavigation => chart.mapNavigation\n // options.navigator => chart.navigator\n // options.scrollbar => chart.scrollbar\n objectEach(options, function (val, key) {\n if (chart[key] &&\n typeof chart[key].update === 'function') {\n chart[key].update(val, false);\n // If a one-to-one object does not exist, look for an adder function\n }\n else if (typeof chart[adders[key]] === 'function') {\n chart[adders[key]](val);\n // Else, just merge the options. For nodes like loading, noData,\n // plotOptions\n }\n else if (key !== 'colors' &&\n chart.collectionsWithUpdate.indexOf(key) === -1) {\n merge(true, chart.options[key], options[key]);\n }\n if (key !== 'chart' &&\n chart.propsRequireUpdateSeries.indexOf(key) !== -1) {\n updateAllSeries = true;\n }\n });\n // Setters for collections. For axes and series, each item is referred\n // by an id. If the id is not found, it defaults to the corresponding\n // item in the collection, so setting one series without an id, will\n // update the first series in the chart. Setting two series without\n // an id will update the first and the second respectively (#6019)\n // chart.update and responsive.\n this.collectionsWithUpdate.forEach(function (coll) {\n if (options[coll]) {\n splat(options[coll]).forEach(function (newOptions, i) {\n const hasId = defined(newOptions.id);\n let item;\n // Match by id\n if (hasId) {\n item = chart.get(newOptions.id);\n }\n // No match by id found, match by index instead\n if (!item && chart[coll]) {\n item = chart[coll][pick(newOptions.index, i)];\n // Check if we grabbed an item with an exising but\n // different id (#13541). Check that the item in this\n // position is not internal (navigator).\n if (item && ((hasId && defined(item.options.id)) ||\n item.options.isInternal)) {\n item = void 0;\n }\n }\n if (item && item.coll === coll) {\n item.update(newOptions, false);\n if (oneToOne) {\n item.touched = true;\n }\n }\n // If oneToOne and no matching item is found, add one\n if (!item && oneToOne && chart.collectionsWithInit[coll]) {\n chart.collectionsWithInit[coll][0].apply(chart, \n // [newOptions, ...extraArguments, redraw=false]\n [\n newOptions\n ].concat(\n // Not all initializers require extra args\n chart.collectionsWithInit[coll][1] || []).concat([\n false\n ])).touched = true;\n }\n });\n // Add items for removal\n if (oneToOne) {\n chart[coll].forEach(function (item) {\n if (!item.touched && !item.options.isInternal) {\n itemsForRemoval.push(item);\n }\n else {\n delete item.touched;\n }\n });\n }\n }\n });\n itemsForRemoval.forEach(function (item) {\n if (item.chart && item.remove) { // #9097, avoid removing twice\n item.remove(false);\n }\n });\n if (updateAllAxes) {\n chart.axes.forEach(function (axis) {\n axis.update({}, false);\n });\n }\n // Certain options require the whole series structure to be thrown away\n // and rebuilt\n if (updateAllSeries) {\n chart.getSeriesOrderByLinks().forEach(function (series) {\n // Avoid removed navigator series\n if (series.chart) {\n series.update({}, false);\n }\n }, this);\n }\n // Update size. Redraw is forced.\n const newWidth = optionsChart && optionsChart.width;\n const newHeight = optionsChart && (isString(optionsChart.height) ?\n relativeLength(optionsChart.height, newWidth || chart.chartWidth) :\n optionsChart.height);\n if (\n // In this case, run chart.setSize with newWidth and newHeight which\n // are undefined, only for reflowing chart elements because margin\n // or spacing has been set (#8190)\n runSetSize ||\n // In this case, the size is actually set\n (isNumber(newWidth) && newWidth !== chart.chartWidth) ||\n (isNumber(newHeight) && newHeight !== chart.chartHeight)) {\n chart.setSize(newWidth, newHeight, animation);\n }\n else if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n fireEvent(chart, 'afterUpdate', {\n options: options,\n redraw: redraw,\n animation: animation\n });\n }\n /**\n * Shortcut to set the subtitle options. This can also be done from {@link\n * Chart#update} or {@link Chart#setTitle}.\n *\n * @function Highcharts.Chart#setSubtitle\n *\n * @param {Highcharts.SubtitleOptions} options\n * New subtitle options. The subtitle text itself is set by the\n * `options.text` property.\n */\n setSubtitle(options, redraw) {\n this.applyDescription('subtitle', options);\n this.layOutTitles(redraw);\n }\n /**\n * Set the caption options. This can also be done from {@link\n * Chart#update}.\n *\n * @function Highcharts.Chart#setCaption\n *\n * @param {Highcharts.CaptionOptions} options\n * New caption options. The caption text itself is set by the\n * `options.text` property.\n */\n setCaption(options, redraw) {\n this.applyDescription('caption', options);\n this.layOutTitles(redraw);\n }\n /**\n * Display the zoom button, so users can reset zoom to the default view\n * settings.\n *\n * @function Highcharts.Chart#showResetZoom\n *\n * @emits Highcharts.Chart#event:afterShowResetZoom\n * @emits Highcharts.Chart#event:beforeShowResetZoom\n */\n showResetZoom() {\n const chart = this, lang = defaultOptions.lang, btnOptions = chart.zooming.resetButton, theme = btnOptions.theme, alignTo = (btnOptions.relativeTo === 'chart' ||\n btnOptions.relativeTo === 'spacingBox' ?\n null :\n 'scrollablePlotBox');\n /**\n * @private\n */\n function zoomOut() {\n chart.zoomOut();\n }\n fireEvent(this, 'beforeShowResetZoom', null, function () {\n chart.resetZoomButton = chart.renderer\n .button(lang.resetZoom, null, null, zoomOut, theme)\n .attr({\n align: btnOptions.position.align,\n title: lang.resetZoomTitle\n })\n .addClass('highcharts-reset-zoom')\n .add()\n .align(btnOptions.position, false, alignTo);\n });\n fireEvent(this, 'afterShowResetZoom');\n }\n /**\n * Zoom the chart out after a user has zoomed in. See also\n * [Axis.setExtremes](/class-reference/Highcharts.Axis#setExtremes).\n *\n * @function Highcharts.Chart#zoomOut\n *\n * @emits Highcharts.Chart#event:selection\n */\n zoomOut() {\n fireEvent(this, 'selection', { resetSelection: true }, this.zoom);\n }\n /**\n * Zoom into a given portion of the chart given by axis coordinates.\n *\n * @private\n * @function Highcharts.Chart#zoom\n * @param {Highcharts.SelectEventObject} event\n */\n zoom(event) {\n const chart = this, pointer = chart.pointer;\n let displayButton = false, hasZoomed;\n // If zoom is called with no arguments, reset the axes\n if (!event || event.resetSelection) {\n chart.axes.forEach(function (axis) {\n hasZoomed = axis.zoom();\n });\n pointer.initiated = false; // #6804\n }\n else { // else, zoom in on all axes\n event.xAxis.concat(event.yAxis).forEach(function (axisData) {\n const axis = axisData.axis, isXAxis = axis.isXAxis;\n // don't zoom more than minRange\n if (pointer[isXAxis ? 'zoomX' : 'zoomY'] &&\n (defined(pointer.mouseDownX) &&\n defined(pointer.mouseDownY) &&\n chart.isInsidePlot(pointer.mouseDownX - chart.plotLeft, pointer.mouseDownY - chart.plotTop, { axis })) || !defined(chart.inverted ? pointer.mouseDownX : pointer.mouseDownY)) {\n hasZoomed = axis.zoom(axisData.min, axisData.max);\n if (axis.displayBtn) {\n displayButton = true;\n }\n }\n });\n }\n // Show or hide the Reset zoom button\n const resetZoomButton = chart.resetZoomButton;\n if (displayButton && !resetZoomButton) {\n chart.showResetZoom();\n }\n else if (!displayButton && isObject(resetZoomButton)) {\n chart.resetZoomButton = resetZoomButton.destroy();\n }\n // Redraw\n if (hasZoomed) {\n chart.redraw(pick(chart.options.chart.animation, event && event.animation, chart.pointCount < 100));\n }\n }\n /**\n * Pan the chart by dragging the mouse across the pane. This function is\n * called on mouse move, and the distance to pan is computed from chartX\n * compared to the first chartX position in the dragging operation.\n *\n * @private\n * @function Highcharts.Chart#pan\n * @param {Highcharts.PointerEventObject} e\n * @param {string} panning\n */\n pan(e, panning) {\n const chart = this, hoverPoints = chart.hoverPoints, panningOptions = (typeof panning === 'object' ?\n panning :\n {\n enabled: panning,\n type: 'x'\n }), chartOptions = chart.options.chart;\n if (chartOptions && chartOptions.panning) {\n chartOptions.panning = panningOptions;\n }\n const type = panningOptions.type;\n let doRedraw;\n fireEvent(this, 'pan', { originalEvent: e }, function () {\n // remove active points for shared tooltip\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n let axes = chart.xAxis;\n if (type === 'xy') {\n axes = axes.concat(chart.yAxis);\n }\n else if (type === 'y') {\n axes = chart.yAxis;\n }\n const nextMousePos = {};\n axes.forEach(function (axis) {\n if (!axis.options.panningEnabled || axis.options.isInternal) {\n return;\n }\n const horiz = axis.horiz, mousePos = e[horiz ? 'chartX' : 'chartY'], mouseDown = horiz ? 'mouseDownX' : 'mouseDownY', startPos = chart[mouseDown], halfPointRange = axis.minPointOffset || 0, pointRangeDirection = (axis.reversed && !chart.inverted) ||\n (!axis.reversed && chart.inverted) ?\n -1 :\n 1, extremes = axis.getExtremes(), panMin = axis.toValue(startPos - mousePos, true) +\n halfPointRange * pointRangeDirection, panMax = axis.toValue(startPos + axis.len - mousePos, true) -\n ((halfPointRange * pointRangeDirection) ||\n (axis.isXAxis && axis.pointRangePadding) ||\n 0), flipped = panMax < panMin, hasVerticalPanning = axis.hasVerticalPanning();\n let newMin = flipped ? panMax : panMin, newMax = flipped ? panMin : panMax, panningState = axis.panningState, spill;\n // General calculations of panning state.\n // This is related to using vertical panning. (#11315).\n if (hasVerticalPanning &&\n !axis.isXAxis && (!panningState || panningState.isDirty)) {\n axis.series.forEach(function (series) {\n const processedData = series.getProcessedData(true), dataExtremes = series.getExtremes(processedData.yData, true);\n if (!panningState) {\n panningState = {\n startMin: Number.MAX_VALUE,\n startMax: -Number.MAX_VALUE\n };\n }\n if (isNumber(dataExtremes.dataMin) &&\n isNumber(dataExtremes.dataMax)) {\n panningState.startMin = Math.min(pick(series.options.threshold, Infinity), dataExtremes.dataMin, panningState.startMin);\n panningState.startMax = Math.max(pick(series.options.threshold, -Infinity), dataExtremes.dataMax, panningState.startMax);\n }\n });\n }\n const paddedMin = Math.min(pick(panningState && panningState.startMin, extremes.dataMin), halfPointRange ?\n extremes.min :\n axis.toValue(axis.toPixels(extremes.min) -\n axis.minPixelPadding));\n const paddedMax = Math.max(pick(panningState && panningState.startMax, extremes.dataMax), halfPointRange ?\n extremes.max :\n axis.toValue(axis.toPixels(extremes.max) +\n axis.minPixelPadding));\n axis.panningState = panningState;\n // It is not necessary to calculate extremes on ordinal axis,\n // because they are already calculated, so we don't want to\n // override them.\n if (!axis.isOrdinal) {\n // If the new range spills over, either to the min or max,\n // adjust the new range.\n spill = paddedMin - newMin;\n if (spill > 0) {\n newMax += spill;\n newMin = paddedMin;\n }\n spill = newMax - paddedMax;\n if (spill > 0) {\n newMax = paddedMax;\n newMin -= spill;\n }\n // Set new extremes if they are actually new\n if (axis.series.length &&\n newMin !== extremes.min &&\n newMax !== extremes.max &&\n newMin >= paddedMin &&\n newMax <= paddedMax) {\n axis.setExtremes(newMin, newMax, false, false, { trigger: 'pan' });\n if (!chart.resetZoomButton &&\n // Show reset zoom button only when both newMin and\n // newMax values are between padded axis range.\n newMin !== paddedMin &&\n newMax !== paddedMax &&\n type.match('y')) {\n chart.showResetZoom();\n axis.displayBtn = false;\n }\n doRedraw = true;\n }\n // set new reference for next run:\n nextMousePos[mouseDown] = mousePos;\n }\n });\n objectEach(nextMousePos, (pos, down) => {\n chart[down] = pos;\n });\n if (doRedraw) {\n chart.redraw(false);\n }\n css(chart.container, { cursor: 'move' });\n });\n }\n }\n extend(Chart.prototype, {\n // Hook for adding callbacks in modules\n callbacks: [],\n /**\n * These collections (arrays) implement `Chart.addSomethig` method used in\n * chart.update() to create new object in the collection. Equivalent for\n * deleting is resolved by simple `Somethig.remove()`.\n *\n * Note: We need to define these references after initializers are bound to\n * chart's prototype.\n *\n * @private\n */\n collectionsWithInit: {\n // collectionName: [ initializingMethod, [extraArguments] ]\n xAxis: [Chart.prototype.addAxis, [true]],\n yAxis: [Chart.prototype.addAxis, [false]],\n series: [Chart.prototype.addSeries]\n },\n /**\n * These collections (arrays) implement update() methods with support for\n * one-to-one option.\n * @private\n */\n collectionsWithUpdate: [\n 'xAxis',\n 'yAxis',\n 'series'\n ],\n /**\n * These properties cause isDirtyBox to be set to true when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireDirtyBox: [\n 'backgroundColor',\n 'borderColor',\n 'borderWidth',\n 'borderRadius',\n 'plotBackgroundColor',\n 'plotBackgroundImage',\n 'plotBorderColor',\n 'plotBorderWidth',\n 'plotShadow',\n 'shadow'\n ],\n /**\n * These properties require a full reflow of chart elements, best\n * implemented through running `Chart.setSize` internally (#8190).\n * @private\n */\n propsRequireReflow: [\n 'margin',\n 'marginTop',\n 'marginRight',\n 'marginBottom',\n 'marginLeft',\n 'spacing',\n 'spacingTop',\n 'spacingRight',\n 'spacingBottom',\n 'spacingLeft'\n ],\n /**\n * These properties cause all series to be updated when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireUpdateSeries: [\n 'chart.inverted',\n 'chart.polar',\n 'chart.ignoreHiddenSeries',\n 'chart.type',\n 'colors',\n 'plotOptions',\n 'time',\n 'tooltip'\n ]\n });\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback for chart constructors.\n *\n * @callback Highcharts.ChartCallbackFunction\n *\n * @param {Highcharts.Chart} chart\n * Created chart.\n */\n /**\n * Format a number and return a string based on input settings.\n *\n * @callback Highcharts.NumberFormatterCallbackFunction\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string} The formatted number.\n */\n /**\n * The chart title. The title has an `update` method that allows modifying the\n * options directly or indirectly via `chart.update`.\n *\n * @interface Highcharts.TitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the title.\n *\n * @function Highcharts.TitleObject#update\n *\n * @param {Highcharts.TitleOptions} titleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the title is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.SubtitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the subtitle.\n *\n * @function Highcharts.SubtitleObject#update\n *\n * @param {Highcharts.SubtitleOptions} subtitleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the subtitle is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * The chart caption. The caption has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.CaptionObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the caption.\n *\n * @function Highcharts.CaptionObject#update\n *\n * @param {Highcharts.CaptionOptions} captionOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the caption is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * @interface Highcharts.ChartIsInsideOptionsObject\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#axis\n * @type {Highcharts.Axis|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreX\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreY\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#paneCoordinates\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#series\n * @type {Highcharts.Series|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#visiblePlotOnly\n * @type {boolean|undefined}\n */\n ''; // keeps doclets above in JS file\n\n return Chart;\n });\n _registerModule(_modules, 'Extensions/ScrollablePlotArea.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Series/Series.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (A, Axis, Chart, Series, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * Highcharts feature to make the Y axis stay fixed when scrolling the chart\n * horizontally on mobile devices. Supports left and right side axes.\n */\n /*\n WIP on vertical scrollable plot area (#9378). To do:\n - Bottom axis positioning\n - Test with Gantt\n - Look for size optimizing the code\n - API and demos\n */\n const { stop } = A;\n const { addEvent, createElement, defined, merge, pick } = U;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n addEvent(Chart, 'afterSetChartSize', function (e) {\n let scrollablePlotArea = this.options.chart.scrollablePlotArea, scrollableMinWidth = scrollablePlotArea && scrollablePlotArea.minWidth, scrollableMinHeight = scrollablePlotArea && scrollablePlotArea.minHeight, scrollablePixelsX, scrollablePixelsY, corrections;\n if (!this.renderer.forExport) {\n // The amount of pixels to scroll, the difference between chart\n // width and scrollable width\n if (scrollableMinWidth) {\n this.scrollablePixelsX = scrollablePixelsX = Math.max(0, scrollableMinWidth - this.chartWidth);\n if (scrollablePixelsX) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.width = this.plotWidth += scrollablePixelsX;\n if (this.inverted) {\n this.clipBox.height += scrollablePixelsX;\n }\n else {\n this.clipBox.width += scrollablePixelsX;\n }\n corrections = {\n // Corrections for right side\n 1: { name: 'right', value: scrollablePixelsX }\n };\n }\n // Currently we can only do either X or Y\n }\n else if (scrollableMinHeight) {\n this.scrollablePixelsY = scrollablePixelsY = Math.max(0, scrollableMinHeight - this.chartHeight);\n if (defined(scrollablePixelsY)) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.height = this.plotHeight += scrollablePixelsY;\n if (this.inverted) {\n this.clipBox.width += scrollablePixelsY;\n }\n else {\n this.clipBox.height += scrollablePixelsY;\n }\n corrections = {\n 2: { name: 'bottom', value: scrollablePixelsY }\n };\n }\n }\n if (corrections && !e.skipAxes) {\n this.axes.forEach(function (axis) {\n // For right and bottom axes, only fix the plot line length\n if (corrections[axis.side]) {\n // Get the plot lines right in getPlotLinePath,\n // temporarily set it to the adjusted plot width.\n axis.getPlotLinePath = function () {\n let marginName = corrections[axis.side].name, correctionValue = corrections[axis.side].value, \n // axis.right or axis.bottom\n margin = this[marginName], path;\n // Temporarily adjust\n this[marginName] = margin - correctionValue;\n path = Axis.prototype.getPlotLinePath.apply(this, arguments);\n // Reset\n this[marginName] = margin;\n return path;\n };\n }\n else {\n // Apply the corrected plotWidth\n axis.setAxisSize();\n axis.setAxisTranslation();\n }\n });\n }\n }\n });\n addEvent(Chart, 'render', function () {\n if (this.scrollablePixelsX || this.scrollablePixelsY) {\n if (this.setUpScrolling) {\n this.setUpScrolling();\n }\n this.applyFixed();\n }\n else if (this.fixedDiv) { // Has been in scrollable mode\n this.applyFixed();\n }\n });\n /**\n * @private\n * @function Highcharts.Chart#setUpScrolling\n * @return {void}\n */\n Chart.prototype.setUpScrolling = function () {\n const css = {\n WebkitOverflowScrolling: 'touch',\n overflowX: 'hidden',\n overflowY: 'hidden'\n };\n if (this.scrollablePixelsX) {\n css.overflowX = 'auto';\n }\n if (this.scrollablePixelsY) {\n css.overflowY = 'auto';\n }\n // Insert a container with position relative\n // that scrolling and fixed container renders to (#10555)\n this.scrollingParent = createElement('div', {\n className: 'highcharts-scrolling-parent'\n }, {\n position: 'relative'\n }, this.renderTo);\n // Add the necessary divs to provide scrolling\n this.scrollingContainer = createElement('div', {\n 'className': 'highcharts-scrolling'\n }, css, this.scrollingParent);\n // On scroll, reset the chart position because it applies to the scrolled\n // container\n let lastHoverPoint;\n addEvent(this.scrollingContainer, 'scroll', () => {\n if (this.pointer) {\n delete this.pointer.chartPosition;\n if (this.hoverPoint) {\n lastHoverPoint = this.hoverPoint;\n }\n this.pointer.runPointActions(void 0, lastHoverPoint, true);\n }\n });\n this.innerContainer = createElement('div', {\n 'className': 'highcharts-inner-container'\n }, null, this.scrollingContainer);\n // Now move the container inside\n this.innerContainer.appendChild(this.container);\n // Don't run again\n this.setUpScrolling = null;\n };\n /**\n * These elements are moved over to the fixed renderer and stay fixed when the\n * user scrolls the chart\n * @private\n */\n Chart.prototype.moveFixedElements = function () {\n let container = this.container, fixedRenderer = this.fixedRenderer, fixedSelectors = [\n '.highcharts-breadcrumbs-group',\n '.highcharts-contextbutton',\n '.highcharts-credits',\n '.highcharts-legend',\n '.highcharts-legend-checkbox',\n '.highcharts-navigator-series',\n '.highcharts-navigator-xaxis',\n '.highcharts-navigator-yaxis',\n '.highcharts-navigator',\n '.highcharts-reset-zoom',\n '.highcharts-drillup-button',\n '.highcharts-scrollbar',\n '.highcharts-subtitle',\n '.highcharts-title'\n ], axisClass;\n if (this.scrollablePixelsX && !this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n else if (this.scrollablePixelsX && this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && !this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n if (axisClass) {\n fixedSelectors.push(`${axisClass}:not(.highcharts-radial-axis)`, `${axisClass}-labels:not(.highcharts-radial-axis-labels)`);\n }\n fixedSelectors.forEach(function (className) {\n [].forEach.call(container.querySelectorAll(className), function (elem) {\n (elem.namespaceURI === fixedRenderer.SVG_NS ?\n fixedRenderer.box :\n fixedRenderer.box.parentNode).appendChild(elem);\n elem.style.pointerEvents = 'auto';\n });\n });\n };\n /**\n * @private\n * @function Highcharts.Chart#applyFixed\n * @return {void}\n */\n Chart.prototype.applyFixed = function () {\n const firstTime = !this.fixedDiv, chartOptions = this.options.chart, scrollableOptions = chartOptions.scrollablePlotArea, Renderer = RendererRegistry.getRendererType();\n let fixedRenderer, scrollableWidth, scrollableHeight;\n // First render\n if (firstTime) {\n this.fixedDiv = createElement('div', {\n className: 'highcharts-fixed'\n }, {\n position: 'absolute',\n overflow: 'hidden',\n pointerEvents: 'none',\n zIndex: (chartOptions.style && chartOptions.style.zIndex || 0) + 2,\n top: 0\n }, null, true);\n if (this.scrollingContainer) {\n this.scrollingContainer.parentNode.insertBefore(this.fixedDiv, this.scrollingContainer);\n }\n this.renderTo.style.overflow = 'visible';\n this.fixedRenderer = fixedRenderer = new Renderer(this.fixedDiv, this.chartWidth, this.chartHeight, this.options.chart.style);\n // Mask\n this.scrollableMask = fixedRenderer\n .path()\n .attr({\n fill: this.options.chart.backgroundColor || '#fff',\n 'fill-opacity': pick(scrollableOptions.opacity, 0.85),\n zIndex: -1\n })\n .addClass('highcharts-scrollable-mask')\n .add();\n addEvent(this, 'afterShowResetZoom', this.moveFixedElements);\n addEvent(this, 'afterApplyDrilldown', this.moveFixedElements);\n addEvent(this, 'afterLayOutTitles', this.moveFixedElements);\n }\n else {\n // Set the size of the fixed renderer to the visible width\n this.fixedRenderer.setSize(this.chartWidth, this.chartHeight);\n }\n if (this.scrollableDirty || firstTime) {\n this.scrollableDirty = false;\n this.moveFixedElements();\n }\n // Increase the size of the scrollable renderer and background\n scrollableWidth = this.chartWidth + (this.scrollablePixelsX || 0);\n scrollableHeight = this.chartHeight + (this.scrollablePixelsY || 0);\n stop(this.container);\n this.container.style.width = scrollableWidth + 'px';\n this.container.style.height = scrollableHeight + 'px';\n this.renderer.boxWrapper.attr({\n width: scrollableWidth,\n height: scrollableHeight,\n viewBox: [0, 0, scrollableWidth, scrollableHeight].join(' ')\n });\n this.chartBackground.attr({\n width: scrollableWidth,\n height: scrollableHeight\n });\n this.scrollingContainer.style.height = this.chartHeight + 'px';\n // Set scroll position\n if (firstTime) {\n if (scrollableOptions.scrollPositionX) {\n this.scrollingContainer.scrollLeft =\n this.scrollablePixelsX *\n scrollableOptions.scrollPositionX;\n }\n if (scrollableOptions.scrollPositionY) {\n this.scrollingContainer.scrollTop =\n this.scrollablePixelsY *\n scrollableOptions.scrollPositionY;\n }\n }\n // Mask behind the left and right side\n let axisOffset = this.axisOffset, maskTop = this.plotTop - axisOffset[0] - 1, maskLeft = this.plotLeft - axisOffset[3] - 1, maskBottom = this.plotTop + this.plotHeight + axisOffset[2] + 1, maskRight = this.plotLeft + this.plotWidth + axisOffset[1] + 1, maskPlotRight = this.plotLeft + this.plotWidth -\n (this.scrollablePixelsX || 0), maskPlotBottom = this.plotTop + this.plotHeight -\n (this.scrollablePixelsY || 0), d;\n if (this.scrollablePixelsX) {\n d = [\n // Left side\n ['M', 0, maskTop],\n ['L', this.plotLeft - 1, maskTop],\n ['L', this.plotLeft - 1, maskBottom],\n ['L', 0, maskBottom],\n ['Z'],\n // Right side\n ['M', maskPlotRight, maskTop],\n ['L', this.chartWidth, maskTop],\n ['L', this.chartWidth, maskBottom],\n ['L', maskPlotRight, maskBottom],\n ['Z']\n ];\n }\n else if (this.scrollablePixelsY) {\n d = [\n // Top side\n ['M', maskLeft, 0],\n ['L', maskLeft, this.plotTop - 1],\n ['L', maskRight, this.plotTop - 1],\n ['L', maskRight, 0],\n ['Z'],\n // Bottom side\n ['M', maskLeft, maskPlotBottom],\n ['L', maskLeft, this.chartHeight],\n ['L', maskRight, this.chartHeight],\n ['L', maskRight, maskPlotBottom],\n ['Z']\n ];\n }\n else {\n d = [['M', 0, 0]];\n }\n if (this.redrawTrigger !== 'adjustHeight') {\n this.scrollableMask.attr({ d });\n }\n };\n addEvent(Axis, 'afterInit', function () {\n this.chart.scrollableDirty = true;\n });\n addEvent(Series, 'show', function () {\n this.chart.scrollableDirty = true;\n });\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for a scrollable plot area. This feature provides a minimum size for\n * the plot area of the chart. If the size gets smaller than this, typically\n * on mobile devices, a native browser scrollbar is presented. This scrollbar\n * provides smooth scrolling for the contents of the plot area, whereas the\n * title, legend and unaffected axes are fixed.\n *\n * Since v7.1.2, a scrollable plot area can be defined for either horizontal or\n * vertical scrolling, depending on whether the `minWidth` or `minHeight`\n * option is set.\n *\n * @sample highcharts/chart/scrollable-plotarea\n * Scrollable plot area\n * @sample highcharts/chart/scrollable-plotarea-vertical\n * Vertically scrollable plot area\n * @sample {gantt} gantt/chart/scrollable-plotarea-vertical\n * Gantt chart with vertically scrollable plot area\n *\n * @since 6.1.0\n * @product highcharts gantt\n * @apioption chart.scrollablePlotArea\n */\n /**\n * The minimum height for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.minHeight\n */\n /**\n * The minimum width for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.minWidth\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the left and 1 aligns it to the right.\n * Typically we would use 1 if the chart has right aligned Y axes.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.scrollPositionX\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the top and 1 aligns it to the bottom.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.scrollPositionY\n */\n /**\n * The opacity of mask applied on one of the sides of the plot\n * area.\n *\n * @sample {highcharts} highcharts/chart/scrollable-plotarea-opacity\n * Disabled opacity for the mask\n *\n * @type {number}\n * @default 0.85\n * @since 7.1.1\n * @apioption chart.scrollablePlotArea.opacity\n */\n (''); // keep doclets above in transpiled file\n\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackItem.js', [_modules['Core/Templating.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (T, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = T;\n const { series: Series } = SeriesRegistry;\n const { destroyObjectProperties, fireEvent, isNumber, merge, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The class for stacks. Each stack, on a specific X value and either negative\n * or positive, has its own stack item.\n * @private\n */\n class StackItem {\n /* *\n *\n * Constructor\n *\n * */\n constructor(axis, options, negativeValue, x, stackOption) {\n const inverted = axis.chart.inverted, reversed = axis.reversed;\n this.axis = axis;\n // The stack goes to the left either if the stack has negative value\n // or when axis is reversed. XOR operator.\n const isNegative = (this.isNegative = !!negativeValue !== !!reversed);\n // Save the options to be able to style the label\n this.options = options = options || {};\n // Save the x value to be able to position the label later\n this.x = x;\n // Initialize total value\n this.total = null;\n this.cumulative = null;\n // This will keep each points' extremes stored by series.index and point\n // index\n this.points = {};\n this.hasValidPoints = false;\n // Save the stack option on the series configuration object,\n // and whether to treat it as percent\n this.stack = stackOption;\n this.leftCliff = 0;\n this.rightCliff = 0;\n // The align options and text align varies on whether the stack is\n // negative and if the chart is inverted or not.\n // First test the user supplied value, then use the dynamic.\n this.alignOptions = {\n align: options.align ||\n (inverted ? (isNegative ? 'left' : 'right') : 'center'),\n verticalAlign: options.verticalAlign ||\n (inverted ? 'middle' : isNegative ? 'bottom' : 'top'),\n y: options.y,\n x: options.x\n };\n this.textAlign =\n options.textAlign ||\n (inverted ? (!isNegative ? 'left' : 'right') : 'center');\n }\n /**\n * @private\n */\n destroy() {\n destroyObjectProperties(this, this.axis);\n }\n /**\n * Renders the stack total label and adds it to the stack label group.\n * @private\n */\n render(group) {\n const chart = this.axis.chart, options = this.options, formatOption = options.format, \n // Format the text in the label.\n str = formatOption ?\n format(formatOption, this, chart) :\n options.formatter.call(this);\n // Change the text to reflect the new total and set visibility to hidden\n // in case the serie is hidden\n if (this.label) {\n this.label.attr({ text: str, visibility: 'hidden' });\n }\n else {\n // Create new label\n this.label = chart.renderer.label(str, null, void 0, options.shape, void 0, void 0, options.useHTML, false, 'stack-labels');\n const attr = {\n r: options.borderRadius || 0,\n text: str,\n // set default padding to 5 as it is in datalabels #12308\n padding: pick(options.padding, 5),\n visibility: 'hidden' // hidden until setOffset is called\n };\n if (!chart.styledMode) {\n attr.fill = options.backgroundColor;\n attr.stroke = options.borderColor;\n attr['stroke-width'] = options.borderWidth;\n this.label.css(options.style || {});\n }\n this.label.attr(attr);\n if (!this.label.added) {\n this.label.add(group); // add to the labels-group\n }\n }\n // Rank it higher than data labels (#8742)\n this.label.labelrank = chart.plotSizeY;\n fireEvent(this, 'afterRender');\n }\n /**\n * Sets the offset that the stack has from the x value and repositions the\n * label.\n * @private\n */\n setOffset(xOffset, width, boxBottom, boxTop, defaultX, xAxis) {\n const { alignOptions, axis, label, options, textAlign } = this, chart = axis.chart, stackBox = this.getStackBox({\n xOffset,\n width,\n boxBottom,\n boxTop,\n defaultX,\n xAxis\n }), { verticalAlign } = alignOptions;\n if (label && stackBox) {\n const labelBox = label.getBBox(), padding = label.padding;\n let isJustify = pick(options.overflow, 'justify') === 'justify', visible;\n // Reset alignOptions property after justify #12337\n alignOptions.x = options.x || 0;\n alignOptions.y = options.y || 0;\n // Calculate the adjusted Stack position, to take into consideration\n // The size if the labelBox and vertical alignment as\n // well as the text alignment. It's need to be done to work with\n // default SVGLabel.align/justify methods.\n const { x, y } = this.adjustStackPosition({\n labelBox,\n verticalAlign,\n textAlign\n });\n stackBox.x -= x;\n stackBox.y -= y;\n // Align the label to the adjusted box.\n label.align(alignOptions, false, stackBox);\n // Check if label is inside the plotArea #12294\n visible = chart.isInsidePlot(label.alignAttr.x + alignOptions.x + x, label.alignAttr.y + alignOptions.y + y);\n if (!visible) {\n isJustify = false;\n }\n if (isJustify) {\n // Justify stackLabel into the alignBox\n Series.prototype.justifyDataLabel.call(axis, label, alignOptions, label.alignAttr, labelBox, stackBox);\n }\n // Add attr to aviod the default animation of justifyDataLabel.\n // Also add correct rotation with its rotation origin. #15129\n label.attr({\n x: label.alignAttr.x,\n y: label.alignAttr.y,\n rotation: options.rotation,\n rotationOriginX: labelBox.width / 2,\n rotationOriginY: labelBox.height / 2\n });\n // Check if the dataLabel should be visible.\n if (pick(!isJustify && options.crop, true)) {\n visible =\n isNumber(label.x) &&\n isNumber(label.y) &&\n chart.isInsidePlot(label.x - padding + label.width, label.y) &&\n chart.isInsidePlot(label.x + padding, label.y);\n }\n label[visible ? 'show' : 'hide']();\n }\n fireEvent(this, 'afterSetOffset', { xOffset, width });\n }\n /**\n * Adjust the stack BBox position, to take into consideration the alignment\n * of the dataLabel. This is necessary to make the stackDataLabel work with\n * core methods like `SVGLabel.adjust` and `Series.justifyDataLabel`.\n * @param AdjustStackPositionProps\n * @return {{x: number, y: number}} Adjusted BBox position of the stack.\n */\n adjustStackPosition({ labelBox, verticalAlign, textAlign }) {\n const factorMap = {\n bottom: 0,\n middle: 1,\n top: 2,\n right: 1,\n center: 0,\n left: -1\n }, verticalAlignFactor = factorMap[verticalAlign], textAlignFactor = factorMap[textAlign];\n return {\n x: labelBox.width / 2 + (labelBox.width / 2) * textAlignFactor,\n y: (labelBox.height / 2) * verticalAlignFactor\n };\n }\n /**\n * Get the bbox of the stack.\n * @private\n * @function Highcharts.StackItem#getStackBox\n * @return {BBoxObject} The x, y, height, width of the stack.\n */\n getStackBox(stackBoxProps) {\n const stackItem = this, axis = this.axis, chart = axis.chart, { boxTop, defaultX, xOffset, width, boxBottom } = stackBoxProps, totalStackValue = axis.stacking.usePercentage ?\n 100 :\n pick(boxTop, this.total, 0), y = axis.toPixels(totalStackValue), xAxis = stackBoxProps.xAxis || chart.xAxis[0], x = pick(defaultX, xAxis.translate(this.x)) + xOffset, yZero = axis.toPixels(boxBottom ||\n (isNumber(axis.min) &&\n axis.logarithmic &&\n axis.logarithmic.lin2log(axis.min)) ||\n 0), height = Math.abs(y - yZero), inverted = chart.inverted, neg = stackItem.isNegative;\n return inverted ?\n {\n x: (neg ? y : y - height) - chart.plotLeft,\n y: xAxis.height - x - width,\n width: height,\n height: width\n } : {\n x: x + xAxis.transB - chart.plotLeft,\n y: (neg ? y - height : y) - chart.plotTop,\n width: width,\n height: height\n };\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Stack of data points\n *\n * @product highcharts\n *\n * @interface Highcharts.StackItemObject\n */ /**\n * Alignment settings\n * @name Highcharts.StackItemObject#alignOptions\n * @type {Highcharts.AlignObject}\n */ /**\n * Related axis\n * @name Highcharts.StackItemObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Cumulative value of the stacked data points\n * @name Highcharts.StackItemObject#cumulative\n * @type {number}\n */ /**\n * True if on the negative side\n * @name Highcharts.StackItemObject#isNegative\n * @type {boolean}\n */ /**\n * Related SVG element\n * @name Highcharts.StackItemObject#label\n * @type {Highcharts.SVGElement}\n */ /**\n * Related stack options\n * @name Highcharts.StackItemObject#options\n * @type {Highcharts.YAxisStackLabelsOptions}\n */ /**\n * Total value of the stacked data points\n * @name Highcharts.StackItemObject#total\n * @type {number}\n */ /**\n * Shared x value of the stack\n * @name Highcharts.StackItemObject#x\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return StackItem;\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackingAxis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Utilities.js']], function (A, Axis, SeriesRegistry, StackItem, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getDeferredAnimation } = A;\n const { series: { prototype: seriesProto } } = SeriesRegistry;\n const { addEvent, correctFloat, defined, destroyObjectProperties, fireEvent, isArray, isNumber, objectEach, pick } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Generate stacks for each series and calculate stacks total values\n *\n * @private\n * @function Highcharts.Chart#getStacks\n */\n function chartGetStacks() {\n const chart = this, inverted = chart.inverted;\n // reset stacks for each yAxis\n chart.yAxis.forEach((axis) => {\n if (axis.stacking && axis.stacking.stacks && axis.hasVisibleSeries) {\n axis.stacking.oldStacks = axis.stacking.stacks;\n }\n });\n chart.series.forEach((series) => {\n const xAxisOptions = series.xAxis && series.xAxis.options || {};\n if (series.options.stacking &&\n (series.visible === true ||\n chart.options.chart.ignoreHiddenSeries === false)) {\n series.stackKey = [\n series.type,\n pick(series.options.stack, ''),\n inverted ? xAxisOptions.top : xAxisOptions.left,\n inverted ? xAxisOptions.height : xAxisOptions.width\n ].join(',');\n }\n });\n }\n /**\n * @private\n */\n function onAxisDestroy() {\n const stacking = this.stacking;\n if (!stacking) {\n return;\n }\n const stacks = stacking.stacks;\n // Destroy each stack total\n objectEach(stacks, function (stack, stackKey) {\n destroyObjectProperties(stack);\n stacks[stackKey] = null;\n });\n if (stacking &&\n stacking.stackTotalGroup) {\n stacking.stackTotalGroup.destroy();\n }\n }\n /**\n * @private\n */\n function onAxisInit() {\n if (this.coll === 'yAxis' && !this.stacking) {\n this.stacking = new AxisAdditions(this);\n }\n }\n /**\n * Get stack indicator, according to it's x-value, to determine points with the\n * same x-value\n *\n * @private\n * @function Highcharts.Series#getStackIndicator\n */\n function seriesGetStackIndicator(stackIndicator, x, index, key) {\n // Update stack indicator, when:\n // first point in a stack || x changed || stack type (negative vs positive)\n // changed:\n if (!defined(stackIndicator) ||\n stackIndicator.x !== x ||\n (key && stackIndicator.stackKey !== key)) {\n stackIndicator = {\n x: x,\n index: 0,\n key: key,\n stackKey: key\n };\n }\n else {\n (stackIndicator).index++;\n }\n stackIndicator.key =\n [index, x, stackIndicator.index].join(',');\n return stackIndicator;\n }\n /**\n * Iterate over all stacks and compute the absolute values to percent\n *\n * @private\n * @function Highcharts.Series#modifyStacks\n */\n function seriesModifyStacks() {\n const series = this, yAxis = series.yAxis, stackKey = series.stackKey, stacks = yAxis.stacking.stacks, processedXData = series.processedXData, stacking = series.options.stacking, stacker = series[stacking + 'Stacker'];\n let stackIndicator;\n if (stacker) { // Modifier function exists (Series.percentStacker etc.)\n [stackKey, '-' + stackKey].forEach((key) => {\n let i = processedXData.length, x, stack, pointExtremes;\n while (i--) {\n x = processedXData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index, key);\n stack = stacks[key] && stacks[key][x];\n pointExtremes =\n stack && stack.points[stackIndicator.key];\n if (pointExtremes) {\n stacker.call(series, pointExtremes, stack, i);\n }\n }\n });\n }\n }\n /**\n * Modifier function for percent stacks. Blows up the stack to 100%.\n *\n * @private\n * @function Highcharts.Series#percentStacker\n */\n function seriesPercentStacker(pointExtremes, stack, i) {\n const totalFactor = stack.total ? 100 / stack.total : 0;\n // Y bottom value\n pointExtremes[0] = correctFloat(pointExtremes[0] * totalFactor);\n // Y value\n pointExtremes[1] = correctFloat(pointExtremes[1] * totalFactor);\n this.stackedYData[i] = pointExtremes[1];\n }\n /**\n * Set grouped points in a stack-like object. When `centerInCategory` is true,\n * and `stacking` is not enabled, we need a pseudo (horizontal) stack in order\n * to handle grouping of points within the same category.\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n * @return {void}\n */\n function seriesSetGroupedPoints() {\n const stacking = this.yAxis.stacking;\n if (this.options.centerInCategory &&\n (this.is('column') || this.is('columnrange')) &&\n // With stacking enabled, we already have stacks that we can compute\n // from\n !this.options.stacking &&\n // With only one series, we don't need to consider centerInCategory\n this.chart.series.length > 1) {\n seriesProto.setStackedPoints.call(this, 'group');\n // After updating, if we now have proper stacks, we must delete the group\n // pseudo stacks (#14986)\n }\n else if (stacking) {\n objectEach(stacking.stacks, (type, key) => {\n if (key.slice(-5) === 'group') {\n objectEach(type, (stack) => stack.destroy());\n delete stacking.stacks[key];\n }\n });\n }\n }\n /**\n * Adds series' points value to corresponding stack\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n */\n function seriesSetStackedPoints(stackingParam) {\n const chart = this.chart, stacking = stackingParam || this.options.stacking;\n if (!stacking || (this.visible !== true &&\n chart.options.chart.ignoreHiddenSeries !== false)) {\n return;\n }\n const series = this, xData = series.processedXData, yData = series.processedYData, stackedYData = [], yDataLength = yData.length, seriesOptions = series.options, threshold = seriesOptions.threshold, stackThreshold = pick(seriesOptions.startFromThreshold && threshold, 0), stackOption = seriesOptions.stack, stackKey = stackingParam ? `${series.type},${stacking}` : series.stackKey, negKey = '-' + stackKey, negStacks = series.negStacks, yAxis = stacking === 'group' ?\n chart.yAxis[0] :\n series.yAxis, stacks = yAxis.stacking.stacks, oldStacks = yAxis.stacking.oldStacks;\n let stackIndicator, isNegative, stack, other, key, pointKey, i, x, y;\n yAxis.stacking.stacksTouched += 1;\n // loop over the non-null y values and read them into a local array\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index);\n pointKey = stackIndicator.key;\n // Read stacked values into a stack based on the x value,\n // the sign of y and the stack key. Stacking is also handled for null\n // values (#739)\n isNegative = negStacks && y < (stackThreshold ? 0 : threshold);\n key = isNegative ? negKey : stackKey;\n // Create empty object for this stack if it doesn't exist yet\n if (!stacks[key]) {\n stacks[key] = {};\n }\n // Initialize StackItem for this x\n if (!stacks[key][x]) {\n if (oldStacks[key] &&\n oldStacks[key][x]) {\n stacks[key][x] = oldStacks[key][x];\n stacks[key][x].total = null;\n }\n else {\n stacks[key][x] = new StackItem(yAxis, yAxis.options.stackLabels, !!isNegative, x, stackOption);\n }\n }\n // If the StackItem doesn't exist, create it first\n stack = stacks[key][x];\n if (y !== null) {\n stack.points[pointKey] = stack.points[series.index] =\n [pick(stack.cumulative, stackThreshold)];\n // Record the base of the stack\n if (!defined(stack.cumulative)) {\n stack.base = pointKey;\n }\n stack.touched = yAxis.stacking.stacksTouched;\n // In area charts, if there are multiple points on the same X value,\n // let the area fill the full span of those points\n if (stackIndicator.index > 0 && series.singleStacks === false) {\n stack.points[pointKey][0] =\n stack.points[series.index + ',' + x + ',0'][0];\n }\n // When updating to null, reset the point stack (#7493)\n }\n else {\n stack.points[pointKey] = stack.points[series.index] =\n null;\n }\n // Add value to the stack total\n if (stacking === 'percent') {\n // Percent stacked column, totals are the same for the positive and\n // negative stacks\n other = isNegative ? stackKey : negKey;\n if (negStacks && stacks[other] && stacks[other][x]) {\n other = stacks[other][x];\n stack.total = other.total =\n Math.max(other.total, stack.total) +\n Math.abs(y) ||\n 0;\n // Percent stacked areas\n }\n else {\n stack.total =\n correctFloat(stack.total + (Math.abs(y) || 0));\n }\n }\n else if (stacking === 'group') {\n if (isArray(y)) {\n y = y[0];\n }\n // In this stack, the total is the number of valid points\n if (y !== null) {\n stack.total = (stack.total || 0) + 1;\n }\n }\n else {\n stack.total = correctFloat(stack.total + (y || 0));\n }\n if (stacking === 'group') {\n // This point's index within the stack, pushed to stack.points[1]\n stack.cumulative = (stack.total || 1) - 1;\n }\n else {\n stack.cumulative = correctFloat(pick(stack.cumulative, stackThreshold) +\n (y || 0));\n }\n if (y !== null) {\n stack.points[pointKey].push(stack.cumulative);\n stackedYData[i] = stack.cumulative;\n stack.hasValidPoints = true;\n }\n }\n if (stacking === 'percent') {\n yAxis.stacking.usePercentage = true;\n }\n if (stacking !== 'group') {\n this.stackedYData = stackedYData; // To be used in getExtremes\n }\n // Reset old stacks\n yAxis.stacking.oldStacks = {};\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * Adds stacking support to axes.\n * @private\n * @class\n */\n class AxisAdditions {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.oldStacks = {};\n this.stacks = {};\n this.stacksTouched = 0;\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Build the stacks from top down\n * @private\n */\n buildStacks() {\n const stacking = this;\n const axis = stacking.axis;\n const axisSeries = axis.series;\n const reversedStacks = axis.options.reversedStacks;\n const len = axisSeries.length;\n let actualSeries, i;\n stacking.usePercentage = false;\n i = len;\n while (i--) {\n actualSeries = axisSeries[reversedStacks ? i : len - i - 1];\n actualSeries.setStackedPoints();\n actualSeries.setGroupedPoints();\n }\n // Loop up again to compute percent and stream stack\n for (i = 0; i < len; i++) {\n axisSeries[i].modifyStacks();\n }\n fireEvent(axis, 'afterBuildStacks');\n }\n /**\n * @private\n */\n cleanStacks() {\n const stacking = this;\n let stacks;\n if (stacking.oldStacks) {\n stacks = stacking.stacks = stacking.oldStacks;\n }\n // reset stacks\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.cumulative = stack.total;\n });\n });\n }\n /**\n * Set all the stacks to initial states and destroy unused ones.\n * @private\n */\n resetStacks() {\n objectEach(this.stacks, (type) => {\n objectEach(type, (stack, x) => {\n // Clean up memory after point deletion (#1044, #4320)\n if (isNumber(stack.touched) &&\n stack.touched < this.stacksTouched) {\n stack.destroy();\n delete type[x];\n // Reset stacks\n }\n else {\n stack.total = null;\n stack.cumulative = null;\n }\n });\n });\n }\n /**\n * @private\n */\n renderStackTotals() {\n const stacking = this, axis = stacking.axis, chart = axis.chart, renderer = chart.renderer, stacks = stacking.stacks, stackLabelsAnim = axis.options.stackLabels &&\n axis.options.stackLabels.animation, animationConfig = getDeferredAnimation(chart, stackLabelsAnim || false), stackTotalGroup = stacking.stackTotalGroup = (stacking.stackTotalGroup ||\n renderer\n .g('stack-labels')\n .attr({\n zIndex: 6,\n opacity: 0\n })\n .add());\n // plotLeft/Top will change when y axis gets wider so we need to\n // translate the stackTotalGroup at every render call. See bug #506\n // and #516\n stackTotalGroup.translate(chart.plotLeft, chart.plotTop);\n // Render each stack total\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.render(stackTotalGroup);\n });\n });\n stackTotalGroup.animate({\n opacity: 1\n }, animationConfig);\n }\n }\n /* *\n *\n * Composition\n *\n * */\n var StackingAxis;\n (function (StackingAxis) {\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis with stacking support.\n * @private\n */\n function compose(AxisClass, ChartClass, SeriesClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'destroy', onAxisDestroy);\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n const chartProto = ChartClass.prototype;\n chartProto.getStacks = chartGetStacks;\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.getStackIndicator = seriesGetStackIndicator;\n seriesProto.modifyStacks = seriesModifyStacks;\n seriesProto.percentStacker = seriesPercentStacker;\n seriesProto.setGroupedPoints = seriesSetGroupedPoints;\n seriesProto.setStackedPoints = seriesSetStackedPoints;\n }\n }\n StackingAxis.compose = compose;\n })(StackingAxis || (StackingAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return StackingAxis;\n });\n _registerModule(_modules, 'Series/Line/LineSeries.js', [_modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The line series is the base type and is therefor the series base prototype.\n *\n * @private\n */\n class LineSeries extends Series {\n constructor() {\n /* *\n *\n * Static Functions\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Draw the graph. Called internally when rendering line-like series\n * types. The first time it generates the `series.graph` item and\n * optionally other series-wide items like `series.area` for area\n * charts. On subsequent calls these items are updated with new\n * positions and attributes.\n *\n * @function Highcharts.Series#drawGraph\n */\n drawGraph() {\n const series = this, options = this.options, graphPath = (this.gappedPath || this.getGraphPath).call(this), styledMode = this.chart.styledMode;\n let props = [[\n 'graph',\n 'highcharts-graph'\n ]];\n // Presentational properties\n if (!styledMode) {\n props[0].push((options.lineColor ||\n this.color ||\n \"#cccccc\" /* Palette.neutralColor20 */ // when colorByPoint = true\n ), options.dashStyle);\n }\n props = series.getZonesGraphs(props);\n // Draw the graph\n props.forEach(function (prop, i) {\n const graphKey = prop[0];\n let attribs, graph = series[graphKey];\n const verb = graph ? 'animate' : 'attr';\n if (graph) {\n graph.endX = series.preventGraphAnimation ?\n null :\n graphPath.xMap;\n graph.animate({ d: graphPath });\n }\n else if (graphPath.length) { // #1487\n /**\n * SVG element of area-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone areas, accessible\n * via `series['zone-area-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#area\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * SVG element of line-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone lines, accessible\n * via `series['zone-graph-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#graph\n * @type {Highcharts.SVGElement|undefined}\n */\n series[graphKey] = graph = series.chart.renderer\n .path(graphPath)\n .addClass(prop[1])\n .attr({ zIndex: 1 }) // #1069\n .add(series.group);\n }\n if (graph && !styledMode) {\n attribs = {\n 'stroke': prop[2],\n 'stroke-width': options.lineWidth || 0,\n // Polygon series use filled graph\n 'fill': (series.fillGraph && series.color) || 'none'\n };\n // Apply dash style\n if (prop[3]) {\n attribs.dashstyle = prop[3];\n // The reason for the `else if` is that linecaps don't mix well\n // with dashstyle. The gaps get partially filled by the\n // linecap.\n }\n else if (options.linecap !== 'square') {\n attribs['stroke-linecap'] =\n attribs['stroke-linejoin'] = 'round';\n }\n graph[verb](attribs)\n // Add shadow to normal series (0) or to first\n // zone (1) #3932\n .shadow((i < 2) && options.shadow);\n }\n // Helpers for animation\n if (graph) {\n graph.startX = graphPath.xMap;\n graph.isArea = graphPath.isArea; // For arearange animation\n }\n });\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get the graph path.\n *\n * @private\n */\n getGraphPath(points, nullsAsZeroes, connectCliffs) {\n const series = this, options = series.options, graphPath = [], xMap = [];\n let gap, step = options.step;\n points = points || series.points;\n // Bottom of a stack is reversed\n const reversed = points.reversed;\n if (reversed) {\n points.reverse();\n }\n // Reverse the steps (#5004)\n step = {\n right: 1,\n center: 2\n }[step] || (step && 3);\n if (step && reversed) {\n step = 4 - step;\n }\n // Remove invalid points, especially in spline (#5015)\n points = this.getValidPoints(points, false, !(options.connectNulls && !nullsAsZeroes && !connectCliffs));\n // Build the line\n points.forEach(function (point, i) {\n const plotX = point.plotX, plotY = point.plotY, lastPoint = points[i - 1], isNull = point.isNull || typeof plotY !== 'number';\n // the path to this point from the previous\n let pathToPoint;\n if ((point.leftCliff || (lastPoint && lastPoint.rightCliff)) &&\n !connectCliffs) {\n gap = true; // ... and continue\n }\n // Line series, nullsAsZeroes is not handled\n if (isNull && !defined(nullsAsZeroes) && i > 0) {\n gap = !options.connectNulls;\n // Area series, nullsAsZeroes is set\n }\n else if (isNull && !nullsAsZeroes) {\n gap = true;\n }\n else {\n if (i === 0 || gap) {\n pathToPoint = [[\n 'M',\n point.plotX,\n point.plotY\n ]];\n // Generate the spline as defined in the SplineSeries object\n }\n else if (series.getPointSpline) {\n pathToPoint = [series.getPointSpline(points, point, i)];\n }\n else if (step) {\n if (step === 1) { // right\n pathToPoint = [[\n 'L',\n lastPoint.plotX,\n plotY\n ]];\n }\n else if (step === 2) { // center\n pathToPoint = [[\n 'L',\n (lastPoint.plotX + plotX) / 2,\n lastPoint.plotY\n ], [\n 'L',\n (lastPoint.plotX + plotX) / 2,\n plotY\n ]];\n }\n else {\n pathToPoint = [[\n 'L',\n plotX,\n lastPoint.plotY\n ]];\n }\n pathToPoint.push([\n 'L',\n plotX,\n plotY\n ]);\n }\n else {\n // normal line to next point\n pathToPoint = [[\n 'L',\n plotX,\n plotY\n ]];\n }\n // Prepare for animation. When step is enabled, there are\n // two path nodes for each x value.\n xMap.push(point.x);\n if (step) {\n xMap.push(point.x);\n if (step === 2) { // step = center (#8073)\n xMap.push(point.x);\n }\n }\n graphPath.push.apply(graphPath, pathToPoint);\n gap = false;\n }\n });\n graphPath.xMap = xMap;\n series.graphPath = graphPath;\n return graphPath;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get zones properties for building graphs. Extendable by series with\n * multiple lines within one series.\n *\n * @private\n */\n getZonesGraphs(props) {\n // Add the zone properties if any\n this.zones.forEach(function (zone, i) {\n const propset = [\n 'zone-graph-' + i,\n 'highcharts-graph highcharts-zone-graph-' + i + ' ' +\n (zone.className || '')\n ];\n if (!this.chart.styledMode) {\n propset.push((zone.color || this.color), (zone.dashStyle || this.options.dashStyle));\n }\n props.push(propset);\n }, this);\n return props;\n }\n }\n LineSeries.defaultOptions = merge(Series.defaultOptions, \n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n {\n legendSymbol: 'lineMarker'\n });\n SeriesRegistry.registerSeriesType('line', LineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A line series displays information as a series of data points connected by\n * straight line segments.\n *\n * @sample {highcharts} highcharts/demo/line-basic/\n * Line chart\n * @sample {highstock} stock/demo/basic-line/\n * Line chart\n *\n * @extends plotOptions.series\n * @product highcharts highstock\n * @apioption plotOptions.line\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * A `line` series. If the [type](#series.line.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.line\n * @excluding dataParser,dataURL\n * @product highcharts highstock\n * @apioption series.line\n */\n /**\n * An array of data points for the series. For the `line` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 1],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.line.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * **Note:** In TypeScript you have to extend `PointOptionsObject` with an\n * additional declaration to allow custom data types:\n * ```ts\n * declare module `highcharts` {\n * interface PointOptionsObject {\n * custom: Record;\n * }\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @declare Highcharts.PointOptionsObject\n * @type {Array|null|*>}\n * @apioption series.line.data\n */\n /**\n * An additional, individual class name for the data point's graphic\n * representation. Changes to a point's color will also be reflected in a\n * chart's legend and tooltip.\n *\n * @sample {highcharts} highcharts/css/point-series-classname\n *\n * @type {string}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.className\n */\n /**\n * Individual color for the point. By default the color is pulled from\n * the global `colors` array.\n *\n * In styled mode, the `color` option doesn't take effect. Instead, use\n * `colorIndex`.\n *\n * @sample {highcharts} highcharts/point/color/\n * Mark the highest point\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock gantt\n * @apioption series.line.data.color\n */\n /**\n * A specific color index to use for the point, so its graphic representations\n * are given the class name `highcharts-color-{n}`. In styled mode this will\n * change the color of the graphic. In non-styled mode, the color is set by the\n * `fill` attribute, so the change in class name won't have a visual effect by\n * default.\n *\n * Since v11, CSS variables on the form `--highcharts-color-{n}` make changing\n * the color scheme very convenient.\n *\n * @sample {highcharts} highcharts/css/colorindex/\n * Series and point color index\n *\n * @type {number}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.colorIndex\n */\n /**\n * A reserved subspace to store options and values for customized functionality.\n * Here you can add additional data for your own event callbacks and formatter\n * callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption series.line.data.custom\n */\n /**\n * Individual data label for each point. The options are the same as\n * the ones for [plotOptions.series.dataLabels](\n * #plotOptions.series.dataLabels).\n *\n * @sample highcharts/point/datalabels/\n * Show a label for the last value\n *\n * @declare Highcharts.DataLabelsOptions\n * @extends plotOptions.line.dataLabels\n * @product highcharts highstock gantt\n * @apioption series.line.data.dataLabels\n */\n /**\n * A description of the point to add to the screen reader information\n * about the point.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption series.line.data.description\n */\n /**\n * An id for the point. This can be used after render time to get a\n * pointer to the point object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/point/id/\n * Remove an id'd point\n *\n * @type {string}\n * @since 1.2.0\n * @product highcharts highstock gantt\n * @apioption series.line.data.id\n */\n /**\n * The rank for this point's data label in case of collision. If two\n * data labels are about to overlap, only the one with the highest `labelrank`\n * will be drawn.\n *\n * @type {number}\n * @apioption series.line.data.labelrank\n */\n /**\n * The name of the point as shown in the legend, tooltip, dataLabels, etc.\n *\n * @see [xAxis.uniqueNames](#xAxis.uniqueNames)\n *\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Point names\n *\n * @type {string}\n * @apioption series.line.data.name\n */\n /**\n * Whether the data point is selected initially.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption series.line.data.selected\n */\n /**\n * The x value of the point. For datetime axes, the X value is the timestamp\n * in milliseconds since 1970.\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.line.data.x\n */\n /**\n * The y value of the point.\n *\n * @type {number|null}\n * @product highcharts highstock\n * @apioption series.line.data.y\n */\n /**\n * The individual point events.\n *\n * @extends plotOptions.series.point.events\n * @product highcharts highstock gantt\n * @apioption series.line.data.events\n */\n /**\n * Options for the point markers of line-like series.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n * @extends plotOptions.series.marker\n * @product highcharts highstock\n * @apioption series.line.data.marker\n */\n ''; // include precedent doclets in transpilat\n\n return LineSeries;\n });\n _registerModule(_modules, 'Series/Area/AreaSeries.js', [_modules['Core/Color/Color.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Color, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { seriesTypes: { line: LineSeries } } = SeriesRegistry;\n const { extend, merge, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Area series type.\n *\n * @private\n * @class\n * @name AreaSeries\n *\n * @augments LineSeries\n */\n class AreaSeries extends LineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Draw the graph and the underlying area. This method calls the Series\n * base function and adds the area. The areaPath is calculated in the\n * getSegmentPath method called from Series.prototype.drawGraph.\n * @private\n */\n drawGraph() {\n // Define or reset areaPath\n this.areaPath = [];\n // Call the base method\n super.drawGraph.apply(this);\n // Define local variables\n const series = this, areaPath = this.areaPath, options = this.options, zones = this.zones, props = [[\n 'area',\n 'highcharts-area',\n this.color,\n options.fillColor\n ]]; // area name, main color, fill color\n zones.forEach(function (zone, i) {\n props.push([\n 'zone-area-' + i,\n 'highcharts-area highcharts-zone-area-' + i + ' ' +\n zone.className,\n zone.color || series.color,\n zone.fillColor || options.fillColor\n ]);\n });\n props.forEach(function (prop) {\n const areaKey = prop[0], attribs = {};\n let area = series[areaKey];\n const verb = area ? 'animate' : 'attr';\n // Create or update the area\n if (area) { // update\n area.endX = series.preventGraphAnimation ?\n null :\n areaPath.xMap;\n area.animate({ d: areaPath });\n }\n else { // create\n attribs.zIndex = 0; // #1069\n area = series[areaKey] = series.chart.renderer\n .path(areaPath)\n .addClass(prop[1])\n .add(series.group);\n area.isArea = true;\n }\n if (!series.chart.styledMode) {\n // If there is fillColor defined for the area, set it\n if (prop[3]) {\n attribs.fill = prop[3];\n }\n else {\n // Otherwise, we set it to the series color and add\n // fill-opacity (#18939)\n attribs.fill = prop[2];\n attribs['fill-opacity'] = pick(options.fillOpacity, 0.75);\n }\n }\n area[verb](attribs);\n area.startX = areaPath.xMap;\n area.shiftUnit = options.step ? 2 : 1;\n });\n }\n /**\n * @private\n */\n getGraphPath(points) {\n const getGraphPath = LineSeries.prototype.getGraphPath, options = this.options, stacking = options.stacking, yAxis = this.yAxis, bottomPoints = [], graphPoints = [], seriesIndex = this.index, stacks = yAxis.stacking.stacks[this.stackKey], threshold = options.threshold, translatedThreshold = Math.round(// #10909\n yAxis.getThreshold(options.threshold)), connectNulls = pick(// #10574\n options.connectNulls, stacking === 'percent'), \n // To display null points in underlying stacked series, this\n // series graph must be broken, and the area also fall down to\n // fill the gap left by the null point. #2069\n addDummyPoints = function (i, otherI, side) {\n const point = points[i], stackedValues = stacking &&\n stacks[point.x].points[seriesIndex], nullVal = point[side + 'Null'] || 0, cliffVal = point[side + 'Cliff'] || 0;\n let top, bottom, isNull = true;\n if (cliffVal || nullVal) {\n top = (nullVal ?\n stackedValues[0] :\n stackedValues[1]) + cliffVal;\n bottom = stackedValues[0] + cliffVal;\n isNull = !!nullVal;\n }\n else if (!stacking &&\n points[otherI] &&\n points[otherI].isNull) {\n top = bottom = threshold;\n }\n // Add to the top and bottom line of the area\n if (typeof top !== 'undefined') {\n graphPoints.push({\n plotX: plotX,\n plotY: top === null ?\n translatedThreshold :\n yAxis.getThreshold(top),\n isNull: isNull,\n isCliff: true\n });\n bottomPoints.push({\n plotX: plotX,\n plotY: bottom === null ?\n translatedThreshold :\n yAxis.getThreshold(bottom),\n doCurve: false // #1041, gaps in areaspline areas\n });\n }\n };\n let plotX, isNull, yBottom;\n // Find what points to use\n points = points || this.points;\n // Fill in missing points\n if (stacking) {\n points = this.getStackPoints(points);\n }\n for (let i = 0, iEnd = points.length; i < iEnd; ++i) {\n // Reset after series.update of stacking property (#12033)\n if (!stacking) {\n points[i].leftCliff = points[i].rightCliff =\n points[i].leftNull = points[i].rightNull = void 0;\n }\n isNull = points[i].isNull;\n plotX = pick(points[i].rectPlotX, points[i].plotX);\n yBottom = stacking ?\n pick(points[i].yBottom, translatedThreshold) :\n translatedThreshold;\n if (!isNull || connectNulls) {\n if (!connectNulls) {\n addDummyPoints(i, i - 1, 'left');\n }\n // Skip null point when stacking is false and connectNulls\n // true\n if (!(isNull && !stacking && connectNulls)) {\n graphPoints.push(points[i]);\n bottomPoints.push({\n x: i,\n plotX: plotX,\n plotY: yBottom\n });\n }\n if (!connectNulls) {\n addDummyPoints(i, i + 1, 'right');\n }\n }\n }\n const topPath = getGraphPath.call(this, graphPoints, true, true);\n bottomPoints.reversed = true;\n const bottomPath = getGraphPath.call(this, bottomPoints, true, true);\n const firstBottomPoint = bottomPath[0];\n if (firstBottomPoint && firstBottomPoint[0] === 'M') {\n bottomPath[0] = ['L', firstBottomPoint[1], firstBottomPoint[2]];\n }\n const areaPath = topPath.concat(bottomPath);\n if (areaPath.length) {\n areaPath.push(['Z']);\n }\n // TODO: don't set leftCliff and rightCliff when connectNulls?\n const graphPath = getGraphPath\n .call(this, graphPoints, false, connectNulls);\n areaPath.xMap = topPath.xMap;\n this.areaPath = areaPath;\n return graphPath;\n }\n /**\n * Return an array of stacked points, where null and missing points are\n * replaced by dummy points in order for gaps to be drawn correctly in\n * stacks.\n * @private\n */\n getStackPoints(points) {\n const series = this, segment = [], keys = [], xAxis = this.xAxis, yAxis = this.yAxis, stack = yAxis.stacking.stacks[this.stackKey], pointMap = {}, yAxisSeries = yAxis.series, seriesLength = yAxisSeries.length, upOrDown = yAxis.options.reversedStacks ? 1 : -1, seriesIndex = yAxisSeries.indexOf(series);\n points = points || this.points;\n if (this.options.stacking) {\n for (let i = 0; i < points.length; i++) {\n // Reset after point update (#7326)\n points[i].leftNull = points[i].rightNull = void 0;\n // Create a map where we can quickly look up the points by\n // their X values.\n pointMap[points[i].x] = points[i];\n }\n // Sort the keys (#1651)\n objectEach(stack, function (stackX, x) {\n // nulled after switching between\n // grouping and not (#1651, #2336)\n if (stackX.total !== null) {\n keys.push(x);\n }\n });\n keys.sort(function (a, b) {\n return a - b;\n });\n const visibleSeries = yAxisSeries.map((s) => s.visible);\n keys.forEach(function (x, idx) {\n let y = 0, stackPoint, stackedValues;\n if (pointMap[x] && !pointMap[x].isNull) {\n segment.push(pointMap[x]);\n // Find left and right cliff. -1 goes left, 1 goes\n // right.\n [-1, 1].forEach(function (direction) {\n const nullName = direction === 1 ?\n 'rightNull' :\n 'leftNull', cliffName = direction === 1 ?\n 'rightCliff' :\n 'leftCliff', otherStack = stack[keys[idx + direction]];\n let cliff = 0;\n // If there is a stack next to this one,\n // to the left or to the right...\n if (otherStack) {\n let i = seriesIndex;\n // Can go either up or down,\n // depending on reversedStacks\n while (i >= 0 && i < seriesLength) {\n const si = yAxisSeries[i].index;\n stackPoint = otherStack.points[si];\n if (!stackPoint) {\n // If the next point in this series is\n // missing, mark the point with\n // point.leftNull or point.rightNull = true.\n if (si === series.index) {\n pointMap[x][nullName] = true;\n // If there are missing points in the next\n // stack in any of the series below this\n // one, we need to substract the missing\n // values and add a hiatus to the left or\n // right.\n }\n else if (visibleSeries[i]) {\n stackedValues = stack[x].points[si];\n if (stackedValues) {\n cliff -= (stackedValues[1] -\n stackedValues[0]);\n }\n }\n }\n // When reversedStacks is true, loop up,\n // else loop down\n i += upOrDown;\n }\n }\n pointMap[x][cliffName] = cliff;\n });\n // There is no point for this X value in this series, so we\n // insert a dummy point in order for the areas to be drawn\n // correctly.\n }\n else {\n // Loop down the stack to find the series below this\n // one that has a value (#1991)\n let i = seriesIndex;\n while (i >= 0 && i < seriesLength) {\n const si = yAxisSeries[i].index;\n stackPoint = stack[x].points[si];\n if (stackPoint) {\n y = stackPoint[1];\n break;\n }\n // When reversedStacks is true, loop up, else loop\n // down\n i += upOrDown;\n }\n y = pick(y, 0);\n y = yAxis.translate(// #6272\n y, 0, 1, 0, 1);\n segment.push({\n isNull: true,\n plotX: xAxis.translate(// #6272\n x, 0, 0, 0, 1),\n x: x,\n plotY: y,\n yBottom: y\n });\n }\n });\n }\n return segment;\n }\n }\n /**\n * The area series type.\n *\n * @sample {highcharts} highcharts/demo/area-basic/\n * Area chart\n * @sample {highstock} stock/demo/area/\n * Area chart\n *\n * @extends plotOptions.line\n * @excluding useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.area\n */\n AreaSeries.defaultOptions = merge(LineSeries.defaultOptions, {\n /**\n * @see [fillColor](#plotOptions.area.fillColor)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @apioption plotOptions.area.color\n */\n /**\n * Fill color or gradient for the area. When `null`, the series' `color`\n * is used with the series' `fillOpacity`.\n *\n * In styled mode, the fill color can be set with the `.highcharts-area`\n * class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-default/\n * Null by default\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.fillColor\n */\n /**\n * Fill opacity for the area. When you set an explicit `fillColor`,\n * the `fillOpacity` is not applied. Instead, you should define the\n * opacity in the `fillColor` with an rgba color definition. The\n * `fillOpacity` setting, also the default setting, overrides the alpha\n * component of the `color` setting.\n *\n * In styled mode, the fill opacity can be set with the\n * `.highcharts-area` class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillopacity/\n * Automatic fill color and fill opacity of 0.1\n *\n * @type {number}\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @product highcharts highstock\n * @apioption plotOptions.area.fillOpacity\n */\n /**\n * A separate color for the graph line. By default the line takes the\n * `color` of the series, but the lineColor setting allows setting a\n * separate color for the line without altering the `fillColor`.\n *\n * In styled mode, the line stroke can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/area-linecolor/\n * Dark gray line\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.lineColor\n */\n /**\n * A separate color for the negative part of the area.\n *\n * In styled mode, a negative color is set with the\n * `.highcharts-negative` class name.\n *\n * @see [negativeColor](#plotOptions.area.negativeColor)\n *\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Negative color in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @product highcharts\n * @apioption plotOptions.area.negativeFillColor\n */\n /**\n * Whether the whole area or just the line should respond to mouseover\n * tooltips and other mouse or touch events.\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/area-trackbyarea/\n * Display the tooltip when the area is hovered\n *\n * @type {boolean}\n * @default false\n * @since 1.1.6\n * @product highcharts highstock\n * @apioption plotOptions.area.trackByArea\n */\n /**\n * The Y axis value to serve as the base for the area, for\n * distinguishing between values above and below a threshold. The area\n * between the graph and the threshold is filled.\n *\n * * If a number is given, the Y axis will scale to the threshold.\n * * If `null`, the scaling behaves like a line series with fill between\n * the graph and the Y axis minimum.\n * * If `Infinity` or `-Infinity`, the area between the graph and the\n * corresponding Y axis extreme is filled (since v6.1.0).\n *\n * @sample {highcharts} highcharts/plotoptions/area-threshold/\n * A threshold of 100\n * @sample {highcharts} highcharts/plotoptions/area-threshold-infinity/\n * A threshold of Infinity\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts highstock\n */\n threshold: 0,\n legendSymbol: 'rectangle'\n });\n extend(AreaSeries.prototype, {\n singleStacks: false\n });\n SeriesRegistry.registerSeriesType('area', AreaSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `area` series. If the [type](#series.area.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.area\n * @excluding dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.area\n */\n /**\n * @see [fillColor](#series.area.fillColor)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.color\n */\n /**\n * An array of data points for the series. For the `area` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` * and `pointInterval` given in the series options. If the\n * axis has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 7],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.area.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.area.data\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.fillColor\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillColor](#series.area.fillColor)\n *\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @apioption series.area.fillOpacity\n */\n ''; // adds doclets above to transpilat\n\n return AreaSeries;\n });\n _registerModule(_modules, 'Series/Spline/SplineSeries.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { line: LineSeries } = SeriesRegistry.seriesTypes;\n const { merge, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Spline series type.\n *\n * @private\n */\n class SplineSeries extends LineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the spline segment from a given point's previous neighbour to the\n * given point.\n *\n * @private\n * @function Highcharts.seriesTypes.spline#getPointSpline\n */\n getPointSpline(points, point, i) {\n const \n // 1 means control points midway between points, 2 means 1/3\n // from the point, 3 is 1/4 etc\n smoothing = 1.5, denom = smoothing + 1, plotX = point.plotX || 0, plotY = point.plotY || 0, lastPoint = points[i - 1], nextPoint = points[i + 1];\n let leftContX, leftContY, rightContX, rightContY;\n /**\n * @private\n */\n function doCurve(otherPoint) {\n return otherPoint &&\n !otherPoint.isNull &&\n otherPoint.doCurve !== false &&\n // #6387, area splines next to null:\n !point.isCliff;\n }\n // Find control points\n if (doCurve(lastPoint) && doCurve(nextPoint)) {\n const lastX = lastPoint.plotX || 0, lastY = lastPoint.plotY || 0, nextX = nextPoint.plotX || 0, nextY = nextPoint.plotY || 0;\n let correction = 0;\n leftContX = (smoothing * plotX + lastX) / denom;\n leftContY = (smoothing * plotY + lastY) / denom;\n rightContX = (smoothing * plotX + nextX) / denom;\n rightContY = (smoothing * plotY + nextY) / denom;\n // Have the two control points make a straight line through main\n // point\n if (rightContX !== leftContX) { // #5016, division by zero\n correction = (((rightContY - leftContY) *\n (rightContX - plotX)) /\n (rightContX - leftContX) + plotY - rightContY);\n }\n leftContY += correction;\n rightContY += correction;\n // to prevent false extremes, check that control points are\n // between neighbouring points' y values\n if (leftContY > lastY && leftContY > plotY) {\n leftContY = Math.max(lastY, plotY);\n // mirror of left control point\n rightContY = 2 * plotY - leftContY;\n }\n else if (leftContY < lastY && leftContY < plotY) {\n leftContY = Math.min(lastY, plotY);\n rightContY = 2 * plotY - leftContY;\n }\n if (rightContY > nextY && rightContY > plotY) {\n rightContY = Math.max(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n else if (rightContY < nextY && rightContY < plotY) {\n rightContY = Math.min(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n // record for drawing in next point\n point.rightContX = rightContX;\n point.rightContY = rightContY;\n }\n // Visualize control points for debugging\n /*\n if (leftContX) {\n this.chart.renderer.circle(\n leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n if (rightContX) {\n this.chart.renderer.circle(\n rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n // */\n const ret = [\n 'C',\n pick(lastPoint.rightContX, lastPoint.plotX, 0),\n pick(lastPoint.rightContY, lastPoint.plotY, 0),\n pick(leftContX, plotX, 0),\n pick(leftContY, plotY, 0),\n plotX,\n plotY\n ];\n // reset for updating series later\n lastPoint.rightContX = lastPoint.rightContY = void 0;\n return ret;\n }\n }\n /**\n * A spline series is a special type of line series, where the segments\n * between the data points are smoothed.\n *\n * @sample {highcharts} highcharts/demo/spline-irregular-time/\n * Spline chart\n * @sample {highstock} stock/demo/spline/\n * Spline chart\n *\n * @extends plotOptions.series\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @optionparent plotOptions.spline\n */\n SplineSeries.defaultOptions = merge(LineSeries.defaultOptions);\n SeriesRegistry.registerSeriesType('spline', SplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `spline` series. If the [type](#series.spline.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.spline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.spline\n */\n /**\n * An array of data points for the series. For the `spline` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.spline.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 0,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.spline.data\n */\n ''; // adds doclets above intro transpilat\n\n return SplineSeries;\n });\n _registerModule(_modules, 'Series/AreaSpline/AreaSplineSeries.js', [_modules['Series/Spline/SplineSeries.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SplineSeries, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { area: AreaSeries, area: { prototype: areaProto } } = SeriesRegistry.seriesTypes;\n const { extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * AreaSpline series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.areaspline\n *\n * @augments Highcharts.Series\n */\n class AreaSplineSeries extends SplineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.points = void 0;\n this.options = void 0;\n }\n }\n AreaSplineSeries.defaultOptions = merge(SplineSeries.defaultOptions, AreaSeries.defaultOptions);\n extend(AreaSplineSeries.prototype, {\n getGraphPath: areaProto.getGraphPath,\n getStackPoints: areaProto.getStackPoints,\n drawGraph: areaProto.drawGraph\n });\n SeriesRegistry.registerSeriesType('areaspline', AreaSplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * The area spline series is an area series where the graph between the\n * points is smoothed into a spline.\n *\n * @sample {highcharts} highcharts/demo/areaspline/\n * Area spline chart\n * @sample {highstock} stock/demo/areaspline/\n * Area spline chart\n *\n * @extends plotOptions.area\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption plotOptions.areaspline\n */\n /**\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.color\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.fillColor\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption plotOptions.areaspline.fillOpacity\n */\n /**\n * A `areaspline` series. If the [type](#series.areaspline.type) option\n * is not specified, it is inherited from [chart.type](#chart.type).\n *\n *\n * @extends series,plotOptions.areaspline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.areaspline\n */\n /**\n * @see [fillColor](#series.areaspline.fillColor)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.color\n */\n /**\n * An array of data points for the series. For the `areaspline` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 10],\n * [1, 9],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.areaspline.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 4,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.areaspline.data\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.fillColor\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillColor](#series.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption series.areaspline.fillOpacity\n */\n ''; // adds doclets above into transpilat\n\n return AreaSplineSeries;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Column series display one column per value along an X axis.\n *\n * @sample {highcharts} highcharts/demo/column-basic/\n * Column chart\n * @sample {highstock} stock/demo/column/\n * Column chart\n *\n * @extends plotOptions.line\n * @excluding connectEnds, connectNulls, gapSize, gapUnit, linecap,\n * lineWidth, marker, step, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.column\n */\n const ColumnSeriesDefaults = {\n /**\n * The corner radius of the border surrounding each column or bar. A number\n * signifies pixels. A percentage string, like for example `50%`, signifies\n * a relative size. For columns this is relative to the column width, for\n * pies it is relative to the radius and the inner radius.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderradius/\n * Rounded columns\n * @sample highcharts/plotoptions/series-border-radius\n * Column and pie with rounded border\n *\n * @type {number|string|Highcharts.BorderRadiusOptionsObject}\n * @product highcharts highstock gantt\n */\n borderRadius: 3,\n /**\n * When using automatic point colors pulled from the global\n * [colors](colors) or series-specific\n * [plotOptions.column.colors](series.colors) collections, this option\n * determines whether the chart should receive one color per series or\n * one color per point.\n *\n * In styled mode, the `colors` or `series.colors` arrays are not\n * supported, and instead this option gives the points individual color\n * class names on the form `highcharts-color-{n}`.\n *\n * @see [series colors](#plotOptions.column.colors)\n *\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @since 2.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colorByPoint\n */\n /**\n * A series specific or series type specific color set to apply instead\n * of the global [colors](#colors) when [colorByPoint](\n * #plotOptions.column.colorByPoint) is true.\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colors\n */\n /**\n * When `true`, the columns will center in the category, ignoring null\n * or missing points. When `false`, space will be reserved for null or\n * missing points.\n *\n * @sample {highcharts} highcharts/series-column/centerincategory/\n * Center in category\n *\n * @since 8.0.1\n * @product highcharts highstock gantt\n */\n centerInCategory: false,\n /**\n * Padding between each value groups, in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-default/\n * 0.2 by default\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-none/\n * No group padding - all columns are evenly spaced\n *\n * @product highcharts highstock gantt\n */\n groupPadding: 0.2,\n /**\n * Whether to group non-stacked columns or to let them render\n * independent of each other. Non-grouped columns will be laid out\n * individually and overlap each other.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n * @sample {highstock} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.grouping\n */\n /** @ignore-option */\n marker: null,\n /**\n * The maximum allowed pixel width for a column, translated to the\n * height of a bar in a bar chart. This prevents the columns from\n * becoming too wide when there is a small number of points in the\n * chart.\n *\n * @see [pointWidth](#plotOptions.column.pointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n * @sample {highstock} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n *\n * @type {number}\n * @since 4.1.8\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.maxPointWidth\n */\n /**\n * Padding between each column or bar, in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-default/\n * 0.1 by default\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-025/\n * 0.25\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-none/\n * 0 for tightly packed columns\n *\n * @product highcharts highstock gantt\n */\n pointPadding: 0.1,\n /**\n * A pixel value specifying a fixed width for each column or bar point.\n * When set to `undefined`, the width is calculated from the\n * `pointPadding` and `groupPadding`. The width effects the dimension\n * that is not based on the point value. For column series it is the\n * hoizontal length and for bar series it is the vertical length.\n *\n * @see [maxPointWidth](#plotOptions.column.maxPointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointwidth-20/\n * 20px wide columns regardless of chart width or the amount of\n * data points\n *\n * @type {number}\n * @since 1.2.5\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.pointWidth\n */\n /**\n * A pixel value specifying a fixed width for the column or bar.\n * Overrides pointWidth on the series.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @default undefined\n * @since 7.0.0\n * @product highcharts highstock gantt\n * @apioption series.column.data.pointWidth\n */\n /**\n * The minimal height for a column or width for a bar. By default,\n * 0 values are not shown. To visualize a 0 (or close to zero) point,\n * set the minimal point length to a pixel value like 3\\. In stacked\n * column charts, minPointLength might not be respected for tightly\n * packed values.\n *\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength/\n * Zero base value\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength-pos-and-neg/\n * Positive and negative close to zero values\n *\n * @product highcharts highstock gantt\n */\n minPointLength: 0,\n /**\n * When the series contains less points than the crop threshold, all\n * points are drawn, event if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns), is that animation is performed on\n * updates. On the other hand, when the series contains more points than\n * the crop threshold, the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @product highcharts highstock gantt\n */\n cropThreshold: 50,\n /**\n * The X axis range that each point is valid for. This determines the\n * width of the column. On a categorized axis, the range will be 1\n * by default (one category unit). On linear and datetime axes, the\n * range will be computed as the distance between the two closest data\n * points.\n *\n * The default `null` means it is computed automatically, but this\n * option can be used to override the automatic value.\n *\n * This option is set by default to 1 if data sorting is enabled.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointrange/\n * Set the point range to one day on a data set with one week\n * between the points\n *\n * @type {number|null}\n * @since 2.3\n * @product highcharts highstock gantt\n */\n pointRange: null,\n states: {\n /**\n * Options for the hovered point. These settings override the normal\n * state options when a point is moused over or touched.\n *\n * @extends plotOptions.series.states.hover\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock gantt\n */\n hover: {\n /** @ignore-option */\n halo: false,\n /**\n * A specific border color for the hovered point. Defaults to\n * inherit the normal state border color.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.borderColor\n */\n /**\n * A specific color for the hovered point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.color\n */\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode, the hover brightening is by default replaced\n * with a fill-opacity set in the `.highcharts-point:hover`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-states-hover-brightness/\n * Brighten by 0.5\n *\n * @product highcharts highstock gantt\n */\n brightness: 0.1\n },\n /**\n * Options for the selected point. These settings override the\n * normal state options when a point is selected.\n *\n * @extends plotOptions.series.states.select\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock gantt\n */\n select: {\n /**\n * A specific color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @product highcharts highstock gantt\n */\n color: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * A specific border color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highcharts highstock gantt\n */\n borderColor: \"#000000\" /* Palette.neutralColor100 */\n }\n },\n dataLabels: {\n align: void 0,\n verticalAlign: void 0,\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @type {number}\n */\n y: void 0\n },\n // false doesn't work well: https://jsfiddle.net/highcharts/hz8fopan/14/\n /** @ignore-option */\n startFromThreshold: true,\n stickyTracking: false,\n tooltip: {\n distance: 6\n },\n /**\n * The Y axis value to serve as the base for the columns, for\n * distinguishing between values above and below a threshold. If `null`,\n * the columns extend from the padding Y axis minimum.\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts\n */\n threshold: 0,\n /**\n * The width of the border surrounding each column or bar. Defaults to\n * `1` when there is room for a border, but to `0` when the columns are\n * so dense that a border would cover the next column.\n *\n * In styled mode, the stroke width can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @default undefined\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.borderWidth\n */\n /**\n * The color of the border surrounding each column or bar.\n *\n * In styled mode, the border stroke can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highstock gantt\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */\n };\n /**\n * A `column` series. If the [type](#series.column.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.column\n * @excluding connectNulls, dataParser, dataURL, gapSize, gapUnit, linecap,\n * lineWidth, marker, connectEnds, step\n * @product highcharts highstock\n * @apioption series.column\n */\n /**\n * An array of data points for the series. For the `column` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 6],\n * [1, 2],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.column.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker\n * @product highcharts highstock\n * @apioption series.column.data\n */\n /**\n * The color of the border surrounding the column or bar.\n *\n * In styled mode, the border stroke can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption series.column.data.borderColor\n */\n /**\n * The width of the border surrounding the column or bar.\n *\n * In styled mode, the stroke width can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.column.data.borderWidth\n */\n /**\n * A name for the dash style to use for the column or bar. Overrides\n * dashStyle on the series.\n *\n * In styled mode, the stroke dash-array can be set with the same classes as\n * listed under [data.color](#series.column.data.color).\n *\n * @see [series.pointWidth](#plotOptions.column.dashStyle)\n *\n * @type {Highcharts.DashStyleValue}\n * @apioption series.column.data.dashStyle\n */\n /**\n * A pixel value specifying a fixed width for the column or bar. Overrides\n * pointWidth on the series. The width effects the dimension that is not based\n * on the point value.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @apioption series.column.data.pointWidth\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.hover\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.select\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeries.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Series/Column/ColumnSeriesDefaults.js'], _modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (A, Color, ColumnSeriesDefaults, H, Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject } = A;\n const { parse: color } = Color;\n const { hasTouch, noop } = H;\n const { clamp, defined, extend, fireEvent, isArray, isNumber, merge, pick, objectEach, relativeLength } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The column series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.column\n *\n * @augments Highcharts.Series\n */\n class ColumnSeries extends Series {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.borderWidth = void 0;\n this.data = void 0;\n this.group = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animate the column heights one by one from zero.\n *\n * @private\n * @function Highcharts.seriesTypes.column#animate\n *\n * @param {boolean} init\n * Whether to initialize the animation or run it\n */\n animate(init) {\n const series = this, yAxis = this.yAxis, yAxisPos = yAxis.pos, options = series.options, inverted = this.chart.inverted, attr = {}, translateProp = inverted ?\n 'translateX' :\n 'translateY';\n let translateStart, translatedThreshold;\n if (init) {\n attr.scaleY = 0.001;\n translatedThreshold = clamp(yAxis.toPixels(options.threshold), yAxisPos, yAxisPos + yAxis.len);\n if (inverted) {\n attr.translateX = translatedThreshold - yAxis.len;\n }\n else {\n attr.translateY = translatedThreshold;\n }\n // apply finnal clipping (used in Highcharts Stock) (#7083)\n // animation is done by scaleY, so cliping is for panes\n if (series.clipBox) {\n series.setClip();\n }\n series.group.attr(attr);\n }\n else { // run the animation\n translateStart = Number(series.group.attr(translateProp));\n series.group.animate({ scaleY: 1 }, extend(animObject(series.options.animation), {\n // Do the scale synchronously to ensure smooth\n // updating (#5030, #7228)\n step: function (val, fx) {\n if (series.group) {\n attr[translateProp] = translateStart +\n fx.pos * (yAxisPos - translateStart);\n series.group.attr(attr);\n }\n }\n }));\n }\n }\n /**\n * Initialize the series. Extends the basic Series.init method by\n * marking other series of the same type as dirty.\n *\n * @private\n * @function Highcharts.seriesTypes.column#init\n */\n init(chart, options) {\n super.init.apply(this, arguments);\n const series = this;\n chart = series.chart;\n // if the series is added dynamically, force redraw of other\n // series affected by a new column\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n }\n /**\n * Return the width and x offset of the columns adjusted for grouping,\n * groupPadding, pointPadding, pointWidth etc.\n *\n * @private\n * @function Highcharts.seriesTypes.column#getColumnMetrics\n */\n getColumnMetrics() {\n const series = this, options = series.options, xAxis = series.xAxis, yAxis = series.yAxis, reversedStacks = xAxis.options.reversedStacks, \n // Keep backward compatibility: reversed xAxis had reversed\n // stacks\n reverseStacks = (xAxis.reversed && !reversedStacks) ||\n (!xAxis.reversed && reversedStacks), stackGroups = {};\n let stackKey, columnCount = 0;\n // Get the total number of column type series. This is called on\n // every series. Consider moving this logic to a chart.orderStacks()\n // function and call it on init, addSeries and removeSeries\n if (options.grouping === false) {\n columnCount = 1;\n }\n else {\n series.chart.series.forEach(function (otherSeries) {\n const otherYAxis = otherSeries.yAxis, otherOptions = otherSeries.options;\n let columnIndex;\n if (otherSeries.type === series.type &&\n (otherSeries.visible ||\n !series.chart.options.chart.ignoreHiddenSeries) &&\n yAxis.len === otherYAxis.len &&\n yAxis.pos === otherYAxis.pos) { // #642, #2086\n if (otherOptions.stacking &&\n otherOptions.stacking !== 'group') {\n stackKey = otherSeries.stackKey;\n if (typeof stackGroups[stackKey] ===\n 'undefined') {\n stackGroups[stackKey] = columnCount++;\n }\n columnIndex = stackGroups[stackKey];\n }\n else if (otherOptions.grouping !== false) { // #1162\n columnIndex = columnCount++;\n }\n otherSeries.columnIndex = columnIndex;\n }\n });\n }\n const categoryWidth = Math.min(Math.abs(xAxis.transA) * ((xAxis.ordinal && xAxis.ordinal.slope) ||\n options.pointRange ||\n xAxis.closestPointRange ||\n xAxis.tickInterval ||\n 1), // #2610\n xAxis.len // #1535\n ), groupPadding = categoryWidth * options.groupPadding, groupWidth = categoryWidth - 2 * groupPadding, pointOffsetWidth = groupWidth / (columnCount || 1), pointWidth = Math.min(options.maxPointWidth || xAxis.len, pick(options.pointWidth, pointOffsetWidth * (1 - 2 * options.pointPadding))), pointPadding = (pointOffsetWidth - pointWidth) / 2, \n // #1251, #3737\n colIndex = (series.columnIndex || 0) + (reverseStacks ? 1 : 0), pointXOffset = pointPadding +\n (groupPadding +\n colIndex * pointOffsetWidth -\n (categoryWidth / 2)) * (reverseStacks ? -1 : 1);\n // Save it for reading in linked series (Error bars particularly)\n series.columnMetrics = {\n width: pointWidth,\n offset: pointXOffset,\n paddedWidth: pointOffsetWidth,\n columnCount\n };\n return series.columnMetrics;\n }\n /**\n * Make the columns crisp. The edges are rounded to the nearest full\n * pixel.\n *\n * @private\n * @function Highcharts.seriesTypes.column#crispCol\n */\n crispCol(x, y, w, h) {\n const chart = this.chart, borderWidth = this.borderWidth, xCrisp = -(borderWidth % 2 ? 0.5 : 0);\n let right, yCrisp = borderWidth % 2 ? 0.5 : 1;\n // Horizontal. We need to first compute the exact right edge, then\n // round it and compute the width from there.\n if (this.options.crisp) {\n right = Math.round(x + w) + xCrisp;\n x = Math.round(x) + xCrisp;\n w = right - x;\n }\n // Vertical\n const bottom = Math.round(y + h) + yCrisp, fromTop = Math.abs(y) <= 0.5 && bottom > 0.5; // #4504, #4656\n y = Math.round(y) + yCrisp;\n h = bottom - y;\n // Top edges are exceptions\n if (fromTop && h) { // #5146\n y -= 1;\n h += 1;\n }\n return {\n x: x,\n y: y,\n width: w,\n height: h\n };\n }\n /**\n * Adjust for missing columns, according to the `centerInCategory`\n * option. Missing columns are either single points or stacks where the\n * point or points are either missing or null.\n *\n * @private\n * @function Highcharts.seriesTypes.column#adjustForMissingColumns\n * @param {number} x\n * The x coordinate of the column, left side\n *\n * @param {number} pointWidth\n * The pointWidth, already computed upstream\n *\n * @param {Highcharts.ColumnPoint} point\n * The point instance\n *\n * @param {Highcharts.ColumnMetricsObject} metrics\n * The series-wide column metrics\n *\n * @return {number}\n * The adjusted x position, or the original if not adjusted\n */\n adjustForMissingColumns(x, pointWidth, point, metrics) {\n const stacking = this.options.stacking;\n if (!point.isNull && metrics.columnCount > 1) {\n const reversedStacks = this.yAxis.options.reversedStacks;\n let indexInCategory = 0, totalInCategory = reversedStacks ? 0 : -metrics.columnCount;\n // Loop over all the stacks on the Y axis. When stacking is enabled,\n // these are real point stacks. When stacking is not enabled, but\n // `centerInCategory` is true, there is one stack handling the\n // grouping of points in each category. This is done in the\n // `setGroupedPoints` function.\n objectEach(this.yAxis.stacking && this.yAxis.stacking.stacks, (stack) => {\n if (typeof point.x === 'number') {\n const stackItem = stack[point.x.toString()];\n if (stackItem) {\n const pointValues = stackItem.points[this.index];\n // If true `stacking` is enabled, count the total\n // number of non-null stacks in the category, and\n // note which index this point is within those\n // stacks.\n if (stacking) {\n if (pointValues) {\n indexInCategory = totalInCategory;\n }\n if (stackItem.hasValidPoints) {\n reversedStacks ? // #16169\n totalInCategory++ : totalInCategory--;\n }\n // If `stacking` is not enabled, look for the index\n }\n else if (isArray(pointValues)) {\n // If there are multiple points with the same X\n // then gather all series in category, and\n // assign index\n let seriesIndexes = Object\n .keys(stackItem.points)\n .filter((pointKey) => \n // Filter out duplicate X's\n !pointKey.match(',') &&\n // Filter out null points\n stackItem.points[pointKey] &&\n stackItem.points[pointKey].length > 1)\n .map(parseFloat)\n .sort((a, b) => b - a);\n indexInCategory = seriesIndexes.indexOf(this.index);\n totalInCategory = seriesIndexes.length;\n }\n }\n }\n });\n // Compute the adjusted x position\n const boxWidth = (totalInCategory - 1) * metrics.paddedWidth +\n pointWidth;\n x = (point.plotX || 0) + boxWidth / 2 - pointWidth -\n indexInCategory * metrics.paddedWidth;\n }\n return x;\n }\n /**\n * Translate each point to the plot area coordinate system and find\n * shape positions\n *\n * @private\n * @function Highcharts.seriesTypes.column#translate\n */\n translate() {\n const series = this, chart = series.chart, options = series.options, dense = series.dense =\n series.closestPointRange * series.xAxis.transA < 2, borderWidth = series.borderWidth = pick(options.borderWidth, dense ? 0 : 1 // #3635\n ), xAxis = series.xAxis, yAxis = series.yAxis, threshold = options.threshold, minPointLength = pick(options.minPointLength, 5), metrics = series.getColumnMetrics(), seriesPointWidth = metrics.width, seriesXOffset = series.pointXOffset = metrics.offset, dataMin = series.dataMin, dataMax = series.dataMax;\n // postprocessed for border width\n let seriesBarW = series.barW =\n Math.max(seriesPointWidth, 1 + 2 * borderWidth), translatedThreshold = series.translatedThreshold =\n yAxis.getThreshold(threshold);\n if (chart.inverted) {\n translatedThreshold -= 0.5; // #3355\n }\n // When the pointPadding is 0, we want the columns to be packed\n // tightly, so we allow individual columns to have individual sizes.\n // When pointPadding is greater, we strive for equal-width columns\n // (#2694).\n if (options.pointPadding) {\n seriesBarW = Math.ceil(seriesBarW);\n }\n Series.prototype.translate.apply(series);\n // Record the new values\n series.points.forEach(function (point) {\n const yBottom = pick(point.yBottom, translatedThreshold), safeDistance = 999 + Math.abs(yBottom), plotX = point.plotX || 0, \n // Don't draw too far outside plot area (#1303, #2241,\n // #4264)\n plotY = clamp(point.plotY, -safeDistance, yAxis.len + safeDistance), stackBox = point.stackBox;\n let up, barY = Math.min(plotY, yBottom), barH = Math.max(plotY, yBottom) - barY, pointWidth = seriesPointWidth, barX = plotX + seriesXOffset, barW = seriesBarW;\n // Handle options.minPointLength\n if (minPointLength && Math.abs(barH) < minPointLength) {\n barH = minPointLength;\n up = (!yAxis.reversed && !point.negative) ||\n (yAxis.reversed && point.negative);\n // Reverse zeros if there's no positive value in the series\n // in visible range (#7046)\n if (isNumber(threshold) &&\n isNumber(dataMax) &&\n point.y === threshold &&\n dataMax <= threshold &&\n // and if there's room for it (#7311)\n (yAxis.min || 0) < threshold &&\n // if all points are the same value (i.e zero) not draw\n // as negative points (#10646), but only if there's room\n // for it (#14876)\n (dataMin !== dataMax || (yAxis.max || 0) <= threshold)) {\n up = !up;\n point.negative = !point.negative;\n }\n // If stacked...\n barY = (Math.abs(barY - translatedThreshold) > minPointLength ?\n // ...keep position\n yBottom - minPointLength :\n // #1485, #4051\n translatedThreshold -\n (up ? minPointLength : 0));\n }\n // Handle point.options.pointWidth\n // @todo Handle grouping/stacking too. Calculate offset properly\n if (defined(point.options.pointWidth)) {\n pointWidth = barW =\n Math.ceil(point.options.pointWidth);\n barX -= Math.round((pointWidth - seriesPointWidth) / 2);\n }\n // Adjust for null or missing points\n if (options.centerInCategory) {\n barX = series.adjustForMissingColumns(barX, pointWidth, point, metrics);\n }\n // Cache for access in polar\n point.barX = barX;\n point.pointWidth = pointWidth;\n // Fix the tooltip on center of grouped columns (#1216, #424,\n // #3648)\n point.tooltipPos = chart.inverted ?\n [\n clamp(yAxis.len + yAxis.pos - chart.plotLeft - plotY, yAxis.pos - chart.plotLeft, yAxis.len + yAxis.pos - chart.plotLeft),\n xAxis.len + xAxis.pos - chart.plotTop - barX - barW / 2,\n barH\n ] :\n [\n xAxis.left - chart.plotLeft + barX + barW / 2,\n clamp(plotY + yAxis.pos -\n chart.plotTop, yAxis.pos - chart.plotTop, yAxis.len + yAxis.pos - chart.plotTop),\n barH\n ];\n // Register shape type and arguments to be used in drawPoints. Allow\n // `shapeType` defined on `pointClass` level.\n point.shapeType = series.pointClass.prototype.shapeType ||\n 'roundedRect';\n point.shapeArgs = series.crispCol(barX, \n // #3169, drilldown from null must have a position to work from.\n // #6585, dataLabel should be placed on xAxis, not floating in\n // the middle of the chart.\n point.isNull ? translatedThreshold : barY, barW, point.isNull ? 0 : barH);\n });\n // Fire a specific event after column translate. We could instead apply\n // all the column logic in an `afterTranslate` event handler, but there\n // are so many other series types that use the column translation, that\n // it is more convenient to have a specific event for it.\n fireEvent(this, 'afterColumnTranslate');\n }\n /**\n * Columns have no graph\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawGraph\n */\n drawGraph() {\n this.group[this.dense ? 'addClass' : 'removeClass']('highcharts-dense-data');\n }\n /**\n * Get presentational attributes\n *\n * @private\n * @function Highcharts.seriesTypes.column#pointAttribs\n */\n pointAttribs(point, state) {\n const options = this.options, p2o = this.pointAttrToOptions || {}, strokeOption = p2o.stroke || 'borderColor', strokeWidthOption = p2o['stroke-width'] || 'borderWidth';\n let stateOptions, zone, brightness, fill = (point && point.color) || this.color, \n // set to fill when borderColor null:\n stroke = ((point && point[strokeOption]) ||\n options[strokeOption] ||\n fill), dashstyle = (point && point.options.dashStyle) || options.dashStyle, strokeWidth = (point && point[strokeWidthOption]) ||\n options[strokeWidthOption] ||\n this[strokeWidthOption] || 0, opacity = pick(point && point.opacity, options.opacity, 1);\n // Handle zone colors\n if (point && this.zones.length) {\n zone = point.getZone();\n // When zones are present, don't use point.color (#4267).\n // Changed order (#6527), added support for colorAxis (#10670)\n fill = (point.options.color ||\n (zone && (zone.color || point.nonZonedColor)) ||\n this.color);\n if (zone) {\n stroke = zone.borderColor || stroke;\n dashstyle = zone.dashStyle || dashstyle;\n strokeWidth = zone.borderWidth || strokeWidth;\n }\n }\n // Select or hover states\n if (state && point) {\n stateOptions = merge(options.states[state], \n // #6401\n point.options.states &&\n point.options.states[state] ||\n {});\n brightness = stateOptions.brightness;\n fill =\n stateOptions.color || (typeof brightness !== 'undefined' &&\n color(fill)\n .brighten(stateOptions.brightness)\n .get()) || fill;\n stroke = stateOptions[strokeOption] || stroke;\n strokeWidth =\n stateOptions[strokeWidthOption] || strokeWidth;\n dashstyle = stateOptions.dashStyle || dashstyle;\n opacity = pick(stateOptions.opacity, opacity);\n }\n const ret = {\n fill: fill,\n stroke: stroke,\n 'stroke-width': strokeWidth,\n opacity: opacity\n };\n if (dashstyle) {\n ret.dashstyle = dashstyle;\n }\n return ret;\n }\n /**\n * Draw the columns. For bars, the series.group is rotated, so the same\n * coordinates apply for columns and bars. This method is inherited by\n * scatter series.\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawPoints\n */\n drawPoints(points = this.points) {\n const series = this, chart = this.chart, options = series.options, renderer = chart.renderer, animationLimit = options.animationLimit || 250;\n let shapeArgs;\n // draw the columns\n points.forEach(function (point) {\n const plotY = point.plotY;\n let graphic = point.graphic, hasGraphic = !!graphic, verb = graphic && chart.pointCount < animationLimit ?\n 'animate' : 'attr';\n if (isNumber(plotY) && point.y !== null) {\n shapeArgs = point.shapeArgs;\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (graphic && point.hasNewShapeType()) {\n graphic = graphic.destroy();\n }\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = series.xAxis.reversed ?\n -(shapeArgs ? (shapeArgs.width || 0) : 0) :\n series.xAxis.width;\n }\n if (!graphic) {\n point.graphic = graphic =\n renderer[point.shapeType](shapeArgs)\n .add(point.group || series.group);\n if (graphic &&\n series.enabledDataSorting &&\n chart.hasRendered &&\n chart.pointCount < animationLimit) {\n graphic.attr({\n x: point.startXPos\n });\n hasGraphic = true;\n verb = 'animate';\n }\n }\n if (graphic && hasGraphic) { // update\n graphic[verb](merge(shapeArgs));\n }\n // Presentational\n if (!chart.styledMode) {\n graphic[verb](series.pointAttribs(point, (point.selected && 'select')))\n .shadow(point.allowShadow !== false && options.shadow);\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n graphic.attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n });\n }\n /**\n * Draw the tracker for a point.\n * @private\n */\n drawTracker(points = this.points) {\n const series = this, chart = series.chart, pointer = chart.pointer, onMouseOver = function (e) {\n const point = pointer.getPointFromEvent(e);\n // undefined on graph in scatterchart\n if (typeof point !== 'undefined' &&\n series.options.enableMouseTracking) {\n pointer.isDirectTouch = true;\n point.onMouseOver(e);\n }\n };\n let dataLabels;\n // Add reference to the point\n points.forEach(function (point) {\n dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n if (point.graphic) {\n point.graphic.element.point = point;\n }\n dataLabels.forEach(function (dataLabel) {\n if (dataLabel.div) {\n dataLabel.div.point = point;\n }\n else {\n dataLabel.element.point = point;\n }\n });\n });\n // Add the event listeners, we need to do this only once\n if (!series._hasTracking) {\n series.trackerGroups.forEach(function (key) {\n if (series[key]) {\n // we don't always have dataLabelsGroup\n series[key]\n .addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (hasTouch) {\n series[key].on('touchstart', onMouseOver);\n }\n if (!chart.styledMode && series.options.cursor) {\n series[key]\n .css({ cursor: series.options.cursor });\n }\n }\n });\n series._hasTracking = true;\n }\n fireEvent(this, 'afterDrawTracker');\n }\n /**\n * Remove this series from the chart\n *\n * @private\n * @function Highcharts.seriesTypes.column#remove\n */\n remove() {\n const series = this, chart = series.chart;\n // column and bar series affects other series of the same type\n // as they are either stacked or grouped\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n Series.prototype.remove.apply(series, arguments);\n }\n }\n ColumnSeries.defaultOptions = merge(Series.defaultOptions, ColumnSeriesDefaults);\n extend(ColumnSeries.prototype, {\n cropShoulder: 0,\n // When tooltip is not shared, this series (and derivatives) requires\n // direct touch/hover. KD-tree does not apply.\n directTouch: true,\n getSymbol: noop,\n // use separate negative stacks, unlike area stacks where a negative\n // point is substracted from previous (#1910)\n negStacks: true,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('column', ColumnSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Adjusted width and x offset of the columns for grouping.\n *\n * @private\n * @interface Highcharts.ColumnMetricsObject\n */ /**\n * Width of the columns.\n * @name Highcharts.ColumnMetricsObject#width\n * @type {number}\n */ /**\n * Offset of the columns.\n * @name Highcharts.ColumnMetricsObject#offset\n * @type {number}\n */\n ''; // detach doclets above\n\n return ColumnSeries;\n });\n _registerModule(_modules, 'Core/Series/DataLabel.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Templating.js'], _modules['Core/Utilities.js']], function (A, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getDeferredAnimation } = A;\n const { format } = F;\n const { defined, extend, fireEvent, isArray, isString, merge, objectEach, pick, splat } = U;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DataLabel;\n (function (DataLabel) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Align each individual data label.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n const series = this, chart = this.chart, inverted = this.isCartesian && chart.inverted, enabledDataSorting = this.enabledDataSorting, plotX = point.plotX, plotY = point.plotY, rotation = options.rotation, align = options.align, isInsidePlot = defined(plotX) &&\n defined(plotY) &&\n chart.isInsidePlot(plotX, Math.round(plotY), {\n inverted,\n paneCoordinates: true,\n series\n }), setStartPos = (alignOptions) => {\n if (enabledDataSorting && series.xAxis && !justify) {\n series.setDataLabelStartPos(point, dataLabel, isNew, isInsidePlot, alignOptions);\n }\n };\n let baseline, rotCorr, // rotation correction\n // Math.round for rounding errors (#2683), alignTo to allow column\n // labels (#2700)\n alignAttr, // the final position;\n justify = pick(options.overflow, (enabledDataSorting ? 'none' : 'justify')) === 'justify', visible = this.visible &&\n point.visible !== false &&\n defined(plotX) &&\n (point.series.forceDL ||\n (enabledDataSorting && !justify) ||\n isInsidePlot ||\n (\n // If the data label is inside the align box, it is\n // enough that parts of the align box is inside the\n // plot area (#12370). When stacking, it is always\n // inside regardless of the option (#15148).\n pick(options.inside, !!this.options.stacking) &&\n alignTo &&\n chart.isInsidePlot(plotX, inverted ?\n alignTo.x + 1 :\n alignTo.y + alignTo.height - 1, {\n inverted,\n paneCoordinates: true,\n series\n })));\n const pos = point.pos();\n if (visible && pos) {\n if (rotation) {\n dataLabel.attr({ align });\n }\n let bBox = dataLabel.getBBox(true), bBoxCorrection = [0, 0];\n baseline = chart.renderer.fontMetrics(dataLabel).b;\n // The alignment box is a singular point\n alignTo = extend({\n x: pos[0],\n y: Math.round(pos[1]),\n width: 0,\n height: 0\n }, alignTo);\n // Add the text size for alignment calculation\n extend(options, {\n width: bBox.width,\n height: bBox.height\n });\n // Allow a hook for changing alignment in the last moment, then do\n // the alignment\n if (rotation) {\n justify = false; // Not supported for rotated text\n rotCorr = chart.renderer.rotCorr(baseline, rotation); // #3723\n alignAttr = {\n x: (alignTo.x +\n (options.x || 0) +\n alignTo.width / 2 +\n rotCorr.x),\n y: (alignTo.y +\n (options.y || 0) +\n { top: 0, middle: 0.5, bottom: 1 }[options.verticalAlign] *\n alignTo.height)\n };\n bBoxCorrection = [\n bBox.x - Number(dataLabel.attr('x')),\n bBox.y - Number(dataLabel.attr('y'))\n ];\n setStartPos(alignAttr); // data sorting\n dataLabel[isNew ? 'attr' : 'animate'](alignAttr);\n }\n else {\n setStartPos(alignTo); // data sorting\n dataLabel.align(options, void 0, alignTo);\n alignAttr = dataLabel.alignAttr;\n }\n // Handle justify or crop\n if (justify && alignTo.height >= 0) { // #8830\n this.justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew);\n // Now check that the data label is within the plot area\n }\n else if (pick(options.crop, true)) {\n let { x, y } = alignAttr;\n x += bBoxCorrection[0];\n y += bBoxCorrection[1];\n // Uncomment this block to visualize the bounding boxes used for\n // determining visibility\n /*\n chart.renderer.rect(\n chart.plotLeft + alignAttr.x + bBox.x,\n chart.plotTop + alignAttr.y + bBox.y + 9999,\n bBox.width,\n bBox.height\n ).attr({\n stroke: 'rgba(0, 0, 0, 0.3)',\n 'stroke-width': 0.5\n }).add();\n chart.renderer.circle(\n chart.plotLeft + alignAttr.x,\n chart.plotTop + alignAttr.y,\n 2\n ).attr({\n fill: 'red',\n zIndex: 20\n }).add();\n // */\n visible =\n chart.isInsidePlot(x, y, {\n paneCoordinates: true,\n series\n }) &&\n chart.isInsidePlot(x + bBox.width, y + bBox.height, {\n paneCoordinates: true,\n series\n });\n }\n // When we're using a shape, make it possible with a connector or an\n // arrow pointing to thie point\n if (options.shape && !rotation) {\n dataLabel[isNew ? 'attr' : 'animate']({\n anchorX: pos[0],\n anchorY: pos[1]\n });\n }\n }\n // To use alignAttr property in hideOverlappingLabels\n if (isNew && enabledDataSorting) {\n dataLabel.placed = false;\n }\n // Show or hide based on the final aligned position\n if (!visible && (!enabledDataSorting || justify)) {\n dataLabel.hide();\n dataLabel.placed = false; // don't animate back in\n }\n else {\n dataLabel.show();\n }\n }\n /**\n * Handle the dataLabels.filter option.\n * @private\n */\n function applyFilter(point, options) {\n const filter = options.filter;\n if (filter) {\n const op = filter.operator;\n const prop = point[filter.property];\n const val = filter.value;\n if ((op === '>' && prop > val) ||\n (op === '<' && prop < val) ||\n (op === '>=' && prop >= val) ||\n (op === '<=' && prop <= val) ||\n (op === '==' && prop == val) || // eslint-disable-line eqeqeq\n (op === '===' && prop === val)) {\n return true;\n }\n return false;\n }\n return true;\n }\n /**\n * @private\n */\n function compose(SeriesClass) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.initDataLabelsGroup = initDataLabelsGroup;\n seriesProto.initDataLabels = initDataLabels;\n seriesProto.alignDataLabel = alignDataLabel;\n seriesProto.drawDataLabels = drawDataLabels;\n seriesProto.justifyDataLabel = justifyDataLabel;\n seriesProto.setDataLabelStartPos = setDataLabelStartPos;\n }\n }\n DataLabel.compose = compose;\n /**\n * Create the SVGElement group for dataLabels\n * @private\n */\n function initDataLabelsGroup() {\n return this.plotGroup('dataLabelsGroup', 'data-labels', this.hasRendered ? 'inherit' : 'hidden', // #5133, #10220\n this.options.dataLabels.zIndex || 6);\n }\n /**\n * Init the data labels with the correct animation\n * @private\n */\n function initDataLabels(animationConfig) {\n const series = this, hasRendered = series.hasRendered || 0;\n // Create a separate group for the data labels to avoid rotation\n const dataLabelsGroup = this.initDataLabelsGroup()\n .attr({ opacity: +hasRendered }); // #3300\n if (!hasRendered && dataLabelsGroup) {\n if (series.visible) { // #2597, #3023, #3024\n dataLabelsGroup.show();\n }\n if (series.options.animation) {\n dataLabelsGroup.animate({ opacity: 1 }, animationConfig);\n }\n else {\n dataLabelsGroup.attr({ opacity: 1 });\n }\n }\n return dataLabelsGroup;\n }\n /**\n * Draw the data labels\n * @private\n */\n function drawDataLabels(points = this.points) {\n var _a,\n _b;\n const series = this, chart = series.chart, seriesOptions = series.options, renderer = chart.renderer, { backgroundColor, plotBackgroundColor } = chart.options.chart, plotOptions = chart.options.plotOptions, contrastColor = renderer.getContrast((isString(plotBackgroundColor) && plotBackgroundColor) ||\n (isString(backgroundColor) && backgroundColor) ||\n \"#000000\" /* Palette.neutralColor100 */);\n let seriesDlOptions = seriesOptions.dataLabels, pointOptions, dataLabelsGroup;\n const firstDLOptions = splat(seriesDlOptions)[0], dataLabelAnim = firstDLOptions.animation, animationConfig = firstDLOptions.defer ?\n getDeferredAnimation(chart, dataLabelAnim, series) :\n { defer: 0, duration: 0 };\n // Merge in plotOptions.dataLabels for series\n seriesDlOptions = mergeArrays(mergeArrays((_a = plotOptions === null || plotOptions === void 0 ? void 0 : plotOptions.series) === null || _a === void 0 ? void 0 : _a.dataLabels, (_b = plotOptions === null || plotOptions === void 0 ? void 0 : plotOptions[series.type]) === null || _b === void 0 ? void 0 : _b.dataLabels), seriesDlOptions);\n fireEvent(this, 'drawDataLabels');\n if (isArray(seriesDlOptions) ||\n seriesDlOptions.enabled ||\n series._hasPointLabels) {\n dataLabelsGroup = this.initDataLabels(animationConfig);\n // Make the labels for each point\n points.forEach((point) => {\n var _a;\n const dataLabels = point.dataLabels || [];\n // Merge in series options for the point.\n // @note dataLabelAttribs (like pointAttribs) would eradicate\n // the need for dlOptions, and simplify the section below.\n pointOptions = splat(mergeArrays(seriesDlOptions, \n // dlOptions is used in treemaps\n point.dlOptions || ((_a = point.options) === null || _a === void 0 ? void 0 : _a.dataLabels)));\n // Handle each individual data label for this point\n pointOptions.forEach((labelOptions, i) => {\n var _a;\n // Options for one datalabel\n const labelEnabled = (labelOptions.enabled &&\n // #2282, #4641, #7112, #10049\n (!point.isNull || point.dataLabelOnNull) &&\n applyFilter(point, labelOptions)), connector = point.connectors ?\n point.connectors[i] :\n point.connector, style = labelOptions.style || {};\n let labelConfig, formatString, labelText, rotation, attr = {}, dataLabel = dataLabels[i], isNew = !dataLabel;\n const labelDistance = pick(labelOptions.distance, point.labelDistance);\n if (labelEnabled) {\n // Create individual options structure that can be\n // extended without affecting others\n formatString = pick(labelOptions[point.formatPrefix + 'Format'], labelOptions.format);\n labelConfig = point.getLabelConfig();\n labelText = defined(formatString) ?\n format(formatString, labelConfig, chart) :\n (labelOptions[point.formatPrefix + 'Formatter'] ||\n labelOptions.formatter).call(labelConfig, labelOptions);\n rotation = labelOptions.rotation;\n if (!chart.styledMode) {\n // Determine the color\n style.color = pick(labelOptions.color, style.color, isString(series.color) ? series.color : void 0, \"#000000\" /* Palette.neutralColor100 */);\n // Get automated contrast color\n if (style.color === 'contrast') {\n point.contrastColor = renderer.getContrast((point.color || series.color));\n style.color = ((!defined(labelDistance) &&\n labelOptions.inside) ||\n (labelDistance || 0) < 0 ||\n seriesOptions.stacking) ?\n point.contrastColor :\n contrastColor;\n }\n else {\n delete point.contrastColor;\n }\n if (seriesOptions.cursor) {\n style.cursor = seriesOptions.cursor;\n }\n }\n attr = {\n r: labelOptions.borderRadius || 0,\n rotation,\n padding: labelOptions.padding,\n zIndex: 1\n };\n if (!chart.styledMode) {\n const { backgroundColor, borderColor } = labelOptions;\n attr.fill = backgroundColor === 'auto' ?\n point.color :\n backgroundColor;\n attr.stroke = borderColor === 'auto' ?\n point.color :\n borderColor;\n attr['stroke-width'] = labelOptions.borderWidth;\n }\n // Remove unused attributes (#947)\n objectEach(attr, (val, name) => {\n if (typeof val === 'undefined') {\n delete attr[name];\n }\n });\n }\n // If the point is outside the plot area, or the label\n // changes properties that we cannot change, destroy it and\n // build a new one below. #678, #820.\n if (dataLabel && (!labelEnabled ||\n !defined(labelText) ||\n !!dataLabel.div !== !!labelOptions.useHTML ||\n (\n // Change from no rotation to rotation and\n // vice versa. Don't use defined() because\n // rotation = 0 means also rotation = undefined\n (!dataLabel.rotation ||\n !labelOptions.rotation) &&\n dataLabel.rotation !== labelOptions.rotation))) {\n dataLabel = void 0;\n isNew = true;\n if (connector && point.connector) {\n point.connector = point.connector.destroy();\n if (point.connectors) {\n // Remove point.connectors if this was the last\n // one\n if (point.connectors.length === 1) {\n delete point.connectors;\n }\n else {\n delete point.connectors[i];\n }\n }\n }\n }\n // Individual labels are disabled if the are explicitly\n // disabled in the point options, or if they fall outside\n // the plot area.\n if (labelEnabled && defined(labelText)) {\n if (!dataLabel) {\n // Create new label element\n dataLabel = rotation ?\n // Labels don't rotate, use text element\n renderer.text(labelText, 0, 0, labelOptions.useHTML)\n .addClass('highcharts-data-label') :\n // We can use label\n renderer.label(labelText, 0, 0, labelOptions.shape, void 0, void 0, labelOptions.useHTML, void 0, 'data-label');\n if (dataLabel) {\n dataLabel.addClass(' highcharts-data-label-color-' +\n point.colorIndex +\n ' ' + (labelOptions.className || '') +\n ( // #3398\n labelOptions.useHTML ?\n ' highcharts-tracker' :\n ''));\n }\n }\n else {\n // Use old element and just update text\n attr.text = labelText;\n }\n // Store data label options for later access\n if (dataLabel) {\n dataLabel.options = labelOptions;\n dataLabel.attr(attr);\n if (!chart.styledMode) {\n // Styles must be applied before add in order to\n // read text bounding box\n dataLabel.css(style).shadow(labelOptions.shadow);\n }\n const textPathOptions = labelOptions[point.formatPrefix + 'TextPath'] || labelOptions.textPath;\n if (textPathOptions && !labelOptions.useHTML) {\n dataLabel.setTextPath(((_a = point.getDataLabelPath) === null || _a === void 0 ? void 0 : _a.call(point, dataLabel)) ||\n point.graphic, textPathOptions);\n if (point.dataLabelPath &&\n !textPathOptions.enabled) {\n // clean the DOM\n point.dataLabelPath = (point.dataLabelPath.destroy());\n }\n }\n if (!dataLabel.added) {\n dataLabel.add(dataLabelsGroup);\n }\n // Now the data label is created and placed at 0,0,\n // so we need to align it\n series.alignDataLabel(point, dataLabel, labelOptions, void 0, isNew);\n dataLabel.isActive = true;\n if (dataLabels[i] && dataLabels[i] !== dataLabel) {\n dataLabels[i].destroy();\n }\n dataLabels[i] = dataLabel;\n }\n }\n });\n // Destroy and remove the inactive ones\n let j = dataLabels.length;\n while (j--) {\n if (dataLabels[j].isActive) {\n dataLabels[j].isActive = false;\n }\n else {\n dataLabels[j].destroy();\n dataLabels.splice(j, 1);\n }\n }\n // Write back\n point.dataLabel = dataLabels[0];\n point.dataLabels = dataLabels;\n });\n }\n fireEvent(this, 'afterDrawDataLabels');\n }\n /**\n * If data labels fall partly outside the plot area, align them back in, in\n * a way that doesn't hide the point.\n * @private\n */\n function justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew) {\n const chart = this.chart, align = options.align, verticalAlign = options.verticalAlign, padding = dataLabel.box ? 0 : (dataLabel.padding || 0);\n let { x = 0, y = 0 } = options, off, justified;\n // Off left\n off = (alignAttr.x || 0) + padding;\n if (off < 0) {\n if (align === 'right' && x >= 0) {\n options.align = 'left';\n options.inside = true;\n }\n else {\n x -= off;\n }\n justified = true;\n }\n // Off right\n off = (alignAttr.x || 0) + bBox.width - padding;\n if (off > chart.plotWidth) {\n if (align === 'left' && x <= 0) {\n options.align = 'right';\n options.inside = true;\n }\n else {\n x += chart.plotWidth - off;\n }\n justified = true;\n }\n // Off top\n off = alignAttr.y + padding;\n if (off < 0) {\n if (verticalAlign === 'bottom' && y >= 0) {\n options.verticalAlign = 'top';\n options.inside = true;\n }\n else {\n y -= off;\n }\n justified = true;\n }\n // Off bottom\n off = (alignAttr.y || 0) + bBox.height - padding;\n if (off > chart.plotHeight) {\n if (verticalAlign === 'top' && y <= 0) {\n options.verticalAlign = 'bottom';\n options.inside = true;\n }\n else {\n y += chart.plotHeight - off;\n }\n justified = true;\n }\n if (justified) {\n options.x = x;\n options.y = y;\n dataLabel.placed = !isNew;\n dataLabel.align(options, void 0, alignTo);\n }\n return justified;\n }\n /**\n * Merge two objects that can be arrays. If one of them is an array, the\n * other is merged into each element. If both are arrays, each element is\n * merged by index. If neither are arrays, we use normal merge.\n * @private\n */\n function mergeArrays(one, two) {\n let res = [], i;\n if (isArray(one) && !isArray(two)) {\n res = one.map(function (el) {\n return merge(el, two);\n });\n }\n else if (isArray(two) && !isArray(one)) {\n res = two.map(function (el) {\n return merge(one, el);\n });\n }\n else if (!isArray(one) && !isArray(two)) {\n res = merge(one, two);\n }\n else if (isArray(one) && isArray(two)) {\n i = Math.max(one.length, two.length);\n while (i--) {\n res[i] = merge(one[i], two[i]);\n }\n }\n return res;\n }\n /**\n * Set starting position for data label sorting animation.\n * @private\n */\n function setDataLabelStartPos(point, dataLabel, isNew, isInside, alignOptions) {\n const chart = this.chart, inverted = chart.inverted, xAxis = this.xAxis, reversed = xAxis.reversed, labelCenter = inverted ? dataLabel.height / 2 : dataLabel.width / 2, pointWidth = point.pointWidth, halfWidth = pointWidth ? pointWidth / 2 : 0;\n dataLabel.startXPos = inverted ?\n alignOptions.x :\n (reversed ?\n -labelCenter - halfWidth :\n xAxis.width - labelCenter + halfWidth);\n dataLabel.startYPos = inverted ?\n (reversed ?\n this.yAxis.height - labelCenter + halfWidth :\n -labelCenter - halfWidth) : alignOptions.y;\n // We need to handle visibility in case of sorting point outside plot\n // area\n if (!isInside) {\n dataLabel\n .attr({ opacity: 1 })\n .animate({ opacity: 0 }, void 0, dataLabel.hide);\n }\n else if (dataLabel.visibility === 'hidden') {\n dataLabel.show();\n dataLabel\n .attr({ opacity: 0 })\n .animate({ opacity: 1 });\n }\n // Save start position on first render, but do not change position\n if (!chart.hasRendered) {\n return;\n }\n // Set start position\n if (isNew) {\n dataLabel.attr({ x: dataLabel.startXPos, y: dataLabel.startYPos });\n }\n dataLabel.placed = true;\n }\n })(DataLabel || (DataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback JavaScript function to format the data label as a string. Note that\n * if a `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @callback Highcharts.DataLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.PointLabelObject} this\n * Data label context to format\n *\n * @param {Highcharts.DataLabelsOptions} options\n * [API options](/highcharts/plotOptions.series.dataLabels) of the data label\n *\n * @return {number|string|null|undefined}\n * Formatted data label text\n */\n /**\n * Values for handling data labels that flow outside the plot area.\n *\n * @typedef {\"allow\"|\"justify\"} Highcharts.DataLabelsOverflowValue\n */\n ''; // keeps doclets above in JS file\n\n return DataLabel;\n });\n _registerModule(_modules, 'Series/Column/ColumnDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { series: Series } = SeriesRegistry;\n const { merge, pick } = U;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Override the basic data label alignment by adjusting for the position of\n * the column.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n let inverted = this.chart.inverted, series = point.series, xLen = (series.xAxis ? series.xAxis.len : this.chart.plotSizeX) || 0, yLen = (series.yAxis ? series.yAxis.len : this.chart.plotSizeY) || 0, \n // data label box for alignment\n dlBox = point.dlBox || point.shapeArgs, below = pick(point.below, // range series\n point.plotY >\n pick(this.translatedThreshold, yLen)), \n // draw it inside the box?\n inside = pick(options.inside, !!this.options.stacking), overshoot;\n // Align to the column itself, or the top of it\n if (dlBox) { // Area range uses this method but not alignTo\n alignTo = merge(dlBox);\n if (alignTo.y < 0) {\n alignTo.height += alignTo.y;\n alignTo.y = 0;\n }\n // If parts of the box overshoots outside the plot area, modify the\n // box to center the label inside\n overshoot = alignTo.y + alignTo.height - yLen;\n if (overshoot > 0 && overshoot < alignTo.height) {\n alignTo.height -= overshoot;\n }\n if (inverted) {\n alignTo = {\n x: yLen - alignTo.y - alignTo.height,\n y: xLen - alignTo.x - alignTo.width,\n width: alignTo.height,\n height: alignTo.width\n };\n }\n // Compute the alignment box\n if (!inside) {\n if (inverted) {\n alignTo.x += below ? 0 : alignTo.width;\n alignTo.width = 0;\n }\n else {\n alignTo.y += below ? alignTo.height : 0;\n alignTo.height = 0;\n }\n }\n }\n // When alignment is undefined (typically columns and bars), display the\n // individual point below or above the point depending on the threshold\n options.align = pick(options.align, !inverted || inside ? 'center' : below ? 'right' : 'left');\n options.verticalAlign = pick(options.verticalAlign, inverted || inside ? 'middle' : below ? 'top' : 'bottom');\n // Call the parent method\n Series.prototype.alignDataLabel.call(this, point, dataLabel, options, alignTo, isNew);\n // If label was justified and we have contrast, set it:\n if (options.inside && point.contrastColor) {\n dataLabel.css({\n color: point.contrastColor\n });\n }\n }\n /** @private */\n function compose(ColumnSeriesClass) {\n DataLabel.compose(Series);\n if (U.pushUnique(composedMembers, ColumnSeriesClass)) {\n ColumnSeriesClass.prototype.alignDataLabel = alignDataLabel;\n }\n }\n ColumnDataLabel.compose = compose;\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Series/Bar/BarSeries.js', [_modules['Series/Column/ColumnSeries.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ColumnSeries, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Bar series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.bar\n *\n * @augments Highcharts.Series\n */\n class BarSeries extends ColumnSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n }\n /**\n * A bar series is a special type of column series where the columns are\n * horizontal.\n *\n * @sample highcharts/demo/bar-basic/\n * Bar chart\n *\n * @extends plotOptions.column\n * @product highcharts\n * @optionparent plotOptions.bar\n */\n BarSeries.defaultOptions = merge(ColumnSeries.defaultOptions, {\n // nothing here yet\n });\n extend(BarSeries.prototype, {\n inverted: true\n });\n SeriesRegistry.registerSeriesType('bar', BarSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `bar` series. If the [type](#series.bar.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.bar\n * @excluding connectNulls, dashStyle, dataParser, dataURL, gapSize, gapUnit,\n * linecap, lineWidth, marker, connectEnds, step\n * @product highcharts\n * @apioption series.bar\n */\n /**\n * An array of data points for the series. For the `bar` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 5],\n * [1, 10],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.bar.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 10,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.column.data\n * @product highcharts\n * @apioption series.bar.data\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.hover\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.select\n */\n ''; // gets doclets above into transpilat\n\n return BarSeries;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A scatter plot uses cartesian coordinates to display values for two\n * variables for a set of data.\n *\n * @sample {highcharts} highcharts/demo/scatter/\n * Scatter plot\n *\n * @extends plotOptions.line\n * @excluding cropThreshold, pointPlacement, shadow, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.scatter\n */\n const ScatterSeriesDefaults = {\n /**\n * The width of the line connecting the data points.\n *\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-none/\n * 0 by default\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-1/\n * 1px\n *\n * @product highcharts highstock\n */\n lineWidth: 0,\n findNearestPointBy: 'xy',\n /**\n * Apply a jitter effect for the rendered markers. When plotting\n * discrete values, a little random noise may help telling the points\n * apart. The jitter setting applies a random displacement of up to `n`\n * axis units in either direction. So for example on a horizontal X\n * axis, setting the `jitter.x` to 0.24 will render the point in a\n * random position between 0.24 units to the left and 0.24 units to the\n * right of the true axis position. On a category axis, setting it to\n * 0.5 will fill up the bin and make the data appear continuous.\n *\n * When rendered on top of a box plot or a column series, a jitter value\n * of 0.24 will correspond to the underlying series' default\n * [groupPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.groupPadding)\n * and [pointPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.pointPadding)\n * settings.\n *\n * @sample {highcharts} highcharts/demo/scatter-jitter\n * Jitter on a scatter plot\n *\n * @sample {highcharts} highcharts/series-scatter/jitter-boxplot\n * Jittered scatter plot on top of a box plot\n *\n * @product highcharts highstock\n * @since 7.0.2\n */\n jitter: {\n /**\n * The maximal X offset for the random jitter effect.\n */\n x: 0,\n /**\n * The maximal Y offset for the random jitter effect.\n */\n y: 0\n },\n marker: {\n enabled: true // Overrides auto-enabling in line series (#3647)\n },\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series, or out of the plot area. When false, the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock highmaps\n * @apioption plotOptions.scatter.stickyTracking\n */\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip).\n * Overridable properties are `headerFormat`, `pointFormat`,\n * `yDecimals`, `xDateFormat`, `yPrefix` and `ySuffix`. Unlike other\n * series, in a scatter plot the series.name by default shows in the\n * headerFormat and point.x and point.y in the pointFormat.\n *\n * @product highcharts highstock highmaps\n */\n tooltip: {\n /**\n * @product highcharts highstock\n */\n headerFormat: '\\u25CF ' +\n ' {series.name}
',\n pointFormat: 'x: {point.x}
y: {point.y}
'\n }\n };\n /**\n * A `scatter` series. If the [type](#series.scatter.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.scatter\n * @excluding cropThreshold, dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.scatter\n */\n /**\n * An array of data points for the series. For the `scatter` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 0],\n * [1, 8],\n * [2, 9]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.scatter.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.scatter.data\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeries.js', [_modules['Series/Scatter/ScatterSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ScatterSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: ColumnSeries, line: LineSeries } = SeriesRegistry.seriesTypes;\n const { addEvent, extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Scatter series type.\n *\n * @private\n */\n class ScatterSeries extends LineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Optionally add the jitter effect.\n * @private\n */\n applyJitter() {\n const series = this, jitter = this.options.jitter, len = this.points.length;\n /**\n * Return a repeatable, pseudo-random number based on an integer\n * seed.\n * @private\n */\n function unrandom(seed) {\n const rand = Math.sin(seed) * 10000;\n return rand - Math.floor(rand);\n }\n if (jitter) {\n this.points.forEach(function (point, i) {\n ['x', 'y'].forEach(function (dim, j) {\n let axis, plotProp = 'plot' + dim.toUpperCase(), min, max, translatedJitter;\n if (jitter[dim] && !point.isNull) {\n axis = series[dim + 'Axis'];\n translatedJitter =\n jitter[dim] * axis.transA;\n if (axis && !axis.isLog) {\n // Identify the outer bounds of the jitter range\n min = Math.max(0, point[plotProp] - translatedJitter);\n max = Math.min(axis.len, point[plotProp] + translatedJitter);\n // Find a random position within this range\n point[plotProp] = min +\n (max - min) * unrandom(i + j * len);\n // Update clientX for the tooltip k-d-tree\n if (dim === 'x') {\n point.clientX = point.plotX;\n }\n }\n }\n });\n });\n }\n }\n /**\n * @private\n */\n drawGraph() {\n if (this.options.lineWidth) {\n super.drawGraph();\n }\n else if (this.graph) {\n this.graph = this.graph.destroy();\n }\n }\n }\n ScatterSeries.defaultOptions = merge(LineSeries.defaultOptions, ScatterSeriesDefaults);\n extend(ScatterSeries.prototype, {\n drawTracker: ColumnSeries.prototype.drawTracker,\n sorted: false,\n requireSorting: false,\n noSharedTooltip: true,\n trackerGroups: ['group', 'markerGroup', 'dataLabelsGroup'],\n takeOrdinalPosition: false // #2342\n });\n /* *\n *\n * Events\n *\n * */\n /* eslint-disable no-invalid-this */\n addEvent(ScatterSeries, 'afterTranslate', function () {\n this.applyJitter();\n });\n SeriesRegistry.registerSeriesType('scatter', ScatterSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeries;\n });\n _registerModule(_modules, 'Series/CenteredUtilities.js', [_modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (H, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { deg2rad } = H;\n const { fireEvent, isNumber, pick, relativeLength } = U;\n /**\n * @private\n */\n var CenteredUtilities;\n (function (CenteredUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the center of the pie based on the size and center options relative\n * to the plot area. Borrowed by the polar and gauge series types.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getCenter\n */\n function getCenter() {\n const options = this.options, chart = this.chart, slicingRoom = 2 * (options.slicedOffset || 0), plotWidth = chart.plotWidth - 2 * slicingRoom, plotHeight = chart.plotHeight - 2 * slicingRoom, centerOption = options.center, smallestSize = Math.min(plotWidth, plotHeight), thickness = options.thickness;\n let handleSlicingRoom, size = options.size, innerSize = options.innerSize || 0, i, value;\n if (typeof size === 'string') {\n size = parseFloat(size);\n }\n if (typeof innerSize === 'string') {\n innerSize = parseFloat(innerSize);\n }\n const positions = [\n pick(centerOption[0], '50%'),\n pick(centerOption[1], '50%'),\n // Prevent from negative values\n pick(size && size < 0 ? void 0 : options.size, '100%'),\n pick(innerSize && innerSize < 0 ? void 0 : options.innerSize || 0, '0%')\n ];\n // No need for inner size in angular (gauges) series but still required\n // for pie series\n if (chart.angular && !(this instanceof Series)) {\n positions[3] = 0;\n }\n for (i = 0; i < 4; ++i) {\n value = positions[i];\n handleSlicingRoom = i < 2 || (i === 2 && /%$/.test(value));\n // i == 0: centerX, relative to width\n // i == 1: centerY, relative to height\n // i == 2: size, relative to smallestSize\n // i == 3: innerSize, relative to size\n positions[i] = relativeLength(value, [plotWidth, plotHeight, smallestSize, positions[2]][i]) + (handleSlicingRoom ? slicingRoom : 0);\n }\n // innerSize cannot be larger than size (#3632)\n if (positions[3] > positions[2]) {\n positions[3] = positions[2];\n }\n // thickness overrides innerSize, need to be less than pie size (#6647)\n if (isNumber(thickness) &&\n thickness * 2 < positions[2] && thickness > 0) {\n positions[3] = positions[2] - thickness * 2;\n }\n fireEvent(this, 'afterGetCenter', { positions });\n return positions;\n }\n CenteredUtilities.getCenter = getCenter;\n /**\n * getStartAndEndRadians - Calculates start and end angles in radians.\n * Used in series types such as pie and sunburst.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getStartAndEndRadians\n *\n * @param {number} [start]\n * Start angle in degrees.\n *\n * @param {number} [end]\n * Start angle in degrees.\n *\n * @return {Highcharts.RadianAngles}\n * Returns an object containing start and end angles as radians.\n */\n function getStartAndEndRadians(start, end) {\n const startAngle = isNumber(start) ? start : 0, // must be a number\n endAngle = ((isNumber(end) && // must be a number\n end > startAngle && // must be larger than the start angle\n // difference must be less than 360 degrees\n (end - startAngle) < 360) ?\n end :\n startAngle + 360), correction = -90;\n return {\n start: deg2rad * (startAngle + correction),\n end: deg2rad * (endAngle + correction)\n };\n }\n CenteredUtilities.getStartAndEndRadians = getStartAndEndRadians;\n })(CenteredUtilities || (CenteredUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @private\n * @interface Highcharts.RadianAngles\n */ /**\n * @name Highcharts.RadianAngles#end\n * @type {number}\n */ /**\n * @name Highcharts.RadianAngles#start\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return CenteredUtilities;\n });\n _registerModule(_modules, 'Series/Pie/PiePoint.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (A, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { setAnimation } = A;\n const { addEvent, defined, extend, isNumber, pick, relativeLength } = U;\n /* *\n *\n * Class\n *\n * */\n class PiePoint extends Point {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.labelDistance = void 0;\n this.options = void 0;\n this.series = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Extendable method for getting the path of the connector between the\n * data label and the pie slice.\n * @private\n */\n getConnectorPath() {\n const labelPosition = this.labelPosition, options = this.series.options.dataLabels, predefinedShapes = this.connectorShapes;\n let connectorShape = options.connectorShape;\n // find out whether to use the predefined shape\n if (predefinedShapes[connectorShape]) {\n connectorShape = predefinedShapes[connectorShape];\n }\n return connectorShape.call(this, {\n // pass simplified label position object for user's convenience\n x: labelPosition.computed.x,\n y: labelPosition.computed.y,\n alignment: labelPosition.alignment\n }, labelPosition.connectorPosition, options);\n }\n /**\n * @private\n */\n getTranslate() {\n return this.sliced ? this.slicedTranslation : {\n translateX: 0,\n translateY: 0\n };\n }\n /**\n * @private\n */\n haloPath(size) {\n const shapeArgs = this.shapeArgs;\n return this.sliced || !this.visible ?\n [] :\n this.series.chart.renderer.symbols.arc(shapeArgs.x, shapeArgs.y, shapeArgs.r + size, shapeArgs.r + size, {\n // Substract 1px to ensure the background is not bleeding\n // through between the halo and the slice (#7495).\n innerR: shapeArgs.r - 1,\n start: shapeArgs.start,\n end: shapeArgs.end,\n borderRadius: shapeArgs.borderRadius\n });\n }\n /**\n * Initialize the pie slice.\n * @private\n */\n init() {\n super.init.apply(this, arguments);\n this.name = pick(this.name, 'Slice');\n // add event listener for select\n const toggleSlice = (e) => {\n this.slice(e.type === 'select');\n };\n addEvent(this, 'select', toggleSlice);\n addEvent(this, 'unselect', toggleSlice);\n return this;\n }\n /**\n * Negative points are not valid (#1530, #3623, #5322)\n * @private\n */\n isValid() {\n return isNumber(this.y) && this.y >= 0;\n }\n /**\n * Toggle the visibility of a pie slice or other data point. Note that this\n * method is available only for some series, like pie, treemap and sunburst.\n *\n * @function Highcharts.Point#setVisible\n *\n * @param {boolean} [vis]\n * True to show the pie slice or other data point, false to hide. If\n * undefined, the visibility is toggled.\n *\n * @param {boolean} [redraw] Whether to redraw the chart after the point is\n * altered. If doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw|chart.redraw()} after.\n *\n */\n setVisible(vis, redraw) {\n const series = this.series, chart = series.chart, ignoreHiddenPoint = series.options.ignoreHiddenPoint;\n redraw = pick(redraw, ignoreHiddenPoint);\n if (vis !== this.visible) {\n // If called without an argument, toggle visibility\n this.visible = this.options.visible = vis =\n typeof vis === 'undefined' ? !this.visible : vis;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n // Show and hide associated elements. This is performed\n // regardless of redraw or not, because chart.redraw only\n // handles full series.\n ['graphic', 'dataLabel', 'connector'].forEach((key) => {\n if (this[key]) {\n this[key][vis ? 'show' : 'hide'](vis);\n }\n });\n if (this.legendItem) {\n chart.legend.colorizeItem(this, vis);\n }\n // #4170, hide halo after hiding point\n if (!vis && this.state === 'hover') {\n this.setState('');\n }\n // Handle ignore hidden slices\n if (ignoreHiddenPoint) {\n series.isDirty = true;\n }\n if (redraw) {\n chart.redraw();\n }\n }\n }\n /**\n * Set or toggle whether the slice is cut out from the pie.\n * @private\n *\n * @param {boolean} sliced\n * When undefined, the slice state is toggled.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart. True by default.\n *\n * @param {boolean|Partial} [animation]\n * Animation options.\n */\n slice(sliced, redraw, animation) {\n const series = this.series, chart = series.chart;\n setAnimation(animation, chart);\n // redraw is true by default\n redraw = pick(redraw, true);\n /**\n * Pie series only. Whether to display a slice offset from the\n * center.\n * @name Highcharts.Point#sliced\n * @type {boolean|undefined}\n */\n // if called without an argument, toggle\n this.sliced = this.options.sliced = sliced =\n defined(sliced) ? sliced : !this.sliced;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n if (this.graphic) {\n this.graphic.animate(this.getTranslate());\n }\n }\n }\n extend(PiePoint.prototype, {\n connectorShapes: {\n // only one available before v7.0.0\n fixedOffset: function (labelPosition, connectorPosition, options) {\n const breakAt = connectorPosition.breakAt, touchingSliceAt = connectorPosition.touchingSliceAt, lineSegment = options.softConnector ? [\n 'C',\n // 1st control point (of the curve)\n labelPosition.x +\n // 5 gives the connector a little horizontal bend\n (labelPosition.alignment === 'left' ? -5 : 5),\n labelPosition.y,\n 2 * breakAt.x - touchingSliceAt.x,\n 2 * breakAt.y - touchingSliceAt.y,\n breakAt.x,\n breakAt.y //\n ] : [\n 'L',\n breakAt.x,\n breakAt.y\n ];\n // assemble the path\n return ([\n ['M', labelPosition.x, labelPosition.y],\n lineSegment,\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ]);\n },\n straight: function (labelPosition, connectorPosition) {\n const touchingSliceAt = connectorPosition.touchingSliceAt;\n // direct line to the slice\n return [\n ['M', labelPosition.x, labelPosition.y],\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ];\n },\n crookedLine: function (labelPosition, connectorPosition, options) {\n const { breakAt, touchingSliceAt } = connectorPosition, { series } = this, [cx, cy, diameter] = series.center, r = diameter / 2, plotWidth = series.chart.plotWidth, plotLeft = series.chart.plotLeft, leftAligned = labelPosition.alignment === 'left', { x, y } = labelPosition;\n let crookX = breakAt.x;\n if (options.crookDistance) {\n const crookDistance = relativeLength(// % to fraction\n options.crookDistance, 1);\n crookX = leftAligned ?\n cx +\n r +\n (plotWidth + plotLeft - cx - r) * (1 - crookDistance) :\n plotLeft + (cx - r) * crookDistance;\n // When the crookDistance option is undefined, make the bend in the\n // intersection between the radial line in the middle of the slice,\n // and the extension of the label position.\n }\n else {\n crookX = cx + (cy - y) * Math.tan((this.angle || 0) - Math.PI / 2);\n }\n const path = [['M', x, y]];\n // The crookedLine formula doesn't make sense if the path overlaps\n // the label - use straight line instead in that case\n if (leftAligned ?\n (crookX <= x && crookX >= breakAt.x) :\n (crookX >= x && crookX <= breakAt.x)) {\n path.push(['L', crookX, y]);\n }\n path.push(['L', breakAt.x, breakAt.y], ['L', touchingSliceAt.x, touchingSliceAt.y]);\n return path;\n }\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return PiePoint;\n });\n _registerModule(_modules, 'Series/Pie/PieSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A pie chart is a circular graphic which is divided into slices to\n * illustrate numerical proportion.\n *\n * @sample highcharts/demo/pie-basic/\n * Pie chart\n *\n * @extends plotOptions.line\n * @excluding animationLimit, boostThreshold, connectEnds, connectNulls,\n * cropThreshold, dashStyle, dataSorting, dragDrop,\n * findNearestPointBy, getExtremesFromAll, label, lineWidth,\n * linkedTo, marker, negativeColor, pointInterval,\n * pointIntervalUnit, pointPlacement, pointStart,\n * softThreshold, stacking, step, threshold, turboThreshold,\n * zoneAxis, zones, dataSorting, boostBlending\n * @product highcharts highmaps\n * @optionparent plotOptions.pie\n *\n * @private\n */\n const PieSeriesDefaults = {\n /**\n * The corner radius of the border surrounding each slice. A number\n * signifies pixels. A percentage string, like for example `50%`, signifies\n * a size relative to the radius and the inner radius.\n *\n * @sample highcharts/plotoptions/series-border-radius\n * Column and pie with rounded border\n *\n * @since 11.0.0\n *\n * @type {number|string|Highcharts.BorderRadiusOptionsObject}\n */\n borderRadius: 3,\n /**\n * @excluding legendItemClick\n * @apioption plotOptions.pie.events\n */\n /**\n * Fires when the checkbox next to the point name in the legend is\n * clicked. One parameter, event, is passed to the function. The state\n * of the checkbox is found by event.checked. The checked item is found\n * by event.item. Return false to prevent the default action which is to\n * toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Function}\n * @since 1.2.0\n * @product highcharts highmaps\n * @context Highcharts.Point\n * @apioption plotOptions.pie.events.checkboxClick\n */\n /**\n * Fires when the legend item belonging to the pie point (slice) is\n * clicked. The `this` keyword refers to the point itself. One\n * parameter, `event`, is passed to the function, containing common\n * event information. The default action is to toggle the visibility of\n * the point. This can be prevented by calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-point-events-legenditemclick/\n * Confirm toggle visibility\n *\n * @type {Highcharts.PointLegendItemClickCallbackFunction}\n * @since 1.2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.point.events.legendItemClick\n */\n /**\n * The center of the pie chart relative to the plot area. Can be\n * percentages or pixel values. The default behaviour (as of 3.0) is to\n * center the pie so that all slices and data labels are within the plot\n * area. As a consequence, the pie may actually jump around in a chart\n * with dynamic values, as the data labels move. In that case, the\n * center should be explicitly set, for example to `[\"50%\", \"50%\"]`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-center/\n * Centered at 100, 100\n *\n * @type {Array<(number|string|null),(number|string|null)>}\n * @default [null, null]\n * @product highcharts highmaps\n *\n * @private\n */\n center: [null, null],\n /**\n * The color of the pie series. A pie series is represented as an empty\n * circle if the total sum of its values is 0. Use this property to\n * define the color of its border.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @apioption plotOptions.pie.color\n */\n /**\n * @product highcharts\n *\n * @private\n */\n clip: false,\n /**\n * @ignore-option\n *\n * @private\n */\n colorByPoint: true,\n /**\n * A series specific or series type specific color set to use instead\n * of the global [colors](#colors).\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome/\n * Set default colors for all pies\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.colors\n */\n /**\n * @declare Highcharts.SeriesPieDataLabelsOptionsObject\n * @extends plotOptions.series.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @private\n */\n dataLabels: {\n /**\n * Alignment method for data labels. Possible values are:\n *\n * - `plotEdges`: Each label touches the nearest vertical edge of\n * the plot area.\n *\n * - `connectors`: Connectors have the same x position and the\n * widest label of each half (left & right) touches the nearest\n * vertical edge of the plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-connectors/\n * alignTo: connectors\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-plotedges/\n * alignTo: plotEdges\n *\n * @type {string}\n * @since 7.0.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.alignTo\n */\n allowOverlap: true,\n /**\n * The color of the line connecting the data label to the pie slice.\n * The default color is the same as the point's color.\n *\n * In styled mode, the connector stroke is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorcolor/\n * Blue connectors\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorColor\n */\n /**\n * The distance from the data label to the connector. Note that\n * data labels also have a default `padding`, so in order for the\n * connector to touch the text, the `padding` must also be 0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorpadding/\n * No padding\n *\n * @since 2.1\n * @product highcharts highmaps\n */\n connectorPadding: 5,\n /**\n * Specifies the method that is used to generate the connector path.\n * Highcharts provides 3 built-in connector shapes: `'crookedLine'`\n * (default since v11), `'fixedOffset'` and `'straight'`.\n *\n * Users can provide their own method by passing a function instead of a\n * string. Three arguments are passed to the callback:\n *\n * - An object that holds the information about the coordinates of the\n * label (`x` & `y` properties) and how the label is located in\n * relation to the pie (`alignment` property). `alignment` can by one\n * of the following: `'left'` (pie on the left side of the data\n * label), `'right'` (pie on the right side of the data label) or\n * `'center'` (data label overlaps the pie).\n *\n * - An object that holds the information about the position of the\n * connector. Its `touchingSliceAt` porperty tells the position of\n * the place where the connector touches the slice.\n *\n * - Data label options\n *\n * The function has to return an SVG path definition in array form (see\n * the example).\n *\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-connectorshape-string/\n * connectorShape is a String\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-connectorshape-function/\n * connectorShape is a function\n *\n * @type {string|Function}\n * @since 7.0.0\n * @product highcharts highmaps\n */\n connectorShape: 'crookedLine',\n /**\n * The width of the line connecting the data label to the pie slice.\n *\n * In styled mode, the connector stroke width is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorwidth-disabled/\n * Disable the connector\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {number}\n * @default 1\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorWidth\n */\n /**\n * Works only if `connectorShape` is `'crookedLine'`. It defines how\n * far from the vertical plot edge the coonnector path should be\n * crooked. With the default, `undefined`, the crook is placed so that\n * the horizontal line from the label intersects with the radial line\n * extending through the center of the pie slice.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-crookdistance/\n * crookDistance set to 90%\n *\n * @since 7.0.0\n * @product highcharts highmaps\n */\n crookDistance: void 0,\n /**\n * The distance of the data label from the pie's edge. Negative\n * numbers put the data label on top of the pie slices. Can also be\n * defined as a percentage of pie's radius. Connectors are only\n * shown for data labels outside the pie.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-distance/\n * Data labels on top of the pie\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highmaps\n */\n distance: 30,\n enabled: true,\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n *\n * @type {string}\n * @default undefined\n * @since 3.0\n * @apioption plotOptions.pie.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that\n * if a `format` is defined, the format takes precedence and the\n * formatter is ignored.\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @default function () { return this.point.isNull ? void 0 : this.point.name; }\n */\n formatter: function () {\n return this.point.isNull ? void 0 : this.point.name;\n },\n /**\n * Whether to render the connector as a soft arc or a line with a sharp\n * break. Works only if `connectorShape` equals to `fixedOffset`.\n *\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-softconnector-true/\n * Soft\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-softconnector-false/\n * Non soft\n *\n * @since 2.1.7\n * @product highcharts highmaps\n */\n softConnector: true,\n /**\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow\n * Long labels truncated with an ellipsis\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap\n * Long labels are wrapped\n *\n * @type {Highcharts.CSSObject}\n * @apioption plotOptions.pie.dataLabels.style\n */\n x: 0\n },\n /**\n * If the total sum of the pie's values is 0, the series is represented\n * as an empty circle . The `fillColor` option defines the color of that\n * circle. Use [pie.borderWidth](#plotOptions.pie.borderWidth) to set\n * the border thickness.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @private\n */\n fillColor: void 0,\n /**\n * The end angle of the pie in degrees where 0 is top and 90 is right.\n * Defaults to `startAngle` plus 360.\n *\n * @sample {highcharts} highcharts/demo/pie-semi-circle/\n * Semi-circle donut\n *\n * @type {number}\n * @since 1.3.6\n * @product highcharts highmaps\n * @apioption plotOptions.pie.endAngle\n */\n /**\n * Thickness describing the ring size for a donut type chart,\n * overriding [innerSize](#plotOptions.pie.innerSize).\n *\n * @type {number}\n * @default undefined\n * @product highcharts\n * @since 10.1.0\n * @apioption plotOptions.pie.thickness\n * @private\n */\n /**\n * Equivalent to [chart.ignoreHiddenSeries](#chart.ignoreHiddenSeries),\n * this option tells whether the series shall be redrawn as if the\n * hidden point were `null`.\n *\n * The default value changed from `false` to `true` with Highcharts\n * 3.0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-ignorehiddenpoint/\n * True, the hiddden point is ignored\n *\n * @since 2.3.0\n * @product highcharts highmaps\n *\n * @private\n */\n ignoreHiddenPoint: true,\n /**\n * @ignore-option\n *\n * @private\n */\n inactiveOtherPoints: true,\n /**\n * The size of the inner diameter for the pie. A size greater than 0\n * renders a donut chart. Can be a percentage or pixel value.\n * Percentages are relative to the pie size. Pixel values are given as\n * integers. Setting overridden by thickness.\n *\n *\n * Note: in Highcharts < 4.1.2, the percentage was relative to the plot\n * area, not the pie size.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-80px/\n * 80px inner size\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-50percent/\n * 50% of the plot area\n * @sample {highcharts} highcharts/demo/3d-pie-donut/\n * 3D donut\n *\n * @type {number|string}\n * @default 0\n * @since 2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.innerSize\n */\n /**\n * @ignore-option\n *\n * @private\n */\n legendType: 'point',\n /**\n * @ignore-option\n *\n * @private\n */\n marker: null,\n /**\n * The minimum size for a pie in response to auto margins. The pie will\n * try to shrink to make room for data labels in side the plot area,\n * but only to this size.\n *\n * @type {number|string}\n * @default 80\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.minSize\n */\n /**\n * The diameter of the pie relative to the plot area. Can be a\n * percentage or pixel value. Pixel values are given as integers. The\n * default behaviour (as of 3.0) is to scale to the plot area and give\n * room for data labels within the plot area.\n * [slicedOffset](#plotOptions.pie.slicedOffset) is also included in the\n * default size calculation. As a consequence, the size of the pie may\n * vary when points are updated and data labels more around. In that\n * case it is best to set a fixed value, for example `\"75%\"`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-size/\n * Smaller pie\n *\n * @type {number|string|null}\n * @product highcharts highmaps\n *\n * @private\n */\n size: null,\n /**\n * Whether to display this particular series or series type in the\n * legend. Since 2.1, pies are not shown in the legend by default.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @product highcharts highmaps\n *\n * @private\n */\n showInLegend: false,\n /**\n * If a point is sliced, moved out from the center, how many pixels\n * should it be moved?.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-slicedoffset-20/\n * 20px offset\n *\n * @product highcharts highmaps\n *\n * @private\n */\n slicedOffset: 10,\n /**\n * The start angle of the pie slices in degrees where 0 is top and 90\n * right.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-startangle-90/\n * Start from right\n *\n * @type {number}\n * @default 0\n * @since 2.3.4\n * @product highcharts highmaps\n * @apioption plotOptions.pie.startAngle\n */\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series, or out of the plot area. When false, the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @product highcharts highmaps\n *\n * @private\n */\n stickyTracking: false,\n tooltip: {\n followPointer: true\n },\n /**\n * The color of the border surrounding each slice. When `null`, the\n * border takes the same color as the slice fill. This can be used\n * together with a `borderWidth` to fill drawing gaps created by\n * antialiazing artefacts in borderless pies.\n *\n * In styled mode, the border stroke is given in the `.highcharts-point`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-bordercolor-black/\n * Black border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highmaps\n *\n * @private\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the border surrounding each slice.\n *\n * When setting the border width to 0, there may be small gaps between\n * the slices due to SVG antialiasing artefacts. To work around this,\n * keep the border width at 0.5 or 1, but set the `borderColor` to\n * `null` instead.\n *\n * In styled mode, the border stroke width is given in the\n * `.highcharts-point` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-borderwidth/\n * 3px border\n *\n * @product highcharts highmaps\n *\n * @private\n */\n borderWidth: 1,\n /**\n * @ignore-option\n * @private\n */\n lineWidth: void 0,\n states: {\n /**\n * @extends plotOptions.series.states.hover\n * @excluding marker, lineWidth, lineWidthPlus\n * @product highcharts highmaps\n */\n hover: {\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode, the hover brightness is by default replaced\n * by a fill-opacity given in the `.highcharts-point-hover`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-states-hover-brightness/\n * Brightened by 0.5\n *\n * @product highcharts highmaps\n */\n brightness: 0.1\n }\n }\n };\n /**\n * A `pie` series. If the [type](#series.pie.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.pie\n * @excluding cropThreshold, dataParser, dataURL, linkedTo, stack, xAxis, yAxis,\n * dataSorting, step, boostThreshold, boostBlending\n * @product highcharts highmaps\n * @apioption series.pie\n */\n /**\n * An array of data points for the series. For the `pie` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.pie.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * y: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker, x\n * @product highcharts highmaps\n * @apioption series.pie.data\n */\n /**\n * @type {Highcharts.SeriesPieDataLabelsOptionsObject}\n * @product highcharts highmaps\n * @apioption series.pie.data.dataLabels\n */\n /**\n * The sequential index of the data point in the legend.\n *\n * @type {number}\n * @product highcharts highmaps\n * @apioption series.pie.data.legendIndex\n */\n /**\n * Whether to display a slice offset from the center.\n *\n * @sample {highcharts} highcharts/point/sliced/\n * One sliced point\n *\n * @type {boolean}\n * @product highcharts highmaps\n * @apioption series.pie.data.sliced\n */\n /**\n * @extends plotOptions.pie.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @product highcharts highmaps\n * @apioption series.pie.dataLabels\n */\n /**\n * @excluding legendItemClick\n * @product highcharts highmaps\n * @apioption series.pie.events\n */\n ''; // placeholder for transpiled doclets above\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Pie/PieSeries.js', [_modules['Series/CenteredUtilities.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Core/Globals.js'], _modules['Series/Pie/PiePoint.js'], _modules['Series/Pie/PieSeriesDefaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Utilities.js']], function (CU, ColumnSeries, H, PiePoint, PieSeriesDefaults, Series, SeriesRegistry, Symbols, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getStartAndEndRadians } = CU;\n const { noop } = H;\n const { clamp, extend, fireEvent, merge, pick, relativeLength } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Pie series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.pie\n *\n * @augments Highcharts.Series\n */\n class PieSeries extends Series {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.center = void 0;\n this.data = void 0;\n this.maxLabelDistance = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animates the pies in.\n * @private\n */\n animate(init) {\n const series = this, points = series.points, startAngleRad = series.startAngleRad;\n if (!init) {\n points.forEach(function (point) {\n const graphic = point.graphic, args = point.shapeArgs;\n if (graphic && args) {\n // start values\n graphic.attr({\n // animate from inner radius (#779)\n r: pick(point.startR, (series.center && series.center[3] / 2)),\n start: startAngleRad,\n end: startAngleRad\n });\n // animate\n graphic.animate({\n r: args.r,\n start: args.start,\n end: args.end\n }, series.options.animation);\n }\n });\n }\n }\n /**\n * Called internally to draw auxiliary graph in pie-like series in\n * situtation when the default graph is not sufficient enough to present\n * the data well. Auxiliary graph is saved in the same object as\n * regular graph.\n * @private\n */\n drawEmpty() {\n const start = this.startAngleRad, end = this.endAngleRad, options = this.options;\n let centerX, centerY;\n // Draw auxiliary graph if there're no visible points.\n if (this.total === 0 && this.center) {\n centerX = this.center[0];\n centerY = this.center[1];\n if (!this.graph) {\n this.graph = this.chart.renderer\n .arc(centerX, centerY, this.center[1] / 2, 0, start, end)\n .addClass('highcharts-empty-series')\n .add(this.group);\n }\n this.graph.attr({\n d: Symbols.arc(centerX, centerY, this.center[2] / 2, 0, {\n start,\n end,\n innerR: this.center[3] / 2\n })\n });\n if (!this.chart.styledMode) {\n this.graph.attr({\n 'stroke-width': options.borderWidth,\n fill: options.fillColor || 'none',\n stroke: options.color || \"#cccccc\" /* Palette.neutralColor20 */\n });\n }\n }\n else if (this.graph) { // Destroy the graph object.\n this.graph = this.graph.destroy();\n }\n }\n /**\n * Slices in pie chart are initialized in DOM, but it's shapes and\n * animations are normally run in `drawPoints()`.\n * @private\n */\n drawPoints() {\n const renderer = this.chart.renderer;\n this.points.forEach(function (point) {\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (point.graphic && point.hasNewShapeType()) {\n point.graphic = point.graphic.destroy();\n }\n if (!point.graphic) {\n point.graphic = renderer[point.shapeType](point.shapeArgs)\n .add(point.series.group);\n point.delayedRendering = true;\n }\n });\n }\n /**\n * Extend the generatePoints method by adding total and percentage\n * properties to each point\n * @private\n */\n generatePoints() {\n super.generatePoints();\n this.updateTotals();\n }\n /**\n * Utility for getting the x value from a given y, used for\n * anticollision logic in data labels. Added point for using specific\n * points' label distance.\n * @private\n */\n getX(y, left, point) {\n const center = this.center, \n // Variable pie has individual radius\n radius = this.radii ?\n this.radii[point.index] || 0 :\n center[2] / 2;\n const angle = Math.asin(clamp((y - center[1]) / (radius + point.labelDistance), -1, 1));\n const x = center[0] +\n (left ? -1 : 1) *\n (Math.cos(angle) * (radius + point.labelDistance)) +\n (point.labelDistance > 0 ?\n (left ? -1 : 1) * this.options.dataLabels.padding :\n 0);\n return x;\n }\n /**\n * Define hasData function for non-cartesian series. Returns true if the\n * series has points at all.\n * @private\n */\n hasData() {\n return !!this.processedXData.length; // != 0\n }\n /**\n * Draw the data points\n * @private\n */\n redrawPoints() {\n const series = this, chart = series.chart;\n let groupTranslation, graphic, pointAttr, shapeArgs;\n this.drawEmpty();\n // Apply the drop-shadow to the group because otherwise each element\n // would cast a shadow on others\n if (series.group && !chart.styledMode) {\n series.group.shadow(series.options.shadow);\n }\n // draw the slices\n series.points.forEach(function (point) {\n const animateTo = {};\n graphic = point.graphic;\n if (!point.isNull && graphic) {\n shapeArgs = point.shapeArgs;\n // If the point is sliced, use special translation, else use\n // plot area translation\n groupTranslation = point.getTranslate();\n if (!chart.styledMode) {\n pointAttr = series.pointAttribs(point, (point.selected && 'select'));\n }\n // Draw the slice\n if (!point.delayedRendering) {\n graphic\n .setRadialReference(series.center);\n if (!chart.styledMode) {\n merge(true, animateTo, pointAttr);\n }\n merge(true, animateTo, shapeArgs, groupTranslation);\n graphic.animate(animateTo);\n }\n else {\n graphic\n .setRadialReference(series.center)\n .attr(shapeArgs)\n .attr(groupTranslation);\n if (!chart.styledMode) {\n graphic\n .attr(pointAttr)\n .attr({ 'stroke-linejoin': 'round' });\n }\n point.delayedRendering = false;\n }\n graphic\n .attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n graphic.addClass(point.getClassName(), true);\n }\n else if (graphic) {\n point.graphic = graphic.destroy();\n }\n });\n }\n /**\n * Utility for sorting data labels.\n * @private\n */\n sortByAngle(points, sign) {\n points.sort(function (a, b) {\n return ((typeof a.angle !== 'undefined') &&\n (b.angle - a.angle) * sign);\n });\n }\n /**\n * Do translation for pie slices\n * @private\n */\n translate(positions) {\n fireEvent(this, 'translate');\n this.generatePoints();\n const series = this, precision = 1000, // issue #172\n options = series.options, slicedOffset = options.slicedOffset, connectorOffset = slicedOffset + (options.borderWidth || 0), radians = getStartAndEndRadians(options.startAngle, options.endAngle), startAngleRad = series.startAngleRad = radians.start, endAngleRad = series.endAngleRad = radians.end, circ = endAngleRad - startAngleRad, // 2 * Math.PI,\n points = series.points, labelDistance = options.dataLabels.distance, ignoreHiddenPoint = options.ignoreHiddenPoint, len = points.length;\n let finalConnectorOffset, start, end, angle, \n // the x component of the radius vector for a given point\n radiusX, radiusY, i, point, cumulative = 0;\n // Get positions - either an integer or a percentage string must be\n // given. If positions are passed as a parameter, we're in a\n // recursive loop for adjusting space for data labels.\n if (!positions) {\n series.center = positions = series.getCenter();\n }\n // Calculate the geometry for each point\n for (i = 0; i < len; i++) {\n point = points[i];\n // set start and end angle\n start = startAngleRad + (cumulative * circ);\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n cumulative += point.percentage / 100;\n }\n end = startAngleRad + (cumulative * circ);\n // set the shape\n const shapeArgs = {\n x: positions[0],\n y: positions[1],\n r: positions[2] / 2,\n innerR: positions[3] / 2,\n start: Math.round(start * precision) / precision,\n end: Math.round(end * precision) / precision\n };\n point.shapeType = 'arc';\n point.shapeArgs = shapeArgs;\n // Used for distance calculation for specific point.\n point.labelDistance = pick((point.options.dataLabels &&\n point.options.dataLabels.distance), labelDistance);\n // Compute point.labelDistance if it's defined as percentage\n // of slice radius (#8854)\n point.labelDistance = relativeLength(point.labelDistance, shapeArgs.r);\n // Saved for later dataLabels distance calculation.\n series.maxLabelDistance = Math.max(series.maxLabelDistance || 0, point.labelDistance);\n // The angle must stay within -90 and 270 (#2645)\n angle = (end + start) / 2;\n if (angle > 1.5 * Math.PI) {\n angle -= 2 * Math.PI;\n }\n else if (angle < -Math.PI / 2) {\n angle += 2 * Math.PI;\n }\n // Center for the sliced out slice\n point.slicedTranslation = {\n translateX: Math.round(Math.cos(angle) * slicedOffset),\n translateY: Math.round(Math.sin(angle) * slicedOffset)\n };\n // set the anchor point for tooltips\n radiusX = Math.cos(angle) * positions[2] / 2;\n radiusY = Math.sin(angle) * positions[2] / 2;\n point.tooltipPos = [\n positions[0] + radiusX * 0.7,\n positions[1] + radiusY * 0.7\n ];\n point.half = angle < -Math.PI / 2 || angle > Math.PI / 2 ?\n 1 :\n 0;\n point.angle = angle;\n // Set the anchor point for data labels. Use point.labelDistance\n // instead of labelDistance // #1174\n // finalConnectorOffset - not override connectorOffset value.\n finalConnectorOffset = Math.min(connectorOffset, point.labelDistance / 5); // #1678\n point.labelPosition = {\n natural: {\n // initial position of the data label - it's utilized for\n // finding the final position for the label\n x: positions[0] + radiusX + Math.cos(angle) *\n point.labelDistance,\n y: positions[1] + radiusY + Math.sin(angle) *\n point.labelDistance\n },\n computed: {\n // used for generating connector path -\n // initialized later in drawDataLabels function\n // x: undefined,\n // y: undefined\n },\n // left - pie on the left side of the data label\n // right - pie on the right side of the data label\n // center - data label overlaps the pie\n alignment: point.labelDistance < 0 ?\n 'center' : point.half ? 'right' : 'left',\n connectorPosition: {\n breakAt: {\n x: positions[0] + radiusX + Math.cos(angle) *\n finalConnectorOffset,\n y: positions[1] + radiusY + Math.sin(angle) *\n finalConnectorOffset\n },\n touchingSliceAt: {\n x: positions[0] + radiusX,\n y: positions[1] + radiusY\n }\n }\n };\n }\n fireEvent(series, 'afterTranslate');\n }\n /**\n * Recompute total chart sum and update percentages of points.\n * @private\n */\n updateTotals() {\n const points = this.points, len = points.length, ignoreHiddenPoint = this.options.ignoreHiddenPoint;\n let i, point, total = 0;\n // Get the total sum\n for (i = 0; i < len; i++) {\n point = points[i];\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n total += point.y;\n }\n }\n this.total = total;\n // Set each point's properties\n for (i = 0; i < len; i++) {\n point = points[i];\n point.percentage =\n (total > 0 && (point.visible || !ignoreHiddenPoint)) ?\n point.y / total * 100 :\n 0;\n point.total = total;\n }\n }\n }\n PieSeries.defaultOptions = merge(Series.defaultOptions, PieSeriesDefaults);\n extend(PieSeries.prototype, {\n axisTypes: [],\n directTouch: true,\n drawGraph: void 0,\n drawTracker: ColumnSeries.prototype.drawTracker,\n getCenter: CU.getCenter,\n getSymbol: noop,\n isCartesian: false,\n noSharedTooltip: true,\n pointAttribs: ColumnSeries.prototype.pointAttribs,\n pointClass: PiePoint,\n requireSorting: false,\n searchPoint: noop,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('pie', PieSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeries;\n });\n _registerModule(_modules, 'Series/Pie/PieDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, H, R, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { noop } = H;\n const { distribute } = R;\n const { series: Series } = SeriesRegistry;\n const { arrayMax, clamp, defined, merge, pick, relativeLength } = U;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n const dataLabelPositioners = {\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionY: function (point) {\n return point.top + point.distributeBox.pos;\n },\n // get the x - use the natural x position for labels near the\n // top and bottom, to prevent the top and botton slice\n // connectors from touching each other on either side\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionX: function (series, point, y, naturalY) {\n return series.getX(y < point.top + 2 || y > point.bottom - 2 ?\n naturalY :\n y, point.half, point);\n },\n // dataLabels.distance determines the x position of the label\n justify: function (point, radius, seriesCenter) {\n return seriesCenter[0] + (point.half ? -1 : 1) *\n (radius + point.labelDistance);\n },\n // Left edges of the left-half labels touch the left edge of the plot\n // area. Right edges of the right-half labels touch the right edge of\n // the plot area.\n alignToPlotEdges: function (dataLabel, half, plotWidth, plotLeft) {\n const dataLabelWidth = dataLabel.getBBox().width;\n return half ? dataLabelWidth + plotLeft :\n plotWidth - dataLabelWidth - plotLeft;\n },\n // Connectors of each side end in the same x position. Labels are\n // aligned to them. Left edge of the widest left-half label touches the\n // left edge of the plot area. Right edge of the widest right-half label\n // touches the right edge of the plot area.\n alignToConnectors: function (points, half, plotWidth, plotLeft) {\n let maxDataLabelWidth = 0, dataLabelWidth;\n // find widest data label\n points.forEach(function (point) {\n dataLabelWidth = point.dataLabel.getBBox().width;\n if (dataLabelWidth > maxDataLabelWidth) {\n maxDataLabelWidth = dataLabelWidth;\n }\n });\n return half ? maxDataLabelWidth + plotLeft :\n plotWidth - maxDataLabelWidth - plotLeft;\n }\n };\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /** @private */\n function compose(PieSeriesClass) {\n DataLabel.compose(Series);\n if (U.pushUnique(composedMembers, PieSeriesClass)) {\n const pieProto = PieSeriesClass.prototype;\n pieProto.dataLabelPositioners = dataLabelPositioners;\n pieProto.alignDataLabel = noop;\n pieProto.drawDataLabels = drawDataLabels;\n pieProto.placeDataLabels = placeDataLabels;\n pieProto.verifyDataLabelOverflow = verifyDataLabelOverflow;\n }\n }\n ColumnDataLabel.compose = compose;\n /**\n * Override the base drawDataLabels method by pie specific functionality\n * @private\n */\n function drawDataLabels() {\n const series = this, data = series.data, chart = series.chart, options = series.options.dataLabels || {}, connectorPadding = options.connectorPadding, plotWidth = chart.plotWidth, plotHeight = chart.plotHeight, plotLeft = chart.plotLeft, maxWidth = Math.round(chart.chartWidth / 3), seriesCenter = series.center, radius = seriesCenter[2] / 2, centerY = seriesCenter[1], halves = [\n [],\n [] // left\n ], overflow = [0, 0, 0, 0], // top, right, bottom, left\n dataLabelPositioners = series.dataLabelPositioners;\n let point, connectorWidth, connector, dataLabel, dataLabelWidth, \n // labelPos,\n labelPosition, labelHeight, \n // divide the points into right and left halves for anti collision\n x, y, visibility, j, pointDataLabelsOptions;\n // get out if not enabled\n if (!series.visible ||\n (!options.enabled &&\n !series._hasPointLabels)) {\n return;\n }\n // Reset all labels that have been shortened\n data.forEach(function (point) {\n if (point.dataLabel && point.visible && point.dataLabel.shortened) {\n point.dataLabel\n .attr({\n width: 'auto'\n }).css({\n width: 'auto',\n textOverflow: 'clip'\n });\n point.dataLabel.shortened = false;\n }\n });\n // run parent method\n Series.prototype.drawDataLabels.apply(series);\n data.forEach(function (point) {\n if (point.dataLabel) {\n if (point.visible) { // #407, #2510\n // Arrange points for detection collision\n halves[point.half].push(point);\n // Reset positions (#4905)\n point.dataLabel._pos = null;\n // Avoid long labels squeezing the pie size too far down\n if (!defined(options.style.width) &&\n !defined(point.options.dataLabels &&\n point.options.dataLabels.style &&\n point.options.dataLabels.style.width)) {\n if (point.dataLabel.getBBox().width > maxWidth) {\n point.dataLabel.css({\n // Use a fraction of the maxWidth to avoid\n // wrapping close to the end of the string.\n width: Math.round(maxWidth * 0.7) + 'px'\n });\n point.dataLabel.shortened = true;\n }\n }\n }\n else {\n point.dataLabel = point.dataLabel.destroy();\n // Workaround to make pies destroy multiple datalabels\n // correctly. This logic needs rewriting to support multiple\n // datalabels fully.\n if (point.dataLabels && point.dataLabels.length === 1) {\n delete point.dataLabels;\n }\n }\n }\n });\n /* Loop over the points in each half, starting from the top and bottom\n * of the pie to detect overlapping labels.\n */\n halves.forEach((points, i) => {\n const length = points.length, positions = [];\n let top, bottom, naturalY, sideOverflow, size = 0, distributionLength;\n if (!length) {\n return;\n }\n // Sort by angle\n series.sortByAngle(points, i - 0.5);\n // Only do anti-collision when we have dataLabels outside the pie\n // and have connectors. (#856)\n if (series.maxLabelDistance > 0) {\n top = Math.max(0, centerY - radius - series.maxLabelDistance);\n bottom = Math.min(centerY + radius + series.maxLabelDistance, chart.plotHeight);\n points.forEach(function (point) {\n // check if specific points' label is outside the pie\n if (point.labelDistance > 0 && point.dataLabel) {\n // point.top depends on point.labelDistance value\n // Used for calculation of y value in getX method\n point.top = Math.max(0, centerY - radius - point.labelDistance);\n point.bottom = Math.min(centerY + radius + point.labelDistance, chart.plotHeight);\n size = point.dataLabel.getBBox().height || 21;\n // point.positionsIndex is needed for getting index of\n // parameter related to specific point inside positions\n // array - not every point is in positions array.\n point.distributeBox = {\n target: point.labelPosition.natural.y -\n point.top + size / 2,\n size,\n rank: point.y\n };\n positions.push(point.distributeBox);\n }\n });\n distributionLength = bottom + size - top;\n distribute(positions, distributionLength, distributionLength / 5);\n }\n // Now the used slots are sorted, fill them up sequentially\n for (j = 0; j < length; j++) {\n point = points[j];\n // labelPos = point.labelPos;\n labelPosition = point.labelPosition;\n dataLabel = point.dataLabel;\n visibility = point.visible === false ? 'hidden' : 'inherit';\n naturalY = labelPosition.natural.y;\n y = naturalY;\n if (positions && defined(point.distributeBox)) {\n if (typeof point.distributeBox.pos === 'undefined') {\n visibility = 'hidden';\n }\n else {\n labelHeight = point.distributeBox.size;\n // Find label's y position\n y = dataLabelPositioners\n .radialDistributionY(point);\n }\n }\n // It is needed to delete point.positionIndex for\n // dynamically added points etc.\n delete point.positionIndex; // @todo unused\n // Find label's x position\n // justify is undocumented in the API - preserve support for it\n if (options.justify) {\n x = dataLabelPositioners.justify(point, radius, seriesCenter);\n }\n else {\n switch (options.alignTo) {\n case 'connectors':\n x = dataLabelPositioners.alignToConnectors(points, i, plotWidth, plotLeft);\n break;\n case 'plotEdges':\n x = dataLabelPositioners.alignToPlotEdges(dataLabel, i, plotWidth, plotLeft);\n break;\n default:\n x = dataLabelPositioners.radialDistributionX(series, point, y, naturalY);\n }\n }\n // Record the placement and visibility\n dataLabel._attr = {\n visibility: visibility,\n align: labelPosition.alignment\n };\n pointDataLabelsOptions = point.options.dataLabels || {};\n dataLabel._pos = {\n x: (x +\n pick(pointDataLabelsOptions.x, options.x) + // (#12985)\n ({\n left: connectorPadding,\n right: -connectorPadding\n }[labelPosition.alignment] || 0)),\n y: (y +\n pick(pointDataLabelsOptions.y, options.y) - // (#12985)\n // Vertically center\n dataLabel.getBBox().height / 2)\n };\n // labelPos.x = x;\n // labelPos.y = y;\n if (labelPosition) {\n labelPosition.computed.x = x;\n labelPosition.computed.y = y;\n }\n // Detect overflowing data labels\n if (pick(options.crop, true)) {\n dataLabelWidth = dataLabel.getBBox().width;\n sideOverflow = null;\n // Overflow left\n if (x - dataLabelWidth < connectorPadding &&\n i === 1 // left half\n ) {\n sideOverflow = Math.round(dataLabelWidth - x + connectorPadding);\n overflow[3] = Math.max(sideOverflow, overflow[3]);\n // Overflow right\n }\n else if (x + dataLabelWidth > plotWidth - connectorPadding &&\n i === 0 // right half\n ) {\n sideOverflow = Math.round(x + dataLabelWidth - plotWidth + connectorPadding);\n overflow[1] = Math.max(sideOverflow, overflow[1]);\n }\n // Overflow top\n if (y - labelHeight / 2 < 0) {\n overflow[0] = Math.max(Math.round(-y + labelHeight / 2), overflow[0]);\n // Overflow left\n }\n else if (y + labelHeight / 2 > plotHeight) {\n overflow[2] = Math.max(Math.round(y + labelHeight / 2 - plotHeight), overflow[2]);\n }\n dataLabel.sideOverflow = sideOverflow;\n }\n } // for each point\n }); // for each half\n // Do not apply the final placement and draw the connectors until we\n // have verified that labels are not spilling over.\n if (arrayMax(overflow) === 0 ||\n this.verifyDataLabelOverflow(overflow)) {\n // Place the labels in the final position\n this.placeDataLabels();\n this.points.forEach(function (point) {\n // #8864: every connector can have individual options\n pointDataLabelsOptions =\n merge(options, point.options.dataLabels);\n connectorWidth =\n pick(pointDataLabelsOptions.connectorWidth, 1);\n // Draw the connector\n if (connectorWidth) {\n let isNew;\n connector = point.connector;\n dataLabel = point.dataLabel;\n if (dataLabel &&\n dataLabel._pos &&\n point.visible &&\n point.labelDistance > 0) {\n visibility = dataLabel._attr.visibility;\n isNew = !connector;\n if (isNew) {\n point.connector = connector = chart.renderer\n .path()\n .addClass('highcharts-data-label-connector ' +\n ' highcharts-color-' + point.colorIndex +\n (point.className ?\n ' ' + point.className :\n ''))\n .add(series.dataLabelsGroup);\n if (!chart.styledMode) {\n connector.attr({\n 'stroke-width': connectorWidth,\n 'stroke': (pointDataLabelsOptions.connectorColor ||\n point.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n }\n connector[isNew ? 'attr' : 'animate']({\n d: point.getConnectorPath()\n });\n connector.attr('visibility', visibility);\n }\n else if (connector) {\n point.connector = connector.destroy();\n }\n }\n });\n }\n }\n /**\n * Perform the final placement of the data labels after we have verified\n * that they fall within the plot area.\n * @private\n */\n function placeDataLabels() {\n this.points.forEach(function (point) {\n let dataLabel = point.dataLabel, _pos;\n if (dataLabel && point.visible) {\n _pos = dataLabel._pos;\n if (_pos) {\n // Shorten data labels with ellipsis if they still overflow\n // after the pie has reached minSize (#223).\n if (dataLabel.sideOverflow) {\n dataLabel._attr.width =\n Math.max(dataLabel.getBBox().width -\n dataLabel.sideOverflow, 0);\n dataLabel.css({\n width: dataLabel._attr.width + 'px',\n textOverflow: ((this.options.dataLabels.style || {})\n .textOverflow ||\n 'ellipsis')\n });\n dataLabel.shortened = true;\n }\n dataLabel.attr(dataLabel._attr);\n dataLabel[dataLabel.moved ? 'animate' : 'attr'](_pos);\n dataLabel.moved = true;\n }\n else if (dataLabel) {\n dataLabel.attr({ y: -9999 });\n }\n }\n // Clear for update\n delete point.distributeBox;\n }, this);\n }\n /**\n * Verify whether the data labels are allowed to draw, or we should run more\n * translation and data label positioning to keep them inside the plot area.\n * Returns true when data labels are ready to draw.\n * @private\n */\n function verifyDataLabelOverflow(overflow) {\n let center = this.center, options = this.options, centerOption = options.center, minSize = options.minSize || 80, newSize = minSize, \n // If a size is set, return true and don't try to shrink the pie\n // to fit the labels.\n ret = options.size !== null;\n if (!ret) {\n // Handle horizontal size and center\n if (centerOption[0] !== null) { // Fixed center\n newSize = Math.max(center[2] -\n Math.max(overflow[1], overflow[3]), minSize);\n }\n else { // Auto center\n newSize = Math.max(\n // horizontal overflow\n center[2] - overflow[1] - overflow[3], minSize);\n // horizontal center\n center[0] += (overflow[3] - overflow[1]) / 2;\n }\n // Handle vertical size and center\n if (centerOption[1] !== null) { // Fixed center\n newSize = clamp(newSize, minSize, center[2] - Math.max(overflow[0], overflow[2]));\n }\n else { // Auto center\n newSize = clamp(newSize, minSize, \n // vertical overflow\n center[2] - overflow[0] - overflow[2]);\n // vertical center\n center[1] += (overflow[0] - overflow[2]) / 2;\n }\n // If the size must be decreased, we need to run translate and\n // drawDataLabels again\n if (newSize < center[2]) {\n center[2] = newSize;\n center[3] = Math.min(// #3632\n options.thickness ?\n Math.max(0, newSize - options.thickness * 2) :\n Math.max(0, relativeLength(options.innerSize || 0, newSize)), newSize); // #6647\n this.translate(center);\n if (this.drawDataLabels) {\n this.drawDataLabels();\n }\n // Else, return true to indicate that the pie and its labels is\n // within the plot area\n }\n else {\n ret = true;\n }\n }\n return ret;\n }\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Extensions/OverlappingDataLabels.js', [_modules['Core/Chart/Chart.js'], _modules['Core/Utilities.js']], function (Chart, U) {\n /* *\n *\n * Highcharts module to hide overlapping data labels.\n * This module is included in Highcharts.\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, fireEvent, isArray, isNumber, objectEach, pick } = U;\n /**\n * Internal type\n * @private\n */\n /* eslint-disable no-invalid-this */\n // Collect potensial overlapping data labels. Stack labels probably don't need\n // to be considered because they are usually accompanied by data labels that lie\n // inside the columns.\n addEvent(Chart, 'render', function collectAndHide() {\n let chart = this, labels = [];\n // Consider external label collectors\n (this.labelCollectors || []).forEach(function (collector) {\n labels = labels.concat(collector());\n });\n (this.yAxis || []).forEach(function (yAxis) {\n if (yAxis.stacking &&\n yAxis.options.stackLabels &&\n !yAxis.options.stackLabels.allowOverlap) {\n objectEach(yAxis.stacking.stacks, function (stack) {\n objectEach(stack, function (stackItem) {\n if (stackItem.label) {\n labels.push(stackItem.label);\n }\n });\n });\n }\n });\n (this.series || []).forEach(function (series) {\n const dlOptions = series.options.dataLabels;\n if (series.visible &&\n !(dlOptions.enabled === false && !series._hasPointLabels)) { // #3866\n const push = (points) => points.forEach((point) => {\n if (point.visible) {\n const dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n dataLabels.forEach(function (label) {\n const options = label.options;\n label.labelrank = pick(options.labelrank, point.labelrank, point.shapeArgs && point.shapeArgs.height); // #4118\n if (!options.allowOverlap) {\n labels.push(label);\n }\n else { // #13449\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n hideOrShow(label, chart);\n }\n });\n }\n });\n push(series.nodes || []);\n push(series.points);\n }\n });\n this.hideOverlappingLabels(labels);\n });\n /**\n * Hide overlapping labels. Labels are moved and faded in and out on zoom to\n * provide a smooth visual imression.\n *\n * @private\n * @function Highcharts.Chart#hideOverlappingLabels\n * @param {Array} labels\n * Rendered data labels\n * @requires modules/overlapping-datalabels\n */\n Chart.prototype.hideOverlappingLabels = function (labels) {\n let chart = this, len = labels.length, ren = chart.renderer, label, i, j, label1, label2, box1, box2, isLabelAffected = false, isIntersectRect = function (box1, box2) {\n return !(box2.x >= box1.x + box1.width ||\n box2.x + box2.width <= box1.x ||\n box2.y >= box1.y + box1.height ||\n box2.y + box2.height <= box1.y);\n }, \n // Get the box with its position inside the chart, as opposed to getBBox\n // that only reports the position relative to the parent.\n getAbsoluteBox = function (label) {\n let pos, parent, bBox, \n // Substract the padding if no background or border (#4333)\n padding = label.box ? 0 : (label.padding || 0), lineHeightCorrection = 0, xOffset = 0, boxWidth, alignValue;\n if (label &&\n (!label.alignAttr || label.placed)) {\n pos = label.alignAttr || {\n x: label.attr('x'),\n y: label.attr('y')\n };\n parent = label.parentGroup;\n // Get width and height if pure text nodes (stack labels)\n if (!label.width) {\n bBox = label.getBBox();\n label.width = bBox.width;\n label.height = bBox.height;\n // Labels positions are computed from top left corner, so we\n // need to substract the text height from text nodes too.\n lineHeightCorrection = ren.fontMetrics(label.element).h;\n }\n boxWidth = label.width - 2 * padding;\n alignValue = {\n left: '0',\n center: '0.5',\n right: '1'\n }[label.alignValue];\n if (alignValue) {\n xOffset = +alignValue * boxWidth;\n }\n else if (isNumber(label.x) &&\n Math.round(label.x) !== label.translateX) {\n xOffset = label.x - label.translateX;\n }\n return {\n x: pos.x + (parent.translateX || 0) + padding -\n (xOffset || 0),\n y: pos.y + (parent.translateY || 0) + padding -\n lineHeightCorrection,\n width: label.width - 2 * padding,\n height: label.height - 2 * padding\n };\n }\n };\n for (i = 0; i < len; i++) {\n label = labels[i];\n if (label) {\n // Mark with initial opacity\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n label.absoluteBox = getAbsoluteBox(label);\n }\n }\n // Prevent a situation in a gradually rising slope, that each label will\n // hide the previous one because the previous one always has lower rank.\n labels.sort(function (a, b) {\n return (b.labelrank || 0) - (a.labelrank || 0);\n });\n // Detect overlapping labels\n for (i = 0; i < len; i++) {\n label1 = labels[i];\n box1 = label1 && label1.absoluteBox;\n for (j = i + 1; j < len; ++j) {\n label2 = labels[j];\n box2 = label2 && label2.absoluteBox;\n if (box1 &&\n box2 &&\n label1 !== label2 && // #6465, polar chart with connectEnds\n label1.newOpacity !== 0 &&\n label2.newOpacity !== 0 &&\n // #15863 dataLabels are no longer hidden by translation\n label1.visibility !== 'hidden' &&\n label2.visibility !== 'hidden') {\n if (isIntersectRect(box1, box2)) {\n (label1.labelrank < label2.labelrank ? label1 : label2)\n .newOpacity = 0;\n }\n }\n }\n }\n // Hide or show\n labels.forEach(function (label) {\n if (hideOrShow(label, chart)) {\n isLabelAffected = true;\n }\n });\n if (isLabelAffected) {\n fireEvent(chart, 'afterHideAllOverlappingLabels');\n }\n };\n /**\n * Hide or show labels based on opacity.\n *\n * @private\n * @function hideOrShow\n * @param {Highcharts.SVGElement} label\n * The label.\n * @param {Highcharts.Chart} chart\n * The chart that contains the label.\n * @return {boolean}\n * Whether label is affected\n */\n function hideOrShow(label, chart) {\n let complete, newOpacity, isLabelAffected = false;\n if (label) {\n newOpacity = label.newOpacity;\n if (label.oldOpacity !== newOpacity) {\n // Make sure the label is completely hidden to avoid catching clicks\n // (#4362)\n if (label.alignAttr && label.placed) { // data labels\n label[newOpacity ? 'removeClass' : 'addClass']('highcharts-data-label-hidden');\n complete = function () {\n if (!chart.styledMode) {\n label.css({\n pointerEvents: newOpacity ? 'auto' : 'none'\n });\n }\n };\n isLabelAffected = true;\n // Animate or set the opacity\n label.alignAttr.opacity = newOpacity;\n label[label.isOld ? 'animate' : 'attr'](label.alignAttr, null, complete);\n fireEvent(chart, 'afterHideOverlappingLabel');\n }\n else { // other labels, tick labels\n label.attr({\n opacity: newOpacity\n });\n }\n }\n label.isOld = true;\n }\n return isLabelAffected;\n }\n\n });\n _registerModule(_modules, 'Extensions/BorderRadius.js', [_modules['Core/Defaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (D, Series, SeriesRegistry, SVGElement, SVGRenderer, U) {\n /* *\n *\n * Highcharts Border Radius module\n *\n * Author: Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { seriesTypes } = SeriesRegistry;\n const { addEvent, extend, isObject, merge, relativeLength } = U;\n /* *\n *\n * Constants\n *\n * */\n const defaultBorderRadiusOptions = {\n radius: 0,\n scope: 'stack',\n where: void 0\n };\n const optionsToObject = (options, seriesBROptions) => {\n if (!isObject(options)) {\n options = { radius: options || 0 };\n }\n return merge(defaultBorderRadiusOptions, seriesBROptions, options);\n };\n const applyBorderRadius = (path, i, r) => {\n const a = path[i];\n let b = path[i + 1];\n if (b[0] === 'Z') {\n b = path[0];\n }\n let line, arc, fromLineToArc;\n // From straight line to arc\n if ((a[0] === 'M' || a[0] === 'L') && b[0] === 'A') {\n line = a;\n arc = b;\n fromLineToArc = true;\n // From arc to straight line\n }\n else if (a[0] === 'A' && (b[0] === 'M' || b[0] === 'L')) {\n line = b;\n arc = a;\n }\n if (line && arc && arc.params) {\n const bigR = arc[1], \n // In our use cases, outer pie slice arcs are clockwise and inner\n // arcs (donut/sunburst etc) are anti-clockwise\n clockwise = arc[5], params = arc.params, { start, end, cx, cy } = params;\n // Some geometric constants\n const relativeR = clockwise ? (bigR - r) : (bigR + r), \n // The angle, on the big arc, that the border radius arc takes up\n angleOfBorderRadius = relativeR ? Math.asin(r / relativeR) : 0, angleOffset = clockwise ?\n angleOfBorderRadius :\n -angleOfBorderRadius, \n // The distance along the radius of the big arc to the starting\n // point of the small border radius arc\n distanceBigCenterToStartArc = (Math.cos(angleOfBorderRadius) *\n relativeR);\n // From line to arc\n if (fromLineToArc) {\n // Update the cache\n params.start = start + angleOffset;\n // First move to the start position at the radial line. We want to\n // start one borderRadius closer to the center.\n line[1] = cx + distanceBigCenterToStartArc * Math.cos(start);\n line[2] = cy + distanceBigCenterToStartArc * Math.sin(start);\n // Now draw an arc towards the point where the small circle touches\n // the great circle.\n path.splice(i + 1, 0, [\n 'A',\n r,\n r,\n 0,\n 0,\n 1,\n cx + bigR * Math.cos(params.start),\n cy + bigR * Math.sin(params.start)\n ]);\n // From arc to line\n }\n else {\n // Update the cache\n params.end = end - angleOffset;\n // End the big arc a bit earlier\n arc[6] = cx + bigR * Math.cos(params.end);\n arc[7] = cy + bigR * Math.sin(params.end);\n // Draw a small arc towards a point on the end angle, but one\n // borderRadius closer to the center relative to the perimeter.\n path.splice(i + 1, 0, [\n 'A',\n r,\n r,\n 0,\n 0,\n 1,\n cx + distanceBigCenterToStartArc * Math.cos(end),\n cy + distanceBigCenterToStartArc * Math.sin(end)\n ]);\n }\n // Long or short arc must be reconsidered because we have modified the\n // start and end points\n arc[4] = Math.abs(params.end - params.start) < Math.PI ? 0 : 1;\n }\n };\n /* *\n *\n * Modifications\n *\n * */\n // Check if the module has already been imported\n // @todo implement as composition\n if (SVGElement.symbolCustomAttribs.indexOf('borderRadius') === -1) {\n SVGElement.symbolCustomAttribs.push('borderRadius', 'brBoxHeight', 'brBoxY');\n // Extend arc with borderRadius\n const arc = SVGRenderer.prototype.symbols.arc;\n SVGRenderer.prototype.symbols.arc = function (x, y, w, h, options = {}) {\n const path = arc(x, y, w, h, options), { innerR = 0, r = w, start = 0, end = 0 } = options;\n if (options.open || !options.borderRadius) {\n return path;\n }\n const alpha = end - start, sinHalfAlpha = Math.sin(alpha / 2), borderRadius = Math.max(Math.min(relativeLength(options.borderRadius || 0, r - innerR), \n // Cap to half the sector radius\n (r - innerR) / 2, \n // For smaller pie slices, cap to the largest small circle that\n // can be fitted within the sector\n (r * sinHalfAlpha) / (1 + sinHalfAlpha)), 0), \n // For the inner radius, we need an extra cap because the inner arc\n // is shorter than the outer arc\n innerBorderRadius = Math.min(borderRadius, 2 * (alpha / Math.PI) * innerR);\n // Apply turn-by-turn border radius. Start at the end since we're\n // splicing in arc segments.\n let i = path.length - 1;\n while (i--) {\n applyBorderRadius(path, i, i > 1 ? innerBorderRadius : borderRadius);\n }\n return path;\n };\n // Extend roundedRect with individual cutting through rOffset\n const roundedRect = SVGRenderer.prototype.symbols.roundedRect;\n SVGRenderer.prototype.symbols.roundedRect = function (x, y, width, height, options = {}) {\n const path = roundedRect(x, y, width, height, options), { r = 0, brBoxHeight = height, brBoxY = y } = options, brOffsetTop = y - brBoxY, brOffsetBtm = (brBoxY + brBoxHeight) - (y + height), \n // When the distance to the border-radius box is greater than the r\n // itself, it means no border radius. The -0.1 accounts for float\n // rounding errors.\n rTop = (brOffsetTop - r) > -0.1 ? 0 : r, rBtm = (brOffsetBtm - r) > -0.1 ? 0 : r, cutTop = Math.max(rTop && brOffsetTop, 0), cutBtm = Math.max(rBtm && brOffsetBtm, 0);\n /*\n\n The naming of control points:\n\n / a -------- b \\\n / \\\n h c\n | |\n | |\n | |\n g d\n \\ /\n \\ f -------- e /\n\n */\n const a = [x + rTop, y], b = [x + width - rTop, y], c = [x + width, y + rTop], d = [\n x + width, y + height - rBtm\n ], e = [\n x + width - rBtm,\n y + height\n ], f = [x + rBtm, y + height], g = [x, y + height - rBtm], h = [x, y + rTop];\n const applyPythagoras = (r, altitude) => Math.sqrt(Math.pow(r, 2) - Math.pow(altitude, 2));\n // Inside stacks, cut off part of the top\n if (cutTop) {\n const base = applyPythagoras(rTop, rTop - cutTop);\n a[0] -= base;\n b[0] += base;\n c[1] = h[1] = y + rTop - cutTop;\n }\n // Column is lower than the radius. Cut off bottom inside the top\n // radius.\n if (height < rTop - cutTop) {\n const base = applyPythagoras(rTop, rTop - cutTop - height);\n c[0] = d[0] = x + width - rTop + base;\n e[0] = Math.min(c[0], e[0]);\n f[0] = Math.max(d[0], f[0]);\n g[0] = h[0] = x + rTop - base;\n c[1] = h[1] = y + height;\n }\n // Inside stacks, cut off part of the bottom\n if (cutBtm) {\n const base = applyPythagoras(rBtm, rBtm - cutBtm);\n e[0] += base;\n f[0] -= base;\n d[1] = g[1] = y + height - rBtm + cutBtm;\n }\n // Cut off top inside the bottom radius\n if (height < rBtm - cutBtm) {\n const base = applyPythagoras(rBtm, rBtm - cutBtm - height);\n c[0] = d[0] = x + width - rBtm + base;\n b[0] = Math.min(c[0], b[0]);\n a[0] = Math.max(d[0], a[0]);\n g[0] = h[0] = x + rBtm - base;\n d[1] = g[1] = y;\n }\n // Preserve the box for data labels\n path.length = 0;\n path.push(['M', ...a], \n // top side\n ['L', ...b], \n // top right corner\n ['A', rTop, rTop, 0, 0, 1, ...c], \n // right side\n ['L', ...d], \n // bottom right corner\n ['A', rBtm, rBtm, 0, 0, 1, ...e], \n // bottom side\n ['L', ...f], \n // bottom left corner\n ['A', rBtm, rBtm, 0, 0, 1, ...g], \n // left side\n ['L', ...h], \n // top left corner\n ['A', rTop, rTop, 0, 0, 1, ...a], ['Z']);\n return path;\n };\n addEvent(seriesTypes.pie, 'afterTranslate', function () {\n const borderRadius = optionsToObject(this.options.borderRadius);\n for (const point of this.points) {\n const shapeArgs = point.shapeArgs;\n if (shapeArgs) {\n shapeArgs.borderRadius = relativeLength(borderRadius.radius, (shapeArgs.r || 0) - ((shapeArgs.innerR) || 0));\n }\n }\n });\n addEvent(Series, 'afterColumnTranslate', function () {\n var _a,\n _b;\n if (this.options.borderRadius &&\n !(this.chart.is3d && this.chart.is3d())) {\n const { options, yAxis } = this, percent = options.stacking === 'percent', seriesDefault = (_b = (_a = defaultOptions.plotOptions) === null || _a === void 0 ? void 0 : _a[this.type]) === null || _b === void 0 ? void 0 : _b.borderRadius, borderRadius = optionsToObject(options.borderRadius, isObject(seriesDefault) ? seriesDefault : {}), reversed = yAxis.options.reversed;\n for (const point of this.points) {\n const { shapeArgs } = point;\n if (point.shapeType === 'roundedRect' && shapeArgs) {\n const { width = 0, height = 0, y = 0 } = shapeArgs;\n let brBoxY = y, brBoxHeight = height;\n // It would be nice to refactor StackItem.getStackBox/\n // setOffset so that we could get a reliable box out of\n // it. Currently it is close if we remove the label\n // offset, but we still need to run crispCol and also\n // flip it if inverted, so atm it is simpler to do it\n // like the below.\n if (borderRadius.scope === 'stack' &&\n point.stackTotal) {\n const stackEnd = yAxis.translate(percent ? 100 : point.stackTotal, false, true, false, true), stackThreshold = yAxis.translate(options.threshold || 0, false, true, false, true), box = this.crispCol(0, Math.min(stackEnd, stackThreshold), 0, Math.abs(stackEnd - stackThreshold));\n brBoxY = box.y;\n brBoxHeight = box.height;\n }\n const flip = (point.negative ? -1 : 1) *\n (reversed ? -1 : 1) === -1;\n // Handle the where option\n let where = borderRadius.where;\n // Waterfall, hanging columns should have rounding on\n // all sides\n if (!where &&\n this.is('waterfall') &&\n Math.abs((point.yBottom || 0) -\n (this.translatedThreshold || 0)) > this.borderWidth) {\n where = 'all';\n }\n if (!where) {\n where = 'end';\n }\n // Get the radius\n const r = Math.min(relativeLength(borderRadius.radius, width), width / 2, \n // Cap to the height, but not if where is `end`\n where === 'all' ? height / 2 : Infinity) || 0;\n // If the `where` option is 'end', cut off the\n // rectangles by making the border-radius box one r\n // greater, so that the imaginary radius falls outside\n // the rectangle.\n if (where === 'end') {\n if (flip) {\n brBoxY -= r;\n brBoxHeight += r;\n }\n else {\n brBoxHeight += r;\n }\n }\n extend(shapeArgs, { brBoxHeight, brBoxY, r });\n }\n }\n }\n }, {\n // After columnrange and polar column modifications\n order: 9\n });\n }\n /* *\n *\n * Default Export\n *\n * */\n const BorderRadius = {\n optionsToObject\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Detailed options for border radius.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderradius/\n * Rounded columns\n * @sample highcharts/plotoptions/series-border-radius\n * Column and pie with rounded border\n *\n * @interface Highcharts.BorderRadiusOptionsObject\n */ /**\n * The border radius. A number signifies pixels. A percentage string, like for\n * example `50%`, signifies a relative size. For columns this is relative to the\n * column width, for pies it is relative to the radius and the inner radius.\n *\n * @name Highcharts.BorderRadiusOptionsObject#radius\n * @type {string|number}\n */ /**\n * The scope of the rounding for column charts. In a stacked column chart, the\n * value `point` means each single point will get rounded corners. The value\n * `stack` means the rounding will apply to the full stack, so that only points\n * close to the top or bottom will receive rounding.\n *\n * @name Highcharts.BorderRadiusOptionsObject#scope\n * @validvalue [\"point\", \"stack\"]\n * @type {string}\n */ /**\n * For column charts, where in the point or stack to apply rounding. The `end`\n * value means only those corners at the point value will be rounded, leaving\n * the corners at the base or threshold unrounded. This is the most intuitive\n * behaviour. The `all` value means also the base will be rounded.\n *\n * @name Highcharts.BorderRadiusOptionsObject#where\n * @validvalue [\"all\", \"end\"]\n * @type {string}\n * @default end\n */\n (''); // keeps doclets above in JS file\n\n return BorderRadius;\n });\n _registerModule(_modules, 'Core/Responsive.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { diffObjects, extend, find, isArray, isObject, merge, objectEach, pick, splat, uniqueKey } = U;\n /* *\n *\n * Composition\n *\n * */\n var Responsive;\n (function (Responsive) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n extend(ChartClass.prototype, {\n matchResponsiveRule,\n setResponsive\n });\n }\n return ChartClass;\n }\n Responsive.compose = compose;\n /**\n * Handle a single responsiveness rule.\n *\n * @private\n * @function Highcharts.Chart#matchResponsiveRule\n * @param {Highcharts.ResponsiveRulesOptions} rule\n * @param {Array} matches\n */\n function matchResponsiveRule(rule, matches) {\n const condition = rule.condition, fn = condition.callback || function () {\n return (this.chartWidth <= pick(condition.maxWidth, Number.MAX_VALUE) &&\n this.chartHeight <= pick(condition.maxHeight, Number.MAX_VALUE) &&\n this.chartWidth >= pick(condition.minWidth, 0) &&\n this.chartHeight >= pick(condition.minHeight, 0));\n };\n if (fn.call(this)) {\n matches.push(rule._id);\n }\n }\n /**\n * Update the chart based on the current chart/document size and options\n * for responsiveness.\n *\n * @private\n * @function Highcharts.Chart#setResponsive\n * @param {boolean} [redraw=true]\n * @param {boolean} [reset=false]\n * Reset by un-applying all rules. Chart.update resets all rules before\n * applying updated options.\n */\n function setResponsive(redraw, reset) {\n const options = this.options.responsive, currentResponsive = this.currentResponsive;\n let ruleIds = [], undoOptions;\n if (!reset && options && options.rules) {\n options.rules.forEach((rule) => {\n if (typeof rule._id === 'undefined') {\n rule._id = uniqueKey();\n }\n this.matchResponsiveRule(rule, ruleIds /* , redraw */);\n }, this);\n }\n // Merge matching rules\n const mergedOptions = merge(...ruleIds\n .map((ruleId) => find((options || {}).rules || [], (rule) => (rule._id === ruleId)))\n .map((rule) => (rule && rule.chartOptions)));\n mergedOptions.isResponsiveOptions = true;\n // Stringified key for the rules that currently apply.\n ruleIds = (ruleIds.toString() || void 0);\n const currentRuleIds = (currentResponsive && currentResponsive.ruleIds);\n // Changes in what rules apply\n if (ruleIds !== currentRuleIds) {\n // Undo previous rules. Before we apply a new set of rules, we\n // need to roll back completely to base options (#6291).\n if (currentResponsive) {\n this.update(currentResponsive.undoOptions, redraw, true);\n }\n if (ruleIds) {\n // Get undo-options for matching rules. The `undoOptions``\n // hold the current values before they are changed by the\n // `mergedOptions`.\n undoOptions = diffObjects(mergedOptions, this.options, true, this.collectionsWithUpdate);\n undoOptions.isResponsiveOptions = true;\n this.currentResponsive = {\n ruleIds: ruleIds,\n mergedOptions: mergedOptions,\n undoOptions: undoOptions\n };\n this.update(mergedOptions, redraw, true);\n }\n else {\n this.currentResponsive = void 0;\n }\n }\n }\n })(Responsive || (Responsive = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A callback function to gain complete control on when the responsive rule\n * applies.\n *\n * @callback Highcharts.ResponsiveCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * Chart context.\n *\n * @return {boolean}\n * Return `true` if it applies.\n */\n (''); // keeps doclets above in JS file\n /* *\n *\n * API Options\n *\n * */\n /**\n * Allows setting a set of rules to apply for different screen or chart\n * sizes. Each rule specifies additional chart options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @since 5.0.0\n * @apioption responsive\n */\n /**\n * A set of rules for responsive settings. The rules are executed from\n * the top down.\n *\n * @sample {highcharts} highcharts/responsive/axis/\n * Axis changes\n * @sample {highstock} highcharts/responsive/axis/\n * Axis changes\n * @sample {highmaps} highcharts/responsive/axis/\n * Axis changes\n *\n * @type {Array<*>}\n * @since 5.0.0\n * @apioption responsive.rules\n */\n /**\n * A full set of chart options to apply as overrides to the general\n * chart options. The chart options are applied when the given rule\n * is active.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](#xAxis), [yAxis](#yAxis) or [series](#series). For these\n * collections, an `id` option is used to map the new option set to\n * an existing object. If an existing object of the same id is not found,\n * the item of the same indexupdated. So for example, setting `chartOptions`\n * with two series items without an `id`, will cause the existing chart's\n * two series to be updated with respective options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @type {Highcharts.Options}\n * @since 5.0.0\n * @apioption responsive.rules.chartOptions\n */\n /**\n * Under which conditions the rule applies.\n *\n * @since 5.0.0\n * @apioption responsive.rules.condition\n */\n /**\n * A callback function to gain complete control on when the responsive\n * rule applies. Return `true` if it applies. This opens for checking\n * against other metrics than the chart size, for example the document\n * size or other elements.\n *\n * @type {Highcharts.ResponsiveCallbackFunction}\n * @since 5.0.0\n * @context Highcharts.Chart\n * @apioption responsive.rules.condition.callback\n */\n /**\n * The responsive rule applies if the chart height is less than this.\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxHeight\n */\n /**\n * The responsive rule applies if the chart width is less than this.\n *\n * @sample highcharts/responsive/axis/\n * Max width is 500\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxWidth\n */\n /**\n * The responsive rule applies if the chart height is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minHeight\n */\n /**\n * The responsive rule applies if the chart width is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minWidth\n */\n (''); // keeps doclets above in JS file\n\n return Responsive;\n });\n _registerModule(_modules, 'masters/highcharts.src.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js'], _modules['Core/Defaults.js'], _modules['Core/Animation/Fx.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Renderer/HTML/AST.js'], _modules['Core/Templating.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Renderer/HTML/HTMLElement.js'], _modules['Core/Renderer/HTML/HTMLRenderer.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Axis/DateTimeAxis.js'], _modules['Core/Axis/LogarithmicAxis.js'], _modules['Core/Axis/PlotLineOrBand/PlotLineOrBand.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Tooltip.js'], _modules['Core/Series/Point.js'], _modules['Core/Pointer.js'], _modules['Core/Legend/Legend.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Axis/Stacking/StackingAxis.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Series/Column/ColumnDataLabel.js'], _modules['Series/Pie/PieSeries.js'], _modules['Series/Pie/PieDataLabel.js'], _modules['Core/Series/DataLabel.js'], _modules['Core/Responsive.js'], _modules['Core/Color/Color.js'], _modules['Core/Time.js']], function (Highcharts, Utilities, Defaults, Fx, Animation, AST, Templating, RendererUtilities, SVGElement, SVGRenderer, HTMLElement, HTMLRenderer, Axis, DateTimeAxis, LogarithmicAxis, PlotLineOrBand, Tick, Tooltip, Point, Pointer, Legend, Chart, StackingAxis, StackItem, Series, SeriesRegistry, ColumnSeries, ColumnDataLabel, PieSeries, PieDataLabel, DataLabel, Responsive, Color, Time) {\n\n const G = Highcharts;\n // Animation\n G.animate = Animation.animate;\n G.animObject = Animation.animObject;\n G.getDeferredAnimation = Animation.getDeferredAnimation;\n G.setAnimation = Animation.setAnimation;\n G.stop = Animation.stop;\n G.timers = Fx.timers;\n // Classes\n G.AST = AST;\n G.Axis = Axis;\n G.Chart = Chart;\n G.chart = Chart.chart;\n G.Fx = Fx;\n G.Legend = Legend;\n G.PlotLineOrBand = PlotLineOrBand;\n G.Point = Point;\n G.Pointer = Pointer;\n G.Series = Series;\n G.StackItem = StackItem;\n G.SVGElement = SVGElement;\n G.SVGRenderer = SVGRenderer;\n G.Templating = Templating;\n G.Tick = Tick;\n G.Time = Time;\n G.Tooltip = Tooltip;\n // Color\n G.Color = Color;\n G.color = Color.parse;\n // Compositions\n HTMLRenderer.compose(SVGRenderer);\n HTMLElement.compose(SVGElement);\n Pointer.compose(Chart);\n Legend.compose(Chart);\n // DefaultOptions\n G.defaultOptions = Defaults.defaultOptions;\n G.getOptions = Defaults.getOptions;\n G.time = Defaults.defaultTime;\n G.setOptions = Defaults.setOptions;\n // Format Utilities\n G.dateFormat = Templating.dateFormat;\n G.format = Templating.format;\n G.numberFormat = Templating.numberFormat;\n // Utilities\n G.addEvent = Utilities.addEvent;\n G.arrayMax = Utilities.arrayMax;\n G.arrayMin = Utilities.arrayMin;\n G.attr = Utilities.attr;\n G.clearTimeout = Utilities.clearTimeout;\n G.correctFloat = Utilities.correctFloat;\n G.createElement = Utilities.createElement;\n G.css = Utilities.css;\n G.defined = Utilities.defined;\n G.destroyObjectProperties = Utilities.destroyObjectProperties;\n G.discardElement = Utilities.discardElement;\n G.distribute = RendererUtilities.distribute;\n G.erase = Utilities.erase;\n G.error = Utilities.error;\n G.extend = Utilities.extend;\n G.extendClass = Utilities.extendClass;\n G.find = Utilities.find;\n G.fireEvent = Utilities.fireEvent;\n G.getMagnitude = Utilities.getMagnitude;\n G.getStyle = Utilities.getStyle;\n G.inArray = Utilities.inArray;\n G.isArray = Utilities.isArray;\n G.isClass = Utilities.isClass;\n G.isDOMElement = Utilities.isDOMElement;\n G.isFunction = Utilities.isFunction;\n G.isNumber = Utilities.isNumber;\n G.isObject = Utilities.isObject;\n G.isString = Utilities.isString;\n G.keys = Utilities.keys;\n G.merge = Utilities.merge;\n G.normalizeTickInterval = Utilities.normalizeTickInterval;\n G.objectEach = Utilities.objectEach;\n G.offset = Utilities.offset;\n G.pad = Utilities.pad;\n G.pick = Utilities.pick;\n G.pInt = Utilities.pInt;\n G.relativeLength = Utilities.relativeLength;\n G.removeEvent = Utilities.removeEvent;\n G.seriesType = SeriesRegistry.seriesType;\n G.splat = Utilities.splat;\n G.stableSort = Utilities.stableSort;\n G.syncTimeout = Utilities.syncTimeout;\n G.timeUnits = Utilities.timeUnits;\n G.uniqueKey = Utilities.uniqueKey;\n G.useSerialIds = Utilities.useSerialIds;\n G.wrap = Utilities.wrap;\n // Compositions\n ColumnDataLabel.compose(ColumnSeries);\n DataLabel.compose(Series);\n DateTimeAxis.compose(Axis);\n LogarithmicAxis.compose(Axis);\n PieDataLabel.compose(PieSeries);\n PlotLineOrBand.compose(Axis);\n Responsive.compose(Chart);\n StackingAxis.compose(Axis, Chart, Series);\n Tooltip.compose(Pointer);\n // Default Export\n\n return G;\n });\n _modules['masters/highcharts.src.js']._modules = _modules;\n return _modules['masters/highcharts.src.js'];\n}));","/**\n * @license Highstock JS v11.1.0 (2023-06-05)\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (root, factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = root.document ?\n factory(root) :\n factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/highstock', function () {\n return factory(root);\n });\n } else {\n if (root.Highcharts) {\n root.Highcharts.error(16, true);\n }\n root.Highcharts = factory(root);\n }\n}(typeof window !== 'undefined' ? window : this, function (window) {\n 'use strict';\n var _modules = {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Core/Globals.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n /**\n * Shared Highcharts properties.\n * @private\n */\n var Globals;\n (function (Globals) {\n /* *\n *\n * Constants\n *\n * */\n Globals.SVG_NS = 'http://www.w3.org/2000/svg', Globals.product = 'Highcharts', Globals.version = '11.1.0', Globals.win = (typeof window !== 'undefined' ?\n window :\n {}), // eslint-disable-line node/no-unsupported-features/es-builtins\n Globals.doc = Globals.win.document, Globals.svg = (Globals.doc &&\n Globals.doc.createElementNS &&\n !!Globals.doc.createElementNS(Globals.SVG_NS, 'svg').createSVGRect), Globals.userAgent = (Globals.win.navigator && Globals.win.navigator.userAgent) || '', Globals.isChrome = Globals.userAgent.indexOf('Chrome') !== -1, Globals.isFirefox = Globals.userAgent.indexOf('Firefox') !== -1, Globals.isMS = /(edge|msie|trident)/i.test(Globals.userAgent) && !Globals.win.opera, Globals.isSafari = !Globals.isChrome && Globals.userAgent.indexOf('Safari') !== -1, Globals.isTouchDevice = /(Mobile|Android|Windows Phone)/.test(Globals.userAgent), Globals.isWebKit = Globals.userAgent.indexOf('AppleWebKit') !== -1, Globals.deg2rad = Math.PI * 2 / 360, Globals.hasBidiBug = (Globals.isFirefox &&\n parseInt(Globals.userAgent.split('Firefox/')[1], 10) < 4 // issue #38\n ), Globals.hasTouch = !!Globals.win.TouchEvent, Globals.marginNames = [\n 'plotTop',\n 'marginRight',\n 'marginBottom',\n 'plotLeft'\n ], Globals.noop = function () { }, Globals.supportsPassiveEvents = (function () {\n // Checks whether the browser supports passive events, (#11353).\n let supportsPassive = false;\n // Object.defineProperty doesn't work on IE as well as passive\n // events - instead of using polyfill, we can exclude IE totally.\n if (!Globals.isMS) {\n const opts = Object.defineProperty({}, 'passive', {\n get: function () {\n supportsPassive = true;\n }\n });\n if (Globals.win.addEventListener && Globals.win.removeEventListener) {\n Globals.win.addEventListener('testPassive', Globals.noop, opts);\n Globals.win.removeEventListener('testPassive', Globals.noop, opts);\n }\n }\n return supportsPassive;\n }());\n /**\n * An array containing the current chart objects in the page. A chart's\n * position in the array is preserved throughout the page's lifetime. When\n * a chart is destroyed, the array item becomes `undefined`.\n *\n * @name Highcharts.charts\n * @type {Array}\n */\n Globals.charts = [];\n /**\n * A hook for defining additional date format specifiers. New\n * specifiers are defined as key-value pairs by using the\n * specifier as key, and a function which takes the timestamp as\n * value. This function returns the formatted portion of the\n * date.\n *\n * @sample highcharts/global/dateformats/\n * Adding support for week number\n *\n * @name Highcharts.dateFormats\n * @type {Record}\n */\n Globals.dateFormats = {};\n /**\n * @private\n * @deprecated\n * @todo Use only `Core/Series/SeriesRegistry.seriesTypes`\n */\n Globals.seriesTypes = {};\n /**\n * @private\n */\n Globals.symbolSizes = {};\n /* *\n *\n * Properties\n *\n * */\n // eslint-disable-next-line prefer-const\n Globals.chartCount = 0;\n })(Globals || (Globals = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Theme options that should get applied to the chart. In module mode it\n * might not be possible to change this property because of read-only\n * restrictions, instead use {@link Highcharts.setOptions}.\n *\n * @deprecated\n * @name Highcharts.theme\n * @type {Highcharts.Options}\n */\n (''); // keeps doclets above in JS file\n\n return Globals;\n });\n _registerModule(_modules, 'Core/Utilities.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { charts, doc, win } = H;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Provide error messages for debugging, with links to online explanation. This\n * function can be overridden to provide custom error handling.\n *\n * @sample highcharts/chart/highcharts-error/\n * Custom error handler\n *\n * @function Highcharts.error\n *\n * @param {number|string} code\n * The error code. See\n * [errors.xml](https://github.com/highcharts/highcharts/blob/master/errors/errors.xml)\n * for available codes. If it is a string, the error message is printed\n * directly in the console.\n *\n * @param {boolean} [stop=false]\n * Whether to throw an error or just log a warning in the console.\n *\n * @param {Highcharts.Chart} [chart]\n * Reference to the chart that causes the error. Used in 'debugger'\n * module to display errors directly on the chart.\n * Important note: This argument is undefined for errors that lack\n * access to the Chart instance. In such case, the error will be\n * displayed on the last created chart.\n *\n * @param {Highcharts.Dictionary} [params]\n * Additional parameters for the generated message.\n *\n * @return {void}\n */\n function error(code, stop, chart, params) {\n const severity = stop ? 'Highcharts error' : 'Highcharts warning';\n if (code === 32) {\n code = `${severity}: Deprecated member`;\n }\n const isCode = isNumber(code);\n let message = isCode ?\n `${severity} #${code}: www.highcharts.com/errors/${code}/` :\n code.toString();\n const defaultHandler = function () {\n if (stop) {\n throw new Error(message);\n }\n // else ...\n if (win.console &&\n error.messages.indexOf(message) === -1 // prevent console flooting\n ) {\n console.warn(message); // eslint-disable-line no-console\n }\n };\n if (typeof params !== 'undefined') {\n let additionalMessages = '';\n if (isCode) {\n message += '?';\n }\n objectEach(params, function (value, key) {\n additionalMessages += `\\n - ${key}: ${value}`;\n if (isCode) {\n message += encodeURI(key) + '=' + encodeURI(value);\n }\n });\n message += additionalMessages;\n }\n fireEvent(H, 'displayError', { chart, code, message, params }, defaultHandler);\n error.messages.push(message);\n }\n (function (error) {\n error.messages = [];\n })(error || (error = {}));\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to deep merge two or more objects and return a third object.\n * If the first argument is true, the contents of the second object is copied\n * into the first object. The merge function can also be used with a single\n * object argument to create a deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {boolean} extend\n * Whether to extend the left-side object (a) or return a whole new\n * object.\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */ /**\n * Utility function to deep merge two or more objects and return a third object.\n * The merge function can also be used with a single object argument to create a\n * deep copy of an object.\n *\n * @function Highcharts.merge\n *\n * @param {T|undefined} a\n * The first object to extend. When only this is given, the function\n * returns a deep copy.\n *\n * @param {...Array} [n]\n * An object to merge into the previous one.\n *\n * @return {T}\n * The merged object. If the first argument is true, the return is the\n * same as the second argument.\n */\n function merge() {\n /* eslint-enable valid-jsdoc */\n let i, args = arguments, ret = {};\n const doCopy = function (copy, original) {\n // An object is replacing a primitive\n if (typeof copy !== 'object') {\n copy = {};\n }\n objectEach(original, function (value, key) {\n // Prototype pollution (#14883)\n if (key === '__proto__' || key === 'constructor') {\n return;\n }\n // Copy the contents of objects, but not arrays or DOM nodes\n if (isObject(value, true) &&\n !isClass(value) &&\n !isDOMElement(value)) {\n copy[key] = doCopy(copy[key] || {}, value);\n // Primitives and arrays are copied over directly\n }\n else {\n copy[key] = original[key];\n }\n });\n return copy;\n };\n // If first argument is true, copy into the existing object. Used in\n // setOptions.\n if (args[0] === true) {\n ret = args[1];\n args = Array.prototype.slice.call(args, 2);\n }\n // For each argument, extend the return\n const len = args.length;\n for (i = 0; i < len; i++) {\n ret = doCopy(ret, args[i]);\n }\n return ret;\n }\n /**\n * Constrain a value to within a lower and upper threshold.\n *\n * @private\n * @param {number} value The initial value\n * @param {number} min The lower threshold\n * @param {number} max The upper threshold\n * @return {number} Returns a number value within min and max.\n */\n function clamp(value, min, max) {\n return value > min ? value < max ? value : max : min;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Return the deep difference between two objects. It can either return the new\n * properties, or optionally return the old values of new properties.\n * @private\n */\n function diffObjects(newer, older, keepOlder, collectionsWithUpdate) {\n const ret = {};\n /**\n * Recurse over a set of options and its current values, and store the\n * current values in the ret object.\n */\n function diff(newer, older, ret, depth) {\n const keeper = keepOlder ? older : newer;\n objectEach(newer, function (newerVal, key) {\n if (!depth &&\n collectionsWithUpdate &&\n collectionsWithUpdate.indexOf(key) > -1 &&\n older[key]) {\n newerVal = splat(newerVal);\n ret[key] = [];\n // Iterate over collections like series, xAxis or yAxis and map\n // the items by index.\n for (let i = 0; i < Math.max(newerVal.length, older[key].length); i++) {\n // Item exists in current data (#6347)\n if (older[key][i]) {\n // If the item is missing from the new data, we need to\n // save the whole config structure. Like when\n // responsively updating from a dual axis layout to a\n // single axis and back (#13544).\n if (newerVal[i] === void 0) {\n ret[key][i] = older[key][i];\n // Otherwise, proceed\n }\n else {\n ret[key][i] = {};\n diff(newerVal[i], older[key][i], ret[key][i], depth + 1);\n }\n }\n }\n }\n else if (isObject(newerVal, true) &&\n !newerVal.nodeType // #10044\n ) {\n ret[key] = isArray(newerVal) ? [] : {};\n diff(newerVal, older[key] || {}, ret[key], depth + 1);\n // Delete empty nested objects\n if (Object.keys(ret[key]).length === 0 &&\n // Except colorAxis which is a special case where the empty\n // object means it is enabled. Which is unfortunate and we\n // should try to find a better way.\n !(key === 'colorAxis' && depth === 0)) {\n delete ret[key];\n }\n }\n else if (newer[key] !== older[key] ||\n // If the newer key is explicitly undefined, keep it (#10525)\n (key in newer && !(key in older))) {\n ret[key] = keeper[key];\n }\n });\n }\n diff(newer, older, ret, 0);\n return ret;\n }\n /**\n * Shortcut for parseInt\n *\n * @private\n * @function Highcharts.pInt\n *\n * @param {*} s\n * any\n *\n * @param {number} [mag]\n * Magnitude\n *\n * @return {number}\n * number\n */\n function pInt(s, mag) {\n return parseInt(s, mag || 10);\n }\n /**\n * Utility function to check for string type.\n *\n * @function Highcharts.isString\n *\n * @param {*} s\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a string.\n */\n function isString(s) {\n return typeof s === 'string';\n }\n /**\n * Utility function to check if an item is an array.\n *\n * @function Highcharts.isArray\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is an array.\n */\n function isArray(obj) {\n const str = Object.prototype.toString.call(obj);\n return str === '[object Array]' || str === '[object Array Iterator]';\n }\n /**\n * Utility function to check if an item is of type object.\n *\n * @function Highcharts.isObject\n *\n * @param {*} obj\n * The item to check.\n *\n * @param {boolean} [strict=false]\n * Also checks that the object is not an array.\n *\n * @return {boolean}\n * True if the argument is an object.\n */\n function isObject(obj, strict) {\n return (!!obj &&\n typeof obj === 'object' &&\n (!strict || !isArray(obj))); // eslint-disable-line @typescript-eslint/no-explicit-any\n }\n /**\n * Utility function to check if an Object is a HTML Element.\n *\n * @function Highcharts.isDOMElement\n *\n * @param {*} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a HTML Element.\n */\n function isDOMElement(obj) {\n return isObject(obj) && typeof obj.nodeType === 'number';\n }\n /**\n * Utility function to check if an Object is a class.\n *\n * @function Highcharts.isClass\n *\n * @param {object|undefined} obj\n * The item to check.\n *\n * @return {boolean}\n * True if the argument is a class.\n */\n function isClass(obj) {\n const c = obj && obj.constructor;\n return !!(isObject(obj, true) &&\n !isDOMElement(obj) &&\n (c && c.name && c.name !== 'Object'));\n }\n /**\n * Utility function to check if an item is a number and it is finite (not NaN,\n * Infinity or -Infinity).\n *\n * @function Highcharts.isNumber\n *\n * @param {*} n\n * The item to check.\n *\n * @return {boolean}\n * True if the item is a finite number\n */\n function isNumber(n) {\n return typeof n === 'number' && !isNaN(n) && n < Infinity && n > -Infinity;\n }\n /**\n * Remove the last occurence of an item from an array.\n *\n * @function Highcharts.erase\n *\n * @param {Array<*>} arr\n * The array.\n *\n * @param {*} item\n * The item to remove.\n *\n * @return {void}\n */\n function erase(arr, item) {\n let i = arr.length;\n while (i--) {\n if (arr[i] === item) {\n arr.splice(i, 1);\n break;\n }\n }\n }\n /**\n * Insert a series or an axis in a collection with other items, either the\n * chart series or yAxis series or axis collections, in the correct order\n * according to the index option and whether it is internal. Used internally\n * when adding series and axes.\n *\n * @private\n * @function Highcharts.Chart#insertItem\n * @param {Highcharts.Series|Highcharts.Axis} item\n * The item to insert\n * @param {Array|Array} collection\n * A collection of items, like `chart.series` or `xAxis.series`.\n * @return {number} The index of the series in the collection.\n */\n function insertItem(item, collection) {\n const indexOption = item.options.index, length = collection.length;\n let i;\n for (\n // Internal item (navigator) should always be pushed to the end\n i = item.options.isInternal ? length : 0; i < length + 1; i++) {\n if (\n // No index option, reached the end of the collection,\n // equivalent to pushing\n !collection[i] ||\n // Handle index option, the element to insert has lower index\n (isNumber(indexOption) &&\n indexOption < pick(collection[i].options.index, collection[i]._i)) ||\n // Insert the new item before other internal items\n // (navigator)\n collection[i].options.isInternal) {\n collection.splice(i, 0, item);\n break;\n }\n }\n return i;\n }\n /**\n * Adds an item to an array, if it is not present in the array.\n *\n * @function Highcharts.pushUnique\n *\n * @param {Array} array\n * The array to add the item to.\n *\n * @param {unknown} item\n * The item to add.\n *\n * @return {boolean}\n * Returns true, if the item was not present and has been added.\n */\n function pushUnique(array, item) {\n return array.indexOf(item) < 0 && !!array.push(item);\n }\n /**\n * Check if an object is null or undefined.\n *\n * @function Highcharts.defined\n *\n * @param {*} obj\n * The object to check.\n *\n * @return {boolean}\n * False if the object is null or undefined, otherwise true.\n */\n function defined(obj) {\n return typeof obj !== 'undefined' && obj !== null;\n }\n /**\n * Set or get an attribute or an object of attributes.\n *\n * To use as a setter, pass a key and a value, or let the second argument be a\n * collection of keys and values. When using a collection, passing a value of\n * `null` or `undefined` will remove the attribute.\n *\n * To use as a getter, pass only a string as the second argument.\n *\n * @function Highcharts.attr\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} elem\n * The DOM element to receive the attribute(s).\n *\n * @param {string|Highcharts.HTMLAttributes|Highcharts.SVGAttributes} [keyOrAttribs]\n * The property or an object of key-value pairs.\n *\n * @param {number|string} [value]\n * The value if a single property is set.\n *\n * @return {string|null|undefined}\n * When used as a getter, return the value.\n */\n function attr(elem, keyOrAttribs, value) {\n const isGetter = isString(keyOrAttribs) && !defined(value);\n let ret;\n const attrSingle = (value, key) => {\n // Set the value\n if (defined(value)) {\n elem.setAttribute(key, value);\n // Get the value\n }\n else if (isGetter) {\n ret = elem.getAttribute(key);\n // IE7 and below cannot get class through getAttribute (#7850)\n if (!ret && key === 'class') {\n ret = elem.getAttribute(key + 'Name');\n }\n // Remove the value\n }\n else {\n elem.removeAttribute(key);\n }\n };\n // If keyOrAttribs is a string\n if (isString(keyOrAttribs)) {\n attrSingle(value, keyOrAttribs);\n // Else if keyOrAttribs is defined, it is a hash of key/value pairs\n }\n else {\n objectEach(keyOrAttribs, attrSingle);\n }\n return ret;\n }\n /**\n * Check if an element is an array, and if not, make it into an array.\n *\n * @function Highcharts.splat\n *\n * @param {*} obj\n * The object to splat.\n *\n * @return {Array}\n * The produced or original array.\n */\n function splat(obj) {\n return isArray(obj) ? obj : [obj];\n }\n /**\n * Set a timeout if the delay is given, otherwise perform the function\n * synchronously.\n *\n * @function Highcharts.syncTimeout\n *\n * @param {Function} fn\n * The function callback.\n *\n * @param {number} delay\n * Delay in milliseconds.\n *\n * @param {*} [context]\n * An optional context to send to the function callback.\n *\n * @return {number}\n * An identifier for the timeout that can later be cleared with\n * Highcharts.clearTimeout. Returns -1 if there is no timeout.\n */\n function syncTimeout(fn, delay, context) {\n if (delay > 0) {\n return setTimeout(fn, delay, context);\n }\n fn.call(0, context);\n return -1;\n }\n /**\n * Internal clear timeout. The function checks that the `id` was not removed\n * (e.g. by `chart.destroy()`). For the details see\n * [issue #7901](https://github.com/highcharts/highcharts/issues/7901).\n *\n * @function Highcharts.clearTimeout\n *\n * @param {number|undefined} id\n * Id of a timeout.\n */\n function internalClearTimeout(id) {\n if (defined(id)) {\n clearTimeout(id);\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Utility function to extend an object with the members of another.\n *\n * @function Highcharts.extend\n *\n * @param {T|undefined} a\n * The object to be extended.\n *\n * @param {Partial} b\n * The object to add to the first one.\n *\n * @return {T}\n * Object a, the original object.\n */\n function extend(a, b) {\n /* eslint-enable valid-jsdoc */\n let n;\n if (!a) {\n a = {};\n }\n for (n in b) { // eslint-disable-line guard-for-in\n a[n] = b[n];\n }\n return a;\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Return the first value that is not null or undefined.\n *\n * @function Highcharts.pick\n *\n * @param {...Array} items\n * Variable number of arguments to inspect.\n *\n * @return {T}\n * The value of the first argument that is not null or undefined.\n */\n function pick() {\n const args = arguments;\n const length = args.length;\n for (let i = 0; i < length; i++) {\n const arg = args[i];\n if (typeof arg !== 'undefined' && arg !== null) {\n return arg;\n }\n }\n }\n /**\n * Set CSS on a given element.\n *\n * @function Highcharts.css\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} el\n * An HTML DOM element.\n *\n * @param {Highcharts.CSSObject} styles\n * Style object with camel case property names.\n *\n * @return {void}\n */\n function css(el, styles) {\n if (H.isMS && !H.svg) { // #2686\n if (styles && defined(styles.opacity)) {\n styles.filter = `alpha(opacity=${styles.opacity * 100})`;\n }\n }\n extend(el.style, styles);\n }\n /**\n * Utility function to create an HTML element with attributes and styles.\n *\n * @function Highcharts.createElement\n *\n * @param {string} tag\n * The HTML tag.\n *\n * @param {Highcharts.HTMLAttributes} [attribs]\n * Attributes as an object of key-value pairs.\n *\n * @param {Highcharts.CSSObject} [styles]\n * Styles as an object of key-value pairs.\n *\n * @param {Highcharts.HTMLDOMElement} [parent]\n * The parent HTML object.\n *\n * @param {boolean} [nopad=false]\n * If true, remove all padding, border and margin.\n *\n * @return {Highcharts.HTMLDOMElement}\n * The created DOM element.\n */\n function createElement(tag, attribs, styles, parent, nopad) {\n const el = doc.createElement(tag);\n if (attribs) {\n extend(el, attribs);\n }\n if (nopad) {\n css(el, { padding: '0', border: 'none', margin: '0' });\n }\n if (styles) {\n css(el, styles);\n }\n if (parent) {\n parent.appendChild(el);\n }\n return el;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Extend a prototyped class by new members.\n *\n * @deprecated\n * @function Highcharts.extendClass\n *\n * @param {Highcharts.Class} parent\n * The parent prototype to inherit.\n *\n * @param {Highcharts.Dictionary<*>} members\n * A collection of prototype members to add or override compared to the\n * parent prototype.\n *\n * @return {Highcharts.Class}\n * A new prototype.\n */\n function extendClass(parent, members) {\n const obj = (function () { });\n obj.prototype = new parent(); // eslint-disable-line new-cap\n extend(obj.prototype, members);\n return obj;\n }\n /**\n * Left-pad a string to a given length by adding a character repetitively.\n *\n * @function Highcharts.pad\n *\n * @param {number} number\n * The input string or number.\n *\n * @param {number} [length]\n * The desired string length.\n *\n * @param {string} [padder=0]\n * The character to pad with.\n *\n * @return {string}\n * The padded string.\n */\n function pad(number, length, padder) {\n return new Array((length || 2) +\n 1 -\n String(number)\n .replace('-', '')\n .length).join(padder || '0') + number;\n }\n /**\n * Return a length based on either the integer value, or a percentage of a base.\n *\n * @function Highcharts.relativeLength\n *\n * @param {Highcharts.RelativeSize} value\n * A percentage string or a number.\n *\n * @param {number} base\n * The full length that represents 100%.\n *\n * @param {number} [offset=0]\n * A pixel offset to apply for percentage values. Used internally in\n * axis positioning.\n *\n * @return {number}\n * The computed length.\n */\n function relativeLength(value, base, offset) {\n return (/%$/).test(value) ?\n (base * parseFloat(value) / 100) + (offset || 0) :\n parseFloat(value);\n }\n /**\n * Wrap a method with extended functionality, preserving the original function.\n *\n * @function Highcharts.wrap\n *\n * @param {*} obj\n * The context object that the method belongs to. In real cases, this is\n * often a prototype.\n *\n * @param {string} method\n * The name of the method to extend.\n *\n * @param {Highcharts.WrapProceedFunction} func\n * A wrapper function callback. This function is called with the same\n * arguments as the original function, except that the original function\n * is unshifted and passed as the first argument.\n */\n function wrap(obj, method, func) {\n const proceed = obj[method];\n obj[method] = function () {\n const outerArgs = arguments, scope = this;\n return func.apply(this, [\n function () {\n return proceed.apply(scope, arguments.length ? arguments : outerArgs);\n }\n ].concat([].slice.call(arguments)));\n };\n }\n /**\n * Get the magnitude of a number.\n *\n * @function Highcharts.getMagnitude\n *\n * @param {number} num\n * The number.\n *\n * @return {number}\n * The magnitude, where 1-9 are magnitude 1, 10-99 magnitude 2 etc.\n */\n function getMagnitude(num) {\n return Math.pow(10, Math.floor(Math.log(num) / Math.LN10));\n }\n /**\n * Take an interval and normalize it to multiples of round numbers.\n *\n * @deprecated\n * @function Highcharts.normalizeTickInterval\n *\n * @param {number} interval\n * The raw, un-rounded interval.\n *\n * @param {Array<*>} [multiples]\n * Allowed multiples.\n *\n * @param {number} [magnitude]\n * The magnitude of the number.\n *\n * @param {boolean} [allowDecimals]\n * Whether to allow decimals.\n *\n * @param {boolean} [hasTickAmount]\n * If it has tickAmount, avoid landing on tick intervals lower than\n * original.\n *\n * @return {number}\n * The normalized interval.\n *\n * @todo\n * Move this function to the Axis prototype. It is here only for historical\n * reasons.\n */\n function normalizeTickInterval(interval, multiples, magnitude, allowDecimals, hasTickAmount) {\n let i, retInterval = interval;\n // round to a tenfold of 1, 2, 2.5 or 5\n magnitude = pick(magnitude, getMagnitude(interval));\n const normalized = interval / magnitude;\n // multiples for a linear scale\n if (!multiples) {\n multiples = hasTickAmount ?\n // Finer grained ticks when the tick amount is hard set, including\n // when alignTicks is true on multiple axes (#4580).\n [1, 1.2, 1.5, 2, 2.5, 3, 4, 5, 6, 8, 10] :\n // Else, let ticks fall on rounder numbers\n [1, 2, 2.5, 5, 10];\n // the allowDecimals option\n if (allowDecimals === false) {\n if (magnitude === 1) {\n multiples = multiples.filter(function (num) {\n return num % 1 === 0;\n });\n }\n else if (magnitude <= 0.1) {\n multiples = [1 / magnitude];\n }\n }\n }\n // normalize the interval to the nearest multiple\n for (i = 0; i < multiples.length; i++) {\n retInterval = multiples[i];\n // only allow tick amounts smaller than natural\n if ((hasTickAmount &&\n retInterval * magnitude >= interval) ||\n (!hasTickAmount &&\n (normalized <=\n (multiples[i] +\n (multiples[i + 1] || multiples[i])) / 2))) {\n break;\n }\n }\n // Multiply back to the correct magnitude. Correct floats to appropriate\n // precision (#6085).\n retInterval = correctFloat(retInterval * magnitude, -Math.round(Math.log(0.001) / Math.LN10));\n return retInterval;\n }\n /**\n * Sort an object array and keep the order of equal items. The ECMAScript\n * standard does not specify the behaviour when items are equal.\n *\n * @function Highcharts.stableSort\n *\n * @param {Array<*>} arr\n * The array to sort.\n *\n * @param {Function} sortFunction\n * The function to sort it with, like with regular Array.prototype.sort.\n */\n function stableSort(arr, sortFunction) {\n // @todo It seems like Chrome since v70 sorts in a stable way internally,\n // plus all other browsers do it, so over time we may be able to remove this\n // function\n const length = arr.length;\n let sortValue, i;\n // Add index to each item\n for (i = 0; i < length; i++) {\n arr[i].safeI = i; // stable sort index\n }\n arr.sort(function (a, b) {\n sortValue = sortFunction(a, b);\n return sortValue === 0 ? a.safeI - b.safeI : sortValue;\n });\n // Remove index from items\n for (i = 0; i < length; i++) {\n delete arr[i].safeI; // stable sort index\n }\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.min` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMin\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The lowest number.\n */\n function arrayMin(data) {\n let i = data.length, min = data[0];\n while (i--) {\n if (data[i] < min) {\n min = data[i];\n }\n }\n return min;\n }\n /**\n * Non-recursive method to find the lowest member of an array. `Math.max` raises\n * a maximum call stack size exceeded error in Chrome when trying to apply more\n * than 150.000 points. This method is slightly slower, but safe.\n *\n * @function Highcharts.arrayMax\n *\n * @param {Array<*>} data\n * An array of numbers.\n *\n * @return {number}\n * The highest number.\n */\n function arrayMax(data) {\n let i = data.length, max = data[0];\n while (i--) {\n if (data[i] > max) {\n max = data[i];\n }\n }\n return max;\n }\n /**\n * Utility method that destroys any SVGElement instances that are properties on\n * the given object. It loops all properties and invokes destroy if there is a\n * destroy method. The property is then delete.\n *\n * @function Highcharts.destroyObjectProperties\n *\n * @param {*} obj\n * The object to destroy properties on.\n *\n * @param {*} [except]\n * Exception, do not destroy this property, only delete it.\n */\n function destroyObjectProperties(obj, except) {\n objectEach(obj, function (val, n) {\n // If the object is non-null and destroy is defined\n if (val && val !== except && val.destroy) {\n // Invoke the destroy\n val.destroy();\n }\n // Delete the property from the object.\n delete obj[n];\n });\n }\n /**\n * Discard a HTML element\n *\n * @function Highcharts.discardElement\n *\n * @param {Highcharts.HTMLDOMElement} element\n * The HTML node to discard.\n */\n function discardElement(element) {\n if (element && element.parentElement) {\n element.parentElement.removeChild(element);\n }\n }\n /**\n * Fix JS round off float errors.\n *\n * @function Highcharts.correctFloat\n *\n * @param {number} num\n * A float number to fix.\n *\n * @param {number} [prec=14]\n * The precision.\n *\n * @return {number}\n * The corrected float number.\n */\n function correctFloat(num, prec) {\n // When the number is higher than 1e14 use the number (#16275)\n return num > 1e14 ? num : parseFloat(num.toPrecision(prec || 14));\n }\n /**\n * The time unit lookup\n *\n * @ignore\n */\n const timeUnits = {\n millisecond: 1,\n second: 1000,\n minute: 60000,\n hour: 3600000,\n day: 24 * 3600000,\n week: 7 * 24 * 3600000,\n month: 28 * 24 * 3600000,\n year: 364 * 24 * 3600000\n };\n /**\n * Easing definition\n *\n * @private\n * @function Math.easeInOutSine\n *\n * @param {number} pos\n * Current position, ranging from 0 to 1.\n *\n * @return {number}\n * Ease result\n */\n Math.easeInOutSine = function (pos) {\n return -0.5 * (Math.cos(Math.PI * pos) - 1);\n };\n /**\n * Find the closest distance between two values of a two-dimensional array\n * @private\n * @function Highcharts.getClosestDistance\n *\n * @param {Array>} arrays\n * An array of arrays of numbers\n *\n * @return {number | undefined}\n * The closest distance between values\n */\n function getClosestDistance(arrays, onError) {\n const allowNegative = !onError;\n let closest, loopLength, distance, i;\n arrays.forEach((xData) => {\n if (xData.length > 1) {\n loopLength = xData.length - 1;\n for (i = loopLength; i > 0; i--) {\n distance = xData[i] - xData[i - 1];\n if (distance < 0 && !allowNegative) {\n onError === null || onError === void 0 ? void 0 : onError();\n // Only one call\n onError = void 0;\n }\n else if (distance && (typeof closest === 'undefined' || distance < closest)) {\n closest = distance;\n }\n }\n }\n });\n return closest;\n }\n /**\n * Returns the value of a property path on a given object.\n *\n * @private\n * @function getNestedProperty\n *\n * @param {string} path\n * Path to the property, for example `custom.myValue`.\n *\n * @param {unknown} obj\n * Instance containing the property on the specific path.\n *\n * @return {unknown}\n * The unknown property value.\n */\n function getNestedProperty(path, parent) {\n const pathElements = path.split('.');\n while (pathElements.length && defined(parent)) {\n const pathElement = pathElements.shift();\n // Filter on the key\n if (typeof pathElement === 'undefined' ||\n pathElement === '__proto__') {\n return; // undefined\n }\n if (pathElement === 'this') {\n let thisProp;\n if (isObject(parent)) {\n thisProp = parent['@this'];\n }\n return thisProp !== null && thisProp !== void 0 ? thisProp : parent;\n }\n const child = parent[pathElement];\n // Filter on the child\n if (!defined(child) ||\n typeof child === 'function' ||\n typeof child.nodeType === 'number' ||\n child === win) {\n return; // undefined\n }\n // Else, proceed\n parent = child;\n }\n return parent;\n }\n /**\n * Get the computed CSS value for given element and property, only for numerical\n * properties. For width and height, the dimension of the inner box (excluding\n * padding) is returned. Used for fitting the chart within the container.\n *\n * @function Highcharts.getStyle\n *\n * @param {Highcharts.HTMLDOMElement} el\n * An HTML element.\n *\n * @param {string} prop\n * The property name.\n *\n * @param {boolean} [toInt=true]\n * Parse to integer.\n *\n * @return {number|string|undefined}\n * The style value.\n */\n function getStyle(el, prop, toInt) {\n let style;\n // For width and height, return the actual inner pixel size (#4913)\n if (prop === 'width') {\n let offsetWidth = Math.min(el.offsetWidth, el.scrollWidth);\n // In flex boxes, we need to use getBoundingClientRect and floor it,\n // because scrollWidth doesn't support subpixel precision (#6427) ...\n const boundingClientRectWidth = el.getBoundingClientRect &&\n el.getBoundingClientRect().width;\n // ...unless if the containing div or its parents are transform-scaled\n // down, in which case the boundingClientRect can't be used as it is\n // also scaled down (#9871, #10498).\n if (boundingClientRectWidth < offsetWidth &&\n boundingClientRectWidth >= offsetWidth - 1) {\n offsetWidth = Math.floor(boundingClientRectWidth);\n }\n return Math.max(0, // #8377\n (offsetWidth -\n (getStyle(el, 'padding-left', true) || 0) -\n (getStyle(el, 'padding-right', true) || 0)));\n }\n if (prop === 'height') {\n return Math.max(0, // #8377\n (Math.min(el.offsetHeight, el.scrollHeight) -\n (getStyle(el, 'padding-top', true) || 0) -\n (getStyle(el, 'padding-bottom', true) || 0)));\n }\n // Otherwise, get the computed style\n const css = win.getComputedStyle(el, void 0); // eslint-disable-line no-undefined\n if (css) {\n style = css.getPropertyValue(prop);\n if (pick(toInt, prop !== 'opacity')) {\n style = pInt(style);\n }\n }\n return style;\n }\n /**\n * Search for an item in an array.\n *\n * @function Highcharts.inArray\n *\n * @deprecated\n *\n * @param {*} item\n * The item to search for.\n *\n * @param {Array<*>} arr\n * The array or node collection to search in.\n *\n * @param {number} [fromIndex=0]\n * The index to start searching from.\n *\n * @return {number}\n * The index within the array, or -1 if not found.\n */\n function inArray(item, arr, fromIndex) {\n error(32, false, void 0, { 'Highcharts.inArray': 'use Array.indexOf' });\n return arr.indexOf(item, fromIndex);\n }\n /**\n * Return the value of the first element in the array that satisfies the\n * provided testing function.\n *\n * @function Highcharts.find\n *\n * @param {Array} arr\n * The array to test.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if this item satisfies the condition.\n *\n * @return {T|undefined}\n * The value of the element.\n */\n const find = Array.prototype.find ?\n function (arr, callback) {\n return arr.find(callback);\n } :\n // Legacy implementation. PhantomJS, IE <= 11 etc. #7223.\n function (arr, callback) {\n let i;\n const length = arr.length;\n for (i = 0; i < length; i++) {\n if (callback(arr[i], i)) { // eslint-disable-line node/callback-return\n return arr[i];\n }\n }\n };\n /**\n * Returns an array of a given object's own properties.\n *\n * @function Highcharts.keys\n * @deprecated\n *\n * @param {*} obj\n * The object of which the properties are to be returned.\n *\n * @return {Array}\n * An array of strings that represents all the properties.\n */\n function keys(obj) {\n error(32, false, void 0, { 'Highcharts.keys': 'use Object.keys' });\n return Object.keys(obj);\n }\n /**\n * Get the element's offset position, corrected for `overflow: auto`.\n *\n * @function Highcharts.offset\n *\n * @param {global.Element} el\n * The DOM element.\n *\n * @return {Highcharts.OffsetObject}\n * An object containing `left` and `top` properties for the position in\n * the page.\n */\n function offset(el) {\n const docElem = doc.documentElement, box = (el.parentElement || el.parentNode) ?\n el.getBoundingClientRect() :\n { top: 0, left: 0, width: 0, height: 0 };\n return {\n top: box.top + (win.pageYOffset || docElem.scrollTop) -\n (docElem.clientTop || 0),\n left: box.left + (win.pageXOffset || docElem.scrollLeft) -\n (docElem.clientLeft || 0),\n width: box.width,\n height: box.height\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Iterate over object key pairs in an object.\n *\n * @function Highcharts.objectEach\n *\n * @param {*} obj\n * The object to iterate over.\n *\n * @param {Highcharts.ObjectEachCallbackFunction} fn\n * The iterator callback. It passes three arguments:\n * * value - The property value.\n * * key - The property key.\n * * obj - The object that objectEach is being applied to.\n *\n * @param {T} [ctx]\n * The context.\n */\n function objectEach(obj, fn, ctx) {\n /* eslint-enable valid-jsdoc */\n for (const key in obj) {\n if (Object.hasOwnProperty.call(obj, key)) {\n fn.call(ctx || obj[key], obj[key], key, obj);\n }\n }\n }\n /**\n * Iterate over an array.\n *\n * @deprecated\n * @function Highcharts.each\n *\n * @param {Array<*>} arr\n * The array to iterate over.\n *\n * @param {Function} fn\n * The iterator callback. It passes three arguments:\n * - `item`: The array item.\n * - `index`: The item's index in the array.\n * - `arr`: The array that each is being applied to.\n *\n * @param {*} [ctx]\n * The context.\n *\n * @return {void}\n */\n /**\n * Filter an array by a callback.\n *\n * @deprecated\n * @function Highcharts.grep\n *\n * @param {Array<*>} arr\n * The array to filter.\n *\n * @param {Function} callback\n * The callback function. The function receives the item as the first\n * argument. Return `true` if the item is to be preserved.\n *\n * @return {Array<*>}\n * A new, filtered array.\n */\n /**\n * Map an array by a callback.\n *\n * @deprecated\n * @function Highcharts.map\n *\n * @param {Array<*>} arr\n * The array to map.\n *\n * @param {Function} fn\n * The callback function. Return the new value for the new array.\n *\n * @return {Array<*>}\n * A new array item with modified items.\n */\n /**\n * Reduce an array to a single value.\n *\n * @deprecated\n * @function Highcharts.reduce\n *\n * @param {Array<*>} arr\n * The array to reduce.\n *\n * @param {Function} fn\n * The callback function. Return the reduced value. Receives 4\n * arguments: Accumulated/reduced value, current value, current array\n * index, and the array.\n *\n * @param {*} initialValue\n * The initial value of the accumulator.\n *\n * @return {*}\n * The reduced value.\n */\n /**\n * Test whether at least one element in the array passes the test implemented by\n * the provided function.\n *\n * @deprecated\n * @function Highcharts.some\n *\n * @param {Array<*>} arr\n * The array to test\n *\n * @param {Function} fn\n * The function to run on each item. Return truty to pass the test.\n * Receives arguments `currentValue`, `index` and `array`.\n *\n * @param {*} ctx\n * The context.\n *\n * @return {boolean}\n */\n objectEach({\n map: 'map',\n each: 'forEach',\n grep: 'filter',\n reduce: 'reduce',\n some: 'some'\n }, function (val, key) {\n H[key] = function (arr) {\n error(32, false, void 0, { [`Highcharts.${key}`]: `use Array.${val}` });\n return Array.prototype[val].apply(arr, [].slice.call(arguments, 1));\n };\n });\n /* eslint-disable valid-jsdoc */\n /**\n * Add an event listener.\n *\n * @function Highcharts.addEvent\n *\n * @param {Highcharts.Class|T} el\n * The element or object to add a listener to. It can be a\n * {@link HTMLDOMElement}, an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The event type.\n *\n * @param {Highcharts.EventCallbackFunction|Function} fn\n * The function callback to execute when the event is fired.\n *\n * @param {Highcharts.EventOptionsObject} [options]\n * Options for adding the event.\n *\n * @return {Function}\n * A callback function to remove the added event.\n */\n function addEvent(el, type, fn, options = {}) {\n /* eslint-enable valid-jsdoc */\n // Add hcEvents to either the prototype (in case we're running addEvent on a\n // class) or the instance. If hasOwnProperty('hcEvents') is false, it is\n // inherited down the prototype chain, in which case we need to set the\n // property on this instance (which may itself be a prototype).\n const owner = typeof el === 'function' && el.prototype || el;\n if (!Object.hasOwnProperty.call(owner, 'hcEvents')) {\n owner.hcEvents = {};\n }\n const events = owner.hcEvents;\n // Allow click events added to points, otherwise they will be prevented by\n // the TouchPointer.pinch function after a pinch zoom operation (#7091).\n if (H.Point && // without H a dependency loop occurs\n el instanceof H.Point &&\n el.series &&\n el.series.chart) {\n el.series.chart.runTrackerClick = true;\n }\n // Handle DOM events\n // If the browser supports passive events, add it to improve performance\n // on touch events (#11353).\n const addEventListener = el.addEventListener;\n if (addEventListener) {\n addEventListener.call(el, type, fn, H.supportsPassiveEvents ? {\n passive: options.passive === void 0 ?\n type.indexOf('touch') !== -1 : options.passive,\n capture: false\n } : false);\n }\n if (!events[type]) {\n events[type] = [];\n }\n const eventObject = {\n fn,\n order: typeof options.order === 'number' ? options.order : Infinity\n };\n events[type].push(eventObject);\n // Order the calls\n events[type].sort((a, b) => a.order - b.order);\n // Return a function that can be called to remove this event.\n return function () {\n removeEvent(el, type, fn);\n };\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Remove an event that was added with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.removeEvent\n *\n * @param {Highcharts.Class|T} el\n * The element to remove events on.\n *\n * @param {string} [type]\n * The type of events to remove. If undefined, all events are removed\n * from the element.\n *\n * @param {Highcharts.EventCallbackFunction} [fn]\n * The specific callback to remove. If undefined, all events that match\n * the element and optionally the type are removed.\n *\n * @return {void}\n */\n function removeEvent(el, type, fn) {\n /* eslint-enable valid-jsdoc */\n /**\n * @private\n */\n function removeOneEvent(type, fn) {\n const removeEventListener = el.removeEventListener;\n if (removeEventListener) {\n removeEventListener.call(el, type, fn, false);\n }\n }\n /**\n * @private\n */\n function removeAllEvents(eventCollection) {\n let types, len;\n if (!el.nodeName) {\n return; // break on non-DOM events\n }\n if (type) {\n types = {};\n types[type] = true;\n }\n else {\n types = eventCollection;\n }\n objectEach(types, function (_val, n) {\n if (eventCollection[n]) {\n len = eventCollection[n].length;\n while (len--) {\n removeOneEvent(n, eventCollection[n][len].fn);\n }\n }\n });\n }\n const owner = typeof el === 'function' && el.prototype || el;\n if (Object.hasOwnProperty.call(owner, 'hcEvents')) {\n const events = owner.hcEvents;\n if (type) {\n const typeEvents = (events[type] || []);\n if (fn) {\n events[type] = typeEvents.filter(function (obj) {\n return fn !== obj.fn;\n });\n removeOneEvent(type, fn);\n }\n else {\n removeAllEvents(events);\n events[type] = [];\n }\n }\n else {\n removeAllEvents(events);\n delete owner.hcEvents;\n }\n }\n }\n /* eslint-disable valid-jsdoc */\n /**\n * Fire an event that was registered with {@link Highcharts#addEvent}.\n *\n * @function Highcharts.fireEvent\n *\n * @param {T} el\n * The object to fire the event on. It can be a {@link HTMLDOMElement},\n * an {@link SVGElement} or any other object.\n *\n * @param {string} type\n * The type of event.\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Custom event arguments that are passed on as an argument to the event\n * handler.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * The default function to execute if the other listeners haven't\n * returned false.\n *\n * @return {void}\n */\n function fireEvent(el, type, eventArguments, defaultFunction) {\n /* eslint-enable valid-jsdoc */\n let e, i;\n eventArguments = eventArguments || {};\n if (doc.createEvent &&\n (el.dispatchEvent ||\n (el.fireEvent &&\n // Enable firing events on Highcharts instance.\n el !== H))) {\n e = doc.createEvent('Events');\n e.initEvent(type, true, true);\n eventArguments = extend(e, eventArguments);\n if (el.dispatchEvent) {\n el.dispatchEvent(eventArguments);\n }\n else {\n el.fireEvent(type, eventArguments);\n }\n }\n else if (el.hcEvents) {\n if (!eventArguments.target) {\n // We're running a custom event\n extend(eventArguments, {\n // Attach a simple preventDefault function to skip\n // default handler if called. The built-in\n // defaultPrevented property is not overwritable (#5112)\n preventDefault: function () {\n eventArguments.defaultPrevented = true;\n },\n // Setting target to native events fails with clicking\n // the zoom-out button in Chrome.\n target: el,\n // If the type is not set, we're running a custom event\n // (#2297). If it is set, we're running a browser event.\n type: type\n });\n }\n const events = [];\n let object = el;\n let multilevel = false;\n // Recurse up the inheritance chain and collect hcEvents set as own\n // objects on the prototypes.\n while (object.hcEvents) {\n if (Object.hasOwnProperty.call(object, 'hcEvents') &&\n object.hcEvents[type]) {\n if (events.length) {\n multilevel = true;\n }\n events.unshift.apply(events, object.hcEvents[type]);\n }\n object = Object.getPrototypeOf(object);\n }\n // For performance reasons, only sort the event handlers in case we are\n // dealing with multiple levels in the prototype chain. Otherwise, the\n // events are already sorted in the addEvent function.\n if (multilevel) {\n // Order the calls\n events.sort((a, b) => a.order - b.order);\n }\n // Call the collected event handlers\n events.forEach((obj) => {\n // If the event handler returns false, prevent the default handler\n // from executing\n if (obj.fn.call(el, eventArguments) === false) {\n eventArguments.preventDefault();\n }\n });\n }\n // Run the default if not prevented\n if (defaultFunction && !eventArguments.defaultPrevented) {\n defaultFunction.call(el, eventArguments);\n }\n }\n let serialMode;\n /**\n * Get a unique key for using in internal element id's and pointers. The key is\n * composed of a random hash specific to this Highcharts instance, and a\n * counter.\n *\n * @example\n * let id = uniqueKey(); // => 'highcharts-x45f6hp-0'\n *\n * @function Highcharts.uniqueKey\n *\n * @return {string}\n * A unique key.\n */\n const uniqueKey = (function () {\n const hash = Math.random().toString(36).substring(2, 9) + '-';\n let id = 0;\n return function () {\n return 'highcharts-' + (serialMode ? '' : hash) + id++;\n };\n }());\n /**\n * Activates a serial mode for element IDs provided by\n * {@link Highcharts.uniqueKey}. This mode can be used in automated tests, where\n * a simple comparison of two rendered SVG graphics is needed.\n *\n * **Note:** This is only for testing purposes and will break functionality in\n * webpages with multiple charts.\n *\n * @example\n * if (\n * process &&\n * process.env.NODE_ENV === 'development'\n * ) {\n * Highcharts.useSerialIds(true);\n * }\n *\n * @function Highcharts.useSerialIds\n *\n * @param {boolean} [mode]\n * Changes the state of serial mode.\n *\n * @return {boolean|undefined}\n * State of the serial mode.\n */\n function useSerialIds(mode) {\n return (serialMode = pick(mode, serialMode));\n }\n function isFunction(obj) {\n return typeof obj === 'function';\n }\n // Register Highcharts as a plugin in jQuery\n if (win.jQuery) {\n /**\n * Highcharts-extended JQuery.\n *\n * @external JQuery\n */\n /**\n * Helper function to return the chart of the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @return {Highcharts.Chart}\n * The chart that is linked to the JQuery selector element.\n */ /**\n * Factory function to create a chart in the current JQuery selector\n * element.\n *\n * @function external:JQuery#highcharts\n *\n * @param {'Chart'|'Map'|'StockChart'|string} [className]\n * Name of the factory class in the Highcharts namespace.\n *\n * @param {Highcharts.Options} [options]\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {JQuery}\n * The current JQuery selector.\n */\n win.jQuery.fn.highcharts = function () {\n const args = [].slice.call(arguments);\n if (this[0]) { // this[0] is the renderTo div\n // Create the chart\n if (args[0]) {\n new H[ // eslint-disable-line computed-property-spacing, no-new\n // Constructor defaults to Chart\n isString(args[0]) ? args.shift() : 'Chart'](this[0], args[0], args[1]);\n return this;\n }\n // When called without parameters or with the return argument,\n // return an existing chart\n return charts[attr(this[0], 'data-highcharts-chart')];\n }\n };\n }\n /* *\n *\n * Default Export\n *\n * */\n // TODO use named exports when supported.\n const Utilities = {\n addEvent,\n arrayMax,\n arrayMin,\n attr,\n clamp,\n clearTimeout: internalClearTimeout,\n correctFloat,\n createElement,\n css,\n defined,\n destroyObjectProperties,\n diffObjects,\n discardElement,\n erase,\n error,\n extend,\n extendClass,\n find,\n fireEvent,\n getClosestDistance,\n getMagnitude,\n getNestedProperty,\n getStyle,\n inArray,\n insertItem,\n isArray,\n isClass,\n isDOMElement,\n isFunction,\n isNumber,\n isObject,\n isString,\n keys,\n merge,\n normalizeTickInterval,\n objectEach,\n offset,\n pad,\n pick,\n pInt,\n pushUnique,\n relativeLength,\n removeEvent,\n splat,\n stableSort,\n syncTimeout,\n timeUnits,\n uniqueKey,\n useSerialIds,\n wrap\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * An animation configuration. Animation configurations can also be defined as\n * booleans, where `false` turns off animation and `true` defaults to a duration\n * of 500ms and defer of 0ms.\n *\n * @interface Highcharts.AnimationOptionsObject\n */ /**\n * A callback function to exectute when the animation finishes.\n * @name Highcharts.AnimationOptionsObject#complete\n * @type {Function|undefined}\n */ /**\n * The animation defer in milliseconds.\n * @name Highcharts.AnimationOptionsObject#defer\n * @type {number|undefined}\n */ /**\n * The animation duration in milliseconds.\n * @name Highcharts.AnimationOptionsObject#duration\n * @type {number|undefined}\n */ /**\n * The name of an easing function as defined on the `Math` object.\n * @name Highcharts.AnimationOptionsObject#easing\n * @type {string|Function|undefined}\n */ /**\n * A callback function to execute on each step of each attribute or CSS property\n * that's being animated. The first argument contains information about the\n * animation and progress.\n * @name Highcharts.AnimationOptionsObject#step\n * @type {Function|undefined}\n */\n /**\n * Creates a frame for the animated SVG element.\n *\n * @callback Highcharts.AnimationStepCallbackFunction\n *\n * @param {Highcharts.SVGElement} this\n * The SVG element to animate.\n *\n * @return {void}\n */\n /**\n * Interface description for a class.\n *\n * @interface Highcharts.Class\n * @extends Function\n */ /**\n * Class costructor.\n * @function Highcharts.Class#new\n * @param {...Array<*>} args\n * Constructor arguments.\n * @return {T}\n * Class instance.\n */\n /**\n * A style object with camel case property names to define visual appearance of\n * a SVG element or HTML element. The properties can be whatever styles are\n * supported on the given SVG or HTML element.\n *\n * @example\n * {\n * fontFamily: 'monospace',\n * fontSize: '1.2em'\n * }\n *\n * @interface Highcharts.CSSObject\n */ /**\n * @name Highcharts.CSSObject#[key:string]\n * @type {boolean|number|string|undefined}\n */ /**\n * Background style for the element.\n * @name Highcharts.CSSObject#background\n * @type {string|undefined}\n */ /**\n * Background color of the element.\n * @name Highcharts.CSSObject#backgroundColor\n * @type {Highcharts.ColorString|undefined}\n */ /**\n * Border style for the element.\n * @name Highcharts.CSSObject#border\n * @type {string|undefined}\n */ /**\n * Radius of the element border.\n * @name Highcharts.CSSObject#borderRadius\n * @type {number|undefined}\n */ /**\n * Color used in the element. The 'contrast' option is a Highcharts custom\n * property that results in black or white, depending on the background of the\n * element.\n * @name Highcharts.CSSObject#color\n * @type {'contrast'|Highcharts.ColorString|undefined}\n */ /**\n * Style of the mouse cursor when resting over the element.\n * @name Highcharts.CSSObject#cursor\n * @type {Highcharts.CursorValue|undefined}\n */ /**\n * Font family of the element text. Multiple values have to be in decreasing\n * preference order and separated by comma.\n * @name Highcharts.CSSObject#fontFamily\n * @type {string|undefined}\n */ /**\n * Font size of the element text.\n * @name Highcharts.CSSObject#fontSize\n * @type {string|undefined}\n */ /**\n * Font weight of the element text.\n * @name Highcharts.CSSObject#fontWeight\n * @type {string|undefined}\n */ /**\n * Height of the element.\n * @name Highcharts.CSSObject#height\n * @type {number|undefined}\n */ /**\n * Width of the element border.\n * @name Highcharts.CSSObject#lineWidth\n * @type {number|undefined}\n */ /**\n * Opacity of the element.\n * @name Highcharts.CSSObject#opacity\n * @type {number|undefined}\n */ /**\n * Space around the element content.\n * @name Highcharts.CSSObject#padding\n * @type {string|undefined}\n */ /**\n * Behaviour of the element when the mouse cursor rests over it.\n * @name Highcharts.CSSObject#pointerEvents\n * @type {string|undefined}\n */ /**\n * Positioning of the element.\n * @name Highcharts.CSSObject#position\n * @type {string|undefined}\n */ /**\n * Alignment of the element text.\n * @name Highcharts.CSSObject#textAlign\n * @type {string|undefined}\n */ /**\n * Additional decoration of the element text.\n * @name Highcharts.CSSObject#textDecoration\n * @type {string|undefined}\n */ /**\n * Outline style of the element text.\n * @name Highcharts.CSSObject#textOutline\n * @type {string|undefined}\n */ /**\n * Line break style of the element text. Highcharts SVG elements support\n * `ellipsis` when a `width` is set.\n * @name Highcharts.CSSObject#textOverflow\n * @type {string|undefined}\n */ /**\n * Top spacing of the element relative to the parent element.\n * @name Highcharts.CSSObject#top\n * @type {string|undefined}\n */ /**\n * Animated transition of selected element properties.\n * @name Highcharts.CSSObject#transition\n * @type {string|undefined}\n */ /**\n * Line break style of the element text.\n * @name Highcharts.CSSObject#whiteSpace\n * @type {string|undefined}\n */ /**\n * Width of the element.\n * @name Highcharts.CSSObject#width\n * @type {number|undefined}\n */\n /**\n * All possible cursor styles.\n *\n * @typedef {'alias'|'all-scroll'|'auto'|'cell'|'col-resize'|'context-menu'|'copy'|'crosshair'|'default'|'e-resize'|'ew-resize'|'grab'|'grabbing'|'help'|'move'|'n-resize'|'ne-resize'|'nesw-resize'|'no-drop'|'none'|'not-allowed'|'ns-resize'|'nw-resize'|'nwse-resize'|'pointer'|'progress'|'row-resize'|'s-resize'|'se-resize'|'sw-resize'|'text'|'vertical-text'|'w-resize'|'wait'|'zoom-in'|'zoom-out'} Highcharts.CursorValue\n */\n /**\n * All possible dash styles.\n *\n * @typedef {'Dash'|'DashDot'|'Dot'|'LongDash'|'LongDashDot'|'LongDashDotDot'|'ShortDash'|'ShortDashDot'|'ShortDashDotDot'|'ShortDot'|'Solid'} Highcharts.DashStyleValue\n */\n /**\n * Generic dictionary in TypeScript notation.\n * Use the native `AnyRecord` instead.\n *\n * @deprecated\n * @interface Highcharts.Dictionary\n */ /**\n * @name Highcharts.Dictionary#[key:string]\n * @type {T}\n */\n /**\n * The function callback to execute when the event is fired. The `this` context\n * contains the instance, that fired the event.\n *\n * @callback Highcharts.EventCallbackFunction\n *\n * @param {T} this\n *\n * @param {Highcharts.Dictionary<*>|Event} [eventArguments]\n * Event arguments.\n *\n * @return {boolean|void}\n */\n /**\n * The event options for adding function callback.\n *\n * @interface Highcharts.EventOptionsObject\n */ /**\n * The order the event handler should be called. This opens for having one\n * handler be called before another, independent of in which order they were\n * added.\n * @name Highcharts.EventOptionsObject#order\n * @type {number}\n */ /**\n * Whether an event should be passive or not.\n * When set to `true`, the function specified by listener will never call\n * `preventDefault()`.\n * @name Highcharts.EventOptionsObject#passive\n * @type boolean\n */\n /**\n * Formats data as a string. Usually the data is accessible throught the `this`\n * keyword.\n *\n * @callback Highcharts.FormatterCallbackFunction\n *\n * @param {T} this\n * Context to format\n *\n * @return {string}\n * Formatted text\n */\n /**\n * An object of key-value pairs for HTML attributes.\n *\n * @typedef {Highcharts.Dictionary} Highcharts.HTMLAttributes\n */\n /**\n * An HTML DOM element. The type is a reference to the regular HTMLElement in\n * the global scope.\n *\n * @typedef {global.HTMLElement} Highcharts.HTMLDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement\n */\n /**\n * The iterator callback.\n *\n * @callback Highcharts.ObjectEachCallbackFunction\n *\n * @param {T} this\n * The context.\n *\n * @param {*} value\n * The property value.\n *\n * @param {string} key\n * The property key.\n *\n * @param {*} obj\n * The object that objectEach is being applied to.\n */\n /**\n * An object containing `left` and `top` properties for the position in the\n * page.\n *\n * @interface Highcharts.OffsetObject\n */ /**\n * Left distance to the page border.\n * @name Highcharts.OffsetObject#left\n * @type {number}\n */ /**\n * Top distance to the page border.\n * @name Highcharts.OffsetObject#top\n * @type {number}\n */\n /**\n * Describes a range.\n *\n * @interface Highcharts.RangeObject\n */ /**\n * Maximum number of the range.\n * @name Highcharts.RangeObject#max\n * @type {number}\n */ /**\n * Minimum number of the range.\n * @name Highcharts.RangeObject#min\n * @type {number}\n */\n /**\n * If a number is given, it defines the pixel length. If a percentage string is\n * given, like for example `'50%'`, the setting defines a length relative to a\n * base size, for example the size of a container.\n *\n * @typedef {number|string} Highcharts.RelativeSize\n */\n /**\n * Proceed function to call original (wrapped) function.\n *\n * @callback Highcharts.WrapProceedFunction\n *\n * @param {*} [arg1]\n * Optional argument. Without any arguments defaults to first argument of\n * the wrapping function.\n *\n * @param {*} [arg2]\n * Optional argument. Without any arguments defaults to second argument\n * of the wrapping function.\n *\n * @param {*} [arg3]\n * Optional argument. Without any arguments defaults to third argument of\n * the wrapping function.\n *\n * @return {*}\n * Return value of the original function.\n */\n /**\n * The Highcharts object is the placeholder for all other members, and various\n * utility functions. The most important member of the namespace would be the\n * chart constructor.\n *\n * @example\n * let chart = Highcharts.chart('container', { ... });\n *\n * @namespace Highcharts\n */\n ''; // detach doclets above\n\n return Utilities;\n });\n _registerModule(_modules, 'Core/Chart/ChartDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for the chart.\n *\n * @optionparent chart\n */\n const ChartDefaults = {\n /**\n * Default `mapData` for all series, in terms of a GeoJSON or TopoJSON\n * object. If set to a string, it functions as an index into the\n * `Highcharts.maps` array.\n *\n * For picking out individual shapes and geometries to use for each series\n * of the map, see [series.mapData](#series.map.mapData).\n *\n * @sample maps/demo/geojson\n * Loading GeoJSON data\n * @sample maps/chart/topojson\n * Loading TopoJSON data\n *\n * @type {string|Array<*>|Highcharts.GeoJSON|Highcharts.TopoJSON}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.map\n */\n /**\n * Set lat/lon transformation definitions for the chart. If not defined,\n * these are extracted from the map data.\n *\n * @type {*}\n * @since 5.0.0\n * @product highmaps\n * @apioption chart.mapTransforms\n */\n /**\n * When using multiple axes, the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks, as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy, it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false,\n * then the `alignTicks ` will be disabled for the axis.\n *\n * Disabled for logarithmic axes.\n *\n * @sample {highcharts} highcharts/chart/alignticks-true/\n * True by default\n * @sample {highcharts} highcharts/chart/alignticks-false/\n * False\n * @sample {highstock} stock/chart/alignticks-true/\n * True by default\n * @sample {highstock} stock/chart/alignticks-false/\n * False\n *\n * @type {boolean}\n * @default true\n * @product highcharts highstock gantt\n * @apioption chart.alignTicks\n */\n /**\n * When using multiple axes, align the thresholds. When this is true, other\n * ticks will also be aligned.\n *\n * Note that for line series and some other series types, the `threshold`\n * option is set to `null` by default. This will in turn cause their y-axis\n * to not have a threshold. In order to avoid that, set the series\n * `threshold` to 0 or another number.\n *\n * If `startOnTick` or `endOnTick` in the axis options are set to false, or\n * if the axis is logarithmic, the threshold will not be aligned.\n *\n * @sample {highcharts} highcharts/chart/alignthresholds/ Set to true\n *\n * @since 10.0.0\n * @product highcharts highstock gantt\n * @apioption chart.alignThresholds\n */\n alignThresholds: false,\n /**\n * Set the overall animation for all chart updating. Animation can be\n * disabled throughout the chart by setting it to false here. It can\n * be overridden for each individual API method as a function parameter.\n * The only animation not affected by this option is the initial series\n * animation, see [plotOptions.series.animation](\n * #plotOptions.series.animation).\n *\n * The animation can either be set as a boolean or a configuration\n * object. If `true`, it will use the 'swing' jQuery easing and a\n * duration of 500 ms. If used as a configuration object, the following\n * properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds.\n *\n * - `easing`: A string reference to an easing function set on the\n * `Math` object. See\n * [the easing demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-animation-easing/).\n *\n * When zooming on a series with less than 100 points, the chart redraw\n * will be done with animation, but in case of more data points, it is\n * necessary to set this option to ensure animation on zoom.\n *\n * @sample {highcharts} highcharts/chart/animation-none/\n * Updating with no animation\n * @sample {highcharts} highcharts/chart/animation-duration/\n * With a longer duration\n * @sample {highcharts} highcharts/chart/animation-easing/\n * With a jQuery UI easing\n * @sample {highmaps} maps/chart/animation-none/\n * Updating with no animation\n * @sample {highmaps} maps/chart/animation-duration/\n * With a longer duration\n *\n * @type {boolean|Partial}\n * @default true\n * @apioption chart.animation\n */\n /**\n * A CSS class name to apply to the charts container `div`, allowing\n * unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption chart.className\n */\n /**\n * Event listeners for the chart.\n *\n * @apioption chart.events\n */\n /**\n * Fires when a series is added to the chart after load time, using the\n * `addSeries` method. One parameter, `event`, is passed to the\n * function, containing common event information. Through\n * `event.options` you can access the series options that were passed to\n * the `addSeries` method. Returning false prevents the series from\n * being added.\n *\n * @sample {highcharts} highcharts/chart/events-addseries/\n * Alert on add series\n * @sample {highstock} stock/chart/events-addseries/\n * Alert on add series\n *\n * @type {Highcharts.ChartAddSeriesCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.addSeries\n */\n /**\n * Fires when clicking on the plot background. One parameter, `event`,\n * is passed to the function, containing common event information.\n *\n * Information on the clicked spot can be found through `event.xAxis`\n * and `event.yAxis`, which are arrays containing the axes of each\n * dimension and each axis' value at the clicked spot. The primary axes\n * are `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * click: function(e) {\n * console.log(\n * Highcharts.dateFormat('%Y-%m-%d %H:%M:%S', e.xAxis[0].value),\n * e.yAxis[0].value\n * )\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-click/\n * Alert coordinates on click\n * @sample {highcharts} highcharts/chart/events-container/\n * Alternatively, attach event to container\n * @sample {highstock} stock/chart/events-click/\n * Alert coordinates on click\n * @sample {highstock} highcharts/chart/events-container/\n * Alternatively, attach event to container\n * @sample {highmaps} maps/chart/events-click/\n * Record coordinates on click\n * @sample {highmaps} highcharts/chart/events-container/\n * Alternatively, attach event to container\n *\n * @type {Highcharts.ChartClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.click\n */\n /**\n * Fires when the chart is finished loading. Since v4.2.2, it also waits\n * for images to be loaded, for example from point markers. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * There is also a second parameter to the chart constructor where a\n * callback function can be passed to be executed on chart.load.\n *\n * @sample {highcharts} highcharts/chart/events-load/\n * Alert on chart load\n * @sample {highcharts} highcharts/chart/events-render/\n * Load vs Redraw vs Render\n * @sample {highstock} stock/chart/events-load/\n * Alert on chart load\n * @sample {highmaps} maps/chart/events-load/\n * Add series on chart load\n *\n * @type {Highcharts.ChartLoadCallbackFunction}\n * @context Highcharts.Chart\n * @apioption chart.events.load\n */\n /**\n * Fires when the chart is redrawn, either after a call to\n * `chart.redraw()` or after an axis, series or point is modified with\n * the `redraw` option set to `true`. One parameter, `event`, is passed\n * to the function, containing common event information.\n *\n * @sample {highcharts} highcharts/chart/events-redraw/\n * Alert on chart redraw\n * @sample {highcharts} highcharts/chart/events-render/\n * Load vs Redraw vs Render\n * @sample {highstock} stock/chart/events-redraw/\n * Alert on chart redraw when adding a series or moving the\n * zoomed range\n * @sample {highmaps} maps/chart/events-redraw/\n * Set subtitle on chart redraw\n *\n * @type {Highcharts.ChartRedrawCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Chart\n * @apioption chart.events.redraw\n */\n /**\n * Fires after initial load of the chart (directly after the `load`\n * event), and after each redraw (directly after the `redraw` event).\n *\n * @sample {highcharts} highcharts/chart/events-render/\n * Load vs Redraw vs Render\n *\n * @type {Highcharts.ChartRenderCallbackFunction}\n * @since 5.0.7\n * @context Highcharts.Chart\n * @apioption chart.events.render\n */\n /**\n * Fires when an area of the chart has been selected. Selection is\n * enabled by setting the chart's zoomType. One parameter, `event`, is\n * passed to the function, containing common event information. The\n * default action for the selection event is to zoom the chart to the\n * selected area. It can be prevented by calling\n * `event.preventDefault()` or return false.\n *\n * Information on the selected area can be found through `event.xAxis`\n * and `event.yAxis`, which are arrays containing the axes of each\n * dimension and each axis' min and max values. The primary axes are\n * `event.xAxis[0]` and `event.yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * ```js\n * selection: function(event) {\n * // log the min and max of the primary, datetime x-axis\n * console.log(\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].min\n * ),\n * Highcharts.dateFormat(\n * '%Y-%m-%d %H:%M:%S',\n * event.xAxis[0].max\n * )\n * );\n * // log the min and max of the y axis\n * console.log(event.yAxis[0].min, event.yAxis[0].max);\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/events-selection/\n * Report on selection and reset\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highstock} stock/chart/events-selection/\n * Report on selection and reset\n * @sample {highstock} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * (Highcharts)\n *\n * @type {Highcharts.ChartSelectionCallbackFunction}\n * @apioption chart.events.selection\n */\n /**\n * The margin between the outer edge of the chart and the plot area.\n * The numbers in the array designate top, right, bottom and left\n * respectively. Use the options `marginTop`, `marginRight`,\n * `marginBottom` and `marginLeft` for shorthand setting of one option.\n *\n * By default there is no margin. The actual space is dynamically\n * calculated from the offset of axis labels, axis title, title,\n * subtitle and legend in addition to the `spacingTop`, `spacingRight`,\n * `spacingBottom` and `spacingLeft` options.\n *\n * @sample {highcharts} highcharts/chart/margins-zero/\n * Zero margins\n * @sample {highstock} stock/chart/margin-zero/\n * Zero margins\n *\n * @type {number|Array}\n * @apioption chart.margin\n */\n /**\n * The margin between the bottom outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingBottom`.\n *\n * @sample {highcharts} highcharts/chart/marginbottom/\n * 100px bottom margin\n * @sample {highstock} stock/chart/marginbottom/\n * 100px bottom margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginBottom\n */\n /**\n * The margin between the left outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingLeft`.\n *\n * @sample {highcharts} highcharts/chart/marginleft/\n * 150px left margin\n * @sample {highstock} stock/chart/marginleft/\n * 150px left margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginLeft\n */\n /**\n * The margin between the right outer edge of the chart and the plot\n * area. Use this to set a fixed pixel value for the margin as opposed\n * to the default dynamic margin. See also `spacingRight`.\n *\n * @sample {highcharts} highcharts/chart/marginright/\n * 100px right margin\n * @sample {highstock} stock/chart/marginright/\n * 100px right margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginRight\n */\n /**\n * The margin between the top outer edge of the chart and the plot area.\n * Use this to set a fixed pixel value for the margin as opposed to\n * the default dynamic margin. See also `spacingTop`.\n *\n * @sample {highcharts} highcharts/chart/margintop/ 100px top margin\n * @sample {highstock} stock/chart/margintop/\n * 100px top margin\n * @sample {highmaps} maps/chart/margin/\n * 100px margins\n *\n * @type {number}\n * @since 2.0\n * @apioption chart.marginTop\n */\n /**\n * Callback function to override the default function that formats all\n * the numbers in the chart. Returns a string with the formatted number.\n *\n * @sample highcharts/members/highcharts-numberformat\n * Arabic digits in Highcharts\n * @type {Highcharts.NumberFormatterCallbackFunction}\n * @since 8.0.0\n * @apioption chart.numberFormatter\n */\n /**\n * Allows setting a key to switch between zooming and panning. Can be\n * one of `alt`, `ctrl`, `meta` (the command key on Mac and Windows\n * key on Windows) or `shift`. The keys are mapped directly to the key\n * properties of the click event argument (`event.altKey`,\n * `event.ctrlKey`, `event.metaKey` and `event.shiftKey`).\n *\n * @type {string}\n * @since 4.0.3\n * @product highcharts gantt\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @apioption chart.panKey\n */\n /**\n * Allow panning in a chart. Best used with [panKey](#chart.panKey)\n * to combine zooming and panning.\n *\n * On touch devices, when the [tooltip.followTouchMove](\n * #tooltip.followTouchMove) option is `true` (default), panning\n * requires two fingers. To allow panning with one finger, set\n * `followTouchMove` to `false`.\n *\n * @sample {highcharts} highcharts/chart/pankey/ Zooming and panning\n * @sample {highstock} stock/chart/panning/ Zooming and xy panning\n */\n panning: {\n /**\n * Enable or disable chart panning.\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock|highmaps} true\n */\n enabled: false,\n /**\n * Decides in what dimensions the user can pan the chart. Can be\n * one of `x`, `y`, or `xy`.\n *\n * When this option is set to `y` or `xy`, [yAxis.startOnTick](#yAxis.startOnTick)\n * and [yAxis.endOnTick](#yAxis.endOnTick) are overwritten to `false`.\n *\n * @sample {highcharts} highcharts/chart/panning-type\n * Zooming and xy panning\n *\n * @declare Highcharts.OptionsChartPanningTypeValue\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @default {highcharts|highstock} x\n * @product highcharts highstock gantt\n */\n type: 'x'\n },\n /**\n * Equivalent to [zoomType](#chart.zoomType), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `zoomType` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} undefined\n * @since 3.0\n * @product highcharts highstock gantt\n * @deprecated\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.pinchType\n */\n /**\n * Whether to apply styled mode. When in styled mode, no presentational\n * attributes or CSS are applied to the chart SVG. Instead, CSS rules\n * are required to style the chart. The default style sheet is\n * available from `https://code.highcharts.com/css/highcharts.css`.\n *\n * [Read more in the docs](https://www.highcharts.com/docs/chart-design-and-style/style-by-css)\n * on what classes and variables are available.\n *\n * @sample highcharts/css/colors\n * Color theming with CSS\n * @sample highcharts/css/prefers-color-scheme\n * Dynamic theme based on system settings\n * @type {boolean}\n * @default false\n * @since 7.0\n * @apioption chart.styledMode\n */\n styledMode: false,\n /**\n * The corner radius of the outer chart border.\n *\n * @sample {highcharts} highcharts/chart/borderradius/\n * 20px radius\n * @sample {highstock} stock/chart/border/\n * 10px radius\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n */\n borderRadius: 0,\n /**\n * In styled mode, this sets how many colors the class names\n * should rotate between. With ten colors, series (or points) are\n * given class names like `highcharts-color-0`, `highcharts-color-1`\n * [...] `highcharts-color-9`. The equivalent in non-styled mode\n * is to set colors using the [colors](#colors) setting.\n *\n * @since 5.0.0\n */\n colorCount: 10,\n /**\n * By default, (because of memory and performance reasons) the chart does\n * not copy the data but keeps it as a reference. In some cases, this might\n * result in mutating the original data source. In order to prevent that,\n * set that property to false. Please note that changing that might decrease\n * performance, especially with bigger sets of data.\n *\n * @type {boolean}\n * @since 10.1.0\n */\n allowMutatingData: true,\n /**\n * If true, the axes will scale to the remaining visible series once\n * one series is hidden. If false, hiding and showing a series will\n * not affect the axes or the other series. For stacks, once one series\n * within the stack is hidden, the rest of the stack will close in\n * around it even if the axis is not affected.\n *\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-false/\n * False\n * @sample {highcharts} highcharts/chart/ignorehiddenseries-true-stacked/\n * True with stack\n * @sample {highstock} stock/chart/ignorehiddenseries-true/\n * True by default\n * @sample {highstock} stock/chart/ignorehiddenseries-false/\n * False\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n ignoreHiddenSeries: true,\n /**\n * Whether to invert the axes so that the x axis is vertical and y axis\n * is horizontal. When `true`, the x axis is [reversed](#xAxis.reversed)\n * by default.\n *\n * @productdesc {highcharts}\n * If a bar series is present in the chart, it will be inverted\n * automatically. Inverting the chart doesn't have an effect if there\n * are no cartesian series in the chart, or if the chart is\n * [polar](#chart.polar).\n *\n * @sample {highcharts} highcharts/chart/inverted/\n * Inverted line\n * @sample {highstock} stock/navigator/inverted/\n * Inverted stock chart\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption chart.inverted\n */\n /**\n * The distance between the outer edge of the chart and the content,\n * like title or legend, or axis title and labels if present. The\n * numbers in the array designate top, right, bottom and left\n * respectively. Use the options spacingTop, spacingRight, spacingBottom\n * and spacingLeft options for shorthand setting of one option.\n *\n * @type {Array}\n * @see [chart.margin](#chart.margin)\n * @default [10, 10, 15, 10]\n * @since 3.0.6\n */\n spacing: [10, 10, 15, 10],\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n *\n * @since 2.2\n * @deprecated 10.2.1\n */\n resetZoomButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.resetZoomButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n */\n theme: {\n /**\n * @internal\n */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.resetZoomButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n },\n /**\n * The pixel width of the plot area border.\n *\n * @sample {highcharts} highcharts/chart/plotborderwidth/\n * 1px border\n * @sample {highstock} stock/chart/plotborder/\n * 2px border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.plotBorderWidth\n */\n /**\n * Whether to apply a drop shadow to the plot area. Requires that\n * plotBackgroundColor be set. The shadow can be an object configuration\n * containing `color`, `offsetX`, `offsetY`, `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/chart/plotshadow/\n * Plot shadow\n * @sample {highstock} stock/chart/plotshadow/\n * Plot shadow\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption chart.plotShadow\n */\n /**\n * When true, cartesian charts like line, spline, area and column are\n * transformed into the polar coordinate system. This produces _polar\n * charts_, also known as _radar charts_.\n *\n * @sample {highcharts} highcharts/demo/polar/\n * Polar chart\n * @sample {highcharts} highcharts/demo/polar-wind-rose/\n * Wind rose, stacked polar column chart\n * @sample {highcharts} highcharts/demo/polar-spider/\n * Spider web chart\n * @sample {highcharts} highcharts/parallel-coordinates/polar/\n * Star plot, multivariate data in a polar chart\n *\n * @type {boolean}\n * @default false\n * @since 2.3.0\n * @product highcharts\n * @requires highcharts-more\n * @apioption chart.polar\n */\n /**\n * Whether to reflow the chart to fit the width of the container div\n * on resizing the window.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * True by default\n * @sample {highcharts} highcharts/chart/reflow-false/\n * False\n * @sample {highstock} stock/chart/reflow-true/\n * True by default\n * @sample {highstock} stock/chart/reflow-false/\n * False\n * @sample {highmaps} maps/chart/reflow-true/\n * True by default\n * @sample {highmaps} maps/chart/reflow-false/\n * False\n *\n * @since 2.1\n */\n reflow: true,\n /**\n * The HTML element where the chart will be rendered. If it is a string,\n * the element by that id is used. The HTML element can also be passed\n * by direct reference, or as the first argument of the chart\n * constructor, in which case the option is not needed.\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * String\n * @sample {highcharts} highcharts/chart/renderto-object/\n * Object reference\n * @sample {highstock} stock/chart/renderto-string/\n * String\n * @sample {highstock} stock/chart/renderto-object/\n * Object reference\n *\n * @type {string|Highcharts.HTMLDOMElement}\n * @apioption chart.renderTo\n */\n /**\n * The background color of the marker square when selecting (zooming\n * in on) an area of the chart.\n *\n * @see In styled mode, the selection marker fill is set with the\n * `.highcharts-selection-marker` class.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default rgba(51,92,173,0.25)\n * @since 2.1.7\n * @apioption chart.selectionMarkerFill\n */\n /**\n * Whether to apply a drop shadow to the global series group. This causes\n * all the series to have the same shadow. Contrary to the `series.shadow`\n * option, this prevents items from casting shadows on each other, like for\n * others series in a stack. The shadow can be an object configuration\n * containing `color`, `offsetX`, `offsetY`, `opacity` and `width`.\n *\n * @sample highcharts/chart/seriesgroupshadow/ Shadow\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption chart.shadow\n */\n /**\n * Whether to apply a drop shadow to the outer chart area. Requires\n * that backgroundColor be set. The shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity` and\n * `width`.\n *\n * @sample {highcharts} highcharts/chart/shadow/\n * Shadow\n * @sample {highstock} stock/chart/shadow/\n * Shadow\n * @sample {highmaps} maps/chart/border/\n * Chart border and shadow\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption chart.shadow\n */\n /**\n * Whether to show the axes initially. This only applies to empty charts\n * where series are added dynamically, as axes are automatically added\n * to cartesian series.\n *\n * @sample {highcharts} highcharts/chart/showaxes-false/\n * False by default\n * @sample {highcharts} highcharts/chart/showaxes-true/\n * True\n *\n * @type {boolean}\n * @since 1.2.5\n * @product highcharts gantt\n * @apioption chart.showAxes\n */\n /**\n * The space between the bottom edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highstock} stock/chart/spacingbottom/\n * Spacing bottom set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 15\n * @since 2.1\n * @apioption chart.spacingBottom\n */\n /**\n * The space between the left edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highstock} stock/chart/spacingleft/\n * Spacing left set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingLeft\n */\n /**\n * The space between the right edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingright-100/\n * Spacing set to 100\n * @sample {highcharts} highcharts/chart/spacingright-legend/\n * Legend in right position with default spacing\n * @sample {highstock} stock/chart/spacingright/\n * Spacing set to 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingRight\n */\n /**\n * The space between the top edge of the chart and the content (plot\n * area, axis title and labels, title, subtitle or legend in top\n * position).\n *\n * @sample {highcharts} highcharts/chart/spacingtop-100/\n * A top spacing of 100\n * @sample {highcharts} highcharts/chart/spacingtop-10/\n * Floating chart title makes the plot area align to the default\n * spacingTop of 10.\n * @sample {highstock} stock/chart/spacingtop/\n * A top spacing of 100\n * @sample {highmaps} maps/chart/spacing/\n * Spacing 100 all around\n *\n * @type {number}\n * @default 10\n * @since 2.1\n * @apioption chart.spacingTop\n */\n /**\n * Additional CSS styles to apply inline to the container `div` and the root\n * SVG.\n *\n * Since v11, the root font size is 1rem by default, and all child element\n * are given a relative `em` font size by default. This allows implementers\n * to control all the chart's font sizes by only setting the root level.\n *\n * @see In styled mode, general chart styles can be set with the\n * `.highcharts-root` class.\n * @sample {highcharts} highcharts/chart/style-serif-font/\n * Using a serif type font\n * @sample {highcharts} highcharts/members/relative-font-size/\n * Relative font sizes\n * @sample {highcharts} highcharts/css/em/\n * Styled mode with relative font sizes\n * @sample {highstock} stock/chart/style/\n * Using a serif type font\n * @sample {highmaps} maps/chart/style-serif-font/\n * Using a serif type font\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontFamily\": Helvetica, Arial, sans-serif\",\"fontSize\":\"1rem\"}\n * @apioption chart.style\n */\n /**\n * The default series type for the chart. Can be any of the chart types\n * listed under [plotOptions](#plotOptions) and [series](#series) or can\n * be a series provided by an additional module.\n *\n * In TypeScript this option has no effect in sense of typing and\n * instead the `type` option must always be set in the series.\n *\n * @sample {highcharts} highcharts/chart/type-bar/\n * Bar\n * @sample {highstock} stock/chart/type/\n * Areaspline\n * @sample {highmaps} maps/chart/type-mapline/\n * Mapline\n *\n * @type {string}\n * @default {highcharts} line\n * @default {highstock} line\n * @default {highmaps} map\n * @since 2.1.0\n * @apioption chart.type\n */\n type: 'line',\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @see [panKey](#chart.panKey)\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * None by default\n * @sample {highcharts} highcharts/chart/zoomtype-x/\n * X\n * @sample {highcharts} highcharts/chart/zoomtype-y/\n * Y\n * @sample {highcharts} highcharts/chart/zoomtype-xy/\n * Xy\n * @sample {highcharts} highcharts/chart/zoomtype-polar/\n * Zoom on polar chart\n * @sample {highstock} stock/demo/basic-line/\n * None by default\n * @sample {highstock} stock/chart/zoomtype-x/\n * X\n * @sample {highstock} stock/chart/zoomtype-y/\n * Y\n * @sample {highstock} stock/chart/zoomtype-xy/\n * Xy\n * @sample {highmaps} maps/chart/zoomtype-xy/\n * Map with selection zoom\n *\n * @type {string}\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @deprecated\n * @apioption chart.zoomType\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zoomType](#chart.zoomType). When enabled, two-finger pinch\n * will still work as set up by [chart.pinchType](#chart.pinchType).\n * However, `zoomBySingleTouch` will interfere with touch-dragging the\n * chart to read the tooltip. And especially when vertical zooming is\n * enabled, it will make it hard to scroll vertically on the page.\n * @since 9.0.0\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n * @product highcharts highstock gantt\n * @deprecated\n */\n /**\n * Chart zooming options.\n * @since 10.2.1\n */\n zooming: {\n /**\n * Equivalent to [type](#chart.zooming.type), but for multitouch\n * gestures only. By default, the `pinchType` is the same as the\n * `type` setting. However, pinching can be enabled separately in\n * some cases, for example in stock charts where a mouse drag pans the\n * chart, while pinching is enabled. When [tooltip.followTouchMove](\n * #tooltip.followTouchMove) is true, pinchType only applies to\n * two-finger touches.\n *\n * @type {string}\n * @default {highcharts} undefined\n * @default {highstock} x\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.pinchType\n */\n /**\n * Decides in what dimensions the user can zoom by dragging the mouse.\n * Can be one of `x`, `y` or `xy`.\n *\n * @declare Highcharts.OptionsChartZoomingTypeValue\n * @type {string}\n * @default {highcharts} undefined\n * @product highcharts highstock gantt\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @apioption chart.zooming.type\n */\n /**\n * Set a key to hold when dragging to zoom the chart. This is useful to\n * avoid zooming while moving points. Should be set different than\n * [chart.panKey](#chart.panKey).\n *\n * @type {string}\n * @default {highcharts} undefined\n * @validvalue [\"alt\", \"ctrl\", \"meta\", \"shift\"]\n * @requires modules/draggable-points\n * @apioption chart.zooming.key\n */\n /**\n * Enables zooming by a single touch, in combination with\n * [chart.zooming.type](#chart.zooming.type). When enabled, two-finger\n * pinch will still work as set up by [chart.zooming.pinchType]\n * (#chart.zooming.pinchType). However, `singleTouch` will interfere\n * with touch-dragging the chart to read the tooltip. And especially\n * when vertical zooming is enabled, it will make it hard to scroll\n * vertically on the page.\n *\n * @sample highcharts/chart/zoombysingletouch\n * Zoom by single touch enabled, with buttons to toggle\n *\n * @product highcharts highstock gantt\n */\n singleTouch: false,\n /**\n * The button that appears after a selection zoom, allowing the user\n * to reset zoom.\n */\n resetButton: {\n /**\n * What frame the button placement should be related to. Can be\n * either `plotBox` or `spacingBox`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n * @sample {highstock} highcharts/chart/resetzoombutton-relativeto/\n * Relative to the chart\n *\n * @type {Highcharts.ButtonRelativeToValue}\n * @default plot\n * @apioption chart.zooming.resetButton.relativeTo\n */\n /**\n * A collection of attributes for the button. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width` or `r`, the\n * border radius. The theme also supports `style`, a collection of\n * CSS properties for the text. Equivalent attributes for the hover\n * state are given in `theme.states.hover`.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n * @sample {highstock} highcharts/chart/resetzoombutton-theme/\n * Theming the button\n *\n * @type {Highcharts.SVGAttributes}\n * @since 10.2.1\n */\n theme: {\n /** @internal */\n zIndex: 6\n },\n /**\n * The position of the button.\n *\n * @sample {highcharts} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highstock} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n * @sample {highmaps} highcharts/chart/resetzoombutton-position/\n * Above the plot area\n *\n * @type {Highcharts.AlignObject}\n * @since 10.2.1\n */\n position: {\n /**\n * The horizontal alignment of the button.\n */\n align: 'right',\n /**\n * The horizontal offset of the button.\n */\n x: -10,\n /**\n * The vertical alignment of the button.\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @apioption chart.zooming.resetButton.position.verticalAlign\n */\n /**\n * The vertical offset of the button.\n */\n y: 10\n }\n }\n },\n /**\n * An explicit width for the chart. By default (when `null`) the width\n * is calculated from the offset width of the containing element.\n *\n * @sample {highcharts} highcharts/chart/width/\n * 800px wide\n * @sample {highstock} stock/chart/width/\n * 800px wide\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n *\n * @type {null|number|string}\n */\n width: null,\n /**\n * An explicit height for the chart. If a _number_, the height is\n * given in pixels. If given a _percentage string_ (for example\n * `'56%'`), the height is given as the percentage of the actual chart\n * width. This allows for preserving the aspect ratio across responsive\n * sizes.\n *\n * By default (when `null`) the height is calculated from the offset\n * height of the containing element, or 400 pixels if the containing\n * element's height is 0.\n *\n * @sample {highcharts} highcharts/chart/height/\n * 500px height\n * @sample {highstock} stock/chart/height/\n * 300px height\n * @sample {highmaps} maps/chart/size/\n * Chart with explicit size\n * @sample highcharts/chart/height-percent/\n * Highcharts with percentage height\n *\n * @type {null|number|string}\n */\n height: null,\n /**\n * The color of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/bordercolor/\n * Brown border\n * @sample {highstock} stock/chart/border/\n * Brown border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#334eff\" /* Palette.highlightColor80 */,\n /**\n * The pixel width of the outer chart border.\n *\n * @see In styled mode, the stroke is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/borderwidth/\n * 5px border\n * @sample {highstock} stock/chart/border/\n * 2px border\n * @sample {highmaps} maps/chart/border/\n * Border options\n *\n * @type {number}\n * @default 0\n * @apioption chart.borderWidth\n */\n /**\n * The background color or gradient for the outer chart area.\n *\n * @see In styled mode, the background is set with the\n * `.highcharts-background` class.\n *\n * @sample {highcharts} highcharts/chart/backgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/backgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/backgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/backgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/backgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The background color or gradient for the plot area.\n *\n * @see In styled mode, the plot background is set with the\n * `.highcharts-plot-background` class.\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highcharts} highcharts/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highstock} stock/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highstock} stock/chart/plotbackgroundcolor-gradient/\n * Gradient\n * @sample {highmaps} maps/chart/plotbackgroundcolor-color/\n * Color\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption chart.plotBackgroundColor\n */\n /**\n * The URL for an image to use as the plot background. To set an image\n * as the background for the entire chart, set a CSS background image\n * to the container element. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export server.\n *\n * @see In styled mode, a plot background image can be set with the\n * `.highcharts-plot-background` class and a [custom pattern](\n * https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns).\n *\n * @sample {highcharts} highcharts/chart/plotbackgroundimage/\n * Skies\n * @sample {highstock} stock/chart/plotbackgroundimage/\n * Skies\n *\n * @type {string}\n * @apioption chart.plotBackgroundImage\n */\n /**\n * The color of the inner chart or plot area border.\n *\n * @see In styled mode, a plot border stroke can be set with the\n * `.highcharts-plot-border` class.\n *\n * @sample {highcharts} highcharts/chart/plotbordercolor/\n * Blue border\n * @sample {highstock} stock/chart/plotborder/\n * Blue border\n * @sample {highmaps} maps/chart/plotborder/\n * Plot border options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n plotBorderColor: \"#cccccc\" /* Palette.neutralColor20 */\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ChartDefaults;\n });\n _registerModule(_modules, 'Core/Color/Color.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isNumber, merge, pInt } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Handle color operations. Some object methods are chainable.\n *\n * @class\n * @name Highcharts.Color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n class Color {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Creates a color instance out of a color string or object.\n *\n * @function Highcharts.Color.parse\n *\n * @param {Highcharts.ColorType} [input]\n * The input color in either rbga or hex format.\n *\n * @return {Highcharts.Color}\n * Color instance.\n */\n static parse(input) {\n return input ? new Color(input) : Color.None;\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(input) {\n this.rgba = [NaN, NaN, NaN, NaN];\n this.input = input;\n const GlobalColor = H.Color;\n // Backwards compatibility, allow class overwrite\n if (GlobalColor && GlobalColor !== Color) {\n return new GlobalColor(input);\n }\n this.init(input);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Parse the input color to rgba array\n *\n * @private\n * @function Highcharts.Color#init\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n */\n init(input) {\n let result, rgba, i, parser;\n // Gradients\n if (typeof input === 'object' &&\n typeof input.stops !== 'undefined') {\n this.stops = input.stops.map((stop) => new Color(stop[1]));\n // Solid colors\n }\n else if (typeof input === 'string') {\n this.input = input = (Color.names[input.toLowerCase()] || input);\n // Bitmasking as input[0] is not working for legacy IE.\n if (input.charAt(0) === '#') {\n const len = input.length, col = parseInt(input.substr(1), 16);\n // Handle long-form, e.g. #AABBCC\n if (len === 7) {\n rgba = [\n (col & 0xFF0000) >> 16,\n (col & 0xFF00) >> 8,\n (col & 0xFF),\n 1\n ];\n // Handle short-form, e.g. #ABC\n // In short form, the value is assumed to be the same\n // for both nibbles for each component. e.g. #ABC = #AABBCC\n }\n else if (len === 4) {\n rgba = [\n (((col & 0xF00) >> 4) |\n (col & 0xF00) >> 8),\n (((col & 0xF0) >> 4) |\n (col & 0xF0)),\n ((col & 0xF) << 4) | (col & 0xF),\n 1\n ];\n }\n }\n // Otherwise, check regex parsers\n if (!rgba) {\n i = Color.parsers.length;\n while (i-- && !rgba) {\n parser = Color.parsers[i];\n result = parser.regex.exec(input);\n if (result) {\n rgba = parser.parse(result);\n }\n }\n }\n }\n if (rgba) {\n this.rgba = rgba;\n }\n }\n /**\n * Return the color or gradient stops in the specified format\n *\n * @function Highcharts.Color#get\n *\n * @param {string} [format]\n * Possible values are 'a', 'rgb', 'rgba' (default).\n *\n * @return {Highcharts.ColorType}\n * This color as a string or gradient stops.\n */\n get(format) {\n const input = this.input, rgba = this.rgba;\n if (typeof input === 'object' &&\n typeof this.stops !== 'undefined') {\n const ret = merge(input);\n ret.stops = [].slice.call(ret.stops);\n this.stops.forEach((stop, i) => {\n ret.stops[i] = [\n ret.stops[i][0],\n stop.get(format)\n ];\n });\n return ret;\n }\n // it's NaN if gradient colors on a column chart\n if (rgba && isNumber(rgba[0])) {\n if (format === 'rgb' || (!format && rgba[3] === 1)) {\n return 'rgb(' + rgba[0] + ',' + rgba[1] + ',' + rgba[2] + ')';\n }\n if (format === 'a') {\n return `${rgba[3]}`;\n }\n return 'rgba(' + rgba.join(',') + ')';\n }\n return input;\n }\n /**\n * Brighten the color instance.\n *\n * @function Highcharts.Color#brighten\n *\n * @param {number} alpha\n * The alpha value.\n *\n * @return {Highcharts.Color}\n * This color with modifications.\n */\n brighten(alpha) {\n const rgba = this.rgba;\n if (this.stops) {\n this.stops.forEach(function (stop) {\n stop.brighten(alpha);\n });\n }\n else if (isNumber(alpha) && alpha !== 0) {\n for (let i = 0; i < 3; i++) {\n rgba[i] += pInt(alpha * 255);\n if (rgba[i] < 0) {\n rgba[i] = 0;\n }\n if (rgba[i] > 255) {\n rgba[i] = 255;\n }\n }\n }\n return this;\n }\n /**\n * Set the color's opacity to a given alpha value.\n *\n * @function Highcharts.Color#setOpacity\n *\n * @param {number} alpha\n * Opacity between 0 and 1.\n *\n * @return {Highcharts.Color}\n * Color with modifications.\n */\n setOpacity(alpha) {\n this.rgba[3] = alpha;\n return this;\n }\n /**\n * Return an intermediate color between two colors.\n *\n * @function Highcharts.Color#tweenTo\n *\n * @param {Highcharts.Color} to\n * The color object to tween to.\n *\n * @param {number} pos\n * The intermediate position, where 0 is the from color (current color\n * item), and 1 is the `to` color.\n *\n * @return {Highcharts.ColorType}\n * The intermediate color in rgba notation, or unsupported type.\n */\n tweenTo(to, pos) {\n const fromRgba = this.rgba, toRgba = to.rgba;\n // Unsupported color, return to-color (#3920, #7034)\n if (!isNumber(fromRgba[0]) || !isNumber(toRgba[0])) {\n return to.input || 'none';\n }\n // Check for has alpha, because rgba colors perform worse due to\n // lack of support in WebKit.\n const hasAlpha = (toRgba[3] !== 1 || fromRgba[3] !== 1);\n return (hasAlpha ? 'rgba(' : 'rgb(') +\n Math.round(toRgba[0] + (fromRgba[0] - toRgba[0]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[1] + (fromRgba[1] - toRgba[1]) * (1 - pos)) +\n ',' +\n Math.round(toRgba[2] + (fromRgba[2] - toRgba[2]) * (1 - pos)) +\n (hasAlpha ?\n (',' +\n (toRgba[3] + (fromRgba[3] - toRgba[3]) * (1 - pos))) :\n '') +\n ')';\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * Collection of named colors. Can be extended from the outside by adding\n * colors to Highcharts.Color.names.\n * @private\n */\n Color.names = {\n white: '#ffffff',\n black: '#000000'\n };\n /**\n * Collection of parsers. This can be extended from the outside by pushing\n * parsers to `Color.parsers`.\n */\n Color.parsers = [{\n // RGBA color\n // eslint-disable-next-line max-len\n regex: /rgba\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]?(?:\\.[0-9]+)?)\\s*\\)/,\n parse: function (result) {\n return [\n pInt(result[1]),\n pInt(result[2]),\n pInt(result[3]),\n parseFloat(result[4], 10)\n ];\n }\n }, {\n // RGB color\n regex: /rgb\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*\\)/,\n parse: function (result) {\n return [pInt(result[1]), pInt(result[2]), pInt(result[3]), 1];\n }\n }];\n // Must be last static member for init cycle\n Color.None = new Color('');\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A valid color to be parsed and handled by Highcharts. Highcharts internally\n * supports hex colors like `#ffffff`, rgb colors like `rgb(255,255,255)` and\n * rgba colors like `rgba(255,255,255,1)`. Other colors may be supported by the\n * browsers and displayed correctly, but Highcharts is not able to process them\n * and apply concepts like opacity and brightening.\n *\n * @typedef {string} Highcharts.ColorString\n */\n /**\n * A valid color type than can be parsed and handled by Highcharts. It can be a\n * color string, a gradient object, or a pattern object.\n *\n * @typedef {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject} Highcharts.ColorType\n */\n /**\n * Gradient options instead of a solid color.\n *\n * @example\n * // Linear gradient used as a color option\n * color: {\n * linearGradient: { x1: 0, x2: 0, y1: 0, y2: 1 },\n * stops: [\n * [0, '#003399'], // start\n * [0.5, '#ffffff'], // middle\n * [1, '#3366AA'] // end\n * ]\n * }\n *\n * @interface Highcharts.GradientColorObject\n */ /**\n * Holds an object that defines the start position and the end position relative\n * to the shape.\n * @name Highcharts.GradientColorObject#linearGradient\n * @type {Highcharts.LinearGradientColorObject|undefined}\n */ /**\n * Holds an object that defines the center position and the radius.\n * @name Highcharts.GradientColorObject#radialGradient\n * @type {Highcharts.RadialGradientColorObject|undefined}\n */ /**\n * The first item in each tuple is the position in the gradient, where 0 is the\n * start of the gradient and 1 is the end of the gradient. Multiple stops can be\n * applied. The second item is the color for each stop. This color can also be\n * given in the rgba format.\n * @name Highcharts.GradientColorObject#stops\n * @type {Array}\n */\n /**\n * Color stop tuple.\n *\n * @see Highcharts.GradientColorObject\n *\n * @interface Highcharts.GradientColorStopObject\n */ /**\n * @name Highcharts.GradientColorStopObject#0\n * @type {number}\n */ /**\n * @name Highcharts.GradientColorStopObject#1\n * @type {Highcharts.ColorString}\n */ /**\n * @name Highcharts.GradientColorStopObject#color\n * @type {Highcharts.Color|undefined}\n */\n /**\n * Defines the start position and the end position for a gradient relative\n * to the shape. Start position (x1, y1) and end position (x2, y2) are relative\n * to the shape, where 0 means top/left and 1 is bottom/right.\n *\n * @interface Highcharts.LinearGradientColorObject\n */ /**\n * Start horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x1\n * @type {number}\n */ /**\n * End horizontal position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#x2\n * @type {number}\n */ /**\n * Start vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y1\n * @type {number}\n */ /**\n * End vertical position of the gradient. Float ranges 0-1.\n * @name Highcharts.LinearGradientColorObject#y2\n * @type {number}\n */\n /**\n * Defines the center position and the radius for a gradient.\n *\n * @interface Highcharts.RadialGradientColorObject\n */ /**\n * Center horizontal position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cx\n * @type {number}\n */ /**\n * Center vertical position relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#cy\n * @type {number}\n */ /**\n * Radius relative to the shape. Float ranges 0-1.\n * @name Highcharts.RadialGradientColorObject#r\n * @type {number}\n */\n /**\n * Creates a color instance out of a color string.\n *\n * @function Highcharts.color\n *\n * @param {Highcharts.ColorType} input\n * The input color in either rbga or hex format\n *\n * @return {Highcharts.Color}\n * Color instance\n */\n (''); // detach doclets above\n\n return Color;\n });\n _registerModule(_modules, 'Core/Color/Palettes.js', [], function () {\n /**\n * Series palettes for Highcharts. Series colors are defined in highcharts.css.\n * **Do not edit this file!** This file is generated using the 'gulp palette' task.\n */\n const SeriesPalettes = {\n /**\n * Colors for data series and points\n */\n colors: [\n '#2caffe',\n '#544fc5',\n '#00e272',\n '#fe6a35',\n '#6b8abc',\n '#d568fb',\n '#2ee0ca',\n '#fa4b42',\n '#feb56a',\n '#91e8e1'\n ]\n };\n\n return SeriesPalettes;\n });\n _registerModule(_modules, 'Core/Time.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { win } = H;\n const { defined, error, extend, isObject, merge, objectEach, pad, pick, splat, timeUnits } = U;\n /* *\n *\n * Constants\n *\n * */\n const hasNewSafariBug = H.isSafari &&\n win.Intl &&\n win.Intl.DateTimeFormat.prototype.formatRange;\n // To do: Remove this when we no longer need support for Safari < v14.1\n const hasOldSafariBug = H.isSafari &&\n win.Intl &&\n !win.Intl.DateTimeFormat.prototype.formatRange;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Time class. Time settings are applied in general for each page using\n * `Highcharts.setOptions`, or individually for each Chart item through the\n * [time](https://api.highcharts.com/highcharts/time) options set.\n *\n * The Time object is available from {@link Highcharts.Chart#time},\n * which refers to `Highcharts.time` if no individual time settings are\n * applied.\n *\n * @example\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n *\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n *\n * @since 6.0.5\n *\n * @class\n * @name Highcharts.Time\n *\n * @param {Highcharts.TimeOptions} [options]\n * Time options as defined in [chart.options.time](/highcharts/time).\n */\n class Time {\n /* *\n *\n * Constructors\n *\n * */\n constructor(options) {\n /* *\n *\n * Properties\n *\n * */\n this.options = {};\n this.useUTC = false;\n this.variableTimezone = false;\n this.Date = win.Date;\n /**\n * Get the time zone offset based on the current timezone information as\n * set in the global options.\n *\n * @function Highcharts.Time#getTimezoneOffset\n *\n * @param {number} timestamp\n * The JavaScript timestamp to inspect.\n *\n * @return {number}\n * The timezone offset in minutes compared to UTC.\n */\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n this.update(options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Time units used in `Time.get` and `Time.set`\n *\n * @typedef {\"Date\"|\"Day\"|\"FullYear\"|\"Hours\"|\"Milliseconds\"|\"Minutes\"|\"Month\"|\"Seconds\"} Highcharts.TimeUnitValue\n */\n /**\n * Get the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.getXXX / Date.getUTCXXX`, so instead of calling\n * `date.getHours()` or `date.getUTCHours()` we will call\n * `time.get('Hours')`.\n *\n * @function Highcharts.Time#get\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n *\n * @return {number}\n * The given time unit\n */\n get(unit, date) {\n if (this.variableTimezone || this.timezoneOffset) {\n const realMs = date.getTime();\n const ms = realMs - this.getTimezoneOffset(date);\n date.setTime(ms); // Temporary adjust to timezone\n const ret = date['getUTC' + unit]();\n date.setTime(realMs); // Reset\n return ret;\n }\n // UTC time with no timezone handling\n if (this.useUTC) {\n return date['getUTC' + unit]();\n }\n // Else, local time\n return date['get' + unit]();\n }\n /**\n * Set the value of a date object in given units, and subject to the Time\n * object's current timezone settings. This function corresponds directly to\n * JavaScripts `Date.setXXX / Date.setUTCXXX`, so instead of calling\n * `date.setHours(0)` or `date.setUTCHours(0)` we will call\n * `time.set('Hours', 0)`.\n *\n * @function Highcharts.Time#set\n *\n * @param {Highcharts.TimeUnitValue} unit\n * @param {Date} date\n * @param {number} value\n *\n * @return {number}\n * The epoch milliseconds of the updated date\n */\n set(unit, date, value) {\n // UTC time with timezone handling\n if (this.variableTimezone || this.timezoneOffset) {\n // For lower order time units, just set it directly using UTC\n // time\n if (unit === 'Milliseconds' ||\n unit === 'Seconds' ||\n (unit === 'Minutes' &&\n this.getTimezoneOffset(date) % 3600000 === 0) // #13961\n ) {\n return date['setUTC' + unit](value);\n }\n // Higher order time units need to take the time zone into\n // account\n // Adjust by timezone\n const offset = this.getTimezoneOffset(date);\n let ms = date.getTime() - offset;\n date.setTime(ms);\n date['setUTC' + unit](value);\n const newOffset = this.getTimezoneOffset(date);\n ms = date.getTime() + newOffset;\n return date.setTime(ms);\n }\n // UTC time with no timezone handling\n if (this.useUTC ||\n // leap calculation in UTC only\n (hasNewSafariBug && unit === 'FullYear')) {\n return date['setUTC' + unit](value);\n }\n // Else, local time\n return date['set' + unit](value);\n }\n /**\n * Update the Time object with current options. It is called internally on\n * initializing Highcharts, after running `Highcharts.setOptions` and on\n * `Chart.update`.\n *\n * @private\n * @function Highcharts.Time#update\n *\n * @param {Highcharts.TimeOptions} [options]\n *\n */\n update(options = {}) {\n const useUTC = pick(options.useUTC, true);\n this.options = options = merge(true, this.options, options);\n // Allow using a different Date class\n this.Date = options.Date || win.Date || Date;\n this.useUTC = useUTC;\n this.timezoneOffset = (useUTC && options.timezoneOffset) || void 0;\n this.getTimezoneOffset = this.timezoneOffsetFunction();\n /*\n * The time object has options allowing for variable time zones, meaning\n * the axis ticks or series data needs to consider this.\n */\n this.variableTimezone = useUTC && !!(options.getTimezoneOffset ||\n options.timezone);\n }\n /**\n * Make a time and returns milliseconds. Interprets the inputs as UTC time,\n * local time or a specific timezone time depending on the current time\n * settings.\n *\n * @function Highcharts.Time#makeTime\n *\n * @param {number} year\n * The year\n *\n * @param {number} month\n * The month. Zero-based, so January is 0.\n *\n * @param {number} [date=1]\n * The day of the month\n *\n * @param {number} [hours=0]\n * The hour of the day, 0-23.\n *\n * @param {number} [minutes=0]\n * The minutes\n *\n * @param {number} [seconds=0]\n * The seconds\n *\n * @return {number}\n * The time in milliseconds since January 1st 1970.\n */\n makeTime(year, month, date, hours, minutes, seconds) {\n let d, offset, newOffset;\n if (this.useUTC) {\n d = this.Date.UTC.apply(0, arguments);\n offset = this.getTimezoneOffset(d);\n d += offset;\n newOffset = this.getTimezoneOffset(d);\n if (offset !== newOffset) {\n d += newOffset - offset;\n // A special case for transitioning from summer time to winter time.\n // When the clock is set back, the same time is repeated twice, i.e.\n // 02:30 am is repeated since the clock is set back from 3 am to\n // 2 am. We need to make the same time as local Date does.\n }\n else if (offset - 36e5 === this.getTimezoneOffset(d - 36e5) &&\n !hasOldSafariBug) {\n d -= 36e5;\n }\n }\n else {\n d = new this.Date(year, month, pick(date, 1), pick(hours, 0), pick(minutes, 0), pick(seconds, 0)).getTime();\n }\n return d;\n }\n /**\n * Sets the getTimezoneOffset function. If the `timezone` option is set, a\n * default getTimezoneOffset function with that timezone is returned. If\n * a `getTimezoneOffset` option is defined, it is returned. If neither are\n * specified, the function using the `timezoneOffset` option or 0 offset is\n * returned.\n *\n * @private\n * @function Highcharts.Time#timezoneOffsetFunction\n *\n * @return {Function}\n * A getTimezoneOffset function\n */\n timezoneOffsetFunction() {\n const time = this, options = this.options, getTimezoneOffset = options.getTimezoneOffset, moment = options.moment || win.moment;\n if (!this.useUTC) {\n return function (timestamp) {\n return new Date(timestamp.toString()).getTimezoneOffset() * 60000;\n };\n }\n if (options.timezone) {\n if (!moment) {\n // getTimezoneOffset-function stays undefined because it depends\n // on Moment.js\n error(25);\n }\n else {\n return function (timestamp) {\n return -moment.tz(timestamp, options.timezone).utcOffset() * 60000;\n };\n }\n }\n // If not timezone is set, look for the getTimezoneOffset callback\n if (this.useUTC && getTimezoneOffset) {\n return function (timestamp) {\n return getTimezoneOffset(timestamp.valueOf()) * 60000;\n };\n }\n // Last, use the `timezoneOffset` option if set\n return function () {\n return (time.timezoneOffset || 0) * 60000;\n };\n }\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970)\n * into a human readable date string. The available format keys are listed\n * below. Additional formats can be given in the\n * {@link Highcharts.dateFormats} hook.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @example\n * const time = new Highcharts.Time();\n * const s = time.dateFormat('%Y-%m-%d %H:%M:%S', Date.UTC(2020, 0, 1));\n * console.log(s); // => 2020-01-01 00:00:00\n *\n * @function Highcharts.Time#dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are\n * prefixed with %.\n *\n * @param {number} [timestamp]\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n dateFormat(format, timestamp, capitalize) {\n if (!defined(timestamp) || isNaN(timestamp)) {\n return (H.defaultOptions.lang &&\n H.defaultOptions.lang.invalidDate ||\n '');\n }\n format = pick(format, '%Y-%m-%d %H:%M:%S');\n const time = this, date = new this.Date(timestamp), \n // get the basic time values\n hours = this.get('Hours', date), day = this.get('Day', date), dayOfMonth = this.get('Date', date), month = this.get('Month', date), fullYear = this.get('FullYear', date), lang = H.defaultOptions.lang, langWeekdays = (lang && lang.weekdays), shortWeekdays = (lang && lang.shortWeekdays), \n // List all format keys. Custom formats can be added from the\n // outside.\n replacements = extend({\n // Day\n // Short weekday, like 'Mon'\n a: shortWeekdays ?\n shortWeekdays[day] :\n langWeekdays[day].substr(0, 3),\n // Long weekday, like 'Monday'\n A: langWeekdays[day],\n // Two digit day of the month, 01 to 31\n d: pad(dayOfMonth),\n // Day of the month, 1 through 31\n e: pad(dayOfMonth, 2, ' '),\n // Day of the week, 0 through 6\n w: day,\n // Week (none implemented)\n // 'W': weekNumber(),\n // Month\n // Short month, like 'Jan'\n b: lang.shortMonths[month],\n // Long month, like 'January'\n B: lang.months[month],\n // Two digit month number, 01 through 12\n m: pad(month + 1),\n // Month number, 1 through 12 (#8150)\n o: month + 1,\n // Year\n // Two digits year, like 09 for 2009\n y: fullYear.toString().substr(2, 2),\n // Four digits year, like 2009\n Y: fullYear,\n // Time\n // Two digits hours in 24h format, 00 through 23\n H: pad(hours),\n // Hours in 24h format, 0 through 23\n k: hours,\n // Two digits hours in 12h format, 00 through 11\n I: pad((hours % 12) || 12),\n // Hours in 12h format, 1 through 12\n l: (hours % 12) || 12,\n // Two digits minutes, 00 through 59\n M: pad(this.get('Minutes', date)),\n // Upper case AM or PM\n p: hours < 12 ? 'AM' : 'PM',\n // Lower case AM or PM\n P: hours < 12 ? 'am' : 'pm',\n // Two digits seconds, 00 through 59\n S: pad(date.getSeconds()),\n // Milliseconds (naming from Ruby)\n L: pad(Math.floor(timestamp % 1000), 3)\n }, H.dateFormats);\n // Do the replaces\n objectEach(replacements, function (val, key) {\n // Regex would do it in one line, but this is faster\n while (format.indexOf('%' + key) !== -1) {\n format = format.replace('%' + key, typeof val === 'function' ? val.call(time, timestamp) : val);\n }\n });\n // Optionally capitalize the string and return\n return capitalize ?\n (format.substr(0, 1).toUpperCase() +\n format.substr(1)) :\n format;\n }\n /**\n * Resolve legacy formats of dateTimeLabelFormats (strings and arrays) into\n * an object.\n * @private\n * @param {string|Array|Highcharts.Dictionary} f\n * General format description\n * @return {Highcharts.Dictionary}\n * The object definition\n */\n resolveDTLFormat(f) {\n if (!isObject(f, true)) { // check for string or array\n f = splat(f);\n return {\n main: f[0],\n from: f[1],\n to: f[2]\n };\n }\n return f;\n }\n /**\n * Return an array with time positions distributed on round time values\n * right and right after min and max. Used in datetime axes as well as for\n * grouping data on a datetime axis.\n *\n * @function Highcharts.Time#getTimeTicks\n *\n * @param {Highcharts.TimeNormalizedObject} normalizedInterval\n * The interval in axis values (ms) and the count\n *\n * @param {number} [min]\n * The minimum in axis values\n *\n * @param {number} [max]\n * The maximum in axis values\n *\n * @param {number} [startOfWeek=1]\n *\n * @return {Highcharts.AxisTickPositionsArray}\n * Time positions\n */\n getTimeTicks(normalizedInterval, min, max, startOfWeek) {\n const time = this, Date = time.Date, tickPositions = [], higherRanks = {}, \n // When crossing DST, use the max. Resolves #6278.\n minDate = new Date(min), interval = normalizedInterval.unitRange, count = normalizedInterval.count || 1;\n let i, minYear, // used in months and years as a basis for Date.UTC()\n variableDayLength, minDay;\n startOfWeek = pick(startOfWeek, 1);\n if (defined(min)) { // #1300\n time.set('Milliseconds', minDate, interval >= timeUnits.second ?\n 0 : // #3935\n count * Math.floor(time.get('Milliseconds', minDate) / count)); // #3652, #3654\n if (interval >= timeUnits.second) { // second\n time.set('Seconds', minDate, interval >= timeUnits.minute ?\n 0 : // #3935\n count * Math.floor(time.get('Seconds', minDate) / count));\n }\n if (interval >= timeUnits.minute) { // minute\n time.set('Minutes', minDate, interval >= timeUnits.hour ?\n 0 :\n count * Math.floor(time.get('Minutes', minDate) / count));\n }\n if (interval >= timeUnits.hour) { // hour\n time.set('Hours', minDate, interval >= timeUnits.day ?\n 0 :\n count * Math.floor(time.get('Hours', minDate) / count));\n }\n if (interval >= timeUnits.day) { // day\n time.set('Date', minDate, interval >= timeUnits.month ?\n 1 :\n Math.max(1, count * Math.floor(time.get('Date', minDate) / count)));\n }\n if (interval >= timeUnits.month) { // month\n time.set('Month', minDate, interval >= timeUnits.year ? 0 :\n count * Math.floor(time.get('Month', minDate) / count));\n minYear = time.get('FullYear', minDate);\n }\n if (interval >= timeUnits.year) { // year\n minYear -= minYear % count;\n time.set('FullYear', minDate, minYear);\n }\n // week is a special case that runs outside the hierarchy\n if (interval === timeUnits.week) {\n // get start of current week, independent of count\n minDay = time.get('Day', minDate);\n time.set('Date', minDate, (time.get('Date', minDate) -\n minDay + startOfWeek +\n // We don't want to skip days that are before\n // startOfWeek (#7051)\n (minDay < startOfWeek ? -7 : 0)));\n }\n // Get basics for variable time spans\n minYear = time.get('FullYear', minDate);\n const minMonth = time.get('Month', minDate), minDateDate = time.get('Date', minDate), minHours = time.get('Hours', minDate);\n // Redefine min to the floored/rounded minimum time (#7432)\n min = minDate.getTime();\n // Handle local timezone offset\n if ((time.variableTimezone || !time.useUTC) && defined(max)) {\n // Detect whether we need to take the DST crossover into\n // consideration. If we're crossing over DST, the day length may\n // be 23h or 25h and we need to compute the exact clock time for\n // each tick instead of just adding hours. This comes at a cost,\n // so first we find out if it is needed (#4951).\n variableDayLength = (\n // Long range, assume we're crossing over.\n max - min > 4 * timeUnits.month ||\n // Short range, check if min and max are in different time\n // zones.\n time.getTimezoneOffset(min) !==\n time.getTimezoneOffset(max));\n }\n // Iterate and add tick positions at appropriate values\n let t = minDate.getTime();\n i = 1;\n while (t < max) {\n tickPositions.push(t);\n // if the interval is years, use Date.UTC to increase years\n if (interval === timeUnits.year) {\n t = time.makeTime(minYear + i * count, 0);\n // if the interval is months, use Date.UTC to increase months\n }\n else if (interval === timeUnits.month) {\n t = time.makeTime(minYear, minMonth + i * count);\n // if we're using global time, the interval is not fixed as it\n // jumps one hour at the DST crossover\n }\n else if (variableDayLength &&\n (interval === timeUnits.day || interval === timeUnits.week)) {\n t = time.makeTime(minYear, minMonth, minDateDate +\n i * count * (interval === timeUnits.day ? 1 : 7));\n }\n else if (variableDayLength &&\n interval === timeUnits.hour &&\n count > 1) {\n // make sure higher ranks are preserved across DST (#6797,\n // #7621)\n t = time.makeTime(minYear, minMonth, minDateDate, minHours + i * count);\n // else, the interval is fixed and we use simple addition\n }\n else {\n t += interval * count;\n }\n i++;\n }\n // push the last time\n tickPositions.push(t);\n // Handle higher ranks. Mark new days if the time is on midnight\n // (#950, #1649, #1760, #3349). Use a reasonable dropout threshold\n // to prevent looping over dense data grouping (#6156).\n if (interval <= timeUnits.hour && tickPositions.length < 10000) {\n tickPositions.forEach(function (t) {\n if (\n // Speed optimization, no need to run dateFormat unless\n // we're on a full or half hour\n t % 1800000 === 0 &&\n // Check for local or global midnight\n time.dateFormat('%H%M%S%L', t) === '000000000') {\n higherRanks[t] = 'day';\n }\n });\n }\n }\n // record information on the chosen unit - for dynamic label formatter\n tickPositions.info = extend(normalizedInterval, {\n higherRanks,\n totalRange: interval * count\n });\n return tickPositions;\n }\n /**\n * Get the optimal date format for a point, based on a range.\n *\n * @private\n * @function Highcharts.Time#getDateFormat\n *\n * @param {number} range\n * The time range\n *\n * @param {number} timestamp\n * The timestamp of the date\n *\n * @param {number} startOfWeek\n * An integer representing the first day of the week, where 0 is\n * Sunday.\n *\n * @param {Highcharts.Dictionary} dateTimeLabelFormats\n * A map of time units to formats.\n *\n * @return {string}\n * The optimal date format for a point.\n */\n getDateFormat(range, timestamp, startOfWeek, dateTimeLabelFormats) {\n const dateStr = this.dateFormat('%m-%d %H:%M:%S.%L', timestamp), blank = '01-01 00:00:00.000', strpos = {\n millisecond: 15,\n second: 12,\n minute: 9,\n hour: 6,\n day: 3\n };\n let n = 'millisecond', \n // for sub-millisecond data, #4223\n lastN = n;\n for (n in timeUnits) { // eslint-disable-line guard-for-in\n // If the range is exactly one week and we're looking at a\n // Sunday/Monday, go for the week format\n if (range === timeUnits.week &&\n +this.dateFormat('%w', timestamp) === startOfWeek &&\n dateStr.substr(6) === blank.substr(6)) {\n n = 'week';\n break;\n }\n // The first format that is too great for the range\n if (timeUnits[n] > range) {\n n = lastN;\n break;\n }\n // If the point is placed every day at 23:59, we need to show\n // the minutes as well. #2637.\n if (strpos[n] &&\n dateStr.substr(strpos[n]) !== blank.substr(strpos[n])) {\n break;\n }\n // Weeks are outside the hierarchy, only apply them on\n // Mondays/Sundays like in the first condition\n if (n !== 'week') {\n lastN = n;\n }\n }\n return this.resolveDTLFormat(dateTimeLabelFormats[n]).main;\n }\n }\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Normalized interval.\n *\n * @interface Highcharts.TimeNormalizedObject\n */ /**\n * The count.\n *\n * @name Highcharts.TimeNormalizedObject#count\n * @type {number|undefined}\n */ /**\n * The interval in axis values (ms).\n *\n * @name Highcharts.TimeNormalizedObject#unitRange\n * @type {number}\n */\n /**\n * Function of an additional date format specifier.\n *\n * @callback Highcharts.TimeFormatCallbackFunction\n *\n * @param {number} timestamp\n * The time to format.\n *\n * @return {string}\n * The formatted portion of the date.\n */\n /**\n * Time ticks.\n *\n * @interface Highcharts.AxisTickPositionsArray\n * @extends global.Array\n */ /**\n * @name Highcharts.AxisTickPositionsArray#info\n * @type {Highcharts.TimeTicksInfoObject|undefined}\n */\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @callback Highcharts.TimezoneOffsetCallbackFunction\n *\n * @param {number} timestamp\n * Timestamp in terms of milliseconds since January 1 1970.\n *\n * @return {number}\n * Timezone offset in minutes.\n */\n /**\n * Allows to manually load the `moment.js` library from Highcharts options\n * instead of the `window`.\n * In case of loading the library from a `script` tag,\n * this option is not needed, it will be loaded from there by default.\n *\n * @type {Function}\n * @since 8.2.0\n * @apioption time.moment\n */\n ''; // keeps doclets above in JS file\n\n return Time;\n });\n _registerModule(_modules, 'Core/Defaults.js', [_modules['Core/Chart/ChartDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Color/Palettes.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js']], function (ChartDefaults, Color, H, Palettes, Time, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { isTouchDevice, svg } = H;\n const { merge } = U;\n /* *\n *\n * API Options\n *\n * */\n /**\n * Global default settings.\n *\n * @name Highcharts.defaultOptions\n * @type {Highcharts.Options}\n */ /**\n * @optionparent\n * @private\n */\n const defaultOptions = {\n /**\n * An array containing the default colors for the chart's series. When\n * all colors are used, new colors are pulled from the start again.\n *\n * Default colors can also be set on a series or series.type basis,\n * see [column.colors](#plotOptions.column.colors),\n * [pie.colors](#plotOptions.pie.colors).\n *\n * In styled mode, the colors option doesn't exist. Instead, colors\n * are defined in CSS and applied either through series or point class\n * names, or through the [chart.colorCount](#chart.colorCount) option.\n *\n * @sample {highcharts} highcharts/chart/colors/\n * Assign a global color theme\n * @sample highcharts/members/theme-v10/\n * Latest release styled like version 10\n *\n * @type {Array<(Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject)>}\n * @default [\n * \"#2caffe\",\n * \"#544fc5\",\n * \"#00e272\",\n * \"#fe6a35\",\n * \"#6b8abc\",\n * \"#d568fb\",\n * \"#2ee0ca\",\n * \"#fa4b42\",\n * \"#feb56a\",\n * \"#91e8e12\n * ]\n */\n colors: Palettes.colors,\n /**\n * Styled mode only. Configuration object for adding SVG definitions for\n * reusable elements. See [gradients, shadows and\n * patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns)\n * for more information and code examples.\n *\n * @type {*}\n * @since 5.0.0\n * @apioption defs\n */\n /**\n * @ignore-option\n */\n symbols: ['circle', 'diamond', 'square', 'triangle', 'triangle-down'],\n /**\n * The language object is global and it can't be set on each chart\n * initialization. Instead, use `Highcharts.setOptions` to set it before any\n * chart is initialized.\n *\n * ```js\n * Highcharts.setOptions({\n * lang: {\n * months: [\n * 'Janvier', 'Février', 'Mars', 'Avril',\n * 'Mai', 'Juin', 'Juillet', 'Août',\n * 'Septembre', 'Octobre', 'Novembre', 'Décembre'\n * ],\n * weekdays: [\n * 'Dimanche', 'Lundi', 'Mardi', 'Mercredi',\n * 'Jeudi', 'Vendredi', 'Samedi'\n * ]\n * }\n * });\n * ```\n */\n lang: {\n /**\n * The loading text that appears when the chart is set into the loading\n * state following a call to `chart.showLoading`.\n */\n loading: 'Loading...',\n /**\n * An array containing the months names. Corresponds to the `%B` format\n * in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\",\n * \"July\", \"August\", \"September\", \"October\", \"November\",\n * \"December\"]\n */\n months: [\n 'January', 'February', 'March', 'April', 'May', 'June', 'July',\n 'August', 'September', 'October', 'November', 'December'\n ],\n /**\n * An array containing the months names in abbreviated form. Corresponds\n * to the `%b` format in `Highcharts.dateFormat()`.\n *\n * @type {Array}\n * @default [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n * \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n */\n shortMonths: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul',\n 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ],\n /**\n * An array containing the weekday names.\n *\n * @type {Array}\n * @default [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\",\n * \"Friday\", \"Saturday\"]\n */\n weekdays: [\n 'Sunday', 'Monday', 'Tuesday', 'Wednesday',\n 'Thursday', 'Friday', 'Saturday'\n ],\n /**\n * Short week days, starting Sunday. If not specified, Highcharts uses\n * the first three letters of the `lang.weekdays` option.\n *\n * @sample highcharts/lang/shortweekdays/\n * Finnish two-letter abbreviations\n *\n * @type {Array}\n * @since 4.2.4\n * @apioption lang.shortWeekdays\n */\n /**\n * What to show in a date field for invalid dates. Defaults to an empty\n * string.\n *\n * @type {string}\n * @since 4.1.8\n * @product highcharts highstock\n * @apioption lang.invalidDate\n */\n /**\n * The title appearing on hovering the zoom in button. The text itself\n * defaults to \"+\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom in\n * @product highmaps\n * @apioption lang.zoomIn\n */\n /**\n * The title appearing on hovering the zoom out button. The text itself\n * defaults to \"-\" and can be changed in the button options.\n *\n * @type {string}\n * @default Zoom out\n * @product highmaps\n * @apioption lang.zoomOut\n */\n /**\n * The default decimal point used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments.\n *\n * @since 1.2.2\n */\n decimalPoint: '.',\n /**\n * [Metric prefixes](https://en.wikipedia.org/wiki/Metric_prefix) used\n * to shorten high numbers in axis labels. Replacing any of the\n * positions with `null` causes the full number to be written. Setting\n * `numericSymbols` to `null` disables shortening altogether.\n *\n * @sample {highcharts} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n * @sample {highstock} highcharts/lang/numericsymbols/\n * Replacing the symbols with text\n *\n * @type {Array}\n * @default [\"k\", \"M\", \"G\", \"T\", \"P\", \"E\"]\n * @since 2.3.0\n */\n numericSymbols: ['k', 'M', 'G', 'T', 'P', 'E'],\n /**\n * The magnitude of [numericSymbols](#lang.numericSymbol) replacements.\n * Use 10000 for Japanese, Korean and various Chinese locales, which\n * use symbols for 10^4, 10^8 and 10^12.\n *\n * @sample highcharts/lang/numericsymbolmagnitude/\n * 10000 magnitude for Japanese\n *\n * @type {number}\n * @default 1000\n * @since 5.0.3\n * @apioption lang.numericSymbolMagnitude\n */\n /**\n * The text for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoom: 'Reset zoom',\n /**\n * The tooltip title for the label appearing when a chart is zoomed.\n *\n * @since 1.2.4\n */\n resetZoomTitle: 'Reset zoom level 1:1',\n /**\n * The default thousands separator used in the `Highcharts.numberFormat`\n * method unless otherwise specified in the function arguments. Defaults\n * to a single space character, which is recommended in\n * [ISO 31-0](https://en.wikipedia.org/wiki/ISO_31-0#Numbers) and works\n * across Anglo-American and continental European languages.\n *\n * @default \\u0020\n * @since 1.2.2\n */\n thousandsSep: ' '\n },\n /**\n * Global options that don't apply to each chart. These options, like\n * the `lang` options, must be set using the `Highcharts.setOptions`\n * method.\n *\n * ```js\n * Highcharts.setOptions({\n * global: {\n * useUTC: false\n * }\n * });\n * ```\n */\n /**\n * _Canvg rendering for Android 2.x is removed as of Highcharts 5.0\\.\n * Use the [libURL](#exporting.libURL) option to configure exporting._\n *\n * The URL to the additional file to lazy load for Android 2.x devices.\n * These devices don't support SVG, so we download a helper file that\n * contains [canvg](https://github.com/canvg/canvg), its dependency\n * rbcolor, and our own CanVG Renderer class. To avoid hotlinking to\n * our site, you can install canvas-tools.js on your own server and\n * change this option accordingly.\n *\n * @deprecated\n *\n * @type {string}\n * @default https://code.highcharts.com/{version}/modules/canvas-tools.js\n * @product highcharts highmaps\n * @apioption global.canvasToolsURL\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.useUTC](#time.useUTC) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {boolean}\n * @apioption global.useUTC\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.Date](#time.Date) that supports individual time settings\n * per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.Date\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.getTimezoneOffset](#time.getTimezoneOffset) that supports\n * individual time settings per chart.\n *\n * @deprecated\n *\n * @type {Function}\n * @product highcharts highstock\n * @apioption global.getTimezoneOffset\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezone](#time.timezone) that supports individual time\n * settings per chart.\n *\n * @deprecated\n *\n * @type {string}\n * @product highcharts highstock\n * @apioption global.timezone\n */\n /**\n * This option is deprecated since v6.0.5. Instead, use\n * [time.timezoneOffset](#time.timezoneOffset) that supports individual\n * time settings per chart.\n *\n * @deprecated\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption global.timezoneOffset\n */\n global: {},\n /**\n * Time options that can apply globally or to individual charts. These\n * settings affect how `datetime` axes are laid out, how tooltips are\n * formatted, how series\n * [pointIntervalUnit](#plotOptions.series.pointIntervalUnit) works and how\n * the Highcharts Stock range selector handles time.\n *\n * The common use case is that all charts in the same Highcharts object\n * share the same time settings, in which case the global settings are set\n * using `setOptions`.\n *\n * ```js\n * // Apply time settings globally\n * Highcharts.setOptions({\n * time: {\n * timezone: 'Europe/London'\n * }\n * });\n * // Apply time settings by instance\n * let chart = Highcharts.chart('container', {\n * time: {\n * timezone: 'America/New_York'\n * },\n * series: [{\n * data: [1, 4, 3, 5]\n * }]\n * });\n *\n * // Use the Time object\n * console.log(\n * 'Current time in New York',\n * chart.time.dateFormat('%Y-%m-%d %H:%M:%S', Date.now())\n * );\n * ```\n *\n * Since v6.0.5, the time options were moved from the `global` obect to the\n * `time` object, and time options can be set on each individual chart.\n *\n * @sample {highcharts|highstock}\n * highcharts/time/timezone/\n * Set the timezone globally\n * @sample {highcharts}\n * highcharts/time/individual/\n * Set the timezone per chart instance\n * @sample {highstock}\n * stock/time/individual/\n * Set the timezone per chart instance\n *\n * @since 6.0.5\n * @optionparent time\n */\n time: {\n /**\n * A custom `Date` class for advanced date handling. For example,\n * [JDate](https://github.com/tahajahangir/jdate) can be hooked in to\n * handle Jalali dates.\n *\n * @type {*}\n * @since 4.0.4\n * @product highcharts highstock gantt\n */\n Date: void 0,\n /**\n * A callback to return the time zone offset for a given datetime. It\n * takes the timestamp in terms of milliseconds since January 1 1970,\n * and returns the timezone offset in minutes. This provides a hook\n * for drawing time based charts in specific time zones using their\n * local DST crossover dates, with the help of external libraries.\n *\n * @see [global.timezoneOffset](#global.timezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/gettimezoneoffset/\n * Use moment.js to draw Oslo time regardless of browser locale\n *\n * @type {Highcharts.TimezoneOffsetCallbackFunction}\n * @since 4.1.0\n * @product highcharts highstock gantt\n */\n getTimezoneOffset: void 0,\n /**\n * Requires [moment.js](https://momentjs.com/). If the timezone option\n * is specified, it creates a default\n * [getTimezoneOffset](#time.getTimezoneOffset) function that looks\n * up the specified timezone in moment.js. If moment.js is not included,\n * this throws a Highcharts error in the console, but does not crash the\n * chart.\n *\n * @see [getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezone/\n * Europe/Oslo\n *\n * @type {string}\n * @since 5.0.7\n * @product highcharts highstock gantt\n */\n timezone: void 0,\n /**\n * The timezone offset in minutes. Positive values are west, negative\n * values are east of UTC, as in the ECMAScript\n * [getTimezoneOffset](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/getTimezoneOffset)\n * method. Use this to display UTC based data in a predefined time zone.\n *\n * @see [time.getTimezoneOffset](#time.getTimezoneOffset)\n *\n * @sample {highcharts|highstock} highcharts/time/timezoneoffset/\n * Timezone offset\n *\n * @since 3.0.8\n * @product highcharts highstock gantt\n */\n timezoneOffset: 0,\n /**\n * Whether to use UTC time for axis scaling, tickmark placement and\n * time display in `Highcharts.dateFormat`. Advantages of using UTC\n * is that the time displays equally regardless of the user agent's\n * time zone settings. Local time can be used when the data is loaded\n * in real time or when correct Daylight Saving Time transitions are\n * required.\n *\n * @sample {highcharts} highcharts/time/useutc-true/\n * True by default\n * @sample {highcharts} highcharts/time/useutc-false/\n * False\n */\n useUTC: true\n },\n chart: ChartDefaults,\n /**\n * The chart's main title.\n *\n * @sample {highmaps} maps/title/title/\n * Title options demonstrated\n */\n title: {\n /**\n * When the title is floating, the plot area will not move to make space\n * for it.\n *\n * @sample {highcharts} highcharts/chart/zoomtype-none/\n * False by default\n * @sample {highcharts} highcharts/title/floating/\n * True - title on top of the plot area\n * @sample {highstock} stock/chart/title-floating/\n * True - title on top of the plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption title.floating\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption title.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When a value is given, the title behaves\n * as if [floating](#title.floating) were `true`.\n *\n * @sample {highcharts} highcharts/title/verticalalign/\n * Chart title in bottom right corner\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption title.verticalAlign\n */\n /**\n * The x position of the title relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption title.x\n */\n /**\n * The y position of the title relative to the alignment within\n * [chart.spacingTop](#chart.spacingTop) and [chart.spacingBottom](\n * #chart.spacingBottom). By default it depends on the font size.\n *\n * @sample {highcharts} highcharts/title/y/\n * Title inside the plot area\n * @sample {highstock} stock/chart/title-verticalalign/\n * Chart title in bottom right corner\n *\n * @type {number}\n * @since 2.0\n * @apioption title.y\n */\n /**\n * CSS styles for the title. Use this for font styling, but use `align`,\n * `x` and `y` for text alignment.\n *\n * In styled mode, the title style is given in the `.highcharts-title`\n * class.\n *\n * @sample {highcharts} highcharts/title/style/\n * Custom color and weight\n * @sample {highstock} stock/chart/title-style/\n * Custom color and weight\n * @sample highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {highcharts|highmaps} { \"color\": \"#333333\", \"fontSize\": \"18px\" }\n * @default {highstock} { \"color\": \"#333333\", \"fontSize\": \"16px\" }\n */\n style: {\n color: \"#333333\" /* Palette.neutralColor80 */,\n fontWeight: 'bold'\n },\n /**\n * The title of the chart. To disable the title, set the `text` to\n * `undefined`.\n *\n * @sample {highcharts} highcharts/title/text/\n * Custom title\n * @sample {highstock} stock/chart/title-text/\n * Custom title\n *\n * @default {highcharts|highmaps} Chart title\n * @default {highstock} undefined\n */\n text: 'Chart title',\n /**\n * The horizontal alignment of the title. Can be one of \"left\", \"center\"\n * and \"right\".\n *\n * @sample {highcharts} highcharts/title/align/\n * Aligned to the plot area (x = 70px = margin left - spacing\n * left)\n * @sample {highstock} stock/chart/title-align/\n * Aligned to the plot area (x = 50px = margin left - spacing\n * left)\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * The margin between the title and the plot area, or if a subtitle\n * is present, the margin between the subtitle and the plot area.\n *\n * @sample {highcharts} highcharts/title/margin-50/\n * A chart title margin of 50\n * @sample {highcharts} highcharts/title/margin-subtitle/\n * The same margin applied with a subtitle\n * @sample {highstock} stock/chart/title-margin/\n * A chart title margin of 50\n *\n * @since 2.1\n */\n margin: 15,\n /**\n * Adjustment made to the title width, normally to reserve space for\n * the exporting burger menu.\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's subtitle. This can be used both to display a subtitle below\n * the main title, and to display random text anywhere in the chart. The\n * subtitle can be updated after chart initialization through the\n * `Chart.setTitle` method.\n *\n * @sample {highmaps} maps/title/subtitle/\n * Subtitle options demonstrated\n */\n subtitle: {\n /**\n * When the subtitle is floating, the plot area will not move to make\n * space for it.\n *\n * @sample {highcharts} highcharts/subtitle/floating/\n * Floating title and subtitle\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote floating at bottom right of plot area\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption subtitle.floating\n */\n /**\n * CSS styles for the title.\n *\n * In styled mode, the subtitle style is given in the\n * `.highcharts-subtitle` class.\n *\n * @sample {highcharts} highcharts/subtitle/style/\n * Custom color and weight\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n * @sample {highstock} stock/chart/subtitle-style\n * Custom color and weight\n * @sample {highstock} highcharts/css/titles/\n * Styled mode\n * @sample {highmaps} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n * @apioption subtitle.style\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption subtitle.useHTML\n */\n /**\n * The vertical alignment of the title. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the subtitle behaves as\n * floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1\n * @apioption subtitle.verticalAlign\n */\n /**\n * The x position of the subtitle relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @default 0\n * @since 2.0\n * @apioption subtitle.x\n */\n /**\n * The y position of the subtitle relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`. By default the subtitle\n * is laid out below the title unless the title is floating.\n *\n * @sample {highcharts} highcharts/subtitle/verticalalign/\n * Footnote at the bottom right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at the bottom right of plot area\n *\n * @type {number}\n * @since 2.0\n * @apioption subtitle.y\n */\n /**\n * CSS styles for the title.\n *\n * In styled mode, the subtitle style is given in the\n * `.highcharts-subtitle` class.\n *\n * @sample {highcharts} highcharts/subtitle/style/\n * Custom color and weight\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n * @sample {highstock} stock/chart/subtitle-style\n * Custom color and weight\n * @sample {highstock} highcharts/css/titles/\n * Styled mode\n * @sample {highmaps} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n */\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */,\n fontSize: '0.8em'\n },\n /**\n * The subtitle of the chart.\n *\n * @sample {highcharts|highstock} highcharts/subtitle/text/\n * Custom subtitle\n * @sample {highcharts|highstock} highcharts/subtitle/text-formatted/\n * Formatted and linked text.\n */\n text: '',\n /**\n * The horizontal alignment of the subtitle. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @sample {highcharts} highcharts/subtitle/align/\n * Footnote at right of plot area\n * @sample {highstock} stock/chart/subtitle-footnote\n * Footnote at bottom right of plot area\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * Adjustment made to the subtitle width, normally to reserve space\n * for the exporting burger menu.\n *\n * @see [title.widthAdjust](#title.widthAdjust)\n *\n * @sample highcharts/title/widthadjust/\n * Wider menu, greater padding\n *\n * @since 4.2.5\n */\n widthAdjust: -44\n },\n /**\n * The chart's caption, which will render below the chart and will be part\n * of exported charts. The caption can be updated after chart initialization\n * through the `Chart.update` or `Chart.caption.update` methods.\n *\n * @sample highcharts/caption/text/\n * A chart with a caption\n * @since 7.2.0\n */\n caption: {\n /**\n * When the caption is floating, the plot area will not move to make\n * space for it.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.floating\n */\n /**\n * The margin between the caption and the plot area.\n */\n margin: 15,\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the text.\n *\n * @type {boolean}\n * @default false\n * @apioption caption.useHTML\n */\n /**\n * The x position of the caption relative to the alignment within\n * `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @type {number}\n * @default 0\n * @apioption caption.x\n */\n /**\n * The y position of the caption relative to the alignment within\n * `chart.spacingTop` and `chart.spacingBottom`.\n *\n * @type {number}\n * @apioption caption.y\n */\n /**\n * CSS styles for the caption.\n *\n * In styled mode, the caption style is given in the\n * `.highcharts-caption` class.\n *\n * @sample {highcharts} highcharts/css/titles/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\"}\n */\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */,\n fontSize: '0.8em'\n },\n /**\n * The caption text of the chart.\n *\n * @sample {highcharts} highcharts/caption/text/\n * Custom caption\n */\n text: '',\n /**\n * The horizontal alignment of the caption. Can be one of \"left\",\n * \"center\" and \"right\".\n *\n * @type {Highcharts.AlignValue}\n */\n align: 'left',\n /**\n * The vertical alignment of the caption. Can be one of `\"top\"`,\n * `\"middle\"` and `\"bottom\"`. When middle, the caption behaves as\n * floating.\n *\n * @type {Highcharts.VerticalAlignValue}\n */\n verticalAlign: 'bottom'\n },\n /**\n * The plotOptions is a wrapper object for config objects for each series\n * type. The config objects for each series can also be overridden for\n * each series item as given in the series array.\n *\n * Configuration options for the series are given in three levels. Options\n * for all series in a chart are given in the [plotOptions.series](\n * #plotOptions.series) object. Then options for all series of a specific\n * type are given in the plotOptions of that type, for example\n * `plotOptions.line`. Next, options for one single series are given in\n * [the series array](#series).\n */\n plotOptions: {},\n /**\n * The legend is a box containing a symbol and name for each series\n * item or point item in the chart. Each series (or points in case\n * of pie charts) is represented by a symbol and its name in the legend.\n *\n * It is possible to override the symbol creator function and create\n * [custom legend symbols](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/studies/legend-custom-symbol/).\n *\n * @productdesc {highmaps}\n * A Highmaps legend by default contains one legend item per series, but if\n * a `colorAxis` is defined, the axis will be displayed in the legend.\n * Either as a gradient, or as multiple legend items for `dataClasses`.\n */\n legend: {\n /**\n * The background color of the legend.\n *\n * @see In styled mode, the legend background fill can be applied with\n * the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/backgroundcolor/\n * Yellowish background\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption legend.backgroundColor\n */\n /**\n * The width of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke width can be applied\n * with the `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/borderwidth/\n * 2px border width\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {number}\n * @default 0\n * @apioption legend.borderWidth\n */\n /**\n * Enable or disable the legend. There is also a series-specific option,\n * [showInLegend](#plotOptions.series.showInLegend), that can hide the\n * series from the legend. In some series types this is `false` by\n * default, so it must set to `true` in order to show the legend for the\n * series.\n *\n * @sample {highcharts} highcharts/legend/enabled-false/ Legend disabled\n * @sample {highstock} stock/legend/align/ Various legend options\n * @sample {highmaps} maps/legend/enabled-false/ Legend disabled\n *\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} false\n */\n enabled: true,\n /**\n * The horizontal alignment of the legend box within the chart area.\n * Valid values are `left`, `center` and `right`.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * @sample {highcharts} highcharts/legend/align/\n * Legend at the right of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 2.0\n */\n align: 'center',\n /**\n * If the [layout](legend.layout) is `horizontal` and the legend items\n * span over two lines or more, whether to align the items into vertical\n * columns. Setting this to `false` makes room for more items, but will\n * look more messy.\n *\n * @since 6.1.0\n */\n alignColumns: true,\n /**\n * A CSS class name to apply to the legend group.\n */\n className: 'highcharts-no-tooltip',\n /**\n * When the legend is floating, the plot area ignores it and is allowed\n * to be placed below it.\n *\n * @sample {highcharts} highcharts/legend/floating-false/\n * False by default\n * @sample {highcharts} highcharts/legend/floating-true/\n * True\n * @sample {highmaps} maps/legend/alignment/\n * Floating legend\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @apioption legend.floating\n */\n /**\n * The layout of the legend items. Can be one of `horizontal` or\n * `vertical` or `proximate`. When `proximate`, the legend items will be\n * placed as close as possible to the graphs they're representing,\n * except in inverted charts or when the legend position doesn't allow\n * it.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highcharts} highcharts/legend/layout-vertical/\n * Vertical\n * @sample highcharts/legend/layout-proximate\n * Labels proximate to the data\n * @sample {highstock} stock/legend/layout-horizontal/\n * Horizontal by default\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Vertical with data classes\n * @sample {highmaps} maps/legend/layout-vertical/\n * Vertical with color axis gradient\n *\n * @validvalue [\"horizontal\", \"vertical\", \"proximate\"]\n */\n layout: 'horizontal',\n /**\n * In a legend with horizontal layout, the itemDistance defines the\n * pixel distance between each item.\n *\n * @sample {highcharts} highcharts/legend/layout-horizontal/\n * 50px item distance\n * @sample {highstock} highcharts/legend/layout-horizontal/\n * 50px item distance\n *\n * @type {number}\n * @default {highcharts} 20\n * @default {highstock} 20\n * @default {highmaps} 8\n * @since 3.0.3\n * @apioption legend.itemDistance\n */\n /**\n * The pixel bottom margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @since 2.2.0\n */\n itemMarginBottom: 2,\n /**\n * The pixel top margin for each legend item.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @since 2.2.0\n */\n itemMarginTop: 2,\n /**\n * The width for each legend item. By default the items are laid out\n * successively. In a [horizontal layout](legend.layout), if the items\n * are laid out across two rows or more, they will be vertically aligned\n * depending on the [legend.alignColumns](legend.alignColumns) option.\n *\n * @sample {highcharts} highcharts/legend/itemwidth-default/\n * Undefined by default\n * @sample {highcharts} highcharts/legend/itemwidth-80/\n * 80 for aligned legend items\n *\n * @type {number}\n * @since 2.0\n * @apioption legend.itemWidth\n */\n /**\n * A [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for each legend label. Available variables relates to properties on\n * the series, or the point in case of pies.\n *\n * @type {string}\n * @default {name}\n * @since 1.3\n * @apioption legend.labelFormat\n */\n /* eslint-disable valid-jsdoc */\n /**\n * Callback function to format each of the series' labels. The `this`\n * keyword refers to the series object, or the point object in case of\n * pie charts. By default the series or point name is printed.\n *\n * @productdesc {highmaps}\n * In Highmaps the context can also be a data class in case of a\n * `colorAxis`.\n *\n * @sample {highcharts} highcharts/legend/labelformatter/\n * Add text\n * @sample {highmaps} maps/legend/labelformatter/\n * Data classes with label formatter\n *\n * @type {Highcharts.FormatterCallbackFunction}\n */\n labelFormatter: function () {\n /** eslint-enable valid-jsdoc */\n return this.name;\n },\n /**\n * Line height for the legend items. Deprecated as of 2.1\\. Instead,\n * the line height for each item can be set using\n * `itemStyle.lineHeight`, and the padding between items using\n * `itemMarginTop` and `itemMarginBottom`.\n *\n * @sample {highcharts} highcharts/legend/lineheight/\n * Setting padding\n *\n * @deprecated\n *\n * @type {number}\n * @default 16\n * @since 2.0\n * @product highcharts gantt\n * @apioption legend.lineHeight\n */\n /**\n * If the plot area sized is calculated automatically and the legend is\n * not floating, the legend margin is the space between the legend and\n * the axis labels or plot area.\n *\n * @sample {highcharts} highcharts/legend/margin-default/\n * 12 pixels by default\n * @sample {highcharts} highcharts/legend/margin-30/\n * 30 pixels\n *\n * @type {number}\n * @default 12\n * @since 2.1\n * @apioption legend.margin\n */\n /**\n * Maximum pixel height for the legend. When the maximum height is\n * extended, navigation will show.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption legend.maxHeight\n */\n /**\n * The color of the drawn border around the legend.\n *\n * @see In styled mode, the legend border stroke can be applied with the\n * `.highcharts-legend-box` class.\n *\n * @sample {highcharts} highcharts/legend/bordercolor/\n * Brown border\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The border corner radius of the legend.\n *\n * @sample {highcharts} highcharts/legend/borderradius-default/\n * Square by default\n * @sample {highcharts} highcharts/legend/borderradius-round/\n * 5px rounded\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n */\n borderRadius: 0,\n /**\n * Options for the paging or navigation appearing when the legend is\n * overflown. Navigation works well on screen, but not in static\n * exported images. One way of working around that is to\n * [increase the chart height in\n * export](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/legend/navigation-enabled-false/).\n */\n navigation: {\n /**\n * How to animate the pages when navigating up or down. A value of\n * `true` applies the default navigation given in the\n * `chart.animation` option. Additional options can be given as an\n * object containing values for easing and duration.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {boolean|Partial}\n * @default true\n * @since 2.2.4\n * @apioption legend.navigation.animation\n */\n /**\n * The pixel size of the up and down arrows in the legend paging\n * navigation.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {number}\n * @default 12\n * @since 2.2.4\n * @apioption legend.navigation.arrowSize\n */\n /**\n * Whether to enable the legend navigation. In most cases, disabling\n * the navigation results in an unwanted overflow.\n *\n * See also the\n * [adapt chart to legend](https://github.com/highcharts/adapt-chart-to-legend)\n * plugin for a solution to extend the chart height to make room for\n * the legend, optionally in exported charts only.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.4\n * @apioption legend.navigation.enabled\n */\n /**\n * Text styles for the legend page navigation.\n *\n * @see In styled mode, the navigation items are styled with the\n * `.highcharts-legend-navigation` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.CSSObject}\n * @since 2.2.4\n * @apioption legend.navigation.style\n */\n style: {\n fontSize: '0.8em'\n },\n /**\n * The color for the active up or down arrow in the legend page\n * navigation.\n *\n * @see In styled mode, the active arrow be styled with the\n * `.highcharts-legend-nav-active` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n activeColor: \"#0022ff\" /* Palette.highlightColor100 */,\n /**\n * The color of the inactive up or down arrow in the legend page\n * navigation. .\n *\n * @see In styled mode, the inactive arrow be styled with the\n * `.highcharts-legend-nav-inactive` class.\n *\n * @sample {highcharts} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n * @sample {highstock} highcharts/legend/navigation/\n * Legend page navigation demonstrated\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.4\n */\n inactiveColor: \"#cccccc\" /* Palette.neutralColor20 */\n },\n /**\n * The inner padding of the legend box.\n *\n * @sample {highcharts|highstock} highcharts/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n *\n * @type {number}\n * @default 8\n * @since 2.2.0\n * @apioption legend.padding\n */\n /**\n * Whether to reverse the order of the legend items compared to the\n * order of the series or points as defined in the configuration object.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks),\n * [series.legendIndex](#series.legendIndex)\n *\n * @sample {highcharts} highcharts/legend/reversed/\n * Stacked bar with reversed legend\n *\n * @type {boolean}\n * @default false\n * @since 1.2.5\n * @apioption legend.reversed\n */\n /**\n * Whether to show the symbol on the right side of the text rather than\n * the left side. This is common in Arabic and Hebrew.\n *\n * @sample {highcharts} highcharts/legend/rtl/\n * Symbol to the right\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption legend.rtl\n */\n /**\n * CSS styles for the legend area. In the 1.x versions the position\n * of the legend area was determined by CSS. In 2.x, the position is\n * determined by properties like `align`, `verticalAlign`, `x` and `y`,\n * but the styles are still parsed for backwards compatibility.\n *\n * @deprecated\n *\n * @type {Highcharts.CSSObject}\n * @product highcharts highstock\n * @apioption legend.style\n */\n /**\n * CSS styles for each legend item. Only a subset of CSS is supported,\n * notably those options related to text. The default `textOverflow`\n * property makes long texts truncate. Set it to `undefined` to wrap\n * text instead. A `width` property can be added to control the text\n * width.\n *\n * @see In styled mode, the legend items can be styled with the\n * `.highcharts-legend-item` class.\n *\n * @sample {highcharts} highcharts/legend/itemstyle/\n * Bold black text\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#333333\", \"cursor\": \"pointer\", \"fontSize\": \"0.75em\", \"fontWeight\": \"bold\", \"textOverflow\": \"ellipsis\"}\n */\n itemStyle: {\n /**\n * @ignore\n */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * @ignore\n */\n cursor: 'pointer',\n /**\n * @ignore\n */\n fontSize: '0.8em',\n /**\n * @ignore\n */\n textDecoration: 'none',\n /**\n * @ignore\n */\n textOverflow: 'ellipsis'\n },\n /**\n * CSS styles for each legend item in hover mode. Only a subset of\n * CSS is supported, notably those options related to text. Properties\n * are inherited from `style` unless overridden here.\n *\n * @see In styled mode, the hovered legend items can be styled with\n * the `.highcharts-legend-item:hover` pesudo-class.\n *\n * @sample {highcharts} highcharts/legend/itemhoverstyle/\n * Red on hover\n * @sample {highmaps} maps/legend/itemstyle/\n * Item text styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#000000\"}\n */\n itemHoverStyle: {\n /**\n * @ignore\n */\n color: \"#000000\" /* Palette.neutralColor100 */\n },\n /**\n * CSS styles for each legend item when the corresponding series or\n * point is hidden. Only a subset of CSS is supported, notably those\n * options related to text. Properties are inherited from `style`\n * unless overridden here.\n *\n * @see In styled mode, the hidden legend items can be styled with\n * the `.highcharts-legend-item-hidden` class.\n *\n * @sample {highcharts} highcharts/legend/itemhiddenstyle/\n * Darker gray color\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#cccccc\"}\n */\n itemHiddenStyle: {\n /**\n * @ignore\n */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /**\n * @ignore\n */\n textDecoration: 'line-through'\n },\n /**\n * Whether to apply a drop shadow to the legend. A `backgroundColor`\n * also needs to be applied for this to take effect. The shadow can be\n * an object configuration containing `color`, `offsetX`, `offsetY`,\n * `opacity` and `width`.\n *\n * @sample {highcharts} highcharts/legend/shadow/\n * White background and drop shadow\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/border-background/\n * Border and background options\n *\n * @type {boolean|Highcharts.CSSObject}\n */\n shadow: false,\n /**\n * Default styling for the checkbox next to a legend item when\n * `showCheckbox` is true.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"width\": \"13px\", \"height\": \"13px\", \"position\":\"absolute\"}\n */\n itemCheckboxStyle: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n width: '13px',\n /**\n * @ignore\n */\n height: '13px'\n },\n // itemWidth: undefined,\n /**\n * When this is true, the legend symbol width will be the same as\n * the symbol height, which in turn defaults to the font size of the\n * legend items.\n *\n * @since 5.0.0\n */\n squareSymbol: true,\n /**\n * The pixel height of the symbol for series types that use a rectangle\n * in the legend. Defaults to the font size of legend items.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a vertical color\n * axis, the height defaults to 200.\n *\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * No distance between data classes\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolHeight\n */\n /**\n * The border radius of the symbol for series types that use a rectangle\n * in the legend. Defaults to half the `symbolHeight`, effectively\n * creating a circle.\n *\n * For color axis scales, it defaults to 3.\n *\n * @sample {highcharts} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highstock} highcharts/legend/symbolradius/\n * Round symbols\n * @sample {highmaps} highcharts/legend/symbolradius/\n * Round symbols\n *\n * @type {number}\n * @since 3.0.8\n * @apioption legend.symbolRadius\n */\n /**\n * The pixel width of the legend item symbol. When the `squareSymbol`\n * option is set, this defaults to the `symbolHeight`, otherwise 16.\n *\n * @productdesc {highmaps}\n * In Highmaps, when the symbol is the gradient of a horizontal color\n * axis, the width defaults to 200.\n *\n * @sample {highcharts} highcharts/legend/symbolwidth/\n * Greater symbol width and padding\n * @sample {highmaps} maps/legend/padding-itemmargin/\n * Padding and item margins demonstrated\n * @sample {highmaps} maps/legend/layout-vertical-sized/\n * Sized vertical gradient\n *\n * @type {number}\n * @apioption legend.symbolWidth\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the legend item texts.\n *\n * Prior to 4.1.7, when using HTML, [legend.navigation](\n * #legend.navigation) was disabled.\n *\n * @type {boolean}\n * @default false\n * @apioption legend.useHTML\n */\n /**\n * For a color axis with data classes, how many decimals to render in\n * the legend. The default preserves the decimals of the range numbers.\n *\n * @type {number}\n * @default -1\n * @product highcharts highmaps\n * @apioption legend.valueDecimals\n */\n /**\n * For a color axis with data classes, a suffix for the range numbers in\n * the legend.\n *\n * @type {string}\n * @default ''\n * @product highcharts highmaps\n * @apioption legend.valueSuffix\n */\n /**\n * The width of the legend box. If a number is set, it translates to\n * pixels. Since v7.0.2 it allows setting a percent string of the full\n * chart width, for example `40%`.\n *\n * Defaults to the full chart width for legends below or above the\n * chart, half the chart width for legends to the left and right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n * @sample {highcharts} highcharts/legend/width-percent/\n * A percent of the chart width\n *\n * @type {number|string}\n * @since 2.0\n * @apioption legend.width\n */\n /**\n * The pixel padding between the legend item symbol and the legend\n * item text.\n *\n * @sample {highcharts} highcharts/legend/symbolpadding/\n * Greater symbol width and padding\n */\n symbolPadding: 5,\n /**\n * The vertical alignment of the legend box. Can be one of `top`,\n * `middle` or `bottom`. Vertical position can be further determined\n * by the `y` option.\n *\n * In the case that the legend is aligned in a corner position, the\n * `layout` option will determine whether to place it above/below\n * or on the side of the plot area.\n *\n * When the [layout](#legend.layout) option is `proximate`, the\n * `verticalAlign` option doesn't apply.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.0\n */\n verticalAlign: 'bottom',\n // width: undefined,\n /**\n * The x offset of the legend relative to its horizontal alignment\n * `align` within chart.spacingLeft and chart.spacingRight. Negative\n * x moves it to the left, positive x moves it to the right.\n *\n * @sample {highcharts} highcharts/legend/width/\n * Aligned to the plot area\n *\n * @since 2.0\n */\n x: 0,\n /**\n * The vertical offset of the legend relative to it's vertical alignment\n * `verticalAlign` within chart.spacingTop and chart.spacingBottom.\n * Negative y moves it up, positive y moves it down.\n *\n * @sample {highcharts} highcharts/legend/verticalalign/\n * Legend 100px from the top of the chart\n * @sample {highstock} stock/legend/align/\n * Various legend options\n * @sample {highmaps} maps/legend/alignment/\n * Legend alignment\n *\n * @since 2.0\n */\n y: 0,\n /**\n * A title to be added on top of the legend.\n *\n * @sample {highcharts} highcharts/legend/title/\n * Legend title\n * @sample {highmaps} maps/legend/alignment/\n * Legend with title\n *\n * @since 3.0\n */\n title: {\n /**\n * A text or HTML string for the title.\n *\n * @type {string}\n * @since 3.0\n * @apioption legend.title.text\n */\n /**\n * Generic CSS styles for the legend title.\n *\n * @see In styled mode, the legend title is styled with the\n * `.highcharts-legend-title` class.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontSize\": \"0.75em\", \"fontWeight\": \"bold\"}\n * @since 3.0\n */\n style: {\n /**\n * @ignore\n */\n fontSize: '0.8em',\n /**\n * @ignore\n */\n fontWeight: 'bold'\n }\n }\n },\n /**\n * The loading options control the appearance of the loading screen\n * that covers the plot area on chart operations. This screen only\n * appears after an explicit call to `chart.showLoading()`. It is a\n * utility for developers to communicate to the end user that something\n * is going on, for example while retrieving new data via an XHR connection.\n * The \"Loading...\" text itself is not part of this configuration\n * object, but part of the `lang` object.\n */\n loading: {\n /**\n * The duration in milliseconds of the fade out effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.hideDuration\n */\n /**\n * The duration in milliseconds of the fade in effect.\n *\n * @sample highcharts/loading/hideduration/\n * Fade in and out over a second\n *\n * @type {number}\n * @default 100\n * @since 1.2.0\n * @apioption loading.showDuration\n */\n /**\n * CSS styles for the loading label `span`.\n *\n * @see In styled mode, the loading label is styled with the\n * `.highcharts-loading-inner` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/labelstyle/\n * Vertically centered\n * @sample {highstock} stock/loading/general/\n * Label styles\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontWeight\": \"bold\", \"position\": \"relative\", \"top\": \"45%\"}\n * @since 1.2.0\n */\n labelStyle: {\n /**\n * @ignore\n */\n fontWeight: 'bold',\n /**\n * @ignore\n */\n position: 'relative',\n /**\n * @ignore\n */\n top: '45%'\n },\n /**\n * CSS styles for the loading screen that covers the plot area.\n *\n * In styled mode, the loading label is styled with the\n * `.highcharts-loading` class.\n *\n * @sample {highcharts|highmaps} highcharts/loading/style/\n * Gray plot area, white text\n * @sample {highstock} stock/loading/general/\n * Gray plot area, white text\n *\n * @type {Highcharts.CSSObject}\n * @default {\"position\": \"absolute\", \"backgroundColor\": \"#ffffff\", \"opacity\": 0.5, \"textAlign\": \"center\"}\n * @since 1.2.0\n */\n style: {\n /**\n * @ignore\n */\n position: 'absolute',\n /**\n * @ignore\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * @ignore\n */\n opacity: 0.5,\n /**\n * @ignore\n */\n textAlign: 'center'\n }\n },\n /**\n * Options for the tooltip that appears when the user hovers over a\n * series or point.\n *\n * @declare Highcharts.TooltipOptions\n */\n tooltip: {\n /**\n * The color of the tooltip border. When `undefined`, the border takes\n * the color of the corresponding series or point.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * Follow series by default\n * @sample {highcharts} highcharts/tooltip/bordercolor-black/\n * Black border\n * @sample {highstock} stock/tooltip/general/\n * Styled tooltip\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption tooltip.borderColor\n */\n /**\n * A CSS class name to apply to the tooltip's container div,\n * allowing unique CSS styling for each chart.\n *\n * @type {string}\n * @apioption tooltip.className\n */\n /**\n * Since 4.1, the crosshair definitions are moved to the Axis object\n * in order for a better separation from the tooltip. See\n * [xAxis.crosshair](#xAxis.crosshair).\n *\n * @sample {highcharts} highcharts/tooltip/crosshairs-x/\n * Enable a crosshair for the x value\n *\n * @deprecated\n *\n * @type {*}\n * @default true\n * @apioption tooltip.crosshairs\n */\n /**\n * Distance from point to tooltip in pixels.\n *\n * @type {number}\n * @default 16\n * @apioption tooltip.distance\n */\n /**\n * Whether the tooltip should follow the mouse as it moves across\n * columns, pie slices and other point types with an extent.\n * By default it behaves this way for pie, polygon, map, sankey\n * and wordcloud series by override in the `plotOptions`\n * for those series types.\n *\n * Does not apply if [split](#tooltip.split) is `true`.\n *\n * For touch moves to behave the same way, [followTouchMove](\n * #tooltip.followTouchMove) must be `true` also.\n *\n * @sample highcharts/tooltip/followpointer/\n * Tooltip follow pointer comparison\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @since 3.0\n * @apioption tooltip.followPointer\n */\n /**\n * Whether the tooltip should update as the finger moves on a touch\n * device. If this is `true` and [chart.panning](#chart.panning) is\n * set,`followTouchMove` will take over one-finger touches, so the user\n * needs to use two fingers for zooming and panning.\n *\n * Note the difference to [followPointer](#tooltip.followPointer) that\n * only defines the _position_ of the tooltip. If `followPointer` is\n * false in for example a column series, the tooltip will show above or\n * below the column, but as `followTouchMove` is true, the tooltip will\n * jump from column to column as the user swipes across the plot area.\n *\n * @type {boolean}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 3.0.1\n * @apioption tooltip.followTouchMove\n */\n /**\n * A [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the whole tooltip. When format strings are a requirement, it is\n * usually more convenient to use `headerFormat`, `pointFormat` and\n * `footerFormat`, but the `format` option allows combining them into\n * one setting.\n *\n * The context of the format string is the same as that of the\n * `formatter` callback.\n *\n * @sample {highcharts} highcharts/tooltip/format-shared/\n * Format for shared tooltip\n *\n * @type {string}\n * @default undefined\n * @since 11.1.0\n * @apioption tooltip.format\n */\n /**\n * Callback function to format the text of the tooltip from scratch. In\n * case of single or [shared](#tooltip.shared) tooltips, a string should\n * be returned. In case of [split](#tooltip.split) tooltips, it should\n * return an array where the first item is the header, and subsequent\n * items are mapped to the points. Return `false` to disable tooltip for\n * a specific point on series.\n *\n * A subset of HTML is supported. Unless `useHTML` is true, the HTML of\n * the tooltip is parsed and converted to SVG, therefore this isn't a\n * complete HTML renderer. The following HTML tags are supported: `b`,\n * `br`, `em`, `i`, `span`, `strong`. Spans can be styled with a `style`\n * attribute, but only text-related CSS, that is shared with SVG, is\n * handled.\n *\n * The available data in the formatter differ a bit depending on whether\n * the tooltip is shared or split, or belongs to a single point. In a\n * shared/split tooltip, all properties except `x`, which is common for\n * all points, are kept in an array, `this.points`.\n *\n * Available data are:\n *\n * - **this.percentage (not shared) /**\n * **this.points[i].percentage (shared)**:\n * Stacked series and pies only. The point's percentage of the total.\n *\n * - **this.point (not shared) / this.points[i].point (shared)**:\n * The point object. The point name, if defined, is available through\n * `this.point.name`.\n *\n * - **this.points**:\n * In a shared tooltip, this is an array containing all other\n * properties for each point.\n *\n * - **this.series (not shared) / this.points[i].series (shared)**:\n * The series object. The series name is available through\n * `this.series.name`.\n *\n * - **this.total (not shared) / this.points[i].total (shared)**:\n * Stacked series only. The total value at this point's x value.\n *\n * - **this.x**:\n * The x value. This property is the same regardless of the tooltip\n * being shared or not.\n *\n * - **this.y (not shared) / this.points[i].y (shared)**:\n * The y value.\n *\n * @sample {highcharts} highcharts/tooltip/formatter-simple/\n * Simple string formatting\n * @sample {highcharts} highcharts/tooltip/formatter-shared/\n * Formatting with shared tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Formatting with split tooltip\n * @sample highcharts/tooltip/formatter-conditional-default/\n * Extending default formatter\n * @sample {highstock} stock/tooltip/formatter/\n * Formatting with shared tooltip\n * @sample {highmaps} maps/tooltip/formatter/\n * String formatting\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.formatter\n */\n /**\n * Callback function to format the text of the tooltip for\n * visible null points.\n * Works analogously to [formatter](#tooltip.formatter).\n *\n * @sample highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {Highcharts.TooltipFormatterCallbackFunction}\n * @apioption tooltip.nullFormatter\n */\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (`false`), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area. For small charts, this may result in clipping\n * or overlapping. When `true`, a separate SVG element is created and\n * overlaid on the page, allowing the tooltip to be aligned inside the\n * page itself.\n *\n * Defaults to `true` if `chart.scrollablePlotArea` is activated,\n * otherwise `false`.\n *\n * @sample highcharts/tooltip/outside\n * Small charts with tooltips outside\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 6.1.1\n * @apioption tooltip.outside\n */\n /**\n * A callback function for formatting the HTML output for a single point\n * in the tooltip. Like the `pointFormat` string, but with more\n * flexibility.\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 4.1.0\n * @context Highcharts.Point\n * @apioption tooltip.pointFormatter\n */\n /**\n * A callback function to place the tooltip in a custom position. The\n * callback receives three parameters: `labelWidth`, `labelHeight` and\n * `point`, where point contains values for `plotX` and `plotY` telling\n * where the reference point is in the plot area. Add `chart.plotLeft`\n * and `chart.plotTop` to get the full coordinates.\n *\n * To find the actual hovered `Point` instance, use\n * `this.chart.hoverPoint`. For shared or split tooltips, all the hover\n * points are available in `this.chart.hoverPoints`.\n *\n * Since v7, when [tooltip.split](#tooltip.split) option is enabled,\n * positioner is called for each of the boxes separately, including\n * xAxis header. xAxis header is not a point, instead `point` argument\n * contains info: `{ plotX: Number, plotY: Number, isHeader: Boolean }`\n *\n * The return should be an object containing x and y values, for example\n * `{ x: 100, y: 100 }`.\n *\n * @sample {highcharts} highcharts/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/positioner/\n * A fixed tooltip position on top of the chart\n * @sample {highmaps} maps/tooltip/positioner/\n * A fixed tooltip position\n * @sample {highstock} stock/tooltip/split-positioner/\n * Split tooltip with fixed positions\n * @sample {highstock} stock/tooltip/positioner-scrollable-plotarea/\n * Scrollable plot area combined with tooltip positioner\n *\n * @type {Highcharts.TooltipPositionerCallbackFunction}\n * @since 2.2.4\n * @apioption tooltip.positioner\n */\n /**\n * Split the tooltip into one label per series, with the header close\n * to the axis. This is recommended over [shared](#tooltip.shared)\n * tooltips for charts with multiple line series, generally making them\n * easier to read. This option takes precedence over `tooltip.shared`.\n *\n * Not supported for [polar](#chart.polar) and [inverted](#chart.inverted) charts.\n *\n * @productdesc {highstock} In Highcharts Stock, tooltips are split\n * by default since v6.0.0. Stock charts typically contain\n * multi-dimension points and multiple panes, making split tooltips\n * the preferred layout over\n * the previous `shared` tooltip.\n *\n * @sample highcharts/tooltip/split/\n * Split tooltip\n * @sample {highcharts|highstock} highcharts/tooltip/formatter-split/\n * Split tooltip and custom formatter callback\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} true\n * @since 5.0.0\n * @product highcharts highstock\n * @apioption tooltip.split\n */\n /**\n * Prevents the tooltip from switching or closing, when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @type {boolean}\n * @since 8.0.1\n * @apioption tooltip.stickOnContact\n */\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @type {boolean}\n * @default false\n * @since 2.2\n * @apioption tooltip.useHTML\n */\n /**\n * How many decimals to show in each series' y value. This is\n * overridable in each series' tooltip options object. The default is to\n * preserve all decimals.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {number|undefined}\n * @since 2.2\n * @apioption tooltip.valueDecimals\n */\n /**\n * A string to prepend to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valuePrefix\n */\n /**\n * A string to append to each series' y value. Overridable in each\n * series' tooltip options object.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n * @sample {highmaps} maps/tooltip/valuedecimals/\n * Set decimals, prefix and suffix for the value\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.valueSuffix\n */\n /**\n * The format for the date in the tooltip header if the X axis is a\n * datetime axis. The default is a best guess based on the smallest\n * distance between points in the chart.\n *\n * @sample {highcharts} highcharts/tooltip/xdateformat/\n * A different format\n *\n * @type {string}\n * @product highcharts highstock gantt\n * @apioption tooltip.xDateFormat\n */\n /**\n * How many decimals to show for the `point.change`\n * or the `point.cumulativeSum` value when the `series.compare`\n * or the `series.cumulative` option is set.\n * This is overridable in each series' tooltip options object.\n *\n * @type {number}\n * @default 2\n * @since 1.0.1\n * @product highstock\n * @apioption tooltip.changeDecimals\n */\n /**\n * Enable or disable the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/enabled/\n * Disabled\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Disable tooltip and show values on chart instead\n */\n enabled: true,\n /**\n * Enable or disable animation of the tooltip.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n */\n animation: svg,\n /**\n * The radius of the rounded border corners.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * Default border radius\n * @sample {highcharts} highcharts/tooltip/borderradius-0/\n * Square borders\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n */\n borderRadius: 3,\n /**\n * For series on datetime axes, the date format in the tooltip's\n * header will by default be guessed based on the closest data points.\n * This member gives the default string representations used for\n * each unit. For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * @see [xAxis.dateTimeLabelFormats](#xAxis.dateTimeLabelFormats)\n *\n * @type {Highcharts.Dictionary}\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /** @internal */\n millisecond: '%A, %e %b, %H:%M:%S.%L',\n /** @internal */\n second: '%A, %e %b, %H:%M:%S',\n /** @internal */\n minute: '%A, %e %b, %H:%M',\n /** @internal */\n hour: '%A, %e %b, %H:%M',\n /** @internal */\n day: '%A, %e %b %Y',\n /** @internal */\n week: 'Week from %A, %e %b %Y',\n /** @internal */\n month: '%B %Y',\n /** @internal */\n year: '%Y'\n },\n /**\n * A string to append to the tooltip format.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @since 2.2\n */\n footerFormat: '',\n /**\n * The name of a symbol to use for the border around the tooltip\n * header. Applies only when [tooltip.split](#tooltip.split) is\n * enabled.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @see [tooltip.shape](#tooltip.shape)\n *\n * @sample {highstock} stock/tooltip/split-positioner/\n * Different shapes for header and split boxes\n *\n * @type {Highcharts.TooltipShapeValue}\n * @validvalue [\"callout\", \"square\"]\n * @since 7.0\n */\n headerShape: 'callout',\n /**\n * The number of milliseconds to wait until the tooltip is hidden when\n * mouse out from a point or chart.\n *\n * @since 3.0\n */\n hideDelay: 500,\n /**\n * Padding inside the tooltip, in pixels.\n *\n * @since 5.0.0\n */\n padding: 8,\n /**\n * The name of a symbol to use for the border around the tooltip. Can\n * be one of: `\"callout\"`, `\"circle\"` or `\"rect\"`. When\n * [tooltip.split](#tooltip.split)\n * option is enabled, shape is applied to all boxes except header, which\n * is controlled by\n * [tooltip.headerShape](#tooltip.headerShape).\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols` the same way as for\n * [series.marker.symbol](plotOptions.line.marker.symbol).\n *\n * @type {Highcharts.TooltipShapeValue}\n * @since 4.0\n */\n shape: 'callout',\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events. Tooltip texts for series types with ordered\n * data (not pie, scatter, flags etc) will be shown in a single bubble.\n * This is recommended for single series charts and for tablet/mobile\n * optimized charts.\n *\n * See also [tooltip.split](#tooltip.split), that is better suited for\n * charts with many series, especially line-type series. The\n * `tooltip.split` option takes precedence over `tooltip.shared`.\n *\n * @sample {highcharts} highcharts/tooltip/shared-false/\n * False by default\n * @sample {highcharts} highcharts/tooltip/shared-true/\n * True\n * @sample {highcharts} highcharts/tooltip/shared-x-crosshair/\n * True with x axis crosshair\n * @sample {highcharts} highcharts/tooltip/shared-true-mixed-types/\n * True with mixed series types\n *\n * @since 2.1\n * @product highcharts highstock\n */\n shared: false,\n /**\n * Proximity snap for graphs or single points. It defaults to 10 for\n * mouse-powered devices and 25 for touch devices.\n *\n * Note that in most cases the whole plot area captures the mouse\n * movement, and in these cases `tooltip.snap` doesn't make sense. This\n * applies when [stickyTracking](#plotOptions.series.stickyTracking)\n * is `true` (default) and when the tooltip is [shared](#tooltip.shared)\n * or [split](#tooltip.split).\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 10 px by default\n * @sample {highcharts} highcharts/tooltip/snap-50/\n * 50 px on graph\n *\n * @type {number}\n * @default 10/25\n * @since 1.2.0\n * @product highcharts highstock\n */\n snap: isTouchDevice ? 25 : 10,\n /**\n * The HTML of the tooltip header line. Variables are enclosed by\n * curly brackets. Available variables are `point.key`, `series.name`,\n * `series.color` and other members from the `point` and `series`\n * objects. The `point.key` variable contains the category name, x\n * value or datetime string depending on the type of axis. For datetime\n * axes, the `point.key` date format can be set using\n * `tooltip.xDateFormat`.\n *\n * @sample {highcharts} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highstock} highcharts/tooltip/footerformat/\n * An HTML table in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @apioption tooltip.headerFormat\n */\n headerFormat: '{point.key}
',\n /**\n * The HTML of the null point's line in the tooltip. Works analogously\n * to [pointFormat](#tooltip.pointFormat).\n *\n * @sample {highcharts} highcharts/plotoptions/series-nullformat\n * Format data label and tooltip for null point.\n *\n * @type {string}\n * @apioption tooltip.nullFormat\n */\n /**\n * The HTML of the point's line in the tooltip. Variables are enclosed\n * by curly brackets. Available variables are `point.x`, `point.y`,\n * `series.name` and `series.color` and other properties on the same\n * form. Furthermore, `point.y` can be extended by the\n * `tooltip.valuePrefix` and `tooltip.valueSuffix` variables. This can\n * also be overridden for each series, which makes it a good hook for\n * displaying units.\n *\n * In styled mode, the dot is colored by a class name rather\n * than the point color.\n *\n * @sample {highcharts} highcharts/tooltip/pointformat/\n * A different point format with value suffix\n * @sample {highcharts|highstock} highcharts/tooltip/pointformat-extra-information/\n * Show extra information about points in the tooltip\n * @sample {highmaps} maps/tooltip/format/\n * Format demo\n *\n * @type {string}\n * @since 2.2\n * @apioption tooltip.pointFormat\n */\n pointFormat: '\\u25CF {series.name}: {point.y}
',\n /**\n * The background color or gradient for the tooltip.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-solid/\n * Yellowish background\n * @sample {highcharts} highcharts/tooltip/backgroundcolor-gradient/\n * Gradient\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The pixel width of the tooltip border. Defaults to 0 for single\n * tooltips and 1 for split tooltips.\n *\n * In styled mode, the stroke width is set in the\n * `.highcharts-tooltip-box` class.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * 2 pixels\n * @sample {highcharts} highcharts/tooltip/borderwidth/\n * No border (shadow only)\n * @sample {highcharts} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highstock} stock/tooltip/general/\n * Custom tooltip\n * @sample {highstock} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n * @sample {highmaps} maps/tooltip/background-border/\n * Background and border demo\n * @sample {highmaps} highcharts/css/tooltip-border-background/\n * Tooltip in styled mode\n *\n * @type {number}\n */\n borderWidth: void 0,\n /**\n * Whether to apply a drop shadow to the tooltip.\n *\n * @sample {highcharts} highcharts/tooltip/bordercolor-default/\n * True by default\n * @sample {highcharts} highcharts/tooltip/shadow/\n * False\n * @sample {highmaps} maps/tooltip/positioner/\n * Fixed tooltip position, border and shadow disabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n */\n shadow: true,\n /**\n * Prevents the tooltip from switching or closing when touched or\n * pointed.\n *\n * @sample highcharts/tooltip/stickoncontact/\n * Tooltip sticks on pointer contact\n *\n * @since 8.0.1\n */\n stickOnContact: false,\n /**\n * CSS styles for the tooltip. The tooltip can also be styled through\n * the CSS class `.highcharts-tooltip`.\n *\n * Note that the default `pointerEvents` style makes the tooltip ignore\n * mouse events, so in order to use clickable tooltips, this value must\n * be set to `auto`.\n *\n * @sample {highcharts} highcharts/tooltip/style/\n * Greater padding, bold text\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '0.8em'\n },\n /**\n * Use HTML to render the contents of the tooltip instead of SVG. Using\n * HTML allows advanced formatting like tables and images in the\n * tooltip. It is also recommended for rtl languages as it works around\n * rtl bugs in early Firefox.\n *\n * @sample {highcharts|highstock} highcharts/tooltip/footerformat/\n * A table for value alignment\n * @sample {highcharts|highstock} highcharts/tooltip/fullhtml/\n * Full HTML tooltip\n * @sample {highmaps} maps/tooltip/usehtml/\n * Pure HTML tooltip\n *\n * @since 2.2\n */\n useHTML: false\n },\n /**\n * Highchart by default puts a credits label in the lower right corner\n * of the chart. This can be changed using these options.\n */\n credits: {\n /**\n * Credits for map source to be concatenated with conventional credit\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapTextFull](#credits.mapTextFull)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default \\u00a9 {geojson.copyrightShort}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapText\n */\n /**\n * Detailed credits for map source to be displayed on hover of credits\n * text. By default this is a format string that collects copyright\n * information from the map if available.\n *\n * @see [mapText](#credits.mapText)\n * @see [text](#credits.text)\n *\n * @type {string}\n * @default {geojson.copyright}\n * @since 4.2.2\n * @product highmaps\n * @apioption credits.mapTextFull\n */\n /**\n * Whether to show the credits text.\n *\n * @sample {highcharts} highcharts/credits/enabled-false/\n * Credits disabled\n * @sample {highstock} stock/credits/enabled/\n * Credits disabled\n * @sample {highmaps} maps/credits/enabled-false/\n * Credits disabled\n */\n enabled: true,\n /**\n * The URL for the credits label.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n href: 'https://www.highcharts.com?credits',\n /**\n * Position configuration for the credits label.\n *\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highcharts} highcharts/credits/position-left/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n * @sample {highmaps} maps/credits/customized/\n * Left aligned\n *\n * @type {Highcharts.AlignObject}\n * @since 2.1\n */\n position: {\n /** @internal */\n align: 'right',\n /** @internal */\n x: -10,\n /** @internal */\n verticalAlign: 'bottom',\n /** @internal */\n y: -5\n },\n /**\n * CSS styles for the credits label.\n *\n * @see In styled mode, credits styles can be set with the\n * `.highcharts-credits` class.\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n cursor: 'pointer',\n /** @internal */\n color: \"#999999\" /* Palette.neutralColor40 */,\n /** @internal */\n fontSize: '0.6em'\n },\n /**\n * The text for the credits label.\n *\n * @productdesc {highmaps}\n * If a map is loaded as GeoJSON, the text defaults to\n * `Highcharts @ {map-credits}`. Otherwise, it defaults to\n * `Highcharts.com`.\n *\n * @sample {highcharts} highcharts/credits/href/\n * Custom URL and text\n * @sample {highmaps} maps/credits/customized/\n * Custom URL and text\n */\n text: 'Highcharts.com'\n }\n };\n /* eslint-disable spaced-comment */\n\n defaultOptions.chart.styledMode = false;\n\n '';\n const defaultTime = new Time(defaultOptions.time);\n /**\n * Get the updated default options. Until 3.0.7, merely exposing defaultOptions\n * for outside modules wasn't enough because the setOptions method created a new\n * object.\n *\n * @function Highcharts.getOptions\n *\n * @return {Highcharts.Options}\n * Default options.\n */\n function getOptions() {\n return defaultOptions;\n }\n /**\n * Merge the default options with custom options and return the new options\n * structure. Commonly used for defining reusable templates.\n *\n * @sample highcharts/global/useutc-false Setting a global option\n * @sample highcharts/members/setoptions Applying a global theme\n *\n * @function Highcharts.setOptions\n *\n * @param {Highcharts.Options} options\n * The new custom chart options.\n *\n * @return {Highcharts.Options}\n * Updated options.\n */\n function setOptions(options) {\n // Copy in the default options\n merge(true, defaultOptions, options);\n // Update the time object\n if (options.time || options.global) {\n if (H.time) {\n H.time.update(merge(defaultOptions.global, defaultOptions.time, options.global, options.time));\n }\n else {\n /**\n * Global `Time` object with default options. Since v6.0.5, time\n * settings can be applied individually for each chart. If no\n * individual settings apply, this `Time` object is shared by all\n * instances.\n *\n * @name Highcharts.time\n * @type {Highcharts.Time}\n */\n H.time = defaultTime;\n }\n }\n return defaultOptions;\n }\n /* *\n *\n * Default Export\n *\n * */\n const DefaultOptions = {\n defaultOptions,\n defaultTime,\n getOptions,\n setOptions\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"plotBox\"|\"spacingBox\"} Highcharts.ButtonRelativeToValue\n */\n /**\n * Gets fired when a series is added to the chart after load time, using the\n * `addSeries` method. Returning `false` prevents the series from being added.\n *\n * @callback Highcharts.ChartAddSeriesCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.ChartAddSeriesEventObject} event\n * The event that occured.\n */\n /**\n * Contains common event information. Through the `options` property you can\n * access the series options that were passed to the `addSeries` method.\n *\n * @interface Highcharts.ChartAddSeriesEventObject\n */ /**\n * The series options that were passed to the `addSeries` method.\n * @name Highcharts.ChartAddSeriesEventObject#options\n * @type {Highcharts.SeriesOptionsType}\n */ /**\n * Prevents the default behaviour of the event.\n * @name Highcharts.ChartAddSeriesEventObject#preventDefault\n * @type {Function}\n */ /**\n * The event target.\n * @name Highcharts.ChartAddSeriesEventObject#target\n * @type {Highcharts.Chart}\n */ /**\n * The event type.\n * @name Highcharts.ChartAddSeriesEventObject#type\n * @type {\"addSeries\"}\n */\n /**\n * Gets fired when clicking on the plot background.\n *\n * @callback Highcharts.ChartClickCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.PointerEventObject} event\n * The event that occured.\n */\n /**\n * Contains an axes of the clicked spot.\n *\n * @interface Highcharts.ChartClickEventAxisObject\n */ /**\n * Axis at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value at the clicked spot.\n * @name Highcharts.ChartClickEventAxisObject#value\n * @type {number}\n */\n /**\n * Contains information about the clicked spot on the chart. Remember the unit\n * of a datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.ChartClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Information about the x-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#xAxis\n * @type {Array}\n */ /**\n * Information about the y-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#yAxis\n * @type {Array}\n */ /**\n * Information about the z-axis on the clicked spot.\n * @name Highcharts.ChartClickEventObject#zAxis\n * @type {Array|undefined}\n */\n /**\n * Gets fired when the chart is finished loading.\n *\n * @callback Highcharts.ChartLoadCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Fires when the chart is redrawn, either after a call to `chart.redraw()` or\n * after an axis, series or point is modified with the `redraw` option set to\n * `true`.\n *\n * @callback Highcharts.ChartRedrawCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired after initial load of the chart (directly after the `load` event),\n * and after each redraw (directly after the `redraw` event).\n *\n * @callback Highcharts.ChartRenderCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired when an area of the chart has been selected. The default action\n * for the selection event is to zoom the chart to the selected area. It can be\n * prevented by calling `event.preventDefault()` or return false.\n *\n * @callback Highcharts.ChartSelectionCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * The chart on which the event occured.\n *\n * @param {Highcharts.SelectEventObject} event\n * Event informations\n *\n * @return {boolean|undefined}\n * Return false to prevent the default action, usually zoom.\n */\n (''); // detach doclets above\n\n return DefaultOptions;\n });\n _registerModule(_modules, 'Core/Animation/Fx.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { win } = H;\n const { isNumber, objectEach } = U;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * An animator object used internally. One instance applies to one property\n * (attribute or style prop) on one element. Animation is always initiated\n * through {@link SVGElement#animate}.\n *\n * @example\n * let rect = renderer.rect(0, 0, 10, 10).add();\n * rect.animate({ width: 100 });\n *\n * @private\n * @class\n * @name Highcharts.Fx\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} elem\n * The element to animate.\n *\n * @param {Partial} options\n * Animation options.\n *\n * @param {string} prop\n * The single attribute or CSS property to animate.\n */\n class Fx {\n /* *\n *\n * Constructors\n *\n * */\n constructor(elem, options, prop) {\n this.pos = NaN;\n this.options = options;\n this.elem = elem;\n this.prop = prop;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the current step of a path definition on SVGElement.\n *\n * @function Highcharts.Fx#dSetter\n *\n */\n dSetter() {\n const paths = this.paths, start = paths && paths[0], end = paths && paths[1], now = this.now || 0;\n let path = [];\n // Land on the final path without adjustment points appended in the ends\n if (now === 1 || !start || !end) {\n path = this.toD || [];\n }\n else if (start.length === end.length && now < 1) {\n for (let i = 0; i < end.length; i++) {\n // Tween between the start segment and the end segment. Start\n // with a copy of the end segment and tween the appropriate\n // numerics\n const startSeg = start[i];\n const endSeg = end[i];\n const tweenSeg = [];\n for (let j = 0; j < endSeg.length; j++) {\n const startItem = startSeg[j];\n const endItem = endSeg[j];\n // Tween numbers\n if (isNumber(startItem) &&\n isNumber(endItem) &&\n // Arc boolean flags\n !(endSeg[0] === 'A' && (j === 4 || j === 5))) {\n tweenSeg[j] = startItem + now * (endItem - startItem);\n // Strings, take directly from the end segment\n }\n else {\n tweenSeg[j] = endItem;\n }\n }\n path.push(tweenSeg);\n }\n // If animation is finished or length not matching, land on right value\n }\n else {\n path = end;\n }\n this.elem.attr('d', path, void 0, true);\n }\n /**\n * Update the element with the current animation step.\n *\n * @function Highcharts.Fx#update\n *\n */\n update() {\n const elem = this.elem, prop = this.prop, // if destroyed, it is null\n now = this.now, step = this.options.step;\n // Animation setter defined from outside\n if (this[prop + 'Setter']) {\n this[prop + 'Setter']();\n // Other animations on SVGElement\n }\n else if (elem.attr) {\n if (elem.element) {\n elem.attr(prop, now, null, true);\n }\n // HTML styles, raw HTML content like container size\n }\n else {\n elem.style[prop] = now + this.unit;\n }\n if (step) {\n step.call(elem, now, this);\n }\n }\n /**\n * Run an animation.\n *\n * @function Highcharts.Fx#run\n *\n * @param {number} from\n * The current value, value to start from.\n *\n * @param {number} to\n * The end value, value to land on.\n *\n * @param {string} unit\n * The property unit, for example `px`.\n *\n */\n run(from, to, unit) {\n const self = this, options = self.options, timer = function (gotoEnd) {\n return timer.stopped ? false : self.step(gotoEnd);\n }, requestAnimationFrame = win.requestAnimationFrame ||\n function (step) {\n setTimeout(step, 13);\n }, step = function () {\n for (let i = 0; i < Fx.timers.length; i++) {\n if (!Fx.timers[i]()) {\n Fx.timers.splice(i--, 1);\n }\n }\n if (Fx.timers.length) {\n requestAnimationFrame(step);\n }\n };\n if (from === to && !this.elem['forceAnimate:' + this.prop]) {\n delete options.curAnim[this.prop];\n if (options.complete &&\n Object.keys(options.curAnim).length === 0) {\n options.complete.call(this.elem);\n }\n }\n else { // #7166\n this.startTime = +new Date();\n this.start = from;\n this.end = to;\n this.unit = unit;\n this.now = this.start;\n this.pos = 0;\n timer.elem = this.elem;\n timer.prop = this.prop;\n if (timer() && Fx.timers.push(timer) === 1) {\n requestAnimationFrame(step);\n }\n }\n }\n /**\n * Run a single step in the animation.\n *\n * @function Highcharts.Fx#step\n *\n * @param {boolean} [gotoEnd]\n * Whether to go to the endpoint of the animation after abort.\n *\n * @return {boolean}\n * Returns `true` if animation continues.\n */\n step(gotoEnd) {\n const t = +new Date(), options = this.options, elem = this.elem, complete = options.complete, duration = options.duration, curAnim = options.curAnim;\n let ret, done;\n if ((elem.attr) && !elem.element) { // #2616, element is destroyed\n ret = false;\n }\n else if (gotoEnd || t >= duration + this.startTime) {\n this.now = this.end;\n this.pos = 1;\n this.update();\n curAnim[this.prop] = true;\n done = true;\n objectEach(curAnim, function (val) {\n if (val !== true) {\n done = false;\n }\n });\n if (done && complete) {\n complete.call(elem);\n }\n ret = false;\n }\n else {\n this.pos = options.easing((t - this.startTime) / duration);\n this.now = this.start + ((this.end -\n this.start) * this.pos);\n this.update();\n ret = true;\n }\n return ret;\n }\n /**\n * Prepare start and end values so that the path can be animated one to one.\n *\n * @function Highcharts.Fx#initPath\n *\n * @param {Highcharts.SVGElement} elem\n * The SVGElement item.\n *\n * @param {Highcharts.SVGPathArray|undefined} fromD\n * Starting path definition.\n *\n * @param {Highcharts.SVGPathArray} toD\n * Ending path definition.\n *\n * @return {Array}\n * An array containing start and end paths in array form so that\n * they can be animated in parallel.\n */\n initPath(elem, fromD, toD) {\n const startX = elem.startX, endX = elem.endX, end = toD.slice(), // copy\n isArea = elem.isArea, positionFactor = isArea ? 2 : 1;\n let shift, fullLength, i, reverse, start = fromD && fromD.slice(); // copy\n if (!start) {\n return [end, end];\n }\n /**\n * If shifting points, prepend a dummy point to the end path.\n * @private\n */\n function prepend(arr, other) {\n while (arr.length < fullLength) {\n // Move to, line to or curve to?\n const moveSegment = arr[0], otherSegment = other[fullLength - arr.length];\n if (otherSegment && moveSegment[0] === 'M') {\n if (otherSegment[0] === 'C') {\n arr[0] = [\n 'C',\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2],\n moveSegment[1],\n moveSegment[2]\n ];\n }\n else {\n arr[0] = ['L', moveSegment[1], moveSegment[2]];\n }\n }\n // Prepend a copy of the first point\n arr.unshift(moveSegment);\n // For areas, the bottom path goes back again to the left, so we\n // need to append a copy of the last point.\n if (isArea) {\n const z = arr.pop();\n arr.push(arr[arr.length - 1], z); // append point and the Z\n }\n }\n }\n /**\n * Copy and append last point until the length matches the end length.\n * @private\n */\n function append(arr, other) {\n while (arr.length < fullLength) {\n // Pull out the slice that is going to be appended or inserted.\n // In a line graph, the positionFactor is 1, and the last point\n // is sliced out. In an area graph, the positionFactor is 2,\n // causing the middle two points to be sliced out, since an area\n // path starts at left, follows the upper path then turns and\n // follows the bottom back.\n const segmentToAdd = arr[Math.floor(arr.length / positionFactor) - 1].slice();\n // Disable the first control point of curve segments\n if (segmentToAdd[0] === 'C') {\n segmentToAdd[1] = segmentToAdd[5];\n segmentToAdd[2] = segmentToAdd[6];\n }\n if (!isArea) {\n arr.push(segmentToAdd);\n }\n else {\n const lowerSegmentToAdd = arr[Math.floor(arr.length / positionFactor)].slice();\n arr.splice(arr.length / 2, 0, segmentToAdd, lowerSegmentToAdd);\n }\n }\n }\n // For sideways animation, find out how much we need to shift to get the\n // start path Xs to match the end path Xs.\n if (startX && endX && endX.length) {\n for (i = 0; i < startX.length; i++) {\n // Moving left, new points coming in on right\n if (startX[i] === endX[0]) {\n shift = i;\n break;\n // Moving right\n }\n else if (startX[0] ===\n endX[endX.length - startX.length + i]) {\n shift = i;\n reverse = true;\n break;\n // Fixed from the right side, \"scaling\" left\n }\n else if (startX[startX.length - 1] ===\n endX[endX.length - startX.length + i]) {\n shift = startX.length - i;\n break;\n }\n }\n if (typeof shift === 'undefined') {\n start = [];\n }\n }\n if (start.length && isNumber(shift)) {\n // The common target length for the start and end array, where both\n // arrays are padded in opposite ends\n fullLength = end.length + shift * positionFactor;\n if (!reverse) {\n prepend(end, start);\n append(start, end);\n }\n else {\n prepend(start, end);\n append(end, start);\n }\n }\n return [start, end];\n }\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#fillSetter\n *\n */\n fillSetter() {\n Fx.prototype.strokeSetter.apply(this, arguments);\n }\n /**\n * Handle animation of the color attributes directly.\n *\n * @function Highcharts.Fx#strokeSetter\n *\n */\n strokeSetter() {\n this.elem.attr(this.prop, color(this.start).tweenTo(color(this.end), this.pos), void 0, true);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Fx.timers = [];\n /* *\n *\n * Default Export\n *\n * */\n\n return Fx;\n });\n _registerModule(_modules, 'Core/Animation/AnimationUtilities.js', [_modules['Core/Animation/Fx.js'], _modules['Core/Utilities.js']], function (Fx, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, getStyle, isArray, isNumber, isObject, merge, objectEach, pick } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the global animation to either a given value, or fall back to the given\n * chart's animation option.\n *\n * @function Highcharts.setAnimation\n *\n * @param {boolean|Partial|undefined} animation\n * The animation object.\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @todo\n * This function always relates to a chart, and sets a property on the renderer,\n * so it should be moved to the SVGRenderer.\n */\n function setAnimation(animation, chart) {\n chart.renderer.globalAnimation = pick(animation, chart.options.chart.animation, true);\n }\n /**\n * Get the animation in object form, where a disabled animation is always\n * returned as `{ duration: 0 }`.\n *\n * @function Highcharts.animObject\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} [animation=0]\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @return {Highcharts.AnimationOptionsObject}\n * An object with at least a duration property.\n */\n function animObject(animation) {\n return isObject(animation) ?\n merge({ duration: 500, defer: 0 }, animation) :\n { duration: animation ? 500 : 0, defer: 0 };\n }\n /**\n * Get the defer as a number value from series animation options.\n *\n * @function Highcharts.getDeferredAnimation\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {boolean|Highcharts.AnimationOptionsObject} animation\n * An animation setting. Can be an object with duration, complete and\n * easing properties, or a boolean to enable or disable.\n *\n * @param {Highcharts.Series} [series]\n * Series to defer animation.\n *\n * @return {number}\n * The numeric value.\n */\n function getDeferredAnimation(chart, animation, series) {\n const labelAnimation = animObject(animation), s = series ? [series] : chart.series;\n let defer = 0, duration = 0;\n s.forEach((series) => {\n const seriesAnim = animObject(series.options.animation);\n defer = animation && defined(animation.defer) ?\n labelAnimation.defer :\n Math.max(defer, seriesAnim.duration + seriesAnim.defer);\n duration = Math.min(labelAnimation.duration, seriesAnim.duration);\n });\n // Disable defer for exporting\n if (chart.renderer.forExport) {\n defer = 0;\n }\n const anim = {\n defer: Math.max(0, defer - duration),\n duration: Math.min(defer, duration)\n };\n return anim;\n }\n /**\n * The global animate method, which uses Fx to create individual animators.\n *\n * @function Highcharts.animate\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGElement} el\n * The element to animate.\n *\n * @param {Highcharts.CSSObject|Highcharts.SVGAttributes} params\n * An object containing key-value pairs of the properties to animate.\n * Supports numeric as pixel-based CSS properties for HTML objects and\n * attributes for SVGElements.\n *\n * @param {Partial} [opt]\n * Animation options.\n *\n * @return {void}\n */\n function animate(el, params, opt) {\n let start, unit = '', end, fx, args;\n if (!isObject(opt)) { // Number or undefined/null\n args = arguments;\n opt = {\n duration: args[2],\n easing: args[3],\n complete: args[4]\n };\n }\n if (!isNumber(opt.duration)) {\n opt.duration = 400;\n }\n opt.easing = typeof opt.easing === 'function' ?\n opt.easing :\n (Math[opt.easing] || Math.easeInOutSine);\n opt.curAnim = merge(params);\n objectEach(params, function (val, prop) {\n // Stop current running animation of this property\n stop(el, prop);\n fx = new Fx(el, opt, prop);\n end = void 0;\n if (prop === 'd' && isArray(params.d)) {\n fx.paths = fx.initPath(el, el.pathArray, params.d);\n fx.toD = params.d;\n start = 0;\n end = 1;\n }\n else if (el.attr) {\n start = el.attr(prop);\n }\n else {\n start = parseFloat(getStyle(el, prop)) || 0;\n if (prop !== 'opacity') {\n unit = 'px';\n }\n }\n if (!end) {\n end = val;\n }\n if (typeof end === 'string' && end.match('px')) {\n end = end.replace(/px/g, ''); // #4351\n }\n fx.run(start, end, unit);\n });\n }\n /**\n * Stop running animation.\n *\n * @function Highcharts.stop\n *\n * @param {Highcharts.SVGElement} el\n * The SVGElement to stop animation on.\n *\n * @param {string} [prop]\n * The property to stop animating. If given, the stop method will stop a\n * single property from animating, while others continue.\n *\n * @return {void}\n *\n * @todo\n * A possible extension to this would be to stop a single property, when\n * we want to continue animating others. Then assign the prop to the timer\n * in the Fx.run method, and check for the prop here. This would be an\n * improvement in all cases where we stop the animation from .attr. Instead of\n * stopping everything, we can just stop the actual attributes we're setting.\n */\n function stop(el, prop) {\n let i = Fx.timers.length;\n // Remove timers related to this element (#4519)\n while (i--) {\n if (Fx.timers[i].elem === el && (!prop || prop === Fx.timers[i].prop)) {\n Fx.timers[i].stopped = true; // #4667\n }\n }\n }\n const animationExports = {\n animate,\n animObject,\n getDeferredAnimation,\n setAnimation,\n stop\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return animationExports;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/AST.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { SVG_NS, win } = H;\n const { attr, createElement, css, error, isFunction, isString, objectEach, splat } = U;\n const { trustedTypes } = win;\n /* *\n *\n * Constants\n *\n * */\n // Create the trusted type policy. This should not be exposed.\n const trustedTypesPolicy = (trustedTypes &&\n isFunction(trustedTypes.createPolicy) &&\n trustedTypes.createPolicy('highcharts', {\n createHTML: (s) => s\n }));\n const emptyHTML = trustedTypesPolicy ?\n trustedTypesPolicy.createHTML('') :\n '';\n // IE9 and PhantomJS are only able to parse XML.\n const hasValidDOMParser = (function () {\n try {\n return Boolean(new DOMParser().parseFromString(emptyHTML, 'text/html'));\n }\n catch (e) {\n return false;\n }\n }());\n /* *\n *\n * Class\n *\n * */\n /**\n * The AST class represents an abstract syntax tree of HTML or SVG content. It\n * can take HTML as an argument, parse it, optionally transform it to SVG, then\n * perform sanitation before inserting it into the DOM.\n *\n * @class\n * @name Highcharts.AST\n *\n * @param {string|Array} source\n * Either an HTML string or an ASTNode list to populate the tree.\n */\n class AST {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Filter an object of SVG or HTML attributes against the allow list.\n *\n * @static\n *\n * @function Highcharts.AST#filterUserAttributes\n *\n * @param {Highcharts.SVGAttributes} attributes The attributes to filter\n *\n * @return {Highcharts.SVGAttributes}\n * The filtered attributes\n */\n static filterUserAttributes(attributes) {\n objectEach(attributes, (val, key) => {\n let valid = true;\n if (AST.allowedAttributes.indexOf(key) === -1) {\n valid = false;\n }\n if (['background', 'dynsrc', 'href', 'lowsrc', 'src']\n .indexOf(key) !== -1) {\n valid = isString(val) && AST.allowedReferences.some((ref) => val.indexOf(ref) === 0);\n }\n if (!valid) {\n error(33, false, void 0, {\n 'Invalid attribute in config': `${key}`\n });\n delete attributes[key];\n }\n // #17753, < is not allowed in SVG attributes\n if (isString(val) && attributes[key]) {\n attributes[key] = val.replace(/ {\n const pair = line.split(':').map((s) => s.trim()), key = pair.shift();\n if (key && pair.length) {\n styles[key.replace(/-([a-z])/g, (g) => g[1].toUpperCase())] = pair.join(':'); // #17146\n }\n return styles;\n }, {});\n }\n /**\n * Utility function to set html content for an element by passing in a\n * markup string. The markup is safely parsed by the AST class to avoid\n * XSS vulnerabilities. This function should be used instead of setting\n * `innerHTML` in all cases where the content is not fully trusted.\n *\n * @static\n * @function Highcharts.AST#setElementHTML\n *\n * @param {SVGDOMElement|HTMLDOMElement} el\n * Node to set content of.\n *\n * @param {string} html\n * Markup string\n */\n static setElementHTML(el, html) {\n el.innerHTML = AST.emptyHTML; // Clear previous\n if (html) {\n const ast = new AST(html);\n ast.addToDOM(el);\n }\n }\n /* *\n *\n * Constructor\n *\n * */\n // Construct an AST from HTML markup, or wrap an array of existing AST nodes\n constructor(source) {\n this.nodes = typeof source === 'string' ?\n this.parseMarkup(source) : source;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add the tree defined as a hierarchical JS structure to the DOM\n *\n * @function Highcharts.AST#addToDOM\n *\n * @param {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement} parent\n * The node where it should be added\n *\n * @return {Highcharts.HTMLDOMElement|Highcharts.SVGDOMElement}\n * The inserted node.\n */\n addToDOM(parent) {\n /**\n * @private\n * @param {Highcharts.ASTNode} subtree\n * HTML/SVG definition\n * @param {Element} [subParent]\n * parent node\n * @return {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n * The inserted node.\n */\n function recurse(subtree, subParent) {\n let ret;\n splat(subtree).forEach(function (item) {\n const tagName = item.tagName;\n const textNode = item.textContent ?\n H.doc.createTextNode(item.textContent) :\n void 0;\n // Whether to ignore the AST filtering totally, #15345\n const bypassHTMLFiltering = AST.bypassHTMLFiltering;\n let node;\n if (tagName) {\n if (tagName === '#text') {\n node = textNode;\n }\n else if (AST.allowedTags.indexOf(tagName) !== -1 ||\n bypassHTMLFiltering) {\n const NS = tagName === 'svg' ?\n SVG_NS :\n (subParent.namespaceURI || SVG_NS);\n const element = H.doc.createElementNS(NS, tagName);\n const attributes = item.attributes || {};\n // Apply attributes from root of AST node, legacy from\n // from before TextBuilder\n objectEach(item, function (val, key) {\n if (key !== 'tagName' &&\n key !== 'attributes' &&\n key !== 'children' &&\n key !== 'style' &&\n key !== 'textContent') {\n attributes[key] = val;\n }\n });\n attr(element, bypassHTMLFiltering ?\n attributes :\n AST.filterUserAttributes(attributes));\n if (item.style) {\n css(element, item.style);\n }\n // Add text content\n if (textNode) {\n element.appendChild(textNode);\n }\n // Recurse\n recurse(item.children || [], element);\n node = element;\n }\n else {\n error(33, false, void 0, {\n 'Invalid tagName in config': tagName\n });\n }\n }\n // Add to the tree\n if (node) {\n subParent.appendChild(node);\n }\n ret = node;\n });\n // Return last node added (on top level it's the only one)\n return ret;\n }\n return recurse(this.nodes, parent);\n }\n /**\n * Parse HTML/SVG markup into AST Node objects. Used internally from the\n * constructor.\n *\n * @private\n *\n * @function Highcharts.AST#getNodesFromMarkup\n *\n * @param {string} markup The markup string.\n *\n * @return {Array} The parsed nodes.\n */\n parseMarkup(markup) {\n const nodes = [];\n markup = markup\n .trim()\n // The style attribute throws a warning when parsing when CSP is\n // enabled (#6884), so use an alias and pick it up below\n // Make all quotation marks parse correctly to DOM (#17627)\n .replace(/ style=([\"'])/g, ' data-style=$1');\n let doc;\n if (hasValidDOMParser) {\n doc = new DOMParser().parseFromString(trustedTypesPolicy ?\n trustedTypesPolicy.createHTML(markup) :\n markup, 'text/html');\n }\n else {\n const body = createElement('div');\n body.innerHTML = markup;\n doc = { body };\n }\n const appendChildNodes = (node, addTo) => {\n const tagName = node.nodeName.toLowerCase();\n // Add allowed tags\n const astNode = {\n tagName\n };\n if (tagName === '#text') {\n astNode.textContent = node.textContent || '';\n }\n const parsedAttributes = node.attributes;\n // Add attributes\n if (parsedAttributes) {\n const attributes = {};\n [].forEach.call(parsedAttributes, (attrib) => {\n if (attrib.name === 'data-style') {\n astNode.style = AST.parseStyle(attrib.value);\n }\n else {\n attributes[attrib.name] = attrib.value;\n }\n });\n astNode.attributes = attributes;\n }\n // Handle children\n if (node.childNodes.length) {\n const children = [];\n [].forEach.call(node.childNodes, (childNode) => {\n appendChildNodes(childNode, children);\n });\n if (children.length) {\n astNode.children = children;\n }\n }\n addTo.push(astNode);\n };\n [].forEach.call(doc.body.childNodes, (childNode) => appendChildNodes(childNode, nodes));\n return nodes;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * The list of allowed SVG or HTML attributes, used for sanitizing\n * potentially harmful content from the chart configuration before adding to\n * the DOM.\n *\n * @see [Source code with default values](\n * https://github.com/highcharts/highcharts/blob/master/ts/Core/Renderer/HTML/AST.ts#:~:text=public%20static%20allowedAttributes)\n *\n * @example\n * // Allow a custom, trusted attribute\n * Highcharts.AST.allowedAttributes.push('data-value');\n *\n * @name Highcharts.AST.allowedAttributes\n * @type {Array}\n */\n AST.allowedAttributes = [\n 'alt',\n 'aria-controls',\n 'aria-describedby',\n 'aria-expanded',\n 'aria-haspopup',\n 'aria-hidden',\n 'aria-label',\n 'aria-labelledby',\n 'aria-live',\n 'aria-pressed',\n 'aria-readonly',\n 'aria-roledescription',\n 'aria-selected',\n 'class',\n 'clip-path',\n 'color',\n 'colspan',\n 'cx',\n 'cy',\n 'd',\n 'dx',\n 'dy',\n 'disabled',\n 'fill',\n 'flood-color',\n 'flood-opacity',\n 'height',\n 'href',\n 'id',\n 'in',\n 'markerHeight',\n 'markerWidth',\n 'offset',\n 'opacity',\n 'orient',\n 'padding',\n 'paddingLeft',\n 'paddingRight',\n 'patternUnits',\n 'r',\n 'refX',\n 'refY',\n 'role',\n 'scope',\n 'slope',\n 'src',\n 'startOffset',\n 'stdDeviation',\n 'stroke',\n 'stroke-linecap',\n 'stroke-width',\n 'style',\n 'tableValues',\n 'result',\n 'rowspan',\n 'summary',\n 'target',\n 'tabindex',\n 'text-align',\n 'text-anchor',\n 'textAnchor',\n 'textLength',\n 'title',\n 'type',\n 'valign',\n 'width',\n 'x',\n 'x1',\n 'x2',\n 'xlink:href',\n 'y',\n 'y1',\n 'y2',\n 'zIndex'\n ];\n /**\n * The list of allowed references for referring attributes like `href` and\n * `src`. Attribute values will only be allowed if they start with one of\n * these strings.\n *\n * @see [Source code with default values](\n * https://github.com/highcharts/highcharts/blob/master/ts/Core/Renderer/HTML/AST.ts#:~:text=public%20static%20allowedReferences)\n *\n * @example\n * // Allow tel:\n * Highcharts.AST.allowedReferences.push('tel:');\n *\n * @name Highcharts.AST.allowedReferences\n * @type {Array}\n */\n AST.allowedReferences = [\n 'https://',\n 'http://',\n 'mailto:',\n '/',\n '../',\n './',\n '#'\n ];\n /**\n * The list of allowed SVG or HTML tags, used for sanitizing potentially\n * harmful content from the chart configuration before adding to the DOM.\n *\n * @see [Source code with default values](\n * https://github.com/highcharts/highcharts/blob/master/ts/Core/Renderer/HTML/AST.ts#:~:text=public%20static%20allowedTags)\n *\n * @example\n * // Allow a custom, trusted tag\n * Highcharts.AST.allowedTags.push('blink'); // ;)\n *\n * @name Highcharts.AST.allowedTags\n * @type {Array}\n */\n AST.allowedTags = [\n 'a',\n 'abbr',\n 'b',\n 'br',\n 'button',\n 'caption',\n 'circle',\n 'clipPath',\n 'code',\n 'dd',\n 'defs',\n 'div',\n 'dl',\n 'dt',\n 'em',\n 'feComponentTransfer',\n 'feDropShadow',\n 'feFuncA',\n 'feFuncB',\n 'feFuncG',\n 'feFuncR',\n 'feGaussianBlur',\n 'feOffset',\n 'feMerge',\n 'feMergeNode',\n 'filter',\n 'h1',\n 'h2',\n 'h3',\n 'h4',\n 'h5',\n 'h6',\n 'hr',\n 'i',\n 'img',\n 'li',\n 'linearGradient',\n 'marker',\n 'ol',\n 'p',\n 'path',\n 'pattern',\n 'pre',\n 'rect',\n 'small',\n 'span',\n 'stop',\n 'strong',\n 'style',\n 'sub',\n 'sup',\n 'svg',\n 'table',\n 'text',\n 'textPath',\n 'thead',\n 'title',\n 'tbody',\n 'tspan',\n 'td',\n 'th',\n 'tr',\n 'u',\n 'ul',\n '#text'\n ];\n AST.emptyHTML = emptyHTML;\n /**\n * Allow all custom SVG and HTML attributes, references and tags (together\n * with potentially harmful ones) to be added to the DOM from the chart\n * configuration. In other words, disable the the allow-listing which is the\n * primary functionality of the AST.\n *\n * WARNING: Setting this property to `true` while allowing untrusted user\n * data in the chart configuration will expose your application to XSS\n * security risks!\n *\n * Note that in case you want to allow a known set of tags or attributes,\n * you should allow-list them instead of disabling the filtering totally.\n * See [allowedAttributes](Highcharts.AST#.allowedAttributes),\n * [allowedReferences](Highcharts.AST#.allowedReferences) and\n * [allowedTags](Highcharts.AST#.allowedTags). The `bypassHTMLFiltering`\n * setting is intended only for those cases where allow-listing is not\n * practical, and the chart configuration already comes from a secure\n * source.\n *\n * @example\n * // Allow all custom attributes, references and tags (disable DOM XSS\n * // filtering)\n * Highcharts.AST.bypassHTMLFiltering = true;\n *\n * @name Highcharts.AST.bypassHTMLFiltering\n * @static\n */\n AST.bypassHTMLFiltering = false;\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Serialized form of an SVG/HTML definition, including children.\n *\n * @interface Highcharts.ASTNode\n */ /**\n * @name Highcharts.ASTNode#attributes\n * @type {Highcharts.SVGAttributes|undefined}\n */ /**\n * @name Highcharts.ASTNode#children\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.ASTNode#tagName\n * @type {string|undefined}\n */ /**\n * @name Highcharts.ASTNode#textContent\n * @type {string|undefined}\n */\n (''); // keeps doclets above in file\n\n return AST;\n });\n _registerModule(_modules, 'Core/Templating.js', [_modules['Core/Defaults.js'], _modules['Core/Utilities.js']], function (D, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions, defaultTime } = D;\n const { extend, getNestedProperty, isArray, isNumber, isObject, isString, pick, pInt } = U;\n const helpers = {\n // Built-in helpers\n add: (a, b) => a + b,\n divide: (a, b) => (b !== 0 ? a / b : ''),\n // eslint-disable-next-line eqeqeq\n eq: (a, b) => a == b,\n each: function (arr) {\n const match = arguments[arguments.length - 1];\n return isArray(arr) ?\n arr.map((item, i) => format(match.body, extend(isObject(item) ? item : { '@this': item }, {\n '@index': i,\n '@first': i === 0,\n '@last': i === arr.length - 1\n }))).join('') :\n false;\n },\n ge: (a, b) => a >= b,\n gt: (a, b) => a > b,\n 'if': (condition) => !!condition,\n le: (a, b) => a <= b,\n lt: (a, b) => a < b,\n multiply: (a, b) => a * b,\n // eslint-disable-next-line eqeqeq\n ne: (a, b) => a != b,\n subtract: (a, b) => a - b,\n unless: (condition) => !condition\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Formats a JavaScript date timestamp (milliseconds since Jan 1st 1970) into a\n * human readable date string. The format is a subset of the formats for PHP's\n * [strftime](https://www.php.net/manual/en/function.strftime.php) function.\n * Additional formats can be given in the {@link Highcharts.dateFormats} hook.\n *\n * Since v6.0.5, all internal dates are formatted through the\n * {@link Highcharts.Chart#time} instance to respect chart-level time settings.\n * The `Highcharts.dateFormat` function only reflects global time settings set\n * with `setOptions`.\n *\n * Supported format keys:\n * - `%a`: Short weekday, like 'Mon'\n * - `%A`: Long weekday, like 'Monday'\n * - `%d`: Two digit day of the month, 01 to 31\n * - `%e`: Day of the month, 1 through 31\n * - `%w`: Day of the week, 0 through 6\n * - `%b`: Short month, like 'Jan'\n * - `%B`: Long month, like 'January'\n * - `%m`: Two digit month number, 01 through 12\n * - `%y`: Two digits year, like 09 for 2009\n * - `%Y`: Four digits year, like 2009\n * - `%H`: Two digits hours in 24h format, 00 through 23\n * - `%k`: Hours in 24h format, 0 through 23\n * - `%I`: Two digits hours in 12h format, 00 through 11\n * - `%l`: Hours in 12h format, 1 through 12\n * - `%M`: Two digits minutes, 00 through 59\n * - `%p`: Upper case AM or PM\n * - `%P`: Lower case AM or PM\n * - `%S`: Two digits seconds, 00 through 59\n * - `%L`: Milliseconds (naming from Ruby)\n *\n * @function Highcharts.dateFormat\n *\n * @param {string} format\n * The desired format where various time representations are prefixed\n * with `%`.\n *\n * @param {number} timestamp\n * The JavaScript timestamp.\n *\n * @param {boolean} [capitalize=false]\n * Upper case first letter in the return.\n *\n * @return {string}\n * The formatted date.\n */\n function dateFormat(format, timestamp, capitalize) {\n return defaultTime.dateFormat(format, timestamp, capitalize);\n }\n /**\n * Format a string according to a subset of the rules of Python's String.format\n * method.\n *\n * @example\n * let s = Highcharts.format(\n * 'The {color} fox was {len:.2f} feet long',\n * { color: 'red', len: Math.PI }\n * );\n * // => The red fox was 3.14 feet long\n *\n * @function Highcharts.format\n *\n * @param {string} str\n * The string to format.\n *\n * @param {Record} ctx\n * The context, a collection of key-value pairs where each key is\n * replaced by its value.\n *\n * @param {Highcharts.Chart} [chart]\n * A `Chart` instance used to get numberFormatter and time.\n *\n * @return {string}\n * The formatted string.\n */\n function format(str = '', ctx, chart) {\n const regex = /\\{([a-zA-Z0-9\\:\\.\\,;\\-\\/<>%_@\"'= #\\(\\)]+)\\}/g, \n // The sub expression regex is the same as the top expression regex,\n // but except parens and block helpers (#), and surrounded by parens\n // instead of curly brackets.\n subRegex = /\\(([a-zA-Z0-9\\:\\.\\,;\\-\\/<>%_@\"'= ]+)\\)/g, matches = [], floatRegex = /f$/, decRegex = /\\.([0-9])/, lang = defaultOptions.lang, time = chart && chart.time || defaultTime, numberFormatter = chart && chart.numberFormatter || numberFormat;\n /*\n * Get a literal or variable value inside a template expression. May be\n * extended with other types like string or null if needed, but keep it\n * small for now.\n */\n const resolveProperty = (key = '') => {\n let n;\n // Literals\n if (key === 'true') {\n return true;\n }\n if (key === 'false') {\n return false;\n }\n if ((n = Number(key)).toString() === key) {\n return n;\n }\n // Variables and constants\n return getNestedProperty(key, ctx);\n };\n let match, currentMatch, depth = 0, hasSub;\n // Parse and create tree\n while ((match = regex.exec(str)) !== null) {\n // When a sub expression is found, it is evaluated first, and the\n // results recursively evaluated until no subexpression exists.\n const subMatch = subRegex.exec(match[1]);\n if (subMatch) {\n match = subMatch;\n hasSub = true;\n }\n if (!currentMatch || !currentMatch.isBlock) {\n currentMatch = {\n ctx,\n expression: match[1],\n find: match[0],\n isBlock: match[1].charAt(0) === '#',\n start: match.index,\n startInner: match.index + match[0].length,\n length: match[0].length\n };\n }\n // Identify helpers\n const fn = match[1].split(' ')[0].replace('#', '');\n if (helpers[fn]) {\n // Block helper, only 0 level is handled\n if (currentMatch.isBlock && fn === currentMatch.fn) {\n depth++;\n }\n if (!currentMatch.fn) {\n currentMatch.fn = fn;\n }\n }\n // Closing a block helper\n const startingElseSection = match[1] === 'else';\n if (currentMatch.isBlock &&\n currentMatch.fn && (match[1] === `/${currentMatch.fn}` ||\n startingElseSection)) {\n if (!depth) { // === 0\n const start = currentMatch.startInner, body = str.substr(start, match.index - start);\n // Either closing without an else section, or when encountering\n // an else section\n if (currentMatch.body === void 0) {\n currentMatch.body = body;\n currentMatch.startInner = match.index + match[0].length;\n // The body exists already, so this is the else section\n }\n else {\n currentMatch.elseBody = body;\n }\n currentMatch.find += body + match[0];\n if (!startingElseSection) {\n matches.push(currentMatch);\n currentMatch = void 0;\n }\n }\n else if (!startingElseSection) {\n depth--;\n }\n // Common expression\n }\n else if (!currentMatch.isBlock) {\n matches.push(currentMatch);\n }\n // Evaluate sub-matches one by one to prevent orphaned block closers\n if (subMatch && !(currentMatch === null || currentMatch === void 0 ? void 0 : currentMatch.isBlock)) {\n break;\n }\n }\n // Execute\n matches.forEach((match) => {\n const { body, elseBody, expression, fn } = match;\n let replacement, i;\n // Helper function\n if (fn) {\n // Pass the helpers the amount of arguments defined by the function,\n // then the match as the last argument.\n const args = [match], parts = expression.split(' ');\n i = helpers[fn].length;\n while (i--) {\n args.unshift(resolveProperty(parts[i + 1]));\n }\n replacement = helpers[fn].apply(ctx, args);\n // Block helpers may return true or false. They may also return a\n // string, like the `each` helper.\n if (match.isBlock && typeof replacement === 'boolean') {\n replacement = format(replacement ? body : elseBody, ctx);\n }\n // Simple variable replacement\n }\n else {\n const valueAndFormat = expression.split(':');\n replacement = resolveProperty(valueAndFormat.shift() || '');\n // Format the replacement\n if (valueAndFormat.length && typeof replacement === 'number') {\n const segment = valueAndFormat.join(':');\n if (floatRegex.test(segment)) { // float\n const decimals = parseInt((segment.match(decRegex) || ['', '-1'])[1], 10);\n if (replacement !== null) {\n replacement = numberFormatter(replacement, decimals, lang.decimalPoint, segment.indexOf(',') > -1 ? lang.thousandsSep : '');\n }\n }\n else {\n replacement = time.dateFormat(segment, replacement);\n }\n }\n }\n str = str.replace(match.find, pick(replacement, ''));\n });\n return hasSub ? format(str, ctx, chart) : str;\n }\n /**\n * Format a number and return a string based on input settings.\n *\n * @sample highcharts/members/highcharts-numberformat/\n * Custom number format\n *\n * @function Highcharts.numberFormat\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string}\n * The formatted number.\n */\n function numberFormat(number, decimals, decimalPoint, thousandsSep) {\n number = +number || 0;\n decimals = +decimals;\n let ret, fractionDigits;\n const lang = defaultOptions.lang, origDec = (number.toString().split('.')[1] || '').split('e')[0].length, exponent = number.toString().split('e'), firstDecimals = decimals;\n if (decimals === -1) {\n // Preserve decimals. Not huge numbers (#3793).\n decimals = Math.min(origDec, 20);\n }\n else if (!isNumber(decimals)) {\n decimals = 2;\n }\n else if (decimals && exponent[1] && exponent[1] < 0) {\n // Expose decimals from exponential notation (#7042)\n fractionDigits = decimals + +exponent[1];\n if (fractionDigits >= 0) {\n // remove too small part of the number while keeping the notation\n exponent[0] = (+exponent[0]).toExponential(fractionDigits)\n .split('e')[0];\n decimals = fractionDigits;\n }\n else {\n // fractionDigits < 0\n exponent[0] = exponent[0].split('.')[0] || 0;\n if (decimals < 20) {\n // use number instead of exponential notation (#7405)\n number = (exponent[0] * Math.pow(10, exponent[1]))\n .toFixed(decimals);\n }\n else {\n // or zero\n number = 0;\n }\n exponent[1] = 0;\n }\n }\n // Add another decimal to avoid rounding errors of float numbers. (#4573)\n // Then use toFixed to handle rounding.\n const roundedNumber = (Math.abs(exponent[1] ? exponent[0] : number) +\n Math.pow(10, -Math.max(decimals, origDec) - 1)).toFixed(decimals);\n // A string containing the positive integer component of the number\n const strinteger = String(pInt(roundedNumber));\n // Leftover after grouping into thousands. Can be 0, 1 or 2.\n const thousands = strinteger.length > 3 ? strinteger.length % 3 : 0;\n // Language\n decimalPoint = pick(decimalPoint, lang.decimalPoint);\n thousandsSep = pick(thousandsSep, lang.thousandsSep);\n // Start building the return\n ret = number < 0 ? '-' : '';\n // Add the leftover after grouping into thousands. For example, in the\n // number 42 000 000, this line adds 42.\n ret += thousands ? strinteger.substr(0, thousands) + thousandsSep : '';\n if (+exponent[1] < 0 && !firstDecimals) {\n ret = '0';\n }\n else {\n // Add the remaining thousands groups, joined by the thousands separator\n ret += strinteger\n .substr(thousands)\n .replace(/(\\d{3})(?=\\d)/g, '$1' + thousandsSep);\n }\n // Add the decimal point and the decimal component\n if (decimals) {\n // Get the decimal component\n ret += decimalPoint + roundedNumber.slice(-decimals);\n }\n if (exponent[1] && +ret !== 0) {\n ret += 'e' + exponent[1];\n }\n return ret;\n }\n /* *\n *\n * Default Export\n *\n * */\n const Templating = {\n dateFormat,\n format,\n helpers,\n numberFormat\n };\n\n return Templating;\n });\n _registerModule(_modules, 'Core/Renderer/RendererUtilities.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Imports\n *\n * */\n const { clamp, pick, stableSort } = U;\n /* *\n *\n * Namespace\n *\n * */\n var RendererUtilities;\n (function (RendererUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * General distribution algorithm for distributing labels of differing size\n * along a confined length in two dimensions. The algorithm takes an array\n * of objects containing a size, a target and a rank. It will place the\n * labels as close as possible to their targets, skipping the lowest ranked\n * labels if necessary.\n * @private\n */\n function distribute(boxes, len, maxDistance) {\n // Original array will be altered with added .pos\n const origBoxes = boxes, reducedLen = origBoxes.reducedLen || len, sortByRank = (a, b) => (b.rank || 0) - (a.rank || 0), sortByTarget = (a, b) => a.target - b.target;\n let i, overlapping = true, restBoxes = [], // The outranked overshoot\n box, target, total = 0;\n // If the total size exceeds the len, remove those boxes with the lowest\n // rank\n i = boxes.length;\n while (i--) {\n total += boxes[i].size;\n }\n // Sort by rank, then slice away overshoot\n if (total > reducedLen) {\n stableSort(boxes, sortByRank);\n i = 0;\n total = 0;\n while (total <= reducedLen) {\n total += boxes[i].size;\n i++;\n }\n restBoxes = boxes.splice(i - 1, boxes.length);\n }\n // Order by target\n stableSort(boxes, sortByTarget);\n // So far we have been mutating the original array. Now\n // create a copy with target arrays\n boxes = boxes.map((box) => ({\n size: box.size,\n targets: [box.target],\n align: pick(box.align, 0.5)\n }));\n while (overlapping) {\n // Initial positions: target centered in box\n i = boxes.length;\n while (i--) {\n box = boxes[i];\n // Composite box, average of targets\n target = (Math.min.apply(0, box.targets) +\n Math.max.apply(0, box.targets)) / 2;\n box.pos = clamp(target - box.size * box.align, 0, len - box.size);\n }\n // Detect overlap and join boxes\n i = boxes.length;\n overlapping = false;\n while (i--) {\n // Overlap\n if (i > 0 &&\n boxes[i - 1].pos + boxes[i - 1].size >\n boxes[i].pos) {\n // Add this size to the previous box\n boxes[i - 1].size += boxes[i].size;\n boxes[i - 1].targets = boxes[i - 1]\n .targets\n .concat(boxes[i].targets);\n boxes[i - 1].align = 0.5;\n // Overlapping right, push left\n if (boxes[i - 1].pos + boxes[i - 1].size > len) {\n boxes[i - 1].pos = len - boxes[i - 1].size;\n }\n boxes.splice(i, 1); // Remove this item\n overlapping = true;\n }\n }\n }\n // Add the rest (hidden boxes)\n origBoxes.push.apply(origBoxes, restBoxes);\n // Now the composite boxes are placed, we need to put the original boxes\n // within them\n i = 0;\n boxes.some((box) => {\n let posInCompositeBox = 0;\n // Exceeded maxDistance => abort\n return (box.targets || []).some(() => {\n origBoxes[i].pos = box.pos + posInCompositeBox;\n // If the distance between the position and the target exceeds\n // maxDistance, abort the loop and decrease the length in\n // increments of 10% to recursively reduce the number of\n // visible boxes by rank. Once all boxes are within the\n // maxDistance, we're good.\n if (typeof maxDistance !== 'undefined' &&\n Math.abs(origBoxes[i].pos - origBoxes[i].target) > maxDistance) {\n // Reset the positions that are already set\n origBoxes\n .slice(0, i + 1)\n .forEach((box) => delete box.pos);\n // Try with a smaller length\n origBoxes.reducedLen =\n (origBoxes.reducedLen || len) - (len * 0.1);\n // Recurse\n if (origBoxes.reducedLen > len * 0.1) {\n distribute(origBoxes, len, maxDistance);\n }\n // Exceeded maxDistance => abort\n return true;\n }\n posInCompositeBox += origBoxes[i].size;\n i++;\n return false;\n });\n });\n // Add the rest (hidden) boxes and sort by target\n stableSort(origBoxes, sortByTarget);\n return origBoxes;\n }\n RendererUtilities.distribute = distribute;\n })(RendererUtilities || (RendererUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererUtilities;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGElement.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (A, Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animate, animObject, stop } = A;\n const { deg2rad, doc, noop, svg, SVG_NS, win } = H;\n const { addEvent, attr, createElement, css, defined, erase, extend, fireEvent, isArray, isFunction, isObject, isString, merge, objectEach, pick, pInt, syncTimeout, uniqueKey } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The SVGElement prototype is a JavaScript wrapper for SVG elements used in the\n * rendering layer of Highcharts. Combined with the\n * {@link Highcharts.SVGRenderer}\n * object, these prototypes allow freeform annotation in the charts or even in\n * HTML pages without instanciating a chart. The SVGElement can also wrap HTML\n * labels, when `text` or `label` elements are created with the `useHTML`\n * parameter.\n *\n * The SVGElement instances are created through factory functions on the\n * {@link Highcharts.SVGRenderer}\n * object, like\n * {@link Highcharts.SVGRenderer#rect|rect},\n * {@link Highcharts.SVGRenderer#path|path},\n * {@link Highcharts.SVGRenderer#text|text},\n * {@link Highcharts.SVGRenderer#label|label},\n * {@link Highcharts.SVGRenderer#g|g}\n * and more.\n *\n * @class\n * @name Highcharts.SVGElement\n */\n class SVGElement {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n this.element = void 0;\n this.onEvents = {};\n this.opacity = 1; // Default base for animation\n this.renderer = void 0;\n this.SVG_NS = SVG_NS;\n }\n // @todo public zIndex?: number;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the current value of an attribute or pseudo attribute,\n * used mainly for animation. Called internally from\n * the {@link Highcharts.SVGRenderer#attr} function.\n *\n * @private\n * @function Highcharts.SVGElement#_defaultGetter\n *\n * @param {string} key\n * Property key.\n *\n * @return {number|string}\n * Property value.\n */\n _defaultGetter(key) {\n let ret = pick(this[key + 'Value'], // align getter\n this[key], this.element ? this.element.getAttribute(key) : null, 0);\n if (/^[\\-0-9\\.]+$/.test(ret)) { // is numerical\n ret = parseFloat(ret);\n }\n return ret;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#_defaultSetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n _defaultSetter(value, key, element) {\n element.setAttribute(key, value);\n }\n /**\n * Add the element to the DOM. All elements must be added this way.\n *\n * @sample highcharts/members/renderer-g\n * Elements added to a group\n *\n * @function Highcharts.SVGElement#add\n *\n * @param {Highcharts.SVGElement} [parent]\n * The parent item to add it to. If undefined, the element is added\n * to the {@link Highcharts.SVGRenderer.box}.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n add(parent) {\n const renderer = this.renderer, element = this.element;\n let inserted;\n if (parent) {\n this.parentGroup = parent;\n }\n // Build formatted text\n if (typeof this.textStr !== 'undefined' &&\n this.element.nodeName === 'text' // Not for SVGLabel instances\n ) {\n renderer.buildText(this);\n }\n // Mark as added\n this.added = true;\n // If we're adding to renderer root, or other elements in the group\n // have a z index, we need to handle it\n if (!parent || parent.handleZ || this.zIndex) {\n inserted = this.zIndexSetter();\n }\n // If zIndex is not handled, append at the end\n if (!inserted) {\n (parent ?\n parent.element :\n renderer.box).appendChild(element);\n }\n // fire an event for internal hooks\n if (this.onAdd) {\n this.onAdd();\n }\n return this;\n }\n /**\n * Add a class name to an element.\n *\n * @function Highcharts.SVGElement#addClass\n *\n * @param {string} className\n * The new class name to add.\n *\n * @param {boolean} [replace=false]\n * When true, the existing class name(s) will be overwritten with the new\n * one. When false, the new one is added.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chainability.\n */\n addClass(className, replace) {\n const currentClassName = replace ? '' : (this.attr('class') || '');\n // Trim the string and remove duplicates\n className = (className || '')\n .split(/ /g)\n .reduce(function (newClassName, name) {\n if (currentClassName.indexOf(name) === -1) {\n newClassName.push(name);\n }\n return newClassName;\n }, (currentClassName ?\n [currentClassName] :\n []))\n .join(' ');\n if (className !== currentClassName) {\n this.attr('class', className);\n }\n return this;\n }\n /**\n * This method is executed in the end of `attr()`, after setting all\n * attributes in the hash. In can be used to efficiently consolidate\n * multiple attributes in one SVG property -- e.g., translate, rotate and\n * scale are merged in one \"transform\" attribute in the SVG node.\n *\n * @private\n * @function Highcharts.SVGElement#afterSetters\n */\n afterSetters() {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.updateTransform();\n this.doTransform = false;\n }\n }\n /**\n * Align the element relative to the chart or another box.\n *\n * @function Highcharts.SVGElement#align\n *\n * @param {Highcharts.AlignObject} [alignOptions]\n * The alignment options. The function can be called without this\n * parameter in order to re-align an element after the box has been\n * updated.\n *\n * @param {boolean} [alignByTranslate]\n * Align element by translation.\n *\n * @param {string|Highcharts.BBoxObject} [box]\n * The box to align to, needs a width and height. When the box is a\n * string, it refers to an object in the Renderer. For example, when\n * box is `spacingBox`, it refers to `Renderer.spacingBox` which\n * holds `width`, `height`, `x` and `y` properties.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n align(alignOptions, alignByTranslate, box) {\n const attribs = {}, renderer = this.renderer, alignedObjects = renderer.alignedObjects;\n let x, y, alignTo, alignFactor, vAlignFactor;\n // First call on instanciate\n if (alignOptions) {\n this.alignOptions = alignOptions;\n this.alignByTranslate = alignByTranslate;\n if (!box || isString(box)) {\n this.alignTo = alignTo = box || 'renderer';\n // prevent duplicates, like legendGroup after resize\n erase(alignedObjects, this);\n alignedObjects.push(this);\n box = void 0; // reassign it below\n }\n // When called on resize, no arguments are supplied\n }\n else {\n alignOptions = this.alignOptions;\n alignByTranslate = this.alignByTranslate;\n alignTo = this.alignTo;\n }\n box = pick(box, renderer[alignTo], alignTo === 'scrollablePlotBox' ?\n renderer.plotBox : void 0, renderer);\n // Assign variables\n const align = alignOptions.align, vAlign = alignOptions.verticalAlign;\n // default: left align\n x = (box.x || 0) + (alignOptions.x || 0);\n // default: top align\n y = (box.y || 0) + (alignOptions.y || 0);\n // Align\n if (align === 'right') {\n alignFactor = 1;\n }\n else if (align === 'center') {\n alignFactor = 2;\n }\n if (alignFactor) {\n x += (box.width - (alignOptions.width || 0)) /\n alignFactor;\n }\n attribs[alignByTranslate ? 'translateX' : 'x'] = Math.round(x);\n // Vertical align\n if (vAlign === 'bottom') {\n vAlignFactor = 1;\n }\n else if (vAlign === 'middle') {\n vAlignFactor = 2;\n }\n if (vAlignFactor) {\n y += (box.height - (alignOptions.height || 0)) /\n vAlignFactor;\n }\n attribs[alignByTranslate ? 'translateY' : 'y'] = Math.round(y);\n // Animate only if already placed\n this[this.placed ? 'animate' : 'attr'](attribs);\n this.placed = true;\n this.alignAttr = attribs;\n return this;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#alignSetter\n * @param {\"left\"|\"center\"|\"right\"} value\n */\n alignSetter(value) {\n const convert = {\n left: 'start',\n center: 'middle',\n right: 'end'\n };\n if (convert[value]) {\n this.alignValue = value;\n this.element.setAttribute('text-anchor', convert[value]);\n }\n }\n /**\n * Animate to given attributes or CSS properties.\n *\n * @sample highcharts/members/element-on/\n * Setting some attributes by animation\n *\n * @function Highcharts.SVGElement#animate\n *\n * @param {Highcharts.SVGAttributes} params\n * SVG attributes or CSS to animate.\n *\n * @param {boolean|Partial} [options]\n * Animation options.\n *\n * @param {Function} [complete]\n * Function to perform at the end of animation.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n animate(params, options, complete) {\n const animOptions = animObject(pick(options, this.renderer.globalAnimation, true)), deferTime = animOptions.defer;\n // When the page is hidden save resources in the background by not\n // running animation at all (#9749).\n if (doc.hidden) {\n animOptions.duration = 0;\n }\n if (animOptions.duration !== 0) {\n // allows using a callback with the global animation without\n // overwriting it\n if (complete) {\n animOptions.complete = complete;\n }\n // If defer option is defined delay the animation #12901\n syncTimeout(() => {\n if (this.element) {\n animate(this, params, animOptions);\n }\n }, deferTime);\n }\n else {\n this.attr(params, void 0, complete || animOptions.complete);\n // Call the end step synchronously\n objectEach(params, function (val, prop) {\n if (animOptions.step) {\n animOptions.step.call(this, val, { prop: prop, pos: 1, elem: this });\n }\n }, this);\n }\n return this;\n }\n /**\n * Apply a text outline through a custom CSS property, by copying the text\n * element and apply stroke to the copy. Used internally. Contrast checks at\n * [example](https://jsfiddle.net/highcharts/43soe9m1/2/).\n *\n * @example\n * // Specific color\n * text.css({\n * textOutline: '1px black'\n * });\n * // Automatic contrast\n * text.css({\n * color: '#000000', // black text\n * textOutline: '1px contrast' // => white outline\n * });\n *\n * @private\n * @function Highcharts.SVGElement#applyTextOutline\n *\n * @param {string} textOutline\n * A custom CSS `text-outline` setting, defined by `width color`.\n */\n applyTextOutline(textOutline) {\n const elem = this.element, hasContrast = textOutline.indexOf('contrast') !== -1, styles = {};\n // When the text shadow is set to contrast, use dark stroke for light\n // text and vice versa.\n if (hasContrast) {\n styles.textOutline = textOutline = textOutline.replace(/contrast/g, this.renderer.getContrast(elem.style.fill));\n }\n // Extract the stroke width and color\n const parts = textOutline.split(' ');\n const color = parts[parts.length - 1];\n let strokeWidth = parts[0];\n if (strokeWidth && strokeWidth !== 'none' && H.svg) {\n this.fakeTS = true; // Fake text shadow\n // Since the stroke is applied on center of the actual outline, we\n // need to double it to get the correct stroke-width outside the\n // glyphs.\n strokeWidth = strokeWidth.replace(/(^[\\d\\.]+)(.*?)$/g, function (match, digit, unit) {\n return (2 * Number(digit)) + unit;\n });\n // Remove shadows from previous runs.\n this.removeTextOutline();\n const outline = doc.createElementNS(SVG_NS, 'tspan');\n attr(outline, {\n 'class': 'highcharts-text-outline',\n fill: color,\n stroke: color,\n 'stroke-width': strokeWidth,\n 'stroke-linejoin': 'round'\n });\n // For each of the tspans and text nodes, create a copy in the\n // outline.\n const parentElem = elem.querySelector('textPath') || elem;\n [].forEach.call(parentElem.childNodes, (childNode) => {\n const clone = childNode.cloneNode(true);\n if (clone.removeAttribute) {\n ['fill', 'stroke', 'stroke-width', 'stroke'].forEach((prop) => clone\n .removeAttribute(prop));\n }\n outline.appendChild(clone);\n });\n // Collect the sum of dy from all children, included nested ones\n let totalHeight = 0;\n [].forEach.call(parentElem.querySelectorAll('text tspan'), (element) => {\n totalHeight += Number(element.getAttribute('dy'));\n });\n // Insert an absolutely positioned break before the original text\n // to keep it in place\n const br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B';\n // Reset the position for the following text\n attr(br, {\n x: Number(elem.getAttribute('x')),\n dy: -totalHeight\n });\n // Insert the outline\n outline.appendChild(br);\n parentElem.insertBefore(outline, parentElem.firstChild);\n }\n }\n /**\n * @function Highcharts.SVGElement#attr\n * @param {string} key\n * @return {number|string}\n */ /**\n * Apply native and custom attributes to the SVG elements.\n *\n * In order to set the rotation center for rotation, set x and y to 0 and\n * use `translateX` and `translateY` attributes to position the element\n * instead.\n *\n * Attributes frequently used in Highcharts are `fill`, `stroke`,\n * `stroke-width`.\n *\n * @sample highcharts/members/renderer-rect/\n * Setting some attributes\n *\n * @example\n * // Set multiple attributes\n * element.attr({\n * stroke: 'red',\n * fill: 'blue',\n * x: 10,\n * y: 10\n * });\n *\n * // Set a single attribute\n * element.attr('stroke', 'red');\n *\n * // Get an attribute\n * element.attr('stroke'); // => 'red'\n *\n * @function Highcharts.SVGElement#attr\n *\n * @param {string|Highcharts.SVGAttributes} [hash]\n * The native and custom SVG attributes.\n *\n * @param {number|string|Highcharts.SVGPathArray} [val]\n * If the type of the first argument is `string`, the second can be a\n * value, which will serve as a single attribute setter. If the first\n * argument is a string and the second is undefined, the function\n * serves as a getter and the current value of the property is\n * returned.\n *\n * @param {Function} [complete]\n * A callback function to execute after setting the attributes. This\n * makes the function compliant and interchangeable with the\n * {@link SVGElement#animate} function.\n *\n * @param {boolean} [continueAnimation=true]\n * Used internally when `.attr` is called as part of an animation\n * step. Otherwise, calling `.attr` for an attribute will stop\n * animation for that attribute.\n *\n * @return {Highcharts.SVGElement}\n * If used as a setter, it returns the current\n * {@link Highcharts.SVGElement} so the calls can be chained. If\n * used as a getter, the current value of the attribute is returned.\n */\n attr(hash, val, complete, continueAnimation) {\n const element = this.element, symbolCustomAttribs = SVGElement.symbolCustomAttribs;\n let key, hasSetSymbolSize, ret = this, skipAttr, setter;\n // single key-value pair\n if (typeof hash === 'string' && typeof val !== 'undefined') {\n key = hash;\n hash = {};\n hash[key] = val;\n }\n // used as a getter: first argument is a string, second is undefined\n if (typeof hash === 'string') {\n ret = (this[hash + 'Getter'] ||\n this._defaultGetter).call(this, hash, element);\n // setter\n }\n else {\n objectEach(hash, function eachAttribute(val, key) {\n skipAttr = false;\n // Unless .attr is from the animator update, stop current\n // running animation of this property\n if (!continueAnimation) {\n stop(this, key);\n }\n // Special handling of symbol attributes\n if (this.symbolName &&\n symbolCustomAttribs.indexOf(key) !== -1) {\n if (!hasSetSymbolSize) {\n this.symbolAttr(hash);\n hasSetSymbolSize = true;\n }\n skipAttr = true;\n }\n if (this.rotation && (key === 'x' || key === 'y')) {\n this.doTransform = true;\n }\n if (!skipAttr) {\n setter = (this[key + 'Setter'] ||\n this._defaultSetter);\n setter.call(this, val, key, element);\n }\n }, this);\n this.afterSetters();\n }\n // In accordance with animate, run a complete callback\n if (complete) {\n complete.call(this);\n }\n return ret;\n }\n /**\n * Apply a clipping rectangle to this element.\n *\n * @function Highcharts.SVGElement#clip\n *\n * @param {Highcharts.ClipRectElement} [clipRect]\n * The clipping rectangle. If skipped, the current clip is removed.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVG element to allow chaining.\n */\n clip(clipRect) {\n return this.attr('clip-path', clipRect ?\n 'url(' + this.renderer.url + '#' + clipRect.id + ')' :\n 'none');\n }\n /**\n * Calculate the coordinates needed for drawing a rectangle crisply and\n * return the calculated attributes.\n *\n * @function Highcharts.SVGElement#crisp\n *\n * @param {Highcharts.RectangleObject} rect\n * Rectangle to crisp.\n *\n * @param {number} [strokeWidth]\n * The stroke width to consider when computing crisp positioning. It can\n * also be set directly on the rect parameter.\n *\n * @return {Highcharts.RectangleObject}\n * The modified rectangle arguments.\n */\n crisp(rect, strokeWidth) {\n const wrapper = this;\n strokeWidth = strokeWidth || rect.strokeWidth || 0;\n // Math.round because strokeWidth can sometimes have roundoff errors\n const normalizer = Math.round(strokeWidth) % 2 / 2;\n // normalize for crisp edges\n rect.x = Math.floor(rect.x || wrapper.x || 0) + normalizer;\n rect.y = Math.floor(rect.y || wrapper.y || 0) + normalizer;\n rect.width = Math.floor((rect.width || wrapper.width || 0) - 2 * normalizer);\n rect.height = Math.floor((rect.height || wrapper.height || 0) - 2 * normalizer);\n if (defined(rect.strokeWidth)) {\n rect.strokeWidth = strokeWidth;\n }\n return rect;\n }\n /**\n * Build and apply an SVG gradient out of a common JavaScript configuration\n * object. This function is called from the attribute setters. An event\n * hook is added for supporting other complex color types.\n *\n * @private\n * @function Highcharts.SVGElement#complexColor\n *\n * @param {Highcharts.GradientColorObject|Highcharts.PatternObject} colorOptions\n * The gradient or pattern options structure.\n *\n * @param {string} prop\n * The property to apply, can either be `fill` or `stroke`.\n *\n * @param {Highcharts.SVGDOMElement} elem\n * SVG element to apply the gradient on.\n */\n complexColor(colorOptions, prop, elem) {\n const renderer = this.renderer;\n let colorObject, gradName, gradAttr, radAttr, gradients, stops, stopColor, stopOpacity, radialReference, id, key = [], value;\n fireEvent(this.renderer, 'complexColor', {\n args: arguments\n }, function () {\n // Apply linear or radial gradients\n if (colorOptions.radialGradient) {\n gradName = 'radialGradient';\n }\n else if (colorOptions.linearGradient) {\n gradName = 'linearGradient';\n }\n if (gradName) {\n gradAttr = colorOptions[gradName];\n gradients = renderer.gradients;\n stops = colorOptions.stops;\n radialReference = elem.radialReference;\n // Keep < 2.2 kompatibility\n if (isArray(gradAttr)) {\n colorOptions[gradName] = gradAttr = {\n x1: gradAttr[0],\n y1: gradAttr[1],\n x2: gradAttr[2],\n y2: gradAttr[3],\n gradientUnits: 'userSpaceOnUse'\n };\n }\n // Correct the radial gradient for the radial reference system\n if (gradName === 'radialGradient' &&\n radialReference &&\n !defined(gradAttr.gradientUnits)) {\n // Save the radial attributes for updating\n radAttr = gradAttr;\n gradAttr = merge(gradAttr, renderer.getRadialAttr(radialReference, radAttr), { gradientUnits: 'userSpaceOnUse' });\n }\n // Build the unique key to detect whether we need to create a\n // new element (#1282)\n objectEach(gradAttr, function (value, n) {\n if (n !== 'id') {\n key.push(n, value);\n }\n });\n objectEach(stops, function (val) {\n key.push(val);\n });\n key = key.join(',');\n // Check if a gradient object with the same config object is\n // created within this renderer\n if (gradients[key]) {\n id = gradients[key].attr('id');\n }\n else {\n // Set the id and create the element\n gradAttr.id = id = uniqueKey();\n const gradientObject = gradients[key] =\n renderer.createElement(gradName)\n .attr(gradAttr)\n .add(renderer.defs);\n gradientObject.radAttr = radAttr;\n // The gradient needs to keep a list of stops to be able to\n // destroy them\n gradientObject.stops = [];\n stops.forEach(function (stop) {\n if (stop[1].indexOf('rgba') === 0) {\n colorObject = Color.parse(stop[1]);\n stopColor = colorObject.get('rgb');\n stopOpacity = colorObject.get('a');\n }\n else {\n stopColor = stop[1];\n stopOpacity = 1;\n }\n const stopObject = renderer.createElement('stop').attr({\n offset: stop[0],\n 'stop-color': stopColor,\n 'stop-opacity': stopOpacity\n }).add(gradientObject);\n // Add the stop element to the gradient\n gradientObject.stops.push(stopObject);\n });\n }\n // Set the reference to the gradient object\n value = 'url(' + renderer.url + '#' + id + ')';\n elem.setAttribute(prop, value);\n elem.gradient = key;\n // Allow the color to be concatenated into tooltips formatters\n // etc. (#2995)\n colorOptions.toString = function () {\n return value;\n };\n }\n });\n }\n /**\n * Set styles for the element. In addition to CSS styles supported by\n * native SVG and HTML elements, there are also some custom made for\n * Highcharts, like `width`, `ellipsis` and `textOverflow` for SVG text\n * elements.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Styled text\n *\n * @function Highcharts.SVGElement#css\n *\n * @param {Highcharts.CSSObject} styles\n * The new CSS styles.\n *\n * @return {Highcharts.SVGElement}\n * Return the SVG element for chaining.\n */\n css(styles) {\n const oldStyles = this.styles, newStyles = {}, elem = this.element;\n let textWidth, hasNew = !oldStyles;\n // Filter out existing styles to increase performance (#2640)\n if (oldStyles) {\n objectEach(styles, function (value, n) {\n if (oldStyles && oldStyles[n] !== value) {\n newStyles[n] = value;\n hasNew = true;\n }\n });\n }\n if (hasNew) {\n // Merge the new styles with the old ones\n if (oldStyles) {\n styles = extend(oldStyles, newStyles);\n }\n // Get the text width from style\n // Previously set, unset it (#8234)\n if (styles.width === null || styles.width === 'auto') {\n delete this.textWidth;\n // Apply new\n }\n else if (elem.nodeName.toLowerCase() === 'text' &&\n styles.width) {\n textWidth = this.textWidth = pInt(styles.width);\n }\n // store object\n this.styles = styles;\n if (textWidth && (!svg && this.renderer.forExport)) {\n delete styles.width;\n }\n const stylesToApply = merge(styles);\n if (elem.namespaceURI === this.SVG_NS) {\n // These CSS properties are interpreted internally by the SVG\n // renderer, but are not supported by SVG and should not be\n // added to the DOM. In styled mode, no CSS should find its way\n // to the DOM whatsoever (#6173, #6474).\n ['textOutline', 'textOverflow', 'width'].forEach((key) => (stylesToApply &&\n delete stylesToApply[key]));\n // SVG requires fill for text\n if (stylesToApply.color) {\n stylesToApply.fill = stylesToApply.color;\n }\n }\n css(elem, stylesToApply);\n }\n if (this.added) {\n // Rebuild text after added. Cache mechanisms in the buildText will\n // prevent building if there are no significant changes.\n if (this.element.nodeName === 'text') {\n this.renderer.buildText(this);\n }\n // Apply text outline after added\n if (styles.textOutline) {\n this.applyTextOutline(styles.textOutline);\n }\n }\n return this;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#dashstyleSetter\n * @param {string} value\n */\n dashstyleSetter(value) {\n let i, strokeWidth = this['stroke-width'];\n // If \"inherit\", like maps in IE, assume 1 (#4981). With HC5 and the new\n // strokeWidth function, we should be able to use that instead.\n if (strokeWidth === 'inherit') {\n strokeWidth = 1;\n }\n value = value && value.toLowerCase();\n if (value) {\n const v = value\n .replace('shortdashdotdot', '3,1,1,1,1,1,')\n .replace('shortdashdot', '3,1,1,1')\n .replace('shortdot', '1,1,')\n .replace('shortdash', '3,1,')\n .replace('longdash', '8,3,')\n .replace(/dot/g, '1,3,')\n .replace('dash', '4,3,')\n .replace(/,$/, '')\n .split(','); // ending comma\n i = v.length;\n while (i--) {\n v[i] = '' + (pInt(v[i]) * pick(strokeWidth, NaN));\n }\n value = v.join(',').replace(/NaN/g, 'none'); // #3226\n this.element.setAttribute('stroke-dasharray', value);\n }\n }\n /**\n * Destroy the element and element wrapper and clear up the DOM and event\n * hooks.\n *\n * @function Highcharts.SVGElement#destroy\n */\n destroy() {\n const wrapper = this, element = wrapper.element || {}, renderer = wrapper.renderer, ownerSVGElement = element.ownerSVGElement;\n let parentToClean = (element.nodeName === 'SPAN' &&\n wrapper.parentGroup ||\n void 0), grandParent, i;\n // remove events\n element.onclick = element.onmouseout = element.onmouseover =\n element.onmousemove = element.point = null;\n stop(wrapper); // stop running animations\n if (wrapper.clipPath && ownerSVGElement) {\n const clipPath = wrapper.clipPath;\n // Look for existing references to this clipPath and remove them\n // before destroying the element (#6196).\n // The upper case version is for Edge\n [].forEach.call(ownerSVGElement.querySelectorAll('[clip-path],[CLIP-PATH]'), function (el) {\n if (el.getAttribute('clip-path').indexOf(clipPath.element.id) > -1) {\n el.removeAttribute('clip-path');\n }\n });\n wrapper.clipPath = clipPath.destroy();\n }\n // Destroy stops in case this is a gradient object @todo old code?\n if (wrapper.stops) {\n for (i = 0; i < wrapper.stops.length; i++) {\n wrapper.stops[i].destroy();\n }\n wrapper.stops.length = 0;\n wrapper.stops = void 0;\n }\n // remove element\n wrapper.safeRemoveChild(element);\n // In case of useHTML, clean up empty containers emulating SVG groups\n // (#1960, #2393, #2697).\n while (parentToClean &&\n parentToClean.div &&\n parentToClean.div.childNodes.length === 0) {\n grandParent = parentToClean.parentGroup;\n wrapper.safeRemoveChild(parentToClean.div);\n delete parentToClean.div;\n parentToClean = grandParent;\n }\n // remove from alignObjects\n if (wrapper.alignTo) {\n erase(renderer.alignedObjects, wrapper);\n }\n objectEach(wrapper, function (val, key) {\n // Destroy child elements of a group\n if (wrapper[key] &&\n wrapper[key].parentGroup === wrapper &&\n wrapper[key].destroy) {\n wrapper[key].destroy();\n }\n // Delete all properties\n delete wrapper[key];\n });\n return;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#dSettter\n * @param {number|string|Highcharts.SVGPathArray} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n dSetter(value, key, element) {\n if (isArray(value)) {\n // Backwards compatibility, convert one-dimensional array into an\n // array of segments\n if (typeof value[0] === 'string') {\n value = this.renderer.pathToSegments(value);\n }\n this.pathArray = value;\n value = value.reduce((acc, seg, i) => {\n if (!seg || !seg.join) {\n return (seg || '').toString();\n }\n return (i ? acc + ' ' : '') + seg.join(' ');\n }, '');\n }\n if (/(NaN| {2}|^$)/.test(value)) {\n value = 'M 0 0';\n }\n // Check for cache before resetting. Resetting causes disturbance in the\n // DOM, causing flickering in some cases in Edge/IE (#6747). Also\n // possible performance gain.\n if (this[key] !== value) {\n element.setAttribute(key, value);\n this[key] = value;\n }\n }\n /**\n * Fade out an element by animating its opacity down to 0, and hide it on\n * complete. Used internally for the tooltip.\n *\n * @function Highcharts.SVGElement#fadeOut\n *\n * @param {number} [duration=150]\n * The fade duration in milliseconds.\n */\n fadeOut(duration) {\n const elemWrapper = this;\n elemWrapper.animate({\n opacity: 0\n }, {\n duration: pick(duration, 150),\n complete: function () {\n // #3088, assuming we're only using this for tooltips\n elemWrapper.hide();\n }\n });\n }\n /**\n * @private\n * @function Highcharts.SVGElement#fillSetter\n * @param {Highcharts.ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n fillSetter(value, key, element) {\n if (typeof value === 'string') {\n element.setAttribute(key, value);\n }\n else if (value) {\n this.complexColor(value, key, element);\n }\n }\n /**\n * Get the bounding box (width, height, x and y) for the element. Generally\n * used to get rendered text size. Since this is called a lot in charts,\n * the results are cached based on text properties, in order to save DOM\n * traffic. The returned bounding box includes the rotation, so for example\n * a single text line of rotation 90 will report a greater height, and a\n * width corresponding to the line-height.\n *\n * @sample highcharts/members/renderer-on-chart/\n * Draw a rectangle based on a text's bounding box\n *\n * @function Highcharts.SVGElement#getBBox\n *\n * @param {boolean} [reload]\n * Skip the cache and get the updated DOM bouding box.\n *\n * @param {number} [rot]\n * Override the element's rotation. This is internally used on axis\n * labels with a value of 0 to find out what the bounding box would\n * be have been if it were not rotated.\n *\n * @return {Highcharts.BBoxObject}\n * The bounding box with `x`, `y`, `width` and `height` properties.\n */\n getBBox(reload, rot) {\n const wrapper = this, { alignValue, element, renderer, styles, textStr } = wrapper, { cache, cacheKeys } = renderer, isSVG = element.namespaceURI === wrapper.SVG_NS, rotation = pick(rot, wrapper.rotation, 0), fontSize = renderer.styledMode ? (element &&\n SVGElement.prototype.getStyle.call(element, 'font-size')) : (styles && styles.fontSize);\n let bBox, width, height, toggleTextShadowShim, cacheKey;\n // Avoid undefined and null (#7316)\n if (defined(textStr)) {\n cacheKey = textStr.toString();\n // Since numbers are monospaced, and numerical labels appear a lot\n // in a chart, we assume that a label of n characters has the same\n // bounding box as others of the same length. Unless there is inner\n // HTML in the label. In that case, leave the numbers as is (#5899).\n if (cacheKey.indexOf('<') === -1) {\n cacheKey = cacheKey.replace(/[0-9]/g, '0');\n }\n // Properties that affect bounding box\n cacheKey += [\n '',\n renderer.rootFontSize,\n fontSize,\n rotation,\n wrapper.textWidth,\n alignValue,\n styles && styles.textOverflow,\n styles && styles.fontWeight // #12163\n ].join(',');\n }\n if (cacheKey && !reload) {\n bBox = cache[cacheKey];\n }\n // No cache found\n if (!bBox) {\n // SVG elements\n if (isSVG || renderer.forExport) {\n try { // Fails in Firefox if the container has display: none.\n // When the text shadow shim is used, we need to hide the\n // fake shadows to get the correct bounding box (#3872)\n toggleTextShadowShim = this.fakeTS && function (display) {\n const outline = element.querySelector('.highcharts-text-outline');\n if (outline) {\n css(outline, { display });\n }\n };\n // Workaround for #3842, Firefox reporting wrong bounding\n // box for shadows\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('none');\n }\n bBox = element.getBBox ?\n // SVG: use extend because IE9 is not allowed to change\n // width and height in case of rotation (below)\n extend({}, element.getBBox()) : {\n // HTML elements with `exporting.allowHTML` and\n // legacy IE in export mode\n width: element.offsetWidth,\n height: element.offsetHeight,\n x: 0,\n y: 0\n };\n // #3842\n if (isFunction(toggleTextShadowShim)) {\n toggleTextShadowShim('');\n }\n }\n catch (e) {\n '';\n }\n // If the bBox is not set, the try-catch block above failed. The\n // other condition is for Opera that returns a width of\n // -Infinity on hidden elements.\n if (!bBox || bBox.width < 0) {\n bBox = { x: 0, y: 0, width: 0, height: 0 };\n }\n // useHTML within SVG\n }\n else {\n bBox = wrapper.htmlGetBBox();\n }\n // True SVG elements as well as HTML elements in modern browsers\n // using the .useHTML option need to compensated for rotation\n width = bBox.width;\n height = bBox.height;\n // Workaround for wrong bounding box in IE, Edge and Chrome on\n // Windows. With Highcharts' default font, IE and Edge report\n // a box height of 16.899 and Chrome rounds it to 17. If this\n // stands uncorrected, it results in more padding added below\n // the text than above when adding a label border or background.\n // Also vertical positioning is affected.\n // https://jsfiddle.net/highcharts/em37nvuj/\n // (#1101, #1505, #1669, #2568, #6213).\n if (isSVG) {\n bBox.height = height = ({\n '11px,17': 14,\n '13px,20': 16\n }[`${fontSize || ''},${Math.round(height)}`] ||\n height);\n }\n // Adjust for rotated text\n if (rotation) {\n const baseline = Number(element.getAttribute('y') || 0) - bBox.y, alignFactor = {\n 'right': 1,\n 'center': 0.5\n }[alignValue || 0] || 0, rad = rotation * deg2rad, rad90 = (rotation - 90) * deg2rad, wCosRad = width * Math.cos(rad), wSinRad = width * Math.sin(rad), cosRad90 = Math.cos(rad90), sinRad90 = Math.sin(rad90), \n // Find the starting point on the left side baseline of\n // the text\n pX = bBox.x + alignFactor * (width - wCosRad), pY = bBox.y + baseline - alignFactor * wSinRad, \n // Find all corners\n aX = pX + baseline * cosRad90, bX = aX + wCosRad, cX = bX - height * cosRad90, dX = cX - wCosRad, aY = pY + baseline * sinRad90, bY = aY + wSinRad, cY = bY - height * sinRad90, dY = cY - wSinRad;\n // Deduct the bounding box from the corners\n bBox.x = Math.min(aX, bX, cX, dX);\n bBox.y = Math.min(aY, bY, cY, dY);\n bBox.width = Math.max(aX, bX, cX, dX) - bBox.x;\n bBox.height = Math.max(aY, bY, cY, dY) - bBox.y;\n }\n }\n // Cache it. When loading a chart in a hidden iframe in Firefox and\n // IE/Edge, the bounding box height is 0, so don't cache it (#5620).\n if (cacheKey && (textStr === '' || bBox.height > 0)) {\n // Rotate (#4681)\n while (cacheKeys.length > 250) {\n delete cache[cacheKeys.shift()];\n }\n if (!cache[cacheKey]) {\n cacheKeys.push(cacheKey);\n }\n cache[cacheKey] = bBox;\n }\n return bBox;\n }\n /**\n * Get the computed style. Only in styled mode.\n *\n * @example\n * chart.series[0].points[0].graphic.getStyle('stroke-width'); // => '1px'\n *\n * @function Highcharts.SVGElement#getStyle\n *\n * @param {string} prop\n * The property name to check for.\n *\n * @return {string}\n * The current computed value.\n */\n getStyle(prop) {\n return win\n .getComputedStyle(this.element || this, '')\n .getPropertyValue(prop);\n }\n /**\n * Check if an element has the given class name.\n *\n * @function Highcharts.SVGElement#hasClass\n *\n * @param {string} className\n * The class name to check for.\n *\n * @return {boolean}\n * Whether the class name is found.\n */\n hasClass(className) {\n return ('' + this.attr('class'))\n .split(' ')\n .indexOf(className) !== -1;\n }\n /**\n * Hide the element, similar to setting the `visibility` attribute to\n * `hidden`.\n *\n * @function Highcharts.SVGElement#hide\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n hide() {\n return this.attr({ visibility: 'hidden' });\n }\n /**\n * @private\n */\n htmlGetBBox() {\n return { height: 0, width: 0, x: 0, y: 0 };\n }\n /**\n * Initialize the SVG element. This function only exists to make the\n * initialization process overridable. It should not be called directly.\n *\n * @function Highcharts.SVGElement#init\n *\n * @param {Highcharts.SVGRenderer} renderer\n * The SVGRenderer instance to initialize to.\n *\n * @param {string} nodeName\n * The SVG node name.\n */\n init(renderer, nodeName) {\n /**\n * The primary DOM node. Each `SVGElement` instance wraps a main DOM\n * node, but may also represent more nodes.\n *\n * @name Highcharts.SVGElement#element\n * @type {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement}\n */\n this.element = nodeName === 'span' ?\n createElement(nodeName) :\n doc.createElementNS(this.SVG_NS, nodeName);\n /**\n * The renderer that the SVGElement belongs to.\n *\n * @name Highcharts.SVGElement#renderer\n * @type {Highcharts.SVGRenderer}\n */\n this.renderer = renderer;\n fireEvent(this, 'afterInit');\n }\n /**\n * Add an event listener. This is a simple setter that replaces the\n * previous event of the same type added by this function, as opposed to\n * the {@link Highcharts#addEvent} function.\n *\n * @sample highcharts/members/element-on/\n * A clickable rectangle\n *\n * @function Highcharts.SVGElement#on\n *\n * @param {string} eventType\n * The event type.\n *\n * @param {Function} handler\n * The handler callback.\n *\n * @return {Highcharts.SVGElement}\n * The SVGElement for chaining.\n */\n on(eventType, handler) {\n const { onEvents } = this;\n if (onEvents[eventType]) {\n // Unbind existing event\n onEvents[eventType]();\n }\n onEvents[eventType] = addEvent(this.element, eventType, handler);\n return this;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#opacitySetter\n * @param {string} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n opacitySetter(value, key, element) {\n // Round off to avoid float errors, like tests where opacity lands on\n // 9.86957e-06 instead of 0\n const opacity = Number(Number(value).toFixed(3));\n this.opacity = opacity;\n element.setAttribute(key, opacity);\n }\n /**\n * Remove a class name from the element.\n *\n * @function Highcharts.SVGElement#removeClass\n *\n * @param {string|RegExp} className\n * The class name to remove.\n *\n * @return {Highcharts.SVGElement} Returns the SVG element for chainability.\n */\n removeClass(className) {\n return this.attr('class', ('' + this.attr('class'))\n .replace(isString(className) ?\n new RegExp(`(^| )${className}( |$)`) : // #12064, #13590\n className, ' ')\n .replace(/ +/g, ' ')\n .trim());\n }\n /**\n *\n * @private\n */\n removeTextOutline() {\n const outline = this.element\n .querySelector('tspan.highcharts-text-outline');\n if (outline) {\n this.safeRemoveChild(outline);\n }\n }\n /**\n * Removes an element from the DOM.\n *\n * @private\n * @function Highcharts.SVGElement#safeRemoveChild\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The DOM node to remove.\n */\n safeRemoveChild(element) {\n const parentNode = element.parentNode;\n if (parentNode) {\n parentNode.removeChild(element);\n }\n }\n /**\n * Set the coordinates needed to draw a consistent radial gradient across\n * a shape regardless of positioning inside the chart. Used on pie slices\n * to make all the slices have the same radial reference point.\n *\n * @function Highcharts.SVGElement#setRadialReference\n *\n * @param {Array} coordinates\n * The center reference. The format is `[centerX, centerY, diameter]` in\n * pixels.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n setRadialReference(coordinates) {\n const existingGradient = (this.element.gradient &&\n this.renderer.gradients[this.element.gradient]);\n this.element.radialReference = coordinates;\n // On redrawing objects with an existing gradient, the gradient needs\n // to be repositioned (#3801)\n if (existingGradient && existingGradient.radAttr) {\n existingGradient.animate(this.renderer.getRadialAttr(coordinates, existingGradient.radAttr));\n }\n return this;\n }\n /**\n * Set a text path for a `text` or `label` element, allowing the text to\n * flow along a path.\n *\n * In order to unset the path for an existing element, call `setTextPath`\n * with `{ enabled: false }` as the second argument.\n *\n * @sample highcharts/members/renderer-textpath/ Text path demonstrated\n *\n * @function Highcharts.SVGElement#setTextPath\n *\n * @param {Highcharts.SVGElement|undefined} path\n * Path to follow. If undefined, it allows changing options for the\n * existing path.\n *\n * @param {Highcharts.DataLabelsTextPathOptionsObject} textPathOptions\n * Options.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n setTextPath(path, textPathOptions) {\n // Defaults\n textPathOptions = merge(true, {\n enabled: true,\n attributes: {\n dy: -5,\n startOffset: '50%',\n textAnchor: 'middle'\n }\n }, textPathOptions);\n const url = this.renderer.url, textWrapper = this.text || this, textPath = textWrapper.textPath, { attributes, enabled } = textPathOptions;\n path = path || (textPath && textPath.path);\n // Remove previously added event\n if (textPath) {\n textPath.undo();\n }\n if (path && enabled) {\n const undo = addEvent(textWrapper, 'afterModifyTree', (e) => {\n if (path && enabled) {\n // Set ID for the path\n let textPathId = path.attr('id');\n if (!textPathId) {\n path.attr('id', textPathId = uniqueKey());\n }\n // Set attributes for the \n const textAttribs = {\n // dx/dy options must by set on (parent), the\n // rest should be set on \n x: 0,\n y: 0\n };\n if (defined(attributes.dx)) {\n textAttribs.dx = attributes.dx;\n delete attributes.dx;\n }\n if (defined(attributes.dy)) {\n textAttribs.dy = attributes.dy;\n delete attributes.dy;\n }\n textWrapper.attr(textAttribs);\n // Handle label properties\n this.attr({ transform: '' });\n if (this.box) {\n this.box = this.box.destroy();\n }\n // Wrap the nodes in a textPath\n const children = e.nodes.slice(0);\n e.nodes.length = 0;\n e.nodes[0] = {\n tagName: 'textPath',\n attributes: extend(attributes, {\n 'text-anchor': attributes.textAnchor,\n href: `${url}#${textPathId}`\n }),\n children\n };\n }\n });\n // Set the reference\n textWrapper.textPath = { path, undo };\n }\n else {\n textWrapper.attr({ dx: 0, dy: 0 });\n delete textWrapper.textPath;\n }\n if (this.added) {\n // Rebuild text after added\n textWrapper.textCache = '';\n this.renderer.buildText(textWrapper);\n }\n return this;\n }\n /**\n * Add a shadow to the element. In styled mode, this method is not used,\n * instead use `defs` and filters.\n *\n * @example\n * renderer.rect(10, 100, 100, 100)\n * .attr({ fill: 'red' })\n * .shadow(true);\n *\n * @function Highcharts.SVGElement#shadow\n *\n * @param {boolean|Highcharts.ShadowOptionsObject} [shadowOptions] The\n * shadow options. If `true`, the default options are applied. If\n * `false`, the current shadow will be removed.\n *\n * @return {Highcharts.SVGElement} Returns the SVGElement for chaining.\n */\n shadow(shadowOptions) {\n var _a;\n const { renderer } = this, options = merge(((_a = this.parentGroup) === null || _a === void 0 ? void 0 : _a.rotation) === 90 ? {\n offsetX: -1,\n offsetY: -1\n } : {}, isObject(shadowOptions) ? shadowOptions : {}), id = renderer.shadowDefinition(options);\n return this.attr({\n filter: shadowOptions ?\n `url(${renderer.url}#${id})` :\n 'none'\n });\n }\n /**\n * Show the element after it has been hidden.\n *\n * @function Highcharts.SVGElement#show\n *\n * @param {boolean} [inherit=true]\n * Set the visibility attribute to `inherit` rather than `visible`.\n * The difference is that an element with `visibility=\"visible\"`\n * will be visible even if the parent is hidden.\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n show(inherit = true) {\n return this.attr({ visibility: inherit ? 'inherit' : 'visible' });\n }\n /**\n * Set the stroke-width and record it on the SVGElement\n *\n * @private\n * @function Highcharts.SVGElement#strokeSetter\n * @param {number|string|ColorType} value\n * @param {string} key\n * @param {Highcharts.SVGDOMElement} element\n */\n 'stroke-widthSetter'(value, key, element) {\n // Record it for quick access in getter\n this[key] = value;\n element.setAttribute(key, value);\n }\n /**\n * Get the computed stroke width in pixel values. This is used extensively\n * when drawing shapes to ensure the shapes are rendered crisp and\n * positioned correctly relative to each other. Using\n * `shape-rendering: crispEdges` leaves us less control over positioning,\n * for example when we want to stack columns next to each other, or position\n * things pixel-perfectly within the plot box.\n *\n * The common pattern when placing a shape is:\n * - Create the SVGElement and add it to the DOM. In styled mode, it will\n * now receive a stroke width from the style sheet. In classic mode we\n * will add the `stroke-width` attribute.\n * - Read the computed `elem.strokeWidth()`.\n * - Place it based on the stroke width.\n *\n * @function Highcharts.SVGElement#strokeWidth\n *\n * @return {number}\n * The stroke width in pixels. Even if the given stroke widtch (in CSS or by\n * attributes) is based on `em` or other units, the pixel size is returned.\n */\n strokeWidth() {\n // In non-styled mode, read the stroke width as set by .attr\n if (!this.renderer.styledMode) {\n return this['stroke-width'] || 0;\n }\n // In styled mode, read computed stroke width\n const val = this.getStyle('stroke-width');\n let ret = 0, dummy;\n // Read pixel values directly\n if (val.indexOf('px') === val.length - 2) {\n ret = pInt(val);\n // Other values like em, pt etc need to be measured\n }\n else if (val !== '') {\n dummy = doc.createElementNS(SVG_NS, 'rect');\n attr(dummy, {\n width: val,\n 'stroke-width': 0\n });\n this.element.parentNode.appendChild(dummy);\n ret = dummy.getBBox().width;\n dummy.parentNode.removeChild(dummy);\n }\n return ret;\n }\n /**\n * If one of the symbol size affecting parameters are changed,\n * check all the others only once for each call to an element's\n * .attr() method\n *\n * @private\n * @function Highcharts.SVGElement#symbolAttr\n *\n * @param {Highcharts.SVGAttributes} hash\n * The attributes to set.\n */\n symbolAttr(hash) {\n const wrapper = this;\n SVGElement.symbolCustomAttribs.forEach(function (key) {\n wrapper[key] = pick(hash[key], wrapper[key]);\n });\n wrapper.attr({\n d: wrapper.renderer.symbols[wrapper.symbolName](wrapper.x, wrapper.y, wrapper.width, wrapper.height, wrapper)\n });\n }\n /**\n * @private\n * @function Highcharts.SVGElement#textSetter\n * @param {string} value\n */\n textSetter(value) {\n if (value !== this.textStr) {\n // Delete size caches when the text changes\n // delete this.bBox; // old code in series-label\n delete this.textPxLength;\n this.textStr = value;\n if (this.added) {\n this.renderer.buildText(this);\n }\n }\n }\n /**\n * @private\n * @function Highcharts.SVGElement#titleSetter\n * @param {string} value\n */\n titleSetter(value) {\n const el = this.element;\n const titleNode = el.getElementsByTagName('title')[0] ||\n doc.createElementNS(this.SVG_NS, 'title');\n // Move to first child\n if (el.insertBefore) {\n el.insertBefore(titleNode, el.firstChild);\n }\n else {\n el.appendChild(titleNode);\n }\n // Replace text content and escape markup\n titleNode.textContent =\n // #3276, #3895\n String(pick(value, ''))\n .replace(/<[^>]*>/g, '')\n .replace(/</g, '<')\n .replace(/>/g, '>');\n }\n /**\n * Bring the element to the front. Alternatively, a new zIndex can be set.\n *\n * @sample highcharts/members/element-tofront/\n * Click an element to bring it to front\n *\n * @function Highcharts.SVGElement#toFront\n *\n * @return {Highcharts.SVGElement}\n * Returns the SVGElement for chaining.\n */\n toFront() {\n const element = this.element;\n element.parentNode.appendChild(element);\n return this;\n }\n /**\n * Move an object and its children by x and y values.\n *\n * @function Highcharts.SVGElement#translate\n *\n * @param {number} x\n * The x value.\n *\n * @param {number} y\n * The y value.\n *\n * @return {Highcharts.SVGElement}\n * Translated element.\n */\n translate(x, y) {\n return this.attr({\n translateX: x,\n translateY: y\n });\n }\n /**\n * Update the transform attribute based on internal properties. Deals with\n * the custom `translateX`, `translateY`, `rotation`, `scaleX` and `scaleY`\n * attributes and updates the SVG `transform` attribute.\n *\n * @private\n * @function Highcharts.SVGElement#updateTransform\n */\n updateTransform() {\n const { element, matrix, rotation = 0, scaleX, scaleY, translateX = 0, translateY = 0 } = this;\n // Apply translate. Nearly all transformed elements have translation,\n // so instead of checking for translate = 0, do it always (#1767,\n // #1846).\n const transform = ['translate(' + translateX + ',' + translateY + ')'];\n // apply matrix\n if (defined(matrix)) {\n transform.push('matrix(' + matrix.join(',') + ')');\n }\n // Apply rotation\n if (rotation) { // text rotation or inverted chart\n transform.push('rotate(' + rotation + ' ' +\n pick(this.rotationOriginX, element.getAttribute('x'), 0) +\n ' ' +\n pick(this.rotationOriginY, element.getAttribute('y') || 0) + ')');\n }\n // apply scale\n if (defined(scaleX) || defined(scaleY)) {\n transform.push('scale(' + pick(scaleX, 1) + ' ' + pick(scaleY, 1) + ')');\n }\n if (transform.length && !(this.text || this).textPath) {\n element.setAttribute('transform', transform.join(' '));\n }\n }\n /**\n * @private\n * @function Highcharts.SVGElement#visibilitySetter\n *\n * @param {string} value\n *\n * @param {string} key\n *\n * @param {Highcharts.SVGDOMElement} element\n *\n */\n visibilitySetter(value, key, element) {\n // IE9-11 doesn't handle visibilty:inherit well, so we remove the\n // attribute instead (#2881, #3909)\n if (value === 'inherit') {\n element.removeAttribute(key);\n }\n else if (this[key] !== value) { // #6747\n element.setAttribute(key, value);\n }\n this[key] = value;\n }\n /**\n * @private\n * @function Highcharts.SVGElement#xGetter\n */\n xGetter(key) {\n if (this.element.nodeName === 'circle') {\n if (key === 'x') {\n key = 'cx';\n }\n else if (key === 'y') {\n key = 'cy';\n }\n }\n return this._defaultGetter(key);\n }\n /**\n * @private\n * @function Highcharts.SVGElement#zIndexSetter\n */\n zIndexSetter(value, key) {\n const renderer = this.renderer, parentGroup = this.parentGroup, parentWrapper = parentGroup || renderer, parentNode = parentWrapper.element || renderer.box, element = this.element, svgParent = parentNode === renderer.box;\n let childNodes, otherElement, otherZIndex, inserted = false, undefinedOtherZIndex, run = this.added, i;\n if (defined(value)) {\n // So we can read it for other elements in the group\n element.setAttribute('data-z-index', value);\n value = +value;\n if (this[key] === value) {\n // Only update when needed (#3865)\n run = false;\n }\n }\n else if (defined(this[key])) {\n element.removeAttribute('data-z-index');\n }\n this[key] = value;\n // Insert according to this and other elements' zIndex. Before .add() is\n // called, nothing is done. Then on add, or by later calls to\n // zIndexSetter, the node is placed on the right place in the DOM.\n if (run) {\n value = this.zIndex;\n if (value && parentGroup) {\n parentGroup.handleZ = true;\n }\n childNodes = parentNode.childNodes;\n for (i = childNodes.length - 1; i >= 0 && !inserted; i--) {\n otherElement = childNodes[i];\n otherZIndex = otherElement.getAttribute('data-z-index');\n undefinedOtherZIndex = !defined(otherZIndex);\n if (otherElement !== element) {\n if (\n // Negative zIndex versus no zIndex:\n // On all levels except the highest. If the parent is\n // , then we don't want to put items before \n // or \n value < 0 &&\n undefinedOtherZIndex &&\n !svgParent &&\n !i) {\n parentNode.insertBefore(element, childNodes[i]);\n inserted = true;\n }\n else if (\n // Insert after the first element with a lower zIndex\n pInt(otherZIndex) <= value ||\n // If negative zIndex, add this before first undefined\n // zIndex element\n (undefinedOtherZIndex &&\n (!defined(value) || value >= 0))) {\n parentNode.insertBefore(element, childNodes[i + 1]);\n inserted = true;\n }\n }\n }\n if (!inserted) {\n parentNode.insertBefore(element, childNodes[svgParent ? 3 : 0]);\n inserted = true;\n }\n }\n return inserted;\n }\n }\n // Custom attributes used for symbols, these should be filtered out when\n // setting SVGElement attributes (#9375).\n SVGElement.symbolCustomAttribs = [\n 'anchorX',\n 'anchorY',\n 'clockwise',\n 'end',\n 'height',\n 'innerR',\n 'r',\n 'start',\n 'width',\n 'x',\n 'y'\n ];\n // Some shared setters and getters\n SVGElement.prototype.strokeSetter = SVGElement.prototype.fillSetter;\n SVGElement.prototype.yGetter = SVGElement.prototype.xGetter;\n SVGElement.prototype.matrixSetter =\n SVGElement.prototype.rotationOriginXSetter =\n SVGElement.prototype.rotationOriginYSetter =\n SVGElement.prototype.rotationSetter =\n SVGElement.prototype.scaleXSetter =\n SVGElement.prototype.scaleYSetter =\n SVGElement.prototype.translateXSetter =\n SVGElement.prototype.translateYSetter =\n SVGElement.prototype.verticalAlignSetter = function (value, key) {\n this[key] = value;\n this.doTransform = true;\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Reference to the global SVGElement class as a workaround for a name conflict\n * in the Highcharts namespace.\n *\n * @global\n * @typedef {global.SVGElement} GlobalSVGElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The horizontal alignment of an element.\n *\n * @typedef {\"center\"|\"left\"|\"right\"} Highcharts.AlignValue\n */\n /**\n * Options to align the element relative to the chart or another box.\n *\n * @interface Highcharts.AlignObject\n */ /**\n * Horizontal alignment. Can be one of `left`, `center` and `right`.\n *\n * @name Highcharts.AlignObject#align\n * @type {Highcharts.AlignValue|undefined}\n *\n * @default left\n */ /**\n * Vertical alignment. Can be one of `top`, `middle` and `bottom`.\n *\n * @name Highcharts.AlignObject#verticalAlign\n * @type {Highcharts.VerticalAlignValue|undefined}\n *\n * @default top\n */ /**\n * Horizontal pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#x\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Vertical pixel offset from alignment.\n *\n * @name Highcharts.AlignObject#y\n * @type {number|undefined}\n *\n * @default 0\n */ /**\n * Use the `transform` attribute with translateX and translateY custom\n * attributes to align this elements rather than `x` and `y` attributes.\n *\n * @name Highcharts.AlignObject#alignByTranslate\n * @type {boolean|undefined}\n *\n * @default false\n */\n /**\n * Bounding box of an element.\n *\n * @interface Highcharts.BBoxObject\n * @extends Highcharts.PositionObject\n */ /**\n * Height of the bounding box.\n *\n * @name Highcharts.BBoxObject#height\n * @type {number}\n */ /**\n * Width of the bounding box.\n *\n * @name Highcharts.BBoxObject#width\n * @type {number}\n */ /**\n * Horizontal position of the bounding box.\n *\n * @name Highcharts.BBoxObject#x\n * @type {number}\n */ /**\n * Vertical position of the bounding box.\n *\n * @name Highcharts.BBoxObject#y\n * @type {number}\n */\n /**\n * An object of key-value pairs for SVG attributes. Attributes in Highcharts\n * elements for the most parts correspond to SVG, but some are specific to\n * Highcharts, like `zIndex`, `rotation`, `rotationOriginX`,\n * `rotationOriginY`, `translateX`, `translateY`, `scaleX` and `scaleY`. SVG\n * attributes containing a hyphen are _not_ camel-cased, they should be\n * quoted to preserve the hyphen.\n *\n * @example\n * {\n * 'stroke': '#ff0000', // basic\n * 'stroke-width': 2, // hyphenated\n * 'rotation': 45 // custom\n * 'd': ['M', 10, 10, 'L', 30, 30, 'z'] // path definition, note format\n * }\n *\n * @interface Highcharts.SVGAttributes\n */ /**\n * @name Highcharts.SVGAttributes#[key:string]\n * @type {*}\n */ /**\n * @name Highcharts.SVGAttributes#d\n * @type {string|Highcharts.SVGPathArray|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dx\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#dy\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#fill\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#matrix\n * @type {Array|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotation\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#rotationOriginY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#scaleY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#stroke\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#style\n * @type {string|Highcharts.CSSObject|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateX\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#translateY\n * @type {number|undefined}\n */ /**\n * @name Highcharts.SVGAttributes#zIndex\n * @type {number|undefined}\n */\n /**\n * An SVG DOM element. The type is a reference to the regular SVGElement in the\n * global scope.\n *\n * @typedef {globals.GlobalSVGElement} Highcharts.SVGDOMElement\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/SVGElement\n */\n /**\n * The vertical alignment of an element.\n *\n * @typedef {\"bottom\"|\"middle\"|\"top\"} Highcharts.VerticalAlignValue\n */\n ''; // keeps doclets above in JS file\n\n return SVGElement;\n });\n _registerModule(_modules, 'Core/Renderer/RendererRegistry.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var RendererRegistry;\n (function (RendererRegistry) {\n /* *\n *\n * Constants\n *\n * */\n RendererRegistry.rendererTypes = {};\n /* *\n *\n * Variables\n *\n * */\n let defaultRenderer;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Gets a registered renderer class. If no renderer type is provided or the\n * requested renderer was not founded, the default renderer is returned.\n *\n * @param {string} [rendererType]\n * Renderer type or the default renderer.\n *\n * @return {Highcharts.Class}\n * Returns the requested renderer class or the default renderer class.\n */\n function getRendererType(rendererType = defaultRenderer) {\n return (RendererRegistry.rendererTypes[rendererType] || RendererRegistry.rendererTypes[defaultRenderer]);\n }\n RendererRegistry.getRendererType = getRendererType;\n /**\n * Register a renderer class.\n *\n * @param {string} rendererType\n * Renderer type to register.\n *\n * @param {Highcharts.Class} rendererClass\n * Returns the requested renderer class or the default renderer class.\n *\n * @param {boolean} setAsDefault\n * Sets the renderer class as the default renderer.\n */\n function registerRendererType(rendererType, rendererClass, setAsDefault) {\n RendererRegistry.rendererTypes[rendererType] = rendererClass;\n if (!defaultRenderer || setAsDefault) {\n defaultRenderer = rendererType;\n H.Renderer = rendererClass; // compatibility\n }\n }\n RendererRegistry.registerRendererType = registerRendererType;\n })(RendererRegistry || (RendererRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return RendererRegistry;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGLabel.js', [_modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, extend, isNumber, merge, pick, removeEvent } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG label to render text.\n * @private\n * @class\n * @name Highcharts.SVGLabel\n * @augments Highcharts.SVGElement\n */\n class SVGLabel extends SVGElement {\n /* *\n *\n * Constructor\n *\n * */\n constructor(renderer, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n super();\n this.paddingLeftSetter = this.paddingSetter;\n this.paddingRightSetter = this.paddingSetter;\n this.init(renderer, 'g');\n this.textStr = str;\n this.x = x;\n this.y = y;\n this.anchorX = anchorX;\n this.anchorY = anchorY;\n this.baseline = baseline;\n this.className = className;\n this.addClass(className === 'button' ?\n 'highcharts-no-tooltip' :\n 'highcharts-label');\n if (className) {\n this.addClass('highcharts-' + className);\n }\n // Create the text element. An undefined text content prevents redundant\n // box calculation (#16121)\n this.text = renderer.text(void 0, 0, 0, useHTML).attr({ zIndex: 1 });\n // Validate the shape argument\n let hasBGImage;\n if (typeof shape === 'string') {\n hasBGImage = /^url\\((.*?)\\)$/.test(shape);\n if (hasBGImage || this.renderer.symbols[shape]) {\n this.symbolKey = shape;\n }\n }\n this.bBox = SVGLabel.emptyBBox;\n this.padding = 3;\n this.baselineOffset = 0;\n this.needsBox = renderer.styledMode || hasBGImage;\n this.deferredAttr = {};\n this.alignFactor = 0;\n }\n /* *\n *\n * Functions\n *\n * */\n alignSetter(value) {\n const alignFactor = ({\n left: 0,\n center: 0.5,\n right: 1\n })[value];\n if (alignFactor !== this.alignFactor) {\n this.alignFactor = alignFactor;\n // Bounding box exists, means we're dynamically changing\n if (this.bBox && isNumber(this.xSetting)) {\n this.attr({ x: this.xSetting }); // #5134\n }\n }\n }\n anchorXSetter(value, key) {\n this.anchorX = value;\n this.boxAttr(key, Math.round(value) - this.getCrispAdjust() - this.xSetting);\n }\n anchorYSetter(value, key) {\n this.anchorY = value;\n this.boxAttr(key, value - this.ySetting);\n }\n /*\n * Set a box attribute, or defer it if the box is not yet created\n */\n boxAttr(key, value) {\n if (this.box) {\n this.box.attr(key, value);\n }\n else {\n this.deferredAttr[key] = value;\n }\n }\n /*\n * Pick up some properties and apply them to the text instead of the\n * wrapper.\n */\n css(styles) {\n if (styles) {\n const textStyles = {};\n // Create a copy to avoid altering the original object\n // (#537)\n styles = merge(styles);\n SVGLabel.textProps.forEach((prop) => {\n if (typeof styles[prop] !== 'undefined') {\n textStyles[prop] = styles[prop];\n delete styles[prop];\n }\n });\n this.text.css(textStyles);\n // Update existing text, box (#9400, #12163, #18212)\n if ('fontSize' in textStyles || 'fontWeight' in textStyles) {\n this.updateTextPadding();\n }\n else if ('width' in textStyles || 'textOverflow' in textStyles) {\n this.updateBoxSize();\n }\n }\n return SVGElement.prototype.css.call(this, styles);\n }\n /*\n * Destroy and release memory.\n */\n destroy() {\n // Added by button implementation\n removeEvent(this.element, 'mouseenter');\n removeEvent(this.element, 'mouseleave');\n if (this.text) {\n this.text.destroy();\n }\n if (this.box) {\n this.box = this.box.destroy();\n }\n // Call base implementation to destroy the rest\n SVGElement.prototype.destroy.call(this);\n return void 0;\n }\n fillSetter(value, key) {\n if (value) {\n this.needsBox = true;\n }\n // for animation getter (#6776)\n this.fill = value;\n this.boxAttr(key, value);\n }\n /*\n * Return the bounding box of the box, not the group.\n */\n getBBox() {\n // If we have a text string and the DOM bBox was 0, it typically means\n // that the label was first rendered hidden, so we need to update the\n // bBox (#15246)\n if (this.textStr && this.bBox.width === 0 && this.bBox.height === 0) {\n this.updateBoxSize();\n }\n const padding = this.padding;\n const paddingLeft = pick(this.paddingLeft, padding);\n return {\n width: this.width,\n height: this.height,\n x: this.bBox.x - paddingLeft,\n y: this.bBox.y - padding\n };\n }\n getCrispAdjust() {\n return this.renderer.styledMode && this.box ?\n this.box.strokeWidth() % 2 / 2 :\n (this['stroke-width'] ? parseInt(this['stroke-width'], 10) : 0) % 2 / 2;\n }\n heightSetter(value) {\n this.heightSetting = value;\n }\n /*\n * After the text element is added, get the desired size of the border\n * box and add it before the text in the DOM.\n */\n onAdd() {\n this.text.add(this);\n this.attr({\n // Alignment is available now (#3295, 0 not rendered if given\n // as a value)\n text: pick(this.textStr, ''),\n x: this.x || 0,\n y: this.y || 0\n });\n if (this.box && defined(this.anchorX)) {\n this.attr({\n anchorX: this.anchorX,\n anchorY: this.anchorY\n });\n }\n }\n paddingSetter(value, key) {\n if (!isNumber(value)) {\n this[key] = void 0;\n }\n else if (value !== this[key]) {\n this[key] = value;\n this.updateTextPadding();\n }\n }\n rSetter(value, key) {\n this.boxAttr(key, value);\n }\n strokeSetter(value, key) {\n // for animation getter (#6776)\n this.stroke = value;\n this.boxAttr(key, value);\n }\n 'stroke-widthSetter'(value, key) {\n if (value) {\n this.needsBox = true;\n }\n this['stroke-width'] = value;\n this.boxAttr(key, value);\n }\n 'text-alignSetter'(value) {\n this.textAlign = value;\n }\n textSetter(text) {\n if (typeof text !== 'undefined') {\n // Must use .attr to ensure transforms are done (#10009)\n this.text.attr({ text });\n }\n this.updateTextPadding();\n }\n /*\n * This function runs after the label is added to the DOM (when the bounding\n * box is available), and after the text of the label is updated to detect\n * the new bounding box and reflect it in the border box.\n */\n updateBoxSize() {\n const text = this.text, attribs = {}, padding = this.padding, \n // #12165 error when width is null (auto)\n // #12163 when fontweight: bold, recalculate bBox withot cache\n // #3295 && 3514 box failure when string equals 0\n bBox = this.bBox = (((!isNumber(this.widthSetting) ||\n !isNumber(this.heightSetting) ||\n this.textAlign) && defined(text.textStr)) ?\n text.getBBox() :\n SVGLabel.emptyBBox);\n let crispAdjust;\n this.width = this.getPaddedWidth();\n this.height = (this.heightSetting || bBox.height || 0) + 2 * padding;\n const metrics = this.renderer.fontMetrics(text);\n // Update the label-scoped y offset. Math.min because of inline\n // style (#9400)\n this.baselineOffset = padding + Math.min(\n // When applicable, use the font size of the first line (#15707)\n (this.text.firstLineMetrics || metrics).b, \n // When the height is 0, there is no bBox, so go with the font\n // metrics. Highmaps CSS demos.\n bBox.height || Infinity);\n // #15491: Vertical centering\n if (this.heightSetting) {\n this.baselineOffset += (this.heightSetting - metrics.h) / 2;\n }\n if (this.needsBox && !text.textPath) {\n // Create the border box if it is not already present\n if (!this.box) {\n // Symbol definition exists (#5324)\n const box = this.box = this.symbolKey ?\n this.renderer.symbol(this.symbolKey) :\n this.renderer.rect();\n box.addClass(// Don't use label className for buttons\n (this.className === 'button' ?\n '' : 'highcharts-label-box') +\n (this.className ?\n ' highcharts-' + this.className + '-box' : ''));\n box.add(this);\n }\n crispAdjust = this.getCrispAdjust();\n attribs.x = crispAdjust;\n attribs.y = ((this.baseline ? -this.baselineOffset : 0) + crispAdjust);\n // Apply the box attributes\n attribs.width = Math.round(this.width);\n attribs.height = Math.round(this.height);\n this.box.attr(extend(attribs, this.deferredAttr));\n this.deferredAttr = {};\n }\n }\n /*\n * This function runs after setting text or padding, but only if padding\n * is changed.\n */\n updateTextPadding() {\n const text = this.text;\n if (!text.textPath) {\n this.updateBoxSize();\n // Determine y based on the baseline\n const textY = this.baseline ? 0 : this.baselineOffset;\n let textX = pick(this.paddingLeft, this.padding);\n // compensate for alignment\n if (defined(this.widthSetting) &&\n this.bBox &&\n (this.textAlign === 'center' || this.textAlign === 'right')) {\n textX += { center: 0.5, right: 1 }[this.textAlign] * (this.widthSetting - this.bBox.width);\n }\n // update if anything changed\n if (textX !== text.x || textY !== text.y) {\n text.attr('x', textX);\n // #8159 - prevent misplaced data labels in treemap\n // (useHTML: true)\n if (text.hasBoxWidthChanged) {\n this.bBox = text.getBBox(true);\n }\n if (typeof textY !== 'undefined') {\n text.attr('y', textY);\n }\n }\n // record current values\n text.x = textX;\n text.y = textY;\n }\n }\n widthSetter(value) {\n // width:auto => null\n this.widthSetting = isNumber(value) ? value : void 0;\n }\n getPaddedWidth() {\n const padding = this.padding;\n const paddingLeft = pick(this.paddingLeft, padding);\n const paddingRight = pick(this.paddingRight, padding);\n return ((this.widthSetting || this.bBox.width || 0) +\n paddingLeft +\n paddingRight);\n }\n xSetter(value) {\n this.x = value; // for animation getter\n if (this.alignFactor) {\n value -= this.alignFactor * this.getPaddedWidth();\n // Force animation even when setting to the same value (#7898)\n this['forceAnimate:x'] = true;\n }\n this.xSetting = Math.round(value);\n this.attr('translateX', this.xSetting);\n }\n ySetter(value) {\n this.ySetting = this.y = Math.round(value);\n this.attr('translateY', this.ySetting);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n SVGLabel.emptyBBox = {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n /**\n * For labels, these CSS properties are applied to the `text` node directly.\n *\n * @private\n * @name Highcharts.SVGLabel#textProps\n * @type {Array}\n */\n SVGLabel.textProps = [\n 'color', 'direction', 'fontFamily', 'fontSize', 'fontStyle',\n 'fontWeight', 'lineHeight', 'textAlign', 'textDecoration',\n 'textOutline', 'textOverflow', 'whiteSpace', 'width'\n ];\n /* *\n *\n * Default Export\n *\n * */\n\n return SVGLabel;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/Symbols.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, isNumber, pick } = U;\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable require-jsdoc, valid-jsdoc */\n function arc(cx, cy, w, h, options) {\n const arc = [];\n if (options) {\n const start = options.start || 0, rx = pick(options.r, w), ry = pick(options.r, h || w), proximity = 0.001, fullCircle = (Math.abs((options.end || 0) - start - 2 * Math.PI) <\n proximity), \n // Substract a small number to prevent cos and sin of start\n // and end from becoming equal on 360 arcs (related: #1561)\n end = (options.end || 0) - proximity, innerRadius = options.innerR, open = pick(options.open, fullCircle), cosStart = Math.cos(start), sinStart = Math.sin(start), cosEnd = Math.cos(end), sinEnd = Math.sin(end), \n // Proximity takes care of rounding errors around PI (#6971)\n longArc = pick(options.longArc, end - start - Math.PI < proximity ? 0 : 1);\n let arcSegment = [\n 'A',\n rx,\n ry,\n 0,\n longArc,\n pick(options.clockwise, 1),\n cx + rx * cosEnd,\n cy + ry * sinEnd\n ];\n arcSegment.params = { start, end, cx, cy }; // Memo for border radius\n arc.push([\n 'M',\n cx + rx * cosStart,\n cy + ry * sinStart\n ], arcSegment);\n if (defined(innerRadius)) {\n arcSegment = [\n 'A',\n innerRadius,\n innerRadius,\n 0,\n longArc,\n // Clockwise - opposite to the outer arc clockwise\n defined(options.clockwise) ? 1 - options.clockwise : 0,\n cx + innerRadius * cosStart,\n cy + innerRadius * sinStart\n ];\n // Memo for border radius\n arcSegment.params = {\n start: end,\n end: start,\n cx,\n cy\n };\n arc.push(open ?\n [\n 'M',\n cx + innerRadius * cosEnd,\n cy + innerRadius * sinEnd\n ] : [\n 'L',\n cx + innerRadius * cosEnd,\n cy + innerRadius * sinEnd\n ], arcSegment);\n }\n if (!open) {\n arc.push(['Z']);\n }\n }\n return arc;\n }\n /**\n * Callout shape used for default tooltips.\n */\n function callout(x, y, w, h, options) {\n const arrowLength = 6, halfDistance = 6, r = Math.min((options && options.r) || 0, w, h), safeDistance = r + halfDistance, anchorX = options && options.anchorX, anchorY = options && options.anchorY || 0;\n const path = roundedRect(x, y, w, h, { r });\n if (!isNumber(anchorX)) {\n return path;\n }\n // Anchor on right side\n if (x + anchorX >= w) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(3, 1, ['L', x + w, anchorY - halfDistance], ['L', x + w + arrowLength, anchorY], ['L', x + w, anchorY + halfDistance], ['L', x + w, y + h - r]);\n // Simple connector\n }\n else {\n path.splice(3, 1, ['L', x + w, h / 2], ['L', anchorX, anchorY], ['L', x + w, h / 2], ['L', x + w, y + h - r]);\n }\n // Anchor on left side\n }\n else if (x + anchorX <= 0) {\n // Chevron\n if (anchorY > y + safeDistance &&\n anchorY < y + h - safeDistance) {\n path.splice(7, 1, ['L', x, anchorY + halfDistance], ['L', x - arrowLength, anchorY], ['L', x, anchorY - halfDistance], ['L', x, y + r]);\n // Simple connector\n }\n else {\n path.splice(7, 1, ['L', x, h / 2], ['L', anchorX, anchorY], ['L', x, h / 2], ['L', x, y + r]);\n }\n }\n else if ( // replace bottom\n anchorY &&\n anchorY > h &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(5, 1, ['L', anchorX + halfDistance, y + h], ['L', anchorX, y + h + arrowLength], ['L', anchorX - halfDistance, y + h], ['L', x + r, y + h]);\n }\n else if ( // replace top\n anchorY &&\n anchorY < 0 &&\n anchorX > x + safeDistance &&\n anchorX < x + w - safeDistance) {\n path.splice(1, 1, ['L', anchorX - halfDistance, y], ['L', anchorX, y - arrowLength], ['L', anchorX + halfDistance, y], ['L', w - r, y]);\n }\n return path;\n }\n function circle(x, y, w, h) {\n // Return a full arc\n return arc(x + w / 2, y + h / 2, w / 2, h / 2, {\n start: Math.PI * 0.5,\n end: Math.PI * 2.5,\n open: false\n });\n }\n function diamond(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h / 2],\n ['L', x + w / 2, y + h],\n ['L', x, y + h / 2],\n ['Z']\n ];\n }\n // #15291\n function rect(x, y, w, h, options) {\n if (options && options.r) {\n return roundedRect(x, y, w, h, options);\n }\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function roundedRect(x, y, w, h, options) {\n const r = (options === null || options === void 0 ? void 0 : options.r) || 0;\n return [\n ['M', x + r, y],\n ['L', x + w - r, y],\n ['A', r, r, 0, 0, 1, x + w, y + r],\n ['L', x + w, y + h - r],\n ['A', r, r, 0, 0, 1, x + w - r, y + h],\n ['L', x + r, y + h],\n ['A', r, r, 0, 0, 1, x, y + h - r],\n ['L', x, y + r],\n ['A', r, r, 0, 0, 1, x + r, y],\n ['Z'] // top-left corner\n ];\n }\n function triangle(x, y, w, h) {\n return [\n ['M', x + w / 2, y],\n ['L', x + w, y + h],\n ['L', x, y + h],\n ['Z']\n ];\n }\n function triangleDown(x, y, w, h) {\n return [\n ['M', x, y],\n ['L', x + w, y],\n ['L', x + w / 2, y + h],\n ['Z']\n ];\n }\n const Symbols = {\n arc,\n callout,\n circle,\n diamond,\n rect,\n roundedRect,\n square: rect,\n triangle,\n 'triangle-down': triangleDown\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return Symbols;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/TextBuilder.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (AST, H, U) {\n /* *\n *\n * (c) 2010-2020 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { doc, SVG_NS, win } = H;\n const { attr, extend, fireEvent, isString, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * SVG Text Builder\n * @private\n * @class\n * @name Highcharts.TextBuilder\n */\n class TextBuilder {\n constructor(svgElement) {\n const textStyles = svgElement.styles;\n this.renderer = svgElement.renderer;\n this.svgElement = svgElement;\n this.width = svgElement.textWidth;\n this.textLineHeight = textStyles && textStyles.lineHeight;\n this.textOutline = textStyles && textStyles.textOutline;\n this.ellipsis = Boolean(textStyles && textStyles.textOverflow === 'ellipsis');\n this.noWrap = Boolean(textStyles && textStyles.whiteSpace === 'nowrap');\n }\n /**\n * Build an SVG representation of the pseudo HTML given in the object's\n * svgElement.\n *\n * @private\n *\n * @return {void}.\n */\n buildSVG() {\n const wrapper = this.svgElement, textNode = wrapper.element, renderer = wrapper.renderer, textStr = pick(wrapper.textStr, '').toString(), hasMarkup = textStr.indexOf('<') !== -1, childNodes = textNode.childNodes, tempParent = !wrapper.added && renderer.box, regexMatchBreaks = //g, \n // The buildText code is quite heavy, so if we're not changing\n // something that affects the text, skip it (#6113).\n textCache = [\n textStr,\n this.ellipsis,\n this.noWrap,\n this.textLineHeight,\n this.textOutline,\n wrapper.getStyle('font-size'),\n this.width\n ].join(',');\n if (textCache === wrapper.textCache) {\n return;\n }\n wrapper.textCache = textCache;\n delete wrapper.actualWidth;\n // Remove old text\n for (let i = childNodes.length; i--;) {\n textNode.removeChild(childNodes[i]);\n }\n // Simple strings, add text directly and return\n if (!hasMarkup &&\n !this.ellipsis &&\n !this.width &&\n !wrapper.textPath &&\n (textStr.indexOf(' ') === -1 ||\n (this.noWrap && !regexMatchBreaks.test(textStr)))) {\n textNode.appendChild(doc.createTextNode(this.unescapeEntities(textStr)));\n // Complex strings, add more logic\n }\n else if (textStr !== '') {\n if (tempParent) {\n // attach it to the DOM to read offset width and font size\n tempParent.appendChild(textNode);\n }\n // Step 1. Parse the markup safely and directly into a tree\n // structure.\n const ast = new AST(textStr);\n // Step 2. Do as many as we can of the modifications to the tree\n // structure before it is added to the DOM\n this.modifyTree(ast.nodes);\n ast.addToDOM(textNode);\n // Step 3. Some modifications can't be done until the structure is\n // in the DOM, because we need to read computed metrics.\n this.modifyDOM();\n // Add title if an ellipsis was added\n if (this.ellipsis &&\n (textNode.textContent || '').indexOf('\\u2026') !== -1) {\n wrapper.attr('title', this.unescapeEntities(wrapper.textStr || '', ['<', '>']) // #7179\n );\n }\n if (tempParent) {\n tempParent.removeChild(textNode);\n }\n }\n // Apply the text outline\n if (isString(this.textOutline) && wrapper.applyTextOutline) {\n wrapper.applyTextOutline(this.textOutline);\n }\n }\n /**\n * Modify the DOM of the generated SVG structure. This function only does\n * operations that cannot be done until the elements are attached to the\n * DOM, like doing layout based on rendered metrics of the added elements.\n *\n * @private\n *\n */\n modifyDOM() {\n const wrapper = this.svgElement;\n const x = attr(wrapper.element, 'x');\n wrapper.firstLineMetrics = void 0;\n // Remove empty tspans (including breaks) from the beginning because\n // SVG's getBBox doesn't count empty lines. The use case is tooltip\n // where the header is empty. By doing this in the DOM rather than in\n // the AST, we can inspect the textContent directly and don't have to\n // recurse down to look for valid content.\n let firstChild;\n while ((firstChild = wrapper.element.firstChild)) {\n if (/^[\\s\\u200B]*$/.test(firstChild.textContent || ' ')) {\n wrapper.element.removeChild(firstChild);\n }\n else {\n break;\n }\n }\n // Modify hard line breaks by applying the rendered line height\n [].forEach.call(wrapper.element.querySelectorAll('tspan.highcharts-br'), (br, i) => {\n if (br.nextSibling && br.previousSibling) { // #5261\n if (i === 0 && br.previousSibling.nodeType === 1) {\n wrapper.firstLineMetrics = wrapper.renderer\n .fontMetrics(br.previousSibling);\n }\n attr(br, {\n // Since the break is inserted in front of the next\n // line, we need to use the next sibling for the line\n // height\n dy: this.getLineHeight(br.nextSibling),\n x\n });\n }\n });\n // Constrain the line width, either by ellipsis or wrapping\n const width = this.width || 0;\n if (!width) {\n return;\n }\n // Insert soft line breaks into each text node\n const modifyTextNode = (textNode, parentElement) => {\n const text = textNode.textContent || '';\n const words = text\n .replace(/([^\\^])-/g, '$1- ') // Split on hyphens\n // .trim()\n .split(' '); // #1273\n const hasWhiteSpace = !this.noWrap && (words.length > 1 || wrapper.element.childNodes.length > 1);\n const dy = this.getLineHeight(parentElement);\n let lineNo = 0;\n let startAt = wrapper.actualWidth;\n if (this.ellipsis) {\n if (text) {\n this.truncate(textNode, text, void 0, 0, \n // Target width\n Math.max(0, \n // Substract the font face to make room for the\n // ellipsis itself\n width - 0.8 * dy), \n // Build the text to test for\n (text, currentIndex) => text.substring(0, currentIndex) + '\\u2026');\n }\n }\n else if (hasWhiteSpace) {\n const lines = [];\n // Remove preceding siblings in order to make the text length\n // calculation correct in the truncate function\n const precedingSiblings = [];\n while (parentElement.firstChild &&\n parentElement.firstChild !== textNode) {\n precedingSiblings.push(parentElement.firstChild);\n parentElement.removeChild(parentElement.firstChild);\n }\n while (words.length) {\n // Apply the previous line\n if (words.length && !this.noWrap && lineNo > 0) {\n lines.push(textNode.textContent || '');\n textNode.textContent = words.join(' ')\n .replace(/- /g, '-');\n }\n // For each line, truncate the remaining\n // words into the line length.\n this.truncate(textNode, void 0, words, lineNo === 0 ? (startAt || 0) : 0, width, \n // Build the text to test for\n (t, currentIndex) => words\n .slice(0, currentIndex)\n .join(' ')\n .replace(/- /g, '-'));\n startAt = wrapper.actualWidth;\n lineNo++;\n }\n // Reinsert the preceding child nodes\n precedingSiblings.forEach((childNode) => {\n parentElement.insertBefore(childNode, textNode);\n });\n // Insert the previous lines before the original text node\n lines.forEach((line) => {\n // Insert the line\n parentElement.insertBefore(doc.createTextNode(line), textNode);\n // Insert a break\n const br = doc.createElementNS(SVG_NS, 'tspan');\n br.textContent = '\\u200B'; // zero-width space\n attr(br, { dy, x });\n parentElement.insertBefore(br, textNode);\n });\n }\n };\n // Recurse down the DOM tree and handle line breaks for each text node\n const modifyChildren = ((node) => {\n const childNodes = [].slice.call(node.childNodes);\n childNodes.forEach((childNode) => {\n if (childNode.nodeType === win.Node.TEXT_NODE) {\n modifyTextNode(childNode, node);\n }\n else {\n // Reset word-wrap width readings after hard breaks\n if (childNode.className.baseVal\n .indexOf('highcharts-br') !== -1) {\n wrapper.actualWidth = 0;\n }\n // Recurse down to child node\n modifyChildren(childNode);\n }\n });\n });\n modifyChildren(wrapper.element);\n }\n /**\n * Get the rendered line height of a , or pure text node.\n *\n * @param {DOMElementType|Text} node The node to check for\n *\n * @return {number} The rendered line height\n */\n getLineHeight(node) {\n // If the node is a text node, use its parent\n const element = (node.nodeType === win.Node.TEXT_NODE) ?\n node.parentElement :\n node;\n return this.textLineHeight ?\n parseInt(this.textLineHeight.toString(), 10) :\n this.renderer.fontMetrics(element || this.svgElement.element).h;\n }\n /**\n * Transform a pseudo HTML AST node tree into an SVG structure. We do as\n * much heavy lifting as we can here, before doing the final processing in\n * the modifyDOM function. The original data is mutated.\n *\n * @private\n *\n * @param {ASTNode[]} nodes The AST nodes\n *\n */\n modifyTree(nodes) {\n const modifyChild = (node, i) => {\n const { attributes = {}, children, style = {}, tagName } = node, styledMode = this.renderer.styledMode;\n // Apply styling to text tags\n if (tagName === 'b' || tagName === 'strong') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-strong';\n }\n else {\n style.fontWeight = 'bold';\n }\n }\n else if (tagName === 'i' || tagName === 'em') {\n if (styledMode) {\n // eslint-disable-next-line dot-notation\n attributes['class'] = 'highcharts-emphasized';\n }\n else {\n style.fontStyle = 'italic';\n }\n }\n // Modify styling\n if (style && style.color) {\n style.fill = style.color;\n }\n // Handle breaks\n if (tagName === 'br') {\n attributes['class'] = 'highcharts-br'; // eslint-disable-line dot-notation\n node.textContent = '\\u200B'; // zero-width space\n // Trim whitespace off the beginning of new lines\n const nextNode = nodes[i + 1];\n if (nextNode && nextNode.textContent) {\n nextNode.textContent =\n nextNode.textContent.replace(/^ +/gm, '');\n }\n // If an anchor has direct text node children, the text is unable to\n // wrap because there is no `getSubStringLength` function on the\n // element. Therefore we need to wrap the child text node or nodes\n // in a tspan. #16173.\n }\n else if (tagName === 'a' &&\n children &&\n children.some((child) => child.tagName === '#text')) {\n node.children = [{ children, tagName: 'tspan' }];\n }\n if (tagName !== '#text' && tagName !== 'a') {\n node.tagName = 'tspan';\n }\n extend(node, { attributes, style });\n // Recurse\n if (children) {\n children\n .filter((c) => c.tagName !== '#text')\n .forEach(modifyChild);\n }\n };\n nodes.forEach(modifyChild);\n fireEvent(this.svgElement, 'afterModifyTree', { nodes });\n }\n /*\n * Truncate the text node contents to a given length. Used when the css\n * width is set. If the `textOverflow` is `ellipsis`, the text is truncated\n * character by character to the given length. If not, the text is\n * word-wrapped line by line.\n */\n truncate(textNode, text, words, startAt, width, getString) {\n const svgElement = this.svgElement;\n const { renderer, rotation } = svgElement;\n // Cache the lengths to avoid checking the same twice\n const lengths = [];\n // Word wrap cannot be truncated to shorter than one word, ellipsis\n // text can be completely blank.\n let minIndex = words ? 1 : 0;\n let maxIndex = (text || words || '').length;\n let currentIndex = maxIndex;\n let str;\n let actualWidth;\n const getSubStringLength = function (charEnd, concatenatedEnd) {\n // charEnd is used when finding the character-by-character\n // break for ellipsis, concatenatedEnd is used for word-by-word\n // break for word wrapping.\n const end = concatenatedEnd || charEnd;\n const parentNode = textNode.parentNode;\n if (parentNode && typeof lengths[end] === 'undefined') {\n // Modern browsers\n if (parentNode.getSubStringLength) {\n // Fails with DOM exception on unit-tests/legend/members\n // of unknown reason. Desired width is 0, text content\n // is \"5\" and end is 1.\n try {\n lengths[end] = startAt +\n parentNode.getSubStringLength(0, words ? end + 1 : end);\n }\n catch (e) {\n '';\n }\n }\n }\n return lengths[end];\n };\n svgElement.rotation = 0; // discard rotation when computing box\n actualWidth = getSubStringLength(textNode.textContent.length);\n if (startAt + actualWidth > width) {\n // Do a binary search for the index where to truncate the text\n while (minIndex <= maxIndex) {\n currentIndex = Math.ceil((minIndex + maxIndex) / 2);\n // When checking words for word-wrap, we need to build the\n // string and measure the subStringLength at the concatenated\n // word length.\n if (words) {\n str = getString(words, currentIndex);\n }\n actualWidth = getSubStringLength(currentIndex, str && str.length - 1);\n if (minIndex === maxIndex) {\n // Complete\n minIndex = maxIndex + 1;\n }\n else if (actualWidth > width) {\n // Too large. Set max index to current.\n maxIndex = currentIndex - 1;\n }\n else {\n // Within width. Set min index to current.\n minIndex = currentIndex;\n }\n }\n // If max index was 0 it means the shortest possible text was also\n // too large. For ellipsis that means only the ellipsis, while for\n // word wrap it means the whole first word.\n if (maxIndex === 0) {\n // Remove ellipsis\n textNode.textContent = '';\n // If the new text length is one less than the original, we don't\n // need the ellipsis\n }\n else if (!(text && maxIndex === text.length - 1)) {\n textNode.textContent = str || getString(text || words, currentIndex);\n }\n }\n // When doing line wrapping, prepare for the next line by removing the\n // items from this line.\n if (words) {\n words.splice(0, currentIndex);\n }\n svgElement.actualWidth = actualWidth;\n svgElement.rotation = rotation; // Apply rotation again.\n }\n /*\n * Un-escape HTML entities based on the public `renderer.escapes` list\n *\n * @private\n *\n * @param {string} inputStr The string to unescape\n * @param {Array} [except] Exceptions\n *\n * @return {string} The processed string\n */\n unescapeEntities(inputStr, except) {\n objectEach(this.renderer.escapes, function (value, key) {\n if (!except || except.indexOf(value) === -1) {\n inputStr = inputStr.toString().replace(new RegExp(value, 'g'), key);\n }\n });\n return inputStr;\n }\n }\n\n return TextBuilder;\n });\n _registerModule(_modules, 'Core/Renderer/SVG/SVGRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGLabel.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Renderer/SVG/TextBuilder.js'], _modules['Core/Utilities.js']], function (AST, Color, H, RendererRegistry, SVGElement, SVGLabel, Symbols, TextBuilder, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { charts, deg2rad, doc, isFirefox, isMS, isWebKit, noop, SVG_NS, symbolSizes, win } = H;\n const { addEvent, attr, createElement, css, defined, destroyObjectProperties, extend, isArray, isNumber, isObject, isString, merge, pick, pInt, uniqueKey } = U;\n /* *\n *\n * Variables\n *\n * */\n let hasInternalReferenceBug;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Allows direct access to the Highcharts rendering layer in order to draw\n * primitive shapes like circles, rectangles, paths or text directly on a chart,\n * or independent from any chart. The SVGRenderer represents a wrapper object\n * for SVG in modern browsers.\n *\n * An existing chart's renderer can be accessed through {@link Chart.renderer}.\n * The renderer can also be used completely decoupled from a chart.\n *\n * @sample highcharts/members/renderer-on-chart\n * Annotating a chart programmatically.\n * @sample highcharts/members/renderer-basic\n * Independent SVG drawing.\n *\n * @example\n * // Use directly without a chart object.\n * let renderer = new Highcharts.Renderer(parentNode, 600, 400);\n *\n * @class\n * @name Highcharts.SVGRenderer\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode.\n * If it does, it will avoid setting presentational attributes in\n * some cases, but not when set explicitly through `.attr` and `.css`\n * etc.\n */\n class SVGRenderer {\n /* *\n *\n * Constructors\n *\n * */\n constructor(container, width, height, style, forExport, allowHTML, styledMode) {\n /* *\n *\n * Properties\n *\n * */\n this.alignedObjects = void 0;\n /**\n * The root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#box\n * @type {Highcharts.SVGDOMElement}\n */\n this.box = void 0;\n /**\n * The wrapper for the root `svg` node of the renderer.\n *\n * @name Highcharts.SVGRenderer#boxWrapper\n * @type {Highcharts.SVGElement}\n */\n this.boxWrapper = void 0;\n this.cache = void 0;\n this.cacheKeys = void 0;\n this.chartIndex = void 0;\n /**\n * A pointer to the `defs` node of the root SVG.\n *\n * @name Highcharts.SVGRenderer#defs\n * @type {Highcharts.SVGElement}\n */\n this.defs = void 0;\n this.globalAnimation = void 0;\n this.gradients = void 0;\n this.height = void 0;\n this.imgCount = void 0;\n this.style = void 0;\n /**\n * Page url used for internal references.\n *\n * @private\n * @name Highcharts.SVGRenderer#url\n * @type {string}\n */\n this.url = void 0;\n this.width = void 0;\n this.init(container, width, height, style, forExport, allowHTML, styledMode);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the SVGRenderer. Overridable initializer function that takes\n * the same parameters as the constructor.\n *\n * @function Highcharts.SVGRenderer#init\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Where to put the SVG in the web page.\n *\n * @param {number} width\n * The width of the SVG.\n *\n * @param {number} height\n * The height of the SVG.\n *\n * @param {Highcharts.CSSObject} [style]\n * The box style, if not in styleMode\n *\n * @param {boolean} [forExport=false]\n * Whether the rendered content is intended for export.\n *\n * @param {boolean} [allowHTML=true]\n * Whether the renderer is allowed to include HTML text, which will be\n * projected on top of the SVG.\n *\n * @param {boolean} [styledMode=false]\n * Whether the renderer belongs to a chart that is in styled mode. If it\n * does, it will avoid setting presentational attributes in some cases, but\n * not when set explicitly through `.attr` and `.css` etc.\n */\n init(container, width, height, style, forExport, allowHTML, styledMode) {\n const renderer = this, boxWrapper = renderer\n .createElement('svg')\n .attr({\n version: '1.1',\n 'class': 'highcharts-root'\n }), element = boxWrapper.element;\n if (!styledMode) {\n boxWrapper.css(this.getStyle(style));\n }\n container.appendChild(element);\n // Always use ltr on the container, otherwise text-anchor will be\n // flipped and text appear outside labels, buttons, tooltip etc (#3482)\n attr(container, 'dir', 'ltr');\n // For browsers other than IE, add the namespace attribute (#1978)\n if (container.innerHTML.indexOf('xmlns') === -1) {\n attr(element, 'xmlns', this.SVG_NS);\n }\n this.box = element;\n this.boxWrapper = boxWrapper;\n renderer.alignedObjects = [];\n this.url = this.getReferenceURL();\n // Add description\n const desc = this.createElement('desc').add();\n desc.element.appendChild(doc.createTextNode('Created with Highcharts 11.1.0'));\n renderer.defs = this.createElement('defs').add();\n renderer.allowHTML = allowHTML;\n renderer.forExport = forExport;\n renderer.styledMode = styledMode;\n renderer.gradients = {}; // Object where gradient SvgElements are stored\n renderer.cache = {}; // Cache for numerical bounding boxes\n renderer.cacheKeys = [];\n renderer.imgCount = 0;\n renderer.rootFontSize = boxWrapper.getStyle('font-size');\n renderer.setSize(width, height, false);\n // Issue 110 workaround:\n // In Firefox, if a div is positioned by percentage, its pixel position\n // may land between pixels. The container itself doesn't display this,\n // but an SVG element inside this container will be drawn at subpixel\n // precision. In order to draw sharp lines, this must be compensated\n // for. This doesn't seem to work inside iframes though (like in\n // jsFiddle).\n let subPixelFix, rect;\n if (isFirefox && container.getBoundingClientRect) {\n subPixelFix = function () {\n css(container, { left: 0, top: 0 });\n rect = container.getBoundingClientRect();\n css(container, {\n left: (Math.ceil(rect.left) - rect.left) + 'px',\n top: (Math.ceil(rect.top) - rect.top) + 'px'\n });\n };\n // run the fix now\n subPixelFix();\n // run it on resize\n renderer.unSubPixelFix = addEvent(win, 'resize', subPixelFix);\n }\n }\n /**\n * General method for adding a definition to the SVG `defs` tag. Can be used\n * for gradients, fills, filters etc. Styled mode only. A hook for adding\n * general definitions to the SVG's defs tag. Definitions can be referenced\n * from the CSS by its `id`. Read more in\n * [gradients, shadows and patterns](https://www.highcharts.com/docs/chart-design-and-style/gradients-shadows-and-patterns).\n * Styled mode only.\n *\n * @function Highcharts.SVGRenderer#definition\n *\n * @param {Highcharts.ASTNode} def\n * A serialized form of an SVG definition, including children.\n *\n * @return {Highcharts.SVGElement}\n * The inserted node.\n */\n definition(def) {\n const ast = new AST([def]);\n return ast.addToDOM(this.defs.element);\n }\n /**\n * Get the prefix needed for internal URL references to work in certain\n * cases. Some older browser versions had a bug where internal url\n * references in SVG attributes, on the form `url(#some-id)`, would fail if\n * a base tag was present in the page. There were also issues with\n * `history.pushState` related to this prefix.\n *\n * Related issues: #24, #672, #1070, #5244.\n *\n * The affected browsers are:\n * - Chrome <= 53 (May 2018)\n * - Firefox <= 51 (January 2017)\n * - Safari/Mac <= 12.1 (2018 or 2019)\n * - Safari/iOS <= 13\n *\n * @todo Remove this hack when time has passed. All the affected browsers\n * are evergreens, so it is increasingly unlikely that users are affected by\n * the bug.\n *\n * @return {string}\n * The prefix to use. An empty string for modern browsers.\n */\n getReferenceURL() {\n if ((isFirefox || isWebKit) &&\n doc.getElementsByTagName('base').length) {\n // Detect if a clip path is taking effect by performing a hit test\n // outside the clipped area. If the hit element is the rectangle\n // that was supposed to be clipped, the bug is present. This only\n // has to be performed once per page load, so we store the result\n // locally in the module.\n if (!defined(hasInternalReferenceBug)) {\n const id = uniqueKey();\n const ast = new AST([{\n tagName: 'svg',\n attributes: {\n width: 8,\n height: 8\n },\n children: [{\n tagName: 'defs',\n children: [{\n tagName: 'clipPath',\n attributes: {\n id\n },\n children: [{\n tagName: 'rect',\n attributes: {\n width: 4,\n height: 4\n }\n }]\n }]\n }, {\n tagName: 'rect',\n attributes: {\n id: 'hitme',\n width: 8,\n height: 8,\n 'clip-path': `url(#${id})`,\n fill: 'rgba(0,0,0,0.001)'\n }\n }]\n }]);\n const svg = ast.addToDOM(doc.body);\n css(svg, {\n position: 'fixed',\n top: 0,\n left: 0,\n zIndex: 9e5\n });\n const hitElement = doc.elementFromPoint(6, 6);\n hasInternalReferenceBug = (hitElement && hitElement.id) === 'hitme';\n doc.body.removeChild(svg);\n }\n if (hasInternalReferenceBug) {\n return win.location.href\n .split('#')[0] // remove the hash\n .replace(/<[^>]*>/g, '') // wing cut HTML\n // escape parantheses and quotes\n .replace(/([\\('\\)])/g, '\\\\$1')\n // replace spaces (needed for Safari only)\n .replace(/ /g, '%20');\n }\n }\n return '';\n }\n /**\n * Get the global style setting for the renderer.\n *\n * @private\n * @function Highcharts.SVGRenderer#getStyle\n *\n * @param {Highcharts.CSSObject} style\n * Style settings.\n *\n * @return {Highcharts.CSSObject}\n * The style settings mixed with defaults.\n */\n getStyle(style) {\n this.style = extend({\n fontFamily: 'Helvetica, Arial, sans-serif',\n fontSize: '1rem'\n }, style);\n return this.style;\n }\n /**\n * Apply the global style on the renderer, mixed with the default styles.\n *\n * @function Highcharts.SVGRenderer#setStyle\n *\n * @param {Highcharts.CSSObject} style\n * CSS to apply.\n */\n setStyle(style) {\n this.boxWrapper.css(this.getStyle(style));\n }\n /**\n * Detect whether the renderer is hidden. This happens when one of the\n * parent elements has `display: none`. Used internally to detect when we\n * needto render preliminarily in another div to get the text bounding boxes\n * right.\n *\n * @function Highcharts.SVGRenderer#isHidden\n *\n * @return {boolean}\n * True if it is hidden.\n */\n isHidden() {\n return !this.boxWrapper.getBBox().width;\n }\n /**\n * Destroys the renderer and its allocated members.\n *\n * @function Highcharts.SVGRenderer#destroy\n *\n * @return {null}\n * Pass through value.\n */\n destroy() {\n const renderer = this, rendererDefs = renderer.defs;\n renderer.box = null;\n renderer.boxWrapper = renderer.boxWrapper.destroy();\n // Call destroy on all gradient elements\n destroyObjectProperties(renderer.gradients || {});\n renderer.gradients = null;\n renderer.defs = rendererDefs.destroy();\n // Remove sub pixel fix handler (#982)\n if (renderer.unSubPixelFix) {\n renderer.unSubPixelFix();\n }\n renderer.alignedObjects = null;\n return null;\n }\n /**\n * Create a wrapper for an SVG element. Serves as a factory for\n * {@link SVGElement}, but this function is itself mostly called from\n * primitive factories like {@link SVGRenderer#path}, {@link\n * SVGRenderer#rect} or {@link SVGRenderer#text}.\n *\n * @function Highcharts.SVGRenderer#createElement\n *\n * @param {string} nodeName\n * The node name, for example `rect`, `g` etc.\n *\n * @return {Highcharts.SVGElement}\n * The generated SVGElement.\n */\n createElement(nodeName) {\n const wrapper = new this.Element();\n wrapper.init(this, nodeName);\n return wrapper;\n }\n /**\n * Get converted radial gradient attributes according to the radial\n * reference. Used internally from the {@link SVGElement#colorGradient}\n * function.\n *\n * @private\n * @function Highcharts.SVGRenderer#getRadialAttr\n */\n getRadialAttr(radialReference, gradAttr) {\n return {\n cx: (radialReference[0] - radialReference[2] / 2) +\n (gradAttr.cx || 0) * radialReference[2],\n cy: (radialReference[1] - radialReference[2] / 2) +\n (gradAttr.cy || 0) * radialReference[2],\n r: (gradAttr.r || 0) * radialReference[2]\n };\n }\n /**\n * Create a drop shadow definition and return its id\n *\n * @private\n * @function Highcharts.SVGRenderer#shadowDefinition\n *\n * @param {boolean|Highcharts.ShadowOptionsObject} [shadowOptions] The\n * shadow options. If `true`, the default options are applied\n */\n shadowDefinition(shadowOptions) {\n const id = [\n `highcharts-drop-shadow-${this.chartIndex}`,\n ...Object.keys(shadowOptions)\n .map((key) => shadowOptions[key])\n ].join('-').replace(/[^a-z0-9\\-]/g, ''), options = merge({\n color: '#000000',\n offsetX: 1,\n offsetY: 1,\n opacity: 0.15,\n width: 5\n }, shadowOptions);\n if (!this.defs.element.querySelector(`#${id}`)) {\n this.definition({\n tagName: 'filter',\n attributes: {\n id\n },\n children: [{\n tagName: 'feDropShadow',\n attributes: {\n dx: options.offsetX,\n dy: options.offsetY,\n 'flood-color': options.color,\n // Tuned and modified to keep a preserve compatibility\n // with the old settings\n 'flood-opacity': Math.min(options.opacity * 5, 1),\n stdDeviation: options.width / 2\n }\n }]\n });\n }\n return id;\n }\n /**\n * Parse a simple HTML string into SVG tspans. Called internally when text\n * is set on an SVGElement. The function supports a subset of HTML tags, CSS\n * text features like `width`, `text-overflow`, `white-space`, and also\n * attributes like `href` and `style`.\n *\n * @private\n * @function Highcharts.SVGRenderer#buildText\n *\n * @param {Highcharts.SVGElement} wrapper\n * The parent SVGElement.\n */\n buildText(wrapper) {\n new TextBuilder(wrapper).buildSVG();\n }\n /**\n * Returns white for dark colors and black for bright colors, based on W3C's\n * definition of [Relative luminance](\n * https://www.w3.org/WAI/GL/wiki/Relative_luminance).\n *\n * @function Highcharts.SVGRenderer#getContrast\n *\n * @param {Highcharts.ColorString} color\n * The color to get the contrast for.\n *\n * @return {Highcharts.ColorString}\n * The contrast color, either `#000000` or `#FFFFFF`.\n */\n getContrast(color) {\n // #6216, #17273\n const rgba = Color.parse(color).rgba\n .map((b8) => {\n const c = b8 / 255;\n return c <= 0.03928 ?\n c / 12.92 :\n Math.pow((c + 0.055) / 1.055, 2.4);\n });\n // Relative luminance\n const l = 0.2126 * rgba[0] + 0.7152 * rgba[1] + 0.0722 * rgba[2];\n // Use white or black based on which provides more contrast\n return 1.05 / (l + 0.05) > (l + 0.05) / 0.05 ? '#FFFFFF' : '#000000';\n }\n /**\n * Create a button with preset states.\n *\n * @function Highcharts.SVGRenderer#button\n *\n * @param {string} text\n * The text or HTML to draw.\n *\n * @param {number} x\n * The x position of the button's left side.\n *\n * @param {number} y\n * The y position of the button's top side.\n *\n * @param {Highcharts.EventCallbackFunction} callback\n * The function to execute on button click or touch.\n *\n * @param {Highcharts.SVGAttributes} [theme]\n * SVG attributes for the normal state.\n *\n * @param {Highcharts.SVGAttributes} [hoverState]\n * SVG attributes for the hover state.\n *\n * @param {Highcharts.SVGAttributes} [selectState]\n * SVG attributes for the pressed state.\n *\n * @param {Highcharts.SVGAttributes} [disabledState]\n * SVG attributes for the disabled state.\n *\n * @param {Highcharts.SymbolKeyValue} [shape=rect]\n * The shape type.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @return {Highcharts.SVGElement}\n * The button element.\n */\n button(text, x, y, callback, theme = {}, hoverState, selectState, disabledState, shape, useHTML) {\n const label = this.label(text, x, y, shape, void 0, void 0, useHTML, void 0, 'button'), styledMode = this.styledMode, states = theme.states || {};\n let curState = 0;\n theme = merge(theme);\n delete theme.states;\n const normalStyle = merge({\n color: \"#333333\" /* Palette.neutralColor80 */,\n cursor: 'pointer',\n fontSize: '0.8em',\n fontWeight: 'normal'\n }, theme.style);\n delete theme.style;\n // Remove stylable attributes. Pass in the ButtonThemeObject and get the\n // SVGAttributes subset back.\n let normalState = AST.filterUserAttributes(theme);\n // Default, non-stylable attributes\n label.attr(merge({ padding: 8, r: 2 }, normalState));\n // Presentational. The string type is a mistake, it is just for\n // compliance with SVGAttribute and is not used in button theme.\n let hoverStyle, selectStyle, disabledStyle;\n if (!styledMode) {\n // Normal state - prepare the attributes\n normalState = merge({\n fill: \"#f7f7f7\" /* Palette.neutralColor3 */,\n stroke: \"#cccccc\" /* Palette.neutralColor20 */,\n 'stroke-width': 1\n }, normalState);\n // Hover state\n hoverState = merge(normalState, {\n fill: \"#e6e6e6\" /* Palette.neutralColor10 */\n }, AST.filterUserAttributes(hoverState || states.hover || {}));\n hoverStyle = hoverState.style;\n delete hoverState.style;\n // Pressed state\n selectState = merge(normalState, {\n fill: \"#e6e9ff\" /* Palette.highlightColor10 */,\n style: {\n color: \"#000000\" /* Palette.neutralColor100 */,\n fontWeight: 'bold'\n }\n }, AST.filterUserAttributes(selectState || states.select || {}));\n selectStyle = selectState.style;\n delete selectState.style;\n // Disabled state\n disabledState = merge(normalState, {\n style: {\n color: \"#cccccc\" /* Palette.neutralColor20 */\n }\n }, AST.filterUserAttributes(disabledState || states.disabled || {}));\n disabledStyle = disabledState.style;\n delete disabledState.style;\n }\n // Add the events. IE9 and IE10 need mouseover and mouseout to function\n // (#667).\n addEvent(label.element, isMS ? 'mouseover' : 'mouseenter', function () {\n if (curState !== 3) {\n label.setState(1);\n }\n });\n addEvent(label.element, isMS ? 'mouseout' : 'mouseleave', function () {\n if (curState !== 3) {\n label.setState(curState);\n }\n });\n label.setState = function (state) {\n // Hover state is temporary, don't record it\n if (state !== 1) {\n label.state = curState = state;\n }\n // Update visuals\n label\n .removeClass(/highcharts-button-(normal|hover|pressed|disabled)/)\n .addClass('highcharts-button-' +\n ['normal', 'hover', 'pressed', 'disabled'][state || 0]);\n if (!styledMode) {\n label\n .attr([\n normalState,\n hoverState,\n selectState,\n disabledState\n ][state || 0]);\n const css = [\n normalStyle,\n hoverStyle,\n selectStyle,\n disabledStyle\n ][state || 0];\n if (isObject(css)) {\n label.css(css);\n }\n }\n };\n // Presentational attributes\n if (!styledMode) {\n label\n .attr(normalState)\n .css(extend({ cursor: 'default' }, normalStyle));\n // HTML labels don't need to handle pointer events because click and\n // mouseenter/mouseleave is bound to the underlying element.\n // Should this be reconsidered, we need more complex logic to share\n // events between the and its
counterpart, and avoid\n // triggering mouseenter/mouseleave when hovering from one to the\n // other (#17440).\n if (useHTML) {\n label.text.css({ pointerEvents: 'none' });\n }\n }\n return label\n .on('touchstart', (e) => e.stopPropagation())\n .on('click', function (e) {\n if (curState !== 3) {\n callback.call(label, e);\n }\n });\n }\n /**\n * Make a straight line crisper by not spilling out to neighbour pixels.\n *\n * @function Highcharts.SVGRenderer#crispLine\n *\n * @param {Highcharts.SVGPathArray} points\n * The original points on the format `[['M', 0, 0], ['L', 100, 0]]`.\n *\n * @param {number} width\n * The width of the line.\n *\n * @param {string} [roundingFunction=round]\n * The rounding function name on the `Math` object, can be one of\n * `round`, `floor` or `ceil`.\n *\n * @return {Highcharts.SVGPathArray}\n * The original points array, but modified to render crisply.\n */\n crispLine(points, width, roundingFunction = 'round') {\n const start = points[0];\n const end = points[1];\n // Normalize to a crisp line\n if (defined(start[1]) && start[1] === end[1]) {\n // Substract due to #1129. Now bottom and left axis gridlines behave\n // the same.\n start[1] = end[1] =\n Math[roundingFunction](start[1]) - (width % 2 / 2);\n }\n if (defined(start[2]) && start[2] === end[2]) {\n start[2] = end[2] =\n Math[roundingFunction](start[2]) + (width % 2 / 2);\n }\n return points;\n }\n /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @sample highcharts/members/renderer-path-on-chart/\n * Draw a path in a chart\n * @sample highcharts/members/renderer-path/\n * Draw a path independent from a chart\n *\n * @example\n * let path = renderer.path(['M', 10, 10, 'L', 30, 30, 'z'])\n * .attr({ stroke: '#ff00ff' })\n * .add();\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGPathArray} [path]\n * An SVG path definition in array form.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n *\n */ /**\n * Draw a path, wraps the SVG `path` element.\n *\n * @function Highcharts.SVGRenderer#path\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n path(path) {\n const attribs = (this.styledMode ? {} : {\n fill: 'none'\n });\n if (isArray(path)) {\n attribs.d = path;\n }\n else if (isObject(path)) { // attributes\n extend(attribs, path);\n }\n return this.createElement('path').attr(attribs);\n }\n /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @sample highcharts/members/renderer-circle/\n * Drawing a circle\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {number} [x]\n * The center x position.\n *\n * @param {number} [y]\n * The center y position.\n *\n * @param {number} [r]\n * The radius.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw a circle, wraps the SVG `circle` element.\n *\n * @function Highcharts.SVGRenderer#circle\n *\n * @param {Highcharts.SVGAttributes} [attribs]\n * The initial attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n circle(x, y, r) {\n const attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ? {} : { x: x, y: y, r: r }), wrapper = this.createElement('circle');\n // Setting x or y translates to cx and cy\n wrapper.xSetter = wrapper.ySetter = function (value, key, element) {\n element.setAttribute('c' + key, value);\n };\n return wrapper.attr(attribs);\n }\n /**\n * Draw and return an arc.\n *\n * @sample highcharts/members/renderer-arc/\n * Drawing an arc\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {number} [x=0]\n * Center X position.\n *\n * @param {number} [y=0]\n * Center Y position.\n *\n * @param {number} [r=0]\n * The outer radius' of the arc.\n *\n * @param {number} [innerR=0]\n * Inner radius like used in donut charts.\n *\n * @param {number} [start=0]\n * The starting angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @param {number} [end=0]\n * The ending angle of the arc in radians, where 0 is to the right and\n * `-Math.PI/2` is up.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return an arc. Overloaded function that takes arguments object.\n *\n * @function Highcharts.SVGRenderer#arc\n *\n * @param {Highcharts.SVGAttributes} attribs\n * Initial SVG attributes.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n arc(x, y, r, innerR, start, end) {\n let options;\n if (isObject(x)) {\n options = x;\n y = options.y;\n r = options.r;\n innerR = options.innerR;\n start = options.start;\n end = options.end;\n x = options.x;\n }\n else {\n options = { innerR, start, end };\n }\n // Arcs are defined as symbols for the ability to set\n // attributes in attr and animate\n const arc = this.symbol('arc', x, y, r, r, options);\n arc.r = r; // #959\n return arc;\n }\n /**\n * Draw and return a rectangle.\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {number} [x]\n * Left position.\n *\n * @param {number} [y]\n * Top position.\n *\n * @param {number} [width]\n * Width of the rectangle.\n *\n * @param {number} [height]\n * Height of the rectangle.\n *\n * @param {number} [r]\n * Border corner radius.\n *\n * @param {number} [strokeWidth]\n * A stroke width can be supplied to allow crisp drawing.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */ /**\n * Draw and return a rectangle.\n *\n * @sample highcharts/members/renderer-rect-on-chart/\n * Draw a rectangle in a chart\n * @sample highcharts/members/renderer-rect/\n * Draw a rectangle independent from a chart\n *\n * @function Highcharts.SVGRenderer#rect\n *\n * @param {Highcharts.SVGAttributes} [attributes]\n * General SVG attributes for the rectangle.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n rect(x, y, width, height, r, strokeWidth) {\n const attribs = (isObject(x) ?\n x :\n typeof x === 'undefined' ?\n {} :\n {\n x,\n y,\n r,\n width: Math.max(width || 0, 0),\n height: Math.max(height || 0, 0)\n }), wrapper = this.createElement('rect');\n if (!this.styledMode) {\n if (typeof strokeWidth !== 'undefined') {\n attribs['stroke-width'] = strokeWidth;\n extend(attribs, wrapper.crisp(attribs));\n }\n attribs.fill = 'none';\n }\n wrapper.rSetter = function (value, _key, element) {\n wrapper.r = value;\n attr(element, {\n rx: value,\n ry: value\n });\n };\n wrapper.rGetter = function () {\n return wrapper.r || 0;\n };\n return wrapper.attr(attribs);\n }\n /**\n * Draw and return a rectangle with advanced corner rounding options.\n *\n * @function Highcharts.SVGRenderer#roundedRect\n *\n * @param {Highcharts.SVGAttributes} attribs\n * Attributes\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n roundedRect(attribs) {\n return this.symbol('roundedRect').attr(attribs);\n }\n /**\n * Resize the {@link SVGRenderer#box} and re-align all aligned child\n * elements.\n *\n * @sample highcharts/members/renderer-g/\n * Show and hide grouped objects\n *\n * @function Highcharts.SVGRenderer#setSize\n *\n * @param {number} width\n * The new pixel width.\n *\n * @param {number} height\n * The new pixel height.\n *\n * @param {boolean|Partial} [animate=true]\n * Whether and how to animate.\n */\n setSize(width, height, animate) {\n const renderer = this;\n renderer.width = width;\n renderer.height = height;\n renderer.boxWrapper.animate({\n width: width,\n height: height\n }, {\n step: function () {\n this.attr({\n viewBox: '0 0 ' + this.attr('width') + ' ' +\n this.attr('height')\n });\n },\n duration: pick(animate, true) ? void 0 : 0\n });\n renderer.alignElements();\n }\n /**\n * Create and return an svg group element. Child\n * {@link Highcharts.SVGElement} objects are added to the group by using the\n * group as the first parameter in {@link Highcharts.SVGElement#add|add()}.\n *\n * @function Highcharts.SVGRenderer#g\n *\n * @param {string} [name]\n * The group will be given a class name of `highcharts-{name}`. This\n * can be used for styling and scripting.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n g(name) {\n const elem = this.createElement('g');\n return name ?\n elem.attr({ 'class': 'highcharts-' + name }) :\n elem;\n }\n /**\n * Display an image.\n *\n * @sample highcharts/members/renderer-image-on-chart/\n * Add an image in a chart\n * @sample highcharts/members/renderer-image/\n * Add an image independent of a chart\n *\n * @function Highcharts.SVGRenderer#image\n *\n * @param {string} href\n * The image source.\n *\n * @param {number} [x]\n * The X position.\n *\n * @param {number} [y]\n * The Y position.\n *\n * @param {number} [width]\n * The image width. If omitted, it defaults to the image file width.\n *\n * @param {number} [height]\n * The image height. If omitted it defaults to the image file\n * height.\n *\n * @param {Function} [onload]\n * Event handler for image load.\n *\n * @return {Highcharts.SVGElement}\n * The generated wrapper element.\n */\n image(href, x, y, width, height, onload) {\n const attribs = { preserveAspectRatio: 'none' };\n // Optional properties (#11756)\n if (isNumber(x)) {\n attribs.x = x;\n }\n if (isNumber(y)) {\n attribs.y = y;\n }\n if (isNumber(width)) {\n attribs.width = width;\n }\n if (isNumber(height)) {\n attribs.height = height;\n }\n const elemWrapper = this.createElement('image').attr(attribs), onDummyLoad = function (e) {\n elemWrapper.attr({ href });\n onload.call(elemWrapper, e);\n };\n // Add load event if supplied\n if (onload) {\n // We have to use a dummy HTML image since IE support for SVG image\n // load events is very buggy. First set a transparent src, wait for\n // dummy to load, and then add the real src to the SVG image.\n elemWrapper.attr({\n /* eslint-disable-next-line max-len */\n href: 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=='\n });\n const dummy = new win.Image();\n addEvent(dummy, 'load', onDummyLoad);\n dummy.src = href;\n if (dummy.complete) {\n onDummyLoad({});\n }\n }\n else {\n elemWrapper.attr({ href });\n }\n return elemWrapper;\n }\n /**\n * Draw a symbol out of pre-defined shape paths from\n * {@link SVGRenderer#symbols}.\n * It is used in Highcharts for point makers, which cake a `symbol` option,\n * and label and button backgrounds like in the tooltip and stock flags.\n *\n * @function Highcharts.SVGRenderer#symbol\n *\n * @param {string} symbol\n * The symbol name.\n *\n * @param {number} [x]\n * The X coordinate for the top left position.\n *\n * @param {number} [y]\n * The Y coordinate for the top left position.\n *\n * @param {number} [width]\n * The pixel width.\n *\n * @param {number} [height]\n * The pixel height.\n *\n * @param {Highcharts.SymbolOptionsObject} [options]\n * Additional options, depending on the actual symbol drawn.\n *\n * @return {Highcharts.SVGElement}\n * SVG symbol.\n */\n symbol(symbol, x, y, width, height, options) {\n const ren = this, imageRegex = /^url\\((.*?)\\)$/, isImage = imageRegex.test(symbol), sym = (!isImage && (this.symbols[symbol] ? symbol : 'circle')), \n // get the symbol definition function\n symbolFn = (sym && this.symbols[sym]);\n let obj, path, imageSrc, centerImage;\n if (symbolFn) {\n // Check if there's a path defined for this symbol\n if (typeof x === 'number') {\n path = symbolFn.call(this.symbols, Math.round(x || 0), Math.round(y || 0), width || 0, height || 0, options);\n }\n obj = this.path(path);\n if (!ren.styledMode) {\n obj.attr('fill', 'none');\n }\n // expando properties for use in animate and attr\n extend(obj, {\n symbolName: (sym || void 0),\n x: x,\n y: y,\n width: width,\n height: height\n });\n if (options) {\n extend(obj, options);\n }\n // Image symbols\n }\n else if (isImage) {\n imageSrc = symbol.match(imageRegex)[1];\n // Create the image synchronously, add attribs async\n const img = obj = this.image(imageSrc);\n // The image width is not always the same as the symbol width. The\n // image may be centered within the symbol, as is the case when\n // image shapes are used as label backgrounds, for example in flags.\n img.imgwidth = pick(options && options.width, symbolSizes[imageSrc] && symbolSizes[imageSrc].width);\n img.imgheight = pick(options && options.height, symbolSizes[imageSrc] && symbolSizes[imageSrc].height);\n /**\n * Set the size and position\n */\n centerImage = (obj) => obj.attr({\n width: obj.width,\n height: obj.height\n });\n /**\n * Width and height setters that take both the image's physical size\n * and the label size into consideration, and translates the image\n * to center within the label.\n */\n ['width', 'height'].forEach(function (key) {\n img[key + 'Setter'] = function (value, key) {\n this[key] = value;\n const { alignByTranslate, element, width, height, imgwidth, imgheight } = this;\n let imgSize = this['img' + key];\n if (defined(imgSize)) {\n let scale = 1;\n // Scale and center the image within its container.\n // The name `backgroundSize` is taken from the CSS spec,\n // but the value `within` is made up. Other possible\n // values in the spec, `cover` and `contain`, can be\n // implemented if needed.\n if (options &&\n options.backgroundSize === 'within' &&\n width &&\n height) {\n scale = Math.min(width / imgwidth, height / imgheight);\n imgSize = Math.round(imgSize * scale);\n // Update both width and height to keep the ratio\n // correct (#17315)\n attr(element, {\n width: Math.round(imgwidth * scale),\n height: Math.round(imgheight * scale)\n });\n }\n else if (element) {\n element.setAttribute(key, imgSize);\n }\n if (!alignByTranslate) {\n this.translate(((width || 0) - (imgwidth * scale)) / 2, ((height || 0) - (imgheight * scale)) / 2);\n }\n }\n };\n });\n if (defined(x)) {\n img.attr({\n x: x,\n y: y\n });\n }\n img.isImg = true;\n if (defined(img.imgwidth) && defined(img.imgheight)) {\n centerImage(img);\n }\n else {\n // Initialize image to be 0 size so export will still function\n // if there's no cached sizes.\n img.attr({ width: 0, height: 0 });\n // Create a dummy JavaScript image to get the width and height.\n createElement('img', {\n onload: function () {\n const chart = charts[ren.chartIndex];\n // Special case for SVGs on IE11, the width is not\n // accessible until the image is part of the DOM\n // (#2854).\n if (this.width === 0) {\n css(this, {\n position: 'absolute',\n top: '-999em'\n });\n doc.body.appendChild(this);\n }\n // Center the image\n symbolSizes[imageSrc] = {\n width: this.width,\n height: this.height\n };\n img.imgwidth = this.width;\n img.imgheight = this.height;\n if (img.element) {\n centerImage(img);\n }\n // Clean up after #2854 workaround.\n if (this.parentNode) {\n this.parentNode.removeChild(this);\n }\n // Fire the load event when all external images are\n // loaded\n ren.imgCount--;\n if (!ren.imgCount && chart && !chart.hasLoaded) {\n chart.onload();\n }\n },\n src: imageSrc\n });\n this.imgCount++;\n }\n }\n return obj;\n }\n /**\n * Define a clipping rectangle. The clipping rectangle is later applied\n * to {@link SVGElement} objects through the {@link SVGElement#clip}\n * function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @function Highcharts.SVGRenderer#clipRect\n *\n * @param {number} [x]\n *\n * @param {number} [y]\n *\n * @param {number} [width]\n *\n * @param {number} [height]\n *\n * @return {Highcharts.ClipRectElement}\n * A clipping rectangle.\n */\n clipRect(x, y, width, height) {\n const \n // Add a hyphen at the end to avoid confusion in testing indexes\n // -1 and -10, -11 etc (#6550)\n id = uniqueKey() + '-', clipPath = this.createElement('clipPath').attr({\n id: id\n }).add(this.defs), wrapper = this.rect(x, y, width, height, 0).add(clipPath);\n wrapper.id = id;\n wrapper.clipPath = clipPath;\n wrapper.count = 0;\n return wrapper;\n }\n /**\n * Draw text. The text can contain a subset of HTML, like spans and anchors\n * and some basic text styling of these. For more advanced features like\n * border and background, use {@link Highcharts.SVGRenderer#label} instead.\n * To update the text after render, run `text.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-text-on-chart/\n * Annotate the chart freely\n * @sample highcharts/members/renderer-on-chart/\n * Annotate with a border and in response to the data\n * @sample highcharts/members/renderer-text/\n * Formatted text\n *\n * @function Highcharts.SVGRenderer#text\n *\n * @param {string} [str]\n * The text of (subset) HTML to draw.\n *\n * @param {number} [x]\n * The x position of the text's lower left corner.\n *\n * @param {number} [y]\n * The y position of the text's lower left corner.\n *\n * @param {boolean} [useHTML=false]\n * Use HTML to render the text.\n *\n * @return {Highcharts.SVGElement}\n * The text object.\n */\n text(str, x, y, useHTML) {\n const renderer = this, attribs = {};\n if (useHTML && (renderer.allowHTML || !renderer.forExport)) {\n return renderer.html(str, x, y);\n }\n attribs.x = Math.round(x || 0); // X always needed for line-wrap logic\n if (y) {\n attribs.y = Math.round(y);\n }\n if (defined(str)) {\n attribs.text = str;\n }\n const wrapper = renderer.createElement('text').attr(attribs);\n if (!useHTML || (renderer.forExport && !renderer.allowHTML)) {\n wrapper.xSetter = function (value, key, element) {\n const tspans = element.getElementsByTagName('tspan'), parentVal = element.getAttribute(key);\n for (let i = 0, tspan; i < tspans.length; i++) {\n tspan = tspans[i];\n // If the x values are equal, the tspan represents a line\n // break\n if (tspan.getAttribute(key) === parentVal) {\n tspan.setAttribute(key, value);\n }\n }\n element.setAttribute(key, value);\n };\n }\n return wrapper;\n }\n /**\n * Utility to return the baseline offset and total line height from the font\n * size.\n *\n * @function Highcharts.SVGRenderer#fontMetrics\n *\n * @param {Highcharts.SVGElement|Highcharts.SVGDOMElement|number} [element]\n * The element to inspect for a current font size. If a number is\n * given, it's used as a fall back for direct font size in pixels.\n *\n * @return {Highcharts.FontMetricsObject}\n * The font metrics.\n */\n fontMetrics(element) {\n const f = pInt(SVGElement.prototype.getStyle.call(element, 'font-size') || 0);\n // Empirical values found by comparing font size and bounding box\n // height. Applies to the default font family.\n // https://jsfiddle.net/highcharts/7xvn7/\n const h = f < 24 ? f + 3 : Math.round(f * 1.2), b = Math.round(h * 0.8);\n return {\n // Line height\n h,\n // Baseline\n b,\n // Font size\n f\n };\n }\n /**\n * Correct X and Y positioning of a label for rotation (#1764).\n *\n * @private\n * @function Highcharts.SVGRenderer#rotCorr\n */\n rotCorr(baseline, rotation, alterY) {\n let y = baseline;\n if (rotation && alterY) {\n y = Math.max(y * Math.cos(rotation * deg2rad), 4);\n }\n return {\n x: (-baseline / 3) * Math.sin(rotation * deg2rad),\n y: y\n };\n }\n /**\n * Compatibility function to convert the legacy one-dimensional path array\n * into an array of segments.\n *\n * It is used in maps to parse the `path` option, and in SVGRenderer.dSetter\n * to support legacy paths from demos.\n *\n * @private\n * @function Highcharts.SVGRenderer#pathToSegments\n */\n pathToSegments(path) {\n const ret = [];\n const segment = [];\n const commandLength = {\n A: 8,\n C: 7,\n H: 2,\n L: 3,\n M: 3,\n Q: 5,\n S: 5,\n T: 3,\n V: 2\n };\n // Short, non-typesafe parsing of the one-dimensional array. It splits\n // the path on any string. This is not type checked against the tuple\n // types, but is shorter, and doesn't require specific checks for any\n // command type in SVG.\n for (let i = 0; i < path.length; i++) {\n // Command skipped, repeat previous or insert L/l for M/m\n if (isString(segment[0]) &&\n isNumber(path[i]) &&\n segment.length === commandLength[(segment[0].toUpperCase())]) {\n path.splice(i, 0, segment[0].replace('M', 'L').replace('m', 'l'));\n }\n // Split on string\n if (typeof path[i] === 'string') {\n if (segment.length) {\n ret.push(segment.slice(0));\n }\n segment.length = 0;\n }\n segment.push(path[i]);\n }\n ret.push(segment.slice(0));\n return ret;\n /*\n // Fully type-safe version where each tuple type is checked. The\n // downside is filesize and a lack of flexibility for unsupported\n // commands\n const ret: SVGPath = [],\n commands = {\n A: 7,\n C: 6,\n H: 1,\n L: 2,\n M: 2,\n Q: 4,\n S: 4,\n T: 2,\n V: 1,\n Z: 0\n };\n\n let i = 0,\n lastI = 0,\n lastCommand;\n\n while (i < path.length) {\n const item = path[i];\n\n let command;\n\n if (typeof item === 'string') {\n command = item;\n i += 1;\n } else {\n command = lastCommand || 'M';\n }\n\n // Upper case\n const commandUC = command.toUpperCase();\n\n if (commandUC in commands) {\n\n // No numeric parameters\n if (command === 'Z' || command === 'z') {\n ret.push([command]);\n\n // One numeric parameter\n } else {\n const val0 = path[i];\n if (typeof val0 === 'number') {\n\n // Horizontal line to\n if (command === 'H' || command === 'h') {\n ret.push([command, val0]);\n i += 1;\n\n // Vertical line to\n } else if (command === 'V' || command === 'v') {\n ret.push([command, val0]);\n i += 1;\n\n // Two numeric parameters\n } else {\n const val1 = path[i + 1];\n if (typeof val1 === 'number') {\n // lineTo\n if (command === 'L' || command === 'l') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // moveTo\n } else if (command === 'M' || command === 'm') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Smooth quadratic bezier\n } else if (command === 'T' || command === 't') {\n ret.push([command, val0, val1]);\n i += 2;\n\n // Four numeric parameters\n } else {\n const val2 = path[i + 2],\n val3 = path[i + 3];\n if (\n typeof val2 === 'number' &&\n typeof val3 === 'number'\n ) {\n // Quadratic bezier to\n if (\n command === 'Q' ||\n command === 'q'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Smooth cubic bezier to\n } else if (\n command === 'S' ||\n command === 's'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3\n ]);\n i += 4;\n\n // Six numeric parameters\n } else {\n const val4 = path[i + 4],\n val5 = path[i + 5];\n\n if (\n typeof val4 === 'number' &&\n typeof val5 === 'number'\n ) {\n // Curve to\n if (\n command === 'C' ||\n command === 'c'\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5\n ]);\n i += 6;\n\n // Seven numeric parameters\n } else {\n const val6 = path[i + 6];\n\n // Arc to\n if (\n typeof val6 ===\n 'number' &&\n (\n command === 'A' ||\n command === 'a'\n )\n ) {\n ret.push([\n command,\n val0,\n val1,\n val2,\n val3,\n val4,\n val5,\n val6\n ]);\n i += 7;\n\n }\n\n }\n }\n }\n }\n }\n }\n\n }\n }\n }\n }\n\n // An unmarked command following a moveTo is a lineTo\n lastCommand = command === 'M' ? 'L' : command;\n\n if (i === lastI) {\n break;\n }\n lastI = i;\n }\n return ret;\n */\n }\n /**\n * Draw a label, which is an extended text element with support for border\n * and background. Highcharts creates a `g` element with a text and a `path`\n * or `rect` inside, to make it behave somewhat like a HTML div. Border and\n * background are set through `stroke`, `stroke-width` and `fill` attributes\n * using the {@link Highcharts.SVGElement#attr|attr} method. To update the\n * text after render, run `label.attr({ text: 'New text' })`.\n *\n * @sample highcharts/members/renderer-label-on-chart/\n * A label on the chart\n *\n * @function Highcharts.SVGRenderer#label\n *\n * @param {string} str\n * The initial text string or (subset) HTML to render.\n *\n * @param {number} x\n * The x position of the label's left side.\n *\n * @param {number} [y]\n * The y position of the label's top side or baseline, depending on\n * the `baseline` parameter.\n *\n * @param {string} [shape='rect']\n * The shape of the label's border/background, if any. Defaults to\n * `rect`. Other possible values are `callout` or other shapes\n * defined in {@link Highcharts.SVGRenderer#symbols}.\n *\n * @param {number} [anchorX]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {number} [anchorY]\n * In case the `shape` has a pointer, like a flag, this is the\n * coordinates it should be pinned to.\n *\n * @param {boolean} [useHTML=false]\n * Whether to use HTML to render the label.\n *\n * @param {boolean} [baseline=false]\n * Whether to position the label relative to the text baseline,\n * like {@link Highcharts.SVGRenderer#text|renderer.text}, or to the\n * upper border of the rectangle.\n *\n * @param {string} [className]\n * Class name for the group.\n *\n * @return {Highcharts.SVGElement}\n * The generated label.\n */\n label(str, x, y, shape, anchorX, anchorY, useHTML, baseline, className) {\n return new SVGLabel(this, str, x, y, shape, anchorX, anchorY, useHTML, baseline, className);\n }\n /**\n * Re-align all aligned elements.\n *\n * @private\n * @function Highcharts.SVGRenderer#alignElements\n */\n alignElements() {\n this.alignedObjects.forEach((el) => el.align());\n }\n }\n extend(SVGRenderer.prototype, {\n /**\n * A pointer to the renderer's associated Element class.\n *\n * @name Highcharts.SVGRenderer#Element\n * @type {Highcharts.SVGElement}\n */\n Element: SVGElement,\n SVG_NS,\n /**\n * A collection of characters mapped to HTML entities. When `useHTML` on an\n * element is true, these entities will be rendered correctly by HTML. In\n * the SVG pseudo-HTML, they need to be unescaped back to simple characters,\n * so for example `<` will render as `<`.\n *\n * @example\n * // Add support for unescaping quotes\n * Highcharts.SVGRenderer.prototype.escapes['\"'] = '"';\n *\n * @name Highcharts.SVGRenderer#escapes\n * @type {Highcharts.Dictionary}\n */\n escapes: {\n '&': '&',\n '<': '<',\n '>': '>',\n \"'\": ''',\n '\"': '"'\n },\n /**\n * An extendable collection of functions for defining symbol paths.\n *\n * @name Highcharts.SVGRenderer#symbols\n * @type {Highcharts.SymbolDictionary}\n */\n symbols: Symbols,\n /**\n * Dummy function for plugins, called every time the renderer is updated.\n * Prior to Highcharts 5, this was used for the canvg renderer.\n *\n * @deprecated\n * @function Highcharts.SVGRenderer#draw\n */\n draw: noop\n });\n /* *\n *\n * Registry\n *\n * */\n RendererRegistry.registerRendererType('svg', SVGRenderer, true);\n /* *\n *\n * Export Default\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A clipping rectangle that can be applied to one or more {@link SVGElement}\n * instances. It is instanciated with the {@link SVGRenderer#clipRect} function\n * and applied with the {@link SVGElement#clip} function.\n *\n * @example\n * let circle = renderer.circle(100, 100, 100)\n * .attr({ fill: 'red' })\n * .add();\n * let clipRect = renderer.clipRect(100, 100, 100, 100);\n *\n * // Leave only the lower right quarter visible\n * circle.clip(clipRect);\n *\n * @typedef {Highcharts.SVGElement} Highcharts.ClipRectElement\n */\n /**\n * The font metrics.\n *\n * @interface Highcharts.FontMetricsObject\n */ /**\n * The baseline relative to the top of the box.\n *\n * @name Highcharts.FontMetricsObject#b\n * @type {number}\n */ /**\n * The font size.\n *\n * @name Highcharts.FontMetricsObject#f\n * @type {number}\n */ /**\n * The line height.\n *\n * @name Highcharts.FontMetricsObject#h\n * @type {number}\n */\n /**\n * An object containing `x` and `y` properties for the position of an element.\n *\n * @interface Highcharts.PositionObject\n */ /**\n * X position of the element.\n * @name Highcharts.PositionObject#x\n * @type {number}\n */ /**\n * Y position of the element.\n * @name Highcharts.PositionObject#y\n * @type {number}\n */\n /**\n * A rectangle.\n *\n * @interface Highcharts.RectangleObject\n */ /**\n * Height of the rectangle.\n * @name Highcharts.RectangleObject#height\n * @type {number}\n */ /**\n * Width of the rectangle.\n * @name Highcharts.RectangleObject#width\n * @type {number}\n */ /**\n * Horizontal position of the rectangle.\n * @name Highcharts.RectangleObject#x\n * @type {number}\n */ /**\n * Vertical position of the rectangle.\n * @name Highcharts.RectangleObject#y\n * @type {number}\n */\n /**\n * The shadow options.\n *\n * @interface Highcharts.ShadowOptionsObject\n */ /**\n * The shadow color.\n * @name Highcharts.ShadowOptionsObject#color\n * @type {Highcharts.ColorString|undefined}\n * @default #000000\n */ /**\n * The horizontal offset from the element.\n *\n * @name Highcharts.ShadowOptionsObject#offsetX\n * @type {number|undefined}\n * @default 1\n */ /**\n * The vertical offset from the element.\n * @name Highcharts.ShadowOptionsObject#offsetY\n * @type {number|undefined}\n * @default 1\n */ /**\n * The shadow opacity.\n *\n * @name Highcharts.ShadowOptionsObject#opacity\n * @type {number|undefined}\n * @default 0.15\n */ /**\n * The shadow width or distance from the element.\n * @name Highcharts.ShadowOptionsObject#width\n * @type {number|undefined}\n * @default 3\n */\n /**\n * @interface Highcharts.SizeObject\n */ /**\n * @name Highcharts.SizeObject#height\n * @type {number}\n */ /**\n * @name Highcharts.SizeObject#width\n * @type {number}\n */\n /**\n * Array of path commands, that will go into the `d` attribute of an SVG\n * element.\n *\n * @typedef {Array<(Array|Array|Array|Array|Array|Array)>} Highcharts.SVGPathArray\n */\n /**\n * Possible path commands in an SVG path array. Valid values are `A`, `C`, `H`,\n * `L`, `M`, `Q`, `S`, `T`, `V`, `Z`.\n *\n * @typedef {string} Highcharts.SVGPathCommand\n * @validvalue [\"a\",\"c\",\"h\",\"l\",\"m\",\"q\",\"s\",\"t\",\"v\",\"z\",\"A\",\"C\",\"H\",\"L\",\"M\",\"Q\",\"S\",\"T\",\"V\",\"Z\"]\n */\n /**\n * An extendable collection of functions for defining symbol paths. Symbols are\n * used internally for point markers, button and label borders and backgrounds,\n * or custom shapes. Extendable by adding to {@link SVGRenderer#symbols}.\n *\n * @interface Highcharts.SymbolDictionary\n */ /**\n * @name Highcharts.SymbolDictionary#[key:string]\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#arc\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#callout\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#circle\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#diamond\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#square\n * @type {Function|undefined}\n */ /**\n * @name Highcharts.SymbolDictionary#triangle\n * @type {Function|undefined}\n */\n /**\n * Can be one of `arc`, `callout`, `circle`, `diamond`, `square`, `triangle`,\n * and `triangle-down`. Symbols are used internally for point markers, button\n * and label borders and backgrounds, or custom shapes. Extendable by adding to\n * {@link SVGRenderer#symbols}.\n *\n * @typedef {\"arc\"|\"callout\"|\"circle\"|\"diamond\"|\"square\"|\"triangle\"|\"triangle-down\"} Highcharts.SymbolKeyValue\n */\n /**\n * Additional options, depending on the actual symbol drawn.\n *\n * @interface Highcharts.SymbolOptionsObject\n */ /**\n * The anchor X position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorX\n * @type {number|undefined}\n */ /**\n * The anchor Y position for the `callout` symbol. This is where the chevron\n * points to.\n *\n * @name Highcharts.SymbolOptionsObject#anchorY\n * @type {number|undefined}\n */ /**\n * The end angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#end\n * @type {number|undefined}\n */ /**\n * Whether to draw `arc` symbol open or closed.\n *\n * @name Highcharts.SymbolOptionsObject#open\n * @type {boolean|undefined}\n */ /**\n * The radius of an `arc` symbol, or the border radius for the `callout` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#r\n * @type {number|undefined}\n */ /**\n * The start angle of an `arc` symbol.\n *\n * @name Highcharts.SymbolOptionsObject#start\n * @type {number|undefined}\n */\n (''); // keeps doclets above in transpiled file\n\n return SVGRenderer;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLElement.js', [_modules['Core/Globals.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (H, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isFirefox, isMS, isWebKit, win } = H;\n const { css, defined, extend, pick, pInt } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n class HTMLElement extends SVGElement {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Modifies SVGElement to support HTML elements.\n * @private\n */\n static compose(SVGElementClass) {\n if (U.pushUnique(composedMembers, SVGElementClass)) {\n const htmlElementProto = HTMLElement.prototype, svgElementProto = SVGElementClass.prototype;\n svgElementProto.getSpanCorrection = htmlElementProto\n .getSpanCorrection;\n svgElementProto.htmlCss = htmlElementProto.htmlCss;\n svgElementProto.htmlGetBBox = htmlElementProto.htmlGetBBox;\n svgElementProto.htmlUpdateTransform = htmlElementProto\n .htmlUpdateTransform;\n svgElementProto.setSpanRotation = htmlElementProto.setSpanRotation;\n }\n return SVGElementClass;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the correction in X and Y positioning as the element is rotated.\n * @private\n */\n getSpanCorrection(width, baseline, alignCorrection) {\n this.xCorr = -width * alignCorrection;\n this.yCorr = -baseline;\n }\n /**\n * Apply CSS to HTML elements. This is used in text within SVG rendering.\n * @private\n */\n htmlCss(styles) {\n const wrapper = this, element = wrapper.element, \n // When setting or unsetting the width style, we need to update\n // transform (#8809)\n isSettingWidth = (element.tagName === 'SPAN' &&\n styles &&\n 'width' in styles), textWidth = pick(isSettingWidth && styles.width, void 0);\n let doTransform;\n if (isSettingWidth) {\n delete styles.width;\n wrapper.textWidth = textWidth;\n doTransform = true;\n }\n if (styles && styles.textOverflow === 'ellipsis') {\n styles.whiteSpace = 'nowrap';\n styles.overflow = 'hidden';\n }\n wrapper.styles = extend(wrapper.styles, styles);\n css(wrapper.element, styles);\n // Now that all styles are applied, to the transform\n if (doTransform) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n }\n /**\n * useHTML method for calculating the bounding box based on offsets.\n */\n htmlGetBBox() {\n const wrapper = this, element = wrapper.element;\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: element.offsetWidth,\n height: element.offsetHeight\n };\n }\n /**\n * @private\n */\n htmlUpdateTransform() {\n // aligning non added elements is expensive\n if (!this.added) {\n this.alignOnAdd = true;\n return;\n }\n const wrapper = this, renderer = wrapper.renderer, elem = wrapper.element, translateX = wrapper.translateX || 0, translateY = wrapper.translateY || 0, x = wrapper.x || 0, y = wrapper.y || 0, align = wrapper.textAlign || 'left', alignCorrection = {\n left: 0, center: 0.5, right: 1\n }[align], styles = wrapper.styles, whiteSpace = styles && styles.whiteSpace;\n /** @private */\n function getTextPxLength() {\n if (wrapper.textPxLength) {\n return wrapper.textPxLength;\n }\n // Reset multiline/ellipsis in order to read width (#4928,\n // #5417)\n css(elem, {\n width: '',\n whiteSpace: whiteSpace || 'nowrap'\n });\n return elem.offsetWidth;\n }\n // apply translate\n css(elem, {\n marginLeft: translateX,\n marginTop: translateY\n });\n if (elem.tagName === 'SPAN') {\n const rotation = wrapper.rotation, textWidth = wrapper.textWidth && pInt(wrapper.textWidth), currentTextTransform = [\n rotation,\n align,\n elem.innerHTML,\n wrapper.textWidth,\n wrapper.textAlign\n ].join(',');\n let baseline, hasBoxWidthChanged = false;\n // Update textWidth. Use the memoized textPxLength if possible, to\n // avoid the getTextPxLength function using elem.offsetWidth.\n // Calling offsetWidth affects rendering time as it forces layout\n // (#7656).\n if (textWidth !== wrapper.oldTextWidth) { // #983, #1254\n const textPxLength = getTextPxLength();\n if (((textWidth > wrapper.oldTextWidth) ||\n textPxLength > textWidth) && (\n // Only set the width if the text is able to word-wrap,\n // or text-overflow is ellipsis (#9537)\n /[ \\-]/.test(elem.textContent || elem.innerText) ||\n elem.style.textOverflow === 'ellipsis')) {\n css(elem, {\n width: (textPxLength > textWidth) || rotation ?\n textWidth + 'px' :\n 'auto',\n display: 'block',\n whiteSpace: whiteSpace || 'normal' // #3331\n });\n wrapper.oldTextWidth = textWidth;\n hasBoxWidthChanged = true; // #8159\n }\n }\n wrapper.hasBoxWidthChanged = hasBoxWidthChanged; // #8159\n // Do the calculations and DOM access only if properties changed\n if (currentTextTransform !== wrapper.cTT) {\n baseline = renderer.fontMetrics(elem).b;\n // Renderer specific handling of span rotation, but only if we\n // have something to update.\n if (defined(rotation) &&\n ((rotation !== (wrapper.oldRotation || 0)) ||\n (align !== wrapper.oldAlign))) {\n wrapper.setSpanRotation(rotation, alignCorrection, baseline);\n }\n wrapper.getSpanCorrection(\n // Avoid elem.offsetWidth if we can, it affects rendering\n // time heavily (#7656)\n ((!defined(rotation) && wrapper.textPxLength) || // #7920\n elem.offsetWidth), baseline, alignCorrection, rotation, align);\n }\n // apply position with correction\n css(elem, {\n left: (x + (wrapper.xCorr || 0)) + 'px',\n top: (y + (wrapper.yCorr || 0)) + 'px'\n });\n // record current text transform\n wrapper.cTT = currentTextTransform;\n wrapper.oldRotation = rotation;\n wrapper.oldAlign = align;\n }\n }\n /**\n * Set the rotation of an individual HTML span.\n * @private\n */\n setSpanRotation(rotation, alignCorrection, baseline) {\n const getTransformKey = () => (isMS &&\n !/Edge/.test(win.navigator.userAgent) ?\n '-ms-transform' :\n isWebKit ?\n '-webkit-transform' :\n isFirefox ?\n 'MozTransform' :\n win.opera ?\n '-o-transform' :\n void 0);\n const rotationStyle = {}, cssTransformKey = getTransformKey();\n if (cssTransformKey) {\n rotationStyle[cssTransformKey] = rotationStyle.transform =\n 'rotate(' + rotation + 'deg)';\n rotationStyle[cssTransformKey + (isFirefox ? 'Origin' : '-origin')] = rotationStyle.transformOrigin =\n (alignCorrection * 100) + '% ' + baseline + 'px';\n css(this.element, rotationStyle);\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLElement;\n });\n _registerModule(_modules, 'Core/Renderer/HTML/HTMLRenderer.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (AST, SVGElement, SVGRenderer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { attr, createElement, extend, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable valid-jsdoc */\n // Extend SvgRenderer for useHTML option.\n class HTMLRenderer extends SVGRenderer {\n /* *\n *\n * Static Functions\n *\n * */\n /** @private */\n static compose(SVGRendererClass) {\n if (U.pushUnique(composedMembers, SVGRendererClass)) {\n const htmlRendererProto = HTMLRenderer.prototype, svgRendererProto = SVGRendererClass.prototype;\n svgRendererProto.html = htmlRendererProto.html;\n }\n return SVGRendererClass;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create HTML text node. This is used by the SVG renderer through the\n * useHTML option.\n *\n * @private\n * @function Highcharts.SVGRenderer#html\n *\n * @param {string} str\n * The text of (subset) HTML to draw.\n *\n * @param {number} x\n * The x position of the text's lower left corner.\n *\n * @param {number} y\n * The y position of the text's lower left corner.\n *\n * @return {Highcharts.HTMLDOMElement}\n * HTML element.\n */\n html(str, x, y) {\n const wrapper = this.createElement('span'), element = wrapper.element, renderer = wrapper.renderer, addSetters = function (gWrapper, style) {\n // These properties are set as attributes on the SVG group, and\n // as identical CSS properties on the div. (#3542)\n ['opacity', 'visibility'].forEach(function (prop) {\n gWrapper[prop + 'Setter'] = function (value, key, elem) {\n const styleObject = gWrapper.div ?\n gWrapper.div.style :\n style;\n SVGElement.prototype[prop + 'Setter']\n .call(this, value, key, elem);\n if (styleObject) {\n styleObject[key] = value;\n }\n };\n });\n gWrapper.addedSetters = true;\n };\n // Text setter\n wrapper.textSetter = function (value) {\n if (value !== this.textStr) {\n delete this.bBox;\n delete this.oldTextWidth;\n AST.setElementHTML(this.element, pick(value, ''));\n this.textStr = value;\n wrapper.doTransform = true;\n }\n };\n addSetters(wrapper, wrapper.element.style);\n // Various setters which rely on update transform\n wrapper.xSetter =\n wrapper.ySetter =\n wrapper.alignSetter =\n wrapper.rotationSetter =\n function (value, key) {\n if (key === 'align') {\n // Do not overwrite the SVGElement.align method.\n wrapper.alignValue = wrapper.textAlign = value;\n }\n else {\n wrapper[key] = value;\n }\n wrapper.doTransform = true;\n };\n // Runs at the end of .attr()\n wrapper.afterSetters = function () {\n // Update transform. Do this outside the loop to prevent redundant\n // updating for batch setting of attributes.\n if (this.doTransform) {\n this.htmlUpdateTransform();\n this.doTransform = false;\n }\n };\n // Set the default attributes\n wrapper\n .attr({\n text: str,\n x: Math.round(x),\n y: Math.round(y)\n })\n .css({\n position: 'absolute'\n });\n if (!renderer.styledMode) {\n wrapper.css({\n fontFamily: this.style.fontFamily,\n fontSize: this.style.fontSize\n });\n }\n // Keep the whiteSpace style outside the wrapper.styles collection\n element.style.whiteSpace = 'nowrap';\n // Use the HTML specific .css method\n wrapper.css = wrapper.htmlCss;\n wrapper.add = function (svgGroupWrapper) {\n const container = renderer.box.parentNode, parents = [];\n let htmlGroup, parentGroup;\n this.parentGroup = svgGroupWrapper;\n // Create a mock group to hold the HTML elements\n if (svgGroupWrapper) {\n htmlGroup = svgGroupWrapper.div;\n if (!htmlGroup) {\n // Read the parent chain into an array and read from top\n // down\n parentGroup = svgGroupWrapper;\n while (parentGroup) {\n parents.push(parentGroup);\n // Move up to the next parent group\n parentGroup = parentGroup.parentGroup;\n }\n // Ensure dynamically updating position when any parent\n // is translated\n parents.reverse().forEach(function (parentGroup) {\n const cls = attr(parentGroup.element, 'class');\n /**\n * Common translate setter for X and Y on the HTML\n * group. Reverted the fix for #6957 du to\n * positioning problems and offline export (#7254,\n * #7280, #7529)\n * @private\n * @param {*} value\n * @param {string} key\n */\n function translateSetter(value, key) {\n parentGroup[key] = value;\n if (key === 'translateX') {\n htmlGroupStyle.left = value + 'px';\n }\n else {\n htmlGroupStyle.top = value + 'px';\n }\n parentGroup.doTransform = true;\n }\n // Create a HTML div and append it to the parent div\n // to emulate the SVG group structure\n const parentGroupStyles = parentGroup.styles || {};\n htmlGroup =\n parentGroup.div =\n parentGroup.div || createElement('div', cls ? { className: cls } : void 0, {\n position: 'absolute',\n left: (parentGroup.translateX || 0) + 'px',\n top: (parentGroup.translateY || 0) + 'px',\n display: parentGroup.display,\n opacity: parentGroup.opacity,\n visibility: parentGroup.visibility\n // the top group is appended to container\n }, htmlGroup || container);\n // Shortcut\n const htmlGroupStyle = htmlGroup.style;\n // Set listeners to update the HTML div's position\n // whenever the SVG group position is changed.\n extend(parentGroup, {\n // (#7287) Pass htmlGroup to use\n // the related group\n classSetter: (function (htmlGroup) {\n return function (value) {\n this.element.setAttribute('class', value);\n htmlGroup.className = value;\n };\n }(htmlGroup)),\n // Extend the parent group's css function by\n // updating the shadow div counterpart with the same\n // style.\n css: function (styles) {\n wrapper.css.call(parentGroup, styles);\n [\n // #6794\n 'cursor',\n // #5595, #18821\n 'pointerEvents'\n ].forEach((prop) => {\n if (styles[prop]) {\n htmlGroupStyle[prop] = styles[prop];\n }\n });\n return parentGroup;\n },\n on: function () {\n if (parents[0].div) { // #6418\n wrapper.on.apply({\n element: parents[0].div,\n onEvents: parentGroup.onEvents\n }, arguments);\n }\n return parentGroup;\n },\n translateXSetter: translateSetter,\n translateYSetter: translateSetter\n });\n if (!parentGroup.addedSetters) {\n addSetters(parentGroup);\n }\n // Apply pre-existing style\n parentGroup.css(parentGroupStyles);\n });\n }\n }\n else {\n htmlGroup = container;\n }\n htmlGroup.appendChild(element);\n wrapper.added = true;\n if (wrapper.alignOnAdd) {\n wrapper.htmlUpdateTransform();\n }\n return wrapper;\n };\n return wrapper;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return HTMLRenderer;\n });\n _registerModule(_modules, 'Core/Axis/AxisDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Namespace\n *\n * */\n var AxisDefaults;\n (function (AxisDefaults) {\n /* *\n *\n * Constants\n *\n * */\n /**\n * The X axis or category axis. Normally this is the horizontal axis,\n * though if the chart is inverted this is the vertical axis. In case of\n * multiple axes, the xAxis node is an array of configuration objects.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden, but it is used behind the scenes to\n * control features like zooming and panning. Zooming is in effect the same\n * as setting the extremes of one of the exes.\n *\n * @type {*|Array<*>}\n * @optionparent xAxis\n */\n AxisDefaults.defaultXAxisOptions = {\n /**\n * When using multiple axis, the ticks of two or more opposite axes\n * will automatically be aligned by adding ticks to the axis or axes\n * with the least ticks, as if `tickAmount` were specified.\n *\n * This can be prevented by setting `alignTicks` to false. If the grid\n * lines look messy, it's a good idea to hide them for the secondary\n * axis by setting `gridLineWidth` to 0.\n *\n * If `startOnTick` or `endOnTick` in an Axis options are set to false,\n * then the `alignTicks ` will be disabled for the Axis.\n *\n * Disabled for logarithmic axes.\n *\n * @product highcharts highstock gantt\n */\n alignTicks: true,\n /**\n * Whether to allow decimals in this axis' ticks. When counting\n * integers, like persons or hits on a web page, decimals should\n * be avoided in the labels. By default, decimals are allowed on small\n * scale axes.\n *\n * @see [minTickInterval](#xAxis.minTickInterval)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-true/\n * True by default\n * @sample {highcharts|highstock} highcharts/yaxis/allowdecimals-false/\n * False\n *\n * @type {boolean|undefined}\n * @default undefined\n * @since 2.0\n */\n allowDecimals: void 0,\n /**\n * When using an alternate grid color, a band is painted across the\n * plot area between every other grid line.\n *\n * @sample {highcharts} highcharts/yaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n * @sample {highstock} stock/xaxis/alternategridcolor/\n * Alternate grid color on the Y axis\n *\n * @type {Highcharts.ColorType}\n * @apioption xAxis.alternateGridColor\n */\n /**\n * An array defining breaks in the axis, the sections defined will be\n * left out and all the points shifted closer to each other.\n *\n * @productdesc {highcharts}\n * Requires that the broken-axis.js module is loaded.\n *\n * @sample {highcharts} highcharts/axisbreak/break-simple/\n * Simple break\n * @sample {highcharts|highstock} highcharts/axisbreak/break-visualized/\n * Advanced with callback\n * @sample {highstock} stock/demo/intraday-breaks/\n * Break on nights and weekends\n *\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks\n */\n /**\n * A number indicating how much space should be left between the start\n * and the end of the break. The break size is given in axis units,\n * so for instance on a `datetime` axis, a break size of 3600000 would\n * indicate the equivalent of an hour.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.breakSize\n */\n /**\n * The point where the break starts.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.from\n */\n /**\n * Defines an interval after which the break appears again. By default\n * the breaks do not repeat.\n *\n * @type {number}\n * @default 0\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.repeat\n */\n /**\n * The point where the break ends.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.breaks.to\n */\n /**\n * If categories are present for the xAxis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also\n * be extracted by giving each point a [name](#series.data) and setting\n * axis [type](#xAxis.type) to `category`. However, if you have multiple\n * series, best practice remains defining the `categories` array.\n *\n * Example: `categories: ['Apples', 'Bananas', 'Oranges']`\n *\n * @sample {highcharts} highcharts/demo/line-labels/\n * With\n * @sample {highcharts} highcharts/xaxis/categories/\n * Without\n *\n * @type {Array}\n * @product highcharts gantt\n * @apioption xAxis.categories\n */\n /**\n * The highest allowed value for automatically computed axis extremes.\n *\n * @see [floor](#xAxis.floor)\n *\n * @sample {highcharts|highstock} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.ceiling\n */\n /**\n * A class name that opens for styling the axis by CSS, especially in\n * Highcharts styled mode. The class name is applied to group elements\n * for the grid, axis elements and labels.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/css/axis/\n * Multiple axes with separate styling\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.className\n */\n /**\n * Configure a crosshair that follows either the mouse pointer or the\n * hovered point.\n *\n * In styled mode, the crosshairs are styled in the\n * `.highcharts-crosshair`, `.highcharts-crosshair-thin` or\n * `.highcharts-xaxis-category` classes.\n *\n * @productdesc {highstock}\n * In Highcharts stock, by default, the crosshair is enabled on the\n * X axis and disabled on the Y axis.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Crosshair on both axes, with y axis label\n * @sample {highmaps} highcharts/xaxis/crosshair-both/\n * Crosshair on both axes\n *\n * @declare Highcharts.AxisCrosshairOptions\n * @type {boolean|*}\n * @default false\n * @since 4.1\n * @apioption xAxis.crosshair\n */\n /**\n * The value on a perpendicular axis where this axis should cross. This\n * is typically used on mathematical plots where the axes cross at 0.\n * When `crossing` is set, space will not be reserved at the sides of\n * the chart for axis labels and title, so those may be clipped. In this\n * case it is better to place the axes without the `crossing` option.\n *\n * @type {number}\n * @sample highcharts/xaxis/crossing\n * Function plot with axes crossing at 0\n * @since 11.0.1\n * @apioption xAxis.crossing\n */\n /**\n * A class name for the crosshair, especially as a hook for styling.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.crosshair.className\n */\n /**\n * The color of the crosshair. Defaults to `#cccccc` for numeric and\n * datetime axes, and `rgba(204,214,235,0.25)` for category axes, where\n * the crosshair by default highlights the whole category.\n *\n * @sample {highcharts|highstock|highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {Highcharts.ColorType}\n * @default #cccccc\n * @since 4.1\n * @apioption xAxis.crosshair.color\n */\n /**\n * The dash style for the crosshair. See\n * [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n * for possible values.\n *\n * @sample {highcharts|highmaps} highcharts/xaxis/crosshair-dotted/\n * Dotted crosshair\n * @sample {highstock} stock/xaxis/crosshair-dashed/\n * Dashed X axis crosshair\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 4.1\n * @apioption xAxis.crosshair.dashStyle\n */\n /**\n * A label on the axis next to the crosshair.\n *\n * In styled mode, the label is styled with the\n * `.highcharts-crosshair-label` class.\n *\n * @sample {highstock} stock/xaxis/crosshair-label/\n * Crosshair labels\n * @sample {highstock} highcharts/css/crosshair-label/\n * Style mode\n *\n * @declare Highcharts.AxisCrosshairLabelOptions\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label\n */\n /**\n * Alignment of the label compared to the axis. Defaults to `\"left\"` for\n * right-side axes, `\"right\"` for left-side axes and `\"center\"` for\n * horizontal axes.\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.align\n */\n /**\n * The background color for the label. Defaults to the related series\n * color, or `#666666` if that is not available.\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.backgroundColor\n */\n /**\n * The border color for the crosshair label\n *\n * @type {Highcharts.ColorType}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderColor\n */\n /**\n * The border corner radius of the crosshair label.\n *\n * @type {number}\n * @default 3\n * @since 2.1.10\n * @product highstock\n * @apioption xAxis.crosshair.label.borderRadius\n */\n /**\n * The border width for the crosshair label.\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.borderWidth\n */\n /**\n * Flag to enable crosshair's label.\n *\n * @sample {highstock} stock/xaxis/crosshairs-xy/\n * Enabled label for yAxis' crosshair\n *\n * @type {boolean}\n * @default false\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.enabled\n */\n /**\n * A format string for the crosshair label. Defaults to `{value}` for\n * numeric axes and `{value:%b %d, %Y}` for datetime axes.\n *\n * @type {string}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.format\n */\n /**\n * Formatter function for the label text.\n *\n * @type {Highcharts.XAxisCrosshairLabelFormatterCallbackFunction}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.formatter\n */\n /**\n * Padding inside the crosshair label.\n *\n * @type {number}\n * @default 8\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.padding\n */\n /**\n * The shape to use for the label box.\n *\n * @type {string}\n * @default callout\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.shape\n */\n /**\n * Text styles for the crosshair label.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"white\", \"fontWeight\": \"normal\", \"fontSize\": \"11px\", \"textAlign\": \"center\"}\n * @since 2.1\n * @product highstock\n * @apioption xAxis.crosshair.label.style\n */\n /**\n * Whether the crosshair should snap to the point or follow the pointer\n * independent of points.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/crosshair-snap-false/\n * True by default\n * @sample {highmaps} maps/demo/latlon-advanced/\n * Snap is false\n *\n * @type {boolean}\n * @default true\n * @since 4.1\n * @apioption xAxis.crosshair.snap\n */\n /**\n * The pixel width of the crosshair. Defaults to 1 for numeric or\n * datetime axes, and for one category width for category axes.\n *\n * @sample {highcharts} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highstock} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n * @sample {highmaps} highcharts/xaxis/crosshair-customized/\n * Customized crosshairs\n *\n * @type {number}\n * @default 1\n * @since 4.1\n * @apioption xAxis.crosshair.width\n */\n /**\n * The Z index of the crosshair. Higher Z indices allow drawing the\n * crosshair on top of the series or behind the grid lines.\n *\n * @type {number}\n * @default 2\n * @since 4.1\n * @apioption xAxis.crosshair.zIndex\n */\n /**\n * Whether to pan axis. If `chart.panning` is enabled, the option\n * allows to disable panning on an individual axis.\n */\n panningEnabled: true,\n /**\n * The Z index for the axis group.\n */\n zIndex: 2,\n /**\n * Whether to zoom axis. If `chart.zoomType` is set, the option allows\n * to disable zooming on an individual axis.\n *\n * @sample {highcharts} highcharts/xaxis/zoomenabled/\n * Zoom enabled is false\n */\n zoomEnabled: true,\n /**\n * For a datetime axis, the scale will automatically adjust to the\n * appropriate unit. This member gives the default string\n * representations used for each unit. For intermediate values,\n * different units may be used, for example the `day` unit can be used\n * on midnight and `hour` unit be used for intermediate values on the\n * same axis.\n *\n * For an overview of the replacement codes, see\n * [dateFormat](/class-reference/Highcharts.Time#dateFormat).\n *\n * Defaults to:\n * ```js\n * {\n * millisecond: '%H:%M:%S.%L',\n * second: '%H:%M:%S',\n * minute: '%H:%M',\n * hour: '%H:%M',\n * day: '%e. %b',\n * week: '%e. %b',\n * month: '%b \\'%y',\n * year: '%Y'\n * }\n * ```\n *\n * @sample {highcharts} highcharts/xaxis/datetimelabelformats/\n * Different day format on X axis\n * @sample {highstock} stock/xaxis/datetimelabelformats/\n * More information in x axis labels\n *\n * @declare Highcharts.AxisDateTimeLabelFormatsOptions\n * @product highcharts highstock gantt\n */\n dateTimeLabelFormats: {\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n millisecond: {\n main: '%H:%M:%S.%L',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n second: {\n main: '%H:%M:%S',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n minute: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n hour: {\n main: '%H:%M',\n range: false\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n day: {\n main: '%e %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n week: {\n main: '%e %b'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n month: {\n main: '%b \\'%y'\n },\n /**\n * @declare Highcharts.AxisDateTimeLabelFormatsOptionsObject\n * @type {string|*}\n */\n year: {\n main: '%Y'\n }\n },\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `endOnTick` is always `false` when the navigator\n * is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False\n *\n * @since 1.2.0\n */\n endOnTick: false,\n /**\n * Event handlers for the axis.\n *\n * @type {*}\n * @apioption xAxis.events\n */\n /**\n * An event fired after the breaks have rendered.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-event/\n * AfterBreak Event\n *\n * @type {Highcharts.AxisEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @apioption xAxis.events.afterBreaks\n */\n /**\n * As opposed to the `setExtremes` event, this event fires after the\n * final min and max values are computed and corrected for `minRange`.\n *\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function, containing\n * common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in axis values. The actual data extremes are found in\n * `event.dataMin` and `event.dataMax`.\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 2.3\n * @context Highcharts.Axis\n * @apioption xAxis.events.afterSetExtremes\n */\n /**\n * An event fired when a break from this axis occurs on a point.\n *\n * @see [breaks](#xAxis.breaks)\n *\n * @sample {highcharts} highcharts/axisbreak/break-visualized/\n * Visualization of a Break\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @since 4.1.0\n * @product highcharts gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointBreak\n */\n /**\n * An event fired when a point falls inside a break from this axis.\n *\n * @type {Highcharts.AxisPointBreakEventCallbackFunction}\n * @product highcharts highstock gantt\n * @context Highcharts.Axis\n * @apioption xAxis.events.pointInBreak\n */\n /**\n * Fires when the minimum and maximum is set for the axis, either by\n * calling the `.setExtremes()` method or by selecting an area in the\n * chart. One parameter, `event`, is passed to the function,\n * containing common event information.\n *\n * The new user set minimum and maximum values can be found by\n * `event.min` and `event.max`. These reflect the axis minimum and\n * maximum in data values. When an axis is zoomed all the way out from\n * the \"Reset zoom\" button, `event.min` and `event.max` are null, and\n * the new extremes are set based on `this.dataMin` and `this.dataMax`.\n *\n * @sample {highstock} stock/xaxis/events-setextremes/\n * Log new extremes on x axis\n *\n * @type {Highcharts.AxisSetExtremesEventCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Axis\n * @apioption xAxis.events.setExtremes\n */\n /**\n * The lowest allowed value for automatically computed axis extremes.\n *\n * @see [ceiling](#yAxis.ceiling)\n *\n * @sample {highcharts} highcharts/yaxis/floor-ceiling/\n * Floor and ceiling\n * @sample {highstock} stock/demo/lazy-loading/\n * Prevent negative stock price on Y axis\n *\n * @type {number}\n * @since 4.0\n * @product highcharts highstock gantt\n * @apioption xAxis.floor\n */\n /**\n * The dash or dot style of the grid lines. For possible values, see\n * [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/gridlinedashstyle/\n * Long dashes\n * @sample {highstock} stock/xaxis/gridlinedashstyle/\n * Long dashes\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n gridLineDashStyle: 'Solid',\n /**\n * The Z index of the grid lines.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/gridzindex/\n * A Z index of 4 renders the grid above the graph\n *\n * @product highcharts highstock gantt\n */\n gridZIndex: 1,\n /**\n * An id for the axis. This can be used after render time to get\n * a pointer to the axis object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/xaxis/id/\n * Get the object\n * @sample {highstock} stock/xaxis/id/\n * Get the object\n *\n * @type {string}\n * @since 1.2.0\n * @apioption xAxis.id\n */\n /**\n * The axis labels show the number or category for each tick.\n *\n * Since v8.0.0: Labels are animated in categorized x-axis with\n * updating data if `tickInterval` and `step` is set to 1.\n *\n * @productdesc {highmaps}\n * X and Y axis labels are by default disabled in Highmaps, but the\n * functionality is inherited from Highcharts and used on `colorAxis`,\n * and can be enabled on X and Y axes too.\n */\n labels: {\n /**\n * What part of the string the given position is anchored to.\n * If `left`, the left side of the string is at the axis position.\n * Can be one of `\"left\"`, `\"center\"` or `\"right\"`. Defaults to\n * an intelligent guess based on which side of the chart the axis\n * is on and the rotation of the label.\n *\n * @see [reserveSpace](#xAxis.labels.reserveSpace)\n *\n * @sample {highcharts} highcharts/xaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/xaxis/labels-align-right/\n * Right\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.labels.align\n */\n /**\n * Whether to allow the axis labels to overlap. When false,\n * overlapping labels are hidden.\n *\n * @sample {highcharts} highcharts/xaxis/labels-allowoverlap-true/\n * X axis labels overlap enabled\n *\n * @type {boolean}\n * @default false\n * @apioption xAxis.labels.allowOverlap\n */\n /**\n * For horizontal axes, the allowed degrees of label rotation\n * to prevent overlapping labels. If there is enough space,\n * labels are not rotated. As the chart gets narrower, it\n * will start rotating the labels -45 degrees, then remove\n * every second label and try again with rotations 0 and -45 etc.\n * Set it to `undefined` to disable rotation, which will\n * cause the labels to word-wrap if possible. Defaults to `[-45]``\n * on bottom and top axes, `undefined` on left and right axes.\n *\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-default/\n * Default auto rotation of 0 or -45\n * @sample {highcharts|highstock} highcharts/xaxis/labels-autorotation-0-90/\n * Custom graded auto rotation\n *\n * @type {Array}\n * @default undefined\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.labels.autoRotation\n */\n autoRotation: void 0,\n /**\n * When each category width is more than this many pixels, we don't\n * apply auto rotation. Instead, we lay out the axis label with word\n * wrap. A lower limit makes sense when the label contains multiple\n * short words that don't extend the available horizontal space for\n * each label.\n *\n * @sample {highcharts} highcharts/xaxis/labels-autorotationlimit/\n * Lower limit\n *\n * @since 4.1.5\n * @product highcharts gantt\n */\n autoRotationLimit: 80,\n /**\n * The label's pixel distance from the perimeter of the plot area.\n * On cartesian charts, this is overridden if the `labels.y` setting\n * is set.\n *\n * @sample {highcharts} highcharts/yaxis/labels-distance/\n * Polar chart, labels centered under the arc\n *\n * @type {number}\n * @product highcharts gantt\n */\n distance: 15,\n /**\n * Enable or disable the axis labels.\n *\n * @sample {highcharts} highcharts/xaxis/labels-enabled/\n * X axis labels disabled\n * @sample {highstock} stock/xaxis/labels-enabled/\n * X axis labels disabled\n *\n */\n enabled: true,\n /**\n * A format string for the axis label. The context is available as\n * format string variables. For example, you can use `{text}` to\n * insert the default formatted text. The recommended way of adding\n * units for the label is using `text`, for example `{text} km`.\n *\n * To add custom numeric or datetime formatting, use `{value}` with\n * formatting, for example `{value:.1f}` or `{value:%Y-%m-%d}`.\n *\n * See\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for more examples of formatting.\n *\n * The default value is not specified due to the dynamic\n * nature of the default implementation.\n *\n * @sample {highcharts|highstock} highcharts/yaxis/labels-format/\n * Add units to Y axis label\n * @sample {highcharts} highcharts/xaxis/labels-format-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-format-custom/\n * Custom number format\n *\n * @type {string}\n * @since 3.0\n * @apioption xAxis.labels.format\n */\n /**\n * Callback JavaScript function to format the label. The value\n * is given by `this.value`. Additional properties for `this` are\n * `axis`, `chart`, `isFirst`, `isLast` and `text` which holds the\n * value of the default formatter.\n *\n * Defaults to a built in function returning a formatted string\n * depending on whether the axis is `category`, `datetime`,\n * `numeric` or other.\n *\n * @sample {highcharts} highcharts/xaxis/labels-formatter-linked/\n * Linked category names\n * @sample {highcharts} highcharts/xaxis/labels-formatter-extended/\n * Modified numeric labels\n * @sample {highstock} stock/xaxis/labels-formatter/\n * Added units on Y axis\n *\n * @type {Highcharts.AxisLabelsFormatterCallbackFunction}\n * @apioption xAxis.labels.formatter\n */\n /**\n * The number of pixels to indent the labels per level in a treegrid\n * axis.\n *\n * @sample gantt/treegrid-axis/demo\n * Indentation 10px by default.\n * @sample gantt/treegrid-axis/indentation-0px\n * Indentation set to 0px.\n *\n * @product gantt\n */\n indentation: 10,\n /**\n * Horizontal axis only. When `staggerLines` is not set,\n * `maxStaggerLines` defines how many lines the axis is allowed to\n * add to automatically avoid overlapping X labels. Set to `1` to\n * disable overlap detection.\n *\n * @deprecated\n * @type {number}\n * @default 5\n * @since 1.3.3\n * @apioption xAxis.labels.maxStaggerLines\n */\n /**\n * How to handle overflowing labels on horizontal axis. If set to\n * `\"allow\"`, it will not be aligned at all. By default it\n * `\"justify\"` labels inside the chart area. If there is room to\n * move it, it will be aligned to the edge, else it will be removed.\n *\n * @since 2.2.5\n * @validvalue [\"allow\", \"justify\"]\n */\n overflow: 'justify',\n /**\n * The pixel padding for axis labels, to ensure white space between\n * them.\n *\n * @product highcharts gantt\n */\n padding: 5,\n /**\n * Whether to reserve space for the labels. By default, space is\n * reserved for the labels in these cases:\n *\n * * On all horizontal axes.\n * * On vertical axes if `label.align` is `right` on a left-side\n * axis or `left` on a right-side axis.\n * * On vertical axes if `label.align` is `center`.\n *\n * This can be turned off when for example the labels are rendered\n * inside the plot area instead of outside.\n *\n * @see [labels.align](#xAxis.labels.align)\n *\n * @sample {highcharts} highcharts/xaxis/labels-reservespace/\n * No reserved space, labels inside plot\n * @sample {highcharts} highcharts/xaxis/labels-reservespace-true/\n * Left-aligned labels on a vertical category axis\n *\n * @type {boolean}\n * @since 4.1.10\n * @product highcharts highstock gantt\n * @apioption xAxis.labels.reserveSpace\n */\n reserveSpace: void 0,\n /**\n * Rotation of the labels in degrees. When `undefined`, the\n * `autoRotation` option takes precedence.\n *\n * @sample {highcharts} highcharts/xaxis/labels-rotation/\n * X axis labels rotated 90°\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.labels.rotation\n */\n rotation: void 0,\n /**\n * Horizontal axes only. The number of lines to spread the labels\n * over to make room or tighter labels. 0 disables staggering.\n *\n * @sample {highcharts} highcharts/xaxis/labels-staggerlines/\n * Show labels over two lines\n * @sample {highstock} stock/xaxis/labels-staggerlines/\n * Show labels over two lines\n *\n * @since 2.1\n */\n staggerLines: 0,\n /**\n * To show only every _n_'th label on the axis, set the step to _n_.\n * Setting the step to 2 shows every other label.\n *\n * By default, when 0, the step is calculated automatically to avoid\n * overlap. To prevent this, set it to 1\\. This usually only\n * happens on a category axis, and is often a sign that you have\n * chosen the wrong axis type.\n *\n * Read more at\n * [Axis docs](https://www.highcharts.com/docs/chart-concepts/axes)\n * => What axis should I use?\n *\n * @sample {highcharts} highcharts/xaxis/labels-step/\n * Showing only every other axis label on a categorized\n * x-axis\n * @sample {highcharts} highcharts/xaxis/labels-step-auto/\n * Auto steps on a category axis\n *\n * @since 2.1\n */\n step: 0,\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n */\n useHTML: false,\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis. Overrides the `labels.distance` option.\n *\n * @type {number}\n * @apioption xAxis.labels.x\n */\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. Overrides the `labels.distance` option.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * X axis labels placed on grid lines\n *\n * @type {number}\n * @apioption xAxis.labels.y\n */\n /**\n * The Z index for the axis labels.\n */\n zIndex: 7,\n /**\n * CSS styles for the label. Use `whiteSpace: 'nowrap'` to prevent\n * wrapping of category labels. Use `textOverflow: 'none'` to\n * prevent ellipsis (dots).\n *\n * In styled mode, the labels are styled with the\n * `.highcharts-axis-labels` class.\n *\n * @sample {highcharts} highcharts/xaxis/labels-style/\n * Red X axis labels\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#333333\" /* Palette.neutralColor80 */,\n /** @internal */\n cursor: 'default',\n /** @internal */\n fontSize: '0.8em'\n }\n },\n /**\n * The left position as the horizontal axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the plot width, offset from plot area\n * left.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.left\n */\n /**\n * The top position as the vertical axis. If it's a number, it is\n * interpreted as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the plot height, offset from plot area top.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.top\n */\n /**\n * Index of another axis that this axis is linked to. When an axis is\n * linked to a master axis, it will take the same extremes as\n * the master, but as assigned by min or max or by setExtremes.\n * It can be used to show additional info, or to ease reading the\n * chart by duplicating the scales.\n *\n * @sample {highcharts} highcharts/xaxis/linkedto/\n * Different string formats of the same date\n * @sample {highcharts} highcharts/yaxis/linkedto/\n * Y values on both sides\n *\n * @type {number}\n * @since 2.0.2\n * @product highcharts highstock gantt\n * @apioption xAxis.linkedTo\n */\n /**\n * The maximum value of the axis. If `null`, the max value is\n * automatically calculated.\n *\n * If the [endOnTick](#yAxis.endOnTick) option is true, the `max` value\n * might be rounded up.\n *\n * If a [tickAmount](#yAxis.tickAmount) is set, the axis may be extended\n * beyond the set max in order to reach the given number of ticks. The\n * same may happen in a chart with multiple axes, determined by [chart.\n * alignTicks](#chart), where a `tickAmount` is applied internally.\n *\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/xaxis/min-max/\n * Fixed min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.max\n */\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding/\n * Max padding of 0.25 on y axis\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n */\n maxPadding: 0.01,\n /**\n * Deprecated. Use `minRange` instead.\n *\n * @deprecated\n * @type {number}\n * @product highcharts highstock\n * @apioption xAxis.maxZoom\n */\n /**\n * The minimum value of the axis. If `null` the min value is\n * automatically calculated.\n *\n * If the [startOnTick](#yAxis.startOnTick) option is true (default),\n * the `min` value might be rounded down.\n *\n * The automatically calculated minimum value is also affected by\n * [floor](#yAxis.floor), [softMin](#yAxis.softMin),\n * [minPadding](#yAxis.minPadding), [minRange](#yAxis.minRange)\n * as well as [series.threshold](#plotOptions.series.threshold)\n * and [series.softThreshold](#plotOptions.series.softThreshold).\n *\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/xaxis/min-max/\n * Set min and max on X axis\n *\n * @type {number|null}\n * @apioption xAxis.min\n */\n /**\n * The dash or dot style of the minor grid lines. For possible values,\n * see [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n * @sample {highstock} stock/xaxis/minorgridlinedashstyle/\n * Long dashes on minor grid lines\n *\n * @type {Highcharts.DashStyleValue}\n * @since 1.2\n */\n minorGridLineDashStyle: 'Solid',\n /**\n * Specific tick interval in axis units for the minor ticks. On a linear\n * axis, if `\"auto\"`, the minor tick interval is calculated as a fifth\n * of the tickInterval. If `null` or `undefined`, minor ticks are not\n * shown.\n *\n * On logarithmic axes, the unit is the power of the value. For example,\n * setting the minorTickInterval to 1 puts one tick on each of 0.1, 1,\n * 10, 100 etc. Setting the minorTickInterval to 0.1 produces 9 ticks\n * between 1 and 10, 10 and 100 etc.\n *\n * If user settings dictate minor ticks to become too dense, they don't\n * make sense, and will be ignored to prevent performance problems.\n *\n * @sample {highcharts} highcharts/yaxis/minortickinterval-null/\n * Null by default\n * @sample {highcharts} highcharts/yaxis/minortickinterval-5/\n * 5 units\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log-auto/\n * \"auto\"\n * @sample {highcharts} highcharts/yaxis/minortickinterval-log/\n * 0.1\n * @sample {highstock} stock/demo/basic-line/\n * Null by default\n * @sample {highstock} stock/xaxis/minortickinterval-auto/\n * \"auto\"\n *\n * @type {number|string|null}\n * @apioption xAxis.minorTickInterval\n */\n /**\n * The pixel length of the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minorticklength/\n * 10px on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * 10px on Y axis\n */\n minorTickLength: 2,\n /**\n * The position of the minor tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/yaxis/minortickposition-outside/\n * Outside by default\n * @sample {highcharts} highcharts/yaxis/minortickposition-inside/\n * Inside\n * @sample {highstock} stock/xaxis/minorticks/\n * Inside\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n minorTickPosition: 'outside',\n /**\n * Enable or disable minor ticks. The interval between the minor ticks\n * can be controlled either by the\n * [minorTicksPerMajor](#xAxis.minorTicksPerMajor) setting, or as an\n * absolute [minorTickInterval](#xAxis.minorTickInterval) value.\n *\n * On a logarithmic axis, minor ticks are laid out based on a best\n * guess, attempting to enter an approximate number of minor ticks\n * between each major tick based on\n * [minorTicksPerMajor](#xAxis.minorTicksPerMajor).\n *\n * Prior to v6.0.0, ticks were enabled in auto layout by setting\n * `minorTickInterval` to `\"auto\"`.\n *\n * @productdesc {highcharts} On axes using\n * [categories](#xAxis.categories), minor ticks are not supported.\n *\n * @sample {highcharts} highcharts/yaxis/minorticks-true/ Enabled on\n * linear Y axis\n *\n * @type {boolean}\n * @default false\n * @since 6.0.0\n * @apioption xAxis.minorTicks\n */\n /**\n * The number of minor ticks per major tick. Works for `linear`,\n * `logarithmic` and `datetime` axes.\n *\n * @sample {highcharts} highcharts/yaxis/minortickspermajor/\n * 2 minor ticks per major tick on Y axis\n *\n * @type {number}\n */\n minorTicksPerMajor: 5,\n /**\n * The pixel width of the minor tick mark.\n *\n * @sample {highcharts} highcharts/yaxis/minortickwidth/\n * 3px width\n * @sample {highstock} stock/xaxis/minorticks/\n * 1px width\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.minorTickWidth\n */\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a min extreme\n * is set using `axis.setExtremes()`, the minPadding will be ignored.\n *\n * @productdesc {highstock}\n * For an [ordinal](#xAxis.ordinal) axis, `minPadding` and `maxPadding`\n * are ignored. Use [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n * @sample {highmaps} maps/chart/plotbackgroundcolor-gradient/\n * Add some padding\n *\n * @default {highcharts} 0.01\n * @default {highstock|highmaps} 0\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.01,\n /**\n * The minimum range to display on this axis. The entire axis will not\n * be allowed to span over a smaller interval than this. For example,\n * for a datetime axis the main unit is milliseconds. If minRange is\n * set to 3600000, you can't zoom in more than to one hour.\n *\n * The default minRange for the x axis is five times the smallest\n * interval between any of the data points.\n *\n * On a logarithmic axis, the unit for the minimum range is the power.\n * So a minRange of 1 means that the axis can be zoomed to 10-100,\n * 100-1000, 1000-10000 etc.\n *\n * **Note**: The `minPadding`, `maxPadding`, `startOnTick` and\n * `endOnTick` settings also affect how the extremes of the axis\n * are computed.\n *\n * @sample {highcharts} highcharts/xaxis/minrange/\n * Minimum range of 5\n * @sample {highstock} stock/xaxis/minrange/\n * Max zoom of 6 months overrides user selections\n *\n * @type {number}\n * @apioption xAxis.minRange\n */\n /**\n * The minimum tick interval allowed in axis values. For example on\n * zooming in on an axis with daily data, this can be used to prevent\n * the axis from showing hours. Defaults to the closest distance between\n * two points on the axis.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption xAxis.minTickInterval\n */\n /**\n * The distance in pixels from the plot area to the axis line.\n * A positive offset moves the axis with it's line, labels and ticks\n * away from the plot area. This is typically used when two or more\n * axes are displayed on the same side of the plot. With multiple\n * axes the offset is dynamically adjusted to avoid collision, this\n * can be overridden by setting offset explicitly.\n *\n * @sample {highcharts} highcharts/yaxis/offset/\n * Y axis offset of 70\n * @sample {highcharts} highcharts/yaxis/offset-centered/\n * Axes positioned in the center of the plot\n * @sample {highstock} stock/xaxis/offset/\n * Y axis offset by 70 px\n *\n * @type {number}\n */\n offset: void 0,\n /**\n * Whether to display the axis on the opposite side of the normal. The\n * normal is on the left side for vertical axes and bottom for\n * horizontal, so the opposite sides will be right and top respectively.\n * This is typically used with dual or multiple axes.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @default {highcharts|highstock|highmaps} false\n * @default {gantt} true\n */\n opposite: false,\n /**\n * In an ordinal axis, the points are equally spaced in the chart\n * regardless of the actual time or x distance between them. This means\n * that missing data periods (e.g. nights or weekends for a stock chart)\n * will not take up space in the chart.\n * Having `ordinal: false` will show any gaps created by the `gapSize`\n * setting proportionate to their duration.\n *\n * In stock charts the X axis is ordinal by default, unless\n * the boost module is used and at least one of the series' data length\n * exceeds the [boostThreshold](#series.line.boostThreshold).\n *\n * For an ordinal axis, `minPadding` and `maxPadding` are ignored. Use\n * [overscroll](#xAxis.overscroll) instead.\n *\n * @sample {highstock} stock/xaxis/ordinal-true/\n * True by default\n * @sample {highstock} stock/xaxis/ordinal-false/\n * False\n *\n * @see [overscroll](#xAxis.overscroll)\n *\n * @type {boolean}\n * @default true\n * @since 1.1\n * @product highstock\n * @apioption xAxis.ordinal\n */\n /**\n * Additional range on the right side of the xAxis. Works similar to\n * `xAxis.maxPadding`, but value is set in milliseconds. Can be set for\n * both main `xAxis` and the navigator's `xAxis`.\n *\n * @sample {highstock} stock/xaxis/overscroll/\n * One minute overscroll with live data\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @product highstock\n * @apioption xAxis.overscroll\n */\n /**\n * Refers to the index in the [panes](#panes) array. Used for circular\n * gauges and polar charts. When the option is not set then first pane\n * will be used.\n *\n * @sample highcharts/demo/gauge-vu-meter\n * Two gauges with different center\n *\n * @type {number}\n * @product highcharts\n * @apioption xAxis.pane\n */\n /**\n * The zoomed range to display when only defining one or none of `min`\n * or `max`. For example, to show the latest month, a range of one month\n * can be set.\n *\n * @sample {highstock} stock/xaxis/range/\n * Setting a zoomed range when the rangeSelector is disabled\n *\n * @type {number}\n * @product highstock\n * @apioption xAxis.range\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin. If the chart is inverted, the x axis is reversed by\n * default.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default undefined\n * @apioption xAxis.reversed\n */\n reversed: void 0,\n /**\n * This option determines how stacks should be ordered within a group.\n * For example reversed xAxis also reverses stacks, so first series\n * comes last in a group. To keep order like for non-reversed xAxis\n * enable this option.\n *\n * @sample {highcharts} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n * @sample {highstock} highcharts/xaxis/reversedstacks/\n * Reversed stacks comparison\n *\n * @since 6.1.1\n * @product highcharts highstock\n */\n reversedStacks: false,\n /**\n * An optional scrollbar to display on the X axis in response to\n * limiting the minimum and maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar are\n * replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/heatmap-scrollbars/\n * Heatmap with both scrollbars\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @apioption xAxis.scrollbar\n */\n /**\n * Whether to show the axis line and title when the axis has no data.\n *\n * @sample {highcharts} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n * @sample {highstock} highcharts/yaxis/showempty/\n * When clicking the legend to hide series, one axis preserves\n * line and title, the other doesn't\n *\n * @since 1.1\n */\n showEmpty: true,\n /**\n * Whether to show the first tick label.\n *\n * @sample {highcharts} highcharts/xaxis/showfirstlabel-false/\n * Set to false on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n */\n showFirstLabel: true,\n /**\n * Whether to show the last tick label. Defaults to `true` on cartesian\n * charts, and `false` on polar charts.\n *\n * @sample {highcharts} highcharts/xaxis/showlastlabel-true/\n * Set to true on X axis\n * @sample {highstock} stock/xaxis/showfirstlabel/\n * Labels below plot lines on Y axis\n *\n * @type {boolean}\n * @default undefined\n * @product highcharts highstock gantt\n */\n showLastLabel: true,\n /**\n * A soft maximum for the axis. If the series data maximum is less than\n * this, the axis will stay at this maximum, but if the series data\n * maximum is higher, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption xAxis.softMin\n */\n /**\n * For datetime axes, this decides where to put the tick between weeks.\n * 0 = Sunday, 1 = Monday.\n *\n * @sample {highcharts} highcharts/xaxis/startofweek-monday/\n * Monday by default\n * @sample {highcharts} highcharts/xaxis/startofweek-sunday/\n * Sunday\n * @sample {highstock} stock/xaxis/startofweek-1\n * Monday by default\n * @sample {highstock} stock/xaxis/startofweek-0\n * Sunday\n *\n * @product highcharts highstock gantt\n */\n startOfWeek: 1,\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `minPadding` option to control the axis start.\n *\n * @productdesc {highstock}\n * In Highcharts Stock, `startOnTick` is always `false` when\n * the navigator is enabled, to prevent jumpy scrolling.\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n *\n * @since 1.2.0\n */\n startOnTick: false,\n /**\n * The amount of ticks to draw on the axis. This opens up for aligning\n * the ticks of multiple charts or panes within a chart. This option\n * overrides the `tickPixelInterval` option.\n *\n * This option only has an effect on linear axes. Datetime, logarithmic\n * or category axes are not affected.\n *\n * @sample {highcharts} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n * @sample {highstock} highcharts/yaxis/tickamount/\n * 8 ticks on Y axis\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @apioption xAxis.tickAmount\n */\n /**\n * The interval of the tick marks in axis units. When `undefined`, the\n * tick interval is computed to approximately follow the\n * [tickPixelInterval](#xAxis.tickPixelInterval) on linear and datetime\n * axes. On categorized axes, a `undefined` tickInterval will default to\n * 1, one category. Note that datetime axes are based on milliseconds,\n * so for example an interval of one day is expressed as\n * `24 * 3600 * 1000`.\n *\n * On logarithmic axes, the tickInterval is based on powers, so a\n * tickInterval of 1 means one tick on each of 0.1, 1, 10, 100 etc. A\n * tickInterval of 2 means a tick of 0.1, 10, 1000 etc. A tickInterval\n * of 0.2 puts a tick on 0.1, 0.2, 0.4, 0.6, 0.8, 1, 2, 4, 6, 8, 10, 20,\n * 40 etc.\n *\n *\n * If the tickInterval is too dense for labels to be drawn, Highcharts\n * may remove ticks.\n *\n * If the chart has multiple axes, the [alignTicks](#chart.alignTicks)\n * option may interfere with the `tickInterval` setting.\n *\n * @see [tickPixelInterval](#xAxis.tickPixelInterval)\n * @see [tickPositions](#xAxis.tickPositions)\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickinterval-5/\n * Tick interval of 5 on a linear axis\n * @sample {highstock} stock/xaxis/tickinterval/\n * Tick interval of 0.01 on Y axis\n *\n * @type {number}\n * @apioption xAxis.tickInterval\n */\n /**\n * The pixel length of the main tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/ticklength/\n * 20 px tick length on the X axis\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n */\n tickLength: 10,\n /**\n * If tickInterval is `null` this option sets the approximate pixel\n * interval of the tick marks. Not applicable to categorized axis.\n *\n * The tick interval is also influenced by the [minTickInterval](\n * #xAxis.minTickInterval) option, that, by default prevents ticks from\n * being denser than the data points.\n *\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpixelinterval-50/\n * 50 px on X axis\n * @sample {highstock} stock/xaxis/tickpixelinterval/\n * 200 px on X axis\n */\n tickPixelInterval: 100,\n /**\n * For categorized axes only. If `on` the tick mark is placed in the\n * center of the category, if `between` the tick mark is placed between\n * categories. The default is `between` if the `tickInterval` is 1, else\n * `on`.\n *\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-between/\n * \"between\" by default\n * @sample {highcharts} highcharts/xaxis/tickmarkplacement-on/\n * \"on\"\n *\n * @product highcharts gantt\n * @validvalue [\"on\", \"between\"]\n */\n tickmarkPlacement: 'between',\n /**\n * The position of the major tick marks relative to the axis line.\n * Can be one of `inside` and `outside`.\n *\n * @sample {highcharts} highcharts/xaxis/tickposition-outside/\n * \"outside\" by default\n * @sample {highcharts} highcharts/xaxis/tickposition-inside/\n * \"inside\"\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @validvalue [\"inside\", \"outside\"]\n */\n tickPosition: 'outside',\n /**\n * A callback function returning array defining where the ticks are\n * laid out on the axis. This overrides the default behaviour of\n * [tickPixelInterval](#xAxis.tickPixelInterval) and [tickInterval](\n * #xAxis.tickInterval). The automatic tick positions are accessible\n * through `this.tickPositions` and can be modified by the callback.\n *\n * @see [tickPositions](#xAxis.tickPositions)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Highcharts.AxisTickPositionerCallbackFunction}\n * @apioption xAxis.tickPositioner\n */\n /**\n * An array defining where the ticks are laid out on the axis. This\n * overrides the default behaviour of [tickPixelInterval](\n * #xAxis.tickPixelInterval) and [tickInterval](#xAxis.tickInterval).\n *\n * @see [tickPositioner](#xAxis.tickPositioner)\n *\n * @sample {highcharts} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n * @sample {highstock} highcharts/xaxis/tickpositions-tickpositioner/\n * Demo of tickPositions and tickPositioner\n *\n * @type {Array}\n * @apioption xAxis.tickPositions\n */\n /**\n * The pixel width of the major tick marks. Defaults to 0 on category\n * axes, otherwise 1.\n *\n * In styled mode, the stroke width is given in the `.highcharts-tick`\n * class, but in order for the element to be generated on category axes,\n * the option must be explicitly set to 1.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/\n * 10 px width\n * @sample {highcharts} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n * @sample {highstock} highcharts/css/axis-grid/\n * Styled mode\n *\n * @type {undefined|number}\n * @default {highstock} 1\n * @default {highmaps} 0\n * @apioption xAxis.tickWidth\n */\n /**\n * The axis title, showing next to the axis line.\n *\n * @productdesc {highmaps}\n * In Highmaps, the axis is hidden by default, but adding an axis title\n * is still possible. X axis and Y axis titles will appear at the bottom\n * and left by default.\n */\n title: {\n /**\n * Alignment of the title relative to the axis values. Possible\n * values are \"low\", \"middle\" or \"high\".\n *\n * @sample {highcharts} highcharts/xaxis/title-align-low/\n * \"low\"\n * @sample {highcharts} highcharts/xaxis/title-align-center/\n * \"middle\" by default\n * @sample {highcharts} highcharts/xaxis/title-align-high/\n * \"high\"\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the Y axis title on top of the axis\n * @sample {highstock} stock/xaxis/title-align/\n * Aligned to \"high\" value\n *\n * @type {Highcharts.AxisTitleAlignValue}\n */\n align: 'middle',\n /**\n * Deprecated. Set the `text` to `undefined` to disable the title.\n *\n * @deprecated\n * @type {boolean}\n * @product highcharts\n * @apioption xAxis.title.enabled\n */\n /**\n * The pixel distance between the axis labels or line and the title.\n * Defaults to 0 for horizontal axes, 10 for vertical\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @apioption xAxis.title.margin\n */\n /**\n * The distance of the axis title from the axis line. By default,\n * this distance is computed from the offset width of the labels,\n * the labels' distance from the axis and the title's margin.\n * However when the offset option is set, it overrides all this.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Place the axis title on top of the axis\n * @sample {highstock} highcharts/yaxis/title-offset/\n * Place the axis title on top of the Y axis\n *\n * @type {number}\n * @since 2.2.0\n * @apioption xAxis.title.offset\n */\n /**\n * Whether to reserve space for the title when laying out the axis.\n *\n * @type {boolean}\n * @default true\n * @since 5.0.11\n * @product highcharts highstock gantt\n * @apioption xAxis.title.reserveSpace\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 0,\n /**\n * The actual text of the axis title. It can contain basic HTML tags\n * like `b`, `i` and `span` with style.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n * @sample {highstock} stock/xaxis/title-text/\n * Titles for both axes\n *\n * @type {string|null}\n * @apioption xAxis.title.text\n */\n /**\n * Alignment of the text, can be `\"left\"`, `\"right\"` or `\"center\"`.\n * Default alignment depends on the\n * [title.align](xAxis.title.align):\n *\n * Horizontal axes:\n * - for `align` = `\"low\"`, `textAlign` is set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"`, `textAlign` is set to `right`\n *\n * Vertical axes:\n * - for `align` = `\"low\"` and `opposite` = `true`, `textAlign` is\n * set to `right`\n * - for `align` = `\"low\"` and `opposite` = `false`, `textAlign` is\n * set to `left`\n * - for `align` = `\"middle\"`, `textAlign` is set to `center`\n * - for `align` = `\"high\"` and `opposite` = `true` `textAlign` is\n * set to `left`\n * - for `align` = `\"high\"` and `opposite` = `false` `textAlign` is\n * set to `right`\n *\n * @type {Highcharts.AlignValue}\n * @apioption xAxis.title.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the axis title.\n *\n * @product highcharts highstock gantt\n */\n useHTML: false,\n /**\n * Horizontal pixel offset of the title position.\n *\n * @since 4.1.6\n * @product highcharts highstock gantt\n */\n x: 0,\n /**\n * Vertical pixel offset of the title position.\n *\n * @product highcharts highstock gantt\n */\n y: 0,\n /**\n * CSS styles for the title. If the title text is longer than the\n * axis length, it will wrap to multiple lines by default. This can\n * be customized by setting `textOverflow: 'ellipsis'`, by\n * setting a specific `width` or by setting `whiteSpace: 'nowrap'`.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-title` class.\n *\n * @sample {highcharts} highcharts/xaxis/title-style/\n * Red\n * @sample {highcharts} highcharts/css/axis/\n * Styled mode\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @internal */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /** @internal */\n fontSize: '0.8em'\n }\n },\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`\n * or `category`. In a datetime axis, the numbers are given in\n * milliseconds, and tick marks are placed on appropriate values like\n * full hours or days. In a category axis, the\n * [point names](#series.line.data.name) of the chart's series are used\n * for categories, if not a [categories](#xAxis.categories) array is\n * defined.\n *\n * @sample {highcharts} highcharts/xaxis/type-linear/\n * Linear\n * @sample {highcharts} highcharts/yaxis/type-log/\n * Logarithmic\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/xaxis/type-log-both/\n * Logarithmic on two axes\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n *\n * @type {Highcharts.AxisTypeValue}\n * @product highcharts gantt\n */\n type: 'linear',\n /**\n * If there are multiple axes on the same side of the chart, the pixel\n * margin between the axes. Defaults to 0 on vertical axes, 15 on\n * horizontal axes.\n *\n * @type {number}\n * @since 7.0.3\n * @apioption xAxis.margin\n */\n /**\n * Applies only when the axis `type` is `category`. When `uniqueNames`\n * is true, points are placed on the X axis according to their names.\n * If the same point name is repeated in the same or another series,\n * the point is placed on the same X position as other points of the\n * same name. When `uniqueNames` is false, the points are laid out in\n * increasing X positions regardless of their names, and the X axis\n * category will take the name of the last point in each position.\n *\n * @sample {highcharts} highcharts/xaxis/uniquenames-true/\n * True by default\n * @sample {highcharts} highcharts/xaxis/uniquenames-false/\n * False\n *\n * @since 4.2.7\n * @product highcharts gantt\n */\n uniqueNames: true,\n /**\n * Datetime axis only. An array determining what time intervals the\n * ticks are allowed to fall on. Each array item is an array where the\n * first value is the time unit and the second value another array of\n * allowed multiples.\n *\n * Defaults to:\n * ```js\n * units: [[\n * 'millisecond', // unit name\n * [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n * ], [\n * 'second',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'minute',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'hour',\n * [1, 2, 3, 4, 6, 8, 12]\n * ], [\n * 'day',\n * [1, 2]\n * ], [\n * 'week',\n * [1, 2]\n * ], [\n * 'month',\n * [1, 2, 3, 4, 6]\n * ], [\n * 'year',\n * null\n * ]]\n * ```\n *\n * @sample {highcharts} highcharts/xaxis/units/\n * Axis units demonstrated\n *\n * @type {Array|null)>>}\n * @product highcharts highstock gantt\n * @apioption xAxis.units\n */\n /**\n * Whether axis, including axis title, line, ticks and labels, should\n * be visible.\n *\n * @since 4.1.9\n * @product highcharts highstock gantt\n */\n visible: true,\n /**\n * Color of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-minor-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinecolor/\n * Bright grey lines from Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #f2f2f2\n */\n minorGridLineColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * Width of the minor, secondary grid lines.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/minorgridlinewidth/\n * 2px lines from Y axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/minorgridlinewidth/\n * 2px lines from Y axis\n */\n minorGridLineWidth: 1,\n /**\n * Color for the minor tick marks.\n *\n * @sample {highcharts} highcharts/yaxis/minortickcolor/\n * Black tick marks on Y axis\n * @sample {highstock} stock/xaxis/minorticks/\n * Black tick marks on Y axis\n *\n * @type {Highcharts.ColorType}\n * @default #999999\n */\n minorTickColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The color of the line marking the axis itself.\n *\n * In styled mode, the line stroke is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A red line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linecolor/\n * A red line on X axis\n *\n * @type {Highcharts.ColorType}\n */\n lineColor: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * The width of the line marking the axis itself.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-axis-line` or `.highcharts-xaxis-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/linecolor/\n * A 1px line on Y axis\n * @sample {highcharts|highstock} highcharts/css/axis/\n * Axes in styled mode\n * @sample {highstock} stock/xaxis/linewidth/\n * A 2px line on X axis\n *\n * @default {highcharts|highstock} 1\n * @default {highmaps} 0\n */\n lineWidth: 1,\n /**\n * Color of the grid lines extending the ticks across the plot area.\n *\n * In styled mode, the stroke is given in the `.highcharts-grid-line`\n * class.\n *\n * @productdesc {highmaps}\n * In Highmaps, the grid lines are hidden by default.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinecolor/\n * Green lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinecolor/\n * Green lines\n *\n * @type {Highcharts.ColorType}\n * @default #e6e6e6\n */\n gridLineColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n /**\n * The width of the grid lines extending the ticks across the plot area.\n * Defaults to 1 on the Y axis and 0 on the X axis, except for 3d\n * charts.\n *\n * In styled mode, the stroke width is given in the\n * `.highcharts-grid-line` class.\n *\n * @sample {highcharts} highcharts/yaxis/gridlinewidth/\n * 2px lines\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/gridlinewidth/\n * 2px lines\n *\n * @type {number}\n * @apioption xAxis.gridLineWidth\n */\n gridLineWidth: void 0,\n /**\n * The height as the vertical axis. If it's a number, it is\n * interpreted as pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted\n * as percentages of the total plot height.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.height\n */\n /**\n * The width as the horizontal axis. If it's a number, it is interpreted\n * as pixels.\n *\n * Since Highcharts v5.0.13: If it's a percentage string, it is\n * interpreted as percentages of the total plot width.\n *\n * @sample {highcharts} highcharts/xaxis/axis-position-properties\n * Different axis position properties\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption xAxis.width\n */\n /**\n * Color for the main tick marks.\n *\n * In styled mode, the stroke is given in the `.highcharts-tick`\n * class.\n *\n * @sample {highcharts} highcharts/xaxis/tickcolor/\n * Red ticks on X axis\n * @sample {highcharts|highstock} highcharts/css/axis-grid/\n * Styled mode\n * @sample {highstock} stock/xaxis/ticks/\n * Formatted ticks on X axis\n *\n * @type {Highcharts.ColorType}\n */\n tickColor: \"#333333\" /* Palette.neutralColor80 */\n // tickWidth: 1\n };\n /**\n * The Y axis or value axis. Normally this is the vertical axis,\n * though if the chart is inverted this is the horizontal axis.\n * In case of multiple axes, the yAxis node is an array of\n * configuration objects.\n *\n * See [the Axis object](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @excluding currentDateIndicator,ordinal,overscroll\n * @optionparent yAxis\n */\n AxisDefaults.defaultYAxisOptions = {\n /**\n * The type of axis. Can be one of `linear`, `logarithmic`, `datetime`,\n * `category` or `treegrid`. Defaults to `treegrid` for Gantt charts,\n * `linear` for other chart types.\n *\n * In a datetime axis, the numbers are given in milliseconds, and tick\n * marks are placed on appropriate values, like full hours or days. In a\n * category or treegrid axis, the [point names](#series.line.data.name)\n * of the chart's series are used for categories, if a\n * [categories](#xAxis.categories) array is not defined.\n *\n * @sample {highcharts} highcharts/yaxis/type-log-minorgrid/\n * Logarithmic with minor grid lines\n * @sample {highcharts} highcharts/yaxis/type-log-negative/\n * Logarithmic with extension to emulate negative values\n * @sample {gantt} gantt/treegrid-axis/demo\n * Treegrid axis\n *\n * @type {Highcharts.AxisTypeValue}\n * @default {highcharts} linear\n * @default {gantt} treegrid\n * @product highcharts gantt\n * @apioption yAxis.type\n */\n /**\n * The height of the Y axis. If it's a number, it is interpreted as\n * pixels.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the total plot height.\n *\n * @see [yAxis.top](#yAxis.top)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.height\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the maximum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max colors\n *\n * @type {Highcharts.ColorType}\n * @default #003399\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.maxColor\n */\n /**\n * Solid gauge only. Unless [stops](#yAxis.stops) are set, the color\n * to represent the minimum value of the Y axis.\n *\n * @sample {highcharts} highcharts/yaxis/mincolor-maxcolor/\n * Min and max color\n *\n * @type {Highcharts.ColorType}\n * @default #e6ebf5\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.minColor\n */\n /**\n * Whether to reverse the axis so that the highest number is closest\n * to the origin.\n *\n * @sample {highcharts} highcharts/yaxis/reversed/\n * Reversed Y axis\n * @sample {highstock} stock/xaxis/reversed/\n * Reversed Y axis\n *\n * @type {boolean}\n * @default {highcharts} false\n * @default {highstock} false\n * @default {highmaps} true\n * @default {gantt} true\n * @apioption yAxis.reversed\n */\n /**\n * If `true`, the first series in a stack will be drawn on top in a\n * positive, non-reversed Y axis. If `false`, the first series is in\n * the base of the stack.\n *\n * @sample {highcharts} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n * @sample {highstock} highcharts/yaxis/reversedstacks-false/\n * Non-reversed stacks\n *\n * @type {boolean}\n * @default true\n * @since 3.0.10\n * @product highcharts highstock\n * @apioption yAxis.reversedStacks\n */\n reversedStacks: true,\n /**\n * Solid gauge series only. Color stops for the solid gauge. Use this\n * in cases where a linear gradient between a `minColor` and `maxColor`\n * is not sufficient. The stops is an array of tuples, where the first\n * item is a float between 0 and 1 assigning the relative position in\n * the gradient, and the second item is the color.\n *\n * For solid gauges, the Y axis also inherits the concept of\n * [data classes](https://api.highcharts.com/highmaps#colorAxis.dataClasses)\n * from the Highmaps color axis.\n *\n * @sample {highcharts} highcharts/demo/gauge-solid/\n * Gauge with stops\n *\n * @see [minColor](#yAxis.minColor)\n * @see [maxColor](#yAxis.maxColor)\n *\n * @type {Array>}\n * @since 4.0\n * @product highcharts\n * @apioption yAxis.stops\n */\n /**\n * The pixel width of the major tick marks.\n *\n * @sample {highcharts} highcharts/xaxis/tickwidth/ 10 px width\n * @sample {highstock} stock/xaxis/ticks/ Formatted ticks on X axis\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption yAxis.tickWidth\n */\n /**\n * Whether to force the axis to end on a tick. Use this option with\n * the `maxPadding` option to control the axis end.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n *\n * @sample {highcharts} highcharts/yaxis/endontick/\n * True by default\n * @sample {highcharts} highcharts/yaxis/endontick-false/\n * False\n * @sample {highstock} stock/demo/basic-line/\n * True by default\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n */\n endOnTick: true,\n /**\n * Padding of the max value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the highest data value to appear on the edge\n * of the plot area. When the axis' `max` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `maxPadding`,\n * so if the data is tangent to the threshold, `maxPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/maxpadding-02/\n * Max padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n maxPadding: 0.05,\n /**\n * Padding of the min value relative to the length of the axis. A\n * padding of 0.05 will make a 100px axis 5px longer. This is useful\n * when you don't want the lowest data value to appear on the edge\n * of the plot area. When the axis' `min` option is set or a max extreme\n * is set using `axis.setExtremes()`, the maxPadding will be ignored.\n *\n * Also the `softThreshold` option takes precedence over `minPadding`,\n * so if the data is tangent to the threshold, `minPadding` may not\n * apply unless `softThreshold` is set to false.\n *\n * @sample {highcharts} highcharts/yaxis/minpadding/\n * Min padding of 0.2\n * @sample {highstock} stock/xaxis/minpadding-maxpadding/\n * Greater min- and maxPadding\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n minPadding: 0.05,\n /**\n * @productdesc {highstock}\n * In Highcharts Stock 1.x, the Y axis was placed\n * on the left side by default.\n *\n * @sample {highcharts} highcharts/yaxis/opposite/\n * Secondary Y axis opposite\n * @sample {highstock} stock/xaxis/opposite/\n * Y axis on left side\n *\n * @type {boolean}\n * @default {highstock} true\n * @default {highcharts} false\n * @product highstock highcharts gantt\n * @apioption yAxis.opposite\n */\n /**\n * @see [tickInterval](#xAxis.tickInterval)\n * @see [tickPositioner](#xAxis.tickPositioner)\n * @see [tickPositions](#xAxis.tickPositions)\n */\n tickPixelInterval: 72,\n /**\n * Whether to show the last tick label.\n *\n * @productdesc {highcharts|gantt}\n * Defaults to `true` on cartesian charts, and `false` on polar charts.\n *\n * @productdesc {highstock}\n * Defaults to `true` for categorized yAxis and `false` for other types\n * of yAxis.\n *\n * @default undefined\n */\n showLastLabel: true,\n /**\n * @extends xAxis.labels\n */\n labels: {\n /**\n * The label's pixel distance from the perimeter of the plot area.\n * On cartesian charts, this is overridden if the `labels.y` setting\n * is set.\n *\n * On polar charts, if it's a percentage string, it is interpreted\n * the same as [series.radius](#plotOptions.gauge.radius), so the\n * label can be aligned under the gauge's shape.\n *\n * @sample {highcharts} highcharts/yaxis/labels-distance/\n * Polar chart, labels centered under the arc\n *\n * @type {number|string}\n * @product highcharts\n * @apioption yAxis.labels.distance\n */\n /**\n * The y position offset of all labels relative to the tick\n * positions on the axis. For polar and radial axis consider the use\n * of the [distance](#yAxis.labels.distance) option.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n * @default {highcharts} 3\n * @default {highstock} -2\n * @default {highmaps} 3\n * @apioption yAxis.labels.y\n */\n /**\n * What part of the string the given position is anchored to. Can\n * be one of `\"left\"`, `\"center\"` or `\"right\"`. The exact position\n * also depends on the `labels.x` setting.\n *\n * Angular gauges and solid gauges defaults to `\"center\"`.\n * Solid gauges with two labels have additional option `\"auto\"`\n * for automatic horizontal and vertical alignment.\n *\n * @sample {highcharts} highcharts/yaxis/labels-align-left/\n * Left\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge labels auto aligned\n *\n * @type {Highcharts.AlignValue}\n * @default {highstock} right\n * @apioption yAxis.labels.align\n */\n /**\n * The x position offset of all labels relative to the tick\n * positions on the axis. Defaults to -15 for left axis, 15 for\n * right axis.\n *\n * @sample {highcharts} highcharts/xaxis/labels-x/\n * Y axis labels placed on grid lines\n *\n * @type {number}\n */\n x: void 0\n },\n /**\n * @sample {highcharts} highcharts/yaxis/max-200/\n * Y axis max of 200\n * @sample {highcharts} highcharts/yaxis/max-logarithmic/\n * Y axis max on logarithmic axis\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.max\n */\n /**\n * @sample {highcharts} highcharts/yaxis/min-startontick-false/\n * -50 with startOnTick to false\n * @sample {highcharts} highcharts/yaxis/min-startontick-true/\n * -50 with startOnTick true by default\n * @sample {highstock} stock/yaxis/min-max/\n * Fixed min and max on Y axis\n *\n * @apioption yAxis.min\n */\n /**\n * An optional scrollbar to display on the Y axis in response to\n * limiting the minimum an maximum of the axis values.\n *\n * In styled mode, all the presentational options for the scrollbar\n * are replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Scrollbar on the Y axis\n *\n * @extends scrollbar\n * @since 4.2.6\n * @product highstock\n * @excluding height\n * @apioption yAxis.scrollbar\n */\n /**\n * Enable the scrollbar on the Y axis.\n *\n * @sample {highstock} stock/yaxis/scrollbar/\n * Enabled on Y axis\n *\n * @type {boolean}\n * @default false\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.enabled\n */\n /**\n * Pixel margin between the scrollbar and the axis elements.\n *\n * @type {number}\n * @default 10\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.margin\n */\n /* eslint-disable highcharts/doclet-apioption-last */\n /**\n * Defines the position of the scrollbar. By default, it is positioned\n * on the opposite of the main axis (right side of the chart).\n * However, in the case of RTL languages could be set to `false`\n * which positions the scrollbar on the left.\n *\n * Works only for vertical axes.\n * This means yAxis in a non-inverted chart and xAxis in the inverted.\n *\n * @sample stock/yaxis/scrollbar-opposite/\n * A scrollbar not on the opposite side\n *\n * @type {boolean}\n * @default true\n * @since 9.3.0\n *\n * @apioption yAxis.scrollbar.opposite\n * @apioption xAxis.scrollbar.opposite\n *\n */\n /* eslint-enable highcharts/doclet-apioption-last */\n /**\n * Whether to show the scrollbar when it is fully zoomed out at max\n * range. Setting it to `false` on the Y axis makes the scrollbar stay\n * hidden until the user zooms in, like common in browsers.\n *\n * @type {boolean}\n * @default true\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.showFull\n */\n /**\n * The width of a vertical scrollbar or height of a horizontal\n * scrollbar. Defaults to 20 on touch devices.\n *\n * @type {number}\n * @default 14\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.size\n */\n /**\n * Z index of the scrollbar elements.\n *\n * @type {number}\n * @default 3\n * @since 4.2.6\n * @product highstock\n * @apioption yAxis.scrollbar.zIndex\n */\n /**\n * A soft maximum for the axis. If the series data maximum is less\n * than this, the axis will stay at this maximum, but if the series\n * data maximum is higher, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMax\n */\n /**\n * A soft minimum for the axis. If the series data minimum is greater\n * than this, the axis will stay at this minimum, but if the series\n * data minimum is lower, the axis will flex to show all data.\n *\n * **Note**: The [series.softThreshold](\n * #plotOptions.series.softThreshold) option takes precedence over this\n * option.\n *\n * @sample highcharts/yaxis/softmin-softmax/\n * Soft min and max\n *\n * @type {number}\n * @since 5.0.1\n * @product highcharts highstock gantt\n * @apioption yAxis.softMin\n */\n /**\n * Defines the horizontal alignment of the stack total label. Can be one\n * of `\"left\"`, `\"center\"` or `\"right\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-left/\n * Aligned to the left\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-center/\n * Aligned in center\n * @sample {highcharts} highcharts/yaxis/stacklabels-align-right/\n * Aligned to the right\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.align\n */\n /**\n * A format string for the data label. Available variables are the same\n * as for `formatter`.\n *\n * @type {string}\n * @default {total}\n * @since 3.0.2\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.format\n */\n /**\n * Rotation of the labels in degrees.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-rotation/\n * Labels rotated 45°\n *\n * @type {number}\n * @default 0\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.rotation\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed with regards to the stack, `textAlign`\n * determines how the text is aligned against its anchor point. Possible\n * values are `\"left\"`, `\"center\"` and `\"right\"`. The default value is\n * calculated at runtime and depends on orientation and whether the\n * stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-textalign-left/\n * Label in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0\n * @product highcharts highstock\n * @apioption yAxis.stackLabels.useHTML\n */\n /**\n * Defines the vertical alignment of the stack total label. Can be one\n * of `\"top\"`, `\"middle\"` or `\"bottom\"`. The default value is calculated\n * at runtime and depends on orientation and whether the stack is\n * positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-top/\n * Vertically aligned top\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-middle/\n * Vertically aligned middle\n * @sample {highcharts} highcharts/yaxis/stacklabels-verticalalign-bottom/\n * Vertically aligned bottom\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.verticalAlign\n */\n /**\n * The x position offset of the label relative to the left of the\n * stacked bar. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-x/\n * Stack total labels with x offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.x\n */\n /**\n * The y position offset of the label relative to the tick position\n * on the axis. The default value is calculated at runtime and depends\n * on orientation and whether the stack is positive or negative.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-y/\n * Stack total labels with y offset\n *\n * @type {number}\n * @since 2.1.5\n * @product highcharts\n * @apioption yAxis.stackLabels.y\n */\n /**\n * Whether to force the axis to start on a tick. Use this option with\n * the `maxPadding` option to control the axis start.\n *\n * This option is always disabled, when panning type is\n * either `y` or `xy`.\n *\n * @see [type](#chart.panning.type)\n *\n * @sample {highcharts} highcharts/xaxis/startontick-false/\n * False by default\n * @sample {highcharts} highcharts/xaxis/startontick-true/\n * True\n * @sample {highstock} stock/xaxis/endontick/\n * False for Y axis\n *\n * @since 1.2.0\n * @product highcharts highstock gantt\n */\n startOnTick: true,\n title: {\n /**\n * The pixel distance between the axis labels and the title.\n * Positive values are outside the axis line, negative are inside.\n *\n * @sample {highcharts} highcharts/xaxis/title-margin/\n * Y axis title margin of 60\n *\n * @type {number}\n * @default 40\n * @apioption yAxis.title.margin\n */\n /**\n * The rotation of the text in degrees. 0 is horizontal, 270 is\n * vertical reading from bottom to top.\n *\n * @sample {highcharts} highcharts/yaxis/title-offset/\n * Horizontal\n */\n rotation: 270,\n /**\n * The actual text of the axis title. Horizontal texts can contain\n * HTML, but rotated texts are painted using vector techniques and\n * must be clean text. The Y axis title is disabled by setting the\n * `text` option to `undefined`.\n *\n * @sample {highcharts} highcharts/xaxis/title-text/\n * Custom HTML\n *\n * @type {string|null}\n * @default {highcharts} Values\n * @default {highstock} undefined\n * @product highcharts highstock gantt\n */\n text: 'Values'\n },\n /**\n * The top position of the Y axis. If it's a number, it is interpreted\n * as pixel position relative to the chart.\n *\n * Since Highcharts 2: If it's a percentage string, it is interpreted as\n * percentages of the plot height, offset from plot area top.\n *\n * @see [yAxis.height](#yAxis.height)\n *\n * @sample {highstock} stock/demo/candlestick-and-volume/\n * Percentage height panes\n *\n * @type {number|string}\n * @product highcharts highstock\n * @apioption yAxis.top\n */\n /**\n * The stack labels show the total value for each bar in a stacked\n * column or bar chart. The label will be placed on top of positive\n * columns and below negative columns. In case of an inverted column\n * chart or a bar chart the label is placed to the right of positive\n * bars and to the left of negative bars.\n *\n * @product highcharts\n */\n stackLabels: {\n /**\n * Enable or disable the initial animation when a series is\n * displayed for the `stackLabels`. The animation can also be set as\n * a configuration object. Please note that this option only\n * applies to the initial animation.\n * For other animations, see [chart.animation](#chart.animation)\n * and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds.\n * Set to `0` renders stackLabel immediately.\n * As `undefined` inherits defer time from the [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption yAxis.stackLabels.animation.defer\n */\n /**\n * Allow the stack labels to overlap.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-allowoverlap-false/\n * Default false\n *\n * @since 5.0.13\n * @product highcharts\n */\n allowOverlap: false,\n /**\n * The background color or gradient for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.backgroundColor\n */\n /**\n * The border color for the stack label. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {Highcharts.ColorType}\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderColor\n */\n /**\n * The border radius in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderRadius\n */\n /**\n * The border width in pixels for the stack label.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-box/\n * Stack labels box options\n * @type {number}\n * @default 0\n * @since 8.1.0\n * @apioption yAxis.stackLabels.borderWidth\n */\n /**\n * Enable or disable the stack total labels.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled/\n * Enabled stack total labels\n * @sample {highcharts} highcharts/yaxis/stacklabels-enabled-waterfall/\n * Enabled stack labels in waterfall chart\n *\n * @since 2.1.5\n * @product highcharts\n */\n enabled: false,\n /**\n * Whether to hide stack labels that are outside the plot area.\n * By default, the stack label is moved\n * inside the plot area according to the\n * [overflow](/highcharts/#yAxis/stackLabels/overflow)\n * option.\n *\n * @type {boolean}\n * @since 7.1.3\n */\n crop: true,\n /**\n * How to handle stack total labels that flow outside the plot area.\n * The default is set to `\"justify\"`,\n * which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display stack labels outside the plot area,\n * set `crop` to `false` and `overflow` to `\"allow\"`.\n *\n * @sample highcharts/yaxis/stacklabels-overflow/\n * Stack labels flows outside the plot area.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @since 7.1.3\n */\n overflow: 'justify',\n /* eslint-disable valid-jsdoc */\n /**\n * Callback JavaScript function to format the label. The value is\n * given by `this.total`.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-formatter/\n * Added units to stack total value\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @since 2.1.5\n * @product highcharts\n */\n formatter: function () {\n const { numberFormatter } = this.axis.chart;\n /* eslint-enable valid-jsdoc */\n return numberFormatter(this.total || 0, -1);\n },\n /**\n * CSS styles for the label.\n *\n * In styled mode, the styles are set in the\n * `.highcharts-stack-label` class.\n *\n * @sample {highcharts} highcharts/yaxis/stacklabels-style/\n * Red stack total labels\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1.5\n * @product highcharts\n */\n style: {\n /** @internal */\n color: \"#000000\" /* Palette.neutralColor100 */,\n /** @internal */\n fontSize: '0.7em',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n textOutline: '1px contrast'\n }\n },\n gridLineWidth: 1,\n lineWidth: 0\n // tickWidth: 0\n };\n /**\n * The Z axis or depth axis for 3D plots.\n *\n * See the [Axis class](/class-reference/Highcharts.Axis) for programmatic\n * access to the axis.\n *\n * @sample {highcharts} highcharts/3d/scatter-zaxis-categories/\n * Z-Axis with Categories\n * @sample {highcharts} highcharts/3d/scatter-zaxis-grid/\n * Z-Axis with styling\n *\n * @type {*|Array<*>}\n * @extends xAxis\n * @since 5.0.0\n * @product highcharts\n * @excluding breaks, crosshair, height, left, lineColor, lineWidth,\n * nameToX, showEmpty, top, width\n * @apioption zAxis\n */\n // This variable extends the defaultOptions for left axes.\n AxisDefaults.defaultLeftAxisOptions = {\n title: {\n rotation: 270\n }\n };\n // This variable extends the defaultOptions for right axes.\n AxisDefaults.defaultRightAxisOptions = {\n title: {\n rotation: 90\n }\n };\n // This variable extends the defaultOptions for bottom axes.\n AxisDefaults.defaultBottomAxisOptions = {\n labels: {\n autoRotation: [-45]\n // overflow: undefined,\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n // This variable extends the defaultOptions for top axes.\n AxisDefaults.defaultTopAxisOptions = {\n labels: {\n autoRotation: [-45]\n // overflow: undefined\n // staggerLines: null\n },\n margin: 15,\n title: {\n rotation: 0\n }\n };\n })(AxisDefaults || (AxisDefaults = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return AxisDefaults;\n });\n _registerModule(_modules, 'Core/Foundation.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, isFunction, objectEach, removeEvent } = U;\n /* *\n *\n * Class Namespace\n *\n * */\n var Foundation;\n (function (Foundation) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Register event options. If an event handler is set on the options, it\n * should be subject to Chart.update, Axis.update and Series.update. This is\n * contrary to general handlers that are set directly using addEvent either\n * on the class or on the instance. #6538, #6943, #10861.\n * @private\n */\n function registerEventOptions(component, options) {\n // A lookup over those events that are added by _options_ (not\n // programmatically). These are updated through .update()\n component.eventOptions = component.eventOptions || {};\n // Register event listeners\n objectEach(options.events, function (event, eventType) {\n // If event does not exist, or is changed by the .update()\n // function\n if (component.eventOptions[eventType] !== event) {\n // Remove existing if set by option\n if (component.eventOptions[eventType]) {\n removeEvent(component, eventType, component.eventOptions[eventType]);\n delete component.eventOptions[eventType];\n }\n if (isFunction(event)) {\n component.eventOptions[eventType] = event;\n addEvent(component, eventType, event, {\n order: 0 // #14080 fire those events as firsts\n });\n }\n }\n });\n }\n Foundation.registerEventOptions = registerEventOptions;\n })(Foundation || (Foundation = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return Foundation;\n });\n _registerModule(_modules, 'Core/Axis/Tick.js', [_modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (F, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { deg2rad } = H;\n const { clamp, correctFloat, defined, destroyObjectProperties, extend, fireEvent, isNumber, merge, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Tick class.\n *\n * @class\n * @name Highcharts.Tick\n *\n * @param {Highcharts.Axis} axis\n * The axis of the tick.\n *\n * @param {number} pos\n * The position of the tick on the axis in terms of axis values.\n *\n * @param {string} [type]\n * The type of tick, either 'minor' or an empty string\n *\n * @param {boolean} [noLabel=false]\n * Whether to disable the label or not. Defaults to false.\n *\n * @param {Object} [parameters]\n * Optional parameters for the tick.\n */\n class Tick {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis, pos, type, noLabel, parameters) {\n this.isNew = true;\n this.isNewLabel = true;\n /**\n * The related axis of the tick.\n * @name Highcharts.Tick#axis\n * @type {Highcharts.Axis}\n */\n this.axis = axis;\n /**\n * The logical position of the tick on the axis in terms of axis values.\n * @name Highcharts.Tick#pos\n * @type {number}\n */\n this.pos = pos;\n /**\n * The tick type, which can be `\"minor\"`, or an empty string.\n * @name Highcharts.Tick#type\n * @type {string}\n */\n this.type = type || '';\n this.parameters = parameters || {};\n /**\n * The mark offset of the tick on the axis. Usually `undefined`, numeric\n * for grid axes.\n * @name Highcharts.Tick#tickmarkOffset\n * @type {number|undefined}\n */\n this.tickmarkOffset = this.parameters.tickmarkOffset;\n this.options = this.parameters.options;\n fireEvent(this, 'init');\n if (!type && !noLabel) {\n this.addLabel();\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Write the tick label.\n *\n * @private\n * @function Highcharts.Tick#addLabel\n */\n addLabel() {\n const tick = this, axis = tick.axis, options = axis.options, chart = axis.chart, categories = axis.categories, log = axis.logarithmic, names = axis.names, pos = tick.pos, labelOptions = pick(tick.options && tick.options.labels, options.labels), tickPositions = axis.tickPositions, isFirst = pos === tickPositions[0], isLast = pos === tickPositions[tickPositions.length - 1], animateLabels = (!labelOptions.step || labelOptions.step === 1) &&\n axis.tickInterval === 1, tickPositionInfo = tickPositions.info;\n let label = tick.label, dateTimeLabelFormat, dateTimeLabelFormats, i;\n // The context value\n let value = this.parameters.category || (categories ?\n pick(categories[pos], names[pos], pos) :\n pos);\n if (log && isNumber(value)) {\n value = correctFloat(log.lin2log(value));\n }\n // Set the datetime label format. If a higher rank is set for this\n // position, use that. If not, use the general format.\n if (axis.dateTime) {\n if (tickPositionInfo) {\n dateTimeLabelFormats = chart.time.resolveDTLFormat(options.dateTimeLabelFormats[(!options.grid &&\n tickPositionInfo.higherRanks[pos]) ||\n tickPositionInfo.unitName]);\n dateTimeLabelFormat = dateTimeLabelFormats.main;\n }\n else if (isNumber(value)) { // #1441\n dateTimeLabelFormat = axis.dateTime.getXDateFormat(value, options.dateTimeLabelFormats ||\n {});\n }\n }\n // set properties for access in render method\n /**\n * True if the tick is the first one on the axis.\n * @name Highcharts.Tick#isFirst\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isFirst = isFirst;\n /**\n * True if the tick is the last one on the axis.\n * @name Highcharts.Tick#isLast\n * @readonly\n * @type {boolean|undefined}\n */\n tick.isLast = isLast;\n // Get the string\n const ctx = {\n axis,\n chart,\n dateTimeLabelFormat: dateTimeLabelFormat,\n isFirst,\n isLast,\n pos,\n tick: tick,\n tickPositionInfo,\n value\n };\n // Fire an event that allows modifying the context for use in\n // `labels.format` and `labels.formatter`.\n fireEvent(this, 'labelFormat', ctx);\n // Label formatting. When `labels.format` is given, we first run the\n // defaultFormatter and append the result to the context as `text`.\n // Handy for adding prefix or suffix while keeping default number\n // formatting.\n const labelFormatter = (ctx) => {\n if (labelOptions.formatter) {\n return labelOptions.formatter.call(ctx, ctx);\n }\n if (labelOptions.format) {\n ctx.text = axis.defaultLabelFormatter.call(ctx, ctx);\n return F.format(labelOptions.format, ctx, chart);\n }\n return axis.defaultLabelFormatter.call(ctx, ctx);\n };\n const str = labelFormatter.call(ctx, ctx);\n // Set up conditional formatting based on the format list if existing.\n const list = dateTimeLabelFormats && dateTimeLabelFormats.list;\n if (list) {\n tick.shortenLabel = function () {\n for (i = 0; i < list.length; i++) {\n extend(ctx, { dateTimeLabelFormat: list[i] });\n label.attr({\n text: labelFormatter.call(ctx, ctx)\n });\n if (label.getBBox().width <\n axis.getSlotWidth(tick) - 2 *\n labelOptions.padding) {\n return;\n }\n }\n label.attr({\n text: ''\n });\n };\n }\n else {\n // #15692\n tick.shortenLabel = void 0;\n }\n // Call only after first render\n if (animateLabels && axis._addedPlotLB) {\n tick.moveLabel(str, labelOptions);\n }\n // First call\n if (!defined(label) && !tick.movedLabel) {\n /**\n * The rendered text label of the tick.\n * @name Highcharts.Tick#label\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.label = label = tick.createLabel({ x: 0, y: 0 }, str, labelOptions);\n // Base value to detect change for new calls to getBBox\n tick.rotation = 0;\n // update\n }\n else if (label && label.textStr !== str && !animateLabels) {\n // When resetting text, also reset the width if dynamically set\n // (#8809)\n if (label.textWidth &&\n !labelOptions.style.width &&\n !label.styles.width) {\n label.css({ width: null });\n }\n label.attr({ text: str });\n label.textPxLength = label.getBBox().width;\n }\n }\n /**\n * Render and return the label of the tick.\n *\n * @private\n * @function Highcharts.Tick#createLabel\n */\n createLabel(xy, str, labelOptions) {\n const axis = this.axis, chart = axis.chart, label = defined(str) && labelOptions.enabled ?\n chart.renderer\n .text(str, xy.x, xy.y, labelOptions.useHTML)\n .add(axis.labelGroup) :\n null;\n // Un-rotated length\n if (label) {\n // Without position absolute, IE export sometimes is wrong\n if (!chart.styledMode) {\n label.css(merge(labelOptions.style));\n }\n label.textPxLength = label.getBBox().width;\n }\n return label;\n }\n /**\n * Destructor for the tick prototype\n *\n * @private\n * @function Highcharts.Tick#destroy\n */\n destroy() {\n destroyObjectProperties(this, this.axis);\n }\n /**\n * Gets the x and y positions for ticks in terms of pixels.\n *\n * @private\n * @function Highcharts.Tick#getPosition\n *\n * @param {boolean} horiz\n * Whether the tick is on an horizontal axis or not.\n *\n * @param {number} tickPos\n * Position of the tick.\n *\n * @param {number} tickmarkOffset\n * Tickmark offset for all ticks.\n *\n * @param {boolean} [old]\n * Whether the axis has changed or not.\n *\n * @return {Highcharts.PositionObject}\n * The tick position.\n *\n * @emits Highcharts.Tick#event:afterGetPosition\n */\n getPosition(horiz, tickPos, tickmarkOffset, old) {\n const axis = this.axis, chart = axis.chart, cHeight = (old && chart.oldChartHeight) || chart.chartHeight, pos = {\n x: horiz ?\n correctFloat(axis.translate(tickPos + tickmarkOffset, void 0, void 0, old) +\n axis.transB) :\n (axis.left +\n axis.offset +\n (axis.opposite ?\n (((old && chart.oldChartWidth) ||\n chart.chartWidth) -\n axis.right -\n axis.left) :\n 0)),\n y: horiz ?\n (cHeight -\n axis.bottom +\n axis.offset -\n (axis.opposite ? axis.height : 0)) :\n correctFloat(cHeight -\n axis.translate(tickPos + tickmarkOffset, void 0, void 0, old) -\n axis.transB)\n };\n // Chrome workaround for #10516\n pos.y = clamp(pos.y, -1e5, 1e5);\n fireEvent(this, 'afterGetPosition', { pos: pos });\n return pos;\n }\n /**\n * Get the x, y position of the tick label\n * @private\n */\n getLabelPosition(x, y, label, horiz, labelOptions, tickmarkOffset, index, step) {\n const axis = this.axis, transA = axis.transA, reversed = ( // #7911\n axis.isLinked && axis.linkedParent ?\n axis.linkedParent.reversed :\n axis.reversed), staggerLines = axis.staggerLines, rotCorr = axis.tickRotCorr || { x: 0, y: 0 }, \n // Adjust for label alignment if we use reserveSpace: true (#5286)\n labelOffsetCorrection = (!horiz && !axis.reserveSpaceDefault ?\n -axis.labelOffset * (axis.labelAlign === 'center' ? 0.5 : 1) :\n 0), distance = labelOptions.distance, pos = {};\n let yOffset, line;\n if (axis.side === 0) {\n yOffset = label.rotation ? -distance : -label.getBBox().height;\n }\n else if (axis.side === 2) {\n yOffset = rotCorr.y + distance;\n }\n else {\n // #3140, #3140\n yOffset = Math.cos(label.rotation * deg2rad) *\n (rotCorr.y - label.getBBox(false, 0).height / 2);\n }\n if (defined(labelOptions.y)) {\n yOffset = axis.side === 0 && axis.horiz ?\n labelOptions.y + yOffset :\n labelOptions.y;\n }\n x = x +\n pick(labelOptions.x, [0, 1, 0, -1][axis.side] * distance) +\n labelOffsetCorrection +\n rotCorr.x -\n (tickmarkOffset && horiz ?\n tickmarkOffset * transA * (reversed ? -1 : 1) :\n 0);\n y = y + yOffset - (tickmarkOffset && !horiz ?\n tickmarkOffset * transA * (reversed ? 1 : -1) : 0);\n // Correct for staggered labels\n if (staggerLines) {\n line = (index / (step || 1) % staggerLines);\n if (axis.opposite) {\n line = staggerLines - line - 1;\n }\n y += line * (axis.labelOffset / staggerLines);\n }\n pos.x = x;\n pos.y = Math.round(y);\n fireEvent(this, 'afterGetLabelPosition', { pos: pos, tickmarkOffset: tickmarkOffset, index: index });\n return pos;\n }\n /**\n * Get the offset height or width of the label\n *\n * @private\n * @function Highcharts.Tick#getLabelSize\n */\n getLabelSize() {\n return this.label ?\n this.label.getBBox()[this.axis.horiz ? 'height' : 'width'] :\n 0;\n }\n /**\n * Extendible method to return the path of the marker\n * @private\n */\n getMarkPath(x, y, tickLength, tickWidth, horiz, renderer) {\n return renderer.crispLine([[\n 'M',\n x,\n y\n ], [\n 'L',\n x + (horiz ? 0 : -tickLength),\n y + (horiz ? tickLength : 0)\n ]], tickWidth);\n }\n /**\n * Handle the label overflow by adjusting the labels to the left and right\n * edge, or hide them if they collide into the neighbour label.\n *\n * @private\n * @function Highcharts.Tick#handleOverflow\n */\n handleOverflow(xy) {\n const tick = this, axis = this.axis, labelOptions = axis.options.labels, pxPos = xy.x, chartWidth = axis.chart.chartWidth, spacing = axis.chart.spacing, leftBound = pick(axis.labelLeft, Math.min(axis.pos, spacing[3])), rightBound = pick(axis.labelRight, Math.max(!axis.isRadial ? axis.pos + axis.len : 0, chartWidth - spacing[1])), label = this.label, rotation = this.rotation, factor = {\n left: 0,\n center: 0.5,\n right: 1\n }[axis.labelAlign || label.attr('align')], labelWidth = label.getBBox().width, slotWidth = axis.getSlotWidth(tick), xCorrection = factor, css = {};\n let modifiedSlotWidth = slotWidth, goRight = 1, leftPos, rightPos, textWidth;\n // Check if the label overshoots the chart spacing box. If it does, move\n // it. If it now overshoots the slotWidth, add ellipsis.\n if (!rotation && labelOptions.overflow === 'justify') {\n leftPos = pxPos - factor * labelWidth;\n rightPos = pxPos + (1 - factor) * labelWidth;\n if (leftPos < leftBound) {\n modifiedSlotWidth =\n xy.x + modifiedSlotWidth * (1 - factor) - leftBound;\n }\n else if (rightPos > rightBound) {\n modifiedSlotWidth =\n rightBound - xy.x + modifiedSlotWidth * factor;\n goRight = -1;\n }\n modifiedSlotWidth = Math.min(slotWidth, modifiedSlotWidth); // #4177\n if (modifiedSlotWidth < slotWidth && axis.labelAlign === 'center') {\n xy.x += (goRight *\n (slotWidth -\n modifiedSlotWidth -\n xCorrection * (slotWidth - Math.min(labelWidth, modifiedSlotWidth))));\n }\n // If the label width exceeds the available space, set a text width\n // to be picked up below. Also, if a width has been set before, we\n // need to set a new one because the reported labelWidth will be\n // limited by the box (#3938).\n if (labelWidth > modifiedSlotWidth ||\n (axis.autoRotation && (label.styles || {}).width)) {\n textWidth = modifiedSlotWidth;\n }\n // Add ellipsis to prevent rotated labels to be clipped against the edge\n // of the chart\n }\n else if (rotation < 0 &&\n pxPos - factor * labelWidth < leftBound) {\n textWidth = Math.round(pxPos / Math.cos(rotation * deg2rad) - leftBound);\n }\n else if (rotation > 0 &&\n pxPos + factor * labelWidth > rightBound) {\n textWidth = Math.round((chartWidth - pxPos) /\n Math.cos(rotation * deg2rad));\n }\n if (textWidth) {\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else {\n css.width = Math.floor(textWidth) + 'px';\n if (!(labelOptions.style || {}).textOverflow) {\n css.textOverflow = 'ellipsis';\n }\n label.css(css);\n }\n }\n }\n /**\n * Try to replace the label if the same one already exists.\n *\n * @private\n * @function Highcharts.Tick#moveLabel\n */\n moveLabel(str, labelOptions) {\n const tick = this, label = tick.label, axis = tick.axis;\n let moved = false, labelPos;\n if (label && label.textStr === str) {\n tick.movedLabel = label;\n moved = true;\n delete tick.label;\n }\n else { // Find a label with the same string\n objectEach(axis.ticks, function (currentTick) {\n if (!moved &&\n !currentTick.isNew &&\n currentTick !== tick &&\n currentTick.label &&\n currentTick.label.textStr === str) {\n tick.movedLabel = currentTick.label;\n moved = true;\n currentTick.labelPos = tick.movedLabel.xy;\n delete currentTick.label;\n }\n });\n }\n // Create new label if the actual one is moved\n if (!moved && (tick.labelPos || label)) {\n labelPos = tick.labelPos || label.xy;\n tick.movedLabel = tick.createLabel(labelPos, str, labelOptions);\n if (tick.movedLabel) {\n tick.movedLabel.attr({ opacity: 0 });\n }\n }\n }\n /**\n * Put everything in place\n *\n * @private\n * @param {number} index\n *\n * @param {boolean} [old]\n * Use old coordinates to prepare an animation into new position\n *\n * @param {number} [opacity]\n */\n render(index, old, opacity) {\n const tick = this, axis = tick.axis, horiz = axis.horiz, pos = tick.pos, tickmarkOffset = pick(tick.tickmarkOffset, axis.tickmarkOffset), xy = tick.getPosition(horiz, pos, tickmarkOffset, old), x = xy.x, y = xy.y, reverseCrisp = ((horiz && x === axis.pos + axis.len) ||\n (!horiz && y === axis.pos)) ? -1 : 1; // #1480, #1687\n const labelOpacity = pick(opacity, tick.label && tick.label.newOpacity, // #15528\n 1);\n opacity = pick(opacity, 1);\n this.isActive = true;\n // Create the grid line\n this.renderGridLine(old, opacity, reverseCrisp);\n // create the tick mark\n this.renderMark(xy, opacity, reverseCrisp);\n // the label is created on init - now move it into place\n this.renderLabel(xy, old, labelOpacity, index);\n tick.isNew = false;\n fireEvent(this, 'afterRender');\n }\n /**\n * Renders the gridLine.\n *\n * @private\n * @function Highcharts.Tick#renderGridLine\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the grid line\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n renderGridLine(old, opacity, reverseCrisp) {\n const tick = this, axis = tick.axis, options = axis.options, attribs = {}, pos = tick.pos, type = tick.type, tickmarkOffset = pick(tick.tickmarkOffset, axis.tickmarkOffset), renderer = axis.chart.renderer;\n let gridLine = tick.gridLine, gridLinePath, gridLineWidth = options.gridLineWidth, gridLineColor = options.gridLineColor, dashStyle = options.gridLineDashStyle;\n if (tick.type === 'minor') {\n gridLineWidth = options.minorGridLineWidth;\n gridLineColor = options.minorGridLineColor;\n dashStyle = options.minorGridLineDashStyle;\n }\n if (!gridLine) {\n if (!axis.chart.styledMode) {\n attribs.stroke = gridLineColor;\n attribs['stroke-width'] = gridLineWidth || 0;\n attribs.dashstyle = dashStyle;\n }\n if (!type) {\n attribs.zIndex = 1;\n }\n if (old) {\n opacity = 0;\n }\n /**\n * The rendered grid line of the tick.\n * @name Highcharts.Tick#gridLine\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.gridLine = gridLine = renderer.path()\n .attr(attribs)\n .addClass('highcharts-' + (type ? type + '-' : '') + 'grid-line')\n .add(axis.gridGroup);\n }\n if (gridLine) {\n gridLinePath = axis.getPlotLinePath({\n value: pos + tickmarkOffset,\n lineWidth: gridLine.strokeWidth() * reverseCrisp,\n force: 'pass',\n old: old,\n acrossPanes: false // #18025\n });\n // If the parameter 'old' is set, the current call will be followed\n // by another call, therefore do not do any animations this time\n if (gridLinePath) {\n gridLine[old || tick.isNew ? 'attr' : 'animate']({\n d: gridLinePath,\n opacity: opacity\n });\n }\n }\n }\n /**\n * Renders the tick mark.\n *\n * @private\n * @function Highcharts.Tick#renderMark\n * @param {Highcharts.PositionObject} xy The position vector of the mark\n * @param {number} opacity The opacity of the mark\n * @param {number} reverseCrisp Modifier for avoiding overlapping 1 or -1\n */\n renderMark(xy, opacity, reverseCrisp) {\n const tick = this, axis = tick.axis, options = axis.options, renderer = axis.chart.renderer, type = tick.type, tickSize = axis.tickSize(type ? type + 'Tick' : 'tick'), x = xy.x, y = xy.y, tickWidth = pick(options[type !== 'minor' ? 'tickWidth' : 'minorTickWidth'], !type && axis.isXAxis ? 1 : 0), // X axis defaults to 1\n tickColor = options[type !== 'minor' ? 'tickColor' : 'minorTickColor'];\n let mark = tick.mark;\n const isNewMark = !mark;\n if (tickSize) {\n // negate the length\n if (axis.opposite) {\n tickSize[0] = -tickSize[0];\n }\n // First time, create it\n if (!mark) {\n /**\n * The rendered mark of the tick.\n * @name Highcharts.Tick#mark\n * @type {Highcharts.SVGElement|undefined}\n */\n tick.mark = mark = renderer.path()\n .addClass('highcharts-' + (type ? type + '-' : '') + 'tick')\n .add(axis.axisGroup);\n if (!axis.chart.styledMode) {\n mark.attr({\n stroke: tickColor,\n 'stroke-width': tickWidth\n });\n }\n }\n mark[isNewMark ? 'attr' : 'animate']({\n d: tick.getMarkPath(x, y, tickSize[0], mark.strokeWidth() * reverseCrisp, axis.horiz, renderer),\n opacity: opacity\n });\n }\n }\n /**\n * Renders the tick label.\n * Note: The label should already be created in init(), so it should only\n * have to be moved into place.\n *\n * @private\n * @function Highcharts.Tick#renderLabel\n * @param {Highcharts.PositionObject} xy The position vector of the label\n * @param {boolean} old Whether or not the tick is old\n * @param {number} opacity The opacity of the label\n * @param {number} index The index of the tick\n */\n renderLabel(xy, old, opacity, index) {\n const tick = this, axis = tick.axis, horiz = axis.horiz, options = axis.options, label = tick.label, labelOptions = options.labels, step = labelOptions.step, tickmarkOffset = pick(tick.tickmarkOffset, axis.tickmarkOffset), x = xy.x, y = xy.y;\n let show = true;\n if (label && isNumber(x)) {\n label.xy = xy = tick.getLabelPosition(x, y, label, horiz, labelOptions, tickmarkOffset, index, step);\n // Apply show first and show last. If the tick is both first and\n // last, it is a single centered tick, in which case we show the\n // label anyway (#2100).\n if ((tick.isFirst &&\n !tick.isLast &&\n !options.showFirstLabel) ||\n (tick.isLast &&\n !tick.isFirst &&\n !options.showLastLabel)) {\n show = false;\n // Handle label overflow and show or hide accordingly\n }\n else if (horiz &&\n !labelOptions.step &&\n !labelOptions.rotation &&\n !old &&\n opacity !== 0) {\n tick.handleOverflow(xy);\n }\n // apply step\n if (step && index % step) {\n // show those indices dividable by step\n show = false;\n }\n // Set the new position, and show or hide\n if (show && isNumber(xy.y)) {\n xy.opacity = opacity;\n label[tick.isNewLabel ? 'attr' : 'animate'](xy).show(true);\n tick.isNewLabel = false;\n }\n else {\n label.hide(); // #1338, #15863\n tick.isNewLabel = true;\n }\n }\n }\n /**\n * Replace labels with the moved ones to perform animation. Additionally\n * destroy unused labels.\n *\n * @private\n * @function Highcharts.Tick#replaceMovedLabel\n */\n replaceMovedLabel() {\n const tick = this, label = tick.label, axis = tick.axis;\n // Animate and destroy\n if (label && !tick.isNew) {\n label.animate({ opacity: 0 }, void 0, label.destroy);\n delete tick.label;\n }\n axis.isDirty = true;\n tick.label = tick.movedLabel;\n delete tick.movedLabel;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Optional parameters for the tick.\n * @private\n * @interface Highcharts.TickParametersObject\n */ /**\n * Set category for the tick.\n * @name Highcharts.TickParametersObject#category\n * @type {string|undefined}\n */ /**\n * @name Highcharts.TickParametersObject#options\n * @type {Highcharts.Dictionary|undefined}\n */ /**\n * Set tickmarkOffset for the tick.\n * @name Highcharts.TickParametersObject#tickmarkOffset\n * @type {number|undefined}\n */\n /**\n * Additonal time tick information.\n *\n * @interface Highcharts.TimeTicksInfoObject\n * @extends Highcharts.TimeNormalizedObject\n */ /**\n * @name Highcharts.TimeTicksInfoObject#higherRanks\n * @type {Array}\n */ /**\n * @name Highcharts.TimeTicksInfoObject#totalRange\n * @type {number}\n */\n (''); // keeps doclets above in JS file\n\n return Tick;\n });\n _registerModule(_modules, 'Core/Axis/Axis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/AxisDefaults.js'], _modules['Core/Color/Color.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Utilities.js']], function (A, AxisDefaults, Color, D, F, H, Tick, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject } = A;\n const { defaultOptions } = D;\n const { registerEventOptions } = F;\n const { deg2rad } = H;\n const { arrayMax, arrayMin, clamp, correctFloat, defined, destroyObjectProperties, erase, error, extend, fireEvent, getClosestDistance, insertItem, isArray, isNumber, isString, merge, normalizeTickInterval, objectEach, pick, relativeLength, removeEvent, splat, syncTimeout } = U;\n const getNormalizedTickInterval = (axis, tickInterval) => normalizeTickInterval(tickInterval, void 0, void 0, pick(axis.options.allowDecimals, \n // If the tick interval is greather than 0.5, avoid decimals, as\n // linear axes are often used to render discrete values (#3363). If\n // a tick amount is set, allow decimals by default, as it increases\n // the chances for a good fit.\n tickInterval < 0.5 || axis.tickAmount !== void 0), !!axis.tickAmount);\n /* *\n *\n * Class\n *\n * */\n /**\n * Create a new axis object. Called internally when instanciating a new chart or\n * adding axes by {@link Highcharts.Chart#addAxis}.\n *\n * A chart can have from 0 axes (pie chart) to multiples. In a normal, single\n * series cartesian chart, there is one X axis and one Y axis.\n *\n * The X axis or axes are referenced by {@link Highcharts.Chart.xAxis}, which is\n * an array of Axis objects. If there is only one axis, it can be referenced\n * through `chart.xAxis[0]`, and multiple axes have increasing indices. The same\n * pattern goes for Y axes.\n *\n * If you need to get the axes from a series object, use the `series.xAxis` and\n * `series.yAxis` properties. These are not arrays, as one series can only be\n * associated to one X and one Y axis.\n *\n * A third way to reference the axis programmatically is by `id`. Add an `id` in\n * the axis configuration options, and get the axis by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the axes are given in options.xAxis and\n * options.yAxis.\n *\n * @class\n * @name Highcharts.Axis\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options\n */\n class Axis {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, userOptions, coll) {\n this.alternateBands = void 0;\n this.bottom = void 0;\n this.chart = void 0;\n this.closestPointRange = void 0;\n this.coll = void 0;\n this.eventOptions = void 0;\n this.hasNames = void 0;\n this.hasVisibleSeries = void 0;\n this.height = void 0;\n this.index = void 0;\n this.isLinked = void 0;\n this.labelEdge = void 0; // @todo\n this.labelFormatter = void 0;\n this.left = void 0;\n this.len = void 0;\n this.max = void 0;\n this.maxLabelLength = void 0;\n this.min = void 0;\n this.minorTickInterval = void 0;\n this.minorTicks = void 0;\n this.minPixelPadding = void 0;\n this.names = void 0;\n this.offset = void 0;\n this.options = void 0;\n this.overlap = void 0;\n this.paddedTicks = void 0;\n this.plotLinesAndBands = void 0;\n this.plotLinesAndBandsGroups = void 0;\n this.pointRange = void 0;\n this.pointRangePadding = void 0;\n this.pos = void 0;\n this.positiveValuesOnly = void 0;\n this.right = void 0;\n this.series = void 0;\n this.side = void 0;\n this.tickAmount = void 0;\n this.tickInterval = void 0;\n this.tickmarkOffset = void 0;\n this.tickPositions = void 0;\n this.tickRotCorr = void 0;\n this.ticks = void 0;\n this.top = void 0;\n this.transA = void 0;\n this.transB = void 0;\n this.translationSlope = void 0;\n this.userOptions = void 0;\n this.visible = void 0;\n this.width = void 0;\n this.zoomEnabled = void 0;\n this.init(chart, userOptions, coll);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Overrideable function to initialize the axis.\n *\n * @see {@link Axis}\n *\n * @function Highcharts.Axis#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance to apply the axis on.\n *\n * @param {AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterInit\n * @emits Highcharts.Axis#event:init\n */\n init(chart, userOptions, coll = this.coll) {\n const isXAxis = coll === 'xAxis', axis = this;\n /**\n * The Chart that the axis belongs to.\n *\n * @name Highcharts.Axis#chart\n * @type {Highcharts.Chart}\n */\n axis.chart = chart;\n /**\n * Whether the axis is horizontal.\n *\n * @name Highcharts.Axis#horiz\n * @type {boolean|undefined}\n */\n axis.horiz = axis.isZAxis || (chart.inverted ? !isXAxis : isXAxis);\n /**\n * Whether the axis is the x-axis.\n *\n * @name Highcharts.Axis#isXAxis\n * @type {boolean|undefined}\n */\n axis.isXAxis = isXAxis;\n /**\n * The collection where the axis belongs, for example `xAxis`, `yAxis`\n * or `colorAxis`. Corresponds to properties on Chart, for example\n * {@link Chart.xAxis}.\n *\n * @name Highcharts.Axis#coll\n * @type {string}\n */\n axis.coll = coll;\n fireEvent(this, 'init', { userOptions: userOptions });\n // Needed in setOptions\n axis.opposite = pick(userOptions.opposite, axis.opposite);\n /**\n * The side on which the axis is rendered. 0 is top, 1 is right, 2\n * is bottom and 3 is left.\n *\n * @name Highcharts.Axis#side\n * @type {number}\n */\n axis.side = pick(userOptions.side, axis.side, (axis.horiz ?\n (axis.opposite ? 0 : 2) : // top : bottom\n (axis.opposite ? 1 : 3)) // right : left\n );\n /**\n * Current options for the axis after merge of defaults and user's\n * options.\n *\n * @name Highcharts.Axis#options\n * @type {Highcharts.AxisOptions}\n */\n axis.setOptions(userOptions);\n const options = this.options, labelsOptions = options.labels, type = options.type;\n /**\n * User's options for this axis without defaults.\n *\n * @name Highcharts.Axis#userOptions\n * @type {Highcharts.AxisOptions}\n */\n axis.userOptions = userOptions;\n axis.minPixelPadding = 0;\n /**\n * Whether the axis is reversed. Based on the `axis.reversed`,\n * option, but inverted charts have reversed xAxis by default.\n *\n * @name Highcharts.Axis#reversed\n * @type {boolean}\n */\n axis.reversed = pick(options.reversed, axis.reversed);\n axis.visible = options.visible;\n axis.zoomEnabled = options.zoomEnabled;\n // Initial categories\n axis.hasNames =\n type === 'category' || options.categories === true;\n /**\n * If categories are present for the axis, names are used instead of\n * numbers for that axis.\n *\n * Since Highcharts 3.0, categories can also be extracted by giving each\n * point a name and setting axis type to `category`. However, if you\n * have multiple series, best practice remains defining the `categories`\n * array.\n *\n * @see [xAxis.categories](/highcharts/xAxis.categories)\n *\n * @name Highcharts.Axis#categories\n * @type {Array}\n * @readonly\n */\n axis.categories = options.categories || (axis.hasNames ? [] : void 0);\n if (!axis.names) { // Preserve on update (#3830)\n axis.names = [];\n axis.names.keys = {};\n }\n // Placeholder for plotlines and plotbands groups\n axis.plotLinesAndBandsGroups = {};\n // Shorthand types\n axis.positiveValuesOnly = !!axis.logarithmic;\n // Flag, if axis is linked to another axis\n axis.isLinked = defined(options.linkedTo);\n /**\n * List of major ticks mapped by postition on axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#ticks\n * @type {Highcharts.Dictionary}\n */\n axis.ticks = {};\n axis.labelEdge = [];\n /**\n * List of minor ticks mapped by position on the axis.\n *\n * @see {@link Highcharts.Tick}\n *\n * @name Highcharts.Axis#minorTicks\n * @type {Highcharts.Dictionary}\n */\n axis.minorTicks = {};\n // List of plotLines/Bands\n axis.plotLinesAndBands = [];\n // Alternate bands\n axis.alternateBands = {};\n // Axis metrics\n axis.len = 0;\n axis.minRange = axis.userMinRange = options.minRange || options.maxZoom;\n axis.range = options.range;\n axis.offset = options.offset || 0;\n /**\n * The maximum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#max\n * @type {number|null}\n */\n axis.max = null;\n /**\n * The minimum value of the axis. In a logarithmic axis, this is the\n * logarithm of the real value, and the real value can be obtained from\n * {@link Axis#getExtremes}.\n *\n * @name Highcharts.Axis#min\n * @type {number|null}\n */\n axis.min = null;\n /**\n * The processed crosshair options.\n *\n * @name Highcharts.Axis#crosshair\n * @type {boolean|Highcharts.AxisCrosshairOptions}\n */\n const crosshair = pick(options.crosshair, splat(chart.options.tooltip.crosshairs)[isXAxis ? 0 : 1]);\n axis.crosshair = crosshair === true ? {} : crosshair;\n // Register. Don't add it again on Axis.update().\n if (chart.axes.indexOf(axis) === -1) { //\n if (isXAxis) { // #2713\n chart.axes.splice(chart.xAxis.length, 0, axis);\n }\n else {\n chart.axes.push(axis);\n }\n insertItem(this, chart[this.coll]);\n }\n chart.orderItems(axis.coll);\n /**\n * All series associated to the axis.\n *\n * @name Highcharts.Axis#series\n * @type {Array}\n */\n axis.series = axis.series || []; // populated by Series\n // Reversed axis\n if (chart.inverted &&\n !axis.isZAxis &&\n isXAxis &&\n typeof axis.reversed === 'undefined') {\n axis.reversed = true;\n }\n axis.labelRotation = isNumber(labelsOptions.rotation) ?\n labelsOptions.rotation :\n void 0;\n // Register event listeners\n registerEventOptions(axis, options);\n fireEvent(this, 'afterInit');\n }\n /**\n * Merge and set options.\n *\n * @private\n * @function Highcharts.Axis#setOptions\n *\n * @param {Highcharts.AxisOptions} userOptions\n * Axis options.\n *\n * @emits Highcharts.Axis#event:afterSetOptions\n */\n setOptions(userOptions) {\n this.options = merge(AxisDefaults.defaultXAxisOptions, (this.coll === 'yAxis') && AxisDefaults.defaultYAxisOptions, [\n AxisDefaults.defaultTopAxisOptions,\n AxisDefaults.defaultRightAxisOptions,\n AxisDefaults.defaultBottomAxisOptions,\n AxisDefaults.defaultLeftAxisOptions\n ][this.side], merge(\n // if set in setOptions (#1053):\n defaultOptions[this.coll], userOptions));\n fireEvent(this, 'afterSetOptions', { userOptions: userOptions });\n }\n /**\n * The default label formatter. The context is a special config object for\n * the label. In apps, use the\n * [labels.formatter](https://api.highcharts.com/highcharts/xAxis.labels.formatter)\n * instead, except when a modification is needed.\n *\n * @function Highcharts.Axis#defaultLabelFormatter\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n * Formatter context of axis label.\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} [ctx]\n * Formatter context of axis label.\n *\n * @return {string}\n * The formatted label content.\n */\n defaultLabelFormatter(ctx) {\n const axis = this.axis, chart = this.chart, { numberFormatter } = chart, value = isNumber(this.value) ? this.value : NaN, time = axis.chart.time, categories = axis.categories, dateTimeLabelFormat = this.dateTimeLabelFormat, lang = defaultOptions.lang, numericSymbols = lang.numericSymbols, numSymMagnitude = lang.numericSymbolMagnitude || 1000, \n // make sure the same symbol is added for all labels on a linear\n // axis\n numericSymbolDetector = axis.logarithmic ?\n Math.abs(value) :\n axis.tickInterval;\n let i = numericSymbols && numericSymbols.length, multi, ret;\n if (categories) {\n ret = `${this.value}`;\n }\n else if (dateTimeLabelFormat) { // datetime axis\n ret = time.dateFormat(dateTimeLabelFormat, value);\n }\n else if (i && numericSymbolDetector >= 1000) {\n // Decide whether we should add a numeric symbol like k (thousands)\n // or M (millions). If we are to enable this in tooltip or other\n // places as well, we can move this logic to the numberFormatter and\n // enable it by a parameter.\n while (i-- && typeof ret === 'undefined') {\n multi = Math.pow(numSymMagnitude, i + 1);\n if (\n // Only accept a numeric symbol when the distance is more\n // than a full unit. So for example if the symbol is k, we\n // don't accept numbers like 0.5k.\n numericSymbolDetector >= multi &&\n // Accept one decimal before the symbol. Accepts 0.5k but\n // not 0.25k. How does this work with the previous?\n (value * 10) % multi === 0 &&\n numericSymbols[i] !== null &&\n value !== 0) { // #5480\n ret = numberFormatter(value / multi, -1) + numericSymbols[i];\n }\n }\n }\n if (typeof ret === 'undefined') {\n if (Math.abs(value) >= 10000) { // add thousands separators\n ret = numberFormatter(value, -1);\n }\n else { // small numbers\n ret = numberFormatter(value, -1, void 0, ''); // #2466\n }\n }\n return ret;\n }\n /**\n * Get the minimum and maximum for the series of each axis. The function\n * analyzes the axis series and updates `this.dataMin` and `this.dataMax`.\n *\n * @private\n * @function Highcharts.Axis#getSeriesExtremes\n *\n * @emits Highcharts.Axis#event:afterGetSeriesExtremes\n * @emits Highcharts.Axis#event:getSeriesExtremes\n */\n getSeriesExtremes() {\n const axis = this, chart = axis.chart;\n let xExtremes;\n fireEvent(this, 'getSeriesExtremes', null, function () {\n axis.hasVisibleSeries = false;\n // Reset properties in case we're redrawing (#3353)\n axis.dataMin = axis.dataMax = axis.threshold = null;\n axis.softThreshold = !axis.isXAxis;\n // Loop through this axis' series\n axis.series.forEach(function (series) {\n if (series.visible ||\n !chart.options.chart.ignoreHiddenSeries) {\n const seriesOptions = series.options;\n let xData, threshold = seriesOptions.threshold, seriesDataMin, seriesDataMax;\n axis.hasVisibleSeries = true;\n // Validate threshold in logarithmic axes\n if (axis.positiveValuesOnly && threshold <= 0) {\n threshold = null;\n }\n // Get dataMin and dataMax for X axes\n if (axis.isXAxis) {\n xData = series.xData;\n if (xData && xData.length) {\n xData = axis.logarithmic ?\n xData.filter((x) => x > 0) :\n xData;\n xExtremes = series.getXExtremes(xData);\n // If xData contains values which is not numbers,\n // then filter them out. To prevent performance hit,\n // we only do this after we have already found\n // seriesDataMin because in most cases all data is\n // valid. #5234.\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n if (!isNumber(seriesDataMin) &&\n // #5010:\n !(seriesDataMin instanceof Date)) {\n xData = xData.filter(isNumber);\n xExtremes = series.getXExtremes(xData);\n // Do it again with valid data\n seriesDataMin = xExtremes.min;\n seriesDataMax = xExtremes.max;\n }\n if (xData.length) {\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n }\n // Get dataMin and dataMax for Y axes, as well as handle\n // stacking and processed data\n }\n else {\n // Get this particular series extremes\n const dataExtremes = series.applyExtremes();\n // Get the dataMin and dataMax so far. If percentage is\n // used, the min and max are always 0 and 100. If\n // seriesDataMin and seriesDataMax is null, then series\n // doesn't have active y data, we continue with nulls\n if (isNumber(dataExtremes.dataMin)) {\n seriesDataMin = dataExtremes.dataMin;\n axis.dataMin = Math.min(pick(axis.dataMin, seriesDataMin), seriesDataMin);\n }\n if (isNumber(dataExtremes.dataMax)) {\n seriesDataMax = dataExtremes.dataMax;\n axis.dataMax = Math.max(pick(axis.dataMax, seriesDataMax), seriesDataMax);\n }\n // Adjust to threshold\n if (defined(threshold)) {\n axis.threshold = threshold;\n }\n // If any series has a hard threshold, it takes\n // precedence\n if (!seriesOptions.softThreshold ||\n axis.positiveValuesOnly) {\n axis.softThreshold = false;\n }\n }\n }\n });\n });\n fireEvent(this, 'afterGetSeriesExtremes');\n }\n /**\n * Translate from axis value to pixel position on the chart, or back. Use\n * the `toPixels` and `toValue` functions in applications.\n *\n * @private\n * @function Highcharts.Axis#translate\n */\n translate(val, backwards, cvsCoord, old, handleLog, pointPlacement) {\n const axis = (this.linkedParent || this), // #1417\n localMin = (old && axis.old ? axis.old.min : axis.min);\n if (!isNumber(localMin)) {\n return NaN;\n }\n const minPixelPadding = axis.minPixelPadding, doPostTranslate = (axis.isOrdinal ||\n axis.brokenAxis && axis.brokenAxis.hasBreaks ||\n (axis.logarithmic && handleLog)) && axis.lin2val;\n let sign = 1, cvsOffset = 0, localA = old && axis.old ? axis.old.transA : axis.transA, returnValue = 0;\n if (!localA) {\n localA = axis.transA;\n }\n // In vertical axes, the canvas coordinates start from 0 at the top like\n // in SVG.\n if (cvsCoord) {\n sign *= -1; // canvas coordinates inverts the value\n cvsOffset = axis.len;\n }\n // Handle reversed axis\n if (axis.reversed) {\n sign *= -1;\n cvsOffset -= sign * (axis.sector || axis.len);\n }\n // From pixels to value\n if (backwards) { // reverse translation\n val = val * sign + cvsOffset;\n val -= minPixelPadding;\n // from chart pixel to value:\n returnValue = val / localA + localMin;\n if (doPostTranslate) { // log, ordinal and broken axis\n returnValue = axis.lin2val(returnValue);\n }\n // From value to pixels\n }\n else {\n if (doPostTranslate) { // log, ordinal and broken axis\n val = axis.val2lin(val);\n }\n const value = sign * (val - localMin) * localA;\n returnValue = (!axis.isRadial ? correctFloat(value) : value) +\n cvsOffset +\n (sign * minPixelPadding) +\n (isNumber(pointPlacement) ? localA * pointPlacement : 0);\n }\n return returnValue;\n }\n /**\n * Translate a value in terms of axis units into pixels within the chart.\n *\n * @function Highcharts.Axis#toPixels\n *\n * @param {number} value\n * A value in terms of axis units.\n *\n * @param {boolean} paneCoordinates\n * Whether to return the pixel coordinate relative to the chart or just the\n * axis/pane itself.\n *\n * @return {number}\n * Pixel position of the value on the chart or axis.\n */\n toPixels(value, paneCoordinates) {\n return this.translate(value, false, !this.horiz, void 0, true) +\n (paneCoordinates ? 0 : this.pos);\n }\n /**\n * Translate a pixel position along the axis to a value in terms of axis\n * units.\n *\n * @function Highcharts.Axis#toValue\n *\n * @param {number} pixel\n * The pixel value coordinate.\n *\n * @param {boolean} [paneCoordinates=false]\n * Whether the input pixel is relative to the chart or just the axis/pane\n * itself.\n *\n * @return {number}\n * The axis value.\n */\n toValue(pixel, paneCoordinates) {\n return this.translate(pixel - (paneCoordinates ? 0 : this.pos), true, !this.horiz, void 0, true);\n }\n /**\n * Create the path for a plot line that goes from the given value on\n * this axis, across the plot to the opposite side. Also used internally for\n * grid lines and crosshairs.\n *\n * @function Highcharts.Axis#getPlotLinePath\n *\n * @param {Highcharts.AxisPlotLinePathOptionsObject} options\n * Options for the path.\n *\n * @return {Highcharts.SVGPathArray|null}\n * The SVG path definition for the plot line.\n */\n getPlotLinePath(options) {\n const axis = this, chart = axis.chart, axisLeft = axis.left, axisTop = axis.top, old = options.old, value = options.value, lineWidth = options.lineWidth, cHeight = (old && chart.oldChartHeight) || chart.chartHeight, cWidth = (old && chart.oldChartWidth) || chart.chartWidth, transB = axis.transB;\n let translatedValue = options.translatedValue, force = options.force, x1, y1, x2, y2, skip;\n // eslint-disable-next-line valid-jsdoc\n /**\n * Check if x is between a and b. If not, either move to a/b\n * or skip, depending on the force parameter.\n * @private\n */\n function between(x, a, b) {\n if (force !== 'pass' && (x < a || x > b)) {\n if (force) {\n x = clamp(x, a, b);\n }\n else {\n skip = true;\n }\n }\n return x;\n }\n const evt = {\n value: value,\n lineWidth: lineWidth,\n old: old,\n force: force,\n acrossPanes: options.acrossPanes,\n translatedValue: translatedValue\n };\n fireEvent(this, 'getPlotLinePath', evt, function (e) {\n translatedValue = pick(translatedValue, axis.translate(value, void 0, void 0, old));\n // Keep the translated value within sane bounds, and avoid Infinity\n // to fail the isNumber test (#7709).\n translatedValue = clamp(translatedValue, -1e5, 1e5);\n x1 = x2 = Math.round(translatedValue + transB);\n y1 = y2 = Math.round(cHeight - translatedValue - transB);\n if (!isNumber(translatedValue)) { // no min or max\n skip = true;\n force = false; // #7175, don't force it when path is invalid\n }\n else if (axis.horiz) {\n y1 = axisTop;\n y2 = cHeight - axis.bottom;\n x1 = x2 = between(x1, axisLeft, axisLeft + axis.width);\n }\n else {\n x1 = axisLeft;\n x2 = cWidth - axis.right;\n y1 = y2 = between(y1, axisTop, axisTop + axis.height);\n }\n e.path = skip && !force ?\n null :\n chart.renderer.crispLine([['M', x1, y1], ['L', x2, y2]], lineWidth || 1);\n });\n return evt.path;\n }\n /**\n * Internal function to get the tick positions of a linear axis to round\n * values like whole tens or every five.\n *\n * @function Highcharts.Axis#getLinearTickPositions\n *\n * @param {number} tickInterval\n * The normalized tick interval.\n *\n * @param {number} min\n * Axis minimum.\n *\n * @param {number} max\n * Axis maximum.\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n getLinearTickPositions(tickInterval, min, max) {\n const roundedMin = correctFloat(Math.floor(min / tickInterval) * tickInterval), roundedMax = correctFloat(Math.ceil(max / tickInterval) * tickInterval), tickPositions = [];\n let pos, lastPos, precision;\n // When the precision is higher than what we filter out in\n // correctFloat, skip it (#6183).\n if (correctFloat(roundedMin + tickInterval) === roundedMin) {\n precision = 20;\n }\n // For single points, add a tick regardless of the relative position\n // (#2662, #6274)\n if (this.single) {\n return [min];\n }\n // Populate the intermediate values\n pos = roundedMin;\n while (pos <= roundedMax) {\n // Place the tick on the rounded value\n tickPositions.push(pos);\n // Always add the raw tickInterval, not the corrected one.\n pos = correctFloat(pos + tickInterval, precision);\n // If the interval is not big enough in the current min - max range\n // to actually increase the loop variable, we need to break out to\n // prevent endless loop. Issue #619\n if (pos === lastPos) {\n break;\n }\n // Record the last value\n lastPos = pos;\n }\n return tickPositions;\n }\n /**\n * Resolve the new minorTicks/minorTickInterval options into the legacy\n * loosely typed minorTickInterval option.\n *\n * @function Highcharts.Axis#getMinorTickInterval\n *\n * @return {number|\"auto\"|null}\n * Legacy option\n */\n getMinorTickInterval() {\n const options = this.options;\n if (options.minorTicks === true) {\n return pick(options.minorTickInterval, 'auto');\n }\n if (options.minorTicks === false) {\n return null;\n }\n return options.minorTickInterval;\n }\n /**\n * Internal function to return the minor tick positions. For logarithmic\n * axes, the same logic as for major ticks is reused.\n *\n * @function Highcharts.Axis#getMinorTickPositions\n *\n * @return {Array}\n * An array of axis values where ticks should be placed.\n */\n getMinorTickPositions() {\n const axis = this, options = axis.options, tickPositions = axis.tickPositions, minorTickInterval = axis.minorTickInterval, pointRangePadding = axis.pointRangePadding || 0, min = axis.min - pointRangePadding, // #1498\n max = axis.max + pointRangePadding, // #1498\n range = max - min;\n let minorTickPositions = [], pos;\n // If minor ticks get too dense, they are hard to read, and may cause\n // long running script. So we don't draw them.\n if (range && range / minorTickInterval < axis.len / 3) { // #3875\n const logarithmic = axis.logarithmic;\n if (logarithmic) {\n // For each interval in the major ticks, compute the minor ticks\n // separately.\n this.paddedTicks.forEach(function (_pos, i, paddedTicks) {\n if (i) {\n minorTickPositions.push.apply(minorTickPositions, logarithmic.getLogTickPositions(minorTickInterval, paddedTicks[i - 1], paddedTicks[i], true));\n }\n });\n }\n else if (axis.dateTime &&\n this.getMinorTickInterval() === 'auto') { // #1314\n minorTickPositions = minorTickPositions.concat(axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(minorTickInterval), min, max, options.startOfWeek));\n }\n else {\n for (pos = min + (tickPositions[0] - min) % minorTickInterval; pos <= max; pos += minorTickInterval) {\n // Very, very, tight grid lines (#5771)\n if (pos === minorTickPositions[0]) {\n break;\n }\n minorTickPositions.push(pos);\n }\n }\n }\n if (minorTickPositions.length !== 0) {\n axis.trimTicks(minorTickPositions); // #3652 #3743 #1498 #6330\n }\n return minorTickPositions;\n }\n /**\n * Adjust the min and max for the minimum range. Keep in mind that the\n * series data is not yet processed, so we don't have information on data\n * cropping and grouping, or updated `axis.pointRange` or\n * `series.pointRange`. The data can't be processed until we have finally\n * established min and max.\n *\n * @private\n * @function Highcharts.Axis#adjustForMinRange\n */\n adjustForMinRange() {\n const axis = this, options = axis.options, logarithmic = axis.logarithmic;\n let min = axis.min, max = axis.max, zoomOffset, spaceAvailable, closestDataRange, minArgs, maxArgs, minRange;\n // Set the automatic minimum range based on the closest point distance\n if (axis.isXAxis &&\n typeof axis.minRange === 'undefined' &&\n !logarithmic) {\n if (defined(options.min) ||\n defined(options.max) ||\n defined(options.floor) ||\n defined(options.ceiling)) {\n axis.minRange = null; // don't do this again\n }\n else {\n // Find the closest distance between raw data points, as opposed\n // to closestPointRange that applies to processed points\n // (cropped and grouped)\n closestDataRange = getClosestDistance(axis.series.map((s) => { var _a; \n // If xIncrement, we only need to measure the two first\n // points to get the distance. Saves processing time.\n return (s.xIncrement ? (_a = s.xData) === null || _a === void 0 ? void 0 : _a.slice(0, 2) : s.xData) || []; })) || 0;\n axis.minRange = Math.min(closestDataRange * 5, axis.dataMax - axis.dataMin);\n }\n }\n // if minRange is exceeded, adjust\n if (max - min < axis.minRange) {\n spaceAvailable =\n axis.dataMax - axis.dataMin >=\n axis.minRange;\n minRange = axis.minRange;\n zoomOffset = (minRange - max + min) / 2;\n // if min and max options have been set, don't go beyond it\n minArgs = [\n min - zoomOffset,\n pick(options.min, min - zoomOffset)\n ];\n // If space is available, stay within the data range\n if (spaceAvailable) {\n minArgs[2] = logarithmic ?\n logarithmic.log2lin(axis.dataMin) :\n axis.dataMin;\n }\n min = arrayMax(minArgs);\n maxArgs = [\n min + minRange,\n pick(options.max, min + minRange)\n ];\n // If space is availabe, stay within the data range\n if (spaceAvailable) {\n maxArgs[2] = logarithmic ?\n logarithmic.log2lin(axis.dataMax) :\n axis.dataMax;\n }\n max = arrayMin(maxArgs);\n // now if the max is adjusted, adjust the min back\n if (max - min < minRange) {\n minArgs[0] = max - minRange;\n minArgs[1] = pick(options.min, max - minRange);\n min = arrayMax(minArgs);\n }\n }\n // Record modified extremes\n axis.min = min;\n axis.max = max;\n }\n /**\n * Find the closestPointRange across all series, including the single data\n * series.\n *\n * @private\n * @function Highcharts.Axis#getClosest\n */\n getClosest() {\n let closestSingleDistance, closestDistance;\n if (this.categories) {\n closestDistance = 1;\n }\n else {\n const singleXs = [];\n this.series.forEach(function (series) {\n var _a;\n const seriesClosest = series.closestPointRange, visible = series.visible ||\n !series.chart.options.chart.ignoreHiddenSeries;\n if (((_a = series.xData) === null || _a === void 0 ? void 0 : _a.length) === 1) {\n singleXs.push(series.xData[0]);\n }\n else if (!series.noSharedTooltip &&\n defined(seriesClosest) &&\n visible) {\n closestDistance = defined(closestDistance) ?\n Math.min(closestDistance, seriesClosest) :\n seriesClosest;\n }\n });\n if (singleXs.length) {\n singleXs.sort((a, b) => a - b);\n closestSingleDistance = getClosestDistance([singleXs]);\n }\n }\n if (closestSingleDistance && closestDistance) {\n return Math.min(closestSingleDistance, closestDistance);\n }\n return closestSingleDistance || closestDistance;\n }\n /**\n * When a point name is given and no x, search for the name in the existing\n * categories, or if categories aren't provided, search names or create a\n * new category (#2522).\n *\n * @private\n * @function Highcharts.Axis#nameToX\n *\n * @param {Highcharts.Point} point\n * The point to inspect.\n *\n * @return {number}\n * The X value that the point is given.\n */\n nameToX(point) {\n const explicitCategories = isArray(this.options.categories), names = explicitCategories ? this.categories : this.names;\n let nameX = point.options.x, x;\n point.series.requireSorting = false;\n if (!defined(nameX)) {\n nameX = this.options.uniqueNames && names ?\n (explicitCategories ?\n names.indexOf(point.name) :\n pick(names.keys[point.name], -1)) :\n point.series.autoIncrement();\n }\n if (nameX === -1) { // Not found in currenct categories\n if (!explicitCategories && names) {\n x = names.length;\n }\n }\n else {\n x = nameX;\n }\n // Write the last point's name to the names array\n if (typeof x !== 'undefined') {\n this.names[x] = point.name;\n // Backwards mapping is much faster than array searching (#7725)\n this.names.keys[point.name] = x;\n }\n else if (point.x) {\n x = point.x; // #17438\n }\n return x;\n }\n /**\n * When changes have been done to series data, update the axis.names.\n *\n * @private\n * @function Highcharts.Axis#updateNames\n */\n updateNames() {\n const axis = this, names = this.names, i = names.length;\n if (i > 0) {\n Object.keys(names.keys).forEach(function (key) {\n delete (names.keys)[key];\n });\n names.length = 0;\n this.minRange = this.userMinRange; // Reset\n (this.series || []).forEach(function (series) {\n // Reset incrementer (#5928)\n series.xIncrement = null;\n // When adding a series, points are not yet generated\n if (!series.points || series.isDirtyData) {\n // When we're updating the series with data that is longer\n // than it was, and cropThreshold is passed, we need to make\n // sure that the axis.max is increased _before_ running the\n // premature processData. Otherwise this early iteration of\n // processData will crop the points to axis.max, and the\n // names array will be too short (#5857).\n axis.max = Math.max(axis.max, series.xData.length - 1);\n series.processData();\n series.generatePoints();\n }\n series.data.forEach(function (point, i) {\n let x;\n if (point &&\n point.options &&\n typeof point.name !== 'undefined' // #9562\n ) {\n x = axis.nameToX(point);\n if (typeof x !== 'undefined' && x !== point.x) {\n point.x = x;\n series.xData[i] = x;\n }\n }\n });\n });\n }\n }\n /**\n * Update translation information.\n *\n * @private\n * @function Highcharts.Axis#setAxisTranslation\n *\n * @emits Highcharts.Axis#event:afterSetAxisTranslation\n */\n setAxisTranslation() {\n const axis = this, range = axis.max - axis.min, linkedParent = axis.linkedParent, hasCategories = !!axis.categories, isXAxis = axis.isXAxis;\n let pointRange = axis.axisPointRange || 0, closestPointRange, minPointOffset = 0, pointRangePadding = 0, ordinalCorrection, transA = axis.transA;\n // Adjust translation for padding. Y axis with categories need to go\n // through the same (#1784).\n if (isXAxis || hasCategories || pointRange) {\n // Get the closest points\n closestPointRange = axis.getClosest();\n if (linkedParent) {\n minPointOffset = linkedParent.minPointOffset;\n pointRangePadding = linkedParent.pointRangePadding;\n }\n else {\n axis.series.forEach(function (series) {\n const seriesPointRange = hasCategories ?\n 1 :\n (isXAxis ?\n pick(series.options.pointRange, closestPointRange, 0) :\n (axis.axisPointRange || 0)), // #2806\n pointPlacement = series.options.pointPlacement;\n pointRange = Math.max(pointRange, seriesPointRange);\n if (!axis.single || hasCategories) {\n // TODO: series should internally set x- and y-\n // pointPlacement to simplify this logic.\n const isPointPlacementAxis = series.is('xrange') ?\n !isXAxis :\n isXAxis;\n // minPointOffset is the value padding to the left of\n // the axis in order to make room for points with a\n // pointRange, typically columns. When the\n // pointPlacement option is 'between' or 'on', this\n // padding does not apply.\n minPointOffset = Math.max(minPointOffset, isPointPlacementAxis && isString(pointPlacement) ?\n 0 :\n seriesPointRange / 2);\n // Determine the total padding needed to the length of\n // the axis to make room for the pointRange. If the\n // series' pointPlacement is 'on', no padding is added.\n pointRangePadding = Math.max(pointRangePadding, isPointPlacementAxis && pointPlacement === 'on' ?\n 0 :\n seriesPointRange);\n }\n });\n }\n // Record minPointOffset and pointRangePadding\n ordinalCorrection = (axis.ordinal && axis.ordinal.slope && closestPointRange) ?\n axis.ordinal.slope / closestPointRange :\n 1; // #988, #1853\n axis.minPointOffset = minPointOffset =\n minPointOffset * ordinalCorrection;\n axis.pointRangePadding =\n pointRangePadding = pointRangePadding * ordinalCorrection;\n // pointRange means the width reserved for each point, like in a\n // column chart\n axis.pointRange = Math.min(pointRange, axis.single && hasCategories ? 1 : range);\n // closestPointRange means the closest distance between points. In\n // columns it is mostly equal to pointRange, but in lines pointRange\n // is 0 while closestPointRange is some other value\n if (isXAxis && closestPointRange) {\n axis.closestPointRange = closestPointRange;\n }\n }\n // Secondary values\n axis.translationSlope = axis.transA = transA =\n axis.staticScale ||\n axis.len / ((range + pointRangePadding) || 1);\n // Translation addend\n axis.transB = axis.horiz ? axis.left : axis.bottom;\n axis.minPixelPadding = transA * minPointOffset;\n fireEvent(this, 'afterSetAxisTranslation');\n }\n /**\n * @private\n * @function Highcharts.Axis#minFromRange\n */\n minFromRange() {\n const axis = this;\n return axis.max - axis.range;\n }\n /**\n * Set the tick positions to round values and optionally extend the extremes\n * to the nearest tick.\n *\n * @private\n * @function Highcharts.Axis#setTickInterval\n *\n * @param {boolean} secondPass\n * TO-DO: parameter description\n *\n * @emits Highcharts.Axis#event:foundExtremes\n */\n setTickInterval(secondPass) {\n const axis = this, chart = axis.chart, log = axis.logarithmic, options = axis.options, isXAxis = axis.isXAxis, isLinked = axis.isLinked, tickPixelIntervalOption = options.tickPixelInterval, categories = axis.categories, softThreshold = axis.softThreshold;\n let maxPadding = options.maxPadding, minPadding = options.minPadding, length, linkedParentExtremes, \n // Only non-negative tickInterval is valid, #12961\n tickIntervalOption = isNumber(options.tickInterval) && options.tickInterval >= 0 ?\n options.tickInterval : void 0, threshold = isNumber(axis.threshold) ? axis.threshold : null, thresholdMin, thresholdMax, hardMin, hardMax;\n if (!axis.dateTime && !categories && !isLinked) {\n this.getTickAmount();\n }\n // Min or max set either by zooming/setExtremes or initial options\n hardMin = pick(axis.userMin, options.min);\n hardMax = pick(axis.userMax, options.max);\n // Linked axis gets the extremes from the parent axis\n if (isLinked) {\n axis.linkedParent = chart[axis.coll][options.linkedTo];\n linkedParentExtremes = axis.linkedParent.getExtremes();\n axis.min = pick(linkedParentExtremes.min, linkedParentExtremes.dataMin);\n axis.max = pick(linkedParentExtremes.max, linkedParentExtremes.dataMax);\n if (options.type !== axis.linkedParent.options.type) {\n // Can't link axes of different type\n error(11, 1, chart);\n }\n // Initial min and max from the extreme data values\n }\n else {\n // Adjust to hard threshold\n if (softThreshold && defined(threshold)) {\n if (axis.dataMin >= threshold) {\n thresholdMin = threshold;\n minPadding = 0;\n }\n else if (axis.dataMax <= threshold) {\n thresholdMax = threshold;\n maxPadding = 0;\n }\n }\n axis.min = pick(hardMin, thresholdMin, axis.dataMin);\n axis.max = pick(hardMax, thresholdMax, axis.dataMax);\n }\n if (log) {\n if (axis.positiveValuesOnly &&\n !secondPass &&\n Math.min(axis.min, pick(axis.dataMin, axis.min)) <= 0) { // #978\n // Can't plot negative values on log axis\n error(10, 1, chart);\n }\n // The correctFloat cures #934, float errors on full tens. But it\n // was too aggressive for #4360 because of conversion back to lin,\n // therefore use precision 15.\n axis.min = correctFloat(log.log2lin(axis.min), 16);\n axis.max = correctFloat(log.log2lin(axis.max), 16);\n }\n // handle zoomed range\n if (axis.range && defined(axis.max)) {\n // #618, #6773:\n axis.userMin = axis.min = hardMin =\n Math.max(axis.dataMin, axis.minFromRange());\n axis.userMax = hardMax = axis.max;\n axis.range = null; // don't use it when running setExtremes\n }\n // Hook for Highcharts Stock Scroller.\n // Consider combining with beforePadding.\n fireEvent(axis, 'foundExtremes');\n // Hook for adjusting this.min and this.max. Used by bubble series.\n if (axis.beforePadding) {\n axis.beforePadding();\n }\n // Adjust min and max for the minimum range\n axis.adjustForMinRange();\n // Handle options for floor, ceiling, softMin and softMax (#6359)\n if (!isNumber(axis.userMin)) {\n if (isNumber(options.softMin) && options.softMin < axis.min) {\n axis.min = hardMin = options.softMin; // #6894\n }\n }\n if (!isNumber(axis.userMax)) {\n if (isNumber(options.softMax) && options.softMax > axis.max) {\n axis.max = hardMax = options.softMax; // #6894\n }\n }\n // Pad the values to get clear of the chart's edges. To avoid\n // tickInterval taking the padding into account, we do this after\n // computing tick interval (#1337).\n if (!categories &&\n !axis.axisPointRange &&\n !(axis.stacking && axis.stacking.usePercentage) &&\n !isLinked &&\n defined(axis.min) &&\n defined(axis.max)) {\n length = axis.max - axis.min;\n if (length) {\n if (!defined(hardMin) && minPadding) {\n axis.min -= length * minPadding;\n }\n if (!defined(hardMax) && maxPadding) {\n axis.max += length * maxPadding;\n }\n }\n }\n if (!isNumber(axis.userMin) && isNumber(options.floor)) {\n axis.min = Math.max(axis.min, options.floor);\n }\n if (!isNumber(axis.userMax) && isNumber(options.ceiling)) {\n axis.max = Math.min(axis.max, options.ceiling);\n }\n // When the threshold is soft, adjust the extreme value only if the data\n // extreme and the padded extreme land on either side of the threshold.\n // For example, a series of [0, 1, 2, 3] would make the yAxis add a tick\n // for -1 because of the default minPadding and startOnTick options.\n // This is prevented by the softThreshold option.\n if (softThreshold && defined(axis.dataMin)) {\n threshold = threshold || 0;\n if (!defined(hardMin) &&\n axis.min < threshold &&\n axis.dataMin >= threshold) {\n axis.min = axis.options.minRange ?\n Math.min(threshold, axis.max -\n axis.minRange) :\n threshold;\n }\n else if (!defined(hardMax) &&\n axis.max > threshold &&\n axis.dataMax <= threshold) {\n axis.max = axis.options.minRange ?\n Math.max(threshold, axis.min +\n axis.minRange) :\n threshold;\n }\n }\n // If min is bigger than highest, or if max less than lowest value, the\n // chart should not render points. (#14417)\n if (isNumber(axis.min) &&\n isNumber(axis.max) &&\n !this.chart.polar &&\n (axis.min > axis.max)) {\n if (defined(axis.options.min)) {\n axis.max = axis.min;\n }\n else if (defined(axis.options.max)) {\n axis.min = axis.max;\n }\n }\n // get tickInterval\n if (axis.min === axis.max ||\n typeof axis.min === 'undefined' ||\n typeof axis.max === 'undefined') {\n axis.tickInterval = 1;\n }\n else if (isLinked &&\n axis.linkedParent &&\n !tickIntervalOption &&\n tickPixelIntervalOption ===\n axis.linkedParent.options.tickPixelInterval) {\n axis.tickInterval = tickIntervalOption =\n axis.linkedParent.tickInterval;\n }\n else {\n axis.tickInterval = pick(tickIntervalOption, this.tickAmount ?\n ((axis.max - axis.min) /\n Math.max(this.tickAmount - 1, 1)) :\n void 0, \n // For categoried axis, 1 is default, for linear axis use\n // tickPix\n categories ?\n 1 :\n // don't let it be more than the data range\n (axis.max - axis.min) *\n tickPixelIntervalOption /\n Math.max(axis.len, tickPixelIntervalOption));\n }\n // Now we're finished detecting min and max, crop and group series data.\n // This is in turn needed in order to find tick positions in ordinal\n // axes.\n if (isXAxis && !secondPass) {\n const hasExtremesChanged = axis.min !==\n (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n // First process all series assigned to that axis.\n axis.series.forEach(function (series) {\n // Allows filtering out points outside the plot area.\n series.forceCrop = (series.forceCropping &&\n series.forceCropping());\n series.processData(hasExtremesChanged);\n });\n // Then apply grouping if needed. The hasExtremesChanged helps to\n // decide if the data grouping should be skipped in the further\n // calculations #16319.\n fireEvent(this, 'postProcessData', { hasExtremesChanged });\n }\n // set the translation factor used in translate function\n axis.setAxisTranslation();\n // hook for ordinal axes and radial axes\n fireEvent(this, 'initialAxisTranslation');\n // In column-like charts, don't cramp in more ticks than there are\n // points (#1943, #4184)\n if (axis.pointRange && !tickIntervalOption) {\n axis.tickInterval = Math.max(axis.pointRange, axis.tickInterval);\n }\n // Before normalizing the tick interval, handle minimum tick interval.\n // This applies only if tickInterval is not defined.\n const minTickInterval = pick(options.minTickInterval, \n // In datetime axes, don't go below the data interval, except when\n // there are scatter-like series involved (#13369).\n axis.dateTime &&\n !axis.series.some((s) => s.noSharedTooltip) ?\n axis.closestPointRange : 0);\n if (!tickIntervalOption && axis.tickInterval < minTickInterval) {\n axis.tickInterval = minTickInterval;\n }\n // For linear axes, normalize the interval\n if (!axis.dateTime && !axis.logarithmic && !tickIntervalOption) {\n axis.tickInterval = getNormalizedTickInterval(axis, axis.tickInterval);\n }\n // Prevent ticks from getting so close that we can't draw the labels\n if (!this.tickAmount) {\n axis.tickInterval = axis.unsquish();\n }\n this.setTickPositions();\n }\n /**\n * Now we have computed the normalized tickInterval, get the tick positions.\n *\n * @private\n * @function Highcharts.Axis#setTickPositions\n *\n * @emits Highcharts.Axis#event:afterSetTickPositions\n */\n setTickPositions() {\n const axis = this, options = this.options, tickPositionsOption = options.tickPositions, tickPositioner = options.tickPositioner, minorTickIntervalOption = this.getMinorTickInterval(), hasVerticalPanning = this.hasVerticalPanning(), isColorAxis = this.coll === 'colorAxis', startOnTick = ((isColorAxis || !hasVerticalPanning) && options.startOnTick), endOnTick = ((isColorAxis || !hasVerticalPanning) && options.endOnTick);\n let tickPositions = [], tickPositionerResult;\n // Set the tickmarkOffset\n this.tickmarkOffset = (this.categories &&\n options.tickmarkPlacement === 'between' &&\n this.tickInterval === 1) ? 0.5 : 0; // #3202\n // get minorTickInterval\n this.minorTickInterval =\n minorTickIntervalOption === 'auto' &&\n this.tickInterval ?\n this.tickInterval / options.minorTicksPerMajor :\n minorTickIntervalOption;\n // When there is only one point, or all points have the same value on\n // this axis, then min and max are equal and tickPositions.length is 0\n // or 1. In this case, add some padding in order to center the point,\n // but leave it with one tick. #1337.\n this.single =\n this.min === this.max &&\n defined(this.min) &&\n !this.tickAmount &&\n (\n // Data is on integer (#6563)\n parseInt(this.min, 10) === this.min ||\n // Between integers and decimals are not allowed (#6274)\n options.allowDecimals !== false);\n /**\n * Contains the current positions that are laid out on the axis. The\n * positions are numbers in terms of axis values. In a category axis\n * they are integers, in a datetime axis they are also integers, but\n * designating milliseconds.\n *\n * This property is read only - for modifying the tick positions, use\n * the `tickPositioner` callback or [axis.tickPositions(\n * https://api.highcharts.com/highcharts/xAxis.tickPositions) option\n * instead.\n *\n * @name Highcharts.Axis#tickPositions\n * @type {Highcharts.AxisTickPositionsArray|undefined}\n */\n if (tickPositionsOption) {\n // Find the tick positions. Work on a copy (#1565)\n tickPositions = tickPositionsOption.slice();\n }\n else if (isNumber(this.min) && isNumber(this.max)) {\n // Too many ticks (#6405). Create a friendly warning and provide two\n // ticks so at least we can show the data series.\n if ((!axis.ordinal || !axis.ordinal.positions) &&\n ((this.max - this.min) /\n this.tickInterval >\n Math.max(2 * this.len, 200))) {\n tickPositions = [this.min, this.max];\n error(19, false, this.chart);\n }\n else if (axis.dateTime) {\n tickPositions = axis.getTimeTicks(axis.dateTime.normalizeTimeTickInterval(this.tickInterval, options.units), this.min, this.max, options.startOfWeek, axis.ordinal && axis.ordinal.positions, this.closestPointRange, true);\n }\n else if (axis.logarithmic) {\n tickPositions = axis.logarithmic.getLogTickPositions(this.tickInterval, this.min, this.max);\n }\n else {\n const startingTickInterval = this.tickInterval;\n let adjustedTickInterval = startingTickInterval;\n while (adjustedTickInterval <= startingTickInterval * 2) {\n tickPositions = this.getLinearTickPositions(this.tickInterval, this.min, this.max);\n // If there are more tick positions than the set tickAmount,\n // increase the tickInterval and continue until it fits.\n // (#17100)\n if (this.tickAmount &&\n tickPositions.length > this.tickAmount) {\n this.tickInterval = getNormalizedTickInterval(this, adjustedTickInterval *= 1.1);\n }\n else {\n break;\n }\n }\n }\n // Too dense ticks, keep only the first and last (#4477)\n if (tickPositions.length > this.len) {\n tickPositions = [\n tickPositions[0],\n tickPositions[tickPositions.length - 1]\n ];\n // Reduce doubled value (#7339)\n if (tickPositions[0] === tickPositions[1]) {\n tickPositions.length = 1;\n }\n }\n // Run the tick positioner callback, that allows modifying auto tick\n // positions.\n if (tickPositioner) {\n // Make it available to the positioner\n this.tickPositions = tickPositions;\n tickPositionerResult = tickPositioner.apply(axis, [this.min, this.max]);\n if (tickPositionerResult) {\n tickPositions = tickPositionerResult;\n }\n }\n }\n this.tickPositions = tickPositions;\n // Reset min/max or remove extremes based on start/end on tick\n this.paddedTicks = tickPositions.slice(0); // Used for logarithmic minor\n this.trimTicks(tickPositions, startOnTick, endOnTick);\n if (!this.isLinked && isNumber(this.min) && isNumber(this.max)) {\n // Substract half a unit (#2619, #2846, #2515, #3390), but not in\n // case of multiple ticks (#6897)\n if (this.single &&\n tickPositions.length < 2 &&\n !this.categories &&\n !this.series.some((s) => (s.is('heatmap') && s.options.pointPlacement === 'between'))) {\n this.min -= 0.5;\n this.max += 0.5;\n }\n if (!tickPositionsOption && !tickPositionerResult) {\n this.adjustTickAmount();\n }\n }\n fireEvent(this, 'afterSetTickPositions');\n }\n /**\n * Handle startOnTick and endOnTick by either adapting to padding min/max or\n * rounded min/max. Also handle single data points.\n *\n * @private\n * @function Highcharts.Axis#trimTicks\n *\n * @param {Array} tickPositions\n * TO-DO: parameter description\n *\n * @param {boolean} [startOnTick]\n * TO-DO: parameter description\n *\n * @param {boolean} [endOnTick]\n * TO-DO: parameter description\n */\n trimTicks(tickPositions, startOnTick, endOnTick) {\n const roundedMin = tickPositions[0], roundedMax = tickPositions[tickPositions.length - 1], minPointOffset = (!this.isOrdinal && this.minPointOffset) || 0; // (#12716)\n fireEvent(this, 'trimTicks');\n if (!this.isLinked) {\n if (startOnTick && roundedMin !== -Infinity) { // #6502\n this.min = roundedMin;\n }\n else {\n while (this.min - minPointOffset > tickPositions[0]) {\n tickPositions.shift();\n }\n }\n if (endOnTick) {\n this.max = roundedMax;\n }\n else {\n while (this.max + minPointOffset <\n tickPositions[tickPositions.length - 1]) {\n tickPositions.pop();\n }\n }\n // If no tick are left, set one tick in the middle (#3195)\n if (tickPositions.length === 0 &&\n defined(roundedMin) &&\n !this.options.tickPositions) {\n tickPositions.push((roundedMax + roundedMin) / 2);\n }\n }\n }\n /**\n * Check if there are multiple axes in the same pane.\n *\n * @private\n * @function Highcharts.Axis#alignToOthers\n *\n * @return {boolean|undefined}\n * True if there are other axes.\n */\n alignToOthers() {\n const axis = this, alignedAxes = [this], options = axis.options, alignThresholds = (this.coll === 'yAxis' &&\n this.chart.options.chart.alignThresholds), thresholdAlignments = [];\n let hasOther;\n axis.thresholdAlignment = void 0;\n if ((\n // Only if alignTicks or alignThresholds is true\n (this.chart.options.chart.alignTicks !== false &&\n options.alignTicks) || (alignThresholds)) &&\n // Disabled when startOnTick or endOnTick are false (#7604)\n options.startOnTick !== false &&\n options.endOnTick !== false &&\n // Don't try to align ticks on a log axis, they are not evenly\n // spaced (#6021)\n !axis.logarithmic) {\n // Get a key identifying which pane the axis belongs to\n const getKey = (axis) => {\n const { horiz, options } = axis;\n return [\n horiz ? options.left : options.top,\n options.width,\n options.height,\n options.pane\n ].join(',');\n };\n const thisKey = getKey(this);\n this.chart[this.coll].forEach(function (otherAxis) {\n const { series } = otherAxis;\n if (\n // #4442\n series.length &&\n series.some((s) => s.visible) &&\n otherAxis !== axis &&\n getKey(otherAxis) === thisKey) {\n hasOther = true; // #4201\n alignedAxes.push(otherAxis);\n }\n });\n }\n if (hasOther && alignThresholds) {\n // Handle alignThresholds. The `thresholdAlignments` array keeps\n // records of where each axis in the group wants its threshold, from\n // 0 which is on `axis.min`, to 1 which is on `axis.max`.\n alignedAxes.forEach((otherAxis) => {\n const threshAlign = otherAxis.getThresholdAlignment(axis);\n if (isNumber(threshAlign)) {\n thresholdAlignments.push(threshAlign);\n }\n });\n // For each of the axes in the group, record the average\n // `thresholdAlignment`.\n const thresholdAlignment = thresholdAlignments.length > 1 ?\n thresholdAlignments.reduce((sum, n) => (sum += n), 0) / thresholdAlignments.length :\n void 0;\n alignedAxes.forEach((axis) => {\n axis.thresholdAlignment = thresholdAlignment;\n });\n }\n return hasOther;\n }\n /**\n * Where the axis wants its threshold, from 0 which is on `axis.min`, to 1 which\n * is on `axis.max`.\n *\n * @private\n * @function Highcharts.Axis#getThresholdAlignment\n */\n getThresholdAlignment(callerAxis) {\n if (!isNumber(this.dataMin) ||\n (this !== callerAxis &&\n this.series.some((s) => (s.isDirty || s.isDirtyData)))) {\n this.getSeriesExtremes();\n }\n if (isNumber(this.threshold)) {\n let thresholdAlignment = clamp(((this.threshold - (this.dataMin || 0)) /\n ((this.dataMax || 0) - (this.dataMin || 0))), 0, 1);\n if (this.options.reversed) {\n thresholdAlignment = 1 - thresholdAlignment;\n }\n return thresholdAlignment;\n }\n }\n /**\n * Find the max ticks of either the x and y axis collection, and record it\n * in `this.tickAmount`.\n *\n * @private\n * @function Highcharts.Axis#getTickAmount\n */\n getTickAmount() {\n const axis = this, options = this.options, tickPixelInterval = options.tickPixelInterval;\n let tickAmount = options.tickAmount;\n if (!defined(options.tickInterval) &&\n !tickAmount &&\n this.len < tickPixelInterval &&\n !this.isRadial &&\n !axis.logarithmic &&\n options.startOnTick &&\n options.endOnTick) {\n tickAmount = 2;\n }\n if (!tickAmount && this.alignToOthers()) {\n // Add 1 because 4 tick intervals require 5 ticks (including first\n // and last)\n tickAmount = Math.ceil(this.len / tickPixelInterval) + 1;\n }\n // For tick amounts of 2 and 3, compute five ticks and remove the\n // intermediate ones. This prevents the axis from adding ticks that are\n // too far away from the data extremes.\n if (tickAmount < 4) {\n this.finalTickAmt = tickAmount;\n tickAmount = 5;\n }\n this.tickAmount = tickAmount;\n }\n /**\n * When using multiple axes, adjust the number of ticks to match the highest\n * number of ticks in that group.\n *\n * @private\n * @function Highcharts.Axis#adjustTickAmount\n */\n adjustTickAmount() {\n const axis = this, { finalTickAmt, max, min, options, tickPositions, tickAmount, thresholdAlignment } = axis, currentTickAmount = tickPositions && tickPositions.length, threshold = pick(axis.threshold, axis.softThreshold ? 0 : null);\n let len, i, tickInterval = axis.tickInterval, thresholdTickIndex;\n const \n // Extend the tickPositions by appending a position\n append = () => tickPositions.push(correctFloat(tickPositions[tickPositions.length - 1] +\n tickInterval)), \n // Extend the tickPositions by prepending a position\n prepend = () => tickPositions.unshift(correctFloat(tickPositions[0] - tickInterval));\n // If `thresholdAlignment` is a number, it means the `alignThresholds`\n // option is true. The `thresholdAlignment` is a scalar value between 0\n // and 1 for where the threshold should be relative to `axis.min` and\n // `axis.max`. Now that we know the tick amount, convert this to the\n // tick index. Unless `thresholdAlignment` is exactly 0 or 1, avoid the\n // first or last tick because that would lead to series being clipped.\n if (isNumber(thresholdAlignment)) {\n thresholdTickIndex = thresholdAlignment < 0.5 ?\n Math.ceil(thresholdAlignment * (tickAmount - 1)) :\n Math.floor(thresholdAlignment * (tickAmount - 1));\n if (options.reversed) {\n thresholdTickIndex = tickAmount - 1 - thresholdTickIndex;\n }\n }\n if (axis.hasData() && isNumber(min) && isNumber(max)) { // #14769\n // Adjust extremes and translation to the modified tick positions\n const adjustExtremes = () => {\n axis.transA *= (currentTickAmount - 1) / (tickAmount - 1);\n // Do not crop when ticks are not extremes (#9841)\n axis.min = options.startOnTick ?\n tickPositions[0] :\n Math.min(min, tickPositions[0]);\n axis.max = options.endOnTick ?\n tickPositions[tickPositions.length - 1] :\n Math.max(max, tickPositions[tickPositions.length - 1]);\n };\n // When the axis is subject to the alignThresholds option. Use\n // axis.threshold because the local threshold includes the\n // `softThreshold`.\n if (isNumber(thresholdTickIndex) && isNumber(axis.threshold)) {\n // Throw away the previously computed tickPositions and start\n // from scratch with only the threshold itself, then add ticks\n // below the threshold first, then fill up above the threshold.\n // If we are not able to fill up to axis.max, double the\n // tickInterval and run again.\n while (tickPositions[thresholdTickIndex] !== threshold ||\n tickPositions.length !== tickAmount ||\n tickPositions[0] > min ||\n tickPositions[tickPositions.length - 1] < max) {\n tickPositions.length = 0;\n tickPositions.push(axis.threshold);\n while (tickPositions.length < tickAmount) {\n if (\n // Start by prepending positions until the threshold\n // is at the required index...\n tickPositions[thresholdTickIndex] === void 0 ||\n tickPositions[thresholdTickIndex] > axis.threshold) {\n prepend();\n }\n else {\n // ... then append positions until we have the\n // required length\n append();\n }\n }\n // Safety vent\n if (tickInterval > axis.tickInterval * 8) {\n break;\n }\n tickInterval *= 2;\n }\n adjustExtremes();\n }\n else if (currentTickAmount < tickAmount) {\n while (tickPositions.length < tickAmount) {\n // Extend evenly for both sides unless we're on the\n // threshold (#3965)\n if (tickPositions.length % 2 || min === threshold) {\n append();\n }\n else {\n prepend();\n }\n }\n adjustExtremes();\n }\n // The finalTickAmt property is set in getTickAmount\n if (defined(finalTickAmt)) {\n i = len = tickPositions.length;\n while (i--) {\n if (\n // Remove every other tick\n (finalTickAmt === 3 && i % 2 === 1) ||\n // Remove all but first and last\n (finalTickAmt <= 2 && i > 0 && i < len - 1)) {\n tickPositions.splice(i, 1);\n }\n }\n axis.finalTickAmt = void 0;\n }\n }\n }\n /**\n * Set the scale based on data min and max, user set min and max or options.\n *\n * @private\n * @function Highcharts.Axis#setScale\n *\n * @emits Highcharts.Axis#event:afterSetScale\n */\n setScale() {\n const axis = this;\n let isDirtyData = false, isXAxisDirty = false;\n axis.series.forEach(function (series) {\n isDirtyData = isDirtyData || series.isDirtyData || series.isDirty;\n // When x axis is dirty, we need new data extremes for y as\n // well:\n isXAxisDirty = (isXAxisDirty ||\n (series.xAxis && series.xAxis.isDirty) ||\n false);\n });\n // set the new axisLength\n axis.setAxisSize();\n const isDirtyAxisLength = axis.len !== (axis.old && axis.old.len);\n // do we really need to go through all this?\n if (isDirtyAxisLength ||\n isDirtyData ||\n isXAxisDirty ||\n axis.isLinked ||\n axis.forceRedraw ||\n axis.userMin !== (axis.old && axis.old.userMin) ||\n axis.userMax !== (axis.old && axis.old.userMax) ||\n axis.alignToOthers()) {\n if (axis.stacking) {\n axis.stacking.resetStacks();\n axis.stacking.buildStacks();\n }\n axis.forceRedraw = false;\n // #18066 delete minRange property to ensure that it will be\n // calculated again after dirty data in series\n if (!axis.userMinRange) {\n axis.minRange = void 0;\n }\n // get data extremes if needed\n axis.getSeriesExtremes();\n // get fixed positions based on tickInterval\n axis.setTickInterval();\n // Mark as dirty if it is not already set to dirty and extremes have\n // changed. #595.\n if (!axis.isDirty) {\n axis.isDirty =\n isDirtyAxisLength ||\n axis.min !== (axis.old && axis.old.min) ||\n axis.max !== (axis.old && axis.old.max);\n }\n }\n else if (axis.stacking) {\n axis.stacking.cleanStacks();\n }\n // Recalculate panning state object, when the data\n // has changed. It is required when vertical panning is enabled.\n if (isDirtyData && axis.panningState) {\n axis.panningState.isDirty = true;\n }\n fireEvent(this, 'afterSetScale');\n }\n /**\n * Set the minimum and maximum of the axes after render time. If the\n * `startOnTick` and `endOnTick` options are true, the minimum and maximum\n * values are rounded off to the nearest tick. To prevent this, these\n * options can be set to false before calling setExtremes. Also, setExtremes\n * will not allow a range lower than the `minRange` option, which by default\n * is the range of five points.\n *\n * @sample highcharts/members/axis-setextremes/\n * Set extremes from a button\n * @sample highcharts/members/axis-setextremes-datetime/\n * Set extremes on a datetime axis\n * @sample highcharts/members/axis-setextremes-off-ticks/\n * Set extremes off ticks\n * @sample stock/members/axis-setextremes/\n * Set extremes in Highcharts Stock\n *\n * @function Highcharts.Axis#setExtremes\n *\n * @param {number} [newMin]\n * The new minimum value.\n *\n * @param {number} [newMax]\n * The new maximum value.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}\n *\n * @param {boolean|Partial} [animation=true]\n * Enable or modify animations.\n *\n * @param {*} [eventArguments]\n * Arguments to be accessed in event handler.\n *\n * @emits Highcharts.Axis#event:setExtremes\n */\n setExtremes(newMin, newMax, redraw, animation, eventArguments) {\n const axis = this, chart = axis.chart;\n redraw = pick(redraw, true); // defaults to true\n axis.series.forEach(function (serie) {\n delete serie.kdTree;\n });\n // Extend the arguments with min and max\n eventArguments = extend(eventArguments, {\n min: newMin,\n max: newMax\n });\n // Fire the event\n fireEvent(axis, 'setExtremes', eventArguments, function () {\n axis.userMin = newMin;\n axis.userMax = newMax;\n axis.eventArgs = eventArguments;\n if (redraw) {\n chart.redraw(animation);\n }\n });\n }\n /**\n * Overridable method for zooming chart. Pulled out in a separate method to\n * allow overriding in stock charts.\n *\n * @private\n * @function Highcharts.Axis#zoom\n */\n zoom(newMin, newMax) {\n const axis = this, dataMin = this.dataMin, dataMax = this.dataMax, options = this.options, min = Math.min(dataMin, pick(options.min, dataMin)), max = Math.max(dataMax, pick(options.max, dataMax)), evt = {\n newMin: newMin,\n newMax: newMax\n };\n fireEvent(this, 'zoom', evt, function (e) {\n // Use e.newMin and e.newMax - event handlers may have altered them\n let newMin = e.newMin, newMax = e.newMax;\n if (newMin !== axis.min || newMax !== axis.max) { // #5790\n // Prevent pinch zooming out of range. Check for defined is for\n // #1946. #1734.\n if (!axis.allowZoomOutside) {\n // #6014, sometimes newMax will be smaller than min (or\n // newMin will be larger than max).\n if (defined(dataMin)) {\n if (newMin < min) {\n newMin = min;\n }\n if (newMin > max) {\n newMin = max;\n }\n }\n if (defined(dataMax)) {\n if (newMax < min) {\n newMax = min;\n }\n if (newMax > max) {\n newMax = max;\n }\n }\n }\n // In full view, displaying the reset zoom button is not\n // required\n axis.displayBtn = (typeof newMin !== 'undefined' ||\n typeof newMax !== 'undefined');\n // Do it\n axis.setExtremes(newMin, newMax, false, void 0, { trigger: 'zoom' });\n }\n e.zoomed = true;\n });\n return evt.zoomed;\n }\n /**\n * Update the axis metrics.\n *\n * @private\n * @function Highcharts.Axis#setAxisSize\n */\n setAxisSize() {\n const chart = this.chart, options = this.options, \n // [top, right, bottom, left]\n offsets = options.offsets || [0, 0, 0, 0], horiz = this.horiz, \n // Check for percentage based input values. Rounding fixes problems\n // with column overflow and plot line filtering (#4898, #4899)\n width = this.width = Math.round(relativeLength(pick(options.width, chart.plotWidth - offsets[3] + offsets[1]), chart.plotWidth)), height = this.height = Math.round(relativeLength(pick(options.height, chart.plotHeight - offsets[0] + offsets[2]), chart.plotHeight)), top = this.top = Math.round(relativeLength(pick(options.top, chart.plotTop + offsets[0]), chart.plotHeight, chart.plotTop)), left = this.left = Math.round(relativeLength(pick(options.left, chart.plotLeft + offsets[3]), chart.plotWidth, chart.plotLeft));\n // Expose basic values to use in Series object and navigator\n this.bottom = chart.chartHeight - height - top;\n this.right = chart.chartWidth - width - left;\n // Direction agnostic properties\n this.len = Math.max(horiz ? width : height, 0); // Math.max fixes #905\n this.pos = horiz ? left : top; // distance from SVG origin\n }\n /**\n * Get the current extremes for the axis.\n *\n * @sample highcharts/members/axis-getextremes/\n * Report extremes by click on a button\n *\n * @function Highcharts.Axis#getExtremes\n *\n * @return {Highcharts.ExtremesObject}\n * An object containing extremes information.\n */\n getExtremes() {\n const axis = this, log = axis.logarithmic;\n return {\n min: log ?\n correctFloat(log.lin2log(axis.min)) :\n axis.min,\n max: log ?\n correctFloat(log.lin2log(axis.max)) :\n axis.max,\n dataMin: axis.dataMin,\n dataMax: axis.dataMax,\n userMin: axis.userMin,\n userMax: axis.userMax\n };\n }\n /**\n * Get the zero plane either based on zero or on the min or max value.\n * Used in bar and area plots.\n *\n * @function Highcharts.Axis#getThreshold\n *\n * @param {number} threshold\n * The threshold in axis values.\n *\n * @return {number}\n * The translated threshold position in terms of pixels, and corrected to\n * stay within the axis bounds.\n */\n getThreshold(threshold) {\n const axis = this, log = axis.logarithmic, realMin = log ? log.lin2log(axis.min) : axis.min, realMax = log ? log.lin2log(axis.max) : axis.max;\n if (threshold === null || threshold === -Infinity) {\n threshold = realMin;\n }\n else if (threshold === Infinity) {\n threshold = realMax;\n }\n else if (realMin > threshold) {\n threshold = realMin;\n }\n else if (realMax < threshold) {\n threshold = realMax;\n }\n return axis.translate(threshold, 0, 1, 0, 1);\n }\n /**\n * Compute auto alignment for the axis label based on which side the axis is\n * on and the given rotation for the label.\n *\n * @private\n * @function Highcharts.Axis#autoLabelAlign\n *\n * @param {number} rotation\n * The rotation in degrees as set by either the `rotation` or `autoRotation`\n * options.\n *\n * @return {Highcharts.AlignValue}\n * Can be `\"center\"`, `\"left\"` or `\"right\"`.\n */\n autoLabelAlign(rotation) {\n const angle = (pick(rotation, 0) - (this.side * 90) + 720) % 360, evt = { align: 'center' };\n fireEvent(this, 'autoLabelAlign', evt, function (e) {\n if (angle > 15 && angle < 165) {\n e.align = 'right';\n }\n else if (angle > 195 && angle < 345) {\n e.align = 'left';\n }\n });\n return evt.align;\n }\n /**\n * Get the tick length and width for the axis based on axis options.\n *\n * @private\n * @function Highcharts.Axis#tickSize\n *\n * @param {string} [prefix]\n * 'tick' or 'minorTick'\n *\n * @return {Array|undefined}\n * An array of tickLength and tickWidth\n */\n tickSize(prefix) {\n const options = this.options, tickWidth = pick(options[prefix === 'tick' ? 'tickWidth' : 'minorTickWidth'], \n // Default to 1 on linear and datetime X axes\n prefix === 'tick' && this.isXAxis && !this.categories ? 1 : 0);\n let tickLength = options[prefix === 'tick' ? 'tickLength' : 'minorTickLength'], tickSize;\n if (tickWidth && tickLength) {\n // Negate the length\n if (options[prefix + 'Position'] === 'inside') {\n tickLength = -tickLength;\n }\n tickSize = [tickLength, tickWidth];\n }\n const e = { tickSize };\n fireEvent(this, 'afterTickSize', e);\n return e.tickSize;\n }\n /**\n * Return the size of the labels.\n *\n * @private\n * @function Highcharts.Axis#labelMetrics\n */\n labelMetrics() {\n const renderer = this.chart.renderer, ticks = this.ticks, tick = ticks[Object.keys(ticks)[0]] || {};\n return this.chart.renderer.fontMetrics(tick.label ||\n tick.movedLabel ||\n renderer.box);\n }\n /**\n * Prevent the ticks from getting so close we can't draw the labels. On a\n * horizontal axis, this is handled by rotating the labels, removing ticks\n * and adding ellipsis. On a vertical axis remove ticks and add ellipsis.\n *\n * @private\n * @function Highcharts.Axis#unsquish\n */\n unsquish() {\n const labelOptions = this.options.labels, horiz = this.horiz, tickInterval = this.tickInterval, slotSize = this.len / (((this.categories ? 1 : 0) +\n this.max -\n this.min) /\n tickInterval), rotationOption = labelOptions.rotation, \n // We don't know the actual rendered line height at this point, but\n // it defaults to 0.75em\n lineHeight = this.labelMetrics().h * 0.75, range = Math.max(this.max - this.min, 0), \n // Return the multiple of tickInterval that is needed to avoid\n // collision\n getStep = function (spaceNeeded) {\n let step = spaceNeeded / (slotSize || 1);\n step = step > 1 ? Math.ceil(step) : 1;\n // Guard for very small or negative angles (#9835)\n if (step * tickInterval > range &&\n spaceNeeded !== Infinity &&\n slotSize !== Infinity &&\n range) {\n step = Math.ceil(range / tickInterval);\n }\n return correctFloat(step * tickInterval);\n };\n let newTickInterval = tickInterval, rotation, bestScore = Number.MAX_VALUE, autoRotation;\n if (horiz) {\n if (!labelOptions.staggerLines) {\n if (isNumber(rotationOption)) {\n autoRotation = [rotationOption];\n }\n else if (slotSize < labelOptions.autoRotationLimit) {\n autoRotation = labelOptions.autoRotation;\n }\n }\n if (autoRotation) {\n let step, score;\n // Loop over the given autoRotation options, and determine which\n // gives the best score. The best score is that with the lowest\n // number of steps and a rotation closest to horizontal.\n for (const rot of autoRotation) {\n if (rot === rotationOption ||\n (rot && rot >= -90 && rot <= 90)) { // #3891\n step = getStep(Math.abs(lineHeight / Math.sin(deg2rad * rot)));\n score = step + Math.abs(rot / 360);\n if (score < bestScore) {\n bestScore = score;\n rotation = rot;\n newTickInterval = step;\n }\n }\n }\n }\n }\n else { // #4411\n newTickInterval = getStep(lineHeight);\n }\n this.autoRotation = autoRotation;\n this.labelRotation = pick(rotation, isNumber(rotationOption) ? rotationOption : 0);\n return labelOptions.step ? tickInterval : newTickInterval;\n }\n /**\n * Get the general slot width for labels/categories on this axis. This may\n * change between the pre-render (from Axis.getOffset) and the final tick\n * rendering and placement.\n *\n * @private\n * @function Highcharts.Axis#getSlotWidth\n *\n * @param {Highcharts.Tick} [tick] Optionally, calculate the slot width\n * basing on tick label. It is used in highcharts-3d module, where the slots\n * has different widths depending on perspective angles.\n *\n * @return {number}\n * The pixel width allocated to each axis label.\n */\n getSlotWidth(tick) {\n // #5086, #1580, #1931\n const chart = this.chart, horiz = this.horiz, labelOptions = this.options.labels, slotCount = Math.max(this.tickPositions.length - (this.categories ? 0 : 1), 1), marginLeft = chart.margin[3];\n // Used by grid axis\n if (tick && isNumber(tick.slotWidth)) { // #13221, can be 0\n return tick.slotWidth;\n }\n if (horiz && labelOptions.step < 2) {\n if (labelOptions.rotation) { // #4415\n return 0;\n }\n return ((this.staggerLines || 1) * this.len) / slotCount;\n }\n if (!horiz) {\n // #7028\n const cssWidth = labelOptions.style.width;\n if (cssWidth !== void 0) {\n return parseInt(String(cssWidth), 10);\n }\n if (marginLeft) {\n return marginLeft - chart.spacing[3];\n }\n }\n // Last resort, a fraction of the available size\n return chart.chartWidth * 0.33;\n }\n /**\n * Render the axis labels and determine whether ellipsis or rotation need to\n * be applied.\n *\n * @private\n * @function Highcharts.Axis#renderUnsquish\n */\n renderUnsquish() {\n const chart = this.chart, renderer = chart.renderer, tickPositions = this.tickPositions, ticks = this.ticks, labelOptions = this.options.labels, labelStyleOptions = labelOptions.style, horiz = this.horiz, slotWidth = this.getSlotWidth(), innerWidth = Math.max(1, Math.round(slotWidth - 2 * labelOptions.padding)), attr = {}, labelMetrics = this.labelMetrics(), textOverflowOption = labelStyleOptions.textOverflow;\n let commonWidth, commonTextOverflow, maxLabelLength = 0, label, i, pos;\n // Set rotation option unless it is \"auto\", like in gauges\n if (!isString(labelOptions.rotation)) {\n // #4443\n attr.rotation = labelOptions.rotation || 0;\n }\n // Get the longest label length\n tickPositions.forEach(function (tickPosition) {\n const tick = ticks[tickPosition];\n // Replace label - sorting animation\n if (tick.movedLabel) {\n tick.replaceMovedLabel();\n }\n if (tick &&\n tick.label &&\n tick.label.textPxLength > maxLabelLength) {\n maxLabelLength = tick.label.textPxLength;\n }\n });\n this.maxLabelLength = maxLabelLength;\n // Handle auto rotation on horizontal axis\n if (this.autoRotation) {\n // Apply rotation only if the label is too wide for the slot, and\n // the label is wider than its height.\n if (maxLabelLength > innerWidth &&\n maxLabelLength > labelMetrics.h) {\n attr.rotation = this.labelRotation;\n }\n else {\n this.labelRotation = 0;\n }\n // Handle word-wrap or ellipsis on vertical axis\n }\n else if (slotWidth) {\n // For word-wrap or ellipsis\n commonWidth = innerWidth;\n if (!textOverflowOption) {\n commonTextOverflow = 'clip';\n // On vertical axis, only allow word wrap if there is room\n // for more lines.\n i = tickPositions.length;\n while (!horiz && i--) {\n pos = tickPositions[i];\n label = ticks[pos].label;\n if (label) {\n // Reset ellipsis in order to get the correct\n // bounding box (#4070)\n if (label.styles &&\n label.styles.textOverflow === 'ellipsis') {\n label.css({ textOverflow: 'clip' });\n // Set the correct width in order to read\n // the bounding box height (#4678, #5034)\n }\n else if (label.textPxLength > slotWidth) {\n label.css({ width: slotWidth + 'px' });\n }\n if (label.getBBox().height > (this.len / tickPositions.length -\n (labelMetrics.h - labelMetrics.f))) {\n label.specificTextOverflow = 'ellipsis';\n }\n }\n }\n }\n }\n // Add ellipsis if the label length is significantly longer than ideal\n if (attr.rotation) {\n commonWidth = (maxLabelLength > chart.chartHeight * 0.5 ?\n chart.chartHeight * 0.33 :\n maxLabelLength);\n if (!textOverflowOption) {\n commonTextOverflow = 'ellipsis';\n }\n }\n // Set the explicit or automatic label alignment\n this.labelAlign = labelOptions.align ||\n this.autoLabelAlign(this.labelRotation);\n if (this.labelAlign) {\n attr.align = this.labelAlign;\n }\n // Apply general and specific CSS\n tickPositions.forEach(function (pos) {\n const tick = ticks[pos], label = tick && tick.label, widthOption = labelStyleOptions.width, css = {};\n if (label) {\n // This needs to go before the CSS in old IE (#4502)\n label.attr(attr);\n if (tick.shortenLabel) {\n tick.shortenLabel();\n }\n else if (commonWidth &&\n !widthOption &&\n // Setting width in this case messes with the bounding box\n // (#7975)\n labelStyleOptions.whiteSpace !== 'nowrap' &&\n (\n // Speed optimizing, #7656\n commonWidth < label.textPxLength ||\n // Resetting CSS, #4928\n label.element.tagName === 'SPAN')) {\n css.width = commonWidth + 'px';\n if (!textOverflowOption) {\n css.textOverflow = (label.specificTextOverflow ||\n commonTextOverflow);\n }\n label.css(css);\n // Reset previously shortened label (#8210)\n }\n else if (label.styles &&\n label.styles.width &&\n !css.width &&\n !widthOption) {\n label.css({ width: null });\n }\n delete label.specificTextOverflow;\n tick.rotation = attr.rotation;\n }\n }, this);\n // Note: Why is this not part of getLabelPosition?\n this.tickRotCorr = renderer.rotCorr(labelMetrics.b, this.labelRotation || 0, this.side !== 0);\n }\n /**\n * Return true if the axis has associated data.\n *\n * @function Highcharts.Axis#hasData\n *\n * @return {boolean}\n * True if the axis has associated visible series and those series have\n * either valid data points or explicit `min` and `max` settings.\n */\n hasData() {\n return this.series.some(function (s) {\n return s.hasData();\n }) ||\n (this.options.showEmpty &&\n defined(this.min) &&\n defined(this.max));\n }\n /**\n * Adds the title defined in axis.options.title.\n *\n * @function Highcharts.Axis#addTitle\n *\n * @param {boolean} [display]\n * Whether or not to display the title.\n */\n addTitle(display) {\n const axis = this, renderer = axis.chart.renderer, horiz = axis.horiz, opposite = axis.opposite, options = axis.options, axisTitleOptions = options.title, styledMode = axis.chart.styledMode;\n let textAlign;\n if (!axis.axisTitle) {\n textAlign = axisTitleOptions.textAlign;\n if (!textAlign) {\n textAlign = (horiz ? {\n low: 'left',\n middle: 'center',\n high: 'right'\n } : {\n low: opposite ? 'right' : 'left',\n middle: 'center',\n high: opposite ? 'left' : 'right'\n })[axisTitleOptions.align];\n }\n axis.axisTitle = renderer\n .text(axisTitleOptions.text || '', 0, 0, axisTitleOptions.useHTML)\n .attr({\n zIndex: 7,\n rotation: axisTitleOptions.rotation,\n align: textAlign\n })\n .addClass('highcharts-axis-title');\n // #7814, don't mutate style option\n if (!styledMode) {\n axis.axisTitle.css(merge(axisTitleOptions.style));\n }\n axis.axisTitle.add(axis.axisGroup);\n axis.axisTitle.isNew = true;\n }\n // Max width defaults to the length of the axis\n if (!styledMode &&\n !axisTitleOptions.style.width &&\n !axis.isRadial) {\n axis.axisTitle.css({\n width: axis.len + 'px'\n });\n }\n // hide or show the title depending on whether showEmpty is set\n axis.axisTitle[display ? 'show' : 'hide'](display);\n }\n /**\n * Generates a tick for initial positioning.\n *\n * @private\n * @function Highcharts.Axis#generateTick\n *\n * @param {number} pos\n * The tick position in axis values.\n *\n * @param {number} [i]\n * The index of the tick in {@link Axis.tickPositions}.\n */\n generateTick(pos) {\n const axis = this, ticks = axis.ticks;\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n else {\n ticks[pos].addLabel(); // update labels depending on tick interval\n }\n }\n /**\n * Render the tick labels to a preliminary position to get their sizes\n *\n * @private\n * @function Highcharts.Axis#getOffset\n *\n * @emits Highcharts.Axis#event:afterGetOffset\n */\n getOffset() {\n const axis = this, { chart, horiz, options, side, ticks, tickPositions, coll, axisParent // Used in color axis\n } = axis, renderer = chart.renderer, invertedSide = (chart.inverted && !axis.isZAxis ?\n [1, 0, 3, 2][side] :\n side), hasData = axis.hasData(), axisTitleOptions = options.title, labelOptions = options.labels, hasCrossing = isNumber(options.crossing), axisOffset = chart.axisOffset, clipOffset = chart.clipOffset, directionFactor = [-1, 1, 1, -1][side], className = options.className;\n let showAxis, titleOffset = 0, titleOffsetOption, titleMargin = 0, labelOffset = 0, // reset\n labelOffsetPadded, lineHeightCorrection;\n // For reuse in Axis.render\n axis.showAxis = showAxis = hasData || options.showEmpty;\n // Set/reset staggerLines\n axis.staggerLines = (axis.horiz && labelOptions.staggerLines) || void 0;\n // Create the axisGroup and gridGroup elements on first iteration\n if (!axis.axisGroup) {\n const createGroup = (name, suffix, zIndex) => renderer.g(name)\n .attr({ zIndex })\n .addClass(`highcharts-${coll.toLowerCase()}${suffix} ` +\n (this.isRadial ? `highcharts-radial-axis${suffix} ` : '') +\n (className || ''))\n .add(axisParent);\n axis.gridGroup = createGroup('grid', '-grid', options.gridZIndex);\n axis.axisGroup = createGroup('axis', '', options.zIndex);\n axis.labelGroup = createGroup('axis-labels', '-labels', labelOptions.zIndex);\n }\n if (hasData || axis.isLinked) {\n // Generate ticks\n tickPositions.forEach(function (pos) {\n // i is not used here, but may be used in overrides\n axis.generateTick(pos);\n });\n axis.renderUnsquish();\n // Left side must be align: right and right side must\n // have align: left for labels\n axis.reserveSpaceDefault = (side === 0 ||\n side === 2 ||\n { 1: 'left', 3: 'right' }[side] === axis.labelAlign);\n if (pick(labelOptions.reserveSpace, hasCrossing ? false : null, axis.labelAlign === 'center' ? true : null, axis.reserveSpaceDefault)) {\n tickPositions.forEach(function (pos) {\n // get the highest offset\n labelOffset = Math.max(ticks[pos].getLabelSize(), labelOffset);\n });\n }\n if (axis.staggerLines) {\n labelOffset *= axis.staggerLines;\n }\n axis.labelOffset = labelOffset * (axis.opposite ? -1 : 1);\n }\n else { // doesn't have data\n objectEach(ticks, function (tick, n) {\n tick.destroy();\n delete ticks[n];\n });\n }\n if (axisTitleOptions &&\n axisTitleOptions.text &&\n axisTitleOptions.enabled !== false) {\n axis.addTitle(showAxis);\n if (showAxis &&\n !hasCrossing &&\n axisTitleOptions.reserveSpace !== false) {\n axis.titleOffset = titleOffset =\n axis.axisTitle.getBBox()[horiz ? 'height' : 'width'];\n titleOffsetOption = axisTitleOptions.offset;\n titleMargin = defined(titleOffsetOption) ?\n 0 :\n pick(axisTitleOptions.margin, horiz ? 5 : 10);\n }\n }\n // Render the axis line\n axis.renderLine();\n // handle automatic or user set offset\n axis.offset = directionFactor * pick(options.offset, axisOffset[side] ? axisOffset[side] + (options.margin || 0) : 0);\n axis.tickRotCorr = axis.tickRotCorr || { x: 0, y: 0 }; // polar\n if (side === 0) {\n lineHeightCorrection = -axis.labelMetrics().h;\n }\n else if (side === 2) {\n lineHeightCorrection = axis.tickRotCorr.y;\n }\n else {\n lineHeightCorrection = 0;\n }\n // Find the padded label offset\n labelOffsetPadded = Math.abs(labelOffset) + titleMargin;\n if (labelOffset) {\n labelOffsetPadded -= lineHeightCorrection;\n labelOffsetPadded += directionFactor * (horiz ?\n pick(labelOptions.y, axis.tickRotCorr.y +\n directionFactor * labelOptions.distance) :\n pick(labelOptions.x, directionFactor * labelOptions.distance));\n }\n axis.axisTitleMargin = pick(titleOffsetOption, labelOffsetPadded);\n if (axis.getMaxLabelDimensions) {\n axis.maxLabelDimensions = axis.getMaxLabelDimensions(ticks, tickPositions);\n }\n // Due to GridAxis.tickSize, tickSize should be calculated after ticks\n // has rendered.\n if (coll !== 'colorAxis') {\n const tickSize = this.tickSize('tick');\n axisOffset[side] = Math.max(axisOffset[side], (axis.axisTitleMargin || 0) + titleOffset +\n directionFactor * axis.offset, labelOffsetPadded, // #3027\n tickPositions && tickPositions.length && tickSize ?\n tickSize[0] + directionFactor * axis.offset :\n 0 // #4866\n );\n // Decide the clipping needed to keep the graph inside\n // the plot area and axis lines\n const clip = !axis.axisLine || options.offset ?\n 0 :\n // #4308, #4371:\n Math.floor(axis.axisLine.strokeWidth() / 2) * 2;\n clipOffset[invertedSide] =\n Math.max(clipOffset[invertedSide], clip);\n }\n fireEvent(this, 'afterGetOffset');\n }\n /**\n * Internal function to get the path for the axis line. Extended for polar\n * charts.\n *\n * @function Highcharts.Axis#getLinePath\n *\n * @param {number} lineWidth\n * The line width in pixels.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n getLinePath(lineWidth) {\n const chart = this.chart, opposite = this.opposite, offset = this.offset, horiz = this.horiz, lineLeft = this.left + (opposite ? this.width : 0) + offset, lineTop = chart.chartHeight - this.bottom -\n (opposite ? this.height : 0) + offset;\n if (opposite) {\n lineWidth *= -1; // crispify the other way - #1480, #1687\n }\n return chart.renderer\n .crispLine([\n [\n 'M',\n horiz ?\n this.left :\n lineLeft,\n horiz ?\n lineTop :\n this.top\n ],\n [\n 'L',\n horiz ?\n chart.chartWidth - this.right :\n lineLeft,\n horiz ?\n lineTop :\n chart.chartHeight - this.bottom\n ]\n ], lineWidth);\n }\n /**\n * Render the axis line. Called internally when rendering and redrawing the\n * axis.\n *\n * @function Highcharts.Axis#renderLine\n */\n renderLine() {\n if (!this.axisLine) {\n this.axisLine = this.chart.renderer.path()\n .addClass('highcharts-axis-line')\n .add(this.axisGroup);\n if (!this.chart.styledMode) {\n this.axisLine.attr({\n stroke: this.options.lineColor,\n 'stroke-width': this.options.lineWidth,\n zIndex: 7\n });\n }\n }\n }\n /**\n * Position the axis title.\n *\n * @private\n * @function Highcharts.Axis#getTitlePosition\n *\n * @return {Highcharts.PositionObject}\n * X and Y positions for the title.\n */\n getTitlePosition(axisTitle) {\n // compute anchor points for each of the title align options\n const horiz = this.horiz, axisLeft = this.left, axisTop = this.top, axisLength = this.len, axisTitleOptions = this.options.title, margin = horiz ? axisLeft : axisTop, opposite = this.opposite, offset = this.offset, xOption = axisTitleOptions.x, yOption = axisTitleOptions.y, fontMetrics = this.chart.renderer.fontMetrics(axisTitle), \n // The part of a multiline text that is below the baseline of the\n // first line. Subtract 1 to preserve pixel-perfectness from the\n // old behaviour (v5.0.12), where only one line was allowed.\n textHeightOvershoot = axisTitle ? Math.max(axisTitle.getBBox(false, 0).height - fontMetrics.h - 1, 0) : 0, \n // the position in the length direction of the axis\n alongAxis = ({\n low: margin + (horiz ? 0 : axisLength),\n middle: margin + axisLength / 2,\n high: margin + (horiz ? axisLength : 0)\n })[axisTitleOptions.align], \n // the position in the perpendicular direction of the axis\n offAxis = (horiz ? axisTop + this.height : axisLeft) +\n (horiz ? 1 : -1) * // horizontal axis reverses the margin\n (opposite ? -1 : 1) * // so does opposite axes\n (this.axisTitleMargin || 0) +\n [\n -textHeightOvershoot,\n textHeightOvershoot,\n fontMetrics.f,\n -textHeightOvershoot // left\n ][this.side], titlePosition = {\n x: horiz ?\n alongAxis + xOption :\n offAxis + (opposite ? this.width : 0) + offset + xOption,\n y: horiz ?\n offAxis + yOption - (opposite ? this.height : 0) + offset :\n alongAxis + yOption\n };\n fireEvent(this, 'afterGetTitlePosition', { titlePosition: titlePosition });\n return titlePosition;\n }\n /**\n * Render a minor tick into the given position. If a minor tick already\n * exists in this position, move it.\n *\n * @function Highcharts.Axis#renderMinorTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n renderMinorTick(pos, slideIn) {\n const axis = this;\n const minorTicks = axis.minorTicks;\n if (!minorTicks[pos]) {\n minorTicks[pos] = new Tick(axis, pos, 'minor');\n }\n // Render new ticks in old position\n if (slideIn && minorTicks[pos].isNew) {\n minorTicks[pos].render(null, true);\n }\n minorTicks[pos].render(null, false, 1);\n }\n /**\n * Render a major tick into the given position. If a tick already exists\n * in this position, move it.\n *\n * @function Highcharts.Axis#renderTick\n *\n * @param {number} pos\n * The position in axis values.\n *\n * @param {number} i\n * The tick index.\n *\n * @param {boolean} slideIn\n * Whether the tick should animate in from last computed position\n */\n renderTick(pos, i, slideIn) {\n const axis = this, isLinked = axis.isLinked, ticks = axis.ticks;\n // Linked axes need an extra check to find out if\n if (!isLinked ||\n (pos >= axis.min && pos <= axis.max) ||\n (axis.grid && axis.grid.isColumn)) {\n if (!ticks[pos]) {\n ticks[pos] = new Tick(axis, pos);\n }\n // NOTE this seems like overkill. Could be handled in tick.render by\n // setting old position in attr, then set new position in animate.\n // render new ticks in old position\n if (slideIn && ticks[pos].isNew) {\n // Start with negative opacity so that it is visible from\n // halfway into the animation\n ticks[pos].render(i, true, -1);\n }\n ticks[pos].render(i);\n }\n }\n /**\n * Render the axis.\n *\n * @private\n * @function Highcharts.Axis#render\n *\n * @emits Highcharts.Axis#event:afterRender\n */\n render() {\n const axis = this, chart = axis.chart, log = axis.logarithmic, renderer = chart.renderer, options = axis.options, isLinked = axis.isLinked, tickPositions = axis.tickPositions, axisTitle = axis.axisTitle, ticks = axis.ticks, minorTicks = axis.minorTicks, alternateBands = axis.alternateBands, stackLabelOptions = options.stackLabels, alternateGridColor = options.alternateGridColor, crossing = options.crossing, tickmarkOffset = axis.tickmarkOffset, axisLine = axis.axisLine, showAxis = axis.showAxis, animation = animObject(renderer.globalAnimation);\n let from, to;\n // Reset\n axis.labelEdge.length = 0;\n axis.overlap = false;\n // Mark all elements inActive before we go over and mark the active ones\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n objectEach(coll, function (tick) {\n tick.isActive = false;\n });\n });\n // Crossing\n if (isNumber(crossing)) {\n const otherAxis = this.isXAxis ? chart.yAxis[0] : chart.xAxis[0], directionFactor = [1, -1, -1, 1][this.side];\n if (otherAxis) {\n let px = otherAxis.toPixels(crossing, true);\n if (axis.horiz) {\n px = otherAxis.len - px;\n }\n axis.offset = directionFactor * px;\n }\n }\n // If the series has data draw the ticks. Else only the line and title\n if (axis.hasData() || isLinked) {\n const slideInTicks = axis.chart.hasRendered &&\n axis.old && isNumber(axis.old.min);\n // minor ticks\n if (axis.minorTickInterval && !axis.categories) {\n axis.getMinorTickPositions().forEach(function (pos) {\n axis.renderMinorTick(pos, slideInTicks);\n });\n }\n // Major ticks. Pull out the first item and render it last so that\n // we can get the position of the neighbour label. #808.\n if (tickPositions.length) { // #1300\n tickPositions.forEach(function (pos, i) {\n axis.renderTick(pos, i, slideInTicks);\n });\n // In a categorized axis, the tick marks are displayed\n // between labels. So we need to add a tick mark and\n // grid line at the left edge of the X axis.\n if (tickmarkOffset && (axis.min === 0 || axis.single)) {\n if (!ticks[-1]) {\n ticks[-1] = new Tick(axis, -1, null, true);\n }\n ticks[-1].render(-1);\n }\n }\n // alternate grid color\n if (alternateGridColor) {\n tickPositions.forEach(function (pos, i) {\n to = typeof tickPositions[i + 1] !== 'undefined' ?\n tickPositions[i + 1] + tickmarkOffset :\n axis.max - tickmarkOffset;\n if (i % 2 === 0 &&\n pos < axis.max &&\n to <= axis.max + (chart.polar ?\n -tickmarkOffset :\n tickmarkOffset)) { // #2248, #4660\n if (!alternateBands[pos]) {\n // Should be imported from PlotLineOrBand.js, but\n // the dependency cycle with axis is a problem\n alternateBands[pos] = new H.PlotLineOrBand(axis);\n }\n from = pos + tickmarkOffset; // #949\n alternateBands[pos].options = {\n from: log ? log.lin2log(from) : from,\n to: log ? log.lin2log(to) : to,\n color: alternateGridColor,\n className: 'highcharts-alternate-grid'\n };\n alternateBands[pos].render();\n alternateBands[pos].isActive = true;\n }\n });\n }\n // custom plot lines and bands\n if (!axis._addedPlotLB) { // only first time\n axis._addedPlotLB = true;\n (options.plotLines || [])\n .concat(options.plotBands || [])\n .forEach(function (plotLineOptions) {\n axis\n .addPlotBandOrLine(plotLineOptions);\n });\n }\n } // end if hasData\n // Remove inactive ticks\n [ticks, minorTicks, alternateBands].forEach(function (coll) {\n const forDestruction = [], delay = animation.duration, destroyInactiveItems = function () {\n let i = forDestruction.length;\n while (i--) {\n // When resizing rapidly, the same items\n // may be destroyed in different timeouts,\n // or the may be reactivated\n if (coll[forDestruction[i]] &&\n !coll[forDestruction[i]].isActive) {\n coll[forDestruction[i]].destroy();\n delete coll[forDestruction[i]];\n }\n }\n };\n objectEach(coll, function (tick, pos) {\n if (!tick.isActive) {\n // Render to zero opacity\n tick.render(pos, false, 0);\n tick.isActive = false;\n forDestruction.push(pos);\n }\n });\n // When the objects are finished fading out, destroy them\n syncTimeout(destroyInactiveItems, coll === alternateBands ||\n !chart.hasRendered ||\n !delay ?\n 0 :\n delay);\n });\n // Set the axis line path\n if (axisLine) {\n axisLine[axisLine.isPlaced ? 'animate' : 'attr']({\n d: this.getLinePath(axisLine.strokeWidth())\n });\n axisLine.isPlaced = true;\n // Show or hide the line depending on options.showEmpty\n axisLine[showAxis ? 'show' : 'hide'](showAxis);\n }\n if (axisTitle && showAxis) {\n axisTitle[axisTitle.isNew ? 'attr' : 'animate'](axis.getTitlePosition(axisTitle));\n axisTitle.isNew = false;\n }\n // Stacked totals:\n if (stackLabelOptions && stackLabelOptions.enabled && axis.stacking) {\n axis.stacking.renderStackTotals();\n }\n // End stacked totals\n // Record old scaling for updating/animation\n axis.old = {\n len: axis.len,\n max: axis.max,\n min: axis.min,\n transA: axis.transA,\n userMax: axis.userMax,\n userMin: axis.userMin\n };\n axis.isDirty = false;\n fireEvent(this, 'afterRender');\n }\n /**\n * Redraw the axis to reflect changes in the data or axis extremes. Called\n * internally from Highcharts.Chart#redraw.\n *\n * @private\n * @function Highcharts.Axis#redraw\n */\n redraw() {\n if (this.visible) {\n // render the axis\n this.render();\n // move plot lines and bands\n this.plotLinesAndBands.forEach(function (plotLine) {\n plotLine.render();\n });\n }\n // mark associated series as dirty and ready for redraw\n this.series.forEach(function (series) {\n series.isDirty = true;\n });\n }\n /**\n * Returns an array of axis properties, that should be untouched during\n * reinitialization.\n *\n * @private\n * @function Highcharts.Axis#getKeepProps\n */\n getKeepProps() {\n return (this.keepProps || Axis.keepProps);\n }\n /**\n * Destroys an Axis instance. See {@link Axis#remove} for the API endpoint\n * to fully remove the axis.\n *\n * @private\n * @function Highcharts.Axis#destroy\n *\n * @param {boolean} [keepEvents]\n * Whether to preserve events, used internally in Axis.update.\n */\n destroy(keepEvents) {\n const axis = this, plotLinesAndBands = axis.plotLinesAndBands, eventOptions = this.eventOptions;\n fireEvent(this, 'destroy', { keepEvents: keepEvents });\n // Remove the events\n if (!keepEvents) {\n removeEvent(axis);\n }\n // Destroy collections\n [axis.ticks, axis.minorTicks, axis.alternateBands].forEach(function (coll) {\n destroyObjectProperties(coll);\n });\n if (plotLinesAndBands) {\n let i = plotLinesAndBands.length;\n while (i--) { // #1975\n plotLinesAndBands[i].destroy();\n }\n }\n // Destroy elements\n ['axisLine', 'axisTitle', 'axisGroup',\n 'gridGroup', 'labelGroup', 'cross', 'scrollbar'].forEach(function (prop) {\n if (axis[prop]) {\n axis[prop] = axis[prop].destroy();\n }\n });\n // Destroy each generated group for plotlines and plotbands\n for (const plotGroup in axis.plotLinesAndBandsGroups) { // eslint-disable-line guard-for-in\n axis.plotLinesAndBandsGroups[plotGroup] =\n axis.plotLinesAndBandsGroups[plotGroup].destroy();\n }\n // Delete all properties and fall back to the prototype.\n objectEach(axis, function (val, key) {\n if (axis.getKeepProps().indexOf(key) === -1) {\n delete axis[key];\n }\n });\n this.eventOptions = eventOptions;\n }\n /**\n * Internal function to draw a crosshair.\n *\n * @function Highcharts.Axis#drawCrosshair\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments from the modified pointer event, extended with\n * `chartX` and `chartY`\n *\n * @param {Highcharts.Point} [point]\n * The Point object if the crosshair snaps to points.\n *\n * @emits Highcharts.Axis#event:afterDrawCrosshair\n * @emits Highcharts.Axis#event:drawCrosshair\n */\n drawCrosshair(e, point) {\n const options = this.crosshair, snap = pick(options && options.snap, true), chart = this.chart;\n let path, pos, categorized, graphic = this.cross, crossOptions;\n fireEvent(this, 'drawCrosshair', { e: e, point: point });\n // Use last available event when updating non-snapped crosshairs without\n // mouse interaction (#5287)\n if (!e) {\n e = this.cross && this.cross.e;\n }\n if (\n // Disabled in options\n !options ||\n // Snap\n ((defined(point) || !snap) === false)) {\n this.hideCrosshair();\n }\n else {\n // Get the path\n if (!snap) {\n pos = e &&\n (this.horiz ?\n e.chartX - this.pos :\n this.len - e.chartY + this.pos);\n }\n else if (defined(point)) {\n // #3834\n pos = pick(this.coll !== 'colorAxis' ?\n point.crosshairPos : // 3D axis extension\n null, this.isXAxis ?\n point.plotX :\n this.len - point.plotY);\n }\n if (defined(pos)) {\n crossOptions = {\n // value, only used on radial\n value: point && (this.isXAxis ?\n point.x :\n pick(point.stackY, point.y)),\n translatedValue: pos\n };\n if (chart.polar) {\n // Additional information required for crosshairs in\n // polar chart\n extend(crossOptions, {\n isCrosshair: true,\n chartX: e && e.chartX,\n chartY: e && e.chartY,\n point: point\n });\n }\n path = this.getPlotLinePath(crossOptions) ||\n null; // #3189\n }\n if (!defined(path)) {\n this.hideCrosshair();\n return;\n }\n categorized = this.categories && !this.isRadial;\n // Draw the cross\n if (!graphic) {\n this.cross = graphic = chart.renderer\n .path()\n .addClass('highcharts-crosshair highcharts-crosshair-' +\n (categorized ? 'category ' : 'thin ') +\n (options.className || ''))\n .attr({\n zIndex: pick(options.zIndex, 2)\n })\n .add();\n // Presentational attributes\n if (!chart.styledMode) {\n graphic.attr({\n stroke: options.color ||\n (categorized ?\n Color\n .parse(\"#ccd3ff\" /* Palette.highlightColor20 */)\n .setOpacity(0.25)\n .get() :\n \"#cccccc\" /* Palette.neutralColor20 */),\n 'stroke-width': pick(options.width, 1)\n }).css({\n 'pointer-events': 'none'\n });\n if (options.dashStyle) {\n graphic.attr({\n dashstyle: options.dashStyle\n });\n }\n }\n }\n graphic.show().attr({\n d: path\n });\n if (categorized && !options.width) {\n graphic.attr({\n 'stroke-width': this.transA\n });\n }\n this.cross.e = e;\n }\n fireEvent(this, 'afterDrawCrosshair', { e: e, point: point });\n }\n /**\n * Hide the crosshair if visible.\n *\n * @function Highcharts.Axis#hideCrosshair\n */\n hideCrosshair() {\n if (this.cross) {\n this.cross.hide();\n }\n fireEvent(this, 'afterHideCrosshair');\n }\n /**\n * Check whether the chart has vertical panning ('y' or 'xy' type).\n *\n * @private\n * @function Highcharts.Axis#hasVerticalPanning\n */\n hasVerticalPanning() {\n const panningOptions = this.chart.options.chart.panning;\n return Boolean(panningOptions &&\n panningOptions.enabled && // #14624\n /y/.test(panningOptions.type));\n }\n /**\n * Update an axis object with a new set of options. The options are merged\n * with the existing options, so only new or altered options need to be\n * specified.\n *\n * @sample highcharts/members/axis-update/\n * Axis update demo\n *\n * @function Highcharts.Axis#update\n *\n * @param {Highcharts.AxisOptions} options\n * The new options that will be merged in with existing options on the axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n update(options, redraw) {\n const chart = this.chart;\n options = merge(this.userOptions, options);\n this.destroy(true);\n this.init(chart, options);\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n }\n /**\n * Remove the axis from the chart.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Axis#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart following the remove.\n */\n remove(redraw) {\n const chart = this.chart, coll = this.coll, axisSeries = this.series;\n let i = axisSeries.length;\n // Remove associated series (#2687)\n while (i--) {\n if (axisSeries[i]) {\n axisSeries[i].remove(false);\n }\n }\n // Remove the axis\n erase(chart.axes, this);\n erase(chart[coll] || [], this);\n chart.orderItems(coll);\n this.destroy();\n chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n }\n /**\n * Update the axis title by options after render time.\n *\n * @sample highcharts/members/axis-settitle/\n * Set a new Y axis title\n *\n * @function Highcharts.Axis#setTitle\n *\n * @param {Highcharts.AxisTitleOptions} titleOptions\n * The additional title options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after setting the title.\n */\n setTitle(titleOptions, redraw) {\n this.update({ title: titleOptions }, redraw);\n }\n /**\n * Set new axis categories and optionally redraw.\n *\n * @sample highcharts/members/axis-setcategories/\n * Set categories by click on a button\n *\n * @function Highcharts.Axis#setCategories\n *\n * @param {Array} categories\n * The new categories.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n */\n setCategories(categories, redraw) {\n this.update({ categories: categories }, redraw);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Axis.defaultOptions = AxisDefaults.defaultXAxisOptions;\n // Properties to survive after destroy, needed for Axis.update (#4317,\n // #5773, #5881).\n Axis.keepProps = [\n 'coll',\n 'extKey',\n 'hcEvents',\n 'names',\n 'series',\n 'userMax',\n 'userMin'\n ];\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for the path on the Axis to be calculated.\n * @interface Highcharts.AxisPlotLinePathOptionsObject\n */ /**\n * Axis value.\n * @name Highcharts.AxisPlotLinePathOptionsObject#value\n * @type {number|undefined}\n */ /**\n * Line width used for calculation crisp line coordinates. Defaults to 1.\n * @name Highcharts.AxisPlotLinePathOptionsObject#lineWidth\n * @type {number|undefined}\n */ /**\n * If `false`, the function will return null when it falls outside the axis\n * bounds. If `true`, the function will return a path aligned to the plot area\n * sides if it falls outside. If `pass`, it will return a path outside.\n * @name Highcharts.AxisPlotLinePathOptionsObject#force\n * @type {string|boolean|undefined}\n */ /**\n * Used in Highcharts Stock. When `true`, plot paths\n * (crosshair, plotLines, gridLines)\n * will be rendered on all axes when defined on the first axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#acrossPanes\n * @type {boolean|undefined}\n */ /**\n * Use old coordinates (for resizing and rescaling).\n * If not set, defaults to `false`.\n * @name Highcharts.AxisPlotLinePathOptionsObject#old\n * @type {boolean|undefined}\n */ /**\n * If given, return the plot line path of a pixel position on the axis.\n * @name Highcharts.AxisPlotLinePathOptionsObject#translatedValue\n * @type {number|undefined}\n */ /**\n * Used in Polar axes. Reverse the positions for concatenation of polygonal\n * plot bands\n * @name Highcharts.AxisPlotLinePathOptionsObject#reverse\n * @type {boolean|undefined}\n */\n /**\n * Options for crosshairs on axes.\n *\n * @product highstock\n *\n * @typedef {Highcharts.XAxisCrosshairOptions|Highcharts.YAxisCrosshairOptions} Highcharts.AxisCrosshairOptions\n */\n /**\n * @typedef {\"navigator\"|\"pan\"|\"rangeSelectorButton\"|\"rangeSelectorInput\"|\"scrollbar\"|\"traverseUpButton\"|\"zoom\"} Highcharts.AxisExtremesTriggerValue\n */\n /**\n * @callback Highcharts.AxisEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n */\n /**\n * @callback Highcharts.AxisLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} this\n *\n * @param {Highcharts.AxisLabelsFormatterContextObject} ctx\n *\n * @return {string}\n */\n /**\n * @interface Highcharts.AxisLabelsFormatterContextObject\n */ /**\n * The axis item of the label\n * @name Highcharts.AxisLabelsFormatterContextObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The chart instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#chart\n * @type {Highcharts.Chart}\n */ /**\n * Default formatting of date/time labels.\n * @name Highcharts.AxisLabelsFormatterContextObject#dateTimeLabelFormat\n * @type {string|undefined}\n */ /**\n * Whether the label belongs to the first tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isFirst\n * @type {boolean}\n */ /**\n * Whether the label belongs to the last tick on the axis.\n * @name Highcharts.AxisLabelsFormatterContextObject#isLast\n * @type {boolean}\n */ /**\n * The position on the axis in terms of axis values. For category axes, a\n * zero-based index. For datetime axes, the JavaScript time in milliseconds\n * since 1970.\n * @name Highcharts.AxisLabelsFormatterContextObject#pos\n * @type {number}\n */ /**\n * The preformatted text as the result of the default formatting. For example\n * dates will be formatted as strings, and numbers with language-specific comma\n * separators, thousands separators and numeric symbols like `k` or `M`.\n * @name Highcharts.AxisLabelsFormatterContextObject#text\n * @type {string|undefined}\n */ /**\n * The Tick instance.\n * @name Highcharts.AxisLabelsFormatterContextObject#tick\n * @type {Highcharts.Tick}\n */ /**\n * This can be either a numeric value or a category string.\n * @name Highcharts.AxisLabelsFormatterContextObject#value\n * @type {number|string}\n */\n /**\n * Options for axes.\n *\n * @typedef {Highcharts.XAxisOptions|Highcharts.YAxisOptions|Highcharts.ZAxisOptions} Highcharts.AxisOptions\n */\n /**\n * @callback Highcharts.AxisPointBreakEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisPointBreakEventObject} evt\n */\n /**\n * @interface Highcharts.AxisPointBreakEventObject\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#brk\n * @type {Highcharts.Dictionary}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#point\n * @type {Highcharts.Point}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisPointBreakEventObject#type\n * @type {\"pointBreak\"|\"pointInBreak\"}\n */\n /**\n * @callback Highcharts.AxisSetExtremesEventCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @param {Highcharts.AxisSetExtremesEventObject} evt\n */\n /**\n * @interface Highcharts.AxisSetExtremesEventObject\n * @extends Highcharts.ExtremesObject\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#preventDefault\n * @type {Function}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#target\n * @type {Highcharts.SVGElement}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#trigger\n * @type {Highcharts.AxisExtremesTriggerValue|string}\n */ /**\n * @name Highcharts.AxisSetExtremesEventObject#type\n * @type {\"setExtremes\"}\n */\n /**\n * @callback Highcharts.AxisTickPositionerCallbackFunction\n *\n * @param {Highcharts.Axis} this\n *\n * @return {Highcharts.AxisTickPositionsArray}\n */\n /**\n * @interface Highcharts.AxisTickPositionsArray\n * @augments Array\n */\n /**\n * @typedef {\"high\"|\"low\"|\"middle\"} Highcharts.AxisTitleAlignValue\n */\n /**\n * @typedef {Highcharts.XAxisTitleOptions|Highcharts.YAxisTitleOptions|Highcharts.ZAxisTitleOptions} Highcharts.AxisTitleOptions\n */\n /**\n * @typedef {\"linear\"|\"logarithmic\"|\"datetime\"|\"category\"|\"treegrid\"} Highcharts.AxisTypeValue\n */\n /**\n * The returned object literal from the {@link Highcharts.Axis#getExtremes}\n * function.\n *\n * @interface Highcharts.ExtremesObject\n */ /**\n * The maximum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMax\n * @type {number}\n */ /**\n * The minimum value of the axis' associated series.\n * @name Highcharts.ExtremesObject#dataMin\n * @type {number}\n */ /**\n * The maximum axis value, either automatic or set manually. If the `max` option\n * is not set, `maxPadding` is 0 and `endOnTick` is false, this value will be\n * the same as `dataMax`.\n * @name Highcharts.ExtremesObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually. If the `min` option\n * is not set, `minPadding` is 0 and `startOnTick` is false, this value will be\n * the same as `dataMin`.\n * @name Highcharts.ExtremesObject#min\n * @type {number}\n */ /**\n * The user defined maximum, either from the `max` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMax\n * @type {number|undefined}\n */ /**\n * The user defined minimum, either from the `min` option or from a zoom or\n * `setExtremes` action.\n * @name Highcharts.ExtremesObject#userMin\n * @type {number|undefined}\n */\n /**\n * Formatter function for the text of a crosshair label.\n *\n * @callback Highcharts.XAxisCrosshairLabelFormatterCallbackFunction\n *\n * @param {Highcharts.Axis} this\n * Axis context\n *\n * @param {number} value\n * Y value of the data point\n *\n * @return {string}\n */\n ''; // keeps doclets above in JS file\n\n return Axis;\n });\n _registerModule(_modules, 'Core/Axis/DateTimeAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, getMagnitude, normalizeTickInterval, timeUnits } = U;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DateTimeAxis;\n (function (DateTimeAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis class with date and time support.\n * @private\n */\n function compose(AxisClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('dateTime');\n const axisProto = AxisClass.prototype;\n axisProto.getTimeTicks = getTimeTicks;\n addEvent(AxisClass, 'init', onInit);\n }\n return AxisClass;\n }\n DateTimeAxis.compose = compose;\n /**\n * Set the tick positions to a time unit that makes sense, for example\n * on the first of each month or on every Monday. Return an array with\n * the time positions. Used in datetime axes as well as for grouping\n * data on a datetime axis.\n *\n * @private\n * @function Highcharts.Axis#getTimeTicks\n * @param {Highcharts.TimeNormalizeObject} normalizedInterval\n * The interval in axis values (ms) and thecount.\n * @param {number} min\n * The minimum in axis values.\n * @param {number} max\n * The maximum in axis values.\n */\n function getTimeTicks() {\n return this.chart.time.getTimeTicks.apply(this.chart.time, arguments);\n }\n /**\n * @private\n */\n function onInit(e) {\n const axis = this;\n const options = e.userOptions;\n if (options.type !== 'datetime') {\n axis.dateTime = void 0;\n return;\n }\n if (!axis.dateTime) {\n axis.dateTime = new Additions(axis);\n }\n }\n /* *\n *\n * Classes\n *\n * */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get a normalized tick interval for dates. Returns a configuration\n * object with unit range (interval), count and name. Used to prepare\n * data for `getTimeTicks`. Previously this logic was part of\n * getTimeTicks, but as `getTimeTicks` now runs of segments in stock\n * charts, the normalizing logic was extracted in order to prevent it\n * for running over again for each segment having the same interval.\n * #662, #697.\n * @private\n */\n normalizeTimeTickInterval(tickInterval, unitsOption) {\n const units = (unitsOption || [[\n // unit name\n 'millisecond',\n // allowed multiples\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500]\n ], [\n 'second',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'minute',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'hour',\n [1, 2, 3, 4, 6, 8, 12]\n ], [\n 'day',\n [1, 2]\n ], [\n 'week',\n [1, 2]\n ], [\n 'month',\n [1, 2, 3, 4, 6]\n ], [\n 'year',\n null\n ]]);\n let unit = units[units.length - 1], // default unit is years\n interval = timeUnits[unit[0]], multiples = unit[1], i;\n // loop through the units to find the one that best fits the\n // tickInterval\n for (i = 0; i < units.length; i++) {\n unit = units[i];\n interval = timeUnits[unit[0]];\n multiples = unit[1];\n if (units[i + 1]) {\n // lessThan is in the middle between the highest multiple\n // and the next unit.\n const lessThan = (interval *\n multiples[multiples.length - 1] +\n timeUnits[units[i + 1][0]]) / 2;\n // break and keep the current unit\n if (tickInterval <= lessThan) {\n break;\n }\n }\n }\n // prevent 2.5 years intervals, though 25, 250 etc. are allowed\n if (interval === timeUnits.year && tickInterval < 5 * interval) {\n multiples = [1, 2, 5];\n }\n // get the count\n const count = normalizeTickInterval(tickInterval / interval, multiples, unit[0] === 'year' ? // #1913, #2360\n Math.max(getMagnitude(tickInterval / interval), 1) :\n 1);\n return {\n unitRange: interval,\n count: count,\n unitName: unit[0]\n };\n }\n /**\n * Get the best date format for a specific X value based on the closest\n * point range on the axis.\n *\n * @private\n */\n getXDateFormat(x, dateTimeLabelFormats) {\n const { axis } = this, time = axis.chart.time;\n return axis.closestPointRange ?\n time.getDateFormat(axis.closestPointRange, x, axis.options.startOfWeek, dateTimeLabelFormats) ||\n // #2546, 2581\n time.resolveDTLFormat(dateTimeLabelFormats.year).main :\n time.resolveDTLFormat(dateTimeLabelFormats.day).main;\n }\n }\n DateTimeAxis.Additions = Additions;\n })(DateTimeAxis || (DateTimeAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return DateTimeAxis;\n });\n _registerModule(_modules, 'Core/Axis/LogarithmicAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, normalizeTickInterval, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n */\n var LogarithmicAxis;\n (function (LogarithmicAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Provides logarithmic support for axes.\n * @private\n */\n function compose(AxisClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('logarithmic');\n addEvent(AxisClass, 'init', onInit);\n addEvent(AxisClass, 'afterInit', onAfterInit);\n }\n return AxisClass;\n }\n LogarithmicAxis.compose = compose;\n /**\n * @private\n */\n function onInit(e) {\n const axis = this;\n const options = e.userOptions;\n let logarithmic = axis.logarithmic;\n if (options.type !== 'logarithmic') {\n axis.logarithmic = void 0;\n }\n else {\n if (!logarithmic) {\n logarithmic = axis.logarithmic = new Additions(axis);\n }\n }\n }\n /**\n * @private\n */\n function onAfterInit() {\n const axis = this;\n const log = axis.logarithmic;\n // extend logarithmic axis\n if (log) {\n axis.lin2val = function (num) {\n return log.lin2log(num);\n };\n axis.val2lin = function (num) {\n return log.log2lin(num);\n };\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Provides logarithmic support for axes.\n * @private\n * @class\n */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set the tick positions of a logarithmic axis.\n */\n getLogTickPositions(interval, min, max, minor) {\n const log = this;\n const axis = log.axis;\n const axisLength = axis.len;\n const options = axis.options;\n // Since we use this method for both major and minor ticks,\n // use a local variable and return the result\n let positions = [];\n // Reset\n if (!minor) {\n log.minorAutoInterval = void 0;\n }\n // First case: All ticks fall on whole logarithms: 1, 10, 100 etc.\n if (interval >= 0.5) {\n interval = Math.round(interval);\n positions = axis.getLinearTickPositions(interval, min, max);\n // Second case: We need intermediary ticks. For example\n // 1, 2, 4, 6, 8, 10, 20, 40 etc.\n }\n else if (interval >= 0.08) {\n const roundedMin = Math.floor(min);\n let intermediate, i, j, len, pos, lastPos, break2;\n if (interval > 0.3) {\n intermediate = [1, 2, 4];\n // 0.2 equals five minor ticks per 1, 10, 100 etc\n }\n else if (interval > 0.15) {\n intermediate = [1, 2, 4, 6, 8];\n }\n else { // 0.1 equals ten minor ticks per 1, 10, 100 etc\n intermediate = [1, 2, 3, 4, 5, 6, 7, 8, 9];\n }\n for (i = roundedMin; i < max + 1 && !break2; i++) {\n len = intermediate.length;\n for (j = 0; j < len && !break2; j++) {\n pos = log.log2lin(log.lin2log(i) * intermediate[j]);\n // #1670, lastPos is #3113\n if (pos > min &&\n (!minor || lastPos <= max) &&\n typeof lastPos !== 'undefined') {\n positions.push(lastPos);\n }\n if (lastPos > max) {\n break2 = true;\n }\n lastPos = pos;\n }\n }\n // Third case: We are so deep in between whole logarithmic values,\n // that we might as well handle the tick positions like a linear\n // axis. For example 1.01, 1.02, 1.03, 1.04.\n }\n else {\n const realMin = log.lin2log(min), realMax = log.lin2log(max), tickIntervalOption = minor ?\n axis.getMinorTickInterval() :\n options.tickInterval, filteredTickIntervalOption = tickIntervalOption === 'auto' ?\n null :\n tickIntervalOption, tickPixelIntervalOption = options.tickPixelInterval / (minor ? 5 : 1), totalPixelLength = minor ?\n axisLength / axis.tickPositions.length :\n axisLength;\n interval = pick(filteredTickIntervalOption, log.minorAutoInterval, (realMax - realMin) *\n tickPixelIntervalOption / (totalPixelLength || 1));\n interval = normalizeTickInterval(interval);\n positions = axis.getLinearTickPositions(interval, realMin, realMax).map(log.log2lin);\n if (!minor) {\n log.minorAutoInterval = interval / 5;\n }\n }\n // Set the axis-level tickInterval variable\n if (!minor) {\n axis.tickInterval = interval;\n }\n return positions;\n }\n lin2log(num) {\n return Math.pow(10, num);\n }\n log2lin(num) {\n return Math.log(num) / Math.LN10;\n }\n }\n LogarithmicAxis.Additions = Additions;\n })(LogarithmicAxis || (LogarithmicAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LogarithmicAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { erase, extend, isNumber } = U;\n /* *\n *\n * Composition\n *\n * */\n var PlotLineOrBandAxis;\n (function (PlotLineOrBandAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let PlotLineOrBandClass;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add a plot band after render time.\n *\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#addPlotBand\n *\n * @param {Highcharts.AxisPlotBandsOptions} options\n * A configuration object for the plot band, as defined in\n * [xAxis.plotBands](https://api.highcharts.com/highcharts/xAxis.plotBands).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot band.\n */\n function addPlotBand(options) {\n return this.addPlotBandOrLine(options, 'plotBands');\n }\n /**\n * Add a plot band or plot line after render time. Called from\n * addPlotBand and addPlotLine internally.\n *\n * @private\n * @function Highcharts.Axis#addPlotBandOrLine\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n */\n function addPlotBandOrLine(options, coll) {\n const userOptions = this.userOptions;\n let obj = new PlotLineOrBandClass(this, options);\n if (this.visible) {\n obj = obj.render();\n }\n if (obj) { // #2189\n if (!this._addedPlotLB) {\n this._addedPlotLB = true;\n (userOptions.plotLines || [])\n .concat(userOptions.plotBands || [])\n .forEach((plotLineOptions) => {\n this.addPlotBandOrLine(plotLineOptions);\n });\n }\n // Add it to the user options for exporting and Axis.update\n if (coll) {\n // Workaround Microsoft/TypeScript issue #32693\n const updatedOptions = (userOptions[coll] || []);\n updatedOptions.push(options);\n userOptions[coll] = updatedOptions;\n }\n this.plotLinesAndBands.push(obj);\n }\n return obj;\n }\n /**\n * Add a plot line after render time.\n *\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#addPlotLine\n *\n * @param {Highcharts.AxisPlotLinesOptions} options\n * A configuration object for the plot line, as defined in\n * [xAxis.plotLines](https://api.highcharts.com/highcharts/xAxis.plotLines).\n *\n * @return {Highcharts.PlotLineOrBand|undefined}\n * The added plot line.\n */\n function addPlotLine(options) {\n return this.addPlotBandOrLine(options, 'plotLines');\n }\n /**\n * @private\n */\n function compose(PlotLineOrBandType, AxisClass) {\n if (!PlotLineOrBandClass) {\n PlotLineOrBandClass = PlotLineOrBandType;\n }\n if (U.pushUnique(composedMembers, AxisClass)) {\n extend(AxisClass.prototype, {\n addPlotBand,\n addPlotLine,\n addPlotBandOrLine,\n getPlotBandPath,\n removePlotBand,\n removePlotLine,\n removePlotBandOrLine\n });\n }\n return AxisClass;\n }\n PlotLineOrBandAxis.compose = compose;\n /**\n * Internal function to create the SVG path definition for a plot band.\n *\n * @function Highcharts.Axis#getPlotBandPath\n *\n * @param {number} from\n * The axis value to start from.\n *\n * @param {number} to\n * The axis value to end on.\n *\n * @param {Highcharts.AxisPlotBandsOptions|Highcharts.AxisPlotLinesOptions} options\n * The plotBand or plotLine configuration object.\n *\n * @return {Highcharts.SVGPathArray}\n * The SVG path definition in array form.\n */\n function getPlotBandPath(from, to, options = this.options) {\n const toPath = this.getPlotLinePath({\n value: to,\n force: true,\n acrossPanes: options.acrossPanes\n }), result = [], horiz = this.horiz, outside = !isNumber(this.min) ||\n !isNumber(this.max) ||\n (from < this.min && to < this.min) ||\n (from > this.max && to > this.max);\n let path = this.getPlotLinePath({\n value: from,\n force: true,\n acrossPanes: options.acrossPanes\n }), i, \n // #4964 check if chart is inverted or plotband is on yAxis\n plus = 1, isFlat;\n if (path && toPath) {\n // Flat paths don't need labels (#3836)\n if (outside) {\n isFlat = path.toString() === toPath.toString();\n plus = 0;\n }\n // Go over each subpath - for panes in Highcharts Stock\n for (i = 0; i < path.length; i += 2) {\n const pathStart = path[i], pathEnd = path[i + 1], toPathStart = toPath[i], toPathEnd = toPath[i + 1];\n // Type checking all affected path segments. Consider\n // something smarter.\n if ((pathStart[0] === 'M' || pathStart[0] === 'L') &&\n (pathEnd[0] === 'M' || pathEnd[0] === 'L') &&\n (toPathStart[0] === 'M' || toPathStart[0] === 'L') &&\n (toPathEnd[0] === 'M' || toPathEnd[0] === 'L')) {\n // Add 1 pixel when coordinates are the same\n if (horiz && toPathStart[1] === pathStart[1]) {\n toPathStart[1] += plus;\n toPathEnd[1] += plus;\n }\n else if (!horiz && toPathStart[2] === pathStart[2]) {\n toPathStart[2] += plus;\n toPathEnd[2] += plus;\n }\n result.push(['M', pathStart[1], pathStart[2]], ['L', pathEnd[1], pathEnd[2]], ['L', toPathEnd[1], toPathEnd[2]], ['L', toPathStart[1], toPathStart[2]], ['Z']);\n }\n result.isFlat = isFlat;\n }\n }\n else { // outside the axis area\n path = null;\n }\n return result;\n }\n /**\n * Remove a plot band by its id.\n *\n * @sample highcharts/members/axis-removeplotband/\n * Remove plot band by id\n * @sample highcharts/members/axis-addplotband/\n * Toggle the plot band from a button\n *\n * @function Highcharts.Axis#removePlotBand\n *\n * @param {string} id\n * The plot band's `id` as given in the original configuration\n * object or in the `addPlotBand` option.\n */\n function removePlotBand(id) {\n this.removePlotBandOrLine(id);\n }\n /**\n * Remove a plot band or plot line from the chart by id. Called\n * internally from `removePlotBand` and `removePlotLine`.\n * @private\n * @function Highcharts.Axis#removePlotBandOrLine\n */\n function removePlotBandOrLine(id) {\n const plotLinesAndBands = this.plotLinesAndBands, options = this.options, userOptions = this.userOptions;\n if (plotLinesAndBands) { // #15639\n let i = plotLinesAndBands.length;\n while (i--) {\n if (plotLinesAndBands[i].id === id) {\n plotLinesAndBands[i].destroy();\n }\n }\n ([\n options.plotLines || [],\n userOptions.plotLines || [],\n options.plotBands || [],\n userOptions.plotBands || []\n ]).forEach(function (arr) {\n i = arr.length;\n while (i--) {\n if ((arr[i] || {}).id === id) {\n erase(arr, arr[i]);\n }\n }\n });\n }\n }\n /**\n * Remove a plot line by its id.\n *\n * @sample highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n * @sample highcharts/members/axis-addplotline/\n * Toggle the plot line from a button\n *\n * @function Highcharts.Axis#removePlotLine\n *\n * @param {string} id\n * The plot line's `id` as given in the original configuration\n * object or in the `addPlotLine` option.\n */\n function removePlotLine(id) {\n this.removePlotBandOrLine(id);\n }\n })(PlotLineOrBandAxis || (PlotLineOrBandAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return PlotLineOrBandAxis;\n });\n _registerModule(_modules, 'Core/Axis/PlotLineOrBand/PlotLineOrBand.js', [_modules['Core/Axis/PlotLineOrBand/PlotLineOrBandAxis.js'], _modules['Core/Utilities.js']], function (PlotLineOrBandAxis, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { arrayMax, arrayMin, defined, destroyObjectProperties, erase, fireEvent, merge, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The object wrapper for plot lines and plot bands\n *\n * @class\n * @name Highcharts.PlotLineOrBand\n *\n * @param {Highcharts.Axis} axis\n * Related axis.\n *\n * @param {Highcharts.AxisPlotLinesOptions|Highcharts.AxisPlotBandsOptions} [options]\n * Options to use.\n */\n class PlotLineOrBand {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AxisClass) {\n return PlotLineOrBandAxis.compose(PlotLineOrBand, AxisClass);\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(axis, options) {\n this.axis = axis;\n if (options) {\n this.options = options;\n this.id = options.id;\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Render the plot line or plot band. If it is already existing,\n * move it.\n * @private\n * @function Highcharts.PlotLineOrBand#render\n */\n render() {\n fireEvent(this, 'render');\n const plotLine = this, axis = plotLine.axis, horiz = axis.horiz, log = axis.logarithmic, options = plotLine.options, color = options.color, zIndex = pick(options.zIndex, 0), events = options.events, groupAttribs = {}, renderer = axis.chart.renderer;\n let optionsLabel = options.label, label = plotLine.label, to = options.to, from = options.from, value = options.value, svgElem = plotLine.svgElem, path = [], group;\n const isBand = defined(from) && defined(to), isLine = defined(value), isNew = !svgElem, attribs = {\n 'class': 'highcharts-plot-' + (isBand ? 'band ' : 'line ') +\n (options.className || '')\n };\n let groupName = isBand ? 'bands' : 'lines';\n // logarithmic conversion\n if (log) {\n from = log.log2lin(from);\n to = log.log2lin(to);\n value = log.log2lin(value);\n }\n // Set the presentational attributes\n if (!axis.chart.styledMode) {\n if (isLine) {\n attribs.stroke = color || \"#999999\" /* Palette.neutralColor40 */;\n attribs['stroke-width'] = pick(options.width, 1);\n if (options.dashStyle) {\n attribs.dashstyle =\n options.dashStyle;\n }\n }\n else if (isBand) { // plot band\n attribs.fill = color || \"#e6e9ff\" /* Palette.highlightColor10 */;\n if (options.borderWidth) {\n attribs.stroke = options.borderColor;\n attribs['stroke-width'] = options.borderWidth;\n }\n }\n }\n // Grouping and zIndex\n groupAttribs.zIndex = zIndex;\n groupName += '-' + zIndex;\n group = axis.plotLinesAndBandsGroups[groupName];\n if (!group) {\n axis.plotLinesAndBandsGroups[groupName] = group =\n renderer.g('plot-' + groupName)\n .attr(groupAttribs).add();\n }\n // Create the path\n if (isNew) {\n /**\n * SVG element of the plot line or band.\n *\n * @name Highcharts.PlotLineOrBand#svgElem\n * @type {Highcharts.SVGElement}\n */\n plotLine.svgElem = svgElem = renderer\n .path()\n .attr(attribs)\n .add(group);\n }\n // Set the path or return\n if (isLine) {\n path = axis.getPlotLinePath({\n value: value,\n lineWidth: svgElem.strokeWidth(),\n acrossPanes: options.acrossPanes\n });\n }\n else if (isBand) { // plot band\n path = axis.getPlotBandPath(from, to, options);\n }\n else {\n return;\n }\n // common for lines and bands\n // Add events only if they were not added before.\n if (!plotLine.eventsAdded && events) {\n objectEach(events, function (event, eventType) {\n svgElem.on(eventType, function (e) {\n events[eventType].apply(plotLine, [e]);\n });\n });\n plotLine.eventsAdded = true;\n }\n if ((isNew || !svgElem.d) && path && path.length) {\n svgElem.attr({ d: path });\n }\n else if (svgElem) {\n if (path) {\n svgElem.show();\n svgElem.animate({ d: path });\n }\n else if (svgElem.d) {\n svgElem.hide();\n if (label) {\n plotLine.label = label = label.destroy();\n }\n }\n }\n // the plot band/line label\n if (optionsLabel &&\n (defined(optionsLabel.text) || defined(optionsLabel.formatter)) &&\n path &&\n path.length &&\n axis.width > 0 &&\n axis.height > 0 &&\n !path.isFlat) {\n // apply defaults\n optionsLabel = merge({\n align: horiz && isBand && 'center',\n x: horiz ? !isBand && 4 : 10,\n verticalAlign: !horiz && isBand && 'middle',\n y: horiz ? isBand ? 16 : 10 : isBand ? 6 : -4,\n rotation: horiz && !isBand && 90\n }, optionsLabel);\n this.renderLabel(optionsLabel, path, isBand, zIndex);\n }\n else if (label) { // move out of sight\n label.hide();\n }\n // chainable\n return plotLine;\n }\n /**\n * Render and align label for plot line or band.\n * @private\n * @function Highcharts.PlotLineOrBand#renderLabel\n */\n renderLabel(optionsLabel, path, isBand, zIndex) {\n const plotLine = this, axis = plotLine.axis, renderer = axis.chart.renderer;\n let label = plotLine.label;\n // add the SVG element\n if (!label) {\n /**\n * SVG element of the label.\n *\n * @name Highcharts.PlotLineOrBand#label\n * @type {Highcharts.SVGElement}\n */\n plotLine.label = label = renderer\n .text(this.getLabelText(optionsLabel), 0, 0, optionsLabel.useHTML)\n .attr({\n align: optionsLabel.textAlign || optionsLabel.align,\n rotation: optionsLabel.rotation,\n 'class': 'highcharts-plot-' + (isBand ? 'band' : 'line') +\n '-label ' + (optionsLabel.className || ''),\n zIndex\n })\n .add();\n if (!axis.chart.styledMode) {\n label.css(merge({\n fontSize: '0.8em',\n textOverflow: 'ellipsis'\n }, optionsLabel.style));\n }\n }\n // get the bounding box and align the label\n // #3000 changed to better handle choice between plotband or plotline\n const xBounds = path.xBounds ||\n [path[0][1], path[1][1], (isBand ? path[2][1] : path[0][1])];\n const yBounds = path.yBounds ||\n [path[0][2], path[1][2], (isBand ? path[2][2] : path[0][2])];\n const x = arrayMin(xBounds);\n const y = arrayMin(yBounds);\n label.align(optionsLabel, false, {\n x,\n y,\n width: arrayMax(xBounds) - x,\n height: arrayMax(yBounds) - y\n });\n if (!label.alignValue || label.alignValue === 'left') {\n const width = optionsLabel.clip ?\n axis.width : axis.chart.chartWidth;\n label.css({\n width: (label.rotation === 90 ?\n axis.height - (label.alignAttr.y - axis.top) :\n width - (label.alignAttr.x - axis.left)) + 'px'\n });\n }\n label.show(true);\n }\n /**\n * Get label's text content.\n * @private\n * @function Highcharts.PlotLineOrBand#getLabelText\n */\n getLabelText(optionsLabel) {\n return defined(optionsLabel.formatter) ?\n optionsLabel.formatter\n .call(this) :\n optionsLabel.text;\n }\n /**\n * Remove the plot line or band.\n *\n * @function Highcharts.PlotLineOrBand#destroy\n */\n destroy() {\n // remove it from the lookup\n erase(this.axis.plotLinesAndBands, this);\n delete this.axis;\n destroyObjectProperties(this);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Options for plot bands on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsOptions|Highcharts.YAxisPlotBandsOptions|Highcharts.ZAxisPlotBandsOptions} Highcharts.AxisPlotBandsOptions\n */\n /**\n * Options for plot band labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotBandsLabelOptions|Highcharts.YAxisPlotBandsLabelOptions|Highcharts.ZAxisPlotBandsLabelOptions} Highcharts.AxisPlotBandsLabelOptions\n */\n /**\n * Options for plot lines on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesOptions|Highcharts.YAxisPlotLinesOptions|Highcharts.ZAxisPlotLinesOptions} Highcharts.AxisPlotLinesOptions\n */\n /**\n * Options for plot line labels on axes.\n *\n * @typedef {Highcharts.XAxisPlotLinesLabelOptions|Highcharts.YAxisPlotLinesLabelOptions|Highcharts.ZAxisPlotLinesLabelOptions} Highcharts.AxisPlotLinesLabelOptions\n */\n ('');\n /* *\n *\n * API Options\n *\n * */\n /**\n * An array of colored bands stretching across the plot area marking an\n * interval on the axis.\n *\n * In styled mode, the plot bands are styled by the `.highcharts-plot-band`\n * class in addition to the `className` option.\n *\n * @productdesc {highcharts}\n * In a gauge, a plot band on the Y axis (value axis) will stretch along the\n * perimeter of the gauge.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands\n */\n /**\n * Flag to decide if plotBand should be rendered across all panes.\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotBands.acrossPanes\n */\n /**\n * Border color for the plot band. Also requires `borderWidth` to be set.\n *\n * @type {Highcharts.ColorString}\n * @apioption xAxis.plotBands.borderColor\n */\n /**\n * Border width for the plot band. Also requires `borderColor` to be set.\n *\n * @type {number}\n * @default 0\n * @apioption xAxis.plotBands.borderWidth\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-band`,\n * to apply to each individual band.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotBands.className\n */\n /**\n * The color of the plot band.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Color band\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #e6e9ff\n * @apioption xAxis.plotBands.color\n */\n /**\n * An object defining mouse events for the plot band. Supported properties\n * are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotBands.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotBands.events.mouseover\n */\n /**\n * The start position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.from\n */\n /**\n * An id used for identifying the plot band in Axis.removePlotBand.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n * @sample {highstock} highcharts/xaxis/plotbands-id/\n * Remove plot band by id\n *\n * @type {string}\n * @apioption xAxis.plotBands.id\n */\n /**\n * The end position of the plot band in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Datetime axis\n * @sample {highcharts} highcharts/xaxis/plotbands-from/\n * Categorized axis\n * @sample {highstock} stock/xaxis/plotbands/\n * Plot band on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotBands.to\n */\n /**\n * The z index of the plot band within the chart, relative to other\n * elements. Using the same z index as another element may give\n * unpredictable results, as the last rendered element will be on top.\n * Values from 0 to 20 make sense.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-color/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotbands-zindex-above-series/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotBands.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @product highcharts highstock gantt\n * @apioption xAxis.plotBands.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @since 2.1\n * @apioption xAxis.plotBands.label.align\n */\n /**\n * Rotation of the text label in degrees .\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text\n *\n * @type {number}\n * @default 0\n * @since 2.1\n * @apioption xAxis.plotBands.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-band-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotBands.label.style\n */\n /**\n * The string text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotBands.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-rotation/\n * Vertical text in center position but text-aligned left\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotBands.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotBands.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot band. Can be one of\n * \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-verticalalign/\n * Vertically centered label\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default top\n * @since 2.1\n * @apioption xAxis.plotBands.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-align/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-label-y/\n * Label on x axis\n * @sample {highstock} stock/xaxis/plotbands-label/\n * Plot band with labels\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotBands.label.y\n */\n /**\n * An array of lines stretching across the plot area, marking a specific\n * value on one of the axes.\n *\n * In styled mode, the plot lines are styled by the\n * `.highcharts-plot-line` class in addition to the `className` option.\n *\n * @type {Array<*>}\n * @product highcharts highstock gantt\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Basic plot line\n * @sample {highcharts} highcharts/series-solidgauge/labels-auto-aligned/\n * Solid gauge plot line\n * @apioption xAxis.plotLines\n */\n /**\n * Flag to decide if plotLine should be rendered across all panes.\n *\n * @sample {highstock} stock/xaxis/plotlines-acrosspanes/\n * Plot lines on different panes\n *\n * @since 7.1.2\n * @product highstock\n * @type {boolean}\n * @default true\n * @apioption xAxis.plotLines.acrossPanes\n */\n /**\n * A custom class name, in addition to the default `highcharts-plot-line`,\n * to apply to each individual line.\n *\n * @type {string}\n * @since 5.0.0\n * @apioption xAxis.plotLines.className\n */\n /**\n * The color of the line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * A red line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.ColorString}\n * @default #999999\n * @apioption xAxis.plotLines.color\n */\n /**\n * The dashing or dot style for the plot line. For possible values see\n * [this overview](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-dashstyle/\n * Dash and dot pattern\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 1.2\n * @apioption xAxis.plotLines.dashStyle\n */\n /**\n * An object defining mouse events for the plot line. Supported\n * properties are `click`, `mouseover`, `mouseout`, `mousemove`.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-events/\n * Mouse events demonstrated\n *\n * @since 1.2\n * @apioption xAxis.plotLines.events\n */\n /**\n * Click event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.click\n */\n /**\n * Mouse move event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mousemove\n */\n /**\n * Mouse out event on the corner of a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseout\n */\n /**\n * Mouse over event on a plot band.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @apioption xAxis.plotLines.events.mouseover\n */\n /**\n * An id used for identifying the plot line in Axis.removePlotLine.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-id/\n * Remove plot line by id\n *\n * @type {string}\n * @apioption xAxis.plotLines.id\n */\n /**\n * The position of the line in axis units.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * Between two categories on X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @apioption xAxis.plotLines.value\n */\n /**\n * The width or thickness of the plot line.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-color/\n * 2px wide line from X axis\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @default 2\n * @apioption xAxis.plotLines.width\n */\n /**\n * The z index of the plot line within the chart.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-behind/\n * Behind plot lines by default\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above/\n * Above plot lines\n * @sample {highcharts} highcharts/xaxis/plotlines-zindex-above-all/\n * Above plot lines and series\n *\n * @type {number}\n * @since 1.2\n * @apioption xAxis.plotLines.zIndex\n */\n /**\n * Text labels for the plot bands\n *\n * @apioption xAxis.plotLines.label\n */\n /**\n * Horizontal alignment of the label. Can be one of \"left\", \"center\" or\n * \"right\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned to the right\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {Highcharts.AlignValue}\n * @default left\n * @since 2.1\n * @apioption xAxis.plotLines.label.align\n */\n /**\n * Whether to hide labels that are outside the plot area.\n *\n * @type {boolean}\n * @default false\n * @since 10.3.3\n * @apioption xAxis.plotLines.labels.clip\n */\n /**\n * Callback JavaScript function to format the label. Useful properties like\n * the value of plot line or the range of plot band (`from` & `to`\n * properties) can be found in `this.options` object.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-plotbands-label-formatter\n * Label formatters for plot line and plot band.\n * @type {Highcharts.FormatterCallbackFunction}\n * @apioption xAxis.plotLines.label.formatter\n */\n /**\n * Rotation of the text label in degrees. Defaults to 0 for horizontal plot\n * lines and 90 for vertical lines.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Slanted text\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.rotation\n */\n /**\n * CSS styles for the text label.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-plot-line-label` class.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-style/\n * Blue and bold label\n *\n * @type {Highcharts.CSSObject}\n * @since 2.1\n * @apioption xAxis.plotLines.label.style\n */\n /**\n * The text itself. A subset of HTML is supported.\n *\n * @type {string}\n * @since 2.1\n * @apioption xAxis.plotLines.label.text\n */\n /**\n * The text alignment for the label. While `align` determines where the\n * texts anchor point is placed within the plot band, `textAlign` determines\n * how the text is aligned against its anchor point. Possible values are\n * \"left\", \"center\" and \"right\". Defaults to the same as the `align` option.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-textalign/\n * Text label in bottom position\n *\n * @type {Highcharts.AlignValue}\n * @since 2.1\n * @apioption xAxis.plotLines.label.textAlign\n */\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @since 3.0.3\n * @apioption xAxis.plotLines.label.useHTML\n */\n /**\n * Vertical alignment of the label relative to the plot line. Can be\n * one of \"top\", \"middle\" or \"bottom\".\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-verticalalign-middle/\n * Vertically centered label\n *\n * @type {Highcharts.VerticalAlignValue}\n * @default {highcharts} top\n * @default {highstock} top\n * @since 2.1\n * @apioption xAxis.plotLines.label.verticalAlign\n */\n /**\n * Horizontal position relative the alignment. Default varies by\n * orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-align-right/\n * Aligned 10px from the right edge\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.x\n */\n /**\n * Vertical position of the text baseline relative to the alignment. Default\n * varies by orientation.\n *\n * @sample {highcharts} highcharts/xaxis/plotlines-label-y/\n * Label below the plot line\n * @sample {highstock} stock/xaxis/plotlines/\n * Plot line on Y axis\n *\n * @type {number}\n * @since 2.1\n * @apioption xAxis.plotLines.label.y\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotBands\n * @apioption yAxis.plotBands\n */\n /**\n * In a gauge chart, this option determines the inner radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n * By default, the inner radius is controlled by the [thickness](\n * #yAxis.plotBands.thickness) option.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.innerRadius\n */\n /**\n * In a gauge chart, this option determines the outer radius of the\n * plot band that stretches along the perimeter. It can be given as\n * a percentage string, like `\"100%\"`, or as a pixel number, like `100`.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 100%\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.outerRadius\n */\n /**\n * In a gauge chart, this option sets the width of the plot band\n * stretching along the perimeter. It can be given as a percentage\n * string, like `\"10%\"`, or as a pixel number, like `10`. The default\n * value 10 is the same as the default [tickLength](#yAxis.tickLength),\n * thus making the plot band act as a background for the tick markers.\n *\n * @sample {highcharts} highcharts/xaxis/plotbands-gauge\n * Gauge plot band\n *\n * @type {number|string}\n * @default 10\n * @since 2.3\n * @product highcharts\n * @apioption yAxis.plotBands.thickness\n */\n /**\n * @type {Array<*>}\n * @extends xAxis.plotLines\n * @apioption yAxis.plotLines\n */\n (''); // keeps doclets above in JS file\n\n return PlotLineOrBand;\n });\n _registerModule(_modules, 'Core/Tooltip.js', [_modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (F, H, R, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = F;\n const { doc, isSafari } = H;\n const { distribute } = R;\n const { addEvent, clamp, css, discardElement, extend, fireEvent, isArray, isNumber, isString, merge, pick, splat, syncTimeout } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Tooltip of a chart.\n *\n * @class\n * @name Highcharts.Tooltip\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n class Tooltip {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allowShared = true;\n this.container = void 0;\n this.crosshairs = [];\n this.distance = 0;\n this.isHidden = true;\n this.isSticky = false;\n this.now = {};\n this.options = {};\n this.outside = false;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Build the body (lines) of the tooltip by iterating over the items and\n * returning one entry for each item, abstracting this functionality allows\n * to easily overwrite and extend it.\n *\n * @private\n * @function Highcharts.Tooltip#bodyFormatter\n */\n bodyFormatter(items) {\n return items.map(function (item) {\n const tooltipOptions = item.series.tooltipOptions;\n return (tooltipOptions[(item.point.formatPrefix || 'point') + 'Formatter'] ||\n item.point.tooltipFormatter).call(item.point, tooltipOptions[(item.point.formatPrefix || 'point') + 'Format'] || '');\n });\n }\n /**\n * Destroy the single tooltips in a split tooltip.\n * If the tooltip is active then it is not destroyed, unless forced to.\n *\n * @private\n * @function Highcharts.Tooltip#cleanSplit\n *\n * @param {boolean} [force]\n * Force destroy all tooltips.\n */\n cleanSplit(force) {\n this.chart.series.forEach(function (series) {\n const tt = series && series.tt;\n if (tt) {\n if (!tt.isActive || force) {\n series.tt = tt.destroy();\n }\n else {\n tt.isActive = false;\n }\n }\n });\n }\n /**\n * In case no user defined formatter is given, this will be used. Note that\n * the context here is an object holding point, series, x, y etc.\n *\n * @function Highcharts.Tooltip#defaultFormatter\n *\n * @param {Highcharts.Tooltip} tooltip\n *\n * @return {string|Array}\n * Returns a string (single tooltip and shared)\n * or an array of strings (split tooltip)\n */\n defaultFormatter(tooltip) {\n const items = this.points || splat(this);\n let s;\n // Build the header\n s = [tooltip.tooltipFooterHeaderFormatter(items[0])];\n // build the values\n s = s.concat(tooltip.bodyFormatter(items));\n // footer\n s.push(tooltip.tooltipFooterHeaderFormatter(items[0], true));\n return s;\n }\n /**\n * Removes and destroys the tooltip and its elements.\n *\n * @function Highcharts.Tooltip#destroy\n */\n destroy() {\n // Destroy and clear local variables\n if (this.label) {\n this.label = this.label.destroy();\n }\n if (this.split) {\n this.cleanSplit(true);\n if (this.tt) {\n this.tt = this.tt.destroy();\n }\n }\n if (this.renderer) {\n this.renderer = this.renderer.destroy();\n discardElement(this.container);\n }\n U.clearTimeout(this.hideTimer);\n U.clearTimeout(this.tooltipTimeout);\n }\n /**\n * Extendable method to get the anchor position of the tooltip\n * from a point or set of points\n *\n * @private\n * @function Highcharts.Tooltip#getAnchor\n */\n getAnchor(points, mouseEvent) {\n const chart = this.chart, pointer = chart.pointer, inverted = chart.inverted, plotTop = chart.plotTop, plotLeft = chart.plotLeft;\n let ret;\n points = splat(points);\n // If reversedStacks are false the tooltip position should be taken from\n // the last point (#17948)\n if (points[0].series &&\n points[0].series.yAxis &&\n !points[0].series.yAxis.options.reversedStacks) {\n points = points.slice().reverse();\n }\n // When tooltip follows mouse, relate the position to the mouse\n if (this.followPointer && mouseEvent) {\n if (typeof mouseEvent.chartX === 'undefined') {\n mouseEvent = pointer.normalize(mouseEvent);\n }\n ret = [\n mouseEvent.chartX - plotLeft,\n mouseEvent.chartY - plotTop\n ];\n // Some series types use a specificly calculated tooltip position for\n // each point\n }\n else if (points[0].tooltipPos) {\n ret = points[0].tooltipPos;\n // Calculate the average position and adjust for axis positions\n }\n else {\n let chartX = 0, chartY = 0;\n points.forEach(function (point) {\n const pos = point.pos(true);\n if (pos) {\n chartX += pos[0];\n chartY += pos[1];\n }\n });\n chartX /= points.length;\n chartY /= points.length;\n // When shared, place the tooltip next to the mouse (#424)\n if (this.shared && points.length > 1 && mouseEvent) {\n if (inverted) {\n chartX = mouseEvent.chartX;\n }\n else {\n chartY = mouseEvent.chartY;\n }\n }\n // Use the average position for multiple points\n ret = [chartX - plotLeft, chartY - plotTop];\n }\n return ret.map(Math.round);\n }\n /**\n * Get the CSS class names for the tooltip's label. Styles the label\n * by `colorIndex` or user-defined CSS.\n *\n * @function Highcharts.Tooltip#getClassName\n *\n * @return {string}\n * The class names.\n */\n getClassName(point, isSplit, isHeader) {\n const options = this.options, series = point.series, seriesOptions = series.options;\n return [\n options.className,\n 'highcharts-label',\n isHeader && 'highcharts-tooltip-header',\n isSplit ? 'highcharts-tooltip-box' : 'highcharts-tooltip',\n !isHeader && 'highcharts-color-' + pick(point.colorIndex, series.colorIndex),\n (seriesOptions && seriesOptions.className)\n ].filter(isString).join(' ');\n }\n /**\n * Creates the Tooltip label element if it does not exist, then returns it.\n *\n * @function Highcharts.Tooltip#getLabel\n *\n * @return {Highcharts.SVGElement}\n * Tooltip label\n */\n getLabel() {\n const tooltip = this, styledMode = this.chart.styledMode, options = this.options, doSplit = this.split && this.allowShared, pointerEvents = (options.style.pointerEvents ||\n (this.shouldStickOnContact() ? 'auto' : 'none'));\n let container, renderer = this.chart.renderer;\n // If changing from a split tooltip to a non-split tooltip, we must\n // destroy it in order to get the SVG right. #13868.\n if (this.label) {\n const wasSplit = !this.label.hasClass('highcharts-label');\n if ((!doSplit && wasSplit) || (doSplit && !wasSplit)) {\n this.destroy();\n }\n }\n if (!this.label) {\n if (this.outside) {\n const chartStyle = this.chart.options.chart.style, Renderer = RendererRegistry.getRendererType();\n /**\n * Reference to the tooltip's container, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#container\n * @type {Highcharts.HTMLDOMElement|undefined}\n */\n this.container = container = H.doc.createElement('div');\n container.className = 'highcharts-tooltip-container';\n css(container, {\n position: 'absolute',\n top: '1px',\n pointerEvents,\n zIndex: Math.max(this.options.style.zIndex || 0, (chartStyle && chartStyle.zIndex || 0) + 3)\n });\n H.doc.body.appendChild(container);\n /**\n * Reference to the tooltip's renderer, when\n * [Highcharts.Tooltip#outside] is set to true, otherwise\n * it's undefined.\n *\n * @name Highcharts.Tooltip#renderer\n * @type {Highcharts.SVGRenderer|undefined}\n */\n this.renderer = renderer = new Renderer(container, 0, 0, chartStyle, void 0, void 0, renderer.styledMode);\n }\n // Create the label\n if (doSplit) {\n this.label = renderer.g('tooltip');\n }\n else {\n this.label = renderer\n .label('', 0, 0, options.shape, void 0, void 0, options.useHTML, void 0, 'tooltip')\n .attr({\n padding: options.padding,\n r: options.borderRadius\n });\n if (!styledMode) {\n this.label\n .attr({\n fill: options.backgroundColor,\n 'stroke-width': options.borderWidth || 0\n })\n // #2301, #2657\n .css(options.style)\n .css({ pointerEvents });\n }\n }\n // Split tooltip use updateTooltipContainer to position the tooltip\n // container.\n if (tooltip.outside) {\n const label = this.label;\n const { xSetter, ySetter } = label;\n label.xSetter = function (value) {\n xSetter.call(label, tooltip.distance);\n container.style.left = value + 'px';\n };\n label.ySetter = function (value) {\n ySetter.call(label, tooltip.distance);\n container.style.top = value + 'px';\n };\n }\n this.label\n .attr({ zIndex: 8 })\n .shadow(options.shadow)\n .add();\n }\n return this.label;\n }\n /**\n * Get the total area available area to place the tooltip\n *\n * @private\n */\n getPlayingField() {\n const { body, documentElement } = doc, { chart, distance, outside } = this;\n return {\n width: outside ?\n // Substract distance to prevent scrollbars\n Math.max(body.scrollWidth, documentElement.scrollWidth, body.offsetWidth, documentElement.offsetWidth, documentElement.clientWidth) - 2 * distance :\n chart.chartWidth,\n height: outside ?\n Math.max(body.scrollHeight, documentElement.scrollHeight, body.offsetHeight, documentElement.offsetHeight, documentElement.clientHeight) :\n chart.chartHeight\n };\n }\n /**\n * Place the tooltip in a chart without spilling over and not covering the\n * point itself.\n *\n * @function Highcharts.Tooltip#getPosition\n *\n * @param {number} boxWidth\n * Width of the tooltip box.\n *\n * @param {number} boxHeight\n * Height of the tooltip box.\n *\n * @param {Highcharts.Point} point\n * Tooltip related point.\n *\n * @return {Highcharts.PositionObject}\n * Recommended position of the tooltip.\n */\n getPosition(boxWidth, boxHeight, point) {\n const chart = this.chart, distance = this.distance, ret = {}, \n // Don't use h if chart isn't inverted (#7242) ???\n h = (chart.inverted && point.h) || 0, // #4117 ???\n outside = this.outside, playingField = this.getPlayingField(), outerWidth = playingField.width, outerHeight = playingField.height, chartPosition = chart.pointer.getChartPosition(), scaleX = (val) => ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleX), scaleY = (val) => ( // eslint-disable-line no-confusing-arrow\n val * chartPosition.scaleY), \n // Build parameter arrays for firstDimension()/secondDimension()\n buildDimensionArray = (dim) => {\n const isX = dim === 'x';\n return [\n dim,\n isX ? outerWidth : outerHeight,\n isX ? boxWidth : boxHeight\n ].concat(outside ? [\n // If we are using tooltip.outside, we need to scale the\n // position to match scaling of the container in case there\n // is a transform/zoom on the container. #11329\n isX ? scaleX(boxWidth) : scaleY(boxHeight),\n isX ? chartPosition.left - distance +\n scaleX(point.plotX + chart.plotLeft) :\n chartPosition.top - distance +\n scaleY(point.plotY + chart.plotTop),\n 0,\n isX ? outerWidth : outerHeight\n ] : [\n // Not outside, no scaling is needed\n isX ? boxWidth : boxHeight,\n isX ? point.plotX + chart.plotLeft :\n point.plotY + chart.plotTop,\n isX ? chart.plotLeft : chart.plotTop,\n isX ? chart.plotLeft + chart.plotWidth :\n chart.plotTop + chart.plotHeight\n ]);\n };\n let first = buildDimensionArray('y'), second = buildDimensionArray('x'), swapped;\n // Handle negative points or reversed axis (#13780)\n let flipped = !!point.negative;\n if (!chart.polar &&\n chart.hoverSeries &&\n chart.hoverSeries.yAxis &&\n chart.hoverSeries.yAxis.reversed) {\n flipped = !flipped;\n }\n // The far side is right or bottom\n const preferFarSide = !this.followPointer &&\n pick(point.ttBelow, !chart.inverted === flipped), // #4984\n /*\n * Handle the preferred dimension. When the preferred dimension is\n * tooltip on top or bottom of the point, it will look for space\n * there.\n *\n * @private\n */\n firstDimension = function (dim, outerSize, innerSize, scaledInnerSize, // #11329\n point, min, max) {\n const scaledDist = outside ?\n (dim === 'y' ? scaleY(distance) : scaleX(distance)) :\n distance, scaleDiff = (innerSize - scaledInnerSize) / 2, roomLeft = scaledInnerSize < point - distance, roomRight = point + distance + scaledInnerSize < outerSize, alignedLeft = point - scaledDist - innerSize + scaleDiff, alignedRight = point + scaledDist - scaleDiff;\n if (preferFarSide && roomRight) {\n ret[dim] = alignedRight;\n }\n else if (!preferFarSide && roomLeft) {\n ret[dim] = alignedLeft;\n }\n else if (roomLeft) {\n ret[dim] = Math.min(max - scaledInnerSize, alignedLeft - h < 0 ? alignedLeft : alignedLeft - h);\n }\n else if (roomRight) {\n ret[dim] = Math.max(min, alignedRight + h + innerSize > outerSize ?\n alignedRight :\n alignedRight + h);\n }\n else {\n return false;\n }\n }, \n /*\n * Handle the secondary dimension. If the preferred dimension is\n * tooltip on top or bottom of the point, the second dimension is to\n * align the tooltip above the point, trying to align center but\n * allowing left or right align within the chart box.\n *\n * @private\n */\n secondDimension = function (dim, outerSize, innerSize, scaledInnerSize, // #11329\n point) {\n let retVal;\n // Too close to the edge, return false and swap dimensions\n if (point < distance || point > outerSize - distance) {\n retVal = false;\n // Align left/top\n }\n else if (point < innerSize / 2) {\n ret[dim] = 1;\n // Align right/bottom\n }\n else if (point > outerSize - scaledInnerSize / 2) {\n ret[dim] = outerSize - scaledInnerSize - 2;\n // Align center\n }\n else {\n ret[dim] = point - innerSize / 2;\n }\n return retVal;\n }, \n /*\n * Swap the dimensions\n */\n swap = function (count) {\n const temp = first;\n first = second;\n second = temp;\n swapped = count;\n }, run = function () {\n if (firstDimension.apply(0, first) !== false) {\n if (secondDimension.apply(0, second) === false &&\n !swapped) {\n swap(true);\n run();\n }\n }\n else if (!swapped) {\n swap(true);\n run();\n }\n else {\n ret.x = ret.y = 0;\n }\n };\n // Under these conditions, prefer the tooltip on the side of the point\n if (chart.inverted || this.len > 1) {\n swap();\n }\n run();\n return ret;\n }\n /**\n * Hides the tooltip with a fade out animation.\n *\n * @function Highcharts.Tooltip#hide\n *\n * @param {number} [delay]\n * The fade out in milliseconds. If no value is provided the value\n * of the tooltip.hideDelay option is used. A value of 0 disables\n * the fade out animation.\n */\n hide(delay) {\n const tooltip = this;\n // disallow duplicate timers (#1728, #1766)\n U.clearTimeout(this.hideTimer);\n delay = pick(delay, this.options.hideDelay);\n if (!this.isHidden) {\n this.hideTimer = syncTimeout(function () {\n // If there is a delay, do fadeOut with the default duration. If\n // the hideDelay is 0, we assume no animation is wanted, so we\n // pass 0 duration. #12994.\n tooltip.getLabel().fadeOut(delay ? void 0 : delay);\n tooltip.isHidden = true;\n }, delay);\n }\n }\n /**\n * Initialize tooltip.\n *\n * @private\n * @function Highcharts.Tooltip#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.TooltipOptions} options\n * Tooltip options.\n */\n init(chart, options) {\n /**\n * Chart of the tooltip.\n *\n * @readonly\n * @name Highcharts.Tooltip#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n /**\n * Used tooltip options.\n *\n * @readonly\n * @name Highcharts.Tooltip#options\n * @type {Highcharts.TooltipOptions}\n */\n this.options = options;\n /**\n * List of crosshairs.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#crosshairs\n * @type {Array}\n */\n this.crosshairs = [];\n /**\n * Current values of x and y when animating.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#now\n * @type {Highcharts.PositionObject}\n */\n this.now = { x: 0, y: 0 };\n /**\n * Tooltips are initially hidden.\n *\n * @private\n * @readonly\n * @name Highcharts.Tooltip#isHidden\n * @type {boolean}\n */\n this.isHidden = true;\n /**\n * True, if the tooltip is split into one label per series, with the\n * header close to the axis.\n *\n * @readonly\n * @name Highcharts.Tooltip#split\n * @type {boolean|undefined}\n */\n this.split = options.split && !chart.inverted && !chart.polar;\n /**\n * When the tooltip is shared, the entire plot area will capture mouse\n * movement or touch events.\n *\n * @readonly\n * @name Highcharts.Tooltip#shared\n * @type {boolean|undefined}\n */\n this.shared = options.shared || this.split;\n /**\n * Whether to allow the tooltip to render outside the chart's SVG\n * element box. By default (false), the tooltip is rendered within the\n * chart's SVG element, which results in the tooltip being aligned\n * inside the chart area.\n *\n * @readonly\n * @name Highcharts.Tooltip#outside\n * @type {boolean}\n *\n * @todo\n * Split tooltip does not support outside in the first iteration. Should\n * not be too complicated to implement.\n */\n this.outside = pick(options.outside, Boolean(chart.scrollablePixelsX || chart.scrollablePixelsY));\n }\n shouldStickOnContact(pointerEvent) {\n return !!(!this.followPointer &&\n this.options.stickOnContact &&\n (!pointerEvent || this.chart.pointer.inClass(pointerEvent.target, 'highcharts-tooltip')));\n }\n /**\n * Moves the tooltip with a soft animation to a new position.\n *\n * @private\n * @function Highcharts.Tooltip#move\n *\n * @param {number} x\n *\n * @param {number} y\n *\n * @param {number} anchorX\n *\n * @param {number} anchorY\n */\n move(x, y, anchorX, anchorY) {\n const tooltip = this, now = tooltip.now, animate = tooltip.options.animation !== false &&\n !tooltip.isHidden &&\n // When we get close to the target position, abort animation and\n // land on the right place (#3056)\n (Math.abs(x - now.x) > 1 || Math.abs(y - now.y) > 1), skipAnchor = tooltip.followPointer || tooltip.len > 1;\n // Get intermediate values for animation\n extend(now, {\n x: animate ? (2 * now.x + x) / 3 : x,\n y: animate ? (now.y + y) / 2 : y,\n anchorX: skipAnchor ?\n void 0 :\n animate ? (2 * now.anchorX + anchorX) / 3 : anchorX,\n anchorY: skipAnchor ?\n void 0 :\n animate ? (now.anchorY + anchorY) / 2 : anchorY\n });\n // Move to the intermediate value\n tooltip.getLabel().attr(now);\n tooltip.drawTracker();\n // Run on next tick of the mouse tracker\n if (animate) {\n // Never allow two timeouts\n U.clearTimeout(this.tooltipTimeout);\n // Set the fixed interval ticking for the smooth tooltip\n this.tooltipTimeout = setTimeout(function () {\n // The interval function may still be running during destroy,\n // so check that the chart is really there before calling.\n if (tooltip) {\n tooltip.move(x, y, anchorX, anchorY);\n }\n }, 32);\n }\n }\n /**\n * Refresh the tooltip's text and position.\n *\n * @function Highcharts.Tooltip#refresh\n *\n * @param {Highcharts.Point|Array} pointOrPoints\n * Either a point or an array of points.\n *\n * @param {Highcharts.PointerEventObject} [mouseEvent]\n * Mouse event, that is responsible for the refresh and should be\n * used for the tooltip update.\n */\n refresh(pointOrPoints, mouseEvent) {\n const tooltip = this, chart = this.chart, options = tooltip.options, pointer = chart.pointer, points = splat(pointOrPoints), point = points[0], pointConfig = [], formatString = options.format, formatter = options.formatter || tooltip.defaultFormatter, shared = tooltip.shared, styledMode = chart.styledMode;\n let formatterContext = {};\n if (!options.enabled || !point.series) { // #16820\n return;\n }\n U.clearTimeout(this.hideTimer);\n // A switch saying if this specific tooltip configuration allows shared\n // or split modes\n tooltip.allowShared = !(!isArray(pointOrPoints) &&\n pointOrPoints.series &&\n pointOrPoints.series.noSharedTooltip);\n // get the reference point coordinates (pie charts use tooltipPos)\n tooltip.followPointer = (!tooltip.split && point.series.tooltipOptions.followPointer);\n const anchor = tooltip.getAnchor(pointOrPoints, mouseEvent), x = anchor[0], y = anchor[1];\n // shared tooltip, array is sent over\n if (shared && tooltip.allowShared) {\n pointer.applyInactiveState(points);\n // Now set hover state for the choosen ones:\n points.forEach(function (item) {\n item.setState('hover');\n pointConfig.push(item.getLabelConfig());\n });\n formatterContext = point.getLabelConfig();\n formatterContext.points = pointConfig;\n // single point tooltip\n }\n else {\n formatterContext = point.getLabelConfig();\n }\n this.len = pointConfig.length; // #6128\n const text = isString(formatString) ?\n format(formatString, formatterContext, chart) :\n formatter.call(formatterContext, tooltip);\n // register the current series\n const currentSeries = point.series;\n this.distance = pick(currentSeries.tooltipOptions.distance, 16);\n // update the inner HTML\n if (text === false) {\n this.hide();\n }\n else {\n // update text\n if (tooltip.split && tooltip.allowShared) { // #13868\n this.renderSplit(text, points);\n }\n else {\n let checkX = x;\n let checkY = y;\n if (mouseEvent && pointer.isDirectTouch) {\n checkX = mouseEvent.chartX - chart.plotLeft;\n checkY = mouseEvent.chartY - chart.plotTop;\n }\n // #11493, #13095\n if (chart.polar ||\n currentSeries.options.clip === false ||\n points.some((p) => // #16004\n pointer.isDirectTouch || // ##17929\n p.series.shouldShowTooltip(checkX, checkY))) {\n const label = tooltip.getLabel();\n // Prevent the tooltip from flowing over the chart box\n // (#6659)\n if (!options.style.width || styledMode) {\n label.css({\n width: (this.outside ?\n this.getPlayingField() :\n chart.spacingBox).width + 'px'\n });\n }\n label.attr({\n text: text && text.join ?\n text.join('') :\n text\n });\n // Set the stroke color of the box to reflect the point\n label.addClass(tooltip.getClassName(point), true);\n if (!styledMode) {\n label.attr({\n stroke: (options.borderColor ||\n point.color ||\n currentSeries.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n tooltip.updatePosition({\n plotX: x,\n plotY: y,\n negative: point.negative,\n ttBelow: point.ttBelow,\n h: anchor[2] || 0\n });\n }\n else {\n tooltip.hide();\n return;\n }\n }\n // show it\n if (tooltip.isHidden && tooltip.label) {\n tooltip.label.attr({\n opacity: 1\n }).show();\n }\n tooltip.isHidden = false;\n }\n fireEvent(this, 'refresh');\n }\n /**\n * Render the split tooltip. Loops over each point's text and adds\n * a label next to the point, then uses the distribute function to\n * find best non-overlapping positions.\n *\n * @private\n * @function Highcharts.Tooltip#renderSplit\n *\n * @param {string|Array<(boolean|string)>} labels\n *\n * @param {Array} points\n */\n renderSplit(labels, points) {\n const tooltip = this;\n const { chart, chart: { chartWidth, chartHeight, plotHeight, plotLeft, plotTop, pointer, scrollablePixelsY = 0, scrollablePixelsX, scrollingContainer: { scrollLeft, scrollTop } = { scrollLeft: 0, scrollTop: 0 }, styledMode }, distance, options, options: { positioner } } = tooltip;\n // The area which the tooltip should be limited to. Limit to scrollable\n // plot area if enabled, otherwise limit to the chart container. If\n // outside is true it should be the whole viewport\n const bounds = (tooltip.outside &&\n typeof scrollablePixelsX !== 'number') ?\n doc.documentElement.getBoundingClientRect() : {\n left: scrollLeft,\n right: scrollLeft + chartWidth,\n top: scrollTop,\n bottom: scrollTop + chartHeight\n };\n const tooltipLabel = tooltip.getLabel();\n const ren = this.renderer || chart.renderer;\n const headerTop = Boolean(chart.xAxis[0] && chart.xAxis[0].opposite);\n const { left: chartLeft, top: chartTop } = pointer.getChartPosition();\n let distributionBoxTop = plotTop + scrollTop;\n let headerHeight = 0;\n let adjustedPlotHeight = plotHeight - scrollablePixelsY;\n /**\n * Calculates the anchor position for the partial tooltip\n *\n * @private\n * @param {Highcharts.Point} point The point related to the tooltip\n * @return {Object} Returns an object with anchorX and anchorY\n */\n function getAnchor(point) {\n const { isHeader, plotX = 0, plotY = 0, series } = point;\n let anchorX;\n let anchorY;\n if (isHeader) {\n // Set anchorX to plotX\n anchorX = plotLeft + plotX;\n // Set anchorY to center of visible plot area.\n anchorY = plotTop + plotHeight / 2;\n }\n else {\n const { xAxis, yAxis } = series;\n // Set anchorX to plotX. Limit to within xAxis.\n anchorX = xAxis.pos + clamp(plotX, -distance, xAxis.len + distance);\n // Set anchorY, limit to the scrollable plot area\n if (series.shouldShowTooltip(0, yAxis.pos - plotTop + plotY, {\n ignoreX: true\n })) {\n anchorY = yAxis.pos + plotY;\n }\n }\n // Limit values to plot area\n anchorX = clamp(anchorX, bounds.left - distance, bounds.right + distance);\n return { anchorX, anchorY };\n }\n /**\n * Calculates the position of the partial tooltip\n *\n * @private\n * @param {number} anchorX\n * The partial tooltip anchor x position\n *\n * @param {number} anchorY\n * The partial tooltip anchor y position\n *\n * @param {boolean|undefined} isHeader\n * Whether the partial tooltip is a header\n *\n * @param {number} boxWidth\n * Width of the partial tooltip\n *\n * @return {Highcharts.PositionObject}\n * Returns the partial tooltip x and y position\n */\n function defaultPositioner(anchorX, anchorY, isHeader, boxWidth, alignedLeft = true) {\n let y;\n let x;\n if (isHeader) {\n y = headerTop ? 0 : adjustedPlotHeight;\n x = clamp(anchorX - (boxWidth / 2), bounds.left, bounds.right - boxWidth - (tooltip.outside ? chartLeft : 0));\n }\n else {\n y = anchorY - distributionBoxTop;\n x = alignedLeft ?\n anchorX - boxWidth - distance :\n anchorX + distance;\n x = clamp(x, alignedLeft ? x : bounds.left, bounds.right);\n }\n // NOTE: y is relative to distributionBoxTop\n return { x, y };\n }\n /**\n * Updates the attributes and styling of the partial tooltip. Creates a\n * new partial tooltip if it does not exists.\n *\n * @private\n * @param {Highcharts.SVGElement|undefined} partialTooltip\n * The partial tooltip to update\n * @param {Highcharts.Point} point\n * The point related to the partial tooltip\n * @param {boolean|string} str The text for the partial tooltip\n * @return {Highcharts.SVGElement} Returns the updated partial tooltip\n */\n function updatePartialTooltip(partialTooltip, point, str) {\n var _a;\n let tt = partialTooltip;\n const { isHeader, series } = point;\n if (!tt) {\n const attribs = {\n padding: options.padding,\n r: options.borderRadius\n };\n if (!styledMode) {\n attribs.fill = options.backgroundColor;\n attribs['stroke-width'] = (_a = options.borderWidth) !== null && _a !== void 0 ? _a : 1;\n }\n tt = ren\n .label('', 0, 0, (options[isHeader ? 'headerShape' : 'shape']), void 0, void 0, options.useHTML)\n .addClass(tooltip.getClassName(point, true, isHeader))\n .attr(attribs)\n .add(tooltipLabel);\n }\n tt.isActive = true;\n tt.attr({\n text: str\n });\n if (!styledMode) {\n tt.css(options.style)\n .attr({\n stroke: (options.borderColor ||\n point.color ||\n series.color ||\n \"#333333\" /* Palette.neutralColor80 */)\n });\n }\n return tt;\n }\n // Graceful degradation for legacy formatters\n if (isString(labels)) {\n labels = [false, labels];\n }\n // Create the individual labels for header and points, ignore footer\n let boxes = labels.slice(0, points.length + 1).reduce(function (boxes, str, i) {\n if (str !== false && str !== '') {\n const point = (points[i - 1] ||\n {\n // Item 0 is the header. Instead of this, we could also\n // use the crosshair label\n isHeader: true,\n plotX: points[0].plotX,\n plotY: plotHeight,\n series: {}\n });\n const isHeader = point.isHeader;\n // Store the tooltip label referance on the series\n const owner = isHeader ? tooltip : point.series;\n const tt = owner.tt = updatePartialTooltip(owner.tt, point, str.toString());\n // Get X position now, so we can move all to the other side in\n // case of overflow\n const bBox = tt.getBBox();\n const boxWidth = bBox.width + tt.strokeWidth();\n if (isHeader) {\n headerHeight = bBox.height;\n adjustedPlotHeight += headerHeight;\n if (headerTop) {\n distributionBoxTop -= headerHeight;\n }\n }\n const { anchorX, anchorY } = getAnchor(point);\n if (typeof anchorY === 'number') {\n const size = bBox.height + 1;\n const boxPosition = (positioner ?\n positioner.call(tooltip, boxWidth, size, point) :\n defaultPositioner(anchorX, anchorY, isHeader, boxWidth));\n boxes.push({\n // 0-align to the top, 1-align to the bottom\n align: positioner ? 0 : void 0,\n anchorX,\n anchorY,\n boxWidth,\n point,\n rank: pick(boxPosition.rank, isHeader ? 1 : 0),\n size,\n target: boxPosition.y,\n tt,\n x: boxPosition.x\n });\n }\n else {\n // Hide tooltips which anchorY is outside the visible plot\n // area\n tt.isActive = false;\n }\n }\n return boxes;\n }, []);\n // Realign the tooltips towards the right if there is not enough space\n // to the left and there is space to to the right\n if (!positioner && boxes.some((box) => {\n // Always realign if the beginning of a label is outside bounds\n const { outside } = tooltip;\n const boxStart = (outside ? chartLeft : 0) + box.anchorX;\n if (boxStart < bounds.left &&\n boxStart + box.boxWidth < bounds.right) {\n return true;\n }\n // Otherwise, check if there is more space available to the right\n return boxStart < (chartLeft - bounds.left) + box.boxWidth &&\n bounds.right - boxStart > boxStart;\n })) {\n boxes = boxes.map((box) => {\n const { x, y } = defaultPositioner(box.anchorX, box.anchorY, box.point.isHeader, box.boxWidth, false);\n return extend(box, {\n target: y,\n x\n });\n });\n }\n // Clean previous run (for missing points)\n tooltip.cleanSplit();\n // Distribute and put in place\n distribute(boxes, adjustedPlotHeight);\n const boxExtremes = {\n left: chartLeft,\n right: chartLeft\n };\n // Get the extremes from series tooltips\n boxes.forEach(function (box) {\n const { x, boxWidth, isHeader } = box;\n if (!isHeader) {\n if (tooltip.outside && chartLeft + x < boxExtremes.left) {\n boxExtremes.left = chartLeft + x;\n }\n if (!isHeader &&\n tooltip.outside &&\n boxExtremes.left + boxWidth > boxExtremes.right) {\n boxExtremes.right = chartLeft + x;\n }\n }\n });\n boxes.forEach(function (box) {\n const { x, anchorX, anchorY, pos, point: { isHeader } } = box;\n const attributes = {\n visibility: typeof pos === 'undefined' ? 'hidden' : 'inherit',\n x,\n /* NOTE: y should equal pos to be consistent with !split\n * tooltip, but is currently relative to plotTop. Is left as is\n * to avoid breaking change. Remove distributionBoxTop to make\n * it consistent.\n */\n y: (pos || 0) + distributionBoxTop,\n anchorX,\n anchorY\n };\n // Handle left-aligned tooltips overflowing the chart area\n if (tooltip.outside && x < anchorX) {\n const offset = chartLeft - boxExtremes.left;\n // Skip this if there is no overflow\n if (offset > 0) {\n if (!isHeader) {\n attributes.x = x + offset;\n attributes.anchorX = anchorX + offset;\n }\n if (isHeader) {\n attributes.x = (boxExtremes.right - boxExtremes.left) / 2;\n attributes.anchorX = anchorX + offset;\n }\n }\n }\n // Put the label in place\n box.tt.attr(attributes);\n });\n /* If we have a seperate tooltip container, then update the necessary\n * container properties.\n * Test that tooltip has its own container and renderer before executing\n * the operation.\n */\n const { container, outside, renderer } = tooltip;\n if (outside && container && renderer) {\n // Set container size to fit the bounds\n const { width, height, x, y } = tooltipLabel.getBBox();\n renderer.setSize(width + x, height + y, false);\n // Position the tooltip container to the chart container\n container.style.left = boxExtremes.left + 'px';\n container.style.top = chartTop + 'px';\n }\n // Workaround for #18927, artefacts left by the shadows of split\n // tooltips in Safari v16 (2023). Check again with later versions if we\n // can remove this.\n if (isSafari) {\n tooltipLabel.attr({\n // Force a redraw of the whole group by chaning the opacity\n // slightly\n opacity: tooltipLabel.opacity === 1 ? 0.999 : 1\n });\n }\n }\n /**\n * If the `stickOnContact` option is active, this will add a tracker shape.\n *\n * @private\n * @function Highcharts.Tooltip#drawTracker\n */\n drawTracker() {\n const tooltip = this;\n if (!this.shouldStickOnContact()) {\n if (tooltip.tracker) {\n tooltip.tracker = tooltip.tracker.destroy();\n }\n return;\n }\n const chart = tooltip.chart;\n const label = tooltip.label;\n const points = tooltip.shared ? chart.hoverPoints : chart.hoverPoint;\n if (!label || !points) {\n return;\n }\n const box = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n // Combine anchor and tooltip\n const anchorPos = this.getAnchor(points);\n const labelBBox = label.getBBox();\n anchorPos[0] += chart.plotLeft - label.translateX;\n anchorPos[1] += chart.plotTop - label.translateY;\n // When the mouse pointer is between the anchor point and the label,\n // the label should stick.\n box.x = Math.min(0, anchorPos[0]);\n box.y = Math.min(0, anchorPos[1]);\n box.width = (anchorPos[0] < 0 ?\n Math.max(Math.abs(anchorPos[0]), (labelBBox.width - anchorPos[0])) :\n Math.max(Math.abs(anchorPos[0]), labelBBox.width));\n box.height = (anchorPos[1] < 0 ?\n Math.max(Math.abs(anchorPos[1]), (labelBBox.height - Math.abs(anchorPos[1]))) :\n Math.max(Math.abs(anchorPos[1]), labelBBox.height));\n if (tooltip.tracker) {\n tooltip.tracker.attr(box);\n }\n else {\n tooltip.tracker = label.renderer\n .rect(box)\n .addClass('highcharts-tracker')\n .add(label);\n if (!chart.styledMode) {\n tooltip.tracker.attr({\n fill: 'rgba(0,0,0,0)'\n });\n }\n }\n }\n /**\n * @private\n */\n styledModeFormat(formatString) {\n return formatString\n .replace('style=\"font-size: 0.8em\"', 'class=\"highcharts-header\"')\n .replace(/style=\"color:{(point|series)\\.color}\"/g, 'class=\"highcharts-color-{$1.colorIndex} ' +\n '{series.options.className} ' +\n '{point.options.className}\"');\n }\n /**\n * Format the footer/header of the tooltip\n * #3397: abstraction to enable formatting of footer and header\n *\n * @private\n * @function Highcharts.Tooltip#tooltipFooterHeaderFormatter\n */\n tooltipFooterHeaderFormatter(labelConfig, isFooter) {\n const series = labelConfig.series, tooltipOptions = series.tooltipOptions, xAxis = series.xAxis, dateTime = xAxis && xAxis.dateTime, e = {\n isFooter: isFooter,\n labelConfig: labelConfig\n };\n let xDateFormat = tooltipOptions.xDateFormat, formatString = tooltipOptions[isFooter ? 'footerFormat' : 'headerFormat'];\n fireEvent(this, 'headerFormatter', e, function (e) {\n // Guess the best date format based on the closest point distance\n // (#568, #3418)\n if (dateTime && !xDateFormat && isNumber(labelConfig.key)) {\n xDateFormat = dateTime.getXDateFormat(labelConfig.key, tooltipOptions.dateTimeLabelFormats);\n }\n // Insert the footer date format if any\n if (dateTime && xDateFormat) {\n ((labelConfig.point && labelConfig.point.tooltipDateKeys) ||\n ['key']).forEach(function (key) {\n formatString = formatString.replace('{point.' + key + '}', '{point.' + key + ':' + xDateFormat + '}');\n });\n }\n // Replace default header style with class name\n if (series.chart.styledMode) {\n formatString = this.styledModeFormat(formatString);\n }\n e.text = format(formatString, {\n point: labelConfig,\n series: series\n }, this.chart);\n });\n return e.text;\n }\n /**\n * Updates the tooltip with the provided tooltip options.\n *\n * @function Highcharts.Tooltip#update\n *\n * @param {Highcharts.TooltipOptions} options\n * The tooltip options to update.\n */\n update(options) {\n this.destroy();\n this.init(this.chart, merge(true, this.options, options));\n }\n /**\n * Find the new position and perform the move\n *\n * @private\n * @function Highcharts.Tooltip#updatePosition\n *\n * @param {Highcharts.Point} point\n */\n updatePosition(point) {\n const { chart, distance, options } = this, pointer = chart.pointer, label = this.getLabel(), \n // Needed for outside: true (#11688)\n { left, top, scaleX, scaleY } = pointer.getChartPosition(), pos = (options.positioner || this.getPosition).call(this, label.width, label.height, point);\n let anchorX = (point.plotX || 0) + chart.plotLeft, anchorY = (point.plotY || 0) + chart.plotTop, pad;\n // Set the renderer size dynamically to prevent document size to change\n if (this.outside) {\n // Corrects positions, occurs with tooltip positioner (#16944)\n if (options.positioner) {\n pos.x += left - distance;\n pos.y += top - distance;\n }\n pad = (options.borderWidth || 0) + 2 * distance;\n this.renderer.setSize(label.width + pad, label.height + pad, false);\n // Anchor and tooltip container need scaling if chart container has\n // scale transform/css zoom. #11329.\n if (scaleX !== 1 || scaleY !== 1) {\n css(this.container, {\n transform: `scale(${scaleX}, ${scaleY})`\n });\n anchorX *= scaleX;\n anchorY *= scaleY;\n }\n anchorX += left - pos.x;\n anchorY += top - pos.y;\n }\n // do the move\n this.move(Math.round(pos.x), Math.round(pos.y || 0), // can be undefined (#3977)\n anchorX, anchorY);\n }\n }\n /* *\n *\n * Class namespace\n *\n * */\n (function (Tooltip) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(PointerClass) {\n if (U.pushUnique(composedMembers, PointerClass)) {\n addEvent(PointerClass, 'afterInit', function () {\n const chart = this.chart;\n if (chart.options.tooltip) {\n /**\n * Tooltip object for points of series.\n *\n * @name Highcharts.Chart#tooltip\n * @type {Highcharts.Tooltip}\n */\n chart.tooltip = new Tooltip(chart, chart.options.tooltip);\n }\n });\n }\n }\n Tooltip.compose = compose;\n })(Tooltip || (Tooltip = {}));\n /* *\n *\n * Default export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback function to format the text of the tooltip from scratch.\n *\n * In case of single or shared tooltips, a string should be be returned. In case\n * of splitted tooltips, it should return an array where the first item is the\n * header, and subsequent items are mapped to the points. Return `false` to\n * disable tooltip for a specific point on series.\n *\n * @callback Highcharts.TooltipFormatterCallbackFunction\n *\n * @param {Highcharts.TooltipFormatterContextObject} this\n * Context to format\n *\n * @param {Highcharts.Tooltip} tooltip\n * The tooltip instance\n *\n * @return {false|string|Array<(string|null|undefined)>|null|undefined}\n * Formatted text or false\n */\n /**\n * Configuration for the tooltip formatters.\n *\n * @interface Highcharts.TooltipFormatterContextObject\n * @extends Highcharts.PointLabelObject\n */ /**\n * Array of points in shared tooltips.\n * @name Highcharts.TooltipFormatterContextObject#points\n * @type {Array|undefined}\n */\n /**\n * A callback function to place the tooltip in a specific position.\n *\n * @callback Highcharts.TooltipPositionerCallbackFunction\n *\n * @param {Highcharts.Tooltip} this\n * Tooltip context of the callback.\n *\n * @param {number} labelWidth\n * Width of the tooltip.\n *\n * @param {number} labelHeight\n * Height of the tooltip.\n *\n * @param {Highcharts.TooltipPositionerPointObject} point\n * Point information for positioning a tooltip.\n *\n * @return {Highcharts.PositionObject}\n * New position for the tooltip.\n */\n /**\n * Point information for positioning a tooltip.\n *\n * @interface Highcharts.TooltipPositionerPointObject\n * @extends Highcharts.Point\n */ /**\n * If `tooltip.split` option is enabled and positioner is called for each of the\n * boxes separately, this property indicates the call on the xAxis header, which\n * is not a point itself.\n * @name Highcharts.TooltipPositionerPointObject#isHeader\n * @type {boolean}\n */ /**\n * The reference point relative to the plot area. Add chart.plotLeft to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotX\n * @type {number}\n */ /**\n * The reference point relative to the plot area. Add chart.plotTop to get the\n * full coordinates.\n * @name Highcharts.TooltipPositionerPointObject#plotY\n * @type {number}\n */\n /**\n * @typedef {\"callout\"|\"circle\"|\"square\"} Highcharts.TooltipShapeValue\n */\n ''; // keeps doclets above in JS file\n\n return Tooltip;\n });\n _registerModule(_modules, 'Core/Series/Point.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/Templating.js'], _modules['Core/Utilities.js']], function (AST, A, D, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject } = A;\n const { defaultOptions } = D;\n const { format } = F;\n const { addEvent, defined, erase, extend, fireEvent, getNestedProperty, isArray, isFunction, isNumber, isObject, merge, objectEach, pick, syncTimeout, removeEvent, uniqueKey } = U;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /* *\n *\n * Class\n *\n * */\n /**\n * The Point object. The point objects are generated from the `series.data`\n * configuration objects or raw numbers. They can be accessed from the\n * `Series.points` array. Other ways to instantiate points are through {@link\n * Highcharts.Series#addPoint} or {@link Highcharts.Series#setData}.\n *\n * @class\n * @name Highcharts.Point\n */\n class Point {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n /**\n * For categorized axes this property holds the category name for the\n * point. For other axes it holds the X value.\n *\n * @name Highcharts.Point#category\n * @type {number|string}\n */\n this.category = void 0;\n this.destroyed = false;\n this.formatPrefix = 'point';\n this.id = void 0;\n this.isNull = false;\n /**\n * The name of the point. The name can be given as the first position of the\n * point configuration array, or as a `name` property in the configuration:\n *\n * @example\n * // Array config\n * data: [\n * ['John', 1],\n * ['Jane', 2]\n * ]\n *\n * // Object config\n * data: [{\n * name: 'John',\n * y: 1\n * }, {\n * name: 'Jane',\n * y: 2\n * }]\n *\n * @name Highcharts.Point#name\n * @type {string}\n */\n this.name = void 0;\n /**\n * The point's options as applied in the initial configuration, or\n * extended through `Point.update`.\n *\n * In TypeScript you have to extend `PointOptionsObject` via an\n * additional interface to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @name Highcharts.Point#options\n * @type {Highcharts.PointOptionsObject}\n */\n this.options = void 0;\n /**\n * The percentage for points in a stacked series, pies or gauges.\n *\n * @name Highcharts.Point#percentage\n * @type {number|undefined}\n */\n this.percentage = void 0;\n this.selected = false;\n /**\n * The series object associated with the point.\n *\n * @name Highcharts.Point#series\n * @type {Highcharts.Series}\n */\n this.series = void 0;\n /**\n * The attributes of the rendered SVG shape like in `column` or `pie`\n * series.\n *\n * @readonly\n * @name Highcharts.Point#shapeArgs\n * @type {Readonly|undefined}\n */\n this.shapeArgs = void 0;\n /**\n * The total of values in either a stack for stacked series, or a pie in a\n * pie series.\n *\n * @name Highcharts.Point#total\n * @type {number|undefined}\n */\n this.total = void 0;\n /**\n * For certain series types, like pie charts, where individual points can\n * be shown or hidden.\n *\n * @name Highcharts.Point#visible\n * @type {boolean}\n * @default true\n */\n this.visible = true;\n this.x = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Animate SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#animateBeforeDestroy\n */\n animateBeforeDestroy() {\n const point = this, animateParams = { x: point.startXPos, opacity: 0 }, graphicalProps = point.getGraphicalProps();\n graphicalProps.singular.forEach(function (prop) {\n const isDataLabel = prop === 'dataLabel';\n point[prop] = point[prop].animate(isDataLabel ? {\n x: point[prop].startXPos,\n y: point[prop].startYPos,\n opacity: 0\n } : animateParams);\n });\n graphicalProps.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item.element) {\n item.animate(extend({ x: point.startXPos }, (item.startYPos ? {\n x: item.startXPos,\n y: item.startYPos\n } : {})));\n }\n });\n });\n }\n /**\n * Apply the options containing the x and y data and possible some extra\n * properties. Called on point init or from point.update.\n *\n * @private\n * @function Highcharts.Point#applyOptions\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options as defined in series.data.\n *\n * @param {number} [x]\n * Optionally, the x value.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n */\n applyOptions(options, x) {\n const point = this, series = point.series, pointValKey = series.options.pointValKey || series.pointValKey;\n options = Point.prototype.optionsToObject.call(this, options);\n // copy options directly to point\n extend(point, options);\n point.options = point.options ?\n extend(point.options, options) :\n options;\n // Since options are copied into the Point instance, some accidental\n // options must be shielded (#5681)\n if (options.group) {\n delete point.group;\n }\n if (options.dataLabels) {\n delete point.dataLabels;\n }\n /**\n * The y value of the point.\n * @name Highcharts.Point#y\n * @type {number|undefined}\n */\n // For higher dimension series types. For instance, for ranges, point.y\n // is mapped to point.low.\n if (pointValKey) {\n point.y = Point.prototype.getNestedProperty.call(point, pointValKey);\n }\n point.isNull = this.isValid && !this.isValid();\n point.formatPrefix = point.isNull ? 'null' : 'point'; // #9233, #10874\n // The point is initially selected by options (#5777)\n if (point.selected) {\n point.state = 'select';\n }\n /**\n * The x value of the point.\n * @name Highcharts.Point#x\n * @type {number}\n */\n // If no x is set by now, get auto incremented value. All points must\n // have an x value, however the y value can be null to create a gap in\n // the series\n if ('name' in point &&\n typeof x === 'undefined' &&\n series.xAxis &&\n series.xAxis.hasNames) {\n point.x = series.xAxis.nameToX(point);\n }\n if (typeof point.x === 'undefined' && series) {\n if (typeof x === 'undefined') {\n point.x = series.autoIncrement();\n }\n else {\n point.x = x;\n }\n }\n else if (isNumber(options.x) && series.options.relativeXValue) {\n point.x = series.autoIncrement(options.x);\n }\n return point;\n }\n /**\n * Destroy a point to clear memory. Its reference still stays in\n * `series.data`.\n *\n * @private\n * @function Highcharts.Point#destroy\n */\n destroy() {\n if (!this.destroyed) {\n const point = this, series = point.series, chart = series.chart, dataSorting = series.options.dataSorting, hoverPoints = chart.hoverPoints, globalAnimation = point.series.chart.renderer.globalAnimation, animation = animObject(globalAnimation);\n /**\n * Allow to call after animation.\n * @private\n */\n const destroyPoint = () => {\n // Remove all events and elements\n if (point.graphic ||\n point.graphics ||\n point.dataLabel ||\n point.dataLabels) {\n removeEvent(point);\n point.destroyElements();\n }\n for (const prop in point) { // eslint-disable-line guard-for-in\n delete point[prop];\n }\n };\n if (point.legendItem) {\n // pies have legend items\n chart.legend.destroyItem(point);\n }\n if (hoverPoints) {\n point.setState();\n erase(hoverPoints, point);\n if (!hoverPoints.length) {\n chart.hoverPoints = null;\n }\n }\n if (point === chart.hoverPoint) {\n point.onMouseOut();\n }\n // Remove properties after animation\n if (!dataSorting || !dataSorting.enabled) {\n destroyPoint();\n }\n else {\n this.animateBeforeDestroy();\n syncTimeout(destroyPoint, animation.duration);\n }\n chart.pointCount--;\n }\n this.destroyed = true;\n }\n /**\n * Destroy SVG elements associated with the point.\n *\n * @private\n * @function Highcharts.Point#destroyElements\n * @param {Highcharts.Dictionary} [kinds]\n */\n destroyElements(kinds) {\n const point = this, props = point.getGraphicalProps(kinds);\n props.singular.forEach(function (prop) {\n point[prop] = point[prop].destroy();\n });\n props.plural.forEach(function (plural) {\n point[plural].forEach(function (item) {\n if (item && item.element) {\n item.destroy();\n }\n });\n delete point[plural];\n });\n }\n /**\n * Fire an event on the Point object.\n *\n * @private\n * @function Highcharts.Point#firePointEvent\n *\n * @param {string} eventType\n * Type of the event.\n *\n * @param {Highcharts.Dictionary|Event} [eventArgs]\n * Additional event arguments.\n *\n * @param {Highcharts.EventCallbackFunction|Function} [defaultFunction]\n * Default event handler.\n *\n * @emits Highcharts.Point#event:*\n */\n firePointEvent(eventType, eventArgs, defaultFunction) {\n const point = this, series = this.series, seriesOptions = series.options;\n // load event handlers on demand to save time on mouseover/out\n if (seriesOptions.point.events[eventType] ||\n (point.options &&\n point.options.events &&\n point.options.events[eventType])) {\n point.importEvents();\n }\n // add default handler if in selection mode\n if (eventType === 'click' && seriesOptions.allowPointSelect) {\n defaultFunction = function (event) {\n // Control key is for Windows, meta (= Cmd key) for Mac, Shift\n // for Opera.\n if (point.select) { // #2911\n point.select(null, event.ctrlKey || event.metaKey || event.shiftKey);\n }\n };\n }\n fireEvent(point, eventType, eventArgs, defaultFunction);\n }\n /**\n * Get the CSS class names for individual points. Used internally where the\n * returned value is set on every point.\n *\n * @function Highcharts.Point#getClassName\n *\n * @return {string}\n * The class names.\n */\n getClassName() {\n const point = this;\n return 'highcharts-point' +\n (point.selected ? ' highcharts-point-select' : '') +\n (point.negative ? ' highcharts-negative' : '') +\n (point.isNull ? ' highcharts-null-point' : '') +\n (typeof point.colorIndex !== 'undefined' ?\n ' highcharts-color-' + point.colorIndex : '') +\n (point.options.className ? ' ' + point.options.className : '') +\n (point.zone && point.zone.className ? ' ' +\n point.zone.className.replace('highcharts-negative', '') : '');\n }\n /**\n * Get props of all existing graphical point elements.\n *\n * @private\n * @function Highcharts.Point#getGraphicalProps\n */\n getGraphicalProps(kinds) {\n const point = this, props = [], graphicalProps = { singular: [], plural: [] };\n let prop, i;\n kinds = kinds || { graphic: 1, dataLabel: 1 };\n if (kinds.graphic) {\n props.push('graphic');\n }\n if (kinds.dataLabel) {\n props.push('dataLabel', 'dataLabelPath', 'dataLabelUpper', 'connector');\n }\n i = props.length;\n while (i--) {\n prop = props[i];\n if (point[prop]) {\n graphicalProps.singular.push(prop);\n }\n }\n [\n 'graphic',\n 'dataLabel',\n 'connector'\n ].forEach(function (prop) {\n const plural = prop + 's';\n if (kinds[prop] && point[plural]) {\n graphicalProps.plural.push(plural);\n }\n });\n return graphicalProps;\n }\n /**\n * Return the configuration hash needed for the data label and tooltip\n * formatters.\n *\n * @function Highcharts.Point#getLabelConfig\n *\n * @return {Highcharts.PointLabelObject}\n * Abstract object used in formatters and formats.\n */\n getLabelConfig() {\n return {\n x: this.category,\n y: this.y,\n color: this.color,\n colorIndex: this.colorIndex,\n key: this.name || this.category,\n series: this.series,\n point: this,\n percentage: this.percentage,\n total: this.total || this.stackTotal\n };\n }\n /**\n * Returns the value of the point property for a given value.\n * @private\n */\n getNestedProperty(key) {\n if (!key) {\n return;\n }\n if (key.indexOf('custom.') === 0) {\n return getNestedProperty(key, this.options);\n }\n return this[key];\n }\n /**\n * In a series with `zones`, return the zone that the point belongs to.\n *\n * @function Highcharts.Point#getZone\n *\n * @return {Highcharts.SeriesZonesOptionsObject}\n * The zone item.\n */\n getZone() {\n const series = this.series, zones = series.zones, zoneAxis = series.zoneAxis || 'y';\n let zone, i = 0;\n zone = zones[i];\n while (this[zoneAxis] >= zone.value) {\n zone = zones[++i];\n }\n // For resetting or reusing the point (#8100)\n if (!this.nonZonedColor) {\n this.nonZonedColor = this.color;\n }\n if (zone && zone.color && !this.options.color) {\n this.color = zone.color;\n }\n else {\n this.color = this.nonZonedColor;\n }\n return zone;\n }\n /**\n * Utility to check if point has new shape type. Used in column series and\n * all others that are based on column series.\n * @private\n */\n hasNewShapeType() {\n const point = this;\n const oldShapeType = point.graphic &&\n (point.graphic.symbolName || point.graphic.element.nodeName);\n return oldShapeType !== this.shapeType;\n }\n /**\n * Initialize the point. Called internally based on the `series.data`\n * option.\n *\n * @function Highcharts.Point#init\n *\n * @param {Highcharts.Series} series\n * The series object containing this point.\n *\n * @param {Highcharts.PointOptionsType} options\n * The data in either number, array or object format.\n *\n * @param {number} [x]\n * Optionally, the X value of the point.\n *\n * @return {Highcharts.Point}\n * The Point instance.\n *\n * @emits Highcharts.Point#event:afterInit\n */\n init(series, options, x) {\n this.series = series;\n this.applyOptions(options, x);\n // Add a unique ID to the point if none is assigned\n this.id = defined(this.id) ? this.id : uniqueKey();\n this.resolveColor();\n series.chart.pointCount++;\n fireEvent(this, 'afterInit');\n return this;\n }\n /**\n * Determine if point is valid.\n * @private\n * @function Highcharts.Point#isValid\n */\n isValid() {\n return this.x !== null && isNumber(this.y);\n }\n /**\n * Transform number or array configs into objects. Also called for object\n * configs. Used internally to unify the different configuration formats for\n * points. For example, a simple number `10` in a line series will be\n * transformed to `{ y: 10 }`, and an array config like `[1, 10]` in a\n * scatter series will be transformed to `{ x: 1, y: 10 }`.\n *\n * @deprecated\n * @function Highcharts.Point#optionsToObject\n *\n * @param {Highcharts.PointOptionsType} options\n * Series data options.\n *\n * @return {Highcharts.Dictionary<*>}\n * Transformed point options.\n */\n optionsToObject(options) {\n const series = this.series, keys = series.options.keys, pointArrayMap = keys || series.pointArrayMap || ['y'], valueCount = pointArrayMap.length;\n let ret = {}, firstItemType, i = 0, j = 0;\n if (isNumber(options) || options === null) {\n ret[pointArrayMap[0]] = options;\n }\n else if (isArray(options)) {\n // with leading x value\n if (!keys && options.length > valueCount) {\n firstItemType = typeof options[0];\n if (firstItemType === 'string') {\n ret.name = options[0];\n }\n else if (firstItemType === 'number') {\n ret.x = options[0];\n }\n i++;\n }\n while (j < valueCount) {\n // Skip undefined positions for keys\n if (!keys || typeof options[i] !== 'undefined') {\n if (pointArrayMap[j].indexOf('.') > 0) {\n // Handle nested keys, e.g. ['color.pattern.image']\n // Avoid function call unless necessary.\n Point.prototype.setNestedProperty(ret, options[i], pointArrayMap[j]);\n }\n else {\n ret[pointArrayMap[j]] = options[i];\n }\n }\n i++;\n j++;\n }\n }\n else if (typeof options === 'object') {\n ret = options;\n // This is the fastest way to detect if there are individual point\n // dataLabels that need to be considered in drawDataLabels. These\n // can only occur in object configs.\n if (options.dataLabels) {\n series._hasPointLabels = true;\n }\n // Same approach as above for markers\n if (options.marker) {\n series._hasPointMarkers = true;\n }\n }\n return ret;\n }\n /**\n * Get the pixel position of the point relative to the plot area.\n * @private\n * @function Highcharts.Point#pos\n */\n pos(chartCoordinates, plotY = this.plotY) {\n if (!this.destroyed) {\n const { plotX, series } = this, { chart, xAxis, yAxis } = series;\n let posX = 0, posY = 0;\n if (isNumber(plotX) && isNumber(plotY)) {\n if (chartCoordinates) {\n posX = xAxis ? xAxis.pos : chart.plotLeft;\n posY = yAxis ? yAxis.pos : chart.plotTop;\n }\n return chart.inverted && xAxis && yAxis ?\n [yAxis.len - plotY + posY, xAxis.len - plotX + posX] :\n [plotX + posX, plotY + posY];\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Point#resolveColor\n */\n resolveColor() {\n const series = this.series, optionsChart = series.chart.options.chart, styledMode = series.chart.styledMode;\n let color, colors, colorCount = optionsChart.colorCount, colorIndex;\n // remove points nonZonedColor for later recalculation\n delete this.nonZonedColor;\n if (series.options.colorByPoint) {\n if (!styledMode) {\n colors = series.options.colors || series.chart.options.colors;\n color = colors[series.colorCounter];\n colorCount = colors.length;\n }\n colorIndex = series.colorCounter;\n series.colorCounter++;\n // loop back to zero\n if (series.colorCounter === colorCount) {\n series.colorCounter = 0;\n }\n }\n else {\n if (!styledMode) {\n color = series.color;\n }\n colorIndex = series.colorIndex;\n }\n /**\n * The point's current color index, used in styled mode instead of\n * `color`. The color index is inserted in class names used for styling.\n *\n * @name Highcharts.Point#colorIndex\n * @type {number|undefined}\n */\n this.colorIndex = pick(this.options.colorIndex, colorIndex);\n /**\n * The point's current color.\n *\n * @name Highcharts.Point#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */\n this.color = pick(this.options.color, color);\n }\n /**\n * Set a value in an object, on the property defined by key. The key\n * supports nested properties using dot notation. The function modifies the\n * input object and does not make a copy.\n *\n * @function Highcharts.Point#setNestedProperty\n *\n * @param {T} object\n * The object to set the value on.\n *\n * @param {*} value\n * The value to set.\n *\n * @param {string} key\n * Key to the property to set.\n *\n * @return {T}\n * The modified object.\n */\n setNestedProperty(object, value, key) {\n const nestedKeys = key.split('.');\n nestedKeys.reduce(function (result, key, i, arr) {\n const isLastKey = arr.length - 1 === i;\n result[key] = (isLastKey ?\n value :\n isObject(result[key], true) ?\n result[key] :\n {});\n return result[key];\n }, object);\n return object;\n }\n shouldDraw() {\n return !this.isNull;\n }\n /**\n * Extendable method for formatting each point's tooltip line.\n *\n * @function Highcharts.Point#tooltipFormatter\n *\n * @param {string} pointFormat\n * The point format.\n *\n * @return {string}\n * A string to be concatenated in to the common tooltip text.\n */\n tooltipFormatter(pointFormat) {\n // Insert options for valueDecimals, valuePrefix, and valueSuffix\n const series = this.series, seriesTooltipOptions = series.tooltipOptions, valueDecimals = pick(seriesTooltipOptions.valueDecimals, ''), valuePrefix = seriesTooltipOptions.valuePrefix || '', valueSuffix = seriesTooltipOptions.valueSuffix || '';\n // Replace default point style with class name\n if (series.chart.styledMode) {\n pointFormat =\n series.chart.tooltip.styledModeFormat(pointFormat);\n }\n // Loop over the point array map and replace unformatted values with\n // sprintf formatting markup\n (series.pointArrayMap || ['y']).forEach(function (key) {\n key = '{point.' + key; // without the closing bracket\n if (valuePrefix || valueSuffix) {\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), valuePrefix + key + '}' + valueSuffix);\n }\n pointFormat = pointFormat.replace(RegExp(key + '}', 'g'), key + ':,.' + valueDecimals + 'f}');\n });\n return format(pointFormat, {\n point: this,\n series: this.series\n }, series.chart);\n }\n /**\n * Update point with new options (typically x/y data) and optionally redraw\n * the series.\n *\n * @sample highcharts/members/point-update-column/\n * Update column value\n * @sample highcharts/members/point-update-pie/\n * Update pie slice\n * @sample maps/members/point-update/\n * Update map area value in Highmaps\n *\n * @function Highcharts.Point#update\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. Point options are handled as described under\n * the `series.type.data` item for each series type. For example\n * for a line series, if options is a single number, the point will\n * be given that number as the marin y value. If it is an array, it\n * will be interpreted as x and y values respectively. If it is an\n * object, advanced options are applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is updated. If doing\n * more operations on the chart, it is best practice to set\n * `redraw` to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=true]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @emits Highcharts.Point#event:update\n */\n update(options, redraw, animation, runEvent) {\n const point = this, series = point.series, graphic = point.graphic, chart = series.chart, seriesOptions = series.options;\n let i;\n redraw = pick(redraw, true);\n /**\n * @private\n */\n function update() {\n point.applyOptions(options);\n // Update visuals, #4146\n // Handle mock graphic elements for a11y, #12718\n const hasMockGraphic = graphic && point.hasMockGraphic;\n const shouldDestroyGraphic = point.y === null ?\n !hasMockGraphic :\n hasMockGraphic;\n if (graphic && shouldDestroyGraphic) {\n point.graphic = graphic.destroy();\n delete point.hasMockGraphic;\n }\n if (isObject(options, true)) {\n // Destroy so we can get new elements\n if (graphic && graphic.element) {\n // \"null\" is also a valid symbol\n if (options &&\n options.marker &&\n typeof options.marker.symbol !== 'undefined') {\n point.graphic = graphic.destroy();\n }\n }\n if (options && options.dataLabels && point.dataLabel) {\n point.dataLabel = point.dataLabel.destroy(); // #2468\n }\n if (point.connector) {\n point.connector = point.connector.destroy(); // #7243\n }\n }\n // record changes in the parallel arrays\n i = point.index;\n series.updateParallelArrays(point, i);\n // Record the options to options.data. If the old or the new config\n // is an object, use point options, otherwise use raw options\n // (#4701, #4916).\n seriesOptions.data[i] = (isObject(seriesOptions.data[i], true) ||\n isObject(options, true)) ?\n point.options :\n pick(options, seriesOptions.data[i]);\n // redraw\n series.isDirty = series.isDirtyData = true;\n if (!series.fixedBox && series.hasCartesianSeries) { // #1906, #2320\n chart.isDirtyBox = true;\n }\n if (seriesOptions.legendType === 'point') { // #1831, #1885\n chart.isDirtyLegend = true;\n }\n if (redraw) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of doing the update\n if (runEvent === false) { // When called from setData\n update();\n }\n else {\n point.firePointEvent('update', { options: options }, update);\n }\n }\n /**\n * Remove a point and optionally redraw the series and if necessary the axes\n *\n * @sample highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n * @sample highcharts/members/point-remove/\n * Remove pie slice\n * @sample maps/members/point-remove/\n * Remove selected points in Highmaps\n *\n * @function Highcharts.Point#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call. When\n * doing more operations on the chart, for example running\n * `point.remove()` in a loop, it is best practice to set `redraw`\n * to false and call `chart.redraw()` after.\n *\n * @param {boolean|Partial} [animation=false]\n * Whether to apply animation, and optionally animation\n * configuration.\n */\n remove(redraw, animation) {\n this.series.removePoint(this.series.data.indexOf(this), redraw, animation);\n }\n /**\n * Toggle the selection status of a point.\n *\n * @see Highcharts.Chart#getSelectedPoints\n *\n * @sample highcharts/members/point-select/\n * Select a point from a button\n * @sample highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample maps/series/data-id/\n * Select a point in Highmaps\n *\n * @function Highcharts.Point#select\n *\n * @param {boolean} [selected]\n * When `true`, the point is selected. When `false`, the point is\n * unselected. When `null` or `undefined`, the selection state is toggled.\n *\n * @param {boolean} [accumulate=false]\n * When `true`, the selection is added to other selected points.\n * When `false`, other selected points are deselected. Internally in\n * Highcharts, when\n * [allowPointSelect](https://api.highcharts.com/highcharts/plotOptions.series.allowPointSelect)\n * is `true`, selected points are accumulated on Control, Shift or Cmd\n * clicking the point.\n *\n * @emits Highcharts.Point#event:select\n * @emits Highcharts.Point#event:unselect\n */\n select(selected, accumulate) {\n const point = this, series = point.series, chart = series.chart;\n selected = pick(selected, !point.selected);\n this.selectedStaging = selected;\n // fire the event with the default handler\n point.firePointEvent(selected ? 'select' : 'unselect', { accumulate: accumulate }, function () {\n /**\n * Whether the point is selected or not.\n *\n * @see Point#select\n * @see Chart#getSelectedPoints\n *\n * @name Highcharts.Point#selected\n * @type {boolean}\n */\n point.selected = point.options.selected = selected;\n series.options.data[series.data.indexOf(point)] =\n point.options;\n point.setState(selected && 'select');\n // unselect all other points unless Ctrl or Cmd + click\n if (!accumulate) {\n chart.getSelectedPoints().forEach(function (loopPoint) {\n const loopSeries = loopPoint.series;\n if (loopPoint.selected && loopPoint !== point) {\n loopPoint.selected = loopPoint.options.selected =\n false;\n loopSeries.options.data[loopSeries.data.indexOf(loopPoint)] = loopPoint.options;\n // Programatically selecting a point should restore\n // normal state, but when click happened on other\n // point, set inactive state to match other points\n loopPoint.setState(chart.hoverPoints &&\n loopSeries.options.inactiveOtherPoints ?\n 'inactive' : '');\n loopPoint.firePointEvent('unselect');\n }\n });\n }\n });\n delete this.selectedStaging;\n }\n /**\n * Runs on mouse over the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOver\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The event arguments.\n */\n onMouseOver(e) {\n const point = this, series = point.series, chart = series.chart, pointer = chart.pointer;\n e = e ?\n pointer.normalize(e) :\n // In cases where onMouseOver is called directly without an event\n pointer.getChartCoordinatesFromPoint(point, chart.inverted);\n pointer.runPointActions(e, point);\n }\n /**\n * Runs on mouse out from the point. Called internally from mouse and touch\n * events.\n *\n * @function Highcharts.Point#onMouseOut\n * @emits Highcharts.Point#event:mouseOut\n */\n onMouseOut() {\n const point = this, chart = point.series.chart;\n point.firePointEvent('mouseOut');\n if (!point.series.options.inactiveOtherPoints) {\n (chart.hoverPoints || []).forEach(function (p) {\n p.setState();\n });\n }\n chart.hoverPoints = chart.hoverPoint = null;\n }\n /**\n * Import events from the series' and point's options. Only do it on\n * demand, to save processing time on hovering.\n *\n * @private\n * @function Highcharts.Point#importEvents\n */\n importEvents() {\n if (!this.hasImportedEvents) {\n const point = this, options = merge(point.series.options.point, point.options), events = options.events;\n point.events = events;\n objectEach(events, function (event, eventType) {\n if (isFunction(event)) {\n addEvent(point, eventType, event);\n }\n });\n this.hasImportedEvents = true;\n }\n }\n /**\n * Set the point's state.\n *\n * @function Highcharts.Point#setState\n *\n * @param {Highcharts.PointStateValue|\"\"} [state]\n * The new state, can be one of `'hover'`, `'select'`, `'inactive'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [move]\n * State for animation.\n *\n * @emits Highcharts.Point#event:afterSetState\n */\n setState(state, move) {\n const point = this, series = point.series, previousState = point.state, stateOptions = (series.options.states[state || 'normal'] ||\n {}), markerOptions = (defaultOptions.plotOptions[series.type].marker &&\n series.options.marker), normalDisabled = (markerOptions && markerOptions.enabled === false), markerStateOptions = ((markerOptions &&\n markerOptions.states &&\n markerOptions.states[state || 'normal']) || {}), stateDisabled = markerStateOptions.enabled === false, pointMarker = point.marker || {}, chart = series.chart, hasMarkers = (markerOptions && series.markerAttribs);\n let halo = series.halo, markerAttribs, pointAttribs, pointAttribsAnimation, stateMarkerGraphic = series.stateMarkerGraphic, newSymbol;\n state = state || ''; // empty string\n if (\n // already has this state\n (state === point.state && !move) ||\n // selected points don't respond to hover\n (point.selected && state !== 'select') ||\n // series' state options is disabled\n (stateOptions.enabled === false) ||\n // general point marker's state options is disabled\n (state && (stateDisabled ||\n (normalDisabled &&\n markerStateOptions.enabled === false))) ||\n // individual point marker's state options is disabled\n (state &&\n pointMarker.states &&\n pointMarker.states[state] &&\n pointMarker.states[state].enabled === false) // #1610\n ) {\n return;\n }\n point.state = state;\n if (hasMarkers) {\n markerAttribs = series.markerAttribs(point, state);\n }\n // Apply hover styles to the existing point\n // Prevent from mocked null points (#14966)\n if (point.graphic && !point.hasMockGraphic) {\n if (previousState) {\n point.graphic.removeClass('highcharts-point-' + previousState);\n }\n if (state) {\n point.graphic.addClass('highcharts-point-' + state);\n }\n if (!chart.styledMode) {\n pointAttribs = series.pointAttribs(point, state);\n pointAttribsAnimation = pick(chart.options.chart.animation, stateOptions.animation);\n const opacity = pointAttribs.opacity;\n // Some inactive points (e.g. slices in pie) should apply\n // opacity also for their labels\n if (series.options.inactiveOtherPoints && isNumber(opacity)) {\n (point.dataLabels || []).forEach(function (label) {\n if (label &&\n !label.hasClass('highcharts-data-label-hidden')) {\n label.animate({ opacity }, pointAttribsAnimation);\n }\n });\n if (point.connector) {\n point.connector.animate({ opacity }, pointAttribsAnimation);\n }\n }\n point.graphic.animate(pointAttribs, pointAttribsAnimation);\n }\n if (markerAttribs) {\n point.graphic.animate(markerAttribs, pick(\n // Turn off globally:\n chart.options.chart.animation, markerStateOptions.animation, markerOptions.animation));\n }\n // Zooming in from a range with no markers to a range with markers\n if (stateMarkerGraphic) {\n stateMarkerGraphic.hide();\n }\n }\n else {\n // if a graphic is not applied to each point in the normal state,\n // create a shared graphic for the hover state\n if (state && markerStateOptions) {\n newSymbol = pointMarker.symbol || series.symbol;\n // If the point has another symbol than the previous one, throw\n // away the state marker graphic and force a new one (#1459)\n if (stateMarkerGraphic &&\n stateMarkerGraphic.currentSymbol !== newSymbol) {\n stateMarkerGraphic = stateMarkerGraphic.destroy();\n }\n // Add a new state marker graphic\n if (markerAttribs) {\n if (!stateMarkerGraphic) {\n if (newSymbol) {\n series.stateMarkerGraphic = stateMarkerGraphic =\n chart.renderer\n .symbol(newSymbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height)\n .add(series.markerGroup);\n stateMarkerGraphic.currentSymbol = newSymbol;\n }\n // Move the existing graphic\n }\n else {\n stateMarkerGraphic[move ? 'animate' : 'attr']({\n x: markerAttribs.x,\n y: markerAttribs.y\n });\n }\n }\n if (!chart.styledMode && stateMarkerGraphic &&\n point.state !== 'inactive') {\n stateMarkerGraphic.attr(series.pointAttribs(point, state));\n }\n }\n if (stateMarkerGraphic) {\n stateMarkerGraphic[state && point.isInside ? 'show' : 'hide'](); // #2450\n stateMarkerGraphic.element.point = point; // #4310\n stateMarkerGraphic.addClass(point.getClassName(), true);\n }\n }\n // Show me your halo\n const haloOptions = stateOptions.halo;\n const markerGraphic = (point.graphic || stateMarkerGraphic);\n const markerVisibility = (markerGraphic && markerGraphic.visibility || 'inherit');\n if (haloOptions &&\n haloOptions.size &&\n markerGraphic &&\n markerVisibility !== 'hidden' &&\n !point.isCluster) {\n if (!halo) {\n series.halo = halo = chart.renderer.path()\n // #5818, #5903, #6705\n .add(markerGraphic.parentGroup);\n }\n halo.show()[move ? 'animate' : 'attr']({\n d: point.haloPath(haloOptions.size)\n });\n halo.attr({\n 'class': 'highcharts-halo highcharts-color-' +\n pick(point.colorIndex, series.colorIndex) +\n (point.className ? ' ' + point.className : ''),\n 'visibility': markerVisibility,\n 'zIndex': -1 // #4929, #8276\n });\n halo.point = point; // #6055\n if (!chart.styledMode) {\n halo.attr(extend({\n 'fill': point.color || series.color,\n 'fill-opacity': haloOptions.opacity\n }, AST.filterUserAttributes(haloOptions.attributes || {})));\n }\n }\n else if (halo && halo.point && halo.point.haloPath) {\n // Animate back to 0 on the current halo point (#6055)\n halo.animate({ d: halo.point.haloPath(0) }, null, \n // Hide after unhovering. The `complete` callback runs in the\n // halo's context (#7681).\n halo.hide);\n }\n fireEvent(point, 'afterSetState', { state });\n }\n /**\n * Get the path definition for the halo, which is usually a shadow-like\n * circle around the currently hovered point.\n *\n * @function Highcharts.Point#haloPath\n *\n * @param {number} size\n * The radius of the circular halo.\n *\n * @return {Highcharts.SVGPathArray}\n * The path definition.\n */\n haloPath(size) {\n const pos = this.pos();\n return pos ? this.series.chart.renderer.symbols.circle(Math.floor(pos[0]) - size, pos[1] - size, size * 2, size * 2) : [];\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Function callback when a series point is clicked. Return false to cancel the\n * action.\n *\n * @callback Highcharts.PointClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point where the event occured.\n *\n * @param {Highcharts.PointClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series point.\n *\n * @interface Highcharts.PointClickEventObject\n * @extends Highcharts.PointerEventObject\n */ /**\n * Clicked point.\n * @name Highcharts.PointClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Configuration for the data label and tooltip formatters.\n *\n * @interface Highcharts.PointLabelObject\n */ /**\n * The point's current color.\n * @name Highcharts.PointLabelObject#color\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject|undefined}\n */ /**\n * The point's current color index, used in styled mode instead of `color`. The\n * color index is inserted in class names used for styling.\n * @name Highcharts.PointLabelObject#colorIndex\n * @type {number}\n */ /**\n * The name of the related point.\n * @name Highcharts.PointLabelObject#key\n * @type {string|undefined}\n */ /**\n * The percentage for related points in a stacked series or pies.\n * @name Highcharts.PointLabelObject#percentage\n * @type {number}\n */ /**\n * The related point. The point name, if defined, is available through\n * `this.point.name`.\n * @name Highcharts.PointLabelObject#point\n * @type {Highcharts.Point}\n */ /**\n * The related series. The series name is available through `this.series.name`.\n * @name Highcharts.PointLabelObject#series\n * @type {Highcharts.Series}\n */ /**\n * The total of values in either a stack for stacked series, or a pie in a pie\n * series.\n * @name Highcharts.PointLabelObject#total\n * @type {number|undefined}\n */ /**\n * For categorized axes this property holds the category name for the point. For\n * other axes it holds the X value.\n * @name Highcharts.PointLabelObject#x\n * @type {number|string|undefined}\n */ /**\n * The y value of the point.\n * @name Highcharts.PointLabelObject#y\n * @type {number|null|undefined}\n */\n /**\n * Gets fired when the mouse leaves the area close to the point.\n *\n * @callback Highcharts.PointMouseOutCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the area close to the point.\n *\n * @callback Highcharts.PointMouseOverCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * The generic point options for all series.\n *\n * In TypeScript you have to extend `PointOptionsObject` with an additional\n * declaration to allow custom data options:\n *\n * ```\n * declare interface PointOptionsObject {\n * customProperty: string;\n * }\n * ```\n *\n * @interface Highcharts.PointOptionsObject\n */\n /**\n * Possible option types for a data point. Use `null` to indicate a gap.\n *\n * @typedef {number|string|Highcharts.PointOptionsObject|Array<(number|string|null)>|null} Highcharts.PointOptionsType\n */\n /**\n * Gets fired when the point is removed using the `.remove()` method.\n *\n * @callback Highcharts.PointRemoveCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the point state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.PointStateValue\n */\n /**\n * Gets fired when the point is updated programmatically through the `.update()`\n * method.\n *\n * @callback Highcharts.PointUpdateCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointUpdateEventObject} event\n * Event that occured.\n */\n /**\n * Information about the update event.\n *\n * @interface Highcharts.PointUpdateEventObject\n * @extends global.Event\n */ /**\n * Options data of the update event.\n * @name Highcharts.PointUpdateEventObject#options\n * @type {Highcharts.PointOptionsType}\n */\n /**\n * @interface Highcharts.PointEventsOptionsObject\n */ /**\n * Fires when the point is selected either programmatically or following a click\n * on the point. One parameter, `event`, is passed to the function. Returning\n * `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#select\n * @type {Highcharts.PointSelectCallbackFunction|undefined}\n */ /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point. One parameter, `event`, is passed to the function.\n * Returning `false` cancels the operation.\n * @name Highcharts.PointEventsOptionsObject#unselect\n * @type {Highcharts.PointUnselectCallbackFunction|undefined}\n */\n /**\n * Information about the select/unselect event.\n *\n * @interface Highcharts.PointInteractionEventObject\n * @extends global.Event\n */ /**\n * @name Highcharts.PointInteractionEventObject#accumulate\n * @type {boolean}\n */\n /**\n * Gets fired when the point is selected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointSelectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n /**\n * Fires when the point is unselected either programmatically or following a\n * click on the point.\n *\n * @callback Highcharts.PointUnselectCallbackFunction\n *\n * @param {Highcharts.Point} this\n * Point where the event occured.\n *\n * @param {Highcharts.PointInteractionEventObject} event\n * Event that occured.\n */\n ''; // keeps doclets above in JS file.\n\n return Point;\n });\n _registerModule(_modules, 'Core/Pointer.js', [_modules['Core/Color/Color.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (Color, H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { charts, noop } = H;\n const { addEvent, attr, css, defined, extend, find, fireEvent, isNumber, isObject, objectEach, offset, pick, splat } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The mouse and touch tracker object. Each {@link Chart} item has one\n * associated Pointer item that can be accessed from the {@link Chart.pointer}\n * property.\n *\n * @class\n * @name Highcharts.Pointer\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and tooltip\n * structures.\n */\n class Pointer {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, options) {\n this.lastValidTouch = {};\n this.pinchDown = [];\n this.runChartClick = false;\n this.eventsToUnbind = [];\n this.chart = chart;\n this.hasDragged = false;\n this.options = options;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set inactive state to all series that are not currently hovered,\n * or, if `inactiveOtherPoints` is set to true, set inactive state to\n * all points within that series.\n *\n * @private\n * @function Highcharts.Pointer#applyInactiveState\n *\n * @param {Array} points\n * Currently hovered points\n */\n applyInactiveState(points) {\n let activeSeries = [], series;\n // Get all active series from the hovered points\n (points || []).forEach(function (item) {\n series = item.series;\n // Include itself\n activeSeries.push(series);\n // Include parent series\n if (series.linkedParent) {\n activeSeries.push(series.linkedParent);\n }\n // Include all child series\n if (series.linkedSeries) {\n activeSeries = activeSeries.concat(series.linkedSeries);\n }\n // Include navigator series\n if (series.navigatorSeries) {\n activeSeries.push(series.navigatorSeries);\n }\n });\n // Now loop over all series, filtering out active series\n this.chart.series.forEach(function (inactiveSeries) {\n if (activeSeries.indexOf(inactiveSeries) === -1) {\n // Inactive series\n inactiveSeries.setState('inactive', true);\n }\n else if (inactiveSeries.options.inactiveOtherPoints) {\n // Active series, but other points should be inactivated\n inactiveSeries.setAllPointsToState('inactive');\n }\n });\n }\n /**\n * Destroys the Pointer object and disconnects DOM events.\n *\n * @function Highcharts.Pointer#destroy\n */\n destroy() {\n const pointer = this;\n this.eventsToUnbind.forEach((unbind) => unbind());\n this.eventsToUnbind = [];\n if (!H.chartCount) {\n if (Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = Pointer.unbindDocumentMouseUp();\n }\n if (Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = (Pointer.unbindDocumentTouchEnd());\n }\n }\n // memory and CPU leak\n clearInterval(pointer.tooltipTimeout);\n objectEach(pointer, function (_val, prop) {\n pointer[prop] = void 0;\n });\n }\n /**\n * Calculate attrs for selection marker.\n * @private\n * @function Highcharts.Pointer#getSelectionMarkerAttrs\n * @emits getSelectionMarkerAttrs\n */\n getSelectionMarkerAttrs(chartX, chartY) {\n const e = {\n args: { chartX, chartY },\n attrs: {},\n shapeType: 'rect'\n };\n fireEvent(this, 'getSelectionMarkerAttrs', e, (e) => {\n const { chart, mouseDownX = 0, mouseDownY = 0, zoomHor, zoomVert } = this, attrs = e.attrs;\n let size;\n attrs.x = chart.plotLeft;\n attrs.y = chart.plotTop;\n attrs.width = zoomHor ? 1 : chart.plotWidth;\n attrs.height = zoomVert ? 1 : chart.plotHeight;\n // Adjust the width of the selection marker\n if (zoomHor) {\n size = chartX - mouseDownX;\n attrs.width = Math.abs(size);\n attrs.x = (size > 0 ? 0 : size) + mouseDownX;\n }\n // Adjust the height of the selection marker\n if (zoomVert) {\n size = chartY - mouseDownY;\n attrs.height = Math.abs(size);\n attrs.y = (size > 0 ? 0 : size) + mouseDownY;\n }\n });\n return e;\n }\n /**\n * Perform a drag operation in response to a mousemove event while the mouse\n * is down.\n * @private\n * @function Highcharts.Pointer#drag\n */\n drag(e) {\n const chart = this.chart, chartOptions = chart.options.chart, plotLeft = chart.plotLeft, plotTop = chart.plotTop, plotWidth = chart.plotWidth, plotHeight = chart.plotHeight, mouseDownX = (this.mouseDownX || 0), mouseDownY = (this.mouseDownY || 0), panningEnabled = isObject(chartOptions.panning) ?\n chartOptions.panning && chartOptions.panning.enabled :\n chartOptions.panning, panKey = (chartOptions.panKey && e[chartOptions.panKey + 'Key']);\n let chartX = e.chartX, chartY = e.chartY, clickedInside, selectionMarker = this.selectionMarker;\n // If the device supports both touch and mouse (like IE11), and we are\n // touch-dragging inside the plot area, don't handle the mouse event.\n // #4339.\n if (selectionMarker && selectionMarker.touch) {\n return;\n }\n // If the mouse is outside the plot area, adjust to coordinates\n // inside to prevent the selection marker from going outside\n if (chartX < plotLeft) {\n chartX = plotLeft;\n }\n else if (chartX > plotLeft + plotWidth) {\n chartX = plotLeft + plotWidth;\n }\n if (chartY < plotTop) {\n chartY = plotTop;\n }\n else if (chartY > plotTop + plotHeight) {\n chartY = plotTop + plotHeight;\n }\n // determine if the mouse has moved more than 10px\n this.hasDragged = Math.sqrt(Math.pow(mouseDownX - chartX, 2) +\n Math.pow(mouseDownY - chartY, 2));\n if (this.hasDragged > 10) {\n clickedInside = chart.isInsidePlot(mouseDownX - plotLeft, mouseDownY - plotTop, {\n visiblePlotOnly: true\n });\n const { shapeType, attrs } = this.getSelectionMarkerAttrs(chartX, chartY);\n // make a selection\n if ((chart.hasCartesianSeries || chart.mapView) &&\n (this.zoomX || this.zoomY) &&\n clickedInside &&\n !panKey) {\n if (!selectionMarker) {\n this.selectionMarker = selectionMarker =\n chart.renderer[shapeType]();\n selectionMarker\n .attr({\n 'class': 'highcharts-selection-marker',\n zIndex: 7\n })\n .add();\n if (!chart.styledMode) {\n selectionMarker.attr({\n fill: chartOptions.selectionMarkerFill ||\n color(\"#334eff\" /* Palette.highlightColor80 */)\n .setOpacity(0.25).get()\n });\n }\n }\n }\n if (selectionMarker) {\n selectionMarker.attr(attrs);\n }\n // panning\n if (clickedInside &&\n !selectionMarker &&\n panningEnabled) {\n chart.pan(e, chartOptions.panning);\n }\n }\n }\n /**\n * Start a drag operation.\n * @private\n * @function Highcharts.Pointer#dragStart\n */\n dragStart(e) {\n const chart = this.chart;\n // Record the start position\n chart.mouseIsDown = e.type;\n chart.cancelClick = false;\n chart.mouseDownX = this.mouseDownX = e.chartX;\n chart.mouseDownY = this.mouseDownY = e.chartY;\n }\n /**\n * Get selection box to calculate extremes\n * @private\n * @function Highcharts.Pointer#getSelectionBox\n * @emits getSelectionBox\n */\n getSelectionBox(marker) {\n const e = {\n args: { marker },\n result: {}\n };\n fireEvent(this, 'getSelectionBox', e, (e) => {\n e.result = {\n x: marker.attr ? +marker.attr('x') : marker.x,\n y: marker.attr ? +marker.attr('y') : marker.y,\n width: marker.attr ? marker.attr('width') : marker.width,\n height: marker.attr ? marker.attr('height') : marker.height\n };\n });\n return e.result;\n }\n /**\n * On mouse up or touch end across the entire document, drop the selection.\n * @private\n * @function Highcharts.Pointer#drop\n */\n drop(e) {\n const pointer = this, chart = this.chart, hasPinched = this.hasPinched;\n if (this.selectionMarker) {\n const { x, y, width, height } = this.getSelectionBox(this.selectionMarker);\n const selectionData = {\n originalEvent: e,\n xAxis: [],\n yAxis: [],\n x,\n y,\n width,\n height\n };\n // Start by false runZoom, unless when we have a mapView, in\n // which case the zoom will be handled in the selection event.\n let runZoom = Boolean(chart.mapView);\n // a selection has been made\n if (this.hasDragged || hasPinched) {\n // record each axis' min and max\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled &&\n defined(axis.min) &&\n (hasPinched ||\n pointer[{\n xAxis: 'zoomX',\n yAxis: 'zoomY'\n }[axis.coll]]) &&\n isNumber(x) &&\n isNumber(y) &&\n isNumber(width) &&\n isNumber(height)) { // #859, #3569\n const horiz = axis.horiz, minPixelPadding = e.type === 'touchend' ?\n axis.minPixelPadding :\n 0, // #1207, #3075\n selectionMin = axis.toValue((horiz ? x : y) + minPixelPadding), selectionMax = axis.toValue((horiz ? x + width : y + height) -\n minPixelPadding);\n selectionData[axis.coll].push({\n axis: axis,\n // Min/max for reversed axes\n min: Math.min(selectionMin, selectionMax),\n max: Math.max(selectionMin, selectionMax)\n });\n runZoom = true;\n }\n });\n if (runZoom) {\n fireEvent(chart, 'selection', selectionData, function (args) {\n chart.zoom(extend(args, hasPinched ?\n { animation: false } :\n null));\n });\n }\n }\n if (isNumber(chart.index)) {\n this.selectionMarker = this.selectionMarker.destroy();\n }\n // Reset scaling preview\n if (hasPinched) {\n this.scaleGroups();\n }\n }\n // Reset all. Check isNumber because it may be destroyed on mouse up\n // (#877)\n if (chart && isNumber(chart.index)) {\n css(chart.container, { cursor: chart._cursor });\n chart.cancelClick = this.hasDragged > 10; // #370\n chart.mouseIsDown = this.hasDragged = this.hasPinched = false;\n this.pinchDown = [];\n }\n }\n /**\n * Finds the closest point to a set of coordinates, using the k-d-tree\n * algorithm.\n *\n * @function Highcharts.Pointer#findNearestKDPoint\n *\n * @param {Array} series\n * All the series to search in.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} e\n * The pointer event object, containing chart coordinates of the pointer.\n *\n * @return {Highcharts.Point|undefined}\n * The point closest to given coordinates.\n */\n findNearestKDPoint(series, shared, e) {\n let closest;\n /** @private */\n function sort(p1, p2) {\n const isCloserX = p1.distX - p2.distX, isCloser = p1.dist - p2.dist, isAbove = ((p2.series.group && p2.series.group.zIndex) -\n (p1.series.group && p1.series.group.zIndex));\n let result;\n // We have two points which are not in the same place on xAxis\n // and shared tooltip:\n if (isCloserX !== 0 && shared) { // #5721\n result = isCloserX;\n // Points are not exactly in the same place on x/yAxis:\n }\n else if (isCloser !== 0) {\n result = isCloser;\n // The same xAxis and yAxis position, sort by z-index:\n }\n else if (isAbove !== 0) {\n result = isAbove;\n // The same zIndex, sort by array index:\n }\n else {\n result =\n p1.series.index > p2.series.index ?\n -1 :\n 1;\n }\n return result;\n }\n series.forEach(function (s) {\n const noSharedTooltip = s.noSharedTooltip && shared, compareX = (!noSharedTooltip &&\n s.options.findNearestPointBy.indexOf('y') < 0), point = s.searchPoint(e, compareX);\n if ( // Check that we actually found a point on the series.\n isObject(point, true) && point.series &&\n // Use the new point if it is closer.\n (!isObject(closest, true) ||\n (sort(closest, point) > 0))) {\n closest = point;\n }\n });\n return closest;\n }\n /**\n * @private\n * @function Highcharts.Pointer#getChartCoordinatesFromPoint\n */\n getChartCoordinatesFromPoint(point, inverted) {\n const series = point.series, xAxis = series.xAxis, yAxis = series.yAxis, shapeArgs = point.shapeArgs;\n if (xAxis && yAxis) {\n let x = pick(point.clientX, point.plotX);\n let y = point.plotY || 0;\n if (point.isNode &&\n shapeArgs &&\n isNumber(shapeArgs.x) &&\n isNumber(shapeArgs.y)) {\n x = shapeArgs.x;\n y = shapeArgs.y;\n }\n return inverted ? {\n chartX: yAxis.len + yAxis.pos - y,\n chartY: xAxis.len + xAxis.pos - x\n } : {\n chartX: x + xAxis.pos,\n chartY: y + yAxis.pos\n };\n }\n if (shapeArgs && shapeArgs.x && shapeArgs.y) {\n // E.g. pies do not have axes\n return {\n chartX: shapeArgs.x,\n chartY: shapeArgs.y\n };\n }\n }\n /**\n * Return the cached chartPosition if it is available on the Pointer,\n * otherwise find it. Running offset is quite expensive, so it should be\n * avoided when we know the chart hasn't moved.\n *\n * @function Highcharts.Pointer#getChartPosition\n *\n * @return {Highcharts.ChartPositionObject}\n * The offset of the chart container within the page\n */\n getChartPosition() {\n if (this.chartPosition) {\n return this.chartPosition;\n }\n const { container } = this.chart;\n const pos = offset(container);\n this.chartPosition = {\n left: pos.left,\n top: pos.top,\n scaleX: 1,\n scaleY: 1\n };\n const offsetWidth = container.offsetWidth;\n const offsetHeight = container.offsetHeight;\n // #13342 - tooltip was not visible in Chrome, when chart\n // updates height.\n if (offsetWidth > 2 && // #13342\n offsetHeight > 2 // #13342\n ) {\n this.chartPosition.scaleX = pos.width / offsetWidth;\n this.chartPosition.scaleY = pos.height / offsetHeight;\n }\n return this.chartPosition;\n }\n /**\n * Get the click position in terms of axis values.\n *\n * @function Highcharts.Pointer#getCoordinates\n *\n * @param {Highcharts.PointerEventObject} e\n * Pointer event, extended with `chartX` and `chartY` properties.\n *\n * @return {Highcharts.PointerAxisCoordinatesObject}\n * Axis coordinates.\n */\n getCoordinates(e) {\n const coordinates = {\n xAxis: [],\n yAxis: []\n };\n this.chart.axes.forEach(function (axis) {\n coordinates[axis.isXAxis ? 'xAxis' : 'yAxis'].push({\n axis: axis,\n value: axis.toValue(e[axis.horiz ? 'chartX' : 'chartY'])\n });\n });\n return coordinates;\n }\n /**\n * Calculates what is the current hovered point/points and series.\n *\n * @private\n * @function Highcharts.Pointer#getHoverData\n *\n * @param {Highcharts.Point|undefined} existingHoverPoint\n * The point currently being hovered.\n *\n * @param {Highcharts.Series|undefined} existingHoverSeries\n * The series currently being hovered.\n *\n * @param {Array} series\n * All the series in the chart.\n *\n * @param {boolean} isDirectTouch\n * Is the pointer directly hovering the point.\n *\n * @param {boolean|undefined} shared\n * Whether it is a shared tooltip or not.\n *\n * @param {Highcharts.PointerEventObject} [e]\n * The triggering event, containing chart coordinates of the pointer.\n *\n * @return {Object}\n * Object containing resulting hover data: hoverPoint, hoverSeries, and\n * hoverPoints.\n */\n getHoverData(existingHoverPoint, existingHoverSeries, series, isDirectTouch, shared, e) {\n const hoverPoints = [], useExisting = !!(isDirectTouch && existingHoverPoint), filter = function (s) {\n return (s.visible &&\n !(!shared && s.directTouch) && // #3821\n pick(s.options.enableMouseTracking, true));\n };\n let hoverSeries = existingHoverSeries, \n // Which series to look in for the hover point\n searchSeries, \n // Parameters needed for beforeGetHoverData event.\n eventArgs = {\n chartX: e ? e.chartX : void 0,\n chartY: e ? e.chartY : void 0,\n shared: shared\n };\n // Find chart.hoverPane and update filter method in polar.\n fireEvent(this, 'beforeGetHoverData', eventArgs);\n const notSticky = hoverSeries && !hoverSeries.stickyTracking;\n searchSeries = notSticky ?\n // Only search on hovered series if it has stickyTracking false\n [hoverSeries] :\n // Filter what series to look in.\n series.filter((s) => s.stickyTracking &&\n (eventArgs.filter || filter)(s));\n // Use existing hovered point or find the one closest to coordinates.\n const hoverPoint = useExisting || !e ?\n existingHoverPoint :\n this.findNearestKDPoint(searchSeries, shared, e);\n // Assign hover series\n hoverSeries = hoverPoint && hoverPoint.series;\n // If we have a hoverPoint, assign hoverPoints.\n if (hoverPoint) {\n // When tooltip is shared, it displays more than one point\n if (shared && !hoverSeries.noSharedTooltip) {\n searchSeries = series.filter(function (s) {\n return eventArgs.filter ?\n eventArgs.filter(s) : filter(s) && !s.noSharedTooltip;\n });\n // Get all points with the same x value as the hoverPoint\n searchSeries.forEach(function (s) {\n let point = find(s.points, function (p) {\n return p.x === hoverPoint.x && !p.isNull;\n });\n if (isObject(point)) {\n /*\n * Boost returns a minimal point. Convert it to a usable\n * point for tooltip and states.\n */\n if (s.boosted && s.boost) {\n point = s.boost.getPoint(point);\n }\n hoverPoints.push(point);\n }\n });\n }\n else {\n hoverPoints.push(hoverPoint);\n }\n }\n // Check whether the hoverPoint is inside pane we are hovering over.\n eventArgs = { hoverPoint: hoverPoint };\n fireEvent(this, 'afterGetHoverData', eventArgs);\n return {\n hoverPoint: eventArgs.hoverPoint,\n hoverSeries: hoverSeries,\n hoverPoints: hoverPoints\n };\n }\n /**\n * @private\n * @function Highcharts.Pointer#getPointFromEvent\n */\n getPointFromEvent(e) {\n let target = e.target, point;\n while (target && !point) {\n point = target.point;\n target = target.parentNode;\n }\n return point;\n }\n /**\n * @private\n * @function Highcharts.Pointer#onTrackerMouseOut\n */\n onTrackerMouseOut(e) {\n const chart = this.chart;\n const relatedTarget = e.relatedTarget;\n const series = chart.hoverSeries;\n this.isDirectTouch = false;\n if (series &&\n relatedTarget &&\n !series.stickyTracking &&\n !this.inClass(relatedTarget, 'highcharts-tooltip') &&\n (!this.inClass(relatedTarget, 'highcharts-series-' + series.index) || // #2499, #4465, #5553\n !this.inClass(relatedTarget, 'highcharts-tracker'))) {\n series.onMouseOut();\n }\n }\n /**\n * Utility to detect whether an element has, or has a parent with, a\n * specific class name. Used on detection of tracker objects and on deciding\n * whether hovering the tooltip should cause the active series to mouse out.\n *\n * @function Highcharts.Pointer#inClass\n *\n * @param {Highcharts.SVGDOMElement|Highcharts.HTMLDOMElement} element\n * The element to investigate.\n *\n * @param {string} className\n * The class name to look for.\n *\n * @return {boolean|undefined}\n * True if either the element or one of its parents has the given class\n * name.\n */\n inClass(element, className) {\n let elem = element, elemClassName;\n while (elem) {\n elemClassName = attr(elem, 'class');\n if (elemClassName) {\n if (elemClassName.indexOf(className) !== -1) {\n return true;\n }\n if (elemClassName.indexOf('highcharts-container') !== -1) {\n return false;\n }\n }\n elem = elem.parentElement;\n }\n }\n /**\n * Initialize the Pointer.\n *\n * @private\n * @function Highcharts.Pointer#init\n *\n * @param {Highcharts.Chart} chart\n * The Chart instance.\n *\n * @param {Highcharts.Options} options\n * The root options object. The pointer uses options from the chart and\n * tooltip structures.\n */\n init(chart, options) {\n // Store references\n this.options = options;\n this.chart = chart;\n // Do we need to handle click on a touch device?\n this.runChartClick = Boolean(options.chart.events && options.chart.events.click);\n this.pinchDown = [];\n this.lastValidTouch = {};\n this.setDOMEvents();\n fireEvent(this, 'afterInit');\n }\n /**\n * Takes a browser event object and extends it with custom Highcharts\n * properties `chartX` and `chartY` in order to work on the internal\n * coordinate system.\n *\n * On map charts, the properties `lon` and `lat` are added to the event\n * object given that the chart has projection information.\n *\n * @function Highcharts.Pointer#normalize\n *\n * @param {global.MouseEvent|global.PointerEvent|global.TouchEvent} e\n * Event object in standard browsers.\n *\n * @param {Highcharts.OffsetObject} [chartPosition]\n * Additional chart offset.\n *\n * @return {Highcharts.PointerEventObject}\n * A browser event with extended properties `chartX` and `chartY`.\n */\n normalize(e, chartPosition) {\n const touches = e.touches;\n // iOS (#2757)\n const ePos = (touches ?\n touches.length ?\n touches.item(0) :\n (pick(// #13534\n touches.changedTouches, e.changedTouches))[0] :\n e);\n // Get mouse position\n if (!chartPosition) {\n chartPosition = this.getChartPosition();\n }\n let chartX = ePos.pageX - chartPosition.left, chartY = ePos.pageY - chartPosition.top;\n // #11329 - when there is scaling on a parent element, we need to take\n // this into account\n chartX /= chartPosition.scaleX;\n chartY /= chartPosition.scaleY;\n return extend(e, {\n chartX: Math.round(chartX),\n chartY: Math.round(chartY)\n });\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerClick\n */\n onContainerClick(e) {\n const chart = this.chart;\n const hoverPoint = chart.hoverPoint;\n const pEvt = this.normalize(e);\n const plotLeft = chart.plotLeft;\n const plotTop = chart.plotTop;\n if (!chart.cancelClick) {\n // On tracker click, fire the series and point events. #783, #1583\n if (hoverPoint &&\n this.inClass(pEvt.target, 'highcharts-tracker')) {\n // the series click event\n fireEvent(hoverPoint.series, 'click', extend(pEvt, {\n point: hoverPoint\n }));\n // the point click event\n if (chart.hoverPoint) { // it may be destroyed (#1844)\n hoverPoint.firePointEvent('click', pEvt);\n }\n // When clicking outside a tracker, fire a chart event\n }\n else {\n extend(pEvt, this.getCoordinates(pEvt));\n // fire a click event in the chart\n if (chart.isInsidePlot(pEvt.chartX - plotLeft, pEvt.chartY - plotTop, {\n visiblePlotOnly: true\n })) {\n fireEvent(chart, 'click', pEvt);\n }\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerMouseDown\n */\n onContainerMouseDown(e) {\n const isPrimaryButton = ((e.buttons || e.button) & 1) === 1;\n e = this.normalize(e);\n // #11635, Firefox does not reliably fire move event after click scroll\n if (H.isFirefox &&\n e.button !== 0) {\n this.onContainerMouseMove(e);\n }\n // #11635, limiting to primary button\n if (typeof e.button === 'undefined' ||\n isPrimaryButton) {\n this.zoomOption(e);\n // #295, #13737 solve conflict between container drag and chart zoom\n if (isPrimaryButton &&\n e.preventDefault) {\n e.preventDefault();\n }\n this.dragStart(e);\n }\n }\n /**\n * When mouse leaves the container, hide the tooltip.\n * @private\n * @function Highcharts.Pointer#onContainerMouseLeave\n */\n onContainerMouseLeave(e) {\n const chart = charts[pick(Pointer.hoverChartIndex, -1)];\n e = this.normalize(e);\n // #4886, MS Touch end fires mouseleave but with no related target\n if (chart &&\n e.relatedTarget &&\n !this.inClass(e.relatedTarget, 'highcharts-tooltip')) {\n chart.pointer.reset();\n // Also reset the chart position, used in #149 fix\n chart.pointer.chartPosition = void 0;\n }\n }\n /**\n * When mouse enters the container, delete pointer's chartPosition.\n * @private\n * @function Highcharts.Pointer#onContainerMouseEnter\n */\n onContainerMouseEnter(e) {\n delete this.chartPosition;\n }\n /**\n * The mousemove, touchmove and touchstart event handler\n * @private\n * @function Highcharts.Pointer#onContainerMouseMove\n */\n onContainerMouseMove(e) {\n const chart = this.chart, tooltip = chart.tooltip, pEvt = this.normalize(e);\n this.setHoverChartIndex();\n if (chart.mouseIsDown === 'mousedown' || this.touchSelect(pEvt)) {\n this.drag(pEvt);\n }\n // Show the tooltip and run mouse over events (#977)\n if (!chart.openMenu &&\n (this.inClass(pEvt.target, 'highcharts-tracker') ||\n chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n })) &&\n // If the tooltip has stickOnContact enabled, do nothing. This\n // applies regardless of any combinations of the `split` and\n // `useHTML` options.\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt))) {\n if (this.inClass(pEvt.target, 'highcharts-no-tooltip')) {\n this.reset(false, 0);\n }\n else {\n this.runPointActions(pEvt);\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentTouchEnd\n */\n onDocumentTouchEnd(e) {\n const hoverChart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart) {\n hoverChart.pointer.drop(e);\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchMove\n */\n onContainerTouchMove(e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseMove(e);\n }\n else {\n this.touch(e);\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onContainerTouchStart\n */\n onContainerTouchStart(e) {\n if (this.touchSelect(e)) {\n this.onContainerMouseDown(e);\n }\n else {\n this.zoomOption(e);\n this.touch(e, true);\n }\n }\n /**\n * Special handler for mouse move that will hide the tooltip when the mouse\n * leaves the plotarea. Issue #149 workaround. The mouseleave event does not\n * always fire.\n * @private\n * @function Highcharts.Pointer#onDocumentMouseMove\n */\n onDocumentMouseMove(e) {\n const chart = this.chart;\n const tooltip = chart.tooltip;\n const chartPosition = this.chartPosition;\n const pEvt = this.normalize(e, chartPosition);\n // If we're outside, hide the tooltip\n if (chartPosition &&\n !chart.isInsidePlot(pEvt.chartX - chart.plotLeft, pEvt.chartY - chart.plotTop, {\n visiblePlotOnly: true\n }) &&\n !(tooltip &&\n tooltip.shouldStickOnContact(pEvt)) &&\n !this.inClass(pEvt.target, 'highcharts-tracker')) {\n this.reset();\n }\n }\n /**\n * @private\n * @function Highcharts.Pointer#onDocumentMouseUp\n */\n onDocumentMouseUp(e) {\n const chart = charts[pick(Pointer.hoverChartIndex, -1)];\n if (chart) {\n chart.pointer.drop(e);\n }\n }\n /**\n * Handle touch events with two touches\n * @private\n * @function Highcharts.Pointer#pinch\n */\n pinch(e) {\n const self = this, chart = self.chart, pinchDown = self.pinchDown, touches = (e.touches || []), touchesLength = touches.length, lastValidTouch = self.lastValidTouch, hasZoom = self.hasZoom, transform = {}, fireClickEvent = touchesLength === 1 && ((self.inClass(e.target, 'highcharts-tracker') &&\n chart.runTrackerClick) ||\n self.runChartClick), clip = {}, tooltip = self.chart.tooltip, followTouchMove = touchesLength === 1 &&\n pick((tooltip && tooltip.options.followTouchMove), true);\n let selectionMarker = self.selectionMarker;\n // Don't initiate panning until the user has pinched. This prevents us\n // from blocking page scrolling as users scroll down a long page\n // (#4210).\n if (touchesLength > 1) {\n self.initiated = true;\n }\n else if (followTouchMove) {\n // #16119: Prevent blocking scroll when single-finger panning is\n // not enabled\n self.initiated = false;\n }\n // On touch devices, only proceed to trigger click if a handler is\n // defined\n if (hasZoom &&\n self.initiated &&\n !fireClickEvent &&\n e.cancelable !== false) {\n e.preventDefault();\n }\n // Normalize each touch\n [].map.call(touches, function (e) {\n return self.normalize(e);\n });\n // Register the touch start position\n if (e.type === 'touchstart') {\n [].forEach.call(touches, function (e, i) {\n pinchDown[i] = { chartX: e.chartX, chartY: e.chartY };\n });\n lastValidTouch.x = [pinchDown[0].chartX, pinchDown[1] &&\n pinchDown[1].chartX];\n lastValidTouch.y = [pinchDown[0].chartY, pinchDown[1] &&\n pinchDown[1].chartY];\n // Identify the data bounds in pixels\n chart.axes.forEach(function (axis) {\n if (axis.zoomEnabled) {\n const bounds = chart.bounds[axis.horiz ? 'h' : 'v'], minPixelPadding = axis.minPixelPadding, min = axis.toPixels(Math.min(pick(axis.options.min, axis.dataMin), axis.dataMin)), max = axis.toPixels(Math.max(pick(axis.options.max, axis.dataMax), axis.dataMax)), absMin = Math.min(min, max), absMax = Math.max(min, max);\n // Store the bounds for use in the touchmove handler\n bounds.min = Math.min(axis.pos, absMin - minPixelPadding);\n bounds.max = Math.max(axis.pos + axis.len, absMax + minPixelPadding);\n }\n });\n self.res = true; // reset on next move\n // Optionally move the tooltip on touchmove\n }\n else if (followTouchMove) {\n this.runPointActions(self.normalize(e));\n // Event type is touchmove, handle panning and pinching\n }\n else if (pinchDown.length) { // can be 0 when releasing, if touchend\n // fires first\n fireEvent(chart, 'touchpan', { originalEvent: e }, () => {\n // Set the marker\n if (!selectionMarker) {\n // @todo It's a mock object, so maybe we need a separate\n // interface\n self.selectionMarker = selectionMarker = extend({\n destroy: noop,\n touch: true\n }, chart.plotBox);\n }\n self.pinchTranslate(pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n self.hasPinched = hasZoom;\n // Scale and translate the groups to provide visual feedback\n // during pinching\n self.scaleGroups(transform, clip);\n });\n if (self.res) {\n self.res = false;\n this.reset(false, 0);\n }\n }\n }\n /**\n * Run translation operations\n * @private\n * @function Highcharts.Pointer#pinchTranslate\n */\n pinchTranslate(pinchDown, touches, transform, selectionMarker, clip, lastValidTouch) {\n if (this.zoomHor) {\n this.pinchTranslateDirection(true, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n if (this.zoomVert) {\n this.pinchTranslateDirection(false, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch);\n }\n }\n /**\n * Run translation operations for each direction (horizontal and vertical)\n * independently.\n * @private\n * @function Highcharts.Pointer#pinchTranslateDirection\n */\n pinchTranslateDirection(horiz, pinchDown, touches, transform, selectionMarker, clip, lastValidTouch, forcedScale) {\n const chart = this.chart, xy = horiz ? 'x' : 'y', XY = horiz ? 'X' : 'Y', sChartXY = ('chart' + XY), wh = horiz ? 'width' : 'height', plotLeftTop = chart['plot' + (horiz ? 'Left' : 'Top')], inverted = chart.inverted, bounds = chart.bounds[horiz ? 'h' : 'v'], singleTouch = pinchDown.length === 1, touch0Start = pinchDown[0][sChartXY], touch1Start = !singleTouch && pinchDown[1][sChartXY], setScale = function () {\n // Don't zoom if fingers are too close on this axis\n if (typeof touch1Now === 'number' &&\n Math.abs(touch0Start - touch1Start) > 20) {\n scale = forcedScale ||\n Math.abs(touch0Now - touch1Now) /\n Math.abs(touch0Start - touch1Start);\n }\n clipXY = ((plotLeftTop - touch0Now) / scale) + touch0Start;\n selectionWH = chart['plot' + (horiz ? 'Width' : 'Height')] / scale;\n };\n let selectionWH, selectionXY, clipXY, scale = forcedScale || 1, touch0Now = touches[0][sChartXY], touch1Now = !singleTouch && touches[1][sChartXY], outOfBounds;\n // Set the scale, first pass\n setScale();\n // The clip position (x or y) is altered if out of bounds, the selection\n // position is not\n selectionXY = clipXY;\n // Out of bounds\n if (selectionXY < bounds.min) {\n selectionXY = bounds.min;\n outOfBounds = true;\n }\n else if (selectionXY + selectionWH > bounds.max) {\n selectionXY = bounds.max - selectionWH;\n outOfBounds = true;\n }\n // Is the chart dragged off its bounds, determined by dataMin and\n // dataMax?\n if (outOfBounds) {\n // Modify the touchNow position in order to create an elastic drag\n // movement. This indicates to the user that the chart is responsive\n // but can't be dragged further.\n touch0Now -= 0.8 * (touch0Now - lastValidTouch[xy][0]);\n if (typeof touch1Now === 'number') {\n touch1Now -= 0.8 * (touch1Now - lastValidTouch[xy][1]);\n }\n // Set the scale, second pass to adapt to the modified touchNow\n // positions\n setScale();\n }\n else {\n lastValidTouch[xy] = [touch0Now, touch1Now];\n }\n // Set geometry for clipping, selection and transformation\n if (!inverted) {\n clip[xy] = clipXY - plotLeftTop;\n clip[wh] = selectionWH;\n }\n const scaleKey = inverted ?\n (horiz ? 'scaleY' : 'scaleX') : 'scale' + XY;\n const transformScale = inverted ? 1 / scale : scale;\n selectionMarker[wh] = selectionWH;\n selectionMarker[xy] = selectionXY;\n transform[scaleKey] = scale;\n transform['translate' + XY] = (transformScale * plotLeftTop) +\n (touch0Now - (transformScale * touch0Start));\n }\n /**\n * Reset the tracking by hiding the tooltip, the hover series state and the\n * hover point\n *\n * @function Highcharts.Pointer#reset\n *\n * @param {boolean} [allowMove]\n * Instead of destroying the tooltip altogether, allow moving it if\n * possible.\n *\n * @param {number} [delay]\n */\n reset(allowMove, delay) {\n const pointer = this, chart = pointer.chart, hoverSeries = chart.hoverSeries, hoverPoint = chart.hoverPoint, hoverPoints = chart.hoverPoints, tooltip = chart.tooltip, tooltipPoints = tooltip && tooltip.shared ?\n hoverPoints :\n hoverPoint;\n // Check if the points have moved outside the plot area (#1003, #4736,\n // #5101)\n if (allowMove && tooltipPoints) {\n splat(tooltipPoints).forEach(function (point) {\n if (point.series.isCartesian &&\n typeof point.plotX === 'undefined') {\n allowMove = false;\n }\n });\n }\n // Just move the tooltip, #349\n if (allowMove) {\n if (tooltip && tooltipPoints && splat(tooltipPoints).length) {\n tooltip.refresh(tooltipPoints);\n if (tooltip.shared && hoverPoints) { // #8284\n hoverPoints.forEach(function (point) {\n point.setState(point.state, true);\n if (point.series.isCartesian) {\n if (point.series.xAxis.crosshair) {\n point.series.xAxis\n .drawCrosshair(null, point);\n }\n if (point.series.yAxis.crosshair) {\n point.series.yAxis\n .drawCrosshair(null, point);\n }\n }\n });\n }\n else if (hoverPoint) { // #2500\n hoverPoint.setState(hoverPoint.state, true);\n chart.axes.forEach(function (axis) {\n if (axis.crosshair &&\n hoverPoint.series[axis.coll] === axis) {\n axis.drawCrosshair(null, hoverPoint);\n }\n });\n }\n }\n // Full reset\n }\n else {\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n if (hoverSeries) {\n hoverSeries.onMouseOut();\n }\n if (tooltip) {\n tooltip.hide(delay);\n }\n if (pointer.unDocMouseMove) {\n pointer.unDocMouseMove = pointer.unDocMouseMove();\n }\n // Remove crosshairs\n chart.axes.forEach(function (axis) {\n axis.hideCrosshair();\n });\n pointer.hoverX = chart.hoverPoints = chart.hoverPoint = null;\n }\n }\n /**\n * With line type charts with a single tracker, get the point closest to the\n * mouse. Run Point.onMouseOver and display tooltip for the point or points.\n *\n * @private\n * @function Highcharts.Pointer#runPointActions\n *\n * @emits Highcharts.Point#event:mouseOut\n * @emits Highcharts.Point#event:mouseOver\n */\n runPointActions(e, p, force) {\n const pointer = this, chart = pointer.chart, series = chart.series, tooltip = (chart.tooltip && chart.tooltip.options.enabled ?\n chart.tooltip :\n void 0), shared = (tooltip ?\n tooltip.shared :\n false);\n let hoverPoint = p || chart.hoverPoint, hoverSeries = hoverPoint && hoverPoint.series || chart.hoverSeries;\n const // onMouseOver or already hovering a series with directTouch\n isDirectTouch = (!e || e.type !== 'touchmove') && (!!p || ((hoverSeries && hoverSeries.directTouch) &&\n pointer.isDirectTouch)), hoverData = this.getHoverData(hoverPoint, hoverSeries, series, isDirectTouch, shared, e);\n // Update variables from hoverData.\n hoverPoint = hoverData.hoverPoint;\n hoverSeries = hoverData.hoverSeries;\n const points = hoverData.hoverPoints, followPointer = hoverSeries &&\n hoverSeries.tooltipOptions.followPointer &&\n !hoverSeries.tooltipOptions.split, useSharedTooltip = (shared &&\n hoverSeries &&\n !hoverSeries.noSharedTooltip);\n // Refresh tooltip for kdpoint if new hover point or tooltip was hidden\n // #3926, #4200\n if (hoverPoint &&\n (force ||\n hoverPoint !== chart.hoverPoint ||\n (tooltip && tooltip.isHidden))) {\n (chart.hoverPoints || []).forEach(function (p) {\n if (points.indexOf(p) === -1) {\n p.setState();\n }\n });\n // Set normal state to previous series\n if (chart.hoverSeries !== hoverSeries) {\n hoverSeries.onMouseOver();\n }\n pointer.applyInactiveState(points);\n // Do mouseover on all points (#3919, #3985, #4410, #5622)\n (points || []).forEach(function (p) {\n p.setState('hover');\n });\n // If tracking is on series in stead of on each point,\n // fire mouseOver on hover point. // #4448\n if (chart.hoverPoint) {\n chart.hoverPoint.firePointEvent('mouseOut');\n }\n // Hover point may have been destroyed in the event handlers (#7127)\n if (!hoverPoint.series) {\n return;\n }\n /**\n * Contains all hovered points.\n *\n * @name Highcharts.Chart#hoverPoints\n * @type {Array|null}\n */\n chart.hoverPoints = points;\n /**\n * Contains the original hovered point.\n *\n * @name Highcharts.Chart#hoverPoint\n * @type {Highcharts.Point|null}\n */\n chart.hoverPoint = hoverPoint;\n /**\n * Hover state should not be lost when axis is updated (#12569)\n * Axis.update runs pointer.reset which uses chart.hoverPoint.state\n * to apply state which does not exist in hoverPoint yet.\n * The mouseOver event should be triggered when hoverPoint\n * is correct.\n */\n hoverPoint.firePointEvent('mouseOver', void 0, () => {\n // Draw tooltip if necessary\n if (tooltip && hoverPoint) {\n tooltip.refresh(useSharedTooltip ? points : hoverPoint, e);\n }\n });\n // Update positions (regardless of kdpoint or hoverPoint)\n }\n else if (followPointer && tooltip && !tooltip.isHidden) {\n const anchor = tooltip.getAnchor([{}], e);\n if (chart.isInsidePlot(anchor[0], anchor[1], {\n visiblePlotOnly: true\n })) {\n tooltip.updatePosition({ plotX: anchor[0], plotY: anchor[1] });\n }\n }\n // Start the event listener to pick up the tooltip and crosshairs\n if (!pointer.unDocMouseMove) {\n pointer.unDocMouseMove = addEvent(chart.container.ownerDocument, 'mousemove', function (e) {\n const chart = charts[Pointer.hoverChartIndex];\n if (chart) {\n chart.pointer.onDocumentMouseMove(e);\n }\n });\n pointer.eventsToUnbind.push(pointer.unDocMouseMove);\n }\n // Issues related to crosshair #4927, #5269 #5066, #5658\n chart.axes.forEach(function drawAxisCrosshair(axis) {\n const snap = pick((axis.crosshair || {}).snap, true);\n let point;\n if (snap) {\n point = chart.hoverPoint; // #13002\n if (!point || point.series[axis.coll] !== axis) {\n point = find(points, (p) => p.series && p.series[axis.coll] === axis);\n }\n }\n // Axis has snapping crosshairs, and one of the hover points belongs\n // to axis. Always call drawCrosshair when it is not snap.\n if (point || !snap) {\n axis.drawCrosshair(e, point);\n // Axis has snapping crosshairs, but no hover point belongs to axis\n }\n else {\n axis.hideCrosshair();\n }\n });\n }\n /**\n * Scale series groups to a certain scale and translation.\n * @private\n * @function Highcharts.Pointer#scaleGroups\n */\n scaleGroups(attribs, clip) {\n const chart = this.chart;\n // Scale each series\n chart.series.forEach(function (series) {\n const seriesAttribs = attribs || series.getPlotBox(); // #1701\n if (series.group &&\n ((series.xAxis && series.xAxis.zoomEnabled) ||\n chart.mapView)) {\n series.group.attr(seriesAttribs);\n if (series.markerGroup) {\n series.markerGroup.attr(seriesAttribs);\n series.markerGroup.clip(clip ? chart.clipRect : null);\n }\n if (series.dataLabelsGroup) {\n series.dataLabelsGroup.attr(seriesAttribs);\n }\n }\n });\n // Clip\n chart.clipRect.attr(clip || chart.clipBox);\n }\n /**\n * Set the JS DOM events on the container and document. This method should\n * contain a one-to-one assignment between methods and their handlers. Any\n * advanced logic should be moved to the handler reflecting the event's\n * name.\n * @private\n * @function Highcharts.Pointer#setDOMEvents\n */\n setDOMEvents() {\n const container = this.chart.container, ownerDoc = container.ownerDocument;\n container.onmousedown = this.onContainerMouseDown.bind(this);\n container.onmousemove = this.onContainerMouseMove.bind(this);\n container.onclick = this.onContainerClick.bind(this);\n this.eventsToUnbind.push(addEvent(container, 'mouseenter', this.onContainerMouseEnter.bind(this)));\n this.eventsToUnbind.push(addEvent(container, 'mouseleave', this.onContainerMouseLeave.bind(this)));\n if (!Pointer.unbindDocumentMouseUp) {\n Pointer.unbindDocumentMouseUp = addEvent(ownerDoc, 'mouseup', this.onDocumentMouseUp.bind(this));\n }\n // In case we are dealing with overflow, reset the chart position when\n // scrolling parent elements\n let parent = this.chart.renderTo.parentElement;\n while (parent && parent.tagName !== 'BODY') {\n this.eventsToUnbind.push(addEvent(parent, 'scroll', () => {\n delete this.chartPosition;\n }));\n parent = parent.parentElement;\n }\n if (H.hasTouch) {\n this.eventsToUnbind.push(addEvent(container, 'touchstart', this.onContainerTouchStart.bind(this), { passive: false }));\n this.eventsToUnbind.push(addEvent(container, 'touchmove', this.onContainerTouchMove.bind(this), { passive: false }));\n if (!Pointer.unbindDocumentTouchEnd) {\n Pointer.unbindDocumentTouchEnd = addEvent(ownerDoc, 'touchend', this.onDocumentTouchEnd.bind(this), { passive: false });\n }\n }\n }\n /**\n * Sets the index of the hovered chart and leaves the previous hovered\n * chart, to reset states like tooltip.\n * @private\n * @function Highcharts.Pointer#setHoverChartIndex\n */\n setHoverChartIndex() {\n const chart = this.chart;\n const hoverChart = H.charts[pick(Pointer.hoverChartIndex, -1)];\n if (hoverChart &&\n hoverChart !== chart) {\n hoverChart.pointer.onContainerMouseLeave({ relatedTarget: chart.container });\n }\n if (!hoverChart ||\n !hoverChart.mouseIsDown) {\n Pointer.hoverChartIndex = chart.index;\n }\n }\n /**\n * General touch handler shared by touchstart and touchmove.\n * @private\n * @function Highcharts.Pointer#touch\n */\n touch(e, start) {\n const chart = this.chart;\n let hasMoved, pinchDown, isInside;\n this.setHoverChartIndex();\n if (e.touches.length === 1) {\n e = this.normalize(e);\n isInside = chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop, {\n visiblePlotOnly: true\n });\n if (isInside && !chart.openMenu) {\n // Run mouse events and display tooltip etc\n if (start) {\n this.runPointActions(e);\n }\n // Android fires touchmove events after the touchstart even if\n // the finger hasn't moved, or moved only a pixel or two. In iOS\n // however, the touchmove doesn't fire unless the finger moves\n // more than ~4px. So we emulate this behaviour in Android by\n // checking how much it moved, and cancelling on small\n // distances. #3450.\n if (e.type === 'touchmove') {\n pinchDown = this.pinchDown;\n hasMoved = pinchDown[0] ? Math.sqrt(// #5266\n Math.pow(pinchDown[0].chartX - e.chartX, 2) +\n Math.pow(pinchDown[0].chartY - e.chartY, 2)) >= 4 : false;\n }\n if (pick(hasMoved, true)) {\n this.pinch(e);\n }\n }\n else if (start) {\n // Hide the tooltip on touching outside the plot area (#1203)\n this.reset();\n }\n }\n else if (e.touches.length === 2) {\n this.pinch(e);\n }\n }\n /**\n * Returns true if the chart is set up for zooming by single touch and the\n * event is capable\n * @private\n * @function Highcharts.Pointer#touchSelect\n */\n touchSelect(e) {\n return Boolean(this.chart.zooming.singleTouch &&\n e.touches &&\n e.touches.length === 1);\n }\n /**\n * Resolve the zoomType option, this is reset on all touch start and mouse\n * down events.\n * @private\n * @function Highcharts.Pointer#zoomOption\n */\n zoomOption(e) {\n const chart = this.chart, options = chart.options.chart, inverted = chart.inverted;\n let zoomType = chart.zooming.type || '', zoomX, zoomY;\n // Look for the pinchType option\n if (/touch/.test(e.type)) {\n zoomType = pick(chart.zooming.pinchType, zoomType);\n }\n this.zoomX = zoomX = /x/.test(zoomType);\n this.zoomY = zoomY = /y/.test(zoomType);\n this.zoomHor = (zoomX && !inverted) || (zoomY && inverted);\n this.zoomVert = (zoomY && !inverted) || (zoomX && inverted);\n this.hasZoom = zoomX || zoomY;\n }\n }\n /* *\n *\n * Class Namespace\n *\n * */\n (function (Pointer) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedEvents = [];\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'beforeRender', function () {\n /**\n * The Pointer that keeps track of mouse and touch\n * interaction.\n *\n * @memberof Highcharts.Chart\n * @name pointer\n * @type {Highcharts.Pointer}\n * @instance\n */\n this.pointer = new Pointer(this, this.options);\n });\n }\n }\n Pointer.compose = compose;\n /**\n * @private\n */\n function dissolve() {\n for (let i = 0, iEnd = composedEvents.length; i < iEnd; ++i) {\n composedEvents[i]();\n }\n composedEvents.length = 0;\n }\n Pointer.dissolve = dissolve;\n })(Pointer || (Pointer = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Chart position and scale.\n *\n * @interface Highcharts.ChartPositionObject\n */ /**\n * @name Highcharts.ChartPositionObject#left\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.ChartPositionObject#top\n * @type {number}\n */\n /**\n * One position in relation to an axis.\n *\n * @interface Highcharts.PointerAxisCoordinateObject\n */ /**\n * Related axis.\n *\n * @name Highcharts.PointerAxisCoordinateObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Axis value.\n *\n * @name Highcharts.PointerAxisCoordinateObject#value\n * @type {number}\n */\n /**\n * Positions in terms of axis values.\n *\n * @interface Highcharts.PointerAxisCoordinatesObject\n */ /**\n * Positions on the x-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#xAxis\n * @type {Array}\n */ /**\n * Positions on the y-axis.\n * @name Highcharts.PointerAxisCoordinatesObject#yAxis\n * @type {Array}\n */\n /**\n * Pointer coordinates.\n *\n * @interface Highcharts.PointerCoordinatesObject\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartX\n * @type {number}\n */ /**\n * @name Highcharts.PointerCoordinatesObject#chartY\n * @type {number}\n */\n /**\n * A native browser mouse or touch event, extended with position information\n * relative to the {@link Chart.container}.\n *\n * @interface Highcharts.PointerEventObject\n * @extends global.PointerEvent\n */ /**\n * The X coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartX\n * @type {number}\n */ /**\n * The Y coordinate of the pointer interaction relative to the chart.\n *\n * @name Highcharts.PointerEventObject#chartY\n * @type {number}\n */\n /**\n * Axis-specific data of a selection.\n *\n * @interface Highcharts.SelectDataObject\n */ /**\n * The selected Axis.\n * @name Highcharts.SelectDataObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * The maximum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#max\n * @type {number}\n */ /**\n * The minimum axis value, either automatic or set manually.\n * @name Highcharts.SelectDataObject#min\n * @type {number}\n */\n /**\n * Object for select events.\n * The primary axes are `xAxis[0]` and `yAxis[0]`. Remember the unit of a\n * datetime axis is milliseconds since 1970-01-01 00:00:00.\n *\n * @interface Highcharts.SelectEventObject\n */ /**\n * The related browser event.\n * @name Highcharts.SelectEventObject#originalEvent\n * @type {global.Event}\n */ /**\n * Indicates a reset event to restore default state.\n * @name Highcharts.SelectEventObject#resetSelection\n * @type {boolean|undefined}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#xAxis\n * @type {Array}\n */ /**\n * Arrays containing the axes of each dimension and each axis' min and max\n * values.\n * @name Highcharts.SelectEventObject#yAxis\n * @type {Array}\n */\n ''; // keeps doclets above in JS file\n\n return Pointer;\n });\n _registerModule(_modules, 'Core/Legend/Legend.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Core/Series/Point.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Utilities.js']], function (A, F, H, Point, R, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject, setAnimation } = A;\n const { format } = F;\n const { marginNames } = H;\n const { distribute } = R;\n const { addEvent, createElement, css, defined, discardElement, find, fireEvent, isNumber, merge, pick, relativeLength, stableSort, syncTimeout } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The overview of the chart's series. The legend object is instanciated\n * internally in the chart constructor, and is available from the `chart.legend`\n * property. Each chart has only one legend.\n *\n * @class\n * @name Highcharts.Legend\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n class Legend {\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, options) {\n /* *\n *\n * Properties\n *\n * */\n this.allItems = [];\n this.box = void 0;\n this.contentGroup = void 0;\n this.display = false;\n this.group = void 0;\n this.initialItemY = 0;\n this.itemHeight = 0;\n this.itemMarginBottom = 0;\n this.itemMarginTop = 0;\n this.itemX = 0;\n this.itemY = 0;\n this.lastItemY = 0;\n this.lastLineHeight = 0;\n this.legendHeight = 0;\n this.legendWidth = 0;\n this.maxItemWidth = 0;\n this.maxLegendWidth = 0;\n this.offsetWidth = 0;\n this.options = void 0;\n this.padding = 0;\n this.pages = [];\n this.proximate = false;\n this.scrollGroup = void 0;\n this.symbolHeight = 0;\n this.symbolWidth = 0;\n this.titleHeight = 0;\n this.totalItemWidth = 0;\n this.widthOption = 0;\n this.chart = chart;\n this.init(chart, options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the legend.\n *\n * @private\n * @function Highcharts.Legend#init\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n */\n init(chart, options) {\n /**\n * Chart of this legend.\n *\n * @readonly\n * @name Highcharts.Legend#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n this.setOptions(options);\n if (options.enabled) {\n // Render it\n this.render();\n // move checkboxes\n addEvent(this.chart, 'endResize', function () {\n this.legend.positionCheckboxes();\n });\n // On Legend.init and Legend.update, make sure that proximate layout\n // events are either added or removed (#18362).\n addEvent(this.chart, 'render', () => {\n if (this.proximate) {\n this.proximatePositions();\n this.positionItems();\n }\n });\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#setOptions\n * @param {Highcharts.LegendOptions} options\n */\n setOptions(options) {\n const padding = pick(options.padding, 8);\n /**\n * Legend options.\n *\n * @readonly\n * @name Highcharts.Legend#options\n * @type {Highcharts.LegendOptions}\n */\n this.options = options;\n if (!this.chart.styledMode) {\n this.itemStyle = options.itemStyle;\n this.itemHiddenStyle = merge(this.itemStyle, options.itemHiddenStyle);\n }\n this.itemMarginTop = options.itemMarginTop;\n this.itemMarginBottom = options.itemMarginBottom;\n this.padding = padding;\n this.initialItemY = padding - 5; // 5 is pixels above the text\n this.symbolWidth = pick(options.symbolWidth, 16);\n this.pages = [];\n this.proximate = options.layout === 'proximate' && !this.chart.inverted;\n // #12705: baseline has to be reset on every update\n this.baseline = void 0;\n }\n /**\n * Update the legend with new options. Equivalent to running `chart.update`\n * with a legend configuration option.\n *\n * @sample highcharts/legend/legend-update/\n * Legend update\n *\n * @function Highcharts.Legend#update\n *\n * @param {Highcharts.LegendOptions} options\n * Legend options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the axis is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after. Whether to redraw the chart.\n *\n * @emits Highcharts.Legends#event:afterUpdate\n */\n update(options, redraw) {\n const chart = this.chart;\n this.setOptions(merge(true, this.options, options));\n this.destroy();\n chart.isDirtyLegend = chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n fireEvent(this, 'afterUpdate');\n }\n /**\n * Set the colors for the legend item.\n *\n * @private\n * @function Highcharts.Legend#colorizeItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * A Series or Point instance\n * @param {boolean} [visible=false]\n * Dimmed or colored\n *\n * @todo\n * Make events official: Fires the event `afterColorizeItem`.\n */\n colorizeItem(item, visible) {\n const { group, label, line, symbol } = item.legendItem || {};\n if (group) {\n group[visible ? 'removeClass' : 'addClass']('highcharts-legend-item-hidden');\n }\n if (!this.chart.styledMode) {\n const { itemHiddenStyle } = this, hiddenColor = itemHiddenStyle.color, symbolColor = visible ?\n (item.color || hiddenColor) :\n hiddenColor, markerOptions = item.options && item.options.marker;\n let symbolAttr = { fill: symbolColor };\n label === null || label === void 0 ? void 0 : label.css(merge(visible ? this.itemStyle : itemHiddenStyle));\n line === null || line === void 0 ? void 0 : line.attr({ stroke: symbolColor });\n if (symbol) {\n // Apply marker options\n if (markerOptions && symbol.isMarker) { // #585\n symbolAttr = item.pointAttribs();\n if (!visible) {\n // #6769\n symbolAttr.stroke = symbolAttr.fill = hiddenColor;\n }\n }\n symbol.attr(symbolAttr);\n }\n }\n fireEvent(this, 'afterColorizeItem', { item, visible });\n }\n /**\n * @private\n * @function Highcharts.Legend#positionItems\n */\n positionItems() {\n // Now that the legend width and height are established, put the items\n // in the final position\n this.allItems.forEach(this.positionItem, this);\n if (!this.chart.isResizing) {\n this.positionCheckboxes();\n }\n }\n /**\n * Position the legend item.\n *\n * @private\n * @function Highcharts.Legend#positionItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to position\n */\n positionItem(item) {\n const legend = this, { group, x = 0, y = 0 } = item.legendItem || {}, options = legend.options, symbolPadding = options.symbolPadding, ltr = !options.rtl, checkbox = item.checkbox;\n if (group && group.element) {\n const attribs = {\n translateX: ltr ?\n x :\n legend.legendWidth - x - 2 * symbolPadding - 4,\n translateY: y\n };\n const complete = () => {\n fireEvent(this, 'afterPositionItem', { item });\n };\n group[defined(group.translateY) ? 'animate' : 'attr'](attribs, void 0, complete);\n }\n if (checkbox) {\n checkbox.x = x;\n checkbox.y = y;\n }\n }\n /**\n * Destroy a single legend item, used internally on removing series items.\n *\n * @private\n * @function Highcharts.Legend#destroyItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to remove\n */\n destroyItem(item) {\n const checkbox = item.checkbox, legendItem = item.legendItem || {};\n // destroy SVG elements\n for (const key of ['group', 'label', 'line', 'symbol']) {\n if (legendItem[key]) {\n legendItem[key] = legendItem[key].destroy();\n }\n }\n if (checkbox) {\n discardElement(checkbox);\n }\n item.legendItem = void 0;\n }\n /**\n * Destroy the legend. Used internally. To reflow objects, `chart.redraw`\n * must be called after destruction.\n *\n * @private\n * @function Highcharts.Legend#destroy\n */\n destroy() {\n const legend = this;\n // Destroy items\n for (const item of this.getAllItems()) {\n this.destroyItem(item);\n }\n // Destroy legend elements\n for (const key of [\n 'clipRect',\n 'up',\n 'down',\n 'pager',\n 'nav',\n 'box',\n 'title',\n 'group'\n ]) {\n if (legend[key]) {\n legend[key] = legend[key].destroy();\n }\n }\n this.display = null; // Reset in .render on update.\n }\n /**\n * Position the checkboxes after the width is determined.\n *\n * @private\n * @function Highcharts.Legend#positionCheckboxes\n */\n positionCheckboxes() {\n const alignAttr = this.group && this.group.alignAttr, clipHeight = this.clipHeight || this.legendHeight, titleHeight = this.titleHeight;\n let translateY;\n if (alignAttr) {\n translateY = alignAttr.translateY;\n this.allItems.forEach(function (item) {\n const checkbox = item.checkbox;\n let top;\n if (checkbox) {\n top = translateY + titleHeight + checkbox.y +\n (this.scrollOffset || 0) + 3;\n css(checkbox, {\n left: (alignAttr.translateX + item.checkboxOffset +\n checkbox.x - 20) + 'px',\n top: top + 'px',\n display: this.proximate || (top > translateY - 6 &&\n top < translateY + clipHeight - 6) ?\n '' :\n 'none'\n });\n }\n }, this);\n }\n }\n /**\n * Render the legend title on top of the legend.\n *\n * @private\n * @function Highcharts.Legend#renderTitle\n */\n renderTitle() {\n const options = this.options, padding = this.padding, titleOptions = options.title;\n let bBox, titleHeight = 0;\n if (titleOptions.text) {\n if (!this.title) {\n /**\n * SVG element of the legend title.\n *\n * @readonly\n * @name Highcharts.Legend#title\n * @type {Highcharts.SVGElement}\n */\n this.title = this.chart.renderer.label(titleOptions.text, padding - 3, padding - 4, void 0, void 0, void 0, options.useHTML, void 0, 'legend-title')\n .attr({ zIndex: 1 });\n if (!this.chart.styledMode) {\n this.title.css(titleOptions.style);\n }\n this.title.add(this.group);\n }\n // Set the max title width (#7253)\n if (!titleOptions.width) {\n this.title.css({\n width: this.maxLegendWidth + 'px'\n });\n }\n bBox = this.title.getBBox();\n titleHeight = bBox.height;\n this.offsetWidth = bBox.width; // #1717\n this.contentGroup.attr({ translateY: titleHeight });\n }\n this.titleHeight = titleHeight;\n }\n /**\n * Set the legend item text.\n *\n * @function Highcharts.Legend#setText\n * @param {Highcharts.Point|Highcharts.Series} item\n * The item for which to update the text in the legend.\n */\n setText(item) {\n const options = this.options;\n item.legendItem.label.attr({\n text: options.labelFormat ?\n format(options.labelFormat, item, this.chart) :\n options.labelFormatter.call(item)\n });\n }\n /**\n * Render a single specific legend item. Called internally from the `render`\n * function.\n *\n * @private\n * @function Highcharts.Legend#renderItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n * The item to render.\n */\n renderItem(item) {\n const legend = this, legendItem = item.legendItem = item.legendItem || {}, chart = legend.chart, renderer = chart.renderer, options = legend.options, horizontal = options.layout === 'horizontal', symbolWidth = legend.symbolWidth, symbolPadding = options.symbolPadding || 0, itemStyle = legend.itemStyle, itemHiddenStyle = legend.itemHiddenStyle, itemDistance = horizontal ? pick(options.itemDistance, 20) : 0, ltr = !options.rtl, isSeries = !item.series, series = !isSeries && item.series.drawLegendSymbol ?\n item.series :\n item, seriesOptions = series.options, showCheckbox = (legend.createCheckboxForItem) &&\n seriesOptions &&\n seriesOptions.showCheckbox, useHTML = options.useHTML, itemClassName = item.options.className;\n let label = legendItem.label, \n // full width minus text width\n itemExtraWidth = symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (!label) { // generate it once, later move it\n // Generate the group box, a group to hold the symbol and text. Text\n // is to be appended in Legend class.\n legendItem.group = renderer\n .g('legend-item')\n .addClass('highcharts-' + series.type + '-series ' +\n 'highcharts-color-' + item.colorIndex +\n (itemClassName ? ' ' + itemClassName : '') +\n (isSeries ?\n ' highcharts-series-' + item.index :\n ''))\n .attr({ zIndex: 1 })\n .add(legend.scrollGroup);\n // Generate the list item text and add it to the group\n legendItem.label = label = renderer.text('', ltr ?\n symbolWidth + symbolPadding :\n -symbolPadding, legend.baseline || 0, useHTML);\n if (!chart.styledMode) {\n // merge to prevent modifying original (#1021)\n label.css(merge(item.visible ?\n itemStyle :\n itemHiddenStyle));\n }\n label\n .attr({\n align: ltr ? 'left' : 'right',\n zIndex: 2\n })\n .add(legendItem.group);\n // Get the baseline for the first item - the font size is equal for\n // all\n if (!legend.baseline) {\n legend.fontMetrics = renderer.fontMetrics(label);\n legend.baseline =\n legend.fontMetrics.f + 3 + legend.itemMarginTop;\n label.attr('y', legend.baseline);\n legend.symbolHeight =\n pick(options.symbolHeight, legend.fontMetrics.f);\n if (options.squareSymbol) {\n legend.symbolWidth = pick(options.symbolWidth, Math.max(legend.symbolHeight, 16));\n itemExtraWidth = legend.symbolWidth + symbolPadding +\n itemDistance + (showCheckbox ? 20 : 0);\n if (ltr) {\n label.attr('x', legend.symbolWidth + symbolPadding);\n }\n }\n }\n // Draw the legend symbol inside the group box\n series.drawLegendSymbol(legend, item);\n if (legend.setItemEvents) {\n legend.setItemEvents(item, label, useHTML);\n }\n }\n // Add the HTML checkbox on top\n if (showCheckbox && !item.checkbox && legend.createCheckboxForItem) {\n legend.createCheckboxForItem(item);\n }\n // Colorize the items\n legend.colorizeItem(item, item.visible);\n // Take care of max width and text overflow (#6659)\n if (chart.styledMode || !itemStyle.width) {\n label.css({\n width: ((options.itemWidth ||\n legend.widthOption ||\n chart.spacingBox.width) - itemExtraWidth) + 'px'\n });\n }\n // Always update the text\n legend.setText(item);\n // calculate the positions for the next line\n const bBox = label.getBBox();\n const fontMetricsH = (legend.fontMetrics && legend.fontMetrics.h) || 0;\n item.itemWidth = item.checkboxOffset =\n options.itemWidth ||\n legendItem.labelWidth ||\n bBox.width + itemExtraWidth;\n legend.maxItemWidth = Math.max(legend.maxItemWidth, item.itemWidth);\n legend.totalItemWidth += item.itemWidth;\n legend.itemHeight = item.itemHeight = Math.round(legendItem.labelHeight ||\n // use bBox for multiline (#16398)\n (bBox.height > fontMetricsH * 1.5 ? bBox.height : fontMetricsH));\n }\n /**\n * Get the position of the item in the layout. We now know the\n * maxItemWidth from the previous loop.\n *\n * @private\n * @function Highcharts.Legend#layoutItem\n * @param {Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series} item\n */\n layoutItem(item) {\n const options = this.options, padding = this.padding, horizontal = options.layout === 'horizontal', itemHeight = item.itemHeight, itemMarginBottom = this.itemMarginBottom, itemMarginTop = this.itemMarginTop, itemDistance = horizontal ? pick(options.itemDistance, 20) : 0, maxLegendWidth = this.maxLegendWidth, itemWidth = (options.alignColumns &&\n this.totalItemWidth > maxLegendWidth) ?\n this.maxItemWidth :\n item.itemWidth, legendItem = item.legendItem || {};\n // If the item exceeds the width, start a new line\n if (horizontal &&\n this.itemX - padding + itemWidth > maxLegendWidth) {\n this.itemX = padding;\n if (this.lastLineHeight) { // Not for the first line (#10167)\n this.itemY += (itemMarginTop +\n this.lastLineHeight +\n itemMarginBottom);\n }\n this.lastLineHeight = 0; // reset for next line (#915, #3976)\n }\n // Set the edge positions\n this.lastItemY = itemMarginTop + this.itemY + itemMarginBottom;\n this.lastLineHeight = Math.max(// #915\n itemHeight, this.lastLineHeight);\n // cache the position of the newly generated or reordered items\n legendItem.x = this.itemX;\n legendItem.y = this.itemY;\n // advance\n if (horizontal) {\n this.itemX += itemWidth;\n }\n else {\n this.itemY +=\n itemMarginTop + itemHeight + itemMarginBottom;\n this.lastLineHeight = itemHeight;\n }\n // the width of the widest item\n this.offsetWidth = this.widthOption || Math.max((horizontal ? this.itemX - padding - (item.checkbox ?\n // decrease by itemDistance only when no checkbox #4853\n 0 :\n itemDistance) : itemWidth) + padding, this.offsetWidth);\n }\n /**\n * Get all items, which is one item per series for most series and one\n * item per point for pie series and its derivatives. Fires the event\n * `afterGetAllItems`.\n *\n * @private\n * @function Highcharts.Legend#getAllItems\n * @return {Array<(Highcharts.BubbleLegendItem|Highcharts.Point|Highcharts.Series)>}\n * The current items in the legend.\n * @emits Highcharts.Legend#event:afterGetAllItems\n */\n getAllItems() {\n let allItems = [];\n this.chart.series.forEach(function (series) {\n const seriesOptions = series && series.options;\n // Handle showInLegend. If the series is linked to another series,\n // defaults to false.\n if (series && pick(seriesOptions.showInLegend, !defined(seriesOptions.linkedTo) ? void 0 : false, true)) {\n // Use points or series for the legend item depending on\n // legendType\n allItems = allItems.concat((series.legendItem || {}).labels ||\n (seriesOptions.legendType === 'point' ?\n series.data :\n series));\n }\n });\n fireEvent(this, 'afterGetAllItems', { allItems });\n return allItems;\n }\n /**\n * Get a short, three letter string reflecting the alignment and layout.\n *\n * @private\n * @function Highcharts.Legend#getAlignment\n * @return {string}\n * The alignment, empty string if floating\n */\n getAlignment() {\n const options = this.options;\n // Use the first letter of each alignment option in order to detect\n // the side. (#4189 - use charAt(x) notation instead of [x] for IE7)\n if (this.proximate) {\n return options.align.charAt(0) + 'tv';\n }\n return options.floating ? '' : (options.align.charAt(0) +\n options.verticalAlign.charAt(0) +\n options.layout.charAt(0));\n }\n /**\n * Adjust the chart margins by reserving space for the legend on only one\n * side of the chart. If the position is set to a corner, top or bottom is\n * reserved for horizontal legends and left or right for vertical ones.\n *\n * @private\n * @function Highcharts.Legend#adjustMargins\n * @param {Array} margin\n * @param {Array} spacing\n */\n adjustMargins(margin, spacing) {\n const chart = this.chart, options = this.options, alignment = this.getAlignment();\n if (alignment) {\n ([\n /(lth|ct|rth)/,\n /(rtv|rm|rbv)/,\n /(rbh|cb|lbh)/,\n /(lbv|lm|ltv)/\n ]).forEach(function (alignments, side) {\n if (alignments.test(alignment) && !defined(margin[side])) {\n // Now we have detected on which side of the chart we should\n // reserve space for the legend\n chart[marginNames[side]] = Math.max(chart[marginNames[side]], (chart.legend[(side + 1) % 2 ? 'legendHeight' : 'legendWidth'] +\n [1, -1, -1, 1][side] * options[(side % 2) ? 'x' : 'y'] +\n pick(options.margin, 12) +\n spacing[side] +\n (chart.titleOffset[side] || 0)));\n }\n });\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#proximatePositions\n */\n proximatePositions() {\n const chart = this.chart, boxes = [], alignLeft = this.options.align === 'left';\n this.allItems.forEach(function (item) {\n let lastPoint, height, useFirstPoint = alignLeft, target, top;\n if (item.yAxis) {\n if (item.xAxis.options.reversed) {\n useFirstPoint = !useFirstPoint;\n }\n if (item.points) {\n lastPoint = find(useFirstPoint ?\n item.points :\n item.points.slice(0).reverse(), function (item) {\n return isNumber(item.plotY);\n });\n }\n height = this.itemMarginTop +\n item.legendItem.label.getBBox().height +\n this.itemMarginBottom;\n top = item.yAxis.top - chart.plotTop;\n if (item.visible) {\n target = lastPoint ?\n lastPoint.plotY :\n item.yAxis.height;\n target += top - 0.3 * height;\n }\n else {\n target = top + item.yAxis.height;\n }\n boxes.push({\n target: target,\n size: height,\n item\n });\n }\n }, this);\n let legendItem;\n for (const box of distribute(boxes, chart.plotHeight)) {\n legendItem = box.item.legendItem || {};\n if (isNumber(box.pos)) {\n legendItem.y = chart.plotTop - chart.spacing[0] + box.pos;\n }\n }\n }\n /**\n * Render the legend. This method can be called both before and after\n * `chart.render`. If called after, it will only rearrange items instead\n * of creating new ones. Called internally on initial render and after\n * redraws.\n *\n * @private\n * @function Highcharts.Legend#render\n */\n render() {\n const legend = this, chart = legend.chart, renderer = chart.renderer, options = legend.options, padding = legend.padding, \n // add each series or point\n allItems = legend.getAllItems();\n let display, legendWidth, legendHeight, legendGroup = legend.group, allowedWidth, box = legend.box;\n legend.itemX = padding;\n legend.itemY = legend.initialItemY;\n legend.offsetWidth = 0;\n legend.lastItemY = 0;\n legend.widthOption = relativeLength(options.width, chart.spacingBox.width - padding);\n // Compute how wide the legend is allowed to be\n allowedWidth = chart.spacingBox.width - 2 * padding - options.x;\n if (['rm', 'lm'].indexOf(legend.getAlignment().substring(0, 2)) > -1) {\n allowedWidth /= 2;\n }\n legend.maxLegendWidth = legend.widthOption || allowedWidth;\n if (!legendGroup) {\n /**\n * SVG group of the legend.\n *\n * @readonly\n * @name Highcharts.Legend#group\n * @type {Highcharts.SVGElement}\n */\n legend.group = legendGroup = renderer\n .g('legend')\n .addClass(options.className || '')\n .attr({ zIndex: 7 })\n .add();\n legend.contentGroup = renderer\n .g()\n .attr({ zIndex: 1 }) // above background\n .add(legendGroup);\n legend.scrollGroup = renderer\n .g()\n .add(legend.contentGroup);\n }\n legend.renderTitle();\n // sort by legendIndex\n stableSort(allItems, (a, b) => ((a.options && a.options.legendIndex) || 0) -\n ((b.options && b.options.legendIndex) || 0));\n // reversed legend\n if (options.reversed) {\n allItems.reverse();\n }\n /**\n * All items for the legend, which is an array of series for most series\n * and an array of points for pie series and its derivatives.\n *\n * @readonly\n * @name Highcharts.Legend#allItems\n * @type {Array<(Highcharts.Point|Highcharts.Series)>}\n */\n legend.allItems = allItems;\n legend.display = display = !!allItems.length;\n // Render the items. First we run a loop to set the text and properties\n // and read all the bounding boxes. The next loop computes the item\n // positions based on the bounding boxes.\n legend.lastLineHeight = 0;\n legend.maxItemWidth = 0;\n legend.totalItemWidth = 0;\n legend.itemHeight = 0;\n allItems.forEach(legend.renderItem, legend);\n allItems.forEach(legend.layoutItem, legend);\n // Get the box\n legendWidth = (legend.widthOption || legend.offsetWidth) + padding;\n legendHeight = legend.lastItemY + legend.lastLineHeight +\n legend.titleHeight;\n legendHeight = legend.handleOverflow(legendHeight);\n legendHeight += padding;\n // Draw the border and/or background\n if (!box) {\n /**\n * SVG element of the legend box.\n *\n * @readonly\n * @name Highcharts.Legend#box\n * @type {Highcharts.SVGElement}\n */\n legend.box = box = renderer.rect()\n .addClass('highcharts-legend-box')\n .attr({\n r: options.borderRadius\n })\n .add(legendGroup);\n }\n // Presentational\n if (!chart.styledMode) {\n box\n .attr({\n stroke: options.borderColor,\n 'stroke-width': options.borderWidth || 0,\n fill: options.backgroundColor || 'none'\n })\n .shadow(options.shadow);\n }\n if (legendWidth > 0 && legendHeight > 0) {\n box[box.placed ? 'animate' : 'attr'](box.crisp.call({}, {\n x: 0,\n y: 0,\n width: legendWidth,\n height: legendHeight\n }, box.strokeWidth()));\n }\n // hide the border if no items\n legendGroup[display ? 'show' : 'hide']();\n // Open for responsiveness\n if (chart.styledMode && legendGroup.getStyle('display') === 'none') {\n legendWidth = legendHeight = 0;\n }\n legend.legendWidth = legendWidth;\n legend.legendHeight = legendHeight;\n if (display) {\n legend.align();\n }\n if (!this.proximate) {\n this.positionItems();\n }\n fireEvent(this, 'afterRender');\n }\n /**\n * Align the legend to chart's box.\n *\n * @private\n * @function Highcharts.align\n * @param {Highcharts.BBoxObject} alignTo\n */\n align(alignTo = this.chart.spacingBox) {\n const chart = this.chart, options = this.options;\n // If aligning to the top and the layout is horizontal, adjust for\n // the title (#7428)\n let y = alignTo.y;\n if (/(lth|ct|rth)/.test(this.getAlignment()) &&\n chart.titleOffset[0] > 0) {\n y += chart.titleOffset[0];\n }\n else if (/(lbh|cb|rbh)/.test(this.getAlignment()) &&\n chart.titleOffset[2] > 0) {\n y -= chart.titleOffset[2];\n }\n if (y !== alignTo.y) {\n alignTo = merge(alignTo, { y });\n }\n if (!chart.hasRendered) {\n // Avoid animation when adjusting alignment for responsiveness and\n // colorAxis label layout\n this.group.placed = false;\n }\n this.group.align(merge(options, {\n width: this.legendWidth,\n height: this.legendHeight,\n verticalAlign: this.proximate ? 'top' : options.verticalAlign\n }), true, alignTo);\n }\n /**\n * Set up the overflow handling by adding navigation with up and down arrows\n * below the legend.\n *\n * @private\n * @function Highcharts.Legend#handleOverflow\n */\n handleOverflow(legendHeight) {\n const legend = this, chart = this.chart, renderer = chart.renderer, options = this.options, optionsY = options.y, alignTop = options.verticalAlign === 'top', padding = this.padding, maxHeight = options.maxHeight, navOptions = options.navigation, animation = pick(navOptions.animation, true), arrowSize = navOptions.arrowSize || 12, pages = this.pages, allItems = this.allItems, clipToHeight = function (height) {\n if (typeof height === 'number') {\n clipRect.attr({\n height: height\n });\n }\n else if (clipRect) { // Reset (#5912)\n legend.clipRect = clipRect.destroy();\n legend.contentGroup.clip();\n }\n // useHTML\n if (legend.contentGroup.div) {\n legend.contentGroup.div.style.clip = height ?\n 'rect(' + padding + 'px,9999px,' +\n (padding + height) + 'px,0)' :\n 'auto';\n }\n }, addTracker = function (key) {\n legend[key] = renderer\n .circle(0, 0, arrowSize * 1.3)\n .translate(arrowSize / 2, arrowSize / 2)\n .add(nav);\n if (!chart.styledMode) {\n legend[key].attr('fill', 'rgba(0,0,0,0.0001)');\n }\n return legend[key];\n };\n let clipHeight, lastY, legendItem, spaceHeight = (chart.spacingBox.height +\n (alignTop ? -optionsY : optionsY) - padding), nav = this.nav, clipRect = this.clipRect;\n // Adjust the height\n if (options.layout === 'horizontal' &&\n options.verticalAlign !== 'middle' &&\n !options.floating) {\n spaceHeight /= 2;\n }\n if (maxHeight) {\n spaceHeight = Math.min(spaceHeight, maxHeight);\n }\n // Reset the legend height and adjust the clipping rectangle\n pages.length = 0;\n if (legendHeight &&\n spaceHeight > 0 &&\n legendHeight > spaceHeight &&\n navOptions.enabled !== false) {\n this.clipHeight = clipHeight =\n Math.max(spaceHeight - 20 - this.titleHeight - padding, 0);\n this.currentPage = pick(this.currentPage, 1);\n this.fullHeight = legendHeight;\n // Fill pages with Y positions so that the top of each a legend item\n // defines the scroll top for each page (#2098)\n allItems.forEach((item, i) => {\n legendItem = item.legendItem || {};\n const y = legendItem.y || 0, h = Math.round(legendItem.label.getBBox().height);\n let len = pages.length;\n if (!len || (y - pages[len - 1] > clipHeight &&\n (lastY || y) !== pages[len - 1])) {\n pages.push(lastY || y);\n len++;\n }\n // Keep track of which page each item is on\n legendItem.pageIx = len - 1;\n if (lastY) {\n (allItems[i - 1].legendItem || {}).pageIx = len - 1;\n }\n // add the last page if needed (#2617, #13683)\n if (\n // check the last item\n i === allItems.length - 1 &&\n // if adding next page is needed (#18768)\n y + h - pages[len - 1] > clipHeight &&\n y > pages[len - 1]) {\n pages.push(y);\n legendItem.pageIx = len;\n }\n if (y !== lastY) {\n lastY = y;\n }\n });\n // Only apply clipping if needed. Clipping causes blurred legend in\n // PDF export (#1787)\n if (!clipRect) {\n clipRect = legend.clipRect =\n renderer.clipRect(0, padding - 2, 9999, 0);\n legend.contentGroup.clip(clipRect);\n }\n clipToHeight(clipHeight);\n // Add navigation elements\n if (!nav) {\n this.nav = nav = renderer.g()\n .attr({ zIndex: 1 })\n .add(this.group);\n this.up = renderer\n .symbol('triangle', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('upTracker')\n .on('click', function () {\n legend.scroll(-1, animation);\n });\n this.pager = renderer.text('', 15, 10)\n .addClass('highcharts-legend-navigation');\n if (!chart.styledMode && navOptions.style) {\n this.pager.css(navOptions.style);\n }\n this.pager.add(nav);\n this.down = renderer\n .symbol('triangle-down', 0, 0, arrowSize, arrowSize)\n .add(nav);\n addTracker('downTracker')\n .on('click', function () {\n legend.scroll(1, animation);\n });\n }\n // Set initial position\n legend.scroll(0);\n legendHeight = spaceHeight;\n // Reset\n }\n else if (nav) {\n clipToHeight();\n this.nav = nav.destroy(); // #6322\n this.scrollGroup.attr({\n translateY: 1\n });\n this.clipHeight = 0; // #1379\n }\n return legendHeight;\n }\n /**\n * Scroll the legend by a number of pages.\n *\n * @private\n * @function Highcharts.Legend#scroll\n *\n * @param {number} scrollBy\n * The number of pages to scroll.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation.\n *\n */\n scroll(scrollBy, animation) {\n const chart = this.chart, pages = this.pages, pageCount = pages.length, clipHeight = this.clipHeight, navOptions = this.options.navigation, pager = this.pager, padding = this.padding;\n let currentPage = this.currentPage + scrollBy;\n // When resizing while looking at the last page\n if (currentPage > pageCount) {\n currentPage = pageCount;\n }\n if (currentPage > 0) {\n if (typeof animation !== 'undefined') {\n setAnimation(animation, chart);\n }\n this.nav.attr({\n translateX: padding,\n translateY: clipHeight + this.padding + 7 + this.titleHeight,\n visibility: 'inherit'\n });\n [this.up, this.upTracker].forEach(function (elem) {\n elem.attr({\n 'class': currentPage === 1 ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n });\n pager.attr({\n text: currentPage + '/' + pageCount\n });\n [this.down, this.downTracker].forEach(function (elem) {\n elem.attr({\n // adjust to text width\n x: 18 + this.pager.getBBox().width,\n 'class': currentPage === pageCount ?\n 'highcharts-legend-nav-inactive' :\n 'highcharts-legend-nav-active'\n });\n }, this);\n if (!chart.styledMode) {\n this.up\n .attr({\n fill: currentPage === 1 ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.upTracker\n .css({\n cursor: currentPage === 1 ? 'default' : 'pointer'\n });\n this.down\n .attr({\n fill: currentPage === pageCount ?\n navOptions.inactiveColor :\n navOptions.activeColor\n });\n this.downTracker\n .css({\n cursor: currentPage === pageCount ?\n 'default' :\n 'pointer'\n });\n }\n this.scrollOffset = -pages[currentPage - 1] + this.initialItemY;\n this.scrollGroup.animate({\n translateY: this.scrollOffset\n });\n this.currentPage = currentPage;\n this.positionCheckboxes();\n // Fire event after scroll animation is complete\n const animOptions = animObject(pick(animation, chart.renderer.globalAnimation, true));\n syncTimeout(() => {\n fireEvent(this, 'afterScroll', { currentPage });\n }, animOptions.duration);\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#setItemEvents\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @param {Highcharts.SVGElement} legendLabel\n * @param {boolean} [useHTML=false]\n * @emits Highcharts.Point#event:legendItemClick\n * @emits Highcharts.Series#event:legendItemClick\n */\n setItemEvents(item, legendLabel, useHTML) {\n const legend = this, legendItem = item.legendItem || {}, boxWrapper = legend.chart.renderer.boxWrapper, isPoint = item instanceof Point, activeClass = 'highcharts-legend-' +\n (isPoint ? 'point' : 'series') + '-active', styledMode = legend.chart.styledMode, \n // When `useHTML`, the symbol is rendered in other group, so\n // we need to apply events listeners to both places\n legendElements = useHTML ?\n [legendLabel, legendItem.symbol] :\n [legendItem.group];\n const setOtherItemsState = (state) => {\n legend.allItems.forEach((otherItem) => {\n if (item !== otherItem) {\n [otherItem]\n .concat(otherItem.linkedSeries || [])\n .forEach((otherItem) => {\n otherItem.setState(state, !isPoint);\n });\n }\n });\n };\n // Set the events on the item group, or in case of useHTML, the item\n // itself (#1249)\n for (const element of legendElements) {\n if (element) {\n element\n .on('mouseover', function () {\n if (item.visible) {\n setOtherItemsState('inactive');\n }\n item.setState('hover');\n // A CSS class to dim or hide other than the hovered\n // series.\n // Works only if hovered series is visible (#10071).\n if (item.visible) {\n boxWrapper.addClass(activeClass);\n }\n if (!styledMode) {\n legendLabel.css(legend.options.itemHoverStyle);\n }\n })\n .on('mouseout', function () {\n if (!legend.chart.styledMode) {\n legendLabel.css(merge(item.visible ?\n legend.itemStyle :\n legend.itemHiddenStyle));\n }\n setOtherItemsState('');\n // A CSS class to dim or hide other than the hovered\n // series.\n boxWrapper.removeClass(activeClass);\n item.setState();\n })\n .on('click', function (event) {\n const strLegendItemClick = 'legendItemClick', fnLegendItemClick = function () {\n if (item.setVisible) {\n item.setVisible();\n }\n // Reset inactive state\n setOtherItemsState(item.visible ? 'inactive' : '');\n };\n // A CSS class to dim or hide other than the hovered\n // series. Event handling in iOS causes the activeClass\n // to be added prior to click in some cases (#7418).\n boxWrapper.removeClass(activeClass);\n // Pass over the click/touch event. #4.\n event = {\n browserEvent: event\n };\n // click the name or symbol\n if (item.firePointEvent) { // point\n item.firePointEvent(strLegendItemClick, event, fnLegendItemClick);\n }\n else {\n fireEvent(item, strLegendItemClick, event, fnLegendItemClick);\n }\n });\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Legend#createCheckboxForItem\n * @param {Highcharts.BubbleLegendItem|Point|Highcharts.Series} item\n * @emits Highcharts.Series#event:checkboxClick\n */\n createCheckboxForItem(item) {\n const legend = this;\n item.checkbox = createElement('input', {\n type: 'checkbox',\n className: 'highcharts-legend-checkbox',\n checked: item.selected,\n defaultChecked: item.selected // required by IE7\n }, legend.options.itemCheckboxStyle, legend.chart.container);\n addEvent(item.checkbox, 'click', function (event) {\n const target = event.target;\n fireEvent(item.series || item, 'checkboxClick', {\n checked: target.checked,\n item: item\n }, function () {\n item.select();\n });\n });\n }\n }\n /* *\n *\n * Class Namespace\n *\n * */\n (function (Legend) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'beforeMargins', function () {\n /**\n * The legend contains an interactive overview over chart items,\n * usually individual series or points depending on the series\n * type. The color axis and bubble legend are also rendered in\n * the chart legend.\n *\n * @name Highcharts.Chart#legend\n * @type {Highcharts.Legend}\n */\n this.legend = new Legend(this, this.options.legend);\n });\n }\n }\n Legend.compose = compose;\n })(Legend || (Legend = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @interface Highcharts.LegendItemObject\n */ /**\n * @name Highcharts.LegendItemObject#item\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#line\n * @type {Highcharts.SVGElement|undefined}\n */ /**\n * @name Highcharts.LegendItemObject#symbol\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * Gets fired when the legend item belonging to a point is clicked. The default\n * action is to toggle the visibility of the point. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.PointLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Point} this\n * The point on which the event occured.\n *\n * @param {Highcharts.PointLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.PointLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.PointLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the point.\n * @name Highcharts.PointLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related point.\n * @name Highcharts.PointLegendItemClickEventObject#target\n * @type {Highcharts.Point}\n */ /**\n * Event type.\n * @name Highcharts.PointLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n /**\n * Series color as used by the legend and some series types.\n * @name Highcharts.Series#color\n * @type {Highcharts.ColorType|undefined}\n */ /**\n * Legend data for the series.\n * @name Highcharts.Series#legendItem\n * @type {Highcharts.LegendItemObject|undefined}\n * @since 10.3.0\n */\n /**\n * Gets fired when the legend item belonging to a series is clicked. The default\n * action is to toggle the visibility of the series. This can be prevented by\n * returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the legend click event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {Highcharts.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesLegendItemClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesLegendItemClickEventObject#type\n * @type {\"legendItemClick\"}\n */\n (''); // keeps doclets above in JS file\n\n return Legend;\n });\n _registerModule(_modules, 'Core/Legend/LegendSymbol.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { extend, merge, pick } = U;\n /* *\n *\n * Namespace\n *\n * */\n var LegendSymbol;\n (function (LegendSymbol) {\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.lineMarker\n *\n * @param {Highcharts.Legend} legend\n * The legend object.\n */\n function lineMarker(legend, item) {\n const legendItem = this.legendItem = this.legendItem || {}, options = this.options, symbolWidth = legend.symbolWidth, symbolHeight = legend.symbolHeight, generalRadius = symbolHeight / 2, renderer = this.chart.renderer, legendItemGroup = legendItem.group, verticalCenter = legend.baseline -\n Math.round(legend.fontMetrics.b * 0.3);\n let attr = {}, legendSymbol, markerOptions = options.marker, lineSizer = 0;\n // Draw the line\n if (!this.chart.styledMode) {\n attr = {\n 'stroke-width': Math.min(options.lineWidth || 0, 24)\n };\n if (options.dashStyle) {\n attr.dashstyle = options.dashStyle;\n }\n else if (options.linecap !== 'square') {\n attr['stroke-linecap'] = 'round';\n }\n }\n legendItem.line = renderer\n .path()\n .addClass('highcharts-graph')\n .attr(attr)\n .add(legendItemGroup);\n if (attr['stroke-linecap']) {\n lineSizer = Math.min(legendItem.line.strokeWidth(), symbolWidth) / 2;\n }\n if (symbolWidth) {\n legendItem.line\n .attr({\n d: [\n ['M', lineSizer, verticalCenter],\n ['L', symbolWidth - lineSizer, verticalCenter]\n ]\n });\n }\n // Draw the marker\n if (markerOptions && markerOptions.enabled !== false && symbolWidth) {\n // Do not allow the marker to be larger than the symbolHeight\n let radius = Math.min(pick(markerOptions.radius, generalRadius), generalRadius);\n // Restrict symbol markers size\n if (this.symbol.indexOf('url') === 0) {\n markerOptions = merge(markerOptions, {\n width: symbolHeight,\n height: symbolHeight\n });\n radius = 0;\n }\n legendItem.symbol = legendSymbol = renderer\n .symbol(this.symbol, (symbolWidth / 2) - radius, verticalCenter - radius, 2 * radius, 2 * radius, extend({ context: 'legend' }, markerOptions))\n .addClass('highcharts-point')\n .add(legendItemGroup);\n legendSymbol.isMarker = true;\n }\n }\n LegendSymbol.lineMarker = lineMarker;\n /**\n * Get the series' symbol in the legend.\n *\n * This method should be overridable to create custom symbols through\n * Highcharts.seriesTypes[type].prototype.drawLegendSymbol.\n *\n * @private\n * @function Highcharts.LegendSymbolMixin.rectangle\n *\n * @param {Highcharts.Legend} legend\n * The legend object\n *\n * @param {Highcharts.Point|Highcharts.Series} item\n * The series (this) or point\n */\n function rectangle(legend, item) {\n const legendItem = item.legendItem || {}, options = legend.options, symbolHeight = legend.symbolHeight, square = options.squareSymbol, symbolWidth = square ? symbolHeight : legend.symbolWidth;\n legendItem.symbol = this.chart.renderer\n .rect(square ? (legend.symbolWidth - symbolHeight) / 2 : 0, legend.baseline - symbolHeight + 1, // #3988\n symbolWidth, symbolHeight, pick(legend.options.symbolRadius, symbolHeight / 2))\n .addClass('highcharts-point')\n .attr({\n zIndex: 3\n })\n .add(legendItem.group);\n }\n LegendSymbol.rectangle = rectangle;\n })(LegendSymbol || (LegendSymbol = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return LegendSymbol;\n });\n _registerModule(_modules, 'Core/Series/SeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n const seriesDefaults = {\n // base series options\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * Pixel width of the graph line.\n *\n * @see In styled mode, the line stroke-width can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-general/\n * On all series\n * @sample {highcharts} highcharts/plotoptions/series-linewidth-specific/\n * On one single series\n *\n * @product highcharts highstock\n */\n lineWidth: 1,\n /**\n * For some series, there is a limit that shuts down animation\n * by default when the total number of points in the chart is too high.\n * For example, for a column chart and its derivatives, animation does\n * not run if there is more than 250 points totally. To disable this\n * cap, set `animationLimit` to `Infinity`. This option works if animation\n * is fired on individual points, not on a group of points like e.g. during\n * the initial animation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animationlimit/\n * Animation limit on updating individual points\n *\n * @type {number}\n * @apioption plotOptions.series.animationLimit\n */\n /**\n * Allow this series' points to be selected by clicking on the graphic\n * (columns, point markers, pie slices, map areas etc).\n *\n * The selected points can be handled by point select and unselect\n * events, or collectively by the [getSelectedPoints\n * ](/class-reference/Highcharts.Chart#getSelectedPoints) function.\n *\n * And alternative way of selecting points is through dragging.\n *\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-allowpointselect-pie/\n * Pie\n * @sample {highcharts} highcharts/chart/events-selection-points/\n * Select a range of points through a drag selection\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @since 1.2.0\n *\n * @private\n */\n allowPointSelect: false,\n /**\n * When true, each point or column edge is rounded to its nearest pixel\n * in order to render sharp on screen. In some cases, when there are a\n * lot of densely packed columns, this leads to visible difference\n * in column widths or distance between columns. In these cases,\n * setting `crisp` to `false` may look better, even though each column\n * is rendered blurry.\n *\n * @sample {highcharts} highcharts/plotoptions/column-crisp-false/\n * Crisp is false\n *\n * @since 5.0.10\n * @product highcharts highstock gantt\n *\n * @private\n */\n crisp: true,\n /**\n * If true, a checkbox is displayed next to the legend item to allow\n * selecting the series. The state of the checkbox is determined by\n * the `selected` option.\n *\n * @productdesc {highmaps}\n * Note that if a `colorAxis` is defined, the color axis is represented\n * in the legend, not the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showcheckbox-true/\n * Show select box\n *\n * @since 1.2.0\n *\n * @private\n */\n showCheckbox: false,\n /**\n * Enable or disable the initial animation when a series is displayed.\n * The animation can also be set as a configuration object. Please\n * note that this option only applies to the initial animation of the\n * series itself. For other animations, see [chart.animation](\n * #chart.animation) and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * - `duration`: The duration of the animation in milliseconds. (Defaults to\n * `1000`)\n *\n * - `easing`: Can be a string reference to an easing function set on\n * the `Math` object or a function. See the _Custom easing function_\n * demo below. (Defaults to `easeInOutSine`)\n *\n * Due to poor performance, animation is disabled in old IE browsers\n * for several chart types.\n *\n * @sample {highcharts} highcharts/plotoptions/series-animation-disabled/\n * Animation disabled\n * @sample {highcharts} highcharts/plotoptions/series-animation-slower/\n * Slower animation\n * @sample {highcharts} highcharts/plotoptions/series-animation-easing/\n * Custom easing function\n * @sample {highstock} stock/plotoptions/animation-slower/\n * Slower animation\n * @sample {highstock} stock/plotoptions/animation-easing/\n * Custom easing function\n * @sample {highmaps} maps/plotoptions/series-animation-true/\n * Animation enabled on map series\n * @sample {highmaps} maps/plotoptions/mapbubble-animation-false/\n * Disabled on mapbubble series\n *\n * @type {boolean|Highcharts.AnimationOptionsObject}\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n *\n * @private\n */\n animation: {\n /** @ignore-option */\n duration: 1000\n },\n /**\n * An additional class name to apply to the series' graphical elements.\n * This option does not replace default class names of the graphical\n * element. Changes to the series' color will also be reflected in a\n * chart's legend and tooltip.\n *\n * @sample {highcharts} highcharts/css/point-series-classname\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.className\n */\n /**\n * Disable this option to allow series rendering in the whole plotting\n * area.\n *\n * **Note:** Clipping should be always enabled when\n * [chart.zoomType](#chart.zoomType) is set\n *\n * @sample {highcharts} highcharts/plotoptions/series-clip/\n * Disabled clipping\n *\n * @default true\n * @type {boolean}\n * @since 3.0.0\n * @apioption plotOptions.series.clip\n */\n /**\n * The main color of the series. In line type series it applies to the\n * line and the point markers unless otherwise specified. In bar type\n * series it applies to the bars unless a color is specified per point.\n * The default value is pulled from the `options.colors` array.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @productdesc {highmaps}\n * In maps, the series color is rarely used, as most choropleth maps use\n * the color to denote the value of each point. The series color can\n * however be used in a map with multiple series holding categorized\n * data.\n *\n * @sample {highcharts} highcharts/plotoptions/series-color-general/\n * General plot option\n * @sample {highcharts} highcharts/plotoptions/series-color-specific/\n * One specific series\n * @sample {highcharts} highcharts/plotoptions/series-color-area/\n * Area color\n * @sample {highcharts} highcharts/series/infographic/\n * Pattern fill\n * @sample {highmaps} maps/demo/category-map/\n * Category map by multiple series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.color\n */\n /**\n * Styled mode only. A specific color index to use for the series, so its\n * graphic representations are given the class name `highcharts-color-{n}`.\n *\n * Since v11, CSS variables on the form `--highcharts-color-{n}` make\n * changing the color scheme very convenient.\n *\n * @sample {highcharts} highcharts/css/colorindex/ Series and point color\n * index\n *\n * @type {number}\n * @since 5.0.0\n * @apioption plotOptions.series.colorIndex\n */\n /**\n * Whether to connect a graph line across null points, or render a gap\n * between the two points on either side of the null.\n *\n * In stacked area chart, if `connectNulls` is set to true,\n * null points are interpreted as 0.\n *\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/series-connectnulls-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.connectNulls\n */\n /**\n * You can set the cursor to \"pointer\" if you have click events attached\n * to the series, to signal to the user that the points and lines can\n * be clicked.\n *\n * In styled mode, the series cursor can be set with the same classes\n * as listed under [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-cursor-line/\n * On line graph\n * @sample {highcharts} highcharts/plotoptions/series-cursor-column/\n * On columns\n * @sample {highcharts} highcharts/plotoptions/series-cursor-scatter/\n * On scatter markers\n * @sample {highstock} stock/plotoptions/cursor/\n * Pointer on a line graph\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Map area\n * @sample {highmaps} maps/plotoptions/mapbubble-allowpointselect/\n * Map bubble\n *\n * @type {string|Highcharts.CursorValue}\n * @apioption plotOptions.series.cursor\n */\n /**\n * A reserved subspace to store options and values for customized\n * functionality. Here you can add additional data for your own event\n * callbacks and formatter callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption plotOptions.series.custom\n */\n /**\n * Name of the dash style to use for the graph, or for some series types\n * the outline of each shape.\n *\n * In styled mode, the\n * [stroke dash-array](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/series-dashstyle/)\n * can be set with the same classes as listed under\n * [series.color](#plotOptions.series.color).\n *\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle/\n * Chart suitable for printing in black and white\n * @sample {highstock} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n * @sample {highmaps} maps/plotoptions/series-dashstyle/\n * Dotted borders on a map\n *\n * @type {Highcharts.DashStyleValue}\n * @default Solid\n * @since 2.1\n * @apioption plotOptions.series.dashStyle\n */\n /**\n * A description of the series to add to the screen reader information\n * about the series.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption plotOptions.series.description\n */\n /**\n * Options for the series data sorting.\n *\n * @type {Highcharts.DataSortingOptionsObject}\n * @since 8.0.0\n * @product highcharts highstock\n * @apioption plotOptions.series.dataSorting\n */\n /**\n * Enable or disable data sorting for the series. Use [xAxis.reversed](\n * #xAxis.reversed) to change the sorting order.\n *\n * @sample {highcharts} highcharts/datasorting/animation/\n * Data sorting in scatter-3d\n * @sample {highcharts} highcharts/datasorting/labels-animation/\n * Axis labels animation\n * @sample {highcharts} highcharts/datasorting/dependent-sorting/\n * Dependent series sorting\n * @sample {highcharts} highcharts/datasorting/independent-sorting/\n * Independent series sorting\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.enabled\n */\n /**\n * Whether to allow matching points by name in an update. If this option\n * is disabled, points will be matched by order.\n *\n * @sample {highcharts} highcharts/datasorting/match-by-name/\n * Enabled match by name\n *\n * @type {boolean}\n * @since 8.0.0\n * @apioption plotOptions.series.dataSorting.matchByName\n */\n /**\n * Determines what data value should be used to sort by.\n *\n * @sample {highcharts} highcharts/datasorting/sort-key/\n * Sort key as `z` value\n *\n * @type {string}\n * @since 8.0.0\n * @default y\n * @apioption plotOptions.series.dataSorting.sortKey\n */\n /**\n * Enable or disable the mouse tracking for a specific series. This\n * includes point tooltips and click events on graphs and points. For\n * large datasets it improves performance.\n *\n * @sample {highcharts} highcharts/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n * @sample {highmaps} maps/plotoptions/series-enablemousetracking-false/\n * No mouse tracking\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.enableMouseTracking\n */\n enableMouseTracking: true,\n /**\n * Whether to use the Y extremes of the total chart width or only the\n * zoomed area when zooming in on parts of the X axis. By default, the\n * Y axis adjusts to the min and max of the visible data. Cartesian\n * series only.\n *\n * @type {boolean}\n * @default false\n * @since 4.1.6\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.getExtremesFromAll\n */\n /**\n * An array specifying which option maps to which key in the data point\n * array. This makes it convenient to work with unstructured data arrays\n * from different sources.\n *\n * @see [series.data](#series.line.data)\n *\n * @sample {highcharts|highstock} highcharts/series/data-keys/\n * An extended data array with keys\n * @sample {highcharts|highstock} highcharts/series/data-nested-keys/\n * Nested keys used to access object properties\n *\n * @type {Array}\n * @since 4.1.6\n * @apioption plotOptions.series.keys\n */\n /**\n * The line cap used for line ends and line joins on the graph.\n *\n * @sample highcharts/series-line/linecap/\n * Line cap comparison\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @product highcharts highstock\n * @apioption plotOptions.series.linecap\n */\n /**\n * The [id](#series.id) of another series to link to. Additionally,\n * the value can be \":previous\" to link to the previous series. When\n * two series are linked, only the first one appears in the legend.\n * Toggling the visibility of this also toggles the linked series.\n *\n * If master series uses data sorting and linked series does not have\n * its own sorting definition, the linked series will be sorted in the\n * same order as the master one.\n *\n * @sample {highcharts|highstock} highcharts/demo/arearange-line/\n * Linked series\n *\n * @type {string}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.linkedTo\n */\n /**\n * Options for the corresponding navigator series if `showInNavigator`\n * is `true` for this series. Available options are the same as any\n * series, documented at [plotOptions](#plotOptions.series) and\n * [series](#series).\n *\n * These options are merged with options in [navigator.series](\n * #navigator.series), and will take precedence if the same option is\n * defined both places.\n *\n * @see [navigator.series](#navigator.series)\n *\n * @type {Highcharts.PlotSeriesOptions}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.navigatorOptions\n */\n /**\n * The color for the parts of the graph or points that are below the\n * [threshold](#plotOptions.series.threshold). Note that `zones` takes\n * precedence over the negative color. Using `negativeColor` is\n * equivalent to applying a zone with value of 0.\n *\n * @see In styled mode, a negative color is applied by setting this option\n * to `true` combined with the `.highcharts-negative` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highcharts} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Styled mode\n * @sample {highstock} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highstock} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n * @sample {highmaps} highcharts/plotoptions/series-negative-color/\n * Spline, area and column\n * @sample {highmaps} highcharts/plotoptions/arearange-negativecolor/\n * Arearange\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @apioption plotOptions.series.negativeColor\n */\n /**\n * Same as\n * [accessibility.point.descriptionFormat](#accessibility.point.descriptionFormat),\n * but for an individual series. Overrides the chart wide configuration.\n *\n * @type {Function}\n * @since 11.1.0\n * @apioption plotOptions.series.pointDescriptionFormat\n */\n /**\n * Same as\n * [accessibility.series.descriptionFormatter](#accessibility.series.descriptionFormatter),\n * but for an individual series. Overrides the chart wide configuration.\n *\n * @type {Function}\n * @since 5.0.12\n * @apioption plotOptions.series.pointDescriptionFormatter\n */\n /**\n * If no x values are given for the points in a series, `pointInterval`\n * defines the interval of the x values. For example, if a series\n * contains one value every decade starting from year 0, set\n * `pointInterval` to `10`. In true `datetime` axes, the `pointInterval`\n * is set in milliseconds.\n *\n * It can be also be combined with `pointIntervalUnit` to draw irregular\n * time intervals.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point, and the `pointInterval` is added x times to the `pointStart`\n * setting.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime X axis\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 1\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointInterval\n */\n /**\n * On datetime series, this allows for setting the\n * [pointInterval](#plotOptions.series.pointInterval) to irregular time\n * units, `day`, `month` and `year`. A day is usually the same as 24\n * hours, but `pointIntervalUnit` also takes the DST crossover into\n * consideration when dealing with local time. Combine this option with\n * `pointInterval` to draw weeks, quarters, 6 months, 10 years etc.\n *\n * Please note that this options applies to the _series data_, not the\n * interval of the axis ticks, which is independent.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n * @sample {highstock} highcharts/plotoptions/series-pointintervalunit/\n * One point a month\n *\n * @type {string}\n * @since 4.1.0\n * @product highcharts highstock gantt\n * @validvalue [\"day\", \"month\", \"year\"]\n * @apioption plotOptions.series.pointIntervalUnit\n */\n /**\n * Possible values: `\"on\"`, `\"between\"`, `number`.\n *\n * In a column chart, when pointPlacement is `\"on\"`, the point will not\n * create any padding of the X axis. In a polar column chart this means\n * that the first column points directly north. If the pointPlacement is\n * `\"between\"`, the columns will be laid out between ticks. This is\n * useful for example for visualising an amount between two points in\n * time or in a certain sector of a polar chart.\n *\n * Since Highcharts 3.0.2, the point placement can also be numeric,\n * where 0 is on the axis value, -0.5 is between this value and the\n * previous, and 0.5 is between this value and the next. Unlike the\n * textual options, numeric point placement options won't affect axis\n * padding.\n *\n * Note that pointPlacement needs a [pointRange](\n * #plotOptions.series.pointRange) to work. For column series this is\n * computed, but for line-type series it needs to be set.\n *\n * For the `xrange` series type and gantt charts, if the Y axis is a\n * category axis, the `pointPlacement` applies to the Y axis rather than\n * the (typically datetime) X axis.\n *\n * Defaults to `undefined` in cartesian charts, `\"between\"` in polar\n * charts.\n *\n * @see [xAxis.tickmarkPlacement](#xAxis.tickmarkPlacement)\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-between/\n * Between in a column chart\n * @sample {highcharts|highstock} highcharts/plotoptions/series-pointplacement-numeric/\n * Numeric placement for custom layout\n * @sample {highcharts|highstock} maps/plotoptions/heatmap-pointplacement/\n * Placement in heatmap\n *\n * @type {string|number}\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointPlacement\n */\n /**\n * If no x values are given for the points in a series, pointStart\n * defines on what value to start. For example, if a series contains one\n * yearly value starting from 1945, set pointStart to 1945.\n *\n * If combined with `relativeXValue`, an x value can be set on each\n * point. The x value from the point options is multiplied by\n * `pointInterval` and added to `pointStart` to produce a modified x\n * value.\n *\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-linear/\n * Linear\n * @sample {highcharts} highcharts/plotoptions/series-pointstart-datetime/\n * Datetime\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative x value\n * @sample {highstock} stock/plotoptions/pointinterval-pointstart/\n * Using pointStart and pointInterval\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative x value\n *\n * @type {number}\n * @default 0\n * @product highcharts highstock gantt\n * @apioption plotOptions.series.pointStart\n */\n /**\n * When true, X values in the data set are relative to the current\n * `pointStart`, `pointInterval` and `pointIntervalUnit` settings. This\n * allows compression of the data for datasets with irregular X values.\n *\n * The real X values are computed on the formula `f(x) = ax + b`, where\n * `a` is the `pointInterval` (optionally with a time unit given by\n * `pointIntervalUnit`), and `b` is the `pointStart`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-relativexvalue/\n * Relative X value\n * @sample {highstock} stock/plotoptions/relativexvalue/\n * Relative X value\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock\n * @apioption plotOptions.series.relativeXValue\n */\n /**\n * Whether to select the series initially. If `showCheckbox` is true,\n * the checkbox next to the series name in the legend will be checked\n * for a selected series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-selected/\n * One out of two series selected\n *\n * @type {boolean}\n * @default false\n * @since 1.2.0\n * @apioption plotOptions.series.selected\n */\n /**\n * Whether to apply a drop shadow to the graph line. Since 2.3 the\n * shadow can be an object configuration containing `color`, `offsetX`,\n * `offsetY`, `opacity` and `width`.\n *\n * Note that in some cases, like stacked columns or other dense layouts, the\n * series may cast shadows on each other. In that case, the\n * `chart.seriesGroupShadow` allows applying a common drop shadow to the\n * whole series group.\n *\n * @sample {highcharts} highcharts/plotoptions/series-shadow/\n * Shadow enabled\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @apioption plotOptions.series.shadow\n */\n /**\n * Whether to display this particular series or series type in the\n * legend. Standalone series are shown in legend by default, and linked\n * series are not. Since v7.2.0 it is possible to show series that use\n * colorAxis by setting this option to `true`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @type {boolean}\n * @apioption plotOptions.series.showInLegend\n */\n /**\n * Whether or not to show the series in the navigator. Takes precedence\n * over [navigator.baseSeries](#navigator.baseSeries) if defined.\n *\n * @type {boolean}\n * @since 5.0.0\n * @product highstock\n * @apioption plotOptions.series.showInNavigator\n */\n /**\n * If set to `true`, the accessibility module will skip past the points\n * in this series for keyboard navigation.\n *\n * @type {boolean}\n * @since 5.0.12\n * @apioption plotOptions.series.skipKeyboardNavigation\n */\n /**\n * Whether to stack the values of each series on top of each other.\n * Possible values are `undefined` to disable, `\"normal\"` to stack by\n * value or `\"percent\"`.\n *\n * When stacking is enabled, data must be sorted\n * in ascending X order.\n *\n * Some stacking options are related to specific series types. In the\n * streamgraph series type, the stacking option is set to `\"stream\"`.\n * The second one is `\"overlap\"`, which only applies to waterfall\n * series.\n *\n * @see [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts} highcharts/plotoptions/series-stacking-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-line/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-bar/\n * Bar\n * @sample {highcharts} highcharts/plotoptions/series-stacking-percent-area/\n * Area\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-normal-stacking\n * Waterfall with normal stacking\n * @sample {highcharts} highcharts/plotoptions/series-waterfall-with-overlap-stacking\n * Waterfall with overlap stacking\n * @sample {highstock} stock/plotoptions/stacking/\n * Area\n *\n * @type {string}\n * @product highcharts highstock\n * @validvalue [\"normal\", \"overlap\", \"percent\", \"stream\"]\n * @apioption plotOptions.series.stacking\n */\n /**\n * Whether to apply steps to the line. Possible values are `left`,\n * `center` and `right`.\n *\n * @sample {highcharts} highcharts/plotoptions/line-step/\n * Different step line options\n * @sample {highcharts} highcharts/plotoptions/area-step/\n * Stepped, stacked area\n * @sample {highstock} stock/plotoptions/line-step/\n * Step line\n *\n * @type {string}\n * @since 1.2.5\n * @product highcharts highstock\n * @validvalue [\"left\", \"center\", \"right\"]\n * @apioption plotOptions.series.step\n */\n /**\n * The threshold, also called zero level or base level. For line type\n * series this is only used in conjunction with\n * [negativeColor](#plotOptions.series.negativeColor).\n *\n * @see [softThreshold](#plotOptions.series.softThreshold).\n *\n * @type {number|null}\n * @default 0\n * @since 3.0\n * @product highcharts highstock\n * @apioption plotOptions.series.threshold\n */\n /**\n * Set the initial visibility of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-visible/\n * Two series, one hidden and one visible\n * @sample {highstock} stock/plotoptions/series-visibility/\n * Hidden series\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.visible\n */\n /**\n * Defines the Axis on which the zones are applied.\n *\n * @see [zones](#plotOptions.series.zones)\n *\n * @sample {highcharts} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n * @sample {highstock} highcharts/series/color-zones-zoneaxis-x/\n * Zones on the X-Axis\n *\n * @type {string}\n * @default y\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zoneAxis\n */\n /**\n * General event handlers for the series items. These event hooks can\n * also be attached to the series at run time using the\n * `Highcharts.addEvent` function.\n *\n * @declare Highcharts.SeriesEventsOptionsObject\n *\n * @private\n */\n events: {},\n /**\n * Fires after the series has finished its initial animation, or in case\n * animation is disabled, immediately as the series is displayed.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n * @sample {highstock} highcharts/plotoptions/series-events-afteranimate/\n * Show label after animate\n *\n * @type {Highcharts.SeriesAfterAnimateCallbackFunction}\n * @since 4.0\n * @product highcharts highstock gantt\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.afterAnimate\n */\n /**\n * Fires when the checkbox next to the series' name in the legend is\n * clicked. One parameter, `event`, is passed to the function. The state\n * of the checkbox is found by `event.checked`. The checked item is\n * found by `event.item`. Return `false` to prevent the default action\n * which is to toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Highcharts.SeriesCheckboxClickCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.checkboxClick\n */\n /**\n * Fires when the series is clicked. One parameter, `event`, is passed\n * to the function, containing common event information. Additionally,\n * `event.point` holds a pointer to the nearest point on the graph.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-click/\n * Alert click info\n * @sample {highstock} stock/plotoptions/series-events-click/\n * Alert click info\n * @sample {highmaps} maps/plotoptions/series-events-click/\n * Display click info in subtitle\n *\n * @type {Highcharts.SeriesClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.click\n */\n /**\n * Fires when the series is hidden after chart generation time, either\n * by clicking the legend item or by calling `.hide()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-hide/\n * Alert when the series is hidden by clicking the legend item\n *\n * @type {Highcharts.SeriesHideCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.hide\n */\n /**\n * Fires when the legend item belonging to the series is clicked. One\n * parameter, `event`, is passed to the function. The default action\n * is to toggle the visibility of the series. This can be prevented\n * by returning `false` or calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-legenditemclick/\n * Confirm hiding and showing\n *\n * @type {Highcharts.SeriesLegendItemClickCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.legendItemClick\n */\n /**\n * Fires when the mouse leaves the graph. One parameter, `event`, is\n * passed to the function, containing common event information. If the\n * [stickyTracking](#plotOptions.series) option is true, `mouseOut`\n * doesn't happen before the mouse enters another graph or leaves the\n * plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOutCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOut\n */\n /**\n * Fires when the mouse enters the graph. One parameter, `event`, is\n * passed to the function, containing common event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-sticky/\n * With sticky tracking by default\n * @sample {highcharts} highcharts/plotoptions/series-events-mouseover-no-sticky/\n * Without sticky tracking\n *\n * @type {Highcharts.SeriesMouseOverCallbackFunction}\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.mouseOver\n */\n /**\n * Fires when the series is shown after chart generation time, either\n * by clicking the legend item or by calling `.show()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-show/\n * Alert when the series is shown by clicking the legend item.\n *\n * @type {Highcharts.SeriesShowCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Series\n * @apioption plotOptions.series.events.show\n */\n /**\n * Options for the point markers of line and scatter-like series. Properties\n * like `fillColor`, `lineColor` and `lineWidth` define the visual\n * appearance of the markers. The `symbol` option defines the shape. Other\n * series types, like column series, don't have markers, but have visual\n * options on the series level instead.\n *\n * In styled mode, the markers can be styled with the `.highcharts-point`,\n * `.highcharts-point-hover` and `.highcharts-point-select` class names.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n *\n * @sample {highmaps} maps/demo/mappoint-mapmarker\n * Using the mapmarker symbol for points\n *\n * @private\n */\n marker: {\n /**\n * Enable or disable the point marker. If `undefined`, the markers\n * are hidden when the data is dense, and shown for more widespread\n * data points.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled/\n * Disabled markers\n * @sample {highcharts} highcharts/plotoptions/series-marker-enabled-false/\n * Disabled in normal state but enabled on hover\n * @sample {highstock} stock/plotoptions/series-marker/\n * Enabled markers\n *\n * @type {boolean}\n * @default {highcharts} undefined\n * @default {highstock} false\n * @apioption plotOptions.series.marker.enabled\n */\n /**\n * The threshold for how dense the point markers should be before\n * they are hidden, given that `enabled` is not defined. The number\n * indicates the horizontal distance between the two closest points\n * in the series, as multiples of the `marker.radius`. In other\n * words, the default value of 2 means points are hidden if\n * overlapping horizontally.\n *\n * @sample highcharts/plotoptions/series-marker-enabledthreshold\n * A higher threshold\n *\n * @since 6.0.5\n */\n enabledThreshold: 2,\n /**\n * The fill color of the point marker. When `undefined`, the series'\n * or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * White fill\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.fillColor\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `width` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.height\n */\n /**\n * The color of the point marker's outline. When `undefined`, the\n * series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * Inherit from series color (undefined)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-fillcolor/\n * 2px blue marker\n */\n lineWidth: 0,\n /**\n * The radius of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-radius/\n * Bigger markers\n *\n * @default {highstock} 2\n * @default {highcharts} 4\n *\n */\n radius: 4,\n /**\n * A predefined shape or symbol for the marker. When undefined, the\n * symbol is pulled from options.symbols. Other possible values are\n * `'circle'`, `'square'`,`'diamond'`, `'triangle'` and\n * `'triangle-down'`.\n *\n * Additionally, the URL to a graphic can be given on this form:\n * `'url(graphic.png)'`. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export\n * server.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols`. The callback is then\n * used by its method name, as shown in the demo.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n * @sample {highstock} highcharts/plotoptions/series-marker-symbol/\n * Predefined, graphic and custom markers\n * @sample {highmaps} maps/demo/mappoint-mapmarker\n * Using the mapmarker symbol for points\n *\n * @type {string}\n * @apioption plotOptions.series.marker.symbol\n */\n /**\n * Image markers only. Set the image width explicitly. When using\n * this option, a `height` must also be set.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n * @sample {highstock} highcharts/plotoptions/series-marker-width-height/\n * Fixed width and height\n *\n * @type {number}\n * @since 4.0.4\n * @apioption plotOptions.series.marker.width\n */\n /**\n * States for a single point marker.\n *\n * @declare Highcharts.PointStatesOptionsObject\n */\n states: {\n /**\n * The normal state of a single point marker. Currently only\n * used for setting animation when returning to normal state\n * from hover.\n *\n * @declare Highcharts.PointStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * The hover state for a single point marker.\n *\n * @declare Highcharts.PointStatesHoverOptionsObject\n */\n hover: {\n /**\n * Animation when hovering over the marker.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 150\n },\n /**\n * Enable or disable the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-enabled/\n * Disabled hover state\n */\n enabled: true,\n /**\n * The fill color of the marker in hover state. When\n * `undefined`, the series' or point's fillColor for normal\n * state is used.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.fillColor\n */\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's lineColor for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linecolor/\n * White fill color, black line color\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption plotOptions.series.marker.states.hover.lineColor\n */\n /**\n * The width of the point marker's outline. When\n * `undefined`, the series' or point's lineWidth for normal\n * state is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-linewidth/\n * 3px line width\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.lineWidth\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2 as per the\n * [radiusPlus](#plotOptions.series.marker.states.hover.radiusPlus)\n * option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-hover-radius/\n * 10px radius\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.hover.radius\n */\n /**\n * The number of pixels to increase the radius of the\n * hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels greater radius on hover\n *\n * @since 4.0.3\n */\n radiusPlus: 2,\n /**\n * The additional line width for a hovered point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 2 pixels wider on hover\n *\n * @since 4.0.3\n */\n lineWidthPlus: 1\n },\n /**\n * The appearance of the point marker when selected. In order to\n * allow a point to be selected, set the\n * `series.allowPointSelect` option to true.\n *\n * @declare Highcharts.PointStatesSelectOptionsObject\n */\n select: {\n /**\n * Enable or disable visible feedback for selection.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-enabled/\n * Disabled select state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.marker.states.select.enabled\n */\n /**\n * The radius of the point marker. In hover state, it\n * defaults to the normal state's radius + 2.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-radius/\n * 10px radius for selected points\n *\n * @type {number}\n * @apioption plotOptions.series.marker.states.select.radius\n */\n /**\n * The fill color of the point marker.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-fillcolor/\n * Solid red discs for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n fillColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The color of the point marker's outline. When\n * `undefined`, the series' or point's color is used.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linecolor/\n * Red line color for selected points\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The width of the point marker's outline.\n *\n * @sample {highcharts} highcharts/plotoptions/series-marker-states-select-linewidth/\n * 3px line width for selected points\n */\n lineWidth: 2\n }\n }\n },\n /**\n * Properties for each single point.\n *\n * @declare Highcharts.PlotSeriesPointOptions\n *\n * @private\n */\n point: {\n /**\n * Fires when a point is clicked. One parameter, `event`, is passed\n * to the function, containing common event information.\n *\n * If the `series.allowPointSelect` option is true, the default\n * action for the point's click event is to toggle the point's\n * select state. Returning `false` cancels this action.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click/\n * Click marker to alert values\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-column/\n * Click column\n * @sample {highcharts} highcharts/plotoptions/series-point-events-click-url/\n * Go to URL\n * @sample {highmaps} maps/plotoptions/series-point-events-click/\n * Click marker to display values\n * @sample {highmaps} maps/plotoptions/series-point-events-click-url/\n * Go to URL\n *\n * @type {Highcharts.PointClickCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.click\n */\n /**\n * Fires when the mouse leaves the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOutCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOut\n */\n /**\n * Fires when the mouse enters the area close to the point. One\n * parameter, `event`, is passed to the function, containing common\n * event information.\n *\n * Returning `false` cancels the default behavior, which is to show a\n * tooltip for the point.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-mouseover/\n * Show values in the chart's corner on mouse over\n *\n * @type {Highcharts.PointMouseOverCallbackFunction}\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.mouseOver\n */\n /**\n * Fires when the point is removed using the `.remove()` method. One\n * parameter, `event`, is passed to the function. Returning `false`\n * cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-remove/\n * Remove point and confirm\n *\n * @type {Highcharts.PointRemoveCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.remove\n */\n /**\n * Fires when the point is selected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-select/\n * Report the last selected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointSelectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.select\n */\n /**\n * Fires when the point is unselected either programmatically or\n * following a click on the point. One parameter, `event`, is passed\n * to the function.\n * Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-unselect/\n * Report the last unselected point\n * @sample {highmaps} maps/plotoptions/series-allowpointselect/\n * Report select and unselect\n *\n * @type {Highcharts.PointUnselectCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.unselect\n */\n /**\n * Fires when the point is updated programmatically through the\n * `.update()` method. One parameter, `event`, is passed to the\n * function. The new point options can be accessed through\n * `event.options`. Returning `false` cancels the operation.\n *\n * @sample {highcharts} highcharts/plotoptions/series-point-events-update/\n * Confirm point updating\n *\n * @type {Highcharts.PointUpdateCallbackFunction}\n * @since 1.2.0\n * @context Highcharts.Point\n * @apioption plotOptions.series.point.events.update\n */\n /**\n * Events for each single point.\n *\n * @declare Highcharts.PointEventsOptionsObject\n */\n events: {}\n },\n /**\n * Options for the series data labels, appearing next to each data\n * point.\n *\n * Since v6.2.0, multiple data labels can be applied to each single\n * point by defining them as an array of configs.\n *\n * In styled mode, the data labels can be styled with the\n * `.highcharts-data-label-box` and `.highcharts-data-label` class names\n * ([see example](https://www.highcharts.com/samples/highcharts/css/series-datalabels)).\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled\n * Data labels enabled\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-multiple\n * Multiple data labels on a bar series\n * @sample {highcharts} highcharts/css/series-datalabels\n * Styled mode example\n * @sample {highmaps} maps/demo/color-axis\n * Choropleth map with data labels\n * @sample {highmaps} maps/demo/mappoint-datalabels-mapmarker\n * Using data labels as map markers\n *\n * @type {*|Array<*>}\n * @product highcharts highstock highmaps gantt\n *\n * @private\n */\n dataLabels: {\n /**\n * Enable or disable the initial animation when a series is displayed\n * for the `dataLabels`. The animation can also be set as a\n * configuration object. Please note that this option only applies to\n * the initial animation.\n *\n * For other animations, see [chart.animation](#chart.animation) and the\n * animation parameter under the API methods. The following properties\n * are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/plotoptions/animation-defer/\n * Animation defer settings\n *\n * @type {boolean|Partial}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation\n */\n animation: {},\n /**\n * The animation delay time in milliseconds. Set to `0` to render the\n * data labels immediately. As `undefined` inherits defer time from the\n * [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption plotOptions.series.dataLabels.animation.defer\n */\n /**\n * The alignment of the data label compared to the point. If `right`,\n * the right side of the label should be touching the point. For points\n * with an extent, like columns, the alignments also dictates how to\n * align it inside the box, as given with the\n * [inside](#plotOptions.column.dataLabels.inside) option. Can be one of\n * `left`, `center` or `right`.\n *\n * @sample {highcharts}\n * highcharts/plotoptions/series-datalabels-align-left/ Left\n * aligned\n * @sample {highcharts}\n * highcharts/plotoptions/bar-datalabels-align-inside-bar/ Data\n * labels inside the bar\n *\n * @type {Highcharts.AlignValue|null}\n */\n align: 'center',\n /**\n * Whether to allow data labels to overlap. To make the labels less\n * sensitive for overlapping, the\n * [dataLabels.padding](#plotOptions.series.dataLabels.padding)\n * can be set to 0.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-allowoverlap-false/\n * Don't allow overlap\n *\n * @type {boolean}\n * @default false\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.allowOverlap\n */\n /**\n * The background color or gradient for the data label. Setting it to\n * `auto` will use the point's color.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/demo/mappoint-datalabels-mapmarker\n * Data labels as map markers\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.backgroundColor\n */\n /**\n * The border color for the data label. Setting it to `auto` will use\n * the point's color. Defaults to `undefined`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderColor\n */\n /**\n * The border radius in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderRadius\n */\n /**\n * The border width in pixels for the data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {number}\n * @default 0\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.borderWidth\n */\n borderWidth: 0,\n /**\n * A class name for the data label. Particularly in styled mode,\n * this can be used to give each series' or point's data label\n * unique styling. In addition to this option, a default color class\n * name is added so that we can give the labels a contrast text\n * shadow.\n *\n * @sample {highcharts} highcharts/css/data-label-contrast/\n * Contrast text shadow\n * @sample {highcharts} highcharts/css/series-datalabels/\n * Styling by CSS\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.dataLabels.className\n */\n /**\n * This options is deprecated.\n * Use [style.color](#plotOptions.series.dataLabels.style) instead.\n *\n * The text color for the data labels. Defaults to `undefined`. For\n * certain series types, like column or map, the data labels can be\n * drawn inside the points. In this case the data label will be\n * drawn with maximum contrast by default. Additionally, it will be\n * given a `text-outline` style with the opposite color, to further\n * increase the contrast. This can be overridden by setting the\n * `text-outline` style to `none` in the `dataLabels.style` option.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-color/\n * Red data labels\n * @sample {highmaps} maps/demo/color-axis/\n * White data labels\n *\n * @see [style.color](#plotOptions.series.dataLabels.style)\n *\n * @type {Highcharts.ColorType}\n * @deprecated 10.3\n * @apioption plotOptions.series.dataLabels.color\n */\n /**\n * Whether to hide data labels that are outside the plot area. By\n * default, the data label is moved inside the plot area according\n * to the\n * [overflow](#plotOptions.series.dataLabels.overflow)\n * option.\n *\n * @type {boolean}\n * @default true\n * @since 2.3.3\n * @apioption plotOptions.series.dataLabels.crop\n */\n /**\n * Whether to defer displaying the data labels until the initial\n * series animation has finished. Setting to `false` renders the\n * data label immediately. If set to `true` inherits the defer\n * time set in [plotOptions.series.animation](#plotOptions.series.animation).\n *\n * @since 4.0.0\n * @type {boolean}\n * @product highcharts highstock gantt\n */\n defer: true,\n /**\n * Enable or disable the data labels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-enabled/\n * Data labels enabled\n * @sample {highmaps} maps/demo/color-axis/\n * Data labels enabled\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.enabled\n */\n /**\n * A declarative filter to control of which data labels to display.\n * The declarative filter is designed for use when callback\n * functions are not available, like when the chart options require\n * a pure JSON structure or for use with graphical editors. For\n * programmatic control, use the `formatter` instead, and return\n * `undefined` to disable a single data label.\n *\n * @example\n * filter: {\n * property: 'percentage',\n * operator: '>',\n * value: 4\n * }\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome\n * Data labels filtered by percentage\n *\n * @declare Highcharts.DataLabelsFilterOptionsObject\n * @since 6.0.3\n * @apioption plotOptions.series.dataLabels.filter\n */\n /**\n * The operator to compare by. Can be one of `>`, `<`, `>=`, `<=`,\n * `==`, and `===`.\n *\n * @type {string}\n * @validvalue [\">\", \"<\", \">=\", \"<=\", \"==\", \"===\"]\n * @apioption plotOptions.series.dataLabels.filter.operator\n */\n /**\n * The point property to filter by. Point options are passed\n * directly to properties, additionally there are `y` value,\n * `percentage` and others listed under {@link Highcharts.Point}\n * members.\n *\n * @type {string}\n * @apioption plotOptions.series.dataLabels.filter.property\n */\n /**\n * The value to compare against.\n *\n * @type {number}\n * @apioption plotOptions.series.dataLabels.filter.value\n */\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format-subexpression/\n * Complex logic in the format string\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value in the data label\n *\n * @type {string}\n * @default y\n * @default point.value\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that if a\n * `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @sample {highmaps} maps/plotoptions/series-datalabels-format/\n * Formatted value\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n */\n formatter: function () {\n const { numberFormatter } = this.series.chart;\n return typeof this.y !== 'number' ?\n '' : numberFormatter(this.y, -1);\n },\n /**\n * For points with an extent, like columns or map areas, whether to\n * align the data label inside the box or to the actual value point.\n * Defaults to `false` in most cases, `true` in stacked columns.\n *\n * @type {boolean}\n * @since 3.0\n * @apioption plotOptions.series.dataLabels.inside\n */\n /**\n * Format for points with the value of null. Works analogously to\n * [format](#plotOptions.series.dataLabels.format). `nullFormat` can\n * be applied only to series which support displaying null points\n * i.e `heatmap` or `tilemap`. Does not work with series that don't\n * display null points, like `line`, `column`, `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {boolean|string}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormat\n */\n /**\n * Callback JavaScript function that defines formatting for points\n * with the value of null. Works analogously to\n * [formatter](#plotOptions.series.dataLabels.formatter).\n * `nullFormatter` can be applied only to series which support\n * displaying null points i.e `heatmap` or `tilemap`. Does not work\n * with series that don't display null points, like `line`, `column`,\n * `bar` or `pie`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-nullformat/\n * Format data label for null points in heat map\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.nullFormatter\n */\n /**\n * How to handle data labels that flow outside the plot area. The\n * default is `\"justify\"`, which aligns them inside the plot area.\n * For columns and bars, this means it will be moved inside the bar.\n * To display data labels outside the plot area, set `crop` to\n * `false` and `overflow` to `\"allow\"`.\n *\n * @type {Highcharts.DataLabelsOverflowValue}\n * @default justify\n * @since 3.0.6\n * @apioption plotOptions.series.dataLabels.overflow\n */\n /**\n * When either the `borderWidth` or the `backgroundColor` is set,\n * this is the padding within the box.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n * @sample {highmaps} maps/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @since 2.2.1\n */\n padding: 5,\n /**\n * Aligns data labels relative to points. If `center` alignment is\n * not possible, it defaults to `right`.\n *\n * @type {Highcharts.AlignValue}\n * @default center\n * @apioption plotOptions.series.dataLabels.position\n */\n /**\n * Text rotation in degrees. Note that due to a more complex\n * structure, backgrounds, borders and padding will be lost on a\n * rotated data label.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical labels\n *\n * @type {number}\n * @default 0\n * @apioption plotOptions.series.dataLabels.rotation\n */\n /**\n * The shadow of the box. Works best with `borderWidth` or\n * `backgroundColor`. Since 2.3 the shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`, `opacity`\n * and `width`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-box/\n * Data labels box options\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n * @default false\n * @since 2.2.1\n * @apioption plotOptions.series.dataLabels.shadow\n */\n /**\n * The name of a symbol to use for the border around the label.\n * Symbols are predefined functions on the Renderer object.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-shape/\n * A callout for annotations\n *\n * @type {string}\n * @default square\n * @since 4.1.2\n * @apioption plotOptions.series.dataLabels.shape\n */\n /**\n * Styles for the label. The default `color` setting is\n * `\"contrast\"`, which is a pseudo color that Highcharts picks up\n * and applies the maximum contrast to the underlying point item,\n * for example the bar in a bar chart.\n *\n * The `textOutline` is a pseudo property that applies an outline of\n * the given width with the given color, which by default is the\n * maximum contrast to the text. So a bright text color will result\n * in a black text outline for maximum readability on a mixed\n * background. In some cases, especially with grayscale text, the\n * text outline doesn't work well, in which cases it can be disabled\n * by setting it to `\"none\"`. When `useHTML` is true, the\n * `textOutline` will not be picked up. In this, case, the same\n * effect can be acheived through the `text-shadow` CSS property.\n *\n * For some series types, where each point has an extent, like for\n * example tree maps, the data label may overflow the point. There\n * are two strategies for handling overflow. By default, the text\n * will wrap to multiple lines. The other strategy is to set\n * `style.textOverflow` to `ellipsis`, which will keep the text on\n * one line plus it will break inside long words.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-style/\n * Bold labels\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow/\n * Long labels truncated with an ellipsis in a pie\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap/\n * Long labels are wrapped in a pie\n * @sample {highmaps} maps/demo/color-axis/\n * Bold labels\n *\n * @type {Highcharts.CSSObject}\n * @since 4.1.0\n * @apioption plotOptions.series.dataLabels.style\n */\n style: {\n /** @internal */\n fontSize: '0.7em',\n /** @internal */\n fontWeight: 'bold',\n /** @internal */\n color: 'contrast',\n /** @internal */\n textOutline: '1px contrast'\n },\n /**\n * Options for a label text which should follow marker's shape.\n * Border and background are disabled for a label that follows a\n * path.\n *\n * **Note:** Only SVG-based renderer supports this option. Setting\n * `useHTML` to true will disable this option.\n *\n * @declare Highcharts.DataLabelsTextPathOptionsObject\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath\n */\n /**\n * Presentation attributes for the text path.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.attributes\n */\n /**\n * Enable or disable `textPath` option for link's or marker's data\n * labels.\n *\n * @type {boolean}\n * @since 7.1.0\n * @apioption plotOptions.series.dataLabels.textPath.enabled\n */\n /**\n * Whether to\n * [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the labels.\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataLabels.useHTML\n */\n /**\n * The vertical alignment of a data label. Can be one of `top`,\n * `middle` or `bottom`. The default value depends on the data, for\n * instance in a column chart, the label is above positive values\n * and below negative values.\n *\n * @type {Highcharts.VerticalAlignValue|null}\n * @since 2.3.3\n */\n verticalAlign: 'bottom',\n /**\n * The x position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n * @sample {highcharts} highcharts/plotoptions/bar-datalabels-align-inside-bar/\n * Data labels inside the bar\n */\n x: 0,\n /**\n * The z index of the data labels. Use a `zIndex` of 6 to display it above\n * the series, or use a `zIndex` of 2 to display it behind the series.\n *\n * @type {number}\n * @default 6\n * @since 2.3.5\n * @apioption plotOptions.series.dataLabels.zIndex\n */\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-rotation/\n * Vertical and positioned\n */\n y: 0\n },\n /**\n * When the series contains less points than the crop threshold, all\n * points are drawn, even if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns), is that animation is performed on\n * updates. On the other hand, when the series contains more points than\n * the crop threshold, the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @since 2.2\n * @product highcharts highstock\n *\n * @private\n */\n cropThreshold: 300,\n /**\n * Opacity of a series parts: line, fill (e.g. area) and dataLabels.\n *\n * @see [states.inactive.opacity](#plotOptions.series.states.inactive.opacity)\n *\n * @since 7.1.0\n *\n * @private\n */\n opacity: 1,\n /**\n * The width of each point on the x axis. For example in a column chart\n * with one value each day, the pointRange would be 1 day (= 24 * 3600\n * * 1000 milliseconds). This is normally computed automatically, but\n * this option can be used to override the automatic value.\n *\n * @product highstock\n *\n * @private\n */\n pointRange: 0,\n /**\n * When this is true, the series will not cause the Y axis to cross\n * the zero plane (or [threshold](#plotOptions.series.threshold) option)\n * unless the data actually crosses the plane.\n *\n * For example, if `softThreshold` is `false`, a series of 0, 1, 2,\n * 3 will make the Y axis show negative values according to the\n * `minPadding` option. If `softThreshold` is `true`, the Y axis starts\n * at 0.\n *\n * @since 4.1.9\n * @product highcharts highstock\n *\n * @private\n */\n softThreshold: true,\n /**\n * @declare Highcharts.SeriesStatesOptionsObject\n *\n * @private\n */\n states: {\n /**\n * The normal state of a series, or for point items in column, pie\n * and similar series. Currently only used for setting animation\n * when returning to normal state from hover.\n *\n * @declare Highcharts.SeriesStatesNormalOptionsObject\n */\n normal: {\n /**\n * Animation when returning to normal state after hovering.\n *\n * @type {boolean|Partial}\n */\n animation: true\n },\n /**\n * Options for the hovered series. These settings override the\n * normal state options when a series is moused over or touched.\n *\n * @declare Highcharts.SeriesStatesHoverOptionsObject\n */\n hover: {\n /**\n * Enable separate styles for the hovered series to visualize\n * that the user hovers either the series itself or the legend.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled/\n * Line\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-column/\n * Column\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-enabled-pie/\n * Pie\n *\n * @type {boolean}\n * @default true\n * @since 1.2\n * @apioption plotOptions.series.states.hover.enabled\n */\n /**\n * Animation setting for hovering the graph in line-type series.\n *\n * @type {boolean|Partial}\n * @since 5.0.8\n * @product highcharts highstock\n */\n animation: {\n /**\n * The duration of the hover animation in milliseconds. By\n * default the hover state animates quickly in, and slowly\n * back to normal.\n *\n * @internal\n */\n duration: 150\n },\n /**\n * Pixel width of the graph line. By default this property is\n * undefined, and the `lineWidthPlus` property dictates how much\n * to increase the linewidth from normal state.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidth/\n * 5px line on hover\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.lineWidth\n */\n /**\n * The additional line width for the graph of a hovered series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n * @sample {highstock} highcharts/plotoptions/series-states-hover-linewidthplus/\n * 5 pixels wider\n *\n * @since 4.0.3\n * @product highcharts highstock\n */\n lineWidthPlus: 1,\n /**\n * In Highcharts 1.0, the appearance of all markers belonging\n * to the hovered series. For settings on the hover state of the\n * individual point, see\n * [marker.states.hover](#plotOptions.series.marker.states.hover).\n *\n * @deprecated\n *\n * @extends plotOptions.series.marker\n * @excluding states, symbol\n * @product highcharts highstock\n */\n marker: {\n // lineWidth: base + 1,\n // radius: base + 1\n },\n /**\n * Options for the halo appearing around the hovered point in\n * line-type series as well as outside the hovered slice in pie\n * charts. By default the halo is filled by the current point or\n * series color with an opacity of 0.25\\. The halo can be\n * disabled by setting the `halo` option to `null`.\n *\n * In styled mode, the halo is styled with the\n * `.highcharts-halo` class, with colors inherited from\n * `.highcharts-color-{n}`.\n *\n * @sample {highcharts} highcharts/plotoptions/halo/\n * Halo options\n * @sample {highstock} highcharts/plotoptions/halo/\n * Halo options\n *\n * @declare Highcharts.SeriesStatesHoverHaloOptionsObject\n * @type {null|*}\n * @since 4.0\n * @product highcharts highstock\n */\n halo: {\n /**\n * A collection of SVG attributes to override the appearance\n * of the halo, for example `fill`, `stroke` and\n * `stroke-width`.\n *\n * @type {Highcharts.SVGAttributes}\n * @since 4.0\n * @product highcharts highstock\n * @apioption plotOptions.series.states.hover.halo.attributes\n */\n /**\n * The pixel size of the halo. For point markers this is the\n * radius of the halo. For pie slices it is the width of the\n * halo outside the slice. For bubbles it defaults to 5 and\n * is the width of the halo outside the bubble.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n size: 10,\n /**\n * Opacity for the halo unless a specific fill is overridden\n * using the `attributes` setting. Note that Highcharts is\n * only able to apply opacity to colors of hex or rgb(a)\n * formats.\n *\n * @since 4.0\n * @product highcharts highstock\n */\n opacity: 0.25\n }\n },\n /**\n * Specific options for point in selected states, after being\n * selected by\n * [allowPointSelect](#plotOptions.series.allowPointSelect)\n * or programmatically.\n *\n * @sample maps/plotoptions/series-allowpointselect/\n * Allow point select demo\n *\n * @declare Highcharts.SeriesStatesSelectOptionsObject\n * @extends plotOptions.series.states.hover\n * @excluding brightness\n */\n select: {\n animation: {\n /** @internal */\n duration: 0\n }\n },\n /**\n * The opposite state of a hover for series.\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @declare Highcharts.SeriesStatesInactiveOptionsObject\n */\n inactive: {\n /**\n * Enable or disable the inactive state for a series\n *\n * @sample highcharts/plotoptions/series-states-inactive-disabled\n * Disabled inactive state\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.states.inactive.enabled\n */\n /**\n * The animation for entering the inactive state.\n *\n * @type {boolean|Partial}\n */\n animation: {\n /** @internal */\n duration: 150\n },\n /**\n * Opacity of series elements (dataLabels, line, area).\n *\n * @type {number}\n */\n opacity: 0.2\n }\n },\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event on a\n * series isn't triggered until the mouse moves over another series, or\n * out of the plot area. When false, the `mouseOut` event on a series is\n * triggered when the mouse leaves the area around the series' graph or\n * markers. This also implies the tooltip when not shared. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series. Defaults to true\n * for line and area type series, but to false for columns, pies etc.\n *\n * **Note:** The boost module will force this option because of\n * technical limitations.\n *\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-true/\n * True by default\n * @sample {highcharts} highcharts/plotoptions/series-stickytracking-false/\n * False\n *\n * @default {highcharts} true\n * @default {highstock} true\n * @default {highmaps} false\n * @since 2.0\n *\n * @private\n */\n stickyTracking: true,\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip), but only\n * the following properties can be defined on a series level.\n *\n * @declare Highcharts.SeriesTooltipOptionsObject\n * @since 2.3\n * @extends tooltip\n * @excluding animation, backgroundColor, borderColor, borderRadius,\n * borderWidth, className, crosshairs, enabled, formatter,\n * headerShape, hideDelay, outside, padding, positioner,\n * shadow, shape, shared, snap, split, stickOnContact,\n * style, useHTML\n * @apioption plotOptions.series.tooltip\n */\n /**\n * When a series contains a data array that is longer than this, only\n * one dimensional arrays of numbers, or two dimensional arrays with\n * x and y values are allowed. Also, only the first point is tested,\n * and the rest are assumed to be the same format. This saves expensive\n * data checking and indexing in long series. Set it to `0` disable.\n *\n * Note:\n * In boost mode turbo threshold is forced. Only array of numbers or\n * two dimensional arrays are allowed.\n *\n * @since 2.2\n * @product highcharts highstock gantt\n *\n * @private\n */\n turboThreshold: 1000,\n /**\n * An array defining zones within a series. Zones can be applied to the\n * X axis, Y axis or Z axis for bubbles, according to the `zoneAxis`\n * option. The zone definitions have to be in ascending order regarding\n * to the value.\n *\n * In styled mode, the color zones are styled with the\n * `.highcharts-zone-{n}` class, or custom classed from the `className`\n * option\n * ([view live demo](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/css/color-zones/)).\n *\n * @see [zoneAxis](#plotOptions.series.zoneAxis)\n *\n * @sample {highcharts} highcharts/series/color-zones-simple/\n * Color zones\n * @sample {highstock} highcharts/series/color-zones-simple/\n * Color zones\n *\n * @declare Highcharts.SeriesZonesOptionsObject\n * @type {Array<*>}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones\n */\n /**\n * Styled mode only. A custom class name for the zone.\n *\n * @sample highcharts/css/color-zones/\n * Zones styled by class name\n *\n * @type {string}\n * @since 5.0.0\n * @apioption plotOptions.series.zones.className\n */\n /**\n * Defines the color of the series.\n *\n * @see [series color](#plotOptions.series.color)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.color\n */\n /**\n * A name for the dash style to use for the graph.\n *\n * @see [plotOptions.series.dashStyle](#plotOptions.series.dashStyle)\n *\n * @sample {highcharts|highstock} highcharts/series/color-zones-dashstyle-dot/\n * Dashed line indicates prognosis\n *\n * @type {Highcharts.DashStyleValue}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.dashStyle\n */\n /**\n * Defines the fill color for the series (in area type series)\n *\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.fillColor\n */\n /**\n * The value up to where the zone extends, if undefined the zones\n * stretches to the last value in the series.\n *\n * @type {number}\n * @since 4.1.0\n * @product highcharts highstock\n * @apioption plotOptions.series.zones.value\n */\n /**\n * When using dual or multiple color axes, this number defines which\n * colorAxis the particular series is connected to. It refers to\n * either the\n * {@link #colorAxis.id|axis id}\n * or the index of the axis in the colorAxis array, with 0 being the\n * first. Set this option to false to prevent a series from connecting\n * to the default color axis.\n *\n * Since v7.2.0 the option can also be an axis id or an axis index\n * instead of a boolean flag.\n *\n * @sample highcharts/coloraxis/coloraxis-with-pie/\n * Color axis with pie series\n * @sample highcharts/coloraxis/multiple-coloraxis/\n * Multiple color axis\n *\n * @type {number|string|boolean}\n * @default 0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorAxis\n */\n /**\n * Determines what data value should be used to calculate point color\n * if `colorAxis` is used. Requires to set `min` and `max` if some\n * custom point property is used or if approximation for data grouping\n * is set to `'sum'`.\n *\n * @sample highcharts/coloraxis/custom-color-key/\n * Custom color key\n * @sample highcharts/coloraxis/color-key-with-stops/\n * Custom colorKey with color axis stops\n * @sample highcharts/coloraxis/changed-default-color-key/\n * Changed default color key\n *\n * @type {string}\n * @default y\n * @since 7.2.0\n * @product highcharts highstock highmaps\n * @apioption plotOptions.series.colorKey\n */\n /**\n * What type of legend symbol to render for this series. Can be one of\n * `lineMarker` or `rectangle`.\n *\n * @validvalue [\"lineMarker\", \"rectangle\"]\n *\n * @sample {highcharts} highcharts/series/legend-symbol/\n * Change the legend symbol\n *\n * @type {string}\n * @default rectangle\n * @since 11.0.1\n * @apioption plotOptions.series.legendSymbol\n */\n /**\n * Determines whether the series should look for the nearest point\n * in both dimensions or just the x-dimension when hovering the series.\n * Defaults to `'xy'` for scatter series and `'x'` for most other\n * series. If the data has duplicate x-values, it is recommended to\n * set this to `'xy'` to allow hovering over all points.\n *\n * Applies only to series types using nearest neighbor search (not\n * direct hover) for tooltip.\n *\n * @sample {highcharts} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highstock} highcharts/series/findnearestpointby/\n * Different hover behaviors\n * @sample {highmaps} highcharts/series/findnearestpointby/\n * Different hover behaviors\n *\n * @since 5.0.10\n * @validvalue [\"x\", \"xy\"]\n *\n * @private\n */\n findNearestPointBy: 'x'\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return seriesDefaults;\n });\n _registerModule(_modules, 'Core/Series/SeriesRegistry.js', [_modules['Core/Globals.js'], _modules['Core/Defaults.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (H, D, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { extendClass, merge } = U;\n /* *\n *\n * Namespace\n *\n * */\n var SeriesRegistry;\n (function (SeriesRegistry) {\n /* *\n *\n * Properties\n *\n * */\n /**\n * @internal\n * @todo Move `Globals.seriesTypes` code to her.\n */\n SeriesRegistry.seriesTypes = H.seriesTypes;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Registers class pattern of a series.\n *\n * @private\n */\n function registerSeriesType(seriesType, SeriesClass) {\n const defaultPlotOptions = defaultOptions.plotOptions || {}, seriesOptions = SeriesClass.defaultOptions, seriesProto = SeriesClass.prototype;\n seriesProto.type = seriesType;\n if (!seriesProto.pointClass) {\n seriesProto.pointClass = Point;\n }\n if (seriesOptions) {\n defaultPlotOptions[seriesType] = seriesOptions;\n }\n SeriesRegistry.seriesTypes[seriesType] = SeriesClass;\n }\n SeriesRegistry.registerSeriesType = registerSeriesType;\n /**\n * Old factory to create new series prototypes.\n *\n * @deprecated\n * @function Highcharts.seriesType\n *\n * @param {string} type\n * The series type name.\n *\n * @param {string} parent\n * The parent series type name. Use `line` to inherit from the basic\n * {@link Series} object.\n *\n * @param {Highcharts.SeriesOptionsType|Highcharts.Dictionary<*>} options\n * The additional default options that are merged with the parent's options.\n *\n * @param {Highcharts.Dictionary<*>} [props]\n * The properties (functions and primitives) to set on the new prototype.\n *\n * @param {Highcharts.Dictionary<*>} [pointProps]\n * Members for a series-specific extension of the {@link Point} prototype if\n * needed.\n *\n * @return {Highcharts.Series}\n * The newly created prototype as extended from {@link Series} or its\n * derivatives.\n */\n function seriesType(type, parent, options, seriesProto, pointProto) {\n const defaultPlotOptions = defaultOptions.plotOptions || {};\n parent = parent || '';\n // Merge the options\n defaultPlotOptions[type] = merge(defaultPlotOptions[parent], options);\n // Create the class\n registerSeriesType(type, extendClass(SeriesRegistry.seriesTypes[parent] || function () { }, seriesProto));\n SeriesRegistry.seriesTypes[type].prototype.type = type;\n // Create the point class if needed\n if (pointProto) {\n SeriesRegistry.seriesTypes[type].prototype.pointClass = extendClass(Point, pointProto);\n }\n return SeriesRegistry.seriesTypes[type];\n }\n SeriesRegistry.seriesType = seriesType;\n })(SeriesRegistry || (SeriesRegistry = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return SeriesRegistry;\n });\n _registerModule(_modules, 'Core/Series/Series.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Defaults.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Legend/LegendSymbol.js'], _modules['Core/Series/Point.js'], _modules['Core/Series/SeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (A, D, F, H, LegendSymbol, Point, SeriesDefaults, SeriesRegistry, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject, setAnimation } = A;\n const { defaultOptions } = D;\n const { registerEventOptions } = F;\n const { hasTouch, svg, win } = H;\n const { seriesTypes } = SeriesRegistry;\n const { addEvent, arrayMax, arrayMin, clamp, correctFloat, defined, diffObjects, erase, error, extend, find, fireEvent, getClosestDistance, getNestedProperty, insertItem, isArray, isNumber, isString, merge, objectEach, pick, removeEvent, splat, syncTimeout } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * This is the base series prototype that all other series types inherit from.\n * A new series is initialized either through the\n * [series](https://api.highcharts.com/highcharts/series)\n * option structure, or after the chart is initialized, through\n * {@link Highcharts.Chart#addSeries}.\n *\n * The object can be accessed in a number of ways. All series and point event\n * handlers give a reference to the `series` object. The chart object has a\n * {@link Highcharts.Chart#series|series} property that is a collection of all\n * the chart's series. The point objects and axis objects also have the same\n * reference.\n *\n * Another way to reference the series programmatically is by `id`. Add an id\n * in the series configuration options, and get the series object by\n * {@link Highcharts.Chart#get}.\n *\n * Configuration options for the series are given in three levels. Options for\n * all series in a chart are given in the\n * [plotOptions.series](https://api.highcharts.com/highcharts/plotOptions.series)\n * object. Then options for all series of a specific type\n * are given in the plotOptions of that type, for example `plotOptions.line`.\n * Next, options for one single series are given in the series array, or as\n * arguments to `chart.addSeries`.\n *\n * The data in the series is stored in various arrays.\n *\n * - First, `series.options.data` contains all the original config options for\n * each point whether added by options or methods like `series.addPoint`.\n *\n * - Next, `series.data` contains those values converted to points, but in case\n * the series data length exceeds the `cropThreshold`, or if the data is\n * grouped, `series.data` doesn't contain all the points. It only contains the\n * points that have been created on demand.\n *\n * - Then there's `series.points` that contains all currently visible point\n * objects. In case of cropping, the cropped-away points are not part of this\n * array. The `series.points` array starts at `series.cropStart` compared to\n * `series.data` and `series.options.data`. If however the series data is\n * grouped, these can't be correlated one to one.\n *\n * - `series.xData` and `series.processedXData` contain clean x values,\n * equivalent to `series.data` and `series.points`.\n *\n * - `series.yData` and `series.processedYData` contain clean y values,\n * equivalent to `series.data` and `series.points`.\n *\n * @class\n * @name Highcharts.Series\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.SeriesOptionsType|object} options\n * The series options.\n */\n class Series {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n this._i = void 0;\n this.chart = void 0;\n this.data = void 0;\n this.eventOptions = void 0;\n this.eventsToUnbind = void 0;\n this.index = void 0;\n this.linkedSeries = void 0;\n this.options = void 0;\n this.points = void 0;\n this.processedXData = void 0;\n this.processedYData = void 0;\n this.tooltipOptions = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zones = void 0;\n /** eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n init(chart, userOptions) {\n fireEvent(this, 'init', { options: userOptions });\n const series = this, chartSeries = chart.series;\n // The 'eventsToUnbind' property moved from prototype into the\n // Series init to avoid reference to the same array between\n // the different series and charts. #12959, #13937\n this.eventsToUnbind = [];\n /**\n * Read only. The chart that the series belongs to.\n *\n * @name Highcharts.Series#chart\n * @type {Highcharts.Chart}\n */\n series.chart = chart;\n /**\n * Read only. The series' type, like \"line\", \"area\", \"column\" etc.\n * The type in the series options anc can be altered using\n * {@link Series#update}.\n *\n * @name Highcharts.Series#type\n * @type {string}\n */\n /**\n * Read only. The series' current options. To update, use\n * {@link Series#update}.\n *\n * @name Highcharts.Series#options\n * @type {Highcharts.SeriesOptionsType}\n */\n series.options = series.setOptions(userOptions);\n const options = series.options;\n series.linkedSeries = [];\n // bind the axes\n series.bindAxes();\n extend(series, {\n /**\n * The series name as given in the options. Defaults to\n * \"Series {n}\".\n *\n * @name Highcharts.Series#name\n * @type {string}\n */\n name: options.name,\n state: '',\n /**\n * Read only. The series' visibility state as set by {@link\n * Series#show}, {@link Series#hide}, or in the initial\n * configuration.\n *\n * @name Highcharts.Series#visible\n * @type {boolean}\n */\n visible: options.visible !== false,\n /**\n * Read only. The series' selected state as set by {@link\n * Highcharts.Series#select}.\n *\n * @name Highcharts.Series#selected\n * @type {boolean}\n */\n selected: options.selected === true // false by default\n });\n registerEventOptions(this, options);\n const events = options.events;\n if ((events && events.click) ||\n (options.point &&\n options.point.events &&\n options.point.events.click) ||\n options.allowPointSelect) {\n chart.runTrackerClick = true;\n }\n series.getColor();\n series.getSymbol();\n // Initialize the parallel data arrays\n series.parallelArrays.forEach(function (key) {\n if (!series[key + 'Data']) {\n series[key + 'Data'] = [];\n }\n });\n // Mark cartesian\n if (series.isCartesian) {\n chart.hasCartesianSeries = true;\n }\n // Get the index and register the series in the chart. The index is\n // one more than the current latest series index (#5960).\n let lastSeries;\n if (chartSeries.length) {\n lastSeries = chartSeries[chartSeries.length - 1];\n }\n series._i = pick(lastSeries && lastSeries._i, -1) + 1;\n series.opacity = series.options.opacity;\n // Insert the series and re-order all series above the insertion\n // point.\n chart.orderItems('series', insertItem(this, chartSeries));\n // Set options for series with sorting and set data later.\n if (options.dataSorting && options.dataSorting.enabled) {\n series.setDataSortingOptions();\n }\n else if (!series.points && !series.data) {\n series.setData(options.data, false);\n }\n fireEvent(this, 'afterInit');\n }\n /**\n * Check whether the series item is itself or inherits from a certain\n * series type.\n *\n * @function Highcharts.Series#is\n * @param {string} type The type of series to check for, can be either\n * featured or custom series types. For example `column`, `pie`,\n * `ohlc` etc.\n *\n * @return {boolean}\n * True if this item is or inherits from the given type.\n */\n is(type) {\n return seriesTypes[type] && this instanceof seriesTypes[type];\n }\n /**\n * Set the xAxis and yAxis properties of cartesian series, and register\n * the series in the `axis.series` array.\n *\n * @private\n * @function Highcharts.Series#bindAxes\n */\n bindAxes() {\n const series = this, seriesOptions = series.options, chart = series.chart;\n let axisOptions;\n fireEvent(this, 'bindAxes', null, function () {\n // repeat for xAxis and yAxis\n (series.axisTypes || []).forEach(function (coll) {\n // loop through the chart's axis objects\n chart[coll].forEach(function (axis) {\n axisOptions = axis.options;\n // apply if the series xAxis or yAxis option mathches\n // the number of the axis, or if undefined, use the\n // first axis\n if (pick(seriesOptions[coll], 0) === axis.index ||\n (typeof seriesOptions[coll] !==\n 'undefined' &&\n seriesOptions[coll] === axisOptions.id)) {\n // register this series in the axis.series lookup\n insertItem(series, axis.series);\n // set this series.xAxis or series.yAxis reference\n /**\n * Read only. The unique xAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#xAxis\n * @type {Highcharts.Axis}\n */\n /**\n * Read only. The unique yAxis object associated\n * with the series.\n *\n * @name Highcharts.Series#yAxis\n * @type {Highcharts.Axis}\n */\n series[coll] = axis;\n // mark dirty for redraw\n axis.isDirty = true;\n }\n });\n // The series needs an X and an Y axis\n if (!series[coll] &&\n series.optionalAxis !== coll) {\n error(18, true, chart);\n }\n });\n });\n fireEvent(this, 'afterBindAxes');\n }\n /**\n * For simple series types like line and column, the data values are\n * held in arrays like xData and yData for quick lookup to find extremes\n * and more. For multidimensional series like bubble and map, this can\n * be extended with arrays like zData and valueData by adding to the\n * `series.parallelArrays` array.\n *\n * @private\n * @function Highcharts.Series#updateParallelArrays\n */\n updateParallelArrays(point, i, iArgs) {\n const series = point.series, fn = isNumber(i) ?\n // Insert the value in the given position\n function (key) {\n const val = key === 'y' && series.toYData ?\n series.toYData(point) :\n point[key];\n series[key + 'Data'][i] = val;\n } :\n // Apply the method specified in i with the following\n // arguments as arguments\n function (key) {\n Array.prototype[i].apply(series[key + 'Data'], iArgs);\n };\n series.parallelArrays.forEach(fn);\n }\n /**\n * Define hasData functions for series. These return true if there\n * are data points on this series within the plot area.\n *\n * @private\n * @function Highcharts.Series#hasData\n */\n hasData() {\n return ((this.visible &&\n typeof this.dataMax !== 'undefined' &&\n typeof this.dataMin !== 'undefined') || ( // #3703\n this.visible &&\n this.yData &&\n this.yData.length > 0) // #9758\n );\n }\n /**\n * Return an auto incremented x value based on the pointStart and\n * pointInterval options. This is only used if an x value is not given\n * for the point that calls autoIncrement.\n *\n * @private\n * @function Highcharts.Series#autoIncrement\n */\n autoIncrement(x) {\n const options = this.options, pointIntervalUnit = options.pointIntervalUnit, relativeXValue = options.relativeXValue, time = this.chart.time;\n let xIncrement = this.xIncrement, date, pointInterval;\n xIncrement = pick(xIncrement, options.pointStart, 0);\n this.pointInterval = pointInterval = pick(this.pointInterval, options.pointInterval, 1);\n if (relativeXValue && isNumber(x)) {\n pointInterval *= x;\n }\n // Added code for pointInterval strings\n if (pointIntervalUnit) {\n date = new time.Date(xIncrement);\n if (pointIntervalUnit === 'day') {\n time.set('Date', date, time.get('Date', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'month') {\n time.set('Month', date, time.get('Month', date) + pointInterval);\n }\n else if (pointIntervalUnit === 'year') {\n time.set('FullYear', date, time.get('FullYear', date) + pointInterval);\n }\n pointInterval = date.getTime() - xIncrement;\n }\n if (relativeXValue && isNumber(x)) {\n return xIncrement + pointInterval;\n }\n this.xIncrement = xIncrement + pointInterval;\n return xIncrement;\n }\n /**\n * Internal function to set properties for series if data sorting is\n * enabled.\n *\n * @private\n * @function Highcharts.Series#setDataSortingOptions\n */\n setDataSortingOptions() {\n const options = this.options;\n extend(this, {\n requireSorting: false,\n sorted: false,\n enabledDataSorting: true,\n allowDG: false\n });\n // To allow unsorted data for column series.\n if (!defined(options.pointRange)) {\n options.pointRange = 1;\n }\n }\n /**\n * Set the series options by merging from the options tree. Called\n * internally on initializing and updating series. This function will\n * not redraw the series. For API usage, use {@link Series#update}.\n * @private\n * @function Highcharts.Series#setOptions\n * @param {Highcharts.SeriesOptionsType} itemOptions\n * The series options.\n * @emits Highcharts.Series#event:afterSetOptions\n */\n setOptions(itemOptions) {\n var _a,\n _b;\n const chart = this.chart, chartOptions = chart.options, plotOptions = chartOptions.plotOptions, userOptions = chart.userOptions || {}, seriesUserOptions = merge(itemOptions), styledMode = chart.styledMode, e = {\n plotOptions: plotOptions,\n userOptions: seriesUserOptions\n };\n let zone;\n fireEvent(this, 'setOptions', e);\n // These may be modified by the event\n const typeOptions = e.plotOptions[this.type], userPlotOptions = (userOptions.plotOptions || {}), userPlotOptionsSeries = userPlotOptions.series || {}, defaultPlotOptionsType = (defaultOptions.plotOptions[this.type] || {}), userPlotOptionsType = userPlotOptions[this.type] || {};\n // use copy to prevent undetected changes (#9762)\n /**\n * Contains series options by the user without defaults.\n * @name Highcharts.Series#userOptions\n * @type {Highcharts.SeriesOptionsType}\n */\n this.userOptions = e.userOptions;\n const options = merge(typeOptions, plotOptions.series, \n // #3881, chart instance plotOptions[type] should trump\n // plotOptions.series\n userPlotOptionsType, seriesUserOptions);\n // The tooltip options are merged between global and series specific\n // options. Importance order asscendingly:\n // globals: (1)tooltip, (2)plotOptions.series,\n // (3)plotOptions[this.type]\n // init userOptions with possible later updates: 4-6 like 1-3 and\n // (7)this series options\n this.tooltipOptions = merge(defaultOptions.tooltip, // 1\n (_a = defaultOptions.plotOptions.series) === null || _a === void 0 ? void 0 : _a.tooltip, // 2\n defaultPlotOptionsType === null || defaultPlotOptionsType === void 0 ? void 0 : defaultPlotOptionsType.tooltip, // 3\n chart.userOptions.tooltip, // 4\n (_b = userPlotOptions.series) === null || _b === void 0 ? void 0 : _b.tooltip, // 5\n userPlotOptionsType.tooltip, // 6\n seriesUserOptions.tooltip // 7\n );\n // When shared tooltip, stickyTracking is true by default,\n // unless user says otherwise.\n this.stickyTracking = pick(seriesUserOptions.stickyTracking, userPlotOptionsType.stickyTracking, userPlotOptionsSeries.stickyTracking, (this.tooltipOptions.shared && !this.noSharedTooltip ?\n true :\n options.stickyTracking));\n // Delete marker object if not allowed (#1125)\n if (typeOptions.marker === null) {\n delete options.marker;\n }\n // Handle color zones\n this.zoneAxis = options.zoneAxis;\n const zones = this.zones = (options.zones || []).slice();\n if ((options.negativeColor || options.negativeFillColor) &&\n !options.zones) {\n zone = {\n value: options[this.zoneAxis + 'Threshold'] ||\n options.threshold ||\n 0,\n className: 'highcharts-negative'\n };\n if (!styledMode) {\n zone.color = options.negativeColor;\n zone.fillColor = options.negativeFillColor;\n }\n zones.push(zone);\n }\n if (zones.length) { // Push one extra zone for the rest\n if (defined(zones[zones.length - 1].value)) {\n zones.push(styledMode ? {} : {\n color: this.color,\n fillColor: this.fillColor\n });\n }\n }\n fireEvent(this, 'afterSetOptions', { options: options });\n return options;\n }\n /**\n * Return series name in \"Series {Number}\" format or the one defined by\n * a user. This method can be simply overridden as series name format\n * can vary (e.g. technical indicators).\n *\n * @function Highcharts.Series#getName\n *\n * @return {string}\n * The series name.\n */\n getName() {\n // #4119\n return pick(this.options.name, 'Series ' + (this.index + 1));\n }\n /**\n * @private\n * @function Highcharts.Series#getCyclic\n */\n getCyclic(prop, value, defaults) {\n const chart = this.chart, indexName = `${prop}Index`, counterName = `${prop}Counter`, len = (\n // Symbol count\n (defaults === null || defaults === void 0 ? void 0 : defaults.length) ||\n // Color count\n chart.options.chart.colorCount);\n let i, setting;\n if (!value) {\n // Pick up either the colorIndex option, or the series.colorIndex\n // after Series.update()\n setting = pick(prop === 'color' ? this.options.colorIndex : void 0, this[indexName]);\n if (defined(setting)) { // after Series.update()\n i = setting;\n }\n else {\n // #6138\n if (!chart.series.length) {\n chart[counterName] = 0;\n }\n i = chart[counterName] % len;\n chart[counterName] += 1;\n }\n if (defaults) {\n value = defaults[i];\n }\n }\n // Set the colorIndex\n if (typeof i !== 'undefined') {\n this[indexName] = i;\n }\n this[prop] = value;\n }\n /**\n * Get the series' color based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getColor\n */\n getColor() {\n if (this.chart.styledMode) {\n this.getCyclic('color');\n }\n else if (this.options.colorByPoint) {\n this.color = \"#cccccc\" /* Palette.neutralColor20 */;\n }\n else {\n this.getCyclic('color', this.options.color ||\n defaultOptions.plotOptions[this.type].color, this.chart.options.colors);\n }\n }\n /**\n * Get all points' instances created for this series.\n *\n * @private\n * @function Highcharts.Series#getPointsCollection\n */\n getPointsCollection() {\n return (this.hasGroupedData ? this.points : this.data) || [];\n }\n /**\n * Get the series' symbol based on either the options or pulled from\n * global options.\n *\n * @private\n * @function Highcharts.Series#getSymbol\n */\n getSymbol() {\n const seriesMarkerOption = this.options.marker;\n this.getCyclic('symbol', seriesMarkerOption.symbol, this.chart.options.symbols);\n }\n /**\n * Finds the index of an existing point that matches the given point\n * options.\n *\n * @private\n * @function Highcharts.Series#findPointIndex\n * @param {Highcharts.PointOptionsObject} optionsObject\n * The options of the point.\n * @param {number} fromIndex\n * The index to start searching from, used for optimizing series with\n * required sorting.\n * @return {number|undefined}\n * Returns the index of a matching point, or undefined if no match is found.\n */\n findPointIndex(optionsObject, fromIndex) {\n const id = optionsObject.id, x = optionsObject.x, oldData = this.points, dataSorting = this.options.dataSorting;\n let matchingPoint, matchedById, pointIndex;\n if (id) {\n const item = this.chart.get(id);\n if (item instanceof Point) {\n matchingPoint = item;\n }\n }\n else if (this.linkedParent ||\n this.enabledDataSorting ||\n this.options.relativeXValue) {\n let matcher = (oldPoint) => !oldPoint.touched &&\n oldPoint.index === optionsObject.index;\n if (dataSorting && dataSorting.matchByName) {\n matcher = (oldPoint) => !oldPoint.touched &&\n oldPoint.name === optionsObject.name;\n }\n else if (this.options.relativeXValue) {\n matcher = (oldPoint) => !oldPoint.touched &&\n oldPoint.options.x === optionsObject.x;\n }\n matchingPoint = find(oldData, matcher);\n // Add unmatched point as a new point\n if (!matchingPoint) {\n return void 0;\n }\n }\n if (matchingPoint) {\n pointIndex = matchingPoint && matchingPoint.index;\n if (typeof pointIndex !== 'undefined') {\n matchedById = true;\n }\n }\n // Search for the same X in the existing data set\n if (typeof pointIndex === 'undefined' && isNumber(x)) {\n pointIndex = this.xData.indexOf(x, fromIndex);\n }\n // Reduce pointIndex if data is cropped\n if (pointIndex !== -1 &&\n typeof pointIndex !== 'undefined' &&\n this.cropped) {\n pointIndex = (pointIndex >= this.cropStart) ?\n pointIndex - this.cropStart : pointIndex;\n }\n if (!matchedById &&\n isNumber(pointIndex) &&\n oldData[pointIndex] && oldData[pointIndex].touched) {\n pointIndex = void 0;\n }\n return pointIndex;\n }\n /**\n * Internal function called from setData. If the point count is the same\n * as it was, or if there are overlapping X values, just run\n * Point.update which is cheaper, allows animation, and keeps references\n * to points. This also allows adding or removing points if the X-es\n * don't match.\n *\n * @private\n * @function Highcharts.Series#updateData\n */\n updateData(data, animation) {\n const options = this.options, dataSorting = options.dataSorting, oldData = this.points, pointsToAdd = [], requireSorting = this.requireSorting, equalLength = data.length === oldData.length;\n let hasUpdatedByKey, i, point, lastIndex, succeeded = true;\n this.xIncrement = null;\n // Iterate the new data\n data.forEach(function (pointOptions, i) {\n const optionsObject = (defined(pointOptions) &&\n this.pointClass.prototype.optionsToObject.call({ series: this }, pointOptions)) || {};\n let pointIndex;\n // Get the x of the new data point\n const x = optionsObject.x, id = optionsObject.id;\n if (id || isNumber(x)) {\n pointIndex = this.findPointIndex(optionsObject, lastIndex);\n // Matching X not found\n // or used already due to ununique x values (#8995),\n // add point (but later)\n if (pointIndex === -1 ||\n typeof pointIndex === 'undefined') {\n pointsToAdd.push(pointOptions);\n // Matching X found, update\n }\n else if (oldData[pointIndex] &&\n pointOptions !== options.data[pointIndex]) {\n oldData[pointIndex].update(pointOptions, false, null, false);\n // Mark it touched, below we will remove all points that\n // are not touched.\n oldData[pointIndex].touched = true;\n // Speed optimize by only searching after last known\n // index. Performs ~20% bettor on large data sets.\n if (requireSorting) {\n lastIndex = pointIndex + 1;\n }\n // Point exists, no changes, don't remove it\n }\n else if (oldData[pointIndex]) {\n oldData[pointIndex].touched = true;\n }\n // If the length is equal and some of the nodes had a\n // match in the same position, we don't want to remove\n // non-matches.\n if (!equalLength ||\n i !== pointIndex ||\n (dataSorting && dataSorting.enabled) ||\n this.hasDerivedData) {\n hasUpdatedByKey = true;\n }\n }\n else {\n // Gather all points that are not matched\n pointsToAdd.push(pointOptions);\n }\n }, this);\n // Remove points that don't exist in the updated data set\n if (hasUpdatedByKey) {\n i = oldData.length;\n while (i--) {\n point = oldData[i];\n if (point && !point.touched && point.remove) {\n point.remove(false, animation);\n }\n }\n // If we did not find keys (ids or x-values), and the length is the\n // same, update one-to-one\n }\n else if (equalLength && (!dataSorting || !dataSorting.enabled)) {\n data.forEach(function (point, i) {\n // .update doesn't exist on a linked, hidden series (#3709)\n // (#10187)\n if (point !== oldData[i].y && !oldData[i].destroyed) {\n oldData[i].update(point, false, null, false);\n }\n });\n // Don't add new points since those configs are used above\n pointsToAdd.length = 0;\n // Did not succeed in updating data\n }\n else {\n succeeded = false;\n }\n oldData.forEach(function (point) {\n if (point) {\n point.touched = false;\n }\n });\n if (!succeeded) {\n return false;\n }\n // Add new points\n pointsToAdd.forEach(function (point) {\n this.addPoint(point, false, null, null, false);\n }, this);\n if (this.xIncrement === null &&\n this.xData &&\n this.xData.length) {\n this.xIncrement = arrayMax(this.xData);\n this.autoIncrement();\n }\n return true;\n }\n /**\n * Apply a new set of data to the series and optionally redraw it. The\n * new data array is passed by reference (except in case of\n * `updatePoints`), and may later be mutated when updating the chart\n * data.\n *\n * Note the difference in behaviour when setting the same amount of\n * points, or a different amount of points, as handled by the\n * `updatePoints` parameter.\n *\n * @sample highcharts/members/series-setdata/\n * Set new data from a button\n * @sample highcharts/members/series-setdata-pie/\n * Set data in a pie\n * @sample stock/members/series-setdata/\n * Set new data in Highcharts Stock\n * @sample maps/members/series-setdata/\n * Set new data in Highmaps\n *\n * @function Highcharts.Series#setData\n *\n * @param {Array} data\n * Takes an array of data in the same format as described under\n * `series.{type}.data` for the given series type, for example a\n * line series would take data in the form described under\n * [series.line.data](https://api.highcharts.com/highcharts/series.line.data).\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If\n * doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw} after.\n *\n * @param {boolean|Partial} [animation]\n * When the updated data is the same length as the existing data,\n * points will be updated by default, and animation visualizes\n * how the points are changed. Set false to disable animation, or\n * a configuration object to set duration or easing.\n *\n * @param {boolean} [updatePoints=true]\n * When this is true, points will be updated instead of replaced\n * whenever possible. This occurs a) when the updated data is the\n * same length as the existing data, b) when points are matched\n * by their id's, or c) when points can be matched by X values.\n * This allows updating with animation and performs better. In\n * this case, the original array is not passed by reference. Set\n * `false` to prevent.\n */\n setData(data, redraw = true, animation, updatePoints) {\n var _a;\n const series = this, oldData = series.points, oldDataLength = (oldData && oldData.length) || 0, options = series.options, chart = series.chart, dataSorting = options.dataSorting, xAxis = series.xAxis, turboThreshold = options.turboThreshold, xData = this.xData, yData = this.yData, pointArrayMap = series.pointArrayMap, valueCount = pointArrayMap && pointArrayMap.length, keys = options.keys;\n let i, pt, updatedData, indexOfX = 0, indexOfY = 1, firstPoint = null, copiedData;\n if (!chart.options.chart.allowMutatingData) { // #4259\n // Remove old reference\n if (options.data) {\n delete series.options.data;\n }\n if (series.userOptions.data) {\n delete series.userOptions.data;\n }\n copiedData = merge(true, data);\n }\n data = copiedData || data || [];\n const dataLength = data.length;\n if (dataSorting && dataSorting.enabled) {\n data = this.sortData(data);\n }\n // First try to run Point.update which is cheaper, allows animation,\n // and keeps references to points.\n if (chart.options.chart.allowMutatingData &&\n updatePoints !== false &&\n dataLength &&\n oldDataLength &&\n !series.cropped &&\n !series.hasGroupedData &&\n series.visible &&\n // Soft updating has no benefit in boost, and causes JS error\n // (#8355)\n !series.boosted) {\n updatedData = this.updateData(data, animation);\n }\n if (!updatedData) {\n // Reset properties\n series.xIncrement = null;\n series.colorCounter = 0; // for series with colorByPoint (#1547)\n // Update parallel arrays\n this.parallelArrays.forEach(function (key) {\n series[key + 'Data'].length = 0;\n });\n // In turbo mode, only one- or twodimensional arrays of numbers\n // are allowed. The first value is tested, and we assume that\n // all the rest are defined the same way. Although the 'for'\n // loops are similar, they are repeated inside each if-else\n // conditional for max performance.\n if (turboThreshold && dataLength > turboThreshold) {\n firstPoint = series.getFirstValidPoint(data);\n if (isNumber(firstPoint)) { // assume all points are numbers\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n // Assume all points are arrays when first point is\n }\n else if (isArray(firstPoint)) {\n if (valueCount) { // [x, low, high] or [x, o, h, l, c]\n if (firstPoint.length === valueCount) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[0];\n yData[i] =\n pt.slice(1, valueCount + 1);\n }\n }\n }\n else { // [x, y]\n if (keys) {\n indexOfX = keys.indexOf('x');\n indexOfY = keys.indexOf('y');\n indexOfX = indexOfX >= 0 ? indexOfX : 0;\n indexOfY = indexOfY >= 0 ? indexOfY : 1;\n }\n if (firstPoint.length === 1) {\n indexOfY = 0;\n }\n if (indexOfX === indexOfY) {\n for (i = 0; i < dataLength; i++) {\n xData[i] = this.autoIncrement();\n yData[i] = data[i][indexOfY];\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = data[i];\n xData[i] = pt[indexOfX];\n yData[i] = pt[indexOfY];\n }\n }\n }\n }\n else {\n // Highcharts expects configs to be numbers or arrays in\n // turbo mode\n error(12, false, chart);\n }\n }\n else {\n for (i = 0; i < dataLength; i++) {\n pt = { series: series };\n series.pointClass.prototype.applyOptions.apply(pt, [data[i]]);\n series.updateParallelArrays(pt, i);\n }\n }\n // Forgetting to cast strings to numbers is a common caveat when\n // handling CSV or JSON\n if (yData && isString(yData[0])) {\n error(14, true, chart);\n }\n series.data = [];\n series.options.data = series.userOptions.data = data;\n // destroy old points\n i = oldDataLength;\n while (i--) {\n (_a = oldData[i]) === null || _a === void 0 ? void 0 : _a.destroy();\n }\n // reset minRange (#878)\n if (xAxis) {\n xAxis.minRange = xAxis.userMinRange;\n }\n // redraw\n series.isDirty = chart.isDirtyBox = true;\n series.isDirtyData = !!oldData;\n animation = false;\n }\n // Typically for pie series, points need to be processed and\n // generated prior to rendering the legend\n if (options.legendType === 'point') {\n this.processData();\n this.generatePoints();\n }\n if (redraw) {\n chart.redraw(animation);\n }\n }\n /**\n * Internal function to sort series data\n *\n * @private\n * @function Highcharts.Series#sortData\n * @param {Array} data\n * Force data grouping.\n */\n sortData(data) {\n const series = this, options = series.options, dataSorting = options.dataSorting, sortKey = dataSorting.sortKey || 'y', getPointOptionsObject = function (series, pointOptions) {\n return (defined(pointOptions) &&\n series.pointClass.prototype.optionsToObject.call({\n series: series\n }, pointOptions)) || {};\n };\n data.forEach(function (pointOptions, i) {\n data[i] = getPointOptionsObject(series, pointOptions);\n data[i].index = i;\n }, this);\n // Sorting\n const sortedData = data.concat().sort((a, b) => {\n const aValue = getNestedProperty(sortKey, a);\n const bValue = getNestedProperty(sortKey, b);\n return bValue < aValue ? -1 : bValue > aValue ? 1 : 0;\n });\n // Set x value depending on the position in the array\n sortedData.forEach(function (point, i) {\n point.x = i;\n }, this);\n // Set the same x for linked series points if they don't have their\n // own sorting\n if (series.linkedSeries) {\n series.linkedSeries.forEach(function (linkedSeries) {\n const options = linkedSeries.options, seriesData = options.data;\n if ((!options.dataSorting ||\n !options.dataSorting.enabled) &&\n seriesData) {\n seriesData.forEach(function (pointOptions, i) {\n seriesData[i] = getPointOptionsObject(linkedSeries, pointOptions);\n if (data[i]) {\n seriesData[i].x = data[i].x;\n seriesData[i].index = i;\n }\n });\n linkedSeries.setData(seriesData, false);\n }\n });\n }\n return data;\n }\n /**\n * Internal function to process the data by cropping away unused data\n * points if the series is longer than the crop threshold. This saves\n * computing time for large series.\n *\n * @private\n * @function Highcharts.Series#getProcessedData\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n getProcessedData(forceExtremesFromAll) {\n const series = this, xAxis = series.xAxis, options = series.options, cropThreshold = options.cropThreshold, getExtremesFromAll = forceExtremesFromAll ||\n series.getExtremesFromAll ||\n options.getExtremesFromAll, // #4599\n logarithmic = xAxis === null || xAxis === void 0 ? void 0 : xAxis.logarithmic, isCartesian = series.isCartesian;\n let croppedData, cropped, cropStart = 0, xExtremes, min, max, \n // copied during slice operation:\n processedXData = series.xData, processedYData = series.yData, updatingNames = false;\n const dataLength = processedXData.length;\n if (xAxis) {\n // corrected for log axis (#3053)\n xExtremes = xAxis.getExtremes();\n min = xExtremes.min;\n max = xExtremes.max;\n updatingNames = !!(xAxis.categories && !xAxis.names.length);\n }\n // optionally filter out points outside the plot area\n if (isCartesian &&\n series.sorted &&\n !getExtremesFromAll &&\n (!cropThreshold ||\n dataLength > cropThreshold ||\n series.forceCrop)) {\n // it's outside current extremes\n if (processedXData[dataLength - 1] < min ||\n processedXData[0] > max) {\n processedXData = [];\n processedYData = [];\n // only crop if it's actually spilling out\n }\n else if (series.yData && (processedXData[0] < min ||\n processedXData[dataLength - 1] > max)) {\n croppedData = this.cropData(series.xData, series.yData, min, max);\n processedXData = croppedData.xData;\n processedYData = croppedData.yData;\n cropStart = croppedData.start;\n cropped = true;\n }\n }\n // Find the closest distance between processed points\n const closestPointRange = getClosestDistance([\n logarithmic ?\n processedXData.map(logarithmic.log2lin) :\n processedXData\n ], \n // Unsorted data is not supported by the line tooltip, as well as\n // data grouping and navigation in Stock charts (#725) and width\n // calculation of columns (#1900). Avoid warning during the\n // premature processing pass in updateNames (#16104).\n () => (series.requireSorting &&\n !updatingNames &&\n error(15, false, series.chart)));\n return {\n xData: processedXData,\n yData: processedYData,\n cropped: cropped,\n cropStart: cropStart,\n closestPointRange: closestPointRange\n };\n }\n /**\n * Internal function to apply processed data.\n * In Highcharts Stock, this function is extended to provide data grouping.\n *\n * @private\n * @function Highcharts.Series#processData\n * @param {boolean} [force]\n * Force data grouping.\n */\n processData(force) {\n const series = this, xAxis = series.xAxis;\n // If the series data or axes haven't changed, don't go through\n // this. Return false to pass the message on to override methods\n // like in data grouping.\n if (series.isCartesian &&\n !series.isDirty &&\n !xAxis.isDirty &&\n !series.yAxis.isDirty &&\n !force) {\n return false;\n }\n const processedData = series.getProcessedData();\n // Record the properties\n series.cropped = processedData.cropped; // undefined or true\n series.cropStart = processedData.cropStart;\n series.processedXData = processedData.xData;\n series.processedYData = processedData.yData;\n series.closestPointRange = (series.basePointRange = processedData.closestPointRange);\n fireEvent(series, 'afterProcessData');\n }\n /**\n * Iterate over xData and crop values between min and max. Returns\n * object containing crop start/end cropped xData with corresponding\n * part of yData, dataMin and dataMax within the cropped range.\n *\n * @private\n * @function Highcharts.Series#cropData\n */\n cropData(xData, yData, min, max, cropShoulder) {\n const dataLength = xData.length;\n let i, j, cropStart = 0, cropEnd = dataLength;\n // line-type series need one point outside\n cropShoulder = pick(cropShoulder, this.cropShoulder);\n // iterate up to find slice start\n for (i = 0; i < dataLength; i++) {\n if (xData[i] >= min) {\n cropStart = Math.max(0, i - cropShoulder);\n break;\n }\n }\n // proceed to find slice end\n for (j = i; j < dataLength; j++) {\n if (xData[j] > max) {\n cropEnd = j + cropShoulder;\n break;\n }\n }\n return {\n xData: xData.slice(cropStart, cropEnd),\n yData: yData.slice(cropStart, cropEnd),\n start: cropStart,\n end: cropEnd\n };\n }\n /**\n * Generate the data point after the data has been processed by cropping\n * away unused points and optionally grouped in Highcharts Stock.\n *\n * @private\n * @function Highcharts.Series#generatePoints\n */\n generatePoints() {\n const series = this, options = series.options, dataOptions = (series.processedData || options.data), processedXData = series.processedXData, processedYData = series.processedYData, PointClass = series.pointClass, processedDataLength = processedXData.length, cropStart = series.cropStart || 0, hasGroupedData = series.hasGroupedData, keys = options.keys, points = [], groupCropStartIndex = (options.dataGrouping &&\n options.dataGrouping.groupAll ?\n cropStart :\n 0);\n let dataLength, cursor, point, i, data = series.data;\n if (!data && !hasGroupedData) {\n const arr = [];\n arr.length = dataOptions.length;\n data = series.data = arr;\n }\n if (keys && hasGroupedData) {\n // grouped data has already applied keys (#6590)\n series.options.keys = false;\n }\n for (i = 0; i < processedDataLength; i++) {\n cursor = cropStart + i;\n if (!hasGroupedData) {\n point = data[cursor];\n // #970:\n if (!point &&\n typeof dataOptions[cursor] !== 'undefined') {\n data[cursor] = point = (new PointClass()).init(series, dataOptions[cursor], processedXData[i]);\n }\n }\n else {\n // splat the y data in case of ohlc data array\n point = (new PointClass()).init(series, [processedXData[i]].concat(splat(processedYData[i])));\n point.dataGroup = series.groupMap[groupCropStartIndex + i];\n if (point.dataGroup.options) {\n point.options = point.dataGroup.options;\n extend(point, point.dataGroup.options);\n // Collision of props and options (#9770)\n delete point.dataLabels;\n }\n }\n if (point) { // #6279\n /**\n * Contains the point's index in the `Series.points` array.\n *\n * @name Highcharts.Point#index\n * @type {number}\n * @readonly\n */\n // For faster access in Point.update\n point.index = hasGroupedData ?\n (groupCropStartIndex + i) : cursor;\n points[i] = point;\n }\n }\n // restore keys options (#6590)\n series.options.keys = keys;\n // Hide cropped-away points - this only runs when the number of\n // points is above cropThreshold, or when swithching view from\n // non-grouped data to grouped data (#637)\n if (data &&\n (processedDataLength !== (dataLength = data.length) ||\n hasGroupedData)) {\n for (i = 0; i < dataLength; i++) {\n // when has grouped data, clear all points\n if (i === cropStart && !hasGroupedData) {\n i += processedDataLength;\n }\n if (data[i]) {\n data[i].destroyElements();\n data[i].plotX = void 0; // #1003\n }\n }\n }\n /**\n * Read only. An array containing those values converted to points.\n * In case the series data length exceeds the `cropThreshold`, or if\n * the data is grouped, `series.data` doesn't contain all the\n * points. Also, in case a series is hidden, the `data` array may be\n * empty. To access raw values, `series.options.data` will always be\n * up to date. `Series.data` only contains the points that have been\n * created on demand. To modify the data, use\n * {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @see Series.points\n *\n * @name Highcharts.Series#data\n * @type {Array}\n */\n series.data = data;\n /**\n * An array containing all currently visible point objects. In case\n * of cropping, the cropped-away points are not part of this array.\n * The `series.points` array starts at `series.cropStart` compared\n * to `series.data` and `series.options.data`. If however the series\n * data is grouped, these can't be correlated one to one. To modify\n * the data, use {@link Highcharts.Series#setData} or\n * {@link Highcharts.Point#update}.\n *\n * @name Highcharts.Series#points\n * @type {Array}\n */\n series.points = points;\n fireEvent(this, 'afterGeneratePoints');\n }\n /**\n * Get current X extremes for the visible data.\n *\n * @private\n * @function Highcharts.Series#getXExtremes\n * @param {Array} xData\n * The data to inspect. Defaults to the current data within the visible\n * range.\n */\n getXExtremes(xData) {\n return {\n min: arrayMin(xData),\n max: arrayMax(xData)\n };\n }\n /**\n * Calculate Y extremes for the visible data. The result is returned\n * as an object with `dataMin` and `dataMax` properties.\n *\n * @private\n * @function Highcharts.Series#getExtremes\n * @param {Array} [yData]\n * The data to inspect. Defaults to the current data within the visible\n * range.\n * @param {boolean} [forceExtremesFromAll]\n * Force getting extremes of a total series data range.\n */\n getExtremes(yData, forceExtremesFromAll) {\n const xAxis = this.xAxis, yAxis = this.yAxis, xData = this.processedXData || this.xData, activeYData = [], \n // Handle X outside the viewed area. This does not work with\n // non-sorted data like scatter (#7639).\n shoulder = this.requireSorting ? this.cropShoulder : 0, positiveValuesOnly = yAxis ? yAxis.positiveValuesOnly : false;\n // #2117, need to compensate for log X axis\n let xExtremes, validValue, withinRange, x, y, i, j, xMin = 0, xMax = 0, activeCounter = 0;\n yData = yData || this.stackedYData || this.processedYData || [];\n const yDataLength = yData.length;\n if (xAxis) {\n xExtremes = xAxis.getExtremes();\n xMin = xExtremes.min;\n xMax = xExtremes.max;\n }\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n // For points within the visible range, including the first\n // point outside the visible range (#7061), consider y extremes.\n validValue = ((isNumber(y) || isArray(y)) &&\n ((y.length || y > 0) || !positiveValuesOnly));\n withinRange = (forceExtremesFromAll ||\n this.getExtremesFromAll ||\n this.options.getExtremesFromAll ||\n this.cropped ||\n !xAxis || // for colorAxis support\n ((xData[i + shoulder] || x) >= xMin &&\n (xData[i - shoulder] || x) <= xMax));\n if (validValue && withinRange) {\n j = y.length;\n if (j) { // array, like ohlc or range data\n while (j--) {\n if (isNumber(y[j])) { // #7380, #11513\n activeYData[activeCounter++] = y[j];\n }\n }\n }\n else {\n activeYData[activeCounter++] = y;\n }\n }\n }\n const dataExtremes = {\n activeYData,\n dataMin: arrayMin(activeYData),\n dataMax: arrayMax(activeYData)\n };\n fireEvent(this, 'afterGetExtremes', { dataExtremes });\n return dataExtremes;\n }\n /**\n * Set the current data extremes as `dataMin` and `dataMax` on the\n * Series item. Use this only when the series properties should be\n * updated.\n *\n * @private\n * @function Highcharts.Series#applyExtremes\n */\n applyExtremes() {\n const dataExtremes = this.getExtremes();\n /**\n * Contains the minimum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMin\n * @type {number|undefined}\n * @readonly\n */\n this.dataMin = dataExtremes.dataMin;\n /**\n * Contains the maximum value of the series' data point. Some series\n * types like `networkgraph` do not support this property as they\n * lack a `y`-value.\n * @name Highcharts.Series#dataMax\n * @type {number|undefined}\n * @readonly\n */\n this.dataMax = dataExtremes.dataMax;\n return dataExtremes;\n }\n /**\n * Find and return the first non null point in the data\n *\n * @private\n * @function Highcharts.Series.getFirstValidPoint\n * @param {Array} data\n * Array of options for points\n */\n getFirstValidPoint(data) {\n const dataLength = data.length;\n let i = 0, firstPoint = null;\n while (firstPoint === null && i < dataLength) {\n firstPoint = data[i];\n i++;\n }\n return firstPoint;\n }\n /**\n * Translate data points from raw data values to chart specific\n * positioning data needed later in the `drawPoints` and `drawGraph`\n * functions. This function can be overridden in plugins and custom\n * series type implementations.\n *\n * @function Highcharts.Series#translate\n *\n * @emits Highcharts.Series#events:translate\n */\n translate() {\n var _a;\n if (!this.processedXData) { // hidden series\n this.processData();\n }\n this.generatePoints();\n const series = this, options = series.options, stacking = options.stacking, xAxis = series.xAxis, categories = xAxis.categories, enabledDataSorting = series.enabledDataSorting, yAxis = series.yAxis, points = series.points, dataLength = points.length, pointPlacement = series.pointPlacementToXValue(), // #7860\n dynamicallyPlaced = Boolean(pointPlacement), threshold = options.threshold, stackThreshold = options.startFromThreshold ? threshold : 0;\n let i, plotX, lastPlotX, stackIndicator, closestPointRangePx = Number.MAX_VALUE;\n /**\n * Plotted coordinates need to be within a limited range. Drawing\n * too far outside the viewport causes various rendering issues\n * (#3201, #3923, #7555).\n * @private\n */\n function limitedRange(val) {\n return clamp(val, -1e5, 1e5);\n }\n // Translate each point\n for (i = 0; i < dataLength; i++) {\n const point = points[i], xValue = point.x;\n let stackItem, stackValues, yValue = point.y, lowValue = point.low;\n const stacks = stacking && ((_a = yAxis.stacking) === null || _a === void 0 ? void 0 : _a.stacks[(series.negStacks &&\n yValue <\n (stackThreshold ? 0 : threshold) ?\n '-' :\n '') + series.stackKey]);\n plotX = xAxis.translate(// #3923\n xValue, false, false, false, true, pointPlacement);\n /**\n * The translated X value for the point in terms of pixels. Relative\n * to the X axis position if the series has one, otherwise relative\n * to the plot area. Depending on the series type this value might\n * not be defined.\n * @name Highcharts.Point#plotX\n * @type {number|undefined}\n */\n point.plotX = isNumber(plotX) ? correctFloat(// #5236\n limitedRange(plotX) // #3923\n ) : void 0;\n // Calculate the bottom y value for stacked series\n if (stacking &&\n series.visible &&\n stacks &&\n stacks[xValue]) {\n stackIndicator = series.getStackIndicator(stackIndicator, xValue, series.index);\n if (!point.isNull && stackIndicator.key) {\n stackItem = stacks[xValue];\n stackValues = stackItem.points[stackIndicator.key];\n }\n if (stackItem && isArray(stackValues)) {\n lowValue = stackValues[0];\n yValue = stackValues[1];\n if (lowValue === stackThreshold &&\n stackIndicator.key === stacks[xValue].base) {\n lowValue = pick(isNumber(threshold) ? threshold : yAxis.min);\n }\n // #1200, #1232\n if (yAxis.positiveValuesOnly &&\n defined(lowValue) &&\n lowValue <= 0) {\n lowValue = void 0;\n }\n point.total = point.stackTotal = pick(stackItem.total);\n point.percentage = defined(point.y) && stackItem.total ?\n (point.y / stackItem.total * 100) : void 0;\n point.stackY = yValue;\n // in case of variwide series (where widths of points are\n // different in most cases), stack labels are positioned\n // wrongly, so the call of the setOffset is omited here and\n // labels are correctly positioned later, at the end of the\n // variwide's translate function (#10962)\n if (!series.irregularWidths) {\n stackItem.setOffset(series.pointXOffset || 0, series.barW || 0, void 0, void 0, void 0, series.xAxis);\n }\n }\n }\n // Set translated yBottom or remove it\n point.yBottom = defined(lowValue) ?\n limitedRange(yAxis.translate(lowValue, false, true, false, true)) :\n void 0;\n // General hook, used for Highcharts Stock compare and cumulative\n if (series.dataModify) {\n yValue = series.dataModify.modifyValue(yValue, i);\n }\n // Set the the plotY value, reset it for redraws #3201, #18422\n let plotY;\n if (isNumber(yValue) && point.plotX !== void 0) {\n plotY = yAxis.translate(yValue, false, true, false, true);\n plotY = isNumber(plotY) ? limitedRange(plotY) : void 0;\n }\n /**\n * The translated Y value for the point in terms of pixels. Relative\n * to the Y axis position if the series has one, otherwise relative\n * to the plot area. Depending on the series type this value might\n * not be defined.\n * @name Highcharts.Point#plotY\n * @type {number|undefined}\n */\n point.plotY = plotY;\n point.isInside = this.isPointInside(point);\n // Set client related positions for mouse tracking\n point.clientX = dynamicallyPlaced ?\n correctFloat(xAxis.translate(xValue, false, false, false, true, pointPlacement)) :\n plotX; // #1514, #5383, #5518\n // Negative points #19028\n point.negative = (point.y || 0) < (threshold || 0);\n // some API data\n point.category = pick(categories && categories[point.x], point.x);\n // Determine auto enabling of markers (#3635, #5099)\n if (!point.isNull && point.visible !== false) {\n if (typeof lastPlotX !== 'undefined') {\n closestPointRangePx = Math.min(closestPointRangePx, Math.abs(plotX - lastPlotX));\n }\n lastPlotX = plotX;\n }\n // Find point zone\n point.zone = this.zones.length ? point.getZone() : void 0;\n // Animate new points with data sorting\n if (!point.graphic && series.group && enabledDataSorting) {\n point.isNew = true;\n }\n }\n series.closestPointRangePx = closestPointRangePx;\n fireEvent(this, 'afterTranslate');\n }\n /**\n * Return the series points with null points filtered out.\n *\n * @function Highcharts.Series#getValidPoints\n *\n * @param {Array} [points]\n * The points to inspect, defaults to {@link Series.points}.\n *\n * @param {boolean} [insideOnly=false]\n * Whether to inspect only the points that are inside the visible view.\n *\n * @param {boolean} [allowNull=false]\n * Whether to allow null points to pass as valid points.\n *\n * @return {Array}\n * The valid points.\n */\n getValidPoints(points, insideOnly, allowNull) {\n const chart = this.chart;\n // #3916, #5029, #5085\n return (points || this.points || []).filter(function (point) {\n const { plotX, plotY } = point, \n // Undefined plotY is treated as null when negative values\n // in log axis (#18422)\n asNull = !allowNull && (point.isNull || !isNumber(plotY));\n if (asNull || (insideOnly && !chart.isInsidePlot(plotX, plotY, { inverted: chart.inverted }))) {\n return false;\n }\n return point.visible !== false;\n });\n }\n /**\n * Get the clipping for the series. Could be called for a series to\n * initiate animating the clip or to set the final clip (only width\n * and x).\n *\n * @private\n * @function Highcharts.Series#getClip\n */\n getClipBox() {\n const { chart, xAxis, yAxis } = this;\n // If no axes on the series, use global clipBox\n const seriesBox = merge(chart.clipBox);\n // Otherwise, use clipBox.width which is corrected for plotBorderWidth\n // and clipOffset\n if (xAxis && xAxis.len !== chart.plotSizeX) {\n seriesBox.width = xAxis.len;\n }\n if (yAxis && yAxis.len !== chart.plotSizeY) {\n seriesBox.height = yAxis.len;\n }\n return seriesBox;\n }\n /**\n * Get the shared clip key, creating it if it doesn't exist.\n *\n * @private\n * @function Highcharts.Series#getSharedClipKey\n */\n getSharedClipKey() {\n this.sharedClipKey = (this.options.xAxis || 0) + ',' +\n (this.options.yAxis || 0);\n return this.sharedClipKey;\n }\n /**\n * Set the clipping for the series. For animated series the clip is later\n * modified.\n *\n * @private\n * @function Highcharts.Series#setClip\n */\n setClip() {\n const { chart, group, markerGroup } = this, sharedClips = chart.sharedClips, renderer = chart.renderer, clipBox = this.getClipBox(), sharedClipKey = this.getSharedClipKey(); // #4526\n let clipRect = sharedClips[sharedClipKey];\n // If a clipping rectangle for the same set of axes does not exist,\n // create it\n if (!clipRect) {\n sharedClips[sharedClipKey] = clipRect = renderer.clipRect(clipBox);\n // When setting chart size, or when the series is rendered again before\n // starting animating, in compliance to a responsive rule\n }\n else {\n clipRect.animate(clipBox);\n }\n if (group) {\n // When clip is false, reset to no clip after animation\n group.clip(this.options.clip === false ? void 0 : clipRect);\n }\n // Unclip temporary animation clip\n if (markerGroup) {\n markerGroup.clip();\n }\n }\n /**\n * Animate in the series. Called internally twice. First with the `init`\n * parameter set to true, which sets up the initial state of the\n * animation. Then when ready, it is called with the `init` parameter\n * undefined, in order to perform the actual animation.\n *\n * @function Highcharts.Series#animate\n *\n * @param {boolean} [init]\n * Initialize the animation.\n */\n animate(init) {\n const { chart, group, markerGroup } = this, inverted = chart.inverted, animation = animObject(this.options.animation), \n // The key for temporary animation clips\n animationClipKey = [\n this.getSharedClipKey(),\n animation.duration,\n animation.easing,\n animation.defer\n ].join(',');\n let animationClipRect = chart.sharedClips[animationClipKey], markerAnimationClipRect = chart.sharedClips[animationClipKey + 'm'];\n // Initialize the animation. Set up the clipping rectangle.\n if (init && group) {\n const clipBox = this.getClipBox();\n // Create temporary animation clips\n if (!animationClipRect) {\n clipBox.width = 0;\n if (inverted) {\n clipBox.x = chart.plotHeight;\n }\n animationClipRect = chart.renderer.clipRect(clipBox);\n chart.sharedClips[animationClipKey] = animationClipRect;\n // The marker clip box. The number 99 is a safe margin to avoid\n // markers being clipped during animation.\n const markerClipBox = {\n x: inverted ? -99 : -99,\n y: inverted ? -99 : -99,\n width: inverted ? chart.plotWidth + 199 : 99,\n height: inverted ? 99 : chart.plotHeight + 199\n };\n markerAnimationClipRect = chart.renderer.clipRect(markerClipBox);\n chart.sharedClips[animationClipKey + 'm'] = markerAnimationClipRect;\n }\n else {\n // When height changes during animation, typically due to\n // responsive settings\n animationClipRect.attr('height', clipBox.height);\n }\n group.clip(animationClipRect);\n if (markerGroup) {\n markerGroup.clip(markerAnimationClipRect);\n }\n // Run the animation\n }\n else if (animationClipRect &&\n // Only first series in this pane\n !animationClipRect.hasClass('highcharts-animating')) {\n const finalBox = this.getClipBox(), step = animation.step;\n // Only do this when there are actually markers\n if (markerGroup && markerGroup.element.childNodes.length) {\n // To provide as smooth animation as possible, update the marker\n // group clipping in steps of the main group animation\n animation.step = function (val, fx) {\n if (step) {\n step.apply(fx, arguments);\n }\n if (fx.prop === 'width' &&\n markerAnimationClipRect &&\n markerAnimationClipRect.element) {\n markerAnimationClipRect.attr(inverted ? 'height' : 'width', val + 99);\n }\n };\n }\n animationClipRect\n .addClass('highcharts-animating')\n .animate(finalBox, animation);\n }\n }\n /**\n * This runs after animation to land on the final plot clipping.\n *\n * @private\n * @function Highcharts.Series#afterAnimate\n *\n * @emits Highcharts.Series#event:afterAnimate\n */\n afterAnimate() {\n this.setClip();\n // Destroy temporary clip rectangles that are no longer in use\n objectEach(this.chart.sharedClips, (clip, key, sharedClips) => {\n if (clip && !this.chart.container.querySelector(`[clip-path=\"url(#${clip.id})\"]`)) {\n clip.destroy();\n delete sharedClips[key];\n }\n });\n this.finishedAnimating = true;\n fireEvent(this, 'afterAnimate');\n }\n /**\n * Draw the markers for line-like series types, and columns or other\n * graphical representation for {@link Point} objects for other series\n * types. The resulting element is typically stored as\n * {@link Point.graphic}, and is created on the first call and updated\n * and moved on subsequent calls.\n *\n * @function Highcharts.Series#drawPoints\n */\n drawPoints(points = this.points) {\n const series = this, chart = series.chart, styledMode = chart.styledMode, { colorAxis, options } = series, seriesMarkerOptions = options.marker, markerGroup = series[series.specialGroup || 'markerGroup'], xAxis = series.xAxis, globallyEnabled = pick(seriesMarkerOptions.enabled, !xAxis || xAxis.isRadial ? true : null, \n // Use larger or equal as radius is null in bubbles (#6321)\n series.closestPointRangePx >= (seriesMarkerOptions.enabledThreshold *\n seriesMarkerOptions.radius));\n let i, point, graphic, verb, pointMarkerOptions, hasPointMarker, markerAttribs;\n if (seriesMarkerOptions.enabled !== false ||\n series._hasPointMarkers) {\n for (i = 0; i < points.length; i++) {\n point = points[i];\n graphic = point.graphic;\n verb = graphic ? 'animate' : 'attr';\n pointMarkerOptions = point.marker || {};\n hasPointMarker = !!point.marker;\n const shouldDrawMarker = ((globallyEnabled &&\n typeof pointMarkerOptions.enabled === 'undefined') || pointMarkerOptions.enabled) && !point.isNull && point.visible !== false;\n // only draw the point if y is defined\n if (shouldDrawMarker) {\n // Shortcuts\n const symbol = pick(pointMarkerOptions.symbol, series.symbol, 'rect');\n markerAttribs = series.markerAttribs(point, (point.selected && 'select'));\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = xAxis.reversed ?\n -(markerAttribs.width || 0) :\n xAxis.width;\n }\n const isInside = point.isInside !== false;\n if (!graphic &&\n isInside &&\n ((markerAttribs.width || 0) > 0 || point.hasImage)) {\n /**\n * SVG graphic representing the point in the chart. In\n * some cases it may be a hidden graphic to improve\n * accessibility.\n *\n * Typically this is a simple shape, like a `rect`\n * for column charts or `path` for line markers, but\n * for some complex series types like boxplot or 3D\n * charts, the graphic may be a `g` element\n * containing other shapes. The graphic is generated\n * the first time {@link Series#drawPoints} runs,\n * and updated and moved on subsequent runs.\n *\n * @see Highcharts.Point#graphics\n *\n * @name Highcharts.Point#graphic\n * @type {Highcharts.SVGElement|undefined}\n */\n point.graphic = graphic = chart.renderer\n .symbol(symbol, markerAttribs.x, markerAttribs.y, markerAttribs.width, markerAttribs.height, hasPointMarker ?\n pointMarkerOptions :\n seriesMarkerOptions)\n .add(markerGroup);\n // Sliding animation for new points\n if (series.enabledDataSorting &&\n chart.hasRendered) {\n graphic.attr({\n x: point.startXPos\n });\n verb = 'animate';\n }\n }\n if (graphic && verb === 'animate') { // update\n // Since the marker group isn't clipped, each\n // individual marker must be toggled\n graphic[isInside ? 'show' : 'hide'](isInside)\n .animate(markerAttribs);\n }\n // Presentational attributes\n if (graphic) {\n const pointAttr = series.pointAttribs(point, ((styledMode || !point.selected) ?\n void 0 :\n 'select'));\n if (!styledMode) {\n graphic[verb](pointAttr);\n }\n else if (colorAxis) { // #14114\n graphic['css']({\n fill: pointAttr.fill\n });\n }\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n }\n }\n }\n /**\n * Get non-presentational attributes for a point. Used internally for\n * both styled mode and classic. Can be overridden for different series\n * types.\n *\n * @see Series#pointAttribs\n *\n * @function Highcharts.Series#markerAttribs\n *\n * @param {Highcharts.Point} point\n * The Point to inspect.\n *\n * @param {string} [state]\n * The state, can be either `hover`, `select` or undefined.\n *\n * @return {Highcharts.SVGAttributes}\n * A hash containing those attributes that are not settable from CSS.\n */\n markerAttribs(point, state) {\n const seriesOptions = this.options, seriesMarkerOptions = seriesOptions.marker, pointMarkerOptions = point.marker || {}, symbol = (pointMarkerOptions.symbol ||\n seriesMarkerOptions.symbol), attribs = {};\n let seriesStateOptions, pointStateOptions, radius = pick(pointMarkerOptions.radius, seriesMarkerOptions && seriesMarkerOptions.radius);\n // Handle hover and select states\n if (state) {\n seriesStateOptions = seriesMarkerOptions.states[state];\n pointStateOptions = pointMarkerOptions.states &&\n pointMarkerOptions.states[state];\n radius = pick(pointStateOptions && pointStateOptions.radius, seriesStateOptions && seriesStateOptions.radius, radius && radius + (seriesStateOptions && seriesStateOptions.radiusPlus ||\n 0));\n }\n point.hasImage = symbol && symbol.indexOf('url') === 0;\n if (point.hasImage) {\n radius = 0; // and subsequently width and height is not set\n }\n const pos = point.pos();\n if (isNumber(radius) && pos) {\n attribs.x = pos[0] - radius;\n attribs.y = pos[1] - radius;\n if (seriesOptions.crisp) {\n // Math.floor for #1843:\n attribs.x = Math.floor(attribs.x);\n }\n }\n if (radius) {\n attribs.width = attribs.height = 2 * radius;\n }\n return attribs;\n }\n /**\n * Internal function to get presentational attributes for each point.\n * Unlike {@link Series#markerAttribs}, this function should return\n * those attributes that can also be set in CSS. In styled mode,\n * `pointAttribs` won't be called.\n *\n * @private\n * @function Highcharts.Series#pointAttribs\n *\n * @param {Highcharts.Point} [point]\n * The point instance to inspect.\n *\n * @param {string} [state]\n * The point state, can be either `hover`, `select` or 'normal'. If\n * undefined, normal state is assumed.\n *\n * @return {Highcharts.SVGAttributes}\n * The presentational attributes to be set on the point.\n */\n pointAttribs(point, state) {\n const seriesMarkerOptions = this.options.marker, pointOptions = point && point.options, pointMarkerOptions = ((pointOptions && pointOptions.marker) || {}), pointColorOption = pointOptions && pointOptions.color, pointColor = point && point.color, zoneColor = point && point.zone && point.zone.color;\n let seriesStateOptions, pointStateOptions, color = this.color, fill, stroke, strokeWidth = pick(pointMarkerOptions.lineWidth, seriesMarkerOptions.lineWidth), opacity = 1;\n color = (pointColorOption ||\n zoneColor ||\n pointColor ||\n color);\n fill = (pointMarkerOptions.fillColor ||\n seriesMarkerOptions.fillColor ||\n color);\n stroke = (pointMarkerOptions.lineColor ||\n seriesMarkerOptions.lineColor ||\n color);\n // Handle hover and select states\n state = state || 'normal';\n if (state) {\n seriesStateOptions = (seriesMarkerOptions.states[state] || {});\n pointStateOptions = (pointMarkerOptions.states &&\n pointMarkerOptions.states[state]) || {};\n strokeWidth = pick(pointStateOptions.lineWidth, seriesStateOptions.lineWidth, strokeWidth + pick(pointStateOptions.lineWidthPlus, seriesStateOptions.lineWidthPlus, 0));\n fill = (pointStateOptions.fillColor ||\n seriesStateOptions.fillColor ||\n fill);\n stroke = (pointStateOptions.lineColor ||\n seriesStateOptions.lineColor ||\n stroke);\n opacity = pick(pointStateOptions.opacity, seriesStateOptions.opacity, opacity);\n }\n return {\n 'stroke': stroke,\n 'stroke-width': strokeWidth,\n 'fill': fill,\n 'opacity': opacity\n };\n }\n /**\n * Clear DOM objects and free up memory.\n *\n * @private\n * @function Highcharts.Series#destroy\n *\n * @emits Highcharts.Series#event:destroy\n */\n destroy(keepEventsForUpdate) {\n const series = this, chart = series.chart, issue134 = /AppleWebKit\\/533/.test(win.navigator.userAgent), data = series.data || [];\n let destroy, i, point, axis;\n // add event hook\n fireEvent(series, 'destroy', { keepEventsForUpdate });\n // remove events\n this.removeEvents(keepEventsForUpdate);\n // erase from axes\n (series.axisTypes || []).forEach(function (AXIS) {\n axis = series[AXIS];\n if (axis && axis.series) {\n erase(axis.series, series);\n axis.isDirty = axis.forceRedraw = true;\n }\n });\n // remove legend items\n if (series.legendItem) {\n series.chart.legend.destroyItem(series);\n }\n // destroy all points with their elements\n i = data.length;\n while (i--) {\n point = data[i];\n if (point && point.destroy) {\n point.destroy();\n }\n }\n if (series.clips) {\n series.clips.forEach((clip) => clip.destroy());\n }\n // Clear the animation timeout if we are destroying the series\n // during initial animation\n U.clearTimeout(series.animationTimeout);\n // Destroy all SVGElements associated to the series\n objectEach(series, function (val, prop) {\n // Survive provides a hook for not destroying\n if (val instanceof SVGElement && !val.survive) {\n // issue 134 workaround\n destroy = issue134 && prop === 'group' ?\n 'hide' :\n 'destroy';\n val[destroy]();\n }\n });\n // remove from hoverSeries\n if (chart.hoverSeries === series) {\n chart.hoverSeries = void 0;\n }\n erase(chart.series, series);\n chart.orderItems('series');\n // clear all members\n objectEach(series, function (val, prop) {\n if (!keepEventsForUpdate || prop !== 'hcEvents') {\n delete series[prop];\n }\n });\n }\n /**\n * Clip the graphs into zones for colors and styling.\n *\n * @private\n * @function Highcharts.Series#applyZones\n */\n applyZones() {\n const series = this, chart = this.chart, renderer = chart.renderer, zones = this.zones, clips = (this.clips || []), graph = this.graph, area = this.area, plotSizeMax = Math.max(chart.plotWidth, chart.plotHeight), axis = this[(this.zoneAxis || 'y') + 'Axis'], inverted = chart.inverted;\n let translatedFrom, translatedTo, clipAttr, extremes, reversed, horiz, pxRange, pxPosMin, pxPosMax, zoneArea, zoneGraph, ignoreZones = false;\n if (zones.length &&\n (graph || area) &&\n axis &&\n typeof axis.min !== 'undefined') {\n reversed = axis.reversed;\n horiz = axis.horiz;\n // The use of the Color Threshold assumes there are no gaps\n // so it is safe to hide the original graph and area\n // unless it is not waterfall series, then use showLine property\n // to set lines between columns to be visible (#7862)\n if (graph && !this.showLine) {\n graph.hide();\n }\n if (area) {\n area.hide();\n }\n // Create the clips\n extremes = axis.getExtremes();\n zones.forEach(function (threshold, i) {\n translatedFrom = reversed ?\n (horiz ? chart.plotWidth : 0) :\n (horiz ? 0 : (axis.toPixels(extremes.min) || 0));\n translatedFrom = clamp(pick(translatedTo, translatedFrom), 0, plotSizeMax);\n translatedTo = clamp(Math.round(axis.toPixels(pick(threshold.value, extremes.max), true) || 0), 0, plotSizeMax);\n if (ignoreZones) {\n translatedFrom = translatedTo =\n axis.toPixels(extremes.max);\n }\n pxRange = Math.abs(translatedFrom - translatedTo);\n pxPosMin = Math.min(translatedFrom, translatedTo);\n pxPosMax = Math.max(translatedFrom, translatedTo);\n if (axis.isXAxis) {\n clipAttr = {\n x: inverted ? pxPosMax : pxPosMin,\n y: 0,\n width: pxRange,\n height: plotSizeMax\n };\n if (!horiz) {\n clipAttr.x = chart.plotHeight - clipAttr.x;\n }\n }\n else {\n clipAttr = {\n x: 0,\n y: inverted ? pxPosMax : pxPosMin,\n width: plotSizeMax,\n height: pxRange\n };\n if (horiz) {\n clipAttr.y = chart.plotWidth - clipAttr.y;\n }\n }\n if (clips[i]) {\n clips[i].animate(clipAttr);\n }\n else {\n clips[i] = renderer.clipRect(clipAttr);\n }\n // when no data, graph zone is not applied and after setData\n // clip was ignored. As a result, it should be applied each\n // time.\n zoneArea = series['zone-area-' + i];\n zoneGraph = series['zone-graph-' + i];\n if (graph && zoneGraph) {\n zoneGraph.clip(clips[i]);\n }\n if (area && zoneArea) {\n zoneArea.clip(clips[i]);\n }\n // if this zone extends out of the axis, ignore the others\n ignoreZones = threshold.value > extremes.max;\n // Clear translatedTo for indicators\n if (series.resetZones && translatedTo === 0) {\n translatedTo = void 0;\n }\n });\n this.clips = clips;\n }\n else if (series.visible) {\n // If zones were removed, restore graph and area\n if (graph) {\n graph.show();\n }\n if (area) {\n area.show();\n }\n }\n }\n /**\n * General abstraction for creating plot groups like series.group,\n * series.dataLabelsGroup and series.markerGroup. On subsequent calls,\n * the group will only be adjusted to the updated plot size.\n *\n * @private\n * @function Highcharts.Series#plotGroup\n */\n plotGroup(prop, name, visibility, zIndex, parent) {\n let group = this[prop];\n const isNew = !group, attrs = {\n visibility,\n zIndex: zIndex || 0.1 // Pointer logic uses this\n };\n // Avoid setting undefined opacity, or in styled mode\n if (typeof this.opacity !== 'undefined' &&\n !this.chart.styledMode && this.state !== 'inactive' // #13719\n ) {\n attrs.opacity = this.opacity;\n }\n // Generate it on first call\n if (isNew) {\n this[prop] = group = this.chart.renderer\n .g()\n .add(parent);\n }\n // Add the class names, and replace existing ones as response to\n // Series.update (#6660)\n group.addClass(('highcharts-' + name +\n ' highcharts-series-' + this.index +\n ' highcharts-' + this.type + '-series ' +\n (defined(this.colorIndex) ?\n 'highcharts-color-' + this.colorIndex + ' ' :\n '') +\n (this.options.className || '') +\n (group.hasClass('highcharts-tracker') ?\n ' highcharts-tracker' :\n '')), true);\n // Place it on first and subsequent (redraw) calls\n group.attr(attrs)[isNew ? 'attr' : 'animate'](this.getPlotBox(name));\n return group;\n }\n /**\n * Get the translation and scale for the plot area of this series.\n *\n * @function Highcharts.Series#getPlotBox\n */\n getPlotBox(name) {\n let horAxis = this.xAxis, vertAxis = this.yAxis;\n const chart = this.chart, inverted = (chart.inverted &&\n !chart.polar &&\n horAxis &&\n this.invertible !== false &&\n name === 'series');\n // Swap axes for inverted (#2339)\n if (chart.inverted) {\n horAxis = vertAxis;\n vertAxis = this.xAxis;\n }\n return {\n translateX: horAxis ? horAxis.left : chart.plotLeft,\n translateY: vertAxis ? vertAxis.top : chart.plotTop,\n rotation: inverted ? 90 : 0,\n rotationOriginX: inverted ?\n (horAxis.len - vertAxis.len) / 2 :\n 0,\n rotationOriginY: inverted ?\n (horAxis.len + vertAxis.len) / 2 :\n 0,\n scaleX: inverted ? -1 : 1,\n scaleY: 1\n };\n }\n /**\n * Removes the event handlers attached previously with addEvents.\n * @private\n * @function Highcharts.Series#removeEvents\n */\n removeEvents(keepEventsForUpdate) {\n const series = this;\n if (!keepEventsForUpdate) {\n // remove all events\n removeEvent(series);\n }\n if (series.eventsToUnbind.length) {\n // remove only internal events for proper update\n // #12355 - solves problem with multiple destroy events\n series.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n series.eventsToUnbind.length = 0;\n }\n }\n /**\n * Render the graph and markers. Called internally when first rendering\n * and later when redrawing the chart. This function can be extended in\n * plugins, but normally shouldn't be called directly.\n *\n * @function Highcharts.Series#render\n *\n * @emits Highcharts.Series#event:afterRender\n */\n render() {\n const series = this, chart = series.chart, options = series.options, animOptions = animObject(options.animation), visibility = series.visible ?\n 'inherit' : 'hidden', // #2597\n zIndex = options.zIndex, hasRendered = series.hasRendered, chartSeriesGroup = chart.seriesGroup, inverted = chart.inverted;\n let animDuration = (!series.finishedAnimating) ?\n animOptions.duration : 0;\n fireEvent(this, 'render');\n // the group\n const group = series.plotGroup('group', 'series', visibility, zIndex, chartSeriesGroup);\n series.markerGroup = series.plotGroup('markerGroup', 'markers', visibility, zIndex, chartSeriesGroup);\n // Initial clipping, applies to columns etc. (#3839).\n if (options.clip !== false) {\n series.setClip();\n }\n // Initialize the animation\n if (series.animate && animDuration) {\n series.animate(true);\n }\n // Draw the graph if any\n if (series.drawGraph) {\n series.drawGraph();\n series.applyZones();\n }\n // Draw the points\n if (series.visible) {\n series.drawPoints();\n }\n // Draw the data labels\n if (series.drawDataLabels) {\n series.drawDataLabels();\n }\n // In pie charts, slices are added to the DOM, but actual rendering\n // is postponed until labels reserved their space\n if (series.redrawPoints) {\n series.redrawPoints();\n }\n // Draw the mouse tracking area\n if (series.drawTracker &&\n options.enableMouseTracking) {\n series.drawTracker();\n }\n // Run the animation\n if (series.animate && animDuration) {\n series.animate();\n }\n // Call the afterAnimate function on animation complete (but don't\n // overwrite the animation.complete option which should be available\n // to the user).\n if (!hasRendered) {\n // Additional time if defer is defined before afterAnimate\n // will be triggered\n if (animDuration && animOptions.defer) {\n animDuration += animOptions.defer;\n }\n series.animationTimeout = syncTimeout(function () {\n series.afterAnimate();\n }, animDuration || 0);\n }\n // Means data is in accordance with what you see\n series.isDirty = false;\n // (See #322) series.isDirty = series.isDirtyData = false; // means\n // data is in accordance with what you see\n series.hasRendered = true;\n fireEvent(series, 'afterRender');\n }\n /**\n * Redraw the series. This function is called internally from\n * `chart.redraw` and normally shouldn't be called directly.\n * @private\n * @function Highcharts.Series#redraw\n */\n redraw() {\n // Cache it here as it is set to false in render, but used after\n const wasDirty = this.isDirty || this.isDirtyData;\n this.translate();\n this.render();\n if (wasDirty) { // #3868, #3945\n delete this.kdTree;\n }\n }\n /**\n * Find the nearest point from a pointer event. This applies to series that\n * use k-d-trees to get the nearest point. Native pointer events must be\n * normalized using `Pointer.normalize`, that adds `chartX` and `chartY`\n * properties.\n *\n * @sample highcharts/demo/synchronized-charts\n * Synchronized charts with tooltips\n *\n * @function Highcharts.Series#searchPoint\n *\n * @param {Highcharts.PointerEvent} e\n * The normalized pointer event\n * @param {boolean} [compareX=false]\n * Search only by the X value, not Y\n *\n * @return {Point|undefined}\n * The closest point to the pointer event\n */\n searchPoint(e, compareX) {\n const series = this, xAxis = series.xAxis, yAxis = series.yAxis, inverted = series.chart.inverted;\n return this.searchKDTree({\n clientX: inverted ?\n xAxis.len - e.chartY + xAxis.pos :\n e.chartX - xAxis.pos,\n plotY: inverted ?\n yAxis.len - e.chartX + yAxis.pos :\n e.chartY - yAxis.pos\n }, compareX, e);\n }\n /**\n * Build the k-d-tree that is used by mouse and touch interaction to get\n * the closest point. Line-like series typically have a one-dimensional\n * tree where points are searched along the X axis, while scatter-like\n * series typically search in two dimensions, X and Y.\n *\n * @private\n * @function Highcharts.Series#buildKDTree\n */\n buildKDTree(e) {\n // Prevent multiple k-d-trees from being built simultaneously\n // (#6235)\n this.buildingKdTree = true;\n const series = this, dimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Internal function\n * @private\n */\n function _kdtree(points, depth, dimensions) {\n const length = points && points.length;\n let axis, median;\n if (length) {\n // alternate between the axis\n axis = series.kdAxisArray[depth % dimensions];\n // sort point array\n points.sort(function (a, b) {\n return a[axis] - b[axis];\n });\n median = Math.floor(length / 2);\n // build and return nod\n return {\n point: points[median],\n left: _kdtree(points.slice(0, median), depth + 1, dimensions),\n right: _kdtree(points.slice(median + 1), depth + 1, dimensions)\n };\n }\n }\n /**\n * Start the recursive build process with a clone of the points\n * array and null points filtered out. (#3873)\n * @private\n */\n function startRecursive() {\n series.kdTree = _kdtree(series.getValidPoints(null, \n // For line-type series restrict to plot area, but\n // column-type series not (#3916, #4511)\n !series.directTouch), dimensions, dimensions);\n series.buildingKdTree = false;\n }\n delete series.kdTree;\n // For testing tooltips, don't build async. Also if touchstart, we\n // may be dealing with click events on mobile, so don't delay\n // (#6817).\n syncTimeout(startRecursive, series.options.kdNow || (e && e.type === 'touchstart') ? 0 : 1);\n }\n /**\n * @private\n * @function Highcharts.Series#searchKDTree\n */\n searchKDTree(point, compareX, e) {\n const series = this, kdX = this.kdAxisArray[0], kdY = this.kdAxisArray[1], kdComparer = compareX ? 'distX' : 'dist', kdDimensions = series.options.findNearestPointBy\n .indexOf('y') > -1 ? 2 : 1;\n /**\n * Set the one and two dimensional distance on the point object.\n * @private\n */\n function setDistance(p1, p2) {\n const x = (defined(p1[kdX]) &&\n defined(p2[kdX])) ?\n Math.pow(p1[kdX] - p2[kdX], 2) :\n null, y = (defined(p1[kdY]) &&\n defined(p2[kdY])) ?\n Math.pow(p1[kdY] - p2[kdY], 2) :\n null, r = (x || 0) + (y || 0);\n p2.dist = defined(r) ? Math.sqrt(r) : Number.MAX_VALUE;\n p2.distX = defined(x) ? Math.sqrt(x) : Number.MAX_VALUE;\n }\n /**\n * @private\n */\n function _search(search, tree, depth, dimensions) {\n const point = tree.point, axis = series.kdAxisArray[depth % dimensions];\n let nPoint1, nPoint2, ret = point;\n setDistance(search, point);\n // Pick side based on distance to splitting point\n const tdist = search[axis] - point[axis], sideA = tdist < 0 ? 'left' : 'right', sideB = tdist < 0 ? 'right' : 'left';\n // End of tree\n if (tree[sideA]) {\n nPoint1 = _search(search, tree[sideA], depth + 1, dimensions);\n ret = (nPoint1[kdComparer] <\n ret[kdComparer] ?\n nPoint1 :\n point);\n }\n if (tree[sideB]) {\n // compare distance to current best to splitting point to\n // decide whether to check side B or not\n if (Math.sqrt(tdist * tdist) < ret[kdComparer]) {\n nPoint2 = _search(search, tree[sideB], depth + 1, dimensions);\n ret = (nPoint2[kdComparer] <\n ret[kdComparer] ?\n nPoint2 :\n ret);\n }\n }\n return ret;\n }\n if (!this.kdTree && !this.buildingKdTree) {\n this.buildKDTree(e);\n }\n if (this.kdTree) {\n return _search(point, this.kdTree, kdDimensions, kdDimensions);\n }\n }\n /**\n * @private\n * @function Highcharts.Series#pointPlacementToXValue\n */\n pointPlacementToXValue() {\n const { options: { pointPlacement, pointRange }, xAxis: axis } = this;\n let factor = pointPlacement;\n // Point placement is relative to each series pointRange (#5889)\n if (factor === 'between') {\n factor = axis.reversed ? -0.5 : 0.5; // #11955\n }\n return isNumber(factor) ?\n factor * (pointRange || axis.pointRange) :\n 0;\n }\n /**\n * @private\n * @function Highcharts.Series#isPointInside\n */\n isPointInside(point) {\n const { chart, xAxis, yAxis } = this, isInside = (typeof point.plotY !== 'undefined' &&\n typeof point.plotX !== 'undefined' &&\n point.plotY >= 0 &&\n point.plotY <= (yAxis ? yAxis.len : chart.plotHeight) &&\n point.plotX >= 0 &&\n point.plotX <= (xAxis ? xAxis.len : chart.plotWidth));\n return isInside;\n }\n /**\n * Draw the tracker object that sits above all data labels and markers to\n * track mouse events on the graph or points. For the line type charts\n * the tracker uses the same graphPath, but with a greater stroke width\n * for better control.\n * @private\n */\n drawTracker() {\n const series = this, options = series.options, trackByArea = options.trackByArea, trackerPath = [].concat(trackByArea ?\n series.areaPath :\n series.graphPath), \n // trackerPathLength = trackerPath.length,\n chart = series.chart, pointer = chart.pointer, renderer = chart.renderer, snap = chart.options.tooltip.snap, tracker = series.tracker, onMouseOver = function (e) {\n if (options.enableMouseTracking &&\n chart.hoverSeries !== series) {\n series.onMouseOver();\n }\n }, \n /*\n * Empirical lowest possible opacities for TRACKER_FILL for an\n * element to stay invisible but clickable\n * IE9: 0.00000000001 (unlimited)\n * IE10: 0.0001 (exporting only)\n * FF: 0.00000000001 (unlimited)\n * Chrome: 0.000001\n * Safari: 0.000001\n * Opera: 0.00000000001 (unlimited)\n */\n TRACKER_FILL = 'rgba(192,192,192,' + (svg ? 0.0001 : 0.002) + ')';\n let i;\n // Draw the tracker\n if (tracker) {\n tracker.attr({ d: trackerPath });\n }\n else if (series.graph) { // create\n series.tracker = renderer.path(trackerPath)\n .attr({\n visibility: series.visible ? 'inherit' : 'hidden',\n zIndex: 2\n })\n .addClass(trackByArea ?\n 'highcharts-tracker-area' :\n 'highcharts-tracker-line')\n .add(series.group);\n if (!chart.styledMode) {\n series.tracker.attr({\n 'stroke-linecap': 'round',\n 'stroke-linejoin': 'round',\n stroke: TRACKER_FILL,\n fill: trackByArea ? TRACKER_FILL : 'none',\n 'stroke-width': series.graph.strokeWidth() +\n (trackByArea ? 0 : 2 * snap)\n });\n }\n // The tracker is added to the series group, which is clipped, but\n // is covered by the marker group. So the marker group also needs to\n // capture events.\n [\n series.tracker,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (tracker) {\n if (tracker) {\n tracker.addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (options.cursor && !chart.styledMode) {\n tracker.css({ cursor: options.cursor });\n }\n if (hasTouch) {\n tracker.on('touchstart', onMouseOver);\n }\n }\n });\n }\n fireEvent(this, 'afterDrawTracker');\n }\n /**\n * Add a point to the series after render time. The point can be added at\n * the end, or by giving it an X value, to the start or in the middle of the\n * series.\n *\n * @sample highcharts/members/series-addpoint-append/\n * Append point\n * @sample highcharts/members/series-addpoint-append-and-shift/\n * Append and shift\n * @sample highcharts/members/series-addpoint-x-and-y/\n * Both X and Y values given\n * @sample highcharts/members/series-addpoint-pie/\n * Append pie slice\n * @sample stock/members/series-addpoint/\n * Append 100 points in Highcharts Stock\n * @sample stock/members/series-addpoint-shift/\n * Append and shift in Highcharts Stock\n * @sample maps/members/series-addpoint/\n * Add a point in Highmaps\n *\n * @function Highcharts.Series#addPoint\n *\n * @param {Highcharts.PointOptionsType} options\n * The point options. If options is a single number, a point with\n * that y value is appended to the series. If it is an array, it will\n * be interpreted as x and y values respectively. If it is an\n * object, advanced options as outlined under `series.data` are\n * applied.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When adding\n * more than one point, it is highly recommended that the redraw\n * option be set to false, and instead {@link Chart#redraw} is\n * explicitly called after the adding of points is finished.\n * Otherwise, the chart will redraw after adding each point.\n *\n * @param {boolean} [shift=false]\n * If true, a point is shifted off the start of the series as one is\n * appended to the end.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `addPoint` event.\n *\n * @emits Highcharts.Series#event:addPoint\n */\n addPoint(options, redraw, shift, animation, withEvent) {\n const series = this, seriesOptions = series.options, data = series.data, chart = series.chart, xAxis = series.xAxis, names = xAxis && xAxis.hasNames && xAxis.names, dataOptions = seriesOptions.data, xData = series.xData;\n let isInTheMiddle, i;\n // Optional redraw, defaults to true\n redraw = pick(redraw, true);\n // Get options and push the point to xData, yData and series.options. In\n // series.generatePoints the Point instance will be created on demand\n // and pushed to the series.data array.\n const point = { series: series };\n series.pointClass.prototype.applyOptions.apply(point, [options]);\n const x = point.x;\n // Get the insertion point\n i = xData.length;\n if (series.requireSorting && x < xData[i - 1]) {\n isInTheMiddle = true;\n while (i && xData[i - 1] > x) {\n i--;\n }\n }\n // Insert undefined item\n series.updateParallelArrays(point, 'splice', [i, 0, 0]);\n // Update it\n series.updateParallelArrays(point, i);\n if (names && point.name) {\n names[x] = point.name;\n }\n dataOptions.splice(i, 0, options);\n if (isInTheMiddle ||\n // When processedData is present we need to splice an empty slot\n // into series.data, otherwise generatePoints won't pick it up.\n series.processedData) {\n series.data.splice(i, 0, null);\n series.processData();\n }\n // Generate points to be added to the legend (#1329)\n if (seriesOptions.legendType === 'point') {\n series.generatePoints();\n }\n // Shift the first point off the parallel arrays\n if (shift) {\n if (data[0] && (data[0].remove)) {\n data[0].remove(false);\n }\n else {\n data.shift();\n series.updateParallelArrays(point, 'shift');\n dataOptions.shift();\n }\n }\n // Fire event\n if (withEvent !== false) {\n fireEvent(series, 'addPoint', { point: point });\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw(animation); // Animation is set anyway on redraw, #5665\n }\n }\n /**\n * Remove a point from the series. Unlike the\n * {@link Highcharts.Point#remove} method, this can also be done on a point\n * that is not instanciated because it is outside the view or subject to\n * Highcharts Stock data grouping.\n *\n * @sample highcharts/members/series-removepoint/\n * Remove cropped point\n *\n * @function Highcharts.Series#removePoint\n *\n * @param {number} i\n * The index of the point in the {@link Highcharts.Series.data|data}\n * array.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the point is added. When\n * removing more than one point, it is highly recommended that the\n * `redraw` option be set to `false`, and instead {@link\n * Highcharts.Chart#redraw} is explicitly called after the adding of\n * points is finished.\n *\n * @param {boolean|Partial} [animation]\n * Whether and optionally how the series should be animated.\n *\n * @emits Highcharts.Point#event:remove\n */\n removePoint(i, redraw, animation) {\n const series = this, data = series.data, point = data[i], points = series.points, chart = series.chart, remove = function () {\n if (points && points.length === data.length) { // #4935\n points.splice(i, 1);\n }\n data.splice(i, 1);\n series.options.data.splice(i, 1);\n series.updateParallelArrays(point || { series: series }, 'splice', [i, 1]);\n if (point) {\n point.destroy();\n }\n // redraw\n series.isDirty = true;\n series.isDirtyData = true;\n if (redraw) {\n chart.redraw();\n }\n };\n setAnimation(animation, chart);\n redraw = pick(redraw, true);\n // Fire the event with a default handler of removing the point\n if (point) {\n point.firePointEvent('remove', null, remove);\n }\n else {\n remove();\n }\n }\n /**\n * Remove a series and optionally redraw the chart.\n *\n * @sample highcharts/members/series-remove/\n * Remove first series from a button\n *\n * @function Highcharts.Series#remove\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for an explicit call to\n * {@link Highcharts.Chart#redraw}.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration.\n *\n * @param {boolean} [withEvent=true]\n * Used internally, whether to fire the series `remove` event.\n *\n * @emits Highcharts.Series#event:remove\n */\n remove(redraw, animation, withEvent, keepEvents) {\n const series = this, chart = series.chart;\n /**\n * @private\n */\n function remove() {\n // Destroy elements\n series.destroy(keepEvents);\n // Redraw\n chart.isDirtyLegend = chart.isDirtyBox = true;\n chart.linkSeries(keepEvents);\n if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n }\n // Fire the event with a default handler of removing the point\n if (withEvent !== false) {\n fireEvent(series, 'remove', null, remove);\n }\n else {\n remove();\n }\n }\n /**\n * Update the series with a new set of options. For a clean and precise\n * handling of new options, all methods and elements from the series are\n * removed, and it is initialized from scratch. Therefore, this method is\n * more performance expensive than some other utility methods like {@link\n * Series#setData} or {@link Series#setVisible}.\n *\n * Note that `Series.update` may mutate the passed `data` options.\n *\n * @sample highcharts/members/series-update/\n * Updating series options\n * @sample maps/members/series-update/\n * Update series options in Highmaps\n *\n * @function Highcharts.Series#update\n *\n * @param {Highcharts.SeriesOptionsType} options\n * New options that will be merged with the series' existing options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to\n * false and call {@link Chart#redraw} after.\n *\n * @emits Highcharts.Series#event:update\n * @emits Highcharts.Series#event:afterUpdate\n */\n update(options, redraw) {\n options = diffObjects(options, this.userOptions);\n fireEvent(this, 'update', { options: options });\n const series = this, chart = series.chart, \n // must use user options when changing type because series.options\n // is merged in with type specific plotOptions\n oldOptions = series.userOptions, initialType = series.initialType || series.type, plotOptions = chart.options.plotOptions, initialSeriesProto = seriesTypes[initialType].prototype, groups = [\n 'group',\n 'markerGroup',\n 'dataLabelsGroup',\n 'transformGroup'\n ], \n // Animation must be enabled when calling update before the initial\n // animation has first run. This happens when calling update\n // directly after chart initialization, or when applying responsive\n // rules (#6912).\n animation = series.finishedAnimating && { animation: false }, kinds = {};\n let seriesOptions, n, preserve = [\n 'colorIndex',\n 'eventOptions',\n 'navigatorSeries',\n 'symbolIndex',\n 'baseSeries'\n ], newType = (options.type ||\n oldOptions.type ||\n chart.options.chart.type);\n const keepPoints = !(\n // Indicators, histograms etc recalculate the data. It should be\n // possible to omit this.\n this.hasDerivedData ||\n // New type requires new point classes\n (newType && newType !== this.type) ||\n // New options affecting how the data points are built\n typeof options.pointStart !== 'undefined' ||\n typeof options.pointInterval !== 'undefined' ||\n typeof options.relativeXValue !== 'undefined' ||\n options.joinBy ||\n options.mapData || // #11636\n // Changes to data grouping requires new points in new group\n series.hasOptionChanged('dataGrouping') ||\n series.hasOptionChanged('pointStart') ||\n series.hasOptionChanged('pointInterval') ||\n series.hasOptionChanged('pointIntervalUnit') ||\n series.hasOptionChanged('keys'));\n newType = newType || initialType;\n if (keepPoints) {\n preserve.push('data', 'isDirtyData', 'points', 'processedData', // #17057\n 'processedXData', 'processedYData', 'xIncrement', 'cropped', '_hasPointMarkers', '_hasPointLabels', 'clips', // #15420\n // Networkgraph (#14397)\n 'nodes', 'layout', \n // Treemap\n 'level', \n // Map specific, consider moving it to series-specific preserve-\n // properties (#10617)\n 'mapMap', 'mapData', 'minY', 'maxY', 'minX', 'maxX');\n if (options.visible !== false) {\n preserve.push('area', 'graph');\n }\n series.parallelArrays.forEach(function (key) {\n preserve.push(key + 'Data');\n });\n if (options.data) {\n // setData uses dataSorting options so we need to update them\n // earlier\n if (options.dataSorting) {\n extend(series.options.dataSorting, options.dataSorting);\n }\n this.setData(options.data, false);\n }\n }\n // Do the merge, with some forced options\n options = merge(oldOptions, animation, {\n // When oldOptions.index is null it should't be cleared.\n // Otherwise navigator series will have wrong indexes (#10193).\n index: typeof oldOptions.index === 'undefined' ?\n series.index : oldOptions.index,\n pointStart: pick(\n // when updating from blank (#7933)\n (plotOptions &&\n plotOptions.series &&\n plotOptions.series.pointStart), oldOptions.pointStart, \n // when updating after addPoint\n series.xData[0])\n }, (!keepPoints && { data: series.options.data }), options);\n // Merge does not merge arrays, but replaces them. Since points were\n // updated, `series.options.data` has correct merged options, use it:\n if (keepPoints && options.data) {\n options.data = series.options.data;\n }\n // Make sure preserved properties are not destroyed (#3094)\n preserve = groups.concat(preserve);\n preserve.forEach(function (prop) {\n preserve[prop] = series[prop];\n delete series[prop];\n });\n let casting = false;\n if (seriesTypes[newType]) {\n casting = newType !== series.type;\n // Destroy the series and delete all properties, it will be\n // reinserted within the `init` call below\n series.remove(false, false, false, true);\n if (casting) {\n // Modern browsers including IE11\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(series, seriesTypes[newType].prototype);\n // Legacy (IE < 11)\n }\n else {\n const ownEvents = Object.hasOwnProperty.call(series, 'hcEvents') && series.hcEvents;\n for (n in initialSeriesProto) { // eslint-disable-line guard-for-in\n series[n] = void 0;\n }\n // Reinsert all methods and properties from the new type\n // prototype (#2270, #3719).\n extend(series, seriesTypes[newType].prototype);\n // The events are tied to the prototype chain, don't copy if\n // they're not the series' own\n if (ownEvents) {\n series.hcEvents = ownEvents;\n }\n else {\n delete series.hcEvents;\n }\n }\n }\n }\n else {\n error(17, true, chart, { missingModuleFor: newType });\n }\n // Re-register groups (#3094) and other preserved properties\n preserve.forEach(function (prop) {\n series[prop] = preserve[prop];\n });\n series.init(chart, options);\n // Remove particular elements of the points. Check `series.options`\n // because we need to consider the options being set on plotOptions as\n // well.\n if (keepPoints && this.points) {\n seriesOptions = series.options;\n // What kind of elements to destroy\n if (seriesOptions.visible === false) {\n kinds.graphic = 1;\n kinds.dataLabel = 1;\n }\n else if (!series._hasPointLabels) {\n const { marker, dataLabels } = seriesOptions, oldMarker = oldOptions.marker || {};\n // If the marker got disabled or changed its symbol, width or\n // height - destroy\n if (marker && (marker.enabled === false ||\n oldMarker.symbol !== marker.symbol || // #10870, #15946\n oldMarker.height !== marker.height || // #16274\n oldMarker.width !== marker.width // #16274\n )) {\n kinds.graphic = 1;\n }\n if (dataLabels &&\n dataLabels.enabled === false) {\n kinds.dataLabel = 1;\n }\n }\n for (const point of this.points) {\n if (point && point.series) {\n point.resolveColor();\n // Destroy elements in order to recreate based on updated\n // series options.\n if (Object.keys(kinds).length) {\n point.destroyElements(kinds);\n }\n if (seriesOptions.showInLegend === false &&\n point.legendItem) {\n chart.legend.destroyItem(point);\n }\n }\n }\n }\n series.initialType = initialType;\n chart.linkSeries(); // Links are lost in series.remove (#3028)\n // #15383: Fire updatedData if the type has changed to keep linked\n // series such as indicators updated\n if (casting && series.linkedSeries.length) {\n series.isDirtyData = true;\n }\n fireEvent(this, 'afterUpdate');\n if (pick(redraw, true)) {\n chart.redraw(keepPoints ? void 0 : false);\n }\n }\n /**\n * Used from within series.update\n * @private\n */\n setName(name) {\n this.name = this.options.name = this.userOptions.name = name;\n this.chart.isDirtyLegend = true;\n }\n /**\n * Check if the option has changed.\n * @private\n */\n hasOptionChanged(optionName) {\n const chart = this.chart, option = this.options[optionName], plotOptions = chart.options.plotOptions, oldOption = this.userOptions[optionName];\n if (oldOption) {\n return option !== oldOption;\n }\n return option !==\n pick(plotOptions &&\n plotOptions[this.type] &&\n plotOptions[this.type][optionName], plotOptions &&\n plotOptions.series &&\n plotOptions.series[optionName], option);\n }\n /**\n * Runs on mouse over the series graphical items.\n *\n * @function Highcharts.Series#onMouseOver\n * @emits Highcharts.Series#event:mouseOver\n */\n onMouseOver() {\n const series = this, chart = series.chart, hoverSeries = chart.hoverSeries, pointer = chart.pointer;\n pointer.setHoverChartIndex();\n // set normal state to previous series\n if (hoverSeries && hoverSeries !== series) {\n hoverSeries.onMouseOut();\n }\n // trigger the event, but to save processing time,\n // only if defined\n if (series.options.events.mouseOver) {\n fireEvent(series, 'mouseOver');\n }\n // hover this\n series.setState('hover');\n /**\n * Contains the original hovered series.\n *\n * @name Highcharts.Chart#hoverSeries\n * @type {Highcharts.Series|null}\n */\n chart.hoverSeries = series;\n }\n /**\n * Runs on mouse out of the series graphical items.\n *\n * @function Highcharts.Series#onMouseOut\n *\n * @emits Highcharts.Series#event:mouseOut\n */\n onMouseOut() {\n // trigger the event only if listeners exist\n const series = this, options = series.options, chart = series.chart, tooltip = chart.tooltip, hoverPoint = chart.hoverPoint;\n // #182, set to null before the mouseOut event fires\n chart.hoverSeries = null;\n // trigger mouse out on the point, which must be in this series\n if (hoverPoint) {\n hoverPoint.onMouseOut();\n }\n // fire the mouse out event\n if (series && options.events.mouseOut) {\n fireEvent(series, 'mouseOut');\n }\n // hide the tooltip\n if (tooltip &&\n !series.stickyTracking &&\n (!tooltip.shared || series.noSharedTooltip)) {\n tooltip.hide();\n }\n // Reset all inactive states\n chart.series.forEach(function (s) {\n s.setState('', true);\n });\n }\n /**\n * Set the state of the series. Called internally on mouse interaction\n * operations, but it can also be called directly to visually\n * highlight a series.\n *\n * @function Highcharts.Series#setState\n *\n * @param {Highcharts.SeriesStateValue|\"\"} [state]\n * The new state, can be either `'hover'`, `'inactive'`, `'select'`,\n * or `''` (an empty string), `'normal'` or `undefined` to set to\n * normal state.\n * @param {boolean} [inherit]\n * Determines if state should be inherited by points too.\n */\n setState(state, inherit) {\n const series = this, options = series.options, graph = series.graph, inactiveOtherPoints = options.inactiveOtherPoints, stateOptions = options.states, \n // By default a quick animation to hover/inactive,\n // slower to un-hover\n stateAnimation = pick((stateOptions[state || 'normal'] &&\n stateOptions[state || 'normal'].animation), series.chart.options.chart.animation);\n let attribs, lineWidth = options.lineWidth, i = 0, opacity = options.opacity;\n state = state || '';\n if (series.state !== state) {\n // Toggle class names\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup\n ].forEach(function (group) {\n if (group) {\n // Old state\n if (series.state) {\n group.removeClass('highcharts-series-' + series.state);\n }\n // New state\n if (state) {\n group.addClass('highcharts-series-' + state);\n }\n }\n });\n series.state = state;\n if (!series.chart.styledMode) {\n if (stateOptions[state] &&\n stateOptions[state].enabled === false) {\n return;\n }\n if (state) {\n lineWidth = (stateOptions[state].lineWidth ||\n lineWidth + (stateOptions[state].lineWidthPlus || 0)); // #4035\n opacity = pick(stateOptions[state].opacity, opacity);\n }\n if (graph && !graph.dashstyle && isNumber(lineWidth)) {\n attribs = {\n 'stroke-width': lineWidth\n };\n // Animate the graph stroke-width.\n graph.animate(attribs, stateAnimation);\n while (series['zone-graph-' + i]) {\n series['zone-graph-' + i].animate(attribs, stateAnimation);\n i = i + 1;\n }\n }\n // For some types (pie, networkgraph, sankey) opacity is\n // resolved on a point level\n if (!inactiveOtherPoints) {\n [\n series.group,\n series.markerGroup,\n series.dataLabelsGroup,\n series.labelBySeries\n ].forEach(function (group) {\n if (group) {\n group.animate({\n opacity: opacity\n }, stateAnimation);\n }\n });\n }\n }\n }\n // Don't loop over points on a series that doesn't apply inactive state\n // to siblings markers (e.g. line, column)\n if (inherit && inactiveOtherPoints && series.points) {\n series.setAllPointsToState(state || void 0);\n }\n }\n /**\n * Set the state for all points in the series.\n *\n * @function Highcharts.Series#setAllPointsToState\n *\n * @private\n *\n * @param {string} [state]\n * Can be either `hover` or undefined to set to normal state.\n */\n setAllPointsToState(state) {\n this.points.forEach(function (point) {\n if (point.setState) {\n point.setState(state);\n }\n });\n }\n /**\n * Show or hide the series.\n *\n * @function Highcharts.Series#setVisible\n *\n * @param {boolean} [visible]\n * True to show the series, false to hide. If undefined, the visibility is\n * toggled.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the series is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw|chart.redraw()} after.\n *\n * @emits Highcharts.Series#event:hide\n * @emits Highcharts.Series#event:show\n */\n setVisible(vis, redraw) {\n const series = this, chart = series.chart, ignoreHiddenSeries = chart.options.chart.ignoreHiddenSeries, oldVisibility = series.visible;\n // if called without an argument, toggle visibility\n series.visible =\n vis =\n series.options.visible =\n series.userOptions.visible =\n typeof vis === 'undefined' ? !oldVisibility : vis; // #5618\n const showOrHide = vis ? 'show' : 'hide';\n // show or hide elements\n [\n 'group',\n 'dataLabelsGroup',\n 'markerGroup',\n 'tracker',\n 'tt'\n ].forEach(function (key) {\n if (series[key]) {\n series[key][showOrHide]();\n }\n });\n // hide tooltip (#1361)\n if (chart.hoverSeries === series ||\n (chart.hoverPoint && chart.hoverPoint.series) === series) {\n series.onMouseOut();\n }\n if (series.legendItem) {\n chart.legend.colorizeItem(series, vis);\n }\n // rescale or adapt to resized chart\n series.isDirty = true;\n // in a stack, all other series are affected\n if (series.options.stacking) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.options.stacking && otherSeries.visible) {\n otherSeries.isDirty = true;\n }\n });\n }\n // show or hide linked series\n series.linkedSeries.forEach(function (otherSeries) {\n otherSeries.setVisible(vis, false);\n });\n if (ignoreHiddenSeries) {\n chart.isDirtyBox = true;\n }\n fireEvent(series, showOrHide);\n if (redraw !== false) {\n chart.redraw();\n }\n }\n /**\n * Show the series if hidden.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#show\n * @emits Highcharts.Series#event:show\n */\n show() {\n this.setVisible(true);\n }\n /**\n * Hide the series if visible. If the\n * [chart.ignoreHiddenSeries](https://api.highcharts.com/highcharts/chart.ignoreHiddenSeries)\n * option is true, the chart is redrawn without this series.\n *\n * @sample highcharts/members/series-hide/\n * Toggle visibility from a button\n *\n * @function Highcharts.Series#hide\n * @emits Highcharts.Series#event:hide\n */\n hide() {\n this.setVisible(false);\n }\n /**\n * Select or unselect the series. This means its\n * {@link Highcharts.Series.selected|selected}\n * property is set, the checkbox in the legend is toggled and when selected,\n * the series is returned by the {@link Highcharts.Chart#getSelectedSeries}\n * function.\n *\n * @sample highcharts/members/series-select/\n * Select a series from a button\n *\n * @function Highcharts.Series#select\n *\n * @param {boolean} [selected]\n * True to select the series, false to unselect. If undefined, the selection\n * state is toggled.\n *\n * @emits Highcharts.Series#event:select\n * @emits Highcharts.Series#event:unselect\n */\n select(selected) {\n const series = this;\n series.selected =\n selected =\n this.options.selected = (typeof selected === 'undefined' ?\n !series.selected :\n selected);\n if (series.checkbox) {\n series.checkbox.checked = selected;\n }\n fireEvent(series, selected ? 'select' : 'unselect');\n }\n /**\n * Checks if a tooltip should be shown for a given point.\n *\n * @private\n */\n shouldShowTooltip(plotX, plotY, options = {}) {\n options.series = this;\n options.visiblePlotOnly = true;\n return this.chart.isInsidePlot(plotX, plotY, options);\n }\n /**\n * Draws the legend symbol based on the legendSymbol user option.\n *\n * @private\n */\n drawLegendSymbol(legend, item) {\n var _a;\n (_a = LegendSymbol[this.options.legendSymbol || 'rectangle']) === null || _a === void 0 ? void 0 : _a.call(this, legend, item);\n }\n }\n Series.defaultOptions = SeriesDefaults;\n /**\n * Registry of all available series types.\n *\n * @name Highcharts.Series.types\n * @type {Highcharts.Dictionary}\n */\n Series.types = SeriesRegistry.seriesTypes;\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Registers a series class to be accessible via `Series.types`.\n *\n * @function Highcharts.Series.registerType\n *\n * @param {string} seriesType\n * The series type as an identifier string in lower case.\n *\n * @param {Function} SeriesClass\n * The series class as a class pattern or a constructor function with\n * prototype.\n */\n Series.registerType = SeriesRegistry.registerSeriesType;\n extend(Series.prototype, {\n axisTypes: ['xAxis', 'yAxis'],\n coll: 'series',\n colorCounter: 0,\n cropShoulder: 1,\n directTouch: false,\n isCartesian: true,\n kdAxisArray: ['clientX', 'plotY'],\n // each point's x and y values are stored in this.xData and this.yData:\n parallelArrays: ['x', 'y'],\n pointClass: Point,\n requireSorting: true,\n // requires the data to be sorted:\n sorted: true\n });\n /* *\n *\n * Registry\n *\n * */\n SeriesRegistry.series = Series;\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * This is a placeholder type of the possible series options for\n * [Highcharts](../highcharts/series), [Highcharts Stock](../highstock/series),\n * [Highmaps](../highmaps/series), and [Gantt](../gantt/series).\n *\n * In TypeScript is this dynamically generated to reference all possible types\n * of series options.\n *\n * @ignore-declaration\n * @typedef {Highcharts.SeriesOptions|Highcharts.Dictionary<*>} Highcharts.SeriesOptionsType\n */\n /**\n * Options for `dataSorting`.\n *\n * @interface Highcharts.DataSortingOptionsObject\n * @since 8.0.0\n */ /**\n * Enable or disable data sorting for the series.\n * @name Highcharts.DataSortingOptionsObject#enabled\n * @type {boolean|undefined}\n */ /**\n * Whether to allow matching points by name in an update.\n * @name Highcharts.DataSortingOptionsObject#matchByName\n * @type {boolean|undefined}\n */ /**\n * Determines what data value should be used to sort by.\n * @name Highcharts.DataSortingOptionsObject#sortKey\n * @type {string|undefined}\n */\n /**\n * Function callback when a series has been animated.\n *\n * @callback Highcharts.SeriesAfterAnimateCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesAfterAnimateEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding completed animation of a series.\n *\n * @interface Highcharts.SeriesAfterAnimateEventObject\n */ /**\n * Animated series.\n * @name Highcharts.SeriesAfterAnimateEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesAfterAnimateEventObject#type\n * @type {\"afterAnimate\"}\n */\n /**\n * Function callback when the checkbox next to the series' name in the legend is\n * clicked.\n *\n * @callback Highcharts.SeriesCheckboxClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesCheckboxClickEventObject} event\n * Event arguments.\n */\n /**\n * Event information regarding check of a series box.\n *\n * @interface Highcharts.SeriesCheckboxClickEventObject\n */ /**\n * Whether the box has been checked.\n * @name Highcharts.SeriesCheckboxClickEventObject#checked\n * @type {boolean}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#item\n * @type {Highcharts.Series}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Function callback when a series is clicked. Return false to cancel toogle\n * actions.\n *\n * @callback Highcharts.SeriesClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesClickEventObject} event\n * Event arguments.\n */\n /**\n * Common information for a click event on a series.\n *\n * @interface Highcharts.SeriesClickEventObject\n * @extends global.Event\n */ /**\n * Nearest point on the graph.\n * @name Highcharts.SeriesClickEventObject#point\n * @type {Highcharts.Point}\n */\n /**\n * Gets fired when the series is hidden after chart generation time, either by\n * clicking the legend item or by calling `.hide()`.\n *\n * @callback Highcharts.SeriesHideCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin` of a line\n * graph.\n *\n * @typedef {\"butt\"|\"round\"|\"square\"|string} Highcharts.SeriesLinecapValue\n */\n /**\n * Gets fired when the legend item belonging to the series is clicked. The\n * default action is to toggle the visibility of the series. This can be\n * prevented by returning `false` or calling `event.preventDefault()`.\n *\n * @callback Highcharts.SeriesLegendItemClickCallbackFunction\n *\n * @param {Highcharts.Series} this\n * The series where the event occured.\n *\n * @param {Highcharts.SeriesLegendItemClickEventObject} event\n * The event that occured.\n */\n /**\n * Information about the event.\n *\n * @interface Highcharts.SeriesLegendItemClickEventObject\n */ /**\n * Related browser event.\n * @name Highcharts.SeriesLegendItemClickEventObject#browserEvent\n * @type {global.PointerEvent}\n */ /**\n * Prevent the default action of toggle the visibility of the series.\n * @name Highcharts.SeriesLegendItemClickEventObject#preventDefault\n * @type {Function}\n */ /**\n * Related series.\n * @name Highcharts.SeriesCheckboxClickEventObject#target\n * @type {Highcharts.Series}\n */ /**\n * Event type.\n * @name Highcharts.SeriesCheckboxClickEventObject#type\n * @type {\"checkboxClick\"}\n */\n /**\n * Gets fired when the mouse leaves the graph.\n *\n * @callback Highcharts.SeriesMouseOutCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Gets fired when the mouse enters the graph.\n *\n * @callback Highcharts.SeriesMouseOverCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.PointerEvent} event\n * Event that occured.\n */\n /**\n * Translation and scale for the plot area of a series.\n *\n * @interface Highcharts.SeriesPlotBoxObject\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#scaleY\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateX\n * @type {number}\n */ /**\n * @name Highcharts.SeriesPlotBoxObject#translateY\n * @type {number}\n */\n /**\n * Gets fired when the series is shown after chart generation time, either by\n * clicking the legend item or by calling `.show()`.\n *\n * @callback Highcharts.SeriesShowCallbackFunction\n *\n * @param {Highcharts.Series} this\n * Series where the event occured.\n *\n * @param {global.Event} event\n * Event that occured.\n */\n /**\n * Possible key values for the series state options.\n *\n * @typedef {\"hover\"|\"inactive\"|\"normal\"|\"select\"} Highcharts.SeriesStateValue\n */\n ''; // detach doclets above\n /* *\n *\n * API Options\n *\n * */\n /**\n * Series options for specific data and the data itself. In TypeScript you\n * have to cast the series options to specific series types, to get all\n * possible options for a series.\n *\n * @example\n * // TypeScript example\n * Highcharts.chart('container', {\n * series: [{\n * color: '#06C',\n * data: [[0, 1], [2, 3]]\n * } as Highcharts.SeriesLineOptions ]\n * });\n *\n * @type {Array<*>}\n * @apioption series\n */\n /**\n * An id for the series. This can be used after render time to get a pointer\n * to the series object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @type {string}\n * @since 1.2.0\n * @apioption series.id\n */\n /**\n * The index of the series in the chart, affecting the internal index in the\n * `chart.series` array, the visible Z index as well as the order in the\n * legend.\n *\n * @type {number}\n * @since 2.3.0\n * @apioption series.index\n */\n /**\n * The sequential index of the series in the legend.\n *\n * @see [legend.reversed](#legend.reversed),\n * [yAxis.reversedStacks](#yAxis.reversedStacks)\n *\n * @sample {highcharts|highstock} highcharts/series/legendindex/\n * Legend in opposite order\n *\n * @type {number}\n * @apioption series.legendIndex\n */\n /**\n * The name of the series as shown in the legend, tooltip etc.\n *\n * @sample {highcharts} highcharts/series/name/\n * Series name\n * @sample {highmaps} maps/demo/category-map/\n * Series name\n *\n * @type {string}\n * @apioption series.name\n */\n /**\n * This option allows grouping series in a stacked chart. The stack option\n * can be a string or anything else, as long as the grouped series' stack\n * options match each other after conversion into a string.\n *\n * @sample {highcharts} highcharts/series/stack/\n * Stacked and grouped columns\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highstock\n * @apioption series.stack\n */\n /**\n * The type of series, for example `line` or `column`. By default, the\n * series type is inherited from [chart.type](#chart.type), so unless the\n * chart is a combination of series types, there is no need to set it on the\n * series level.\n *\n * @sample {highcharts} highcharts/series/type/\n * Line and column in the same chart\n * @sample highcharts/series/type-dynamic/\n * Dynamic types with button selector\n * @sample {highmaps} maps/demo/mapline-mappoint/\n * Multiple types in the same map\n *\n * @type {string}\n * @apioption series.type\n */\n /**\n * When using dual or multiple x axes, this number defines which xAxis the\n * particular series is connected to. It refers to either the\n * {@link #xAxis.id|axis id}\n * or the index of the axis in the xAxis array, with 0 being the first.\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.xAxis\n */\n /**\n * When using dual or multiple y axes, this number defines which yAxis the\n * particular series is connected to. It refers to either the\n * {@link #yAxis.id|axis id}\n * or the index of the axis in the yAxis array, with 0 being the first.\n *\n * @sample {highcharts} highcharts/series/yaxis/\n * Apply the column series to the secondary Y axis\n *\n * @type {number|string}\n * @default 0\n * @product highcharts highstock\n * @apioption series.yAxis\n */\n /**\n * Define the visual z index of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highcharts} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n * @sample {highstock} highcharts/plotoptions/series-zindex-default/\n * With no z index, the series defined last are on top\n * @sample {highstock} highcharts/plotoptions/series-zindex/\n * With a z index, the series with the highest z index is on top\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.zIndex\n */\n ''; // include precedent doclets in transpilat\n\n return Series;\n });\n _registerModule(_modules, 'Core/Chart/Chart.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Templating.js'], _modules['Core/Foundation.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Time.js'], _modules['Core/Utilities.js'], _modules['Core/Renderer/HTML/AST.js']], function (A, Axis, D, Templating, Foundation, H, RendererRegistry, Series, SeriesRegistry, SVGRenderer, Time, U, AST) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animate, animObject, setAnimation } = A;\n const { defaultOptions, defaultTime } = D;\n const { numberFormat } = Templating;\n const { registerEventOptions } = Foundation;\n const { charts, doc, marginNames, svg, win } = H;\n const { seriesTypes } = SeriesRegistry;\n const { addEvent, attr, createElement, css, defined, diffObjects, discardElement, erase, error, extend, find, fireEvent, getStyle, isArray, isNumber, isObject, isString, merge, objectEach, pick, pInt, relativeLength, removeEvent, splat, syncTimeout, uniqueKey } = U;\n /* *\n *\n * Class\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * The Chart class. The recommended constructor is {@link Highcharts#chart}.\n *\n * @example\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * })\n *\n * @class\n * @name Highcharts.Chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images\n * are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n */\n class Chart {\n /**\n * Factory function for basic charts.\n *\n * @example\n * // Render a chart in to div#container\n * let chart = Highcharts.chart('container', {\n * title: {\n * text: 'My chart'\n * },\n * series: [{\n * data: [1, 3, 2, 4]\n * }]\n * });\n *\n * @function Highcharts.chart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure.\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * Function to run when the chart has loaded and and all external images are\n * loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highcharts/chart.events.load)\n * handler is equivalent.\n *\n * @return {Highcharts.Chart}\n * Returns the Chart object.\n */\n static chart(a, b, c) {\n return new Chart(a, b, c);\n }\n constructor(a, b, c) {\n this.axes = void 0;\n this.axisOffset = void 0;\n this.bounds = void 0;\n this.chartHeight = void 0;\n this.chartWidth = void 0;\n this.clipBox = void 0;\n this.colorCounter = void 0;\n this.container = void 0;\n this.eventOptions = void 0;\n this.index = void 0;\n this.isResizing = void 0;\n this.labelCollectors = void 0;\n this.margin = void 0;\n this.numberFormatter = void 0;\n this.options = void 0;\n this.plotBox = void 0;\n this.plotHeight = void 0;\n this.plotLeft = void 0;\n this.plotTop = void 0;\n this.plotWidth = void 0;\n this.pointCount = void 0;\n this.pointer = void 0;\n this.renderer = void 0;\n this.renderTo = void 0;\n this.series = void 0;\n this.sharedClips = {};\n this.spacing = void 0;\n this.spacingBox = void 0;\n this.symbolCounter = void 0;\n this.time = void 0;\n this.titleOffset = void 0;\n this.userOptions = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zooming = void 0;\n this.getArgs(a, b, c);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Handle the arguments passed to the constructor.\n *\n * @private\n * @function Highcharts.Chart#getArgs\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n getArgs(a, b, c) {\n // Remove the optional first argument, renderTo, and\n // set it on this.\n if (isString(a) || a.nodeName) {\n this.renderTo = a;\n this.init(b, c);\n }\n else {\n this.init(a, b);\n }\n }\n /**\n * Function setting zoom options after chart init and after chart update.\n * Offers support for deprecated options.\n *\n * @private\n * @function Highcharts.Chart#setZoomOptions\n */\n setZoomOptions() {\n const chart = this, options = chart.options.chart, zooming = options.zooming;\n chart.zooming = Object.assign(Object.assign({}, zooming), { type: pick(options.zoomType, zooming.type), key: pick(options.zoomKey, zooming.key), pinchType: pick(options.pinchType, zooming.pinchType), singleTouch: pick(options.zoomBySingleTouch, zooming.singleTouch, false), resetButton: merge(zooming.resetButton, options.resetZoomButton) });\n }\n /**\n * Overridable function that initializes the chart. The constructor's\n * arguments are passed on directly.\n *\n * @function Highcharts.Chart#init\n *\n * @param {Highcharts.Options} userOptions\n * Custom options.\n *\n * @param {Function} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded.\n *\n *\n * @emits Highcharts.Chart#event:init\n * @emits Highcharts.Chart#event:afterInit\n */\n init(userOptions, callback) {\n // Fire the event with a default function\n fireEvent(this, 'init', { args: arguments }, function () {\n const options = merge(defaultOptions, userOptions), // do the merge\n optionsChart = options.chart;\n /**\n * The original options given to the constructor or a chart factory\n * like {@link Highcharts.chart} and {@link Highcharts.stockChart}.\n * The original options are shallow copied to avoid mutation. The\n * copy, `chart.userOptions`, may later be mutated to reflect\n * updated options throughout the lifetime of the chart.\n *\n * For collections, like `series`, `xAxis` and `yAxis`, the chart\n * user options should always be reflected by the item user option,\n * so for example the following should always be true:\n *\n * `chart.xAxis[0].userOptions === chart.userOptions.xAxis[0]`\n *\n * @name Highcharts.Chart#userOptions\n * @type {Highcharts.Options}\n */\n this.userOptions = extend({}, userOptions);\n this.margin = [];\n this.spacing = [];\n // Pixel data bounds for touch zoom\n this.bounds = { h: {}, v: {} };\n // An array of functions that returns labels that should be\n // considered for anti-collision\n this.labelCollectors = [];\n this.callback = callback;\n this.isResizing = 0;\n /**\n * The options structure for the chart after merging\n * {@link #defaultOptions} and {@link #userOptions}. It contains\n * members for the sub elements like series, legend, tooltip etc.\n *\n * @name Highcharts.Chart#options\n * @type {Highcharts.Options}\n */\n this.options = options;\n /**\n * All the axes in the chart.\n *\n * @see Highcharts.Chart.xAxis\n * @see Highcharts.Chart.yAxis\n *\n * @name Highcharts.Chart#axes\n * @type {Array}\n */\n this.axes = [];\n /**\n * All the current series in the chart.\n *\n * @name Highcharts.Chart#series\n * @type {Array}\n */\n this.series = [];\n /**\n * The `Time` object associated with the chart. Since v6.0.5,\n * time settings can be applied individually for each chart. If\n * no individual settings apply, the `Time` object is shared by\n * all instances.\n *\n * @name Highcharts.Chart#time\n * @type {Highcharts.Time}\n */\n this.time =\n userOptions.time && Object.keys(userOptions.time).length ?\n new Time(userOptions.time) :\n H.time;\n /**\n * Callback function to override the default function that formats\n * all the numbers in the chart. Returns a string with the formatted\n * number.\n *\n * @name Highcharts.Chart#numberFormatter\n * @type {Highcharts.NumberFormatterCallbackFunction}\n */\n this.numberFormatter = optionsChart.numberFormatter || numberFormat;\n /**\n * Whether the chart is in styled mode, meaning all presentational\n * attributes are avoided.\n *\n * @name Highcharts.Chart#styledMode\n * @type {boolean}\n */\n this.styledMode = optionsChart.styledMode;\n this.hasCartesianSeries = optionsChart.showAxes;\n const chart = this;\n /**\n * Index position of the chart in the {@link Highcharts#charts}\n * property.\n *\n * @name Highcharts.Chart#index\n * @type {number}\n * @readonly\n */\n chart.index = charts.length; // Add the chart to the global lookup\n charts.push(chart);\n H.chartCount++;\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n /**\n * A collection of the X axes in the chart.\n *\n * @name Highcharts.Chart#xAxis\n * @type {Array}\n */\n chart.xAxis = [];\n /**\n * A collection of the Y axes in the chart.\n *\n * @name Highcharts.Chart#yAxis\n * @type {Array}\n *\n * @todo\n * Make events official: Fire the event `afterInit`.\n */\n chart.yAxis = [];\n chart.pointCount = chart.colorCounter = chart.symbolCounter = 0;\n this.setZoomOptions();\n // Fire after init but before first render, before axes and series\n // have been initialized.\n fireEvent(chart, 'afterInit');\n chart.firstRender();\n });\n }\n /**\n * Internal function to unitialize an individual series.\n *\n * @private\n * @function Highcharts.Chart#initSeries\n */\n initSeries(options) {\n const chart = this, optionsChart = chart.options.chart, type = (options.type ||\n optionsChart.type), SeriesClass = seriesTypes[type];\n // No such series type\n if (!SeriesClass) {\n error(17, true, chart, { missingModuleFor: type });\n }\n const series = new SeriesClass();\n if (typeof series.init === 'function') {\n series.init(chart, options);\n }\n return series;\n }\n /**\n * Internal function to set data for all series with enabled sorting.\n *\n * @private\n * @function Highcharts.Chart#setSeriesData\n */\n setSeriesData() {\n this.getSeriesOrderByLinks().forEach(function (series) {\n // We need to set data for series with sorting after series init\n if (!series.points && !series.data && series.enabledDataSorting) {\n series.setData(series.options.data, false);\n }\n });\n }\n /**\n * Sort and return chart series in order depending on the number of linked\n * series.\n *\n * @private\n * @function Highcharts.Series#getSeriesOrderByLinks\n */\n getSeriesOrderByLinks() {\n return this.series.concat().sort(function (a, b) {\n if (a.linkedSeries.length || b.linkedSeries.length) {\n return b.linkedSeries.length - a.linkedSeries.length;\n }\n return 0;\n });\n }\n /**\n * Order all series or axes above a given index. When series or axes are\n * added and ordered by configuration, only the last series is handled\n * (#248, #1123, #2456, #6112). This function is called on series and axis\n * initialization and destroy.\n *\n * @private\n * @function Highcharts.Chart#orderItems\n * @param {string} coll The collection name\n * @param {number} [fromIndex=0]\n * If this is given, only the series above this index are handled.\n */\n orderItems(coll, fromIndex = 0) {\n const collection = this[coll], \n // Item options should be reflected in chart.options.series,\n // chart.options.yAxis etc\n optionsArray = this.options[coll] = splat(this.options[coll])\n .slice(), userOptionsArray = this.userOptions[coll] = this.userOptions[coll] ?\n splat(this.userOptions[coll]).slice() :\n [];\n if (this.hasRendered) {\n // Remove all above index\n optionsArray.splice(fromIndex);\n userOptionsArray.splice(fromIndex);\n }\n if (collection) {\n for (let i = fromIndex, iEnd = collection.length; i < iEnd; ++i) {\n const item = collection[i];\n if (item) {\n /**\n * Contains the series' index in the `Chart.series` array.\n *\n * @name Highcharts.Series#index\n * @type {number}\n * @readonly\n */\n item.index = i;\n if (item instanceof Series) {\n item.name = item.getName();\n }\n if (!item.options.isInternal) {\n optionsArray[i] = item.options;\n userOptionsArray[i] = item.userOptions;\n }\n }\n }\n }\n }\n /**\n * Check whether a given point is within the plot area.\n *\n * @function Highcharts.Chart#isInsidePlot\n *\n * @param {number} plotX\n * Pixel x relative to the plot area.\n *\n * @param {number} plotY\n * Pixel y relative to the plot area.\n *\n * @param {Highcharts.ChartIsInsideOptionsObject} [options]\n * Options object.\n *\n * @return {boolean}\n * Returns true if the given point is inside the plot area.\n */\n isInsidePlot(plotX, plotY, options = {}) {\n const { inverted, plotBox, plotLeft, plotTop, scrollablePlotBox } = this;\n let scrollLeft = 0, scrollTop = 0;\n if (options.visiblePlotOnly && this.scrollingContainer) {\n ({ scrollLeft, scrollTop } = this.scrollingContainer);\n }\n const series = options.series, box = (options.visiblePlotOnly && scrollablePlotBox) || plotBox, x = options.inverted ? plotY : plotX, y = options.inverted ? plotX : plotY, e = {\n x,\n y,\n isInsidePlot: true,\n options\n };\n if (!options.ignoreX) {\n const xAxis = (series &&\n (inverted && !this.polar ? series.yAxis : series.xAxis)) || {\n pos: plotLeft,\n len: Infinity\n };\n const chartX = options.paneCoordinates ?\n xAxis.pos + x : plotLeft + x;\n if (!(chartX >= Math.max(scrollLeft + plotLeft, xAxis.pos) &&\n chartX <= Math.min(scrollLeft + plotLeft + box.width, xAxis.pos + xAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n if (!options.ignoreY && e.isInsidePlot) {\n const yAxis = (!inverted && options.axis &&\n !options.axis.isXAxis && options.axis) || (series && (inverted ? series.xAxis : series.yAxis)) || {\n pos: plotTop,\n len: Infinity\n };\n const chartY = options.paneCoordinates ?\n yAxis.pos + y : plotTop + y;\n if (!(chartY >= Math.max(scrollTop + plotTop, yAxis.pos) &&\n chartY <= Math.min(scrollTop + plotTop + box.height, yAxis.pos + yAxis.len))) {\n e.isInsidePlot = false;\n }\n }\n fireEvent(this, 'afterIsInsidePlot', e);\n return e.isInsidePlot;\n }\n /**\n * Redraw the chart after changes have been done to the data, axis extremes\n * chart size or chart elements. All methods for updating axes, series or\n * points have a parameter for redrawing the chart. This is `true` by\n * default. But in many cases you want to do more than one operation on the\n * chart before redrawing, for example add a number of points. In those\n * cases it is a waste of resources to redraw the chart for each new point\n * added. So you add the points and call `chart.redraw()` after.\n *\n * @function Highcharts.Chart#redraw\n *\n * @param {boolean|Partial} [animation]\n * If or how to apply animation to the redraw. When `undefined`, it applies\n * the animation that is set in the `chart.animation` option.\n *\n * @emits Highcharts.Chart#event:afterSetExtremes\n * @emits Highcharts.Chart#event:beforeRedraw\n * @emits Highcharts.Chart#event:predraw\n * @emits Highcharts.Chart#event:redraw\n * @emits Highcharts.Chart#event:render\n * @emits Highcharts.Chart#event:updatedData\n */\n redraw(animation) {\n fireEvent(this, 'beforeRedraw');\n const chart = this, axes = chart.hasCartesianSeries ? chart.axes : chart.colorAxis || [], series = chart.series, pointer = chart.pointer, legend = chart.legend, legendUserOptions = chart.userOptions.legend, renderer = chart.renderer, isHiddenChart = renderer.isHidden(), afterRedraw = [];\n let hasDirtyStacks, hasStackedSeries, i, isDirtyBox = chart.isDirtyBox, redrawLegend = chart.isDirtyLegend, serie;\n renderer.rootFontSize = renderer.boxWrapper.getStyle('font-size');\n // Handle responsive rules, not only on resize (#6130)\n if (chart.setResponsive) {\n chart.setResponsive(false);\n }\n // Set the global animation. When chart.hasRendered is not true, the\n // redraw call comes from a responsive rule and animation should not\n // occur.\n setAnimation(chart.hasRendered ? animation : false, chart);\n if (isHiddenChart) {\n chart.temporaryDisplay();\n }\n // Adjust title layout (reflow multiline text)\n chart.layOutTitles(false);\n // link stacked series\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking || serie.options.centerInCategory) {\n hasStackedSeries = true;\n if (serie.isDirty) {\n hasDirtyStacks = true;\n break;\n }\n }\n }\n if (hasDirtyStacks) { // mark others as dirty\n i = series.length;\n while (i--) {\n serie = series[i];\n if (serie.options.stacking) {\n serie.isDirty = true;\n }\n }\n }\n // Handle updated data in the series\n series.forEach(function (serie) {\n if (serie.isDirty) {\n if (serie.options.legendType === 'point') {\n if (typeof serie.updateTotals === 'function') {\n serie.updateTotals();\n }\n redrawLegend = true;\n }\n else if (legendUserOptions &&\n (legendUserOptions.labelFormatter ||\n legendUserOptions.labelFormat)) {\n redrawLegend = true; // #2165\n }\n }\n if (serie.isDirtyData) {\n fireEvent(serie, 'updatedData');\n }\n });\n // handle added or removed series\n if (redrawLegend && legend && legend.options.enabled) {\n // draw legend graphics\n legend.render();\n chart.isDirtyLegend = false;\n }\n // reset stacks\n if (hasStackedSeries) {\n chart.getStacks();\n }\n // set axes scales\n axes.forEach(function (axis) {\n axis.updateNames();\n axis.setScale();\n });\n chart.getMargins(); // #3098\n // If one axis is dirty, all axes must be redrawn (#792, #2169)\n axes.forEach(function (axis) {\n if (axis.isDirty) {\n isDirtyBox = true;\n }\n });\n // redraw axes\n axes.forEach(function (axis) {\n // Fire 'afterSetExtremes' only if extremes are set\n const key = axis.min + ',' + axis.max;\n if (axis.extKey !== key) { // #821, #4452\n axis.extKey = key;\n // prevent a recursive call to chart.redraw() (#1119)\n afterRedraw.push(function () {\n fireEvent(axis, 'afterSetExtremes', extend(axis.eventArgs, axis.getExtremes())); // #747, #751\n delete axis.eventArgs;\n });\n }\n if (isDirtyBox || hasStackedSeries) {\n axis.redraw();\n }\n });\n // the plot areas size has changed\n if (isDirtyBox) {\n chart.drawChartBox();\n }\n // Fire an event before redrawing series, used by the boost module to\n // clear previous series renderings.\n fireEvent(chart, 'predraw');\n // redraw affected series\n series.forEach(function (serie) {\n if ((isDirtyBox || serie.isDirty) && serie.visible) {\n serie.redraw();\n }\n // Set it here, otherwise we will have unlimited 'updatedData' calls\n // for a hidden series after setData(). Fixes #6012\n serie.isDirtyData = false;\n });\n // move tooltip or reset\n if (pointer) {\n pointer.reset(true);\n }\n // redraw if canvas\n renderer.draw();\n // Fire the events\n fireEvent(chart, 'redraw');\n fireEvent(chart, 'render');\n if (isHiddenChart) {\n chart.temporaryDisplay(true);\n }\n // Fire callbacks that are put on hold until after the redraw\n afterRedraw.forEach(function (callback) {\n callback.call();\n });\n }\n /**\n * Get an axis, series or point object by `id` as given in the configuration\n * options. Returns `undefined` if no item is found.\n *\n * @sample highcharts/plotoptions/series-id/\n * Get series by id\n *\n * @function Highcharts.Chart#get\n *\n * @param {string} id\n * The id as given in the configuration options.\n *\n * @return {Highcharts.Axis|Highcharts.Series|Highcharts.Point|undefined}\n * The retrieved item.\n */\n get(id) {\n const series = this.series;\n /**\n * @private\n */\n function itemById(item) {\n return (item.id === id ||\n (item.options && item.options.id === id));\n }\n let ret = \n // Search axes\n find(this.axes, itemById) ||\n // Search series\n find(this.series, itemById);\n // Search points\n for (let i = 0; !ret && i < series.length; i++) {\n ret = find(series[i].points || [], itemById);\n }\n return ret;\n }\n /**\n * Create the Axis instances based on the config options.\n *\n * @private\n * @function Highcharts.Chart#getAxes\n * @emits Highcharts.Chart#event:afterGetAxes\n * @emits Highcharts.Chart#event:getAxes\n */\n getAxes() {\n const options = this.options;\n fireEvent(this, 'getAxes');\n for (const coll of ['xAxis', 'yAxis']) {\n const arr = options[coll] = splat(options[coll] || {});\n for (const axisOptions of arr) {\n // eslint-disable-next-line no-new\n new Axis(this, axisOptions, coll);\n }\n }\n fireEvent(this, 'afterGetAxes');\n }\n /**\n * Returns an array of all currently selected points in the chart. Points\n * can be selected by clicking or programmatically by the\n * {@link Highcharts.Point#select}\n * function.\n *\n * @sample highcharts/plotoptions/series-allowpointselect-line/\n * Get selected points\n *\n * @function Highcharts.Chart#getSelectedPoints\n *\n * @return {Array}\n * The currently selected points.\n */\n getSelectedPoints() {\n return this.series.reduce((acc, series) => {\n // For one-to-one points inspect series.data in order to retrieve\n // points outside the visible range (#6445). For grouped data,\n // inspect the generated series.points.\n series.getPointsCollection()\n .forEach((point) => {\n if (pick(point.selectedStaging, point.selected)) {\n acc.push(point);\n }\n });\n return acc;\n }, []);\n }\n /**\n * Returns an array of all currently selected series in the chart. Series\n * can be selected either programmatically by the\n * {@link Highcharts.Series#select}\n * function or by checking the checkbox next to the legend item if\n * [series.showCheckBox](https://api.highcharts.com/highcharts/plotOptions.series.showCheckbox)\n * is true.\n *\n * @sample highcharts/members/chart-getselectedseries/\n * Get selected series\n *\n * @function Highcharts.Chart#getSelectedSeries\n *\n * @return {Array}\n * The currently selected series.\n */\n getSelectedSeries() {\n return this.series.filter(function (serie) {\n return serie.selected;\n });\n }\n /**\n * Set a new title or subtitle for the chart.\n *\n * @sample highcharts/members/chart-settitle/\n * Set title text and styles\n *\n * @function Highcharts.Chart#setTitle\n *\n * @param {Highcharts.TitleOptions} [titleOptions]\n * New title options. The title text itself is set by the\n * `titleOptions.text` property.\n *\n * @param {Highcharts.SubtitleOptions} [subtitleOptions]\n * New subtitle options. The subtitle text itself is set by the\n * `subtitleOptions.text` property.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart or wait for a later call to\n * `chart.redraw()`.\n */\n setTitle(titleOptions, subtitleOptions, redraw) {\n this.applyDescription('title', titleOptions);\n this.applyDescription('subtitle', subtitleOptions);\n // The initial call also adds the caption. On update, chart.update will\n // relay to Chart.setCaption.\n this.applyDescription('caption', void 0);\n this.layOutTitles(redraw);\n }\n /**\n * Apply a title, subtitle or caption for the chart\n *\n * @private\n * @function Highcharts.Chart#applyDescription\n * @param name {string}\n * Either title, subtitle or caption\n * @param {Highcharts.TitleOptions|Highcharts.SubtitleOptions|Highcharts.CaptionOptions|undefined} explicitOptions\n * The options to set, will be merged with default options.\n */\n applyDescription(name, explicitOptions) {\n const chart = this;\n // Merge default options with explicit options\n const options = this.options[name] = merge(this.options[name], explicitOptions);\n let elem = this[name];\n if (elem && explicitOptions) {\n this[name] = elem = elem.destroy(); // remove old\n }\n if (options && !elem) {\n elem = this.renderer.text(options.text, 0, 0, options.useHTML)\n .attr({\n align: options.align,\n 'class': 'highcharts-' + name,\n zIndex: options.zIndex || 4\n })\n .add();\n // Update methods, relay to `applyDescription`\n elem.update = function (updateOptions, redraw) {\n chart.applyDescription(name, updateOptions);\n chart.layOutTitles(redraw);\n };\n // Presentational\n if (!this.styledMode) {\n elem.css(extend(name === 'title' ? {\n // #2944\n fontSize: this.options.isStock ? '1em' : '1.2em'\n } : {}, options.style));\n }\n /**\n * The chart title. The title has an `update` method that allows\n * modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @sample highcharts/members/title-update/\n * Updating titles\n *\n * @name Highcharts.Chart#title\n * @type {Highcharts.TitleObject}\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @name Highcharts.Chart#subtitle\n * @type {Highcharts.SubtitleObject}\n */\n this[name] = elem;\n }\n }\n /**\n * Internal function to lay out the chart title, subtitle and caption, and\n * cache the full offset height for use in `getMargins`. The result is\n * stored in `this.titleOffset`.\n *\n * @private\n * @function Highcharts.Chart#layOutTitles\n *\n * @param {boolean} [redraw=true]\n * @emits Highcharts.Chart#event:afterLayOutTitles\n */\n layOutTitles(redraw = true) {\n const titleOffset = [0, 0, 0], renderer = this.renderer, spacingBox = this.spacingBox;\n // Lay out the title and the subtitle respectively\n ['title', 'subtitle', 'caption'].forEach(function (key) {\n const title = this[key], titleOptions = (this.options[key]), verticalAlign = titleOptions.verticalAlign || 'top', offset = key === 'title' ?\n verticalAlign === 'top' ? -3 : 0 :\n // Floating subtitle (#6574)\n verticalAlign === 'top' ? titleOffset[0] + 2 : 0;\n if (title) {\n title\n .css({\n width: (titleOptions.width ||\n spacingBox.width + (titleOptions.widthAdjust || 0)) + 'px'\n });\n const baseline = renderer.fontMetrics(title).b, \n // Skip the cache for HTML (#3481, #11666)\n height = Math.round(title.getBBox(titleOptions.useHTML).height);\n title.align(extend({\n y: verticalAlign === 'bottom' ?\n baseline :\n offset + baseline,\n height\n }, titleOptions), false, 'spacingBox');\n if (!titleOptions.floating) {\n if (verticalAlign === 'top') {\n titleOffset[0] = Math.ceil(titleOffset[0] +\n height);\n }\n else if (verticalAlign === 'bottom') {\n titleOffset[2] = Math.ceil(titleOffset[2] +\n height);\n }\n }\n }\n }, this);\n // Handle title.margin and caption.margin\n if (titleOffset[0] &&\n (this.options.title.verticalAlign || 'top') === 'top') {\n titleOffset[0] += this.options.title.margin;\n }\n if (titleOffset[2] &&\n this.options.caption.verticalAlign === 'bottom') {\n titleOffset[2] += this.options.caption.margin;\n }\n const requiresDirtyBox = (!this.titleOffset ||\n this.titleOffset.join(',') !== titleOffset.join(','));\n // Used in getMargins\n this.titleOffset = titleOffset;\n fireEvent(this, 'afterLayOutTitles');\n if (!this.isDirtyBox && requiresDirtyBox) {\n this.isDirtyBox = this.isDirtyLegend = requiresDirtyBox;\n // Redraw if necessary (#2719, #2744)\n if (this.hasRendered && redraw && this.isDirtyBox) {\n this.redraw();\n }\n }\n }\n /**\n * Internal function to get the available size of the container element\n *\n * @private\n * @function Highcharts.Chart#getContainerBox\n */\n getContainerBox() {\n return {\n width: getStyle(this.renderTo, 'width', true) || 0,\n height: getStyle(this.renderTo, 'height', true) || 0\n };\n }\n /**\n * Internal function to get the chart width and height according to options\n * and container size. Sets {@link Chart.chartWidth} and\n * {@link Chart.chartHeight}.\n *\n * @private\n * @function Highcharts.Chart#getChartSize\n */\n getChartSize() {\n const chart = this, optionsChart = chart.options.chart, widthOption = optionsChart.width, heightOption = optionsChart.height, containerBox = chart.getContainerBox();\n /**\n * The current pixel width of the chart.\n *\n * @name Highcharts.Chart#chartWidth\n * @type {number}\n */\n chart.chartWidth = Math.max(// #1393\n 0, widthOption || containerBox.width || 600 // #1460\n );\n /**\n * The current pixel height of the chart.\n *\n * @name Highcharts.Chart#chartHeight\n * @type {number}\n */\n chart.chartHeight = Math.max(0, relativeLength(heightOption, chart.chartWidth) ||\n (containerBox.height > 1 ? containerBox.height : 400));\n chart.containerBox = containerBox;\n }\n /**\n * If the renderTo element has no offsetWidth, most likely one or more of\n * its parents are hidden. Loop up the DOM tree to temporarily display the\n * parents, then save the original display properties, and when the true\n * size is retrieved, reset them. Used on first render and on redraws.\n *\n * @private\n * @function Highcharts.Chart#temporaryDisplay\n *\n * @param {boolean} [revert]\n * Revert to the saved original styles.\n */\n temporaryDisplay(revert) {\n let node = this.renderTo, tempStyle;\n if (!revert) {\n while (node && node.style) {\n // When rendering to a detached node, it needs to be temporarily\n // attached in order to read styling and bounding boxes (#5783,\n // #7024).\n if (!doc.body.contains(node) && !node.parentNode) {\n node.hcOrigDetached = true;\n doc.body.appendChild(node);\n }\n if (getStyle(node, 'display', false) === 'none' ||\n node.hcOricDetached) {\n node.hcOrigStyle = {\n display: node.style.display,\n height: node.style.height,\n overflow: node.style.overflow\n };\n tempStyle = {\n display: 'block',\n overflow: 'hidden'\n };\n if (node !== this.renderTo) {\n tempStyle.height = 0;\n }\n css(node, tempStyle);\n // If it still doesn't have an offset width after setting\n // display to block, it probably has an !important priority\n // #2631, 6803\n if (!node.offsetWidth) {\n node.style.setProperty('display', 'block', 'important');\n }\n }\n node = node.parentNode;\n if (node === doc.body) {\n break;\n }\n }\n }\n else {\n while (node && node.style) {\n if (node.hcOrigStyle) {\n css(node, node.hcOrigStyle);\n delete node.hcOrigStyle;\n }\n if (node.hcOrigDetached) {\n doc.body.removeChild(node);\n node.hcOrigDetached = false;\n }\n node = node.parentNode;\n }\n }\n }\n /**\n * Set the {@link Chart.container|chart container's} class name, in\n * addition to `highcharts-container`.\n *\n * @function Highcharts.Chart#setClassName\n *\n * @param {string} [className]\n * The additional class name.\n */\n setClassName(className) {\n this.container.className = 'highcharts-container ' + (className || '');\n }\n /**\n * Get the containing element, determine the size and create the inner\n * container div to hold the chart.\n *\n * @private\n * @function Highcharts.Chart#afterGetContainer\n * @emits Highcharts.Chart#event:afterGetContainer\n */\n getContainer() {\n const chart = this, options = chart.options, optionsChart = options.chart, indexAttrName = 'data-highcharts-chart', containerId = uniqueKey();\n let containerStyle, renderTo = chart.renderTo;\n if (!renderTo) {\n chart.renderTo = renderTo =\n optionsChart.renderTo;\n }\n if (isString(renderTo)) {\n chart.renderTo = renderTo =\n doc.getElementById(renderTo);\n }\n // Display an error if the renderTo is wrong\n if (!renderTo) {\n error(13, true, chart);\n }\n // If the container already holds a chart, destroy it. The check for\n // hasRendered is there because web pages that are saved to disk from\n // the browser, will preserve the data-highcharts-chart attribute and\n // the SVG contents, but not an interactive chart. So in this case,\n // charts[oldChartIndex] will point to the wrong chart if any (#2609).\n const oldChartIndex = pInt(attr(renderTo, indexAttrName));\n if (isNumber(oldChartIndex) &&\n charts[oldChartIndex] &&\n charts[oldChartIndex].hasRendered) {\n charts[oldChartIndex].destroy();\n }\n // Make a reference to the chart from the div\n attr(renderTo, indexAttrName, chart.index);\n // remove previous chart\n renderTo.innerHTML = AST.emptyHTML;\n // If the container doesn't have an offsetWidth, it has or is a child of\n // a node that has display:none. We need to temporarily move it out to a\n // visible state to determine the size, else the legend and tooltips\n // won't render properly. The skipClone option is used in sparklines as\n // a micro optimization, saving about 1-2 ms each chart.\n if (!optionsChart.skipClone && !renderTo.offsetWidth) {\n chart.temporaryDisplay();\n }\n // get the width and height\n chart.getChartSize();\n const chartWidth = chart.chartWidth;\n const chartHeight = chart.chartHeight;\n // Allow table cells and flex-boxes to shrink without the chart blocking\n // them out (#6427)\n css(renderTo, { overflow: 'hidden' });\n // Create the inner container\n if (!chart.styledMode) {\n containerStyle = extend({\n position: 'relative',\n // needed for context menu (avoidscrollbars) and content\n // overflow in IE\n overflow: 'hidden',\n width: chartWidth + 'px',\n height: chartHeight + 'px',\n textAlign: 'left',\n lineHeight: 'normal',\n zIndex: 0,\n '-webkit-tap-highlight-color': 'rgba(0,0,0,0)',\n userSelect: 'none',\n 'touch-action': 'manipulation',\n outline: 'none'\n }, optionsChart.style || {});\n }\n /**\n * The containing HTML element of the chart. The container is\n * dynamically inserted into the element given as the `renderTo`\n * parameter in the {@link Highcharts#chart} constructor.\n *\n * @name Highcharts.Chart#container\n * @type {Highcharts.HTMLDOMElement}\n */\n const container = createElement('div', {\n id: containerId\n }, containerStyle, renderTo);\n chart.container = container;\n // cache the cursor (#1650)\n chart._cursor = container.style.cursor;\n // Initialize the renderer\n const Renderer = optionsChart.renderer || !svg ?\n RendererRegistry.getRendererType(optionsChart.renderer) :\n SVGRenderer;\n /**\n * The renderer instance of the chart. Each chart instance has only one\n * associated renderer.\n *\n * @name Highcharts.Chart#renderer\n * @type {Highcharts.SVGRenderer}\n */\n chart.renderer = new Renderer(container, chartWidth, chartHeight, void 0, optionsChart.forExport, options.exporting && options.exporting.allowHTML, chart.styledMode);\n chart.containerBox = chart.getContainerBox();\n // Set the initial animation from the options\n setAnimation(void 0, chart);\n chart.setClassName(optionsChart.className);\n if (!chart.styledMode) {\n chart.renderer.setStyle(optionsChart.style);\n }\n else {\n // Initialize definitions\n for (const key in options.defs) { // eslint-disable-line guard-for-in\n this.renderer.definition(options.defs[key]);\n }\n }\n // Add a reference to the charts index\n chart.renderer.chartIndex = chart.index;\n fireEvent(this, 'afterGetContainer');\n }\n /**\n * Calculate margins by rendering axis labels in a preliminary position.\n * Title, subtitle and legend have already been rendered at this stage, but\n * will be moved into their final positions.\n *\n * @private\n * @function Highcharts.Chart#getMargins\n * @emits Highcharts.Chart#event:getMargins\n */\n getMargins(skipAxes) {\n const { spacing, margin, titleOffset } = this;\n this.resetMargins();\n // Adjust for title and subtitle\n if (titleOffset[0] && !defined(margin[0])) {\n this.plotTop = Math.max(this.plotTop, titleOffset[0] + spacing[0]);\n }\n if (titleOffset[2] && !defined(margin[2])) {\n this.marginBottom = Math.max(this.marginBottom, titleOffset[2] + spacing[2]);\n }\n // Adjust for legend\n if (this.legend && this.legend.display) {\n this.legend.adjustMargins(margin, spacing);\n }\n fireEvent(this, 'getMargins');\n if (!skipAxes) {\n this.getAxisMargins();\n }\n }\n /**\n * @private\n * @function Highcharts.Chart#getAxisMargins\n */\n getAxisMargins() {\n const chart = this, \n // [top, right, bottom, left]\n axisOffset = chart.axisOffset = [0, 0, 0, 0], colorAxis = chart.colorAxis, margin = chart.margin, getOffset = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.getOffset();\n }\n });\n };\n // pre-render axes to get labels offset width\n if (chart.hasCartesianSeries) {\n getOffset(chart.axes);\n }\n else if (colorAxis && colorAxis.length) {\n getOffset(colorAxis);\n }\n // Add the axis offsets\n marginNames.forEach(function (m, side) {\n if (!defined(margin[side])) {\n chart[m] += axisOffset[side];\n }\n });\n chart.setChartSize();\n }\n /**\n * Return the current options of the chart, but only those that differ from\n * default options. Items that can be either an object or an array of\n * objects, like `series`, `xAxis` and `yAxis`, are always returned as\n * array.\n *\n * @sample highcharts/members/chart-getoptions\n *\n * @function Highcharts.Chart#getOptions\n *\n * @since 11.1.0\n */\n getOptions() {\n return diffObjects(this.userOptions, defaultOptions);\n }\n /**\n * Reflows the chart to its container. By default, the Resize Observer is\n * attached to the chart's div which allows to reflows the chart\n * automatically to its container, as per the\n * [chart.reflow](https://api.highcharts.com/highcharts/chart.reflow)\n * option.\n *\n * @sample highcharts/chart/events-container/\n * Pop up and reflow\n *\n * @function Highcharts.Chart#reflow\n *\n * @param {global.Event} [e]\n * Event arguments. Used primarily when the function is called\n * internally as a response to window resize.\n */\n reflow(e) {\n const chart = this, optionsChart = chart.options.chart, hasUserSize = (defined(optionsChart.width) &&\n defined(optionsChart.height)), oldBox = chart.containerBox, containerBox = chart.getContainerBox();\n delete chart.pointer.chartPosition;\n // Width and height checks for display:none. Target is doc in Opera\n // and win in Firefox, Chrome and IE9.\n if (!hasUserSize &&\n !chart.isPrinting &&\n oldBox &&\n // When fired by resize observer inside hidden container\n containerBox.width) {\n if (containerBox.width !== oldBox.width ||\n containerBox.height !== oldBox.height) {\n U.clearTimeout(chart.reflowTimeout);\n // When called from window.resize, e is set, else it's called\n // directly (#2224)\n chart.reflowTimeout = syncTimeout(function () {\n // Set size, it may have been destroyed in the meantime\n // (#1257)\n if (chart.container) {\n chart.setSize(void 0, void 0, false);\n }\n }, e ? 100 : 0);\n }\n chart.containerBox = containerBox;\n }\n }\n /**\n * Toggle the event handlers necessary for auto resizing, depending on the\n * `chart.reflow` option.\n *\n * @private\n * @function Highcharts.Chart#setReflow\n */\n setReflow() {\n const chart = this;\n const runReflow = (e) => {\n var _a;\n if (((_a = chart.options) === null || _a === void 0 ? void 0 : _a.chart.reflow) && chart.hasLoaded) {\n chart.reflow(e);\n }\n };\n if (typeof ResizeObserver === 'function') {\n (new ResizeObserver(runReflow)).observe(chart.renderTo);\n // Fallback for more legacy browser versions.\n }\n else {\n const unbind = addEvent(win, 'resize', runReflow);\n addEvent(this, 'destroy', unbind);\n }\n }\n /**\n * Resize the chart to a given width and height. In order to set the width\n * only, the height argument may be skipped. To set the height only, pass\n * `undefined` for the width.\n *\n * @sample highcharts/members/chart-setsize-button/\n * Test resizing from buttons\n * @sample highcharts/members/chart-setsize-jquery-resizable/\n * Add a jQuery UI resizable\n * @sample stock/members/chart-setsize/\n * Highcharts Stock with UI resizable\n *\n * @function Highcharts.Chart#setSize\n *\n * @param {number|null} [width]\n * The new pixel width of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value (when\n * setting height only), or `null` to adapt to the width of the\n * containing element.\n *\n * @param {number|null} [height]\n * The new pixel height of the chart. Since v4.2.6, the argument can\n * be `undefined` in order to preserve the current value, or `null`\n * in order to adapt to the height of the containing element.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation. When `undefined`, it applies\n * the animation that is set in the `chart.animation` option.\n *\n *\n * @emits Highcharts.Chart#event:endResize\n * @emits Highcharts.Chart#event:resize\n */\n setSize(width, height, animation) {\n const chart = this, renderer = chart.renderer;\n // Handle the isResizing counter\n chart.isResizing += 1;\n // set the animation for the current process\n setAnimation(animation, chart);\n const globalAnimation = renderer.globalAnimation;\n chart.oldChartHeight = chart.chartHeight;\n chart.oldChartWidth = chart.chartWidth;\n if (typeof width !== 'undefined') {\n chart.options.chart.width = width;\n }\n if (typeof height !== 'undefined') {\n chart.options.chart.height = height;\n }\n chart.getChartSize();\n // Resize the container with the global animation applied if enabled\n // (#2503)\n if (!chart.styledMode) {\n (globalAnimation ? animate : css)(chart.container, {\n width: chart.chartWidth + 'px',\n height: chart.chartHeight + 'px'\n }, globalAnimation);\n }\n chart.setChartSize(true);\n renderer.setSize(chart.chartWidth, chart.chartHeight, globalAnimation);\n // handle axes\n chart.axes.forEach(function (axis) {\n axis.isDirty = true;\n axis.setScale();\n });\n chart.isDirtyLegend = true; // force legend redraw\n chart.isDirtyBox = true; // force redraw of plot and chart border\n chart.layOutTitles(); // #2857\n chart.getMargins();\n chart.redraw(globalAnimation);\n chart.oldChartHeight = null;\n fireEvent(chart, 'resize');\n // Fire endResize and set isResizing back. If animation is disabled,\n // fire without delay\n syncTimeout(function () {\n if (chart) {\n fireEvent(chart, 'endResize', null, function () {\n chart.isResizing -= 1;\n });\n }\n }, animObject(globalAnimation).duration);\n }\n /**\n * Set the public chart properties. This is done before and after the\n * pre-render to determine margin sizes.\n *\n * @private\n * @function Highcharts.Chart#setChartSize\n * @emits Highcharts.Chart#event:afterSetChartSize\n */\n setChartSize(skipAxes) {\n const chart = this, inverted = chart.inverted, renderer = chart.renderer, chartWidth = chart.chartWidth, chartHeight = chart.chartHeight, optionsChart = chart.options.chart, spacing = chart.spacing, clipOffset = chart.clipOffset;\n let plotLeft, plotTop, plotWidth, plotHeight;\n /**\n * The current left position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotLeft\n * @type {number}\n */\n chart.plotLeft = plotLeft = Math.round(chart.plotLeft);\n /**\n * The current top position of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotTop\n * @type {number}\n */\n chart.plotTop = plotTop = Math.round(chart.plotTop);\n /**\n * The current width of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotWidth\n * @type {number}\n */\n chart.plotWidth = plotWidth = Math.max(0, Math.round(chartWidth - plotLeft - chart.marginRight));\n /**\n * The current height of the plot area in pixels.\n *\n * @name Highcharts.Chart#plotHeight\n * @type {number}\n */\n chart.plotHeight = plotHeight = Math.max(0, Math.round(chartHeight - plotTop - chart.marginBottom));\n chart.plotSizeX = inverted ? plotHeight : plotWidth;\n chart.plotSizeY = inverted ? plotWidth : plotHeight;\n chart.plotBorderWidth = optionsChart.plotBorderWidth || 0;\n // Set boxes used for alignment\n chart.spacingBox = renderer.spacingBox = {\n x: spacing[3],\n y: spacing[0],\n width: chartWidth - spacing[3] - spacing[1],\n height: chartHeight - spacing[0] - spacing[2]\n };\n chart.plotBox = renderer.plotBox = {\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n };\n const plotBorderWidth = 2 * Math.floor(chart.plotBorderWidth / 2), clipX = Math.ceil(Math.max(plotBorderWidth, clipOffset[3]) / 2), clipY = Math.ceil(Math.max(plotBorderWidth, clipOffset[0]) / 2);\n chart.clipBox = {\n x: clipX,\n y: clipY,\n width: Math.floor(chart.plotSizeX -\n Math.max(plotBorderWidth, clipOffset[1]) / 2 -\n clipX),\n height: Math.max(0, Math.floor(chart.plotSizeY -\n Math.max(plotBorderWidth, clipOffset[2]) / 2 -\n clipY))\n };\n if (!skipAxes) {\n chart.axes.forEach(function (axis) {\n axis.setAxisSize();\n axis.setAxisTranslation();\n });\n renderer.alignElements();\n }\n fireEvent(chart, 'afterSetChartSize', { skipAxes: skipAxes });\n }\n /**\n * Initial margins before auto size margins are applied.\n *\n * @private\n * @function Highcharts.Chart#resetMargins\n */\n resetMargins() {\n fireEvent(this, 'resetMargins');\n const chart = this, chartOptions = chart.options.chart;\n // Create margin and spacing array\n ['margin', 'spacing'].forEach(function splashArrays(target) {\n const value = chartOptions[target], values = isObject(value) ? value : [value, value, value, value];\n [\n 'Top',\n 'Right',\n 'Bottom',\n 'Left'\n ].forEach(function (sideName, side) {\n chart[target][side] = pick(chartOptions[target + sideName], values[side]);\n });\n });\n // Set margin names like chart.plotTop, chart.plotLeft,\n // chart.marginRight, chart.marginBottom.\n marginNames.forEach(function (m, side) {\n chart[m] = pick(chart.margin[side], chart.spacing[side]);\n });\n chart.axisOffset = [0, 0, 0, 0]; // top, right, bottom, left\n chart.clipOffset = [0, 0, 0, 0];\n }\n /**\n * Internal function to draw or redraw the borders and backgrounds for chart\n * and plot area.\n *\n * @private\n * @function Highcharts.Chart#drawChartBox\n * @emits Highcharts.Chart#event:afterDrawChartBox\n */\n drawChartBox() {\n const chart = this, optionsChart = chart.options.chart, renderer = chart.renderer, chartWidth = chart.chartWidth, chartHeight = chart.chartHeight, styledMode = chart.styledMode, plotBGImage = chart.plotBGImage, chartBackgroundColor = optionsChart.backgroundColor, plotBackgroundColor = optionsChart.plotBackgroundColor, plotBackgroundImage = optionsChart.plotBackgroundImage, plotLeft = chart.plotLeft, plotTop = chart.plotTop, plotWidth = chart.plotWidth, plotHeight = chart.plotHeight, plotBox = chart.plotBox, clipRect = chart.clipRect, clipBox = chart.clipBox;\n let chartBackground = chart.chartBackground, plotBackground = chart.plotBackground, plotBorder = chart.plotBorder, chartBorderWidth, mgn, bgAttr, verb = 'animate';\n // Chart area\n if (!chartBackground) {\n chart.chartBackground = chartBackground = renderer.rect()\n .addClass('highcharts-background')\n .add();\n verb = 'attr';\n }\n if (!styledMode) {\n // Presentational\n chartBorderWidth = optionsChart.borderWidth || 0;\n mgn = chartBorderWidth + (optionsChart.shadow ? 8 : 0);\n bgAttr = {\n fill: chartBackgroundColor || 'none'\n };\n if (chartBorderWidth || chartBackground['stroke-width']) { // #980\n bgAttr.stroke = optionsChart.borderColor;\n bgAttr['stroke-width'] = chartBorderWidth;\n }\n chartBackground\n .attr(bgAttr)\n .shadow(optionsChart.shadow);\n }\n else {\n chartBorderWidth = mgn = chartBackground.strokeWidth();\n }\n chartBackground[verb]({\n x: mgn / 2,\n y: mgn / 2,\n width: chartWidth - mgn - chartBorderWidth % 2,\n height: chartHeight - mgn - chartBorderWidth % 2,\n r: optionsChart.borderRadius\n });\n // Plot background\n verb = 'animate';\n if (!plotBackground) {\n verb = 'attr';\n chart.plotBackground = plotBackground = renderer.rect()\n .addClass('highcharts-plot-background')\n .add();\n }\n plotBackground[verb](plotBox);\n if (!styledMode) {\n // Presentational attributes for the background\n plotBackground\n .attr({\n fill: plotBackgroundColor || 'none'\n })\n .shadow(optionsChart.plotShadow);\n // Create the background image\n if (plotBackgroundImage) {\n if (!plotBGImage) {\n chart.plotBGImage = renderer.image(plotBackgroundImage, plotLeft, plotTop, plotWidth, plotHeight).add();\n }\n else {\n if (plotBackgroundImage !== plotBGImage.attr('href')) {\n plotBGImage.attr('href', plotBackgroundImage);\n }\n plotBGImage.animate(plotBox);\n }\n }\n }\n // Plot clip\n if (!clipRect) {\n chart.clipRect = renderer.clipRect(clipBox);\n }\n else {\n clipRect.animate({\n width: clipBox.width,\n height: clipBox.height\n });\n }\n // Plot area border\n verb = 'animate';\n if (!plotBorder) {\n verb = 'attr';\n chart.plotBorder = plotBorder = renderer.rect()\n .addClass('highcharts-plot-border')\n .attr({\n zIndex: 1 // Above the grid\n })\n .add();\n }\n if (!styledMode) {\n // Presentational\n plotBorder.attr({\n stroke: optionsChart.plotBorderColor,\n 'stroke-width': optionsChart.plotBorderWidth || 0,\n fill: 'none'\n });\n }\n plotBorder[verb](plotBorder.crisp({\n x: plotLeft,\n y: plotTop,\n width: plotWidth,\n height: plotHeight\n }, -plotBorder.strokeWidth())); // #3282 plotBorder should be negative;\n // reset\n chart.isDirtyBox = false;\n fireEvent(this, 'afterDrawChartBox');\n }\n /**\n * Detect whether a certain chart property is needed based on inspecting its\n * options and series. This mainly applies to the chart.inverted property,\n * and in extensions to the chart.angular and chart.polar properties.\n *\n * @private\n * @function Highcharts.Chart#propFromSeries\n */\n propFromSeries() {\n const chart = this, optionsChart = chart.options.chart, seriesOptions = chart.options.series;\n let i, klass, value;\n /**\n * The flag is set to `true` if a series of the chart is inverted.\n *\n * @name Highcharts.Chart#inverted\n * @type {boolean|undefined}\n */\n ['inverted', 'angular', 'polar'].forEach(function (key) {\n // The default series type's class\n klass = seriesTypes[optionsChart.type];\n // Get the value from available chart-wide properties\n value =\n // It is set in the options:\n optionsChart[key] ||\n // The default series class:\n (klass && klass.prototype[key]);\n // requires it\n // 4. Check if any the chart's series require it\n i = seriesOptions && seriesOptions.length;\n while (!value && i--) {\n klass = seriesTypes[seriesOptions[i].type];\n if (klass && klass.prototype[key]) {\n value = true;\n }\n }\n // Set the chart property\n chart[key] = value;\n });\n }\n /**\n * Internal function to link two or more series together, based on the\n * `linkedTo` option. This is done from `Chart.render`, and after\n * `Chart.addSeries` and `Series.remove`.\n *\n * @private\n * @function Highcharts.Chart#linkSeries\n * @emits Highcharts.Chart#event:afterLinkSeries\n */\n linkSeries(isUpdating) {\n const chart = this, chartSeries = chart.series;\n // Reset links\n chartSeries.forEach(function (series) {\n series.linkedSeries.length = 0;\n });\n // Apply new links\n chartSeries.forEach(function (series) {\n let linkedTo = series.options.linkedTo;\n if (isString(linkedTo)) {\n if (linkedTo === ':previous') {\n linkedTo = chart.series[series.index - 1];\n }\n else {\n linkedTo = chart.get(linkedTo);\n }\n // #3341 avoid mutual linking\n if (linkedTo && linkedTo.linkedParent !== series) {\n linkedTo.linkedSeries.push(series);\n series.linkedParent = linkedTo;\n if (linkedTo.enabledDataSorting) {\n series.setDataSortingOptions();\n }\n series.visible = pick(series.options.visible, linkedTo.options.visible, series.visible); // #3879\n }\n }\n });\n fireEvent(this, 'afterLinkSeries', { isUpdating });\n }\n /**\n * Render series for the chart.\n *\n * @private\n * @function Highcharts.Chart#renderSeries\n */\n renderSeries() {\n this.series.forEach(function (serie) {\n serie.translate();\n serie.render();\n });\n }\n /**\n * Render all graphics for the chart. Runs internally on initialization.\n *\n * @private\n * @function Highcharts.Chart#render\n */\n render() {\n const chart = this, axes = chart.axes, colorAxis = chart.colorAxis, renderer = chart.renderer, renderAxes = function (axes) {\n axes.forEach(function (axis) {\n if (axis.visible) {\n axis.render();\n }\n });\n };\n let correction = 0; // correction for X axis labels\n // Title\n chart.setTitle();\n // Fire an event before the margins are computed. This is where the\n // legend is assigned.\n fireEvent(chart, 'beforeMargins');\n // Get stacks\n if (chart.getStacks) {\n chart.getStacks();\n }\n // Get chart margins\n chart.getMargins(true);\n chart.setChartSize();\n // Record preliminary dimensions for later comparison\n const tempWidth = chart.plotWidth;\n axes.some(function (axis) {\n if (axis.horiz &&\n axis.visible &&\n axis.options.labels.enabled &&\n axis.series.length) {\n // 21 is the most common correction for X axis labels\n correction = 21;\n return true;\n }\n });\n // use Math.max to prevent negative plotHeight\n chart.plotHeight = Math.max(chart.plotHeight - correction, 0);\n const tempHeight = chart.plotHeight;\n // Get margins by pre-rendering axes\n axes.forEach(function (axis) {\n axis.setScale();\n });\n chart.getAxisMargins();\n // If the plot area size has changed significantly, calculate tick\n // positions again\n const redoHorizontal = tempWidth / chart.plotWidth > 1.1;\n // Height is more sensitive, use lower threshold\n const redoVertical = tempHeight / chart.plotHeight > 1.05;\n if (redoHorizontal || redoVertical) {\n axes.forEach(function (axis) {\n if ((axis.horiz && redoHorizontal) ||\n (!axis.horiz && redoVertical)) {\n // update to reflect the new margins\n axis.setTickInterval(true);\n }\n });\n chart.getMargins(); // second pass to check for new labels\n }\n // Draw the borders and backgrounds\n chart.drawChartBox();\n // Axes\n if (chart.hasCartesianSeries) {\n renderAxes(axes);\n }\n else if (colorAxis && colorAxis.length) {\n renderAxes(colorAxis);\n }\n // The series\n if (!chart.seriesGroup) {\n chart.seriesGroup = renderer.g('series-group')\n .attr({ zIndex: 3 })\n .shadow(chart.options.chart.seriesGroupShadow)\n .add();\n }\n chart.renderSeries();\n // Credits\n chart.addCredits();\n // Handle responsiveness\n if (chart.setResponsive) {\n chart.setResponsive();\n }\n // Set flag\n chart.hasRendered = true;\n }\n /**\n * Set a new credits label for the chart.\n *\n * @sample highcharts/credits/credits-update/\n * Add and update credits\n *\n * @function Highcharts.Chart#addCredits\n *\n * @param {Highcharts.CreditsOptions} [credits]\n * A configuration object for the new credits.\n */\n addCredits(credits) {\n const chart = this, creds = merge(true, this.options.credits, credits);\n if (creds.enabled && !this.credits) {\n /**\n * The chart's credits label. The label has an `update` method that\n * allows setting new options as per the\n * [credits options set](https://api.highcharts.com/highcharts/credits).\n *\n * @name Highcharts.Chart#credits\n * @type {Highcharts.SVGElement}\n */\n this.credits = this.renderer.text(creds.text + (this.mapCredits || ''), 0, 0)\n .addClass('highcharts-credits')\n .on('click', function () {\n if (creds.href) {\n win.location.href = creds.href;\n }\n })\n .attr({\n align: creds.position.align,\n zIndex: 8\n });\n if (!chart.styledMode) {\n this.credits.css(creds.style);\n }\n this.credits\n .add()\n .align(creds.position);\n // Dynamically update\n this.credits.update = function (options) {\n chart.credits = chart.credits.destroy();\n chart.addCredits(options);\n };\n }\n }\n /**\n * Remove the chart and purge memory. This method is called internally\n * before adding a second chart into the same container, as well as on\n * window unload to prevent leaks.\n *\n * @sample highcharts/members/chart-destroy/\n * Destroy the chart from a button\n * @sample stock/members/chart-destroy/\n * Destroy with Highcharts Stock\n *\n * @function Highcharts.Chart#destroy\n *\n * @emits Highcharts.Chart#event:destroy\n */\n destroy() {\n const chart = this, axes = chart.axes, series = chart.series, container = chart.container, parentNode = container && container.parentNode;\n let i;\n // fire the chart.destoy event\n fireEvent(chart, 'destroy');\n // Delete the chart from charts lookup array\n if (chart.renderer.forExport) {\n erase(charts, chart); // #6569\n }\n else {\n charts[chart.index] = void 0;\n }\n H.chartCount--;\n chart.renderTo.removeAttribute('data-highcharts-chart');\n // remove events\n removeEvent(chart);\n // ==== Destroy collections:\n // Destroy axes\n i = axes.length;\n while (i--) {\n axes[i] = axes[i].destroy();\n }\n // Destroy scroller & scroller series before destroying base series\n if (this.scroller && this.scroller.destroy) {\n this.scroller.destroy();\n }\n // Destroy each series\n i = series.length;\n while (i--) {\n series[i] = series[i].destroy();\n }\n // ==== Destroy chart properties:\n [\n 'title', 'subtitle', 'chartBackground', 'plotBackground',\n 'plotBGImage', 'plotBorder', 'seriesGroup', 'clipRect', 'credits',\n 'pointer', 'rangeSelector', 'legend', 'resetZoomButton', 'tooltip',\n 'renderer'\n ].forEach(function (name) {\n const prop = chart[name];\n if (prop && prop.destroy) {\n chart[name] = prop.destroy();\n }\n });\n // Remove container and all SVG, check container as it can break in IE\n // when destroyed before finished loading\n if (container) {\n container.innerHTML = AST.emptyHTML;\n removeEvent(container);\n if (parentNode) {\n discardElement(container);\n }\n }\n // clean it all up\n objectEach(chart, function (val, key) {\n delete chart[key];\n });\n }\n /**\n * Prepare for first rendering after all data are loaded.\n *\n * @private\n * @function Highcharts.Chart#firstRender\n * @emits Highcharts.Chart#event:beforeRender\n */\n firstRender() {\n const chart = this, options = chart.options;\n // Create the container\n chart.getContainer();\n chart.resetMargins();\n chart.setChartSize();\n // Set the common chart properties (mainly invert) from the given series\n chart.propFromSeries();\n // get axes\n chart.getAxes();\n // Initialize the series\n const series = isArray(options.series) ? options.series : [];\n options.series = []; // Avoid mutation\n series.forEach(\n // #9680\n function (serieOptions) {\n chart.initSeries(serieOptions);\n });\n chart.linkSeries();\n chart.setSeriesData();\n // Run an event after axes and series are initialized, but before\n // render. At this stage, the series data is indexed and cached in the\n // xData and yData arrays, so we can access those before rendering. Used\n // in Highcharts Stock.\n fireEvent(chart, 'beforeRender');\n chart.render();\n chart.pointer.getChartPosition(); // #14973\n // Fire the load event if there are no external images\n if (!chart.renderer.imgCount && !chart.hasLoaded) {\n chart.onload();\n }\n // If the chart was rendered outside the top container, put it back in\n // (#3679)\n chart.temporaryDisplay(true);\n }\n /**\n * Internal function that runs on chart load, async if any images are loaded\n * in the chart. Runs the callbacks and triggers the `load` and `render`\n * events.\n *\n * @private\n * @function Highcharts.Chart#onload\n * @emits Highcharts.Chart#event:load\n * @emits Highcharts.Chart#event:render\n */\n onload() {\n // Run callbacks, first the ones registered by modules, then user's one\n this.callbacks.concat([this.callback]).forEach(function (fn) {\n // Chart destroyed in its own callback (#3600)\n if (fn && typeof this.index !== 'undefined') {\n fn.apply(this, [this]);\n }\n }, this);\n fireEvent(this, 'load');\n fireEvent(this, 'render');\n // Set up auto resize, check for not destroyed (#6068)\n if (defined(this.index)) {\n this.setReflow();\n }\n this.warnIfA11yModuleNotLoaded();\n // Don't run again\n this.hasLoaded = true;\n }\n /**\n * Emit console warning if the a11y module is not loaded.\n */\n warnIfA11yModuleNotLoaded() {\n const { options, title } = this;\n if (options && !this.accessibility) {\n // Make chart behave as an image with the title as alt text\n this.renderer.boxWrapper.attr({\n role: 'img',\n 'aria-label': ((title && title.element.textContent) || ''\n // #17753, < is not allowed in SVG attributes\n ).replace(/} [animation]\n * Whether to apply animation, and optionally animation\n * configuration. When `undefined`, it applies the animation that is\n * set in the `chart.animation` option.\n *\n * @return {Highcharts.Series}\n * The newly created series object.\n *\n * @emits Highcharts.Chart#event:addSeries\n * @emits Highcharts.Chart#event:afterAddSeries\n */\n addSeries(options, redraw, animation) {\n const chart = this;\n let series;\n if (options) { // <- not necessary\n redraw = pick(redraw, true); // defaults to true\n fireEvent(chart, 'addSeries', { options: options }, function () {\n series = chart.initSeries(options);\n chart.isDirtyLegend = true;\n chart.linkSeries();\n if (series.enabledDataSorting) {\n // We need to call `setData` after `linkSeries`\n series.setData(options.data, false);\n }\n fireEvent(chart, 'afterAddSeries', { series: series });\n if (redraw) {\n chart.redraw(animation);\n }\n });\n }\n return series;\n }\n /**\n * Add an axis to the chart after render time. Note that this method should\n * never be used when adding data synchronously at chart render time, as it\n * adds expense to the calculations and rendering. When adding data at the\n * same time as the chart is initialized, add the axis as a configuration\n * option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addAxis\n *\n * @param {Highcharts.AxisOptions} options\n * The axis options.\n *\n * @param {boolean} [isX=false]\n * Whether it is an X axis or a value axis.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation in the redraw. When\n * `undefined`, it applies the animation that is set in the\n * `chart.animation` option.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n addAxis(options, isX, redraw, animation) {\n return this.createAxis(isX ? 'xAxis' : 'yAxis', { axis: options, redraw: redraw, animation: animation });\n }\n /**\n * Add a color axis to the chart after render time. Note that this method\n * should never be used when adding data synchronously at chart render time,\n * as it adds expense to the calculations and rendering. When adding data at\n * the same time as the chart is initialized, add the axis as a\n * configuration option instead.\n *\n * @sample highcharts/members/chart-addaxis/\n * Add and remove axes\n *\n * @function Highcharts.Chart#addColorAxis\n *\n * @param {Highcharts.ColorAxisOptions} options\n * The axis options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after adding.\n *\n * @param {boolean|Partial} [animation]\n * Whether and how to apply animation in the redraw. When\n * `undefined`, it applies the animation that is set in the\n * `chart.animation` option.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n addColorAxis(options, redraw, animation) {\n return this.createAxis('colorAxis', { axis: options, redraw: redraw, animation: animation });\n }\n /**\n * Factory for creating different axis types.\n *\n * @private\n * @function Highcharts.Chart#createAxis\n *\n * @param {string} coll\n * An axis type.\n *\n * @param {...Array<*>} arguments\n * All arguments for the constructor.\n *\n * @return {Highcharts.Axis}\n * The newly generated Axis object.\n */\n createAxis(coll, options) {\n const axis = new Axis(this, options.axis, coll);\n if (pick(options.redraw, true)) {\n this.redraw(options.animation);\n }\n return axis;\n }\n /**\n * Dim the chart and show a loading text or symbol. Options for the loading\n * screen are defined in {@link\n * https://api.highcharts.com/highcharts/loading|the loading options}.\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample highcharts/members/chart-showloading/\n * Apply different text labels\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#showLoading\n *\n * @param {string} [str]\n * An optional text to show in the loading label instead of the\n * default one. The default text is set in\n * [lang.loading](https://api.highcharts.com/highcharts/lang.loading).\n */\n showLoading(str) {\n const chart = this, options = chart.options, loadingOptions = options.loading, setLoadingSize = function () {\n if (loadingDiv) {\n css(loadingDiv, {\n left: chart.plotLeft + 'px',\n top: chart.plotTop + 'px',\n width: chart.plotWidth + 'px',\n height: chart.plotHeight + 'px'\n });\n }\n };\n let loadingDiv = chart.loadingDiv, loadingSpan = chart.loadingSpan;\n // create the layer at the first call\n if (!loadingDiv) {\n chart.loadingDiv = loadingDiv = createElement('div', {\n className: 'highcharts-loading highcharts-loading-hidden'\n }, null, chart.container);\n }\n if (!loadingSpan) {\n chart.loadingSpan = loadingSpan = createElement('span', { className: 'highcharts-loading-inner' }, null, loadingDiv);\n addEvent(chart, 'redraw', setLoadingSize); // #1080\n }\n loadingDiv.className = 'highcharts-loading';\n // Update text\n AST.setElementHTML(loadingSpan, pick(str, options.lang.loading, ''));\n if (!chart.styledMode) {\n // Update visuals\n css(loadingDiv, extend(loadingOptions.style, {\n zIndex: 10\n }));\n css(loadingSpan, loadingOptions.labelStyle);\n // Show it\n if (!chart.loadingShown) {\n css(loadingDiv, {\n opacity: 0,\n display: ''\n });\n animate(loadingDiv, {\n opacity: loadingOptions.style.opacity || 0.5\n }, {\n duration: loadingOptions.showDuration || 0\n });\n }\n }\n chart.loadingShown = true;\n setLoadingSize();\n }\n /**\n * Hide the loading layer.\n *\n * @see Highcharts.Chart#showLoading\n *\n * @sample highcharts/members/chart-hideloading/\n * Show and hide loading from a button\n * @sample stock/members/chart-show-hide-loading/\n * Toggle loading in Highcharts Stock\n *\n * @function Highcharts.Chart#hideLoading\n */\n hideLoading() {\n const options = this.options, loadingDiv = this.loadingDiv;\n if (loadingDiv) {\n loadingDiv.className =\n 'highcharts-loading highcharts-loading-hidden';\n if (!this.styledMode) {\n animate(loadingDiv, {\n opacity: 0\n }, {\n duration: options.loading.hideDuration || 100,\n complete: function () {\n css(loadingDiv, { display: 'none' });\n }\n });\n }\n }\n this.loadingShown = false;\n }\n /**\n * A generic function to update any element of the chart. Elements can be\n * enabled and disabled, moved, re-styled, re-formatted etc.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](https://api.highcharts.com/highcharts/xAxis),\n * [yAxis](https://api.highcharts.com/highcharts/yAxis) or\n * [series](https://api.highcharts.com/highcharts/series). For these\n * collections, an `id` option is used to map the new option set to an\n * existing object. If an existing object of the same id is not found, the\n * corresponding item is updated. So for example, running `chart.update`\n * with a series item without an id, will cause the existing chart's series\n * with the same index in the series array to be updated. When the\n * `oneToOne` parameter is true, `chart.update` will also take care of\n * adding and removing items from the collection. Read more under the\n * parameter description below.\n *\n * Note that when changing series data, `chart.update` may mutate the passed\n * data options.\n *\n * See also the\n * [responsive option set](https://api.highcharts.com/highcharts/responsive).\n * Switching between `responsive.rules` basically runs `chart.update` under\n * the hood.\n *\n * @sample highcharts/members/chart-update/\n * Update chart geometry\n *\n * @function Highcharts.Chart#update\n *\n * @param {Highcharts.Options} options\n * A configuration object for the new chart options.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart.\n *\n * @param {boolean} [oneToOne=false]\n * When `true`, the `series`, `xAxis`, `yAxis` and `annotations`\n * collections will be updated one to one, and items will be either\n * added or removed to match the new updated options. For example,\n * if the chart has two series and we call `chart.update` with a\n * configuration containing three series, one will be added. If we\n * call `chart.update` with one series, one will be removed. Setting\n * an empty `series` array will remove all series, but leaving out\n * the`series` property will leave all series untouched. If the\n * series have id's, the new series options will be matched by id,\n * and the remaining ones removed.\n *\n * @param {boolean|Partial} [animation]\n * Whether to apply animation, and optionally animation\n * configuration. When `undefined`, it applies the animation that is\n * set in the `chart.animation` option.\n *\n * @emits Highcharts.Chart#event:update\n * @emits Highcharts.Chart#event:afterUpdate\n */\n update(options, redraw, oneToOne, animation) {\n const chart = this, adders = {\n credits: 'addCredits',\n title: 'setTitle',\n subtitle: 'setSubtitle',\n caption: 'setCaption'\n }, isResponsiveOptions = options.isResponsiveOptions, itemsForRemoval = [];\n let updateAllAxes, updateAllSeries, runSetSize;\n fireEvent(chart, 'update', { options: options });\n // If there are responsive rules in action, undo the responsive rules\n // before we apply the updated options and replay the responsive rules\n // on top from the chart.redraw function (#9617).\n if (!isResponsiveOptions) {\n chart.setResponsive(false, true);\n }\n options = diffObjects(options, chart.options);\n chart.userOptions = merge(chart.userOptions, options);\n // If the top-level chart option is present, some special updates are\n // required\n const optionsChart = options.chart;\n if (optionsChart) {\n merge(true, chart.options.chart, optionsChart);\n // Add support for deprecated zooming options like zoomType, #17861\n this.setZoomOptions();\n // Setter function\n if ('className' in optionsChart) {\n chart.setClassName(optionsChart.className);\n }\n if ('inverted' in optionsChart ||\n 'polar' in optionsChart ||\n 'type' in optionsChart) {\n // Parse options.chart.inverted and options.chart.polar together\n // with the available series.\n chart.propFromSeries();\n updateAllAxes = true;\n }\n if ('alignTicks' in optionsChart) { // #6452\n updateAllAxes = true;\n }\n if ('events' in optionsChart) {\n // Chart event handlers\n registerEventOptions(this, optionsChart);\n }\n objectEach(optionsChart, function (val, key) {\n if (chart.propsRequireUpdateSeries.indexOf('chart.' + key) !==\n -1) {\n updateAllSeries = true;\n }\n // Only dirty box\n if (chart.propsRequireDirtyBox.indexOf(key) !== -1) {\n chart.isDirtyBox = true;\n }\n // Chart setSize\n if (chart.propsRequireReflow.indexOf(key) !== -1) {\n if (isResponsiveOptions) {\n chart.isDirtyBox = true;\n }\n else {\n runSetSize = true;\n }\n }\n });\n if (!chart.styledMode && optionsChart.style) {\n chart.renderer.setStyle(chart.options.chart.style || {});\n }\n }\n // Moved up, because tooltip needs updated plotOptions (#6218)\n if (!chart.styledMode && options.colors) {\n this.options.colors = options.colors;\n }\n if (options.time) {\n // Maintaining legacy global time. If the chart is instanciated\n // first with global time, then updated with time options, we need\n // to create a new Time instance to avoid mutating the global time\n // (#10536).\n if (this.time === defaultTime) {\n this.time = new Time(options.time);\n }\n // If we're updating, the time class is different from other chart\n // classes (chart.legend, chart.tooltip etc) in that it doesn't know\n // about the chart. The other chart[something].update functions also\n // set the chart.options[something]. For the time class however we\n // need to update the chart options separately. #14230.\n merge(true, chart.options.time, options.time);\n }\n // Some option stuctures correspond one-to-one to chart objects that\n // have update methods, for example\n // options.credits => chart.credits\n // options.legend => chart.legend\n // options.title => chart.title\n // options.tooltip => chart.tooltip\n // options.subtitle => chart.subtitle\n // options.mapNavigation => chart.mapNavigation\n // options.navigator => chart.navigator\n // options.scrollbar => chart.scrollbar\n objectEach(options, function (val, key) {\n if (chart[key] &&\n typeof chart[key].update === 'function') {\n chart[key].update(val, false);\n // If a one-to-one object does not exist, look for an adder function\n }\n else if (typeof chart[adders[key]] === 'function') {\n chart[adders[key]](val);\n // Else, just merge the options. For nodes like loading, noData,\n // plotOptions\n }\n else if (key !== 'colors' &&\n chart.collectionsWithUpdate.indexOf(key) === -1) {\n merge(true, chart.options[key], options[key]);\n }\n if (key !== 'chart' &&\n chart.propsRequireUpdateSeries.indexOf(key) !== -1) {\n updateAllSeries = true;\n }\n });\n // Setters for collections. For axes and series, each item is referred\n // by an id. If the id is not found, it defaults to the corresponding\n // item in the collection, so setting one series without an id, will\n // update the first series in the chart. Setting two series without\n // an id will update the first and the second respectively (#6019)\n // chart.update and responsive.\n this.collectionsWithUpdate.forEach(function (coll) {\n if (options[coll]) {\n splat(options[coll]).forEach(function (newOptions, i) {\n const hasId = defined(newOptions.id);\n let item;\n // Match by id\n if (hasId) {\n item = chart.get(newOptions.id);\n }\n // No match by id found, match by index instead\n if (!item && chart[coll]) {\n item = chart[coll][pick(newOptions.index, i)];\n // Check if we grabbed an item with an exising but\n // different id (#13541). Check that the item in this\n // position is not internal (navigator).\n if (item && ((hasId && defined(item.options.id)) ||\n item.options.isInternal)) {\n item = void 0;\n }\n }\n if (item && item.coll === coll) {\n item.update(newOptions, false);\n if (oneToOne) {\n item.touched = true;\n }\n }\n // If oneToOne and no matching item is found, add one\n if (!item && oneToOne && chart.collectionsWithInit[coll]) {\n chart.collectionsWithInit[coll][0].apply(chart, \n // [newOptions, ...extraArguments, redraw=false]\n [\n newOptions\n ].concat(\n // Not all initializers require extra args\n chart.collectionsWithInit[coll][1] || []).concat([\n false\n ])).touched = true;\n }\n });\n // Add items for removal\n if (oneToOne) {\n chart[coll].forEach(function (item) {\n if (!item.touched && !item.options.isInternal) {\n itemsForRemoval.push(item);\n }\n else {\n delete item.touched;\n }\n });\n }\n }\n });\n itemsForRemoval.forEach(function (item) {\n if (item.chart && item.remove) { // #9097, avoid removing twice\n item.remove(false);\n }\n });\n if (updateAllAxes) {\n chart.axes.forEach(function (axis) {\n axis.update({}, false);\n });\n }\n // Certain options require the whole series structure to be thrown away\n // and rebuilt\n if (updateAllSeries) {\n chart.getSeriesOrderByLinks().forEach(function (series) {\n // Avoid removed navigator series\n if (series.chart) {\n series.update({}, false);\n }\n }, this);\n }\n // Update size. Redraw is forced.\n const newWidth = optionsChart && optionsChart.width;\n const newHeight = optionsChart && (isString(optionsChart.height) ?\n relativeLength(optionsChart.height, newWidth || chart.chartWidth) :\n optionsChart.height);\n if (\n // In this case, run chart.setSize with newWidth and newHeight which\n // are undefined, only for reflowing chart elements because margin\n // or spacing has been set (#8190)\n runSetSize ||\n // In this case, the size is actually set\n (isNumber(newWidth) && newWidth !== chart.chartWidth) ||\n (isNumber(newHeight) && newHeight !== chart.chartHeight)) {\n chart.setSize(newWidth, newHeight, animation);\n }\n else if (pick(redraw, true)) {\n chart.redraw(animation);\n }\n fireEvent(chart, 'afterUpdate', {\n options: options,\n redraw: redraw,\n animation: animation\n });\n }\n /**\n * Shortcut to set the subtitle options. This can also be done from {@link\n * Chart#update} or {@link Chart#setTitle}.\n *\n * @function Highcharts.Chart#setSubtitle\n *\n * @param {Highcharts.SubtitleOptions} options\n * New subtitle options. The subtitle text itself is set by the\n * `options.text` property.\n */\n setSubtitle(options, redraw) {\n this.applyDescription('subtitle', options);\n this.layOutTitles(redraw);\n }\n /**\n * Set the caption options. This can also be done from {@link\n * Chart#update}.\n *\n * @function Highcharts.Chart#setCaption\n *\n * @param {Highcharts.CaptionOptions} options\n * New caption options. The caption text itself is set by the\n * `options.text` property.\n */\n setCaption(options, redraw) {\n this.applyDescription('caption', options);\n this.layOutTitles(redraw);\n }\n /**\n * Display the zoom button, so users can reset zoom to the default view\n * settings.\n *\n * @function Highcharts.Chart#showResetZoom\n *\n * @emits Highcharts.Chart#event:afterShowResetZoom\n * @emits Highcharts.Chart#event:beforeShowResetZoom\n */\n showResetZoom() {\n const chart = this, lang = defaultOptions.lang, btnOptions = chart.zooming.resetButton, theme = btnOptions.theme, alignTo = (btnOptions.relativeTo === 'chart' ||\n btnOptions.relativeTo === 'spacingBox' ?\n null :\n 'scrollablePlotBox');\n /**\n * @private\n */\n function zoomOut() {\n chart.zoomOut();\n }\n fireEvent(this, 'beforeShowResetZoom', null, function () {\n chart.resetZoomButton = chart.renderer\n .button(lang.resetZoom, null, null, zoomOut, theme)\n .attr({\n align: btnOptions.position.align,\n title: lang.resetZoomTitle\n })\n .addClass('highcharts-reset-zoom')\n .add()\n .align(btnOptions.position, false, alignTo);\n });\n fireEvent(this, 'afterShowResetZoom');\n }\n /**\n * Zoom the chart out after a user has zoomed in. See also\n * [Axis.setExtremes](/class-reference/Highcharts.Axis#setExtremes).\n *\n * @function Highcharts.Chart#zoomOut\n *\n * @emits Highcharts.Chart#event:selection\n */\n zoomOut() {\n fireEvent(this, 'selection', { resetSelection: true }, this.zoom);\n }\n /**\n * Zoom into a given portion of the chart given by axis coordinates.\n *\n * @private\n * @function Highcharts.Chart#zoom\n * @param {Highcharts.SelectEventObject} event\n */\n zoom(event) {\n const chart = this, pointer = chart.pointer;\n let displayButton = false, hasZoomed;\n // If zoom is called with no arguments, reset the axes\n if (!event || event.resetSelection) {\n chart.axes.forEach(function (axis) {\n hasZoomed = axis.zoom();\n });\n pointer.initiated = false; // #6804\n }\n else { // else, zoom in on all axes\n event.xAxis.concat(event.yAxis).forEach(function (axisData) {\n const axis = axisData.axis, isXAxis = axis.isXAxis;\n // don't zoom more than minRange\n if (pointer[isXAxis ? 'zoomX' : 'zoomY'] &&\n (defined(pointer.mouseDownX) &&\n defined(pointer.mouseDownY) &&\n chart.isInsidePlot(pointer.mouseDownX - chart.plotLeft, pointer.mouseDownY - chart.plotTop, { axis })) || !defined(chart.inverted ? pointer.mouseDownX : pointer.mouseDownY)) {\n hasZoomed = axis.zoom(axisData.min, axisData.max);\n if (axis.displayBtn) {\n displayButton = true;\n }\n }\n });\n }\n // Show or hide the Reset zoom button\n const resetZoomButton = chart.resetZoomButton;\n if (displayButton && !resetZoomButton) {\n chart.showResetZoom();\n }\n else if (!displayButton && isObject(resetZoomButton)) {\n chart.resetZoomButton = resetZoomButton.destroy();\n }\n // Redraw\n if (hasZoomed) {\n chart.redraw(pick(chart.options.chart.animation, event && event.animation, chart.pointCount < 100));\n }\n }\n /**\n * Pan the chart by dragging the mouse across the pane. This function is\n * called on mouse move, and the distance to pan is computed from chartX\n * compared to the first chartX position in the dragging operation.\n *\n * @private\n * @function Highcharts.Chart#pan\n * @param {Highcharts.PointerEventObject} e\n * @param {string} panning\n */\n pan(e, panning) {\n const chart = this, hoverPoints = chart.hoverPoints, panningOptions = (typeof panning === 'object' ?\n panning :\n {\n enabled: panning,\n type: 'x'\n }), chartOptions = chart.options.chart;\n if (chartOptions && chartOptions.panning) {\n chartOptions.panning = panningOptions;\n }\n const type = panningOptions.type;\n let doRedraw;\n fireEvent(this, 'pan', { originalEvent: e }, function () {\n // remove active points for shared tooltip\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n let axes = chart.xAxis;\n if (type === 'xy') {\n axes = axes.concat(chart.yAxis);\n }\n else if (type === 'y') {\n axes = chart.yAxis;\n }\n const nextMousePos = {};\n axes.forEach(function (axis) {\n if (!axis.options.panningEnabled || axis.options.isInternal) {\n return;\n }\n const horiz = axis.horiz, mousePos = e[horiz ? 'chartX' : 'chartY'], mouseDown = horiz ? 'mouseDownX' : 'mouseDownY', startPos = chart[mouseDown], halfPointRange = axis.minPointOffset || 0, pointRangeDirection = (axis.reversed && !chart.inverted) ||\n (!axis.reversed && chart.inverted) ?\n -1 :\n 1, extremes = axis.getExtremes(), panMin = axis.toValue(startPos - mousePos, true) +\n halfPointRange * pointRangeDirection, panMax = axis.toValue(startPos + axis.len - mousePos, true) -\n ((halfPointRange * pointRangeDirection) ||\n (axis.isXAxis && axis.pointRangePadding) ||\n 0), flipped = panMax < panMin, hasVerticalPanning = axis.hasVerticalPanning();\n let newMin = flipped ? panMax : panMin, newMax = flipped ? panMin : panMax, panningState = axis.panningState, spill;\n // General calculations of panning state.\n // This is related to using vertical panning. (#11315).\n if (hasVerticalPanning &&\n !axis.isXAxis && (!panningState || panningState.isDirty)) {\n axis.series.forEach(function (series) {\n const processedData = series.getProcessedData(true), dataExtremes = series.getExtremes(processedData.yData, true);\n if (!panningState) {\n panningState = {\n startMin: Number.MAX_VALUE,\n startMax: -Number.MAX_VALUE\n };\n }\n if (isNumber(dataExtremes.dataMin) &&\n isNumber(dataExtremes.dataMax)) {\n panningState.startMin = Math.min(pick(series.options.threshold, Infinity), dataExtremes.dataMin, panningState.startMin);\n panningState.startMax = Math.max(pick(series.options.threshold, -Infinity), dataExtremes.dataMax, panningState.startMax);\n }\n });\n }\n const paddedMin = Math.min(pick(panningState && panningState.startMin, extremes.dataMin), halfPointRange ?\n extremes.min :\n axis.toValue(axis.toPixels(extremes.min) -\n axis.minPixelPadding));\n const paddedMax = Math.max(pick(panningState && panningState.startMax, extremes.dataMax), halfPointRange ?\n extremes.max :\n axis.toValue(axis.toPixels(extremes.max) +\n axis.minPixelPadding));\n axis.panningState = panningState;\n // It is not necessary to calculate extremes on ordinal axis,\n // because they are already calculated, so we don't want to\n // override them.\n if (!axis.isOrdinal) {\n // If the new range spills over, either to the min or max,\n // adjust the new range.\n spill = paddedMin - newMin;\n if (spill > 0) {\n newMax += spill;\n newMin = paddedMin;\n }\n spill = newMax - paddedMax;\n if (spill > 0) {\n newMax = paddedMax;\n newMin -= spill;\n }\n // Set new extremes if they are actually new\n if (axis.series.length &&\n newMin !== extremes.min &&\n newMax !== extremes.max &&\n newMin >= paddedMin &&\n newMax <= paddedMax) {\n axis.setExtremes(newMin, newMax, false, false, { trigger: 'pan' });\n if (!chart.resetZoomButton &&\n // Show reset zoom button only when both newMin and\n // newMax values are between padded axis range.\n newMin !== paddedMin &&\n newMax !== paddedMax &&\n type.match('y')) {\n chart.showResetZoom();\n axis.displayBtn = false;\n }\n doRedraw = true;\n }\n // set new reference for next run:\n nextMousePos[mouseDown] = mousePos;\n }\n });\n objectEach(nextMousePos, (pos, down) => {\n chart[down] = pos;\n });\n if (doRedraw) {\n chart.redraw(false);\n }\n css(chart.container, { cursor: 'move' });\n });\n }\n }\n extend(Chart.prototype, {\n // Hook for adding callbacks in modules\n callbacks: [],\n /**\n * These collections (arrays) implement `Chart.addSomethig` method used in\n * chart.update() to create new object in the collection. Equivalent for\n * deleting is resolved by simple `Somethig.remove()`.\n *\n * Note: We need to define these references after initializers are bound to\n * chart's prototype.\n *\n * @private\n */\n collectionsWithInit: {\n // collectionName: [ initializingMethod, [extraArguments] ]\n xAxis: [Chart.prototype.addAxis, [true]],\n yAxis: [Chart.prototype.addAxis, [false]],\n series: [Chart.prototype.addSeries]\n },\n /**\n * These collections (arrays) implement update() methods with support for\n * one-to-one option.\n * @private\n */\n collectionsWithUpdate: [\n 'xAxis',\n 'yAxis',\n 'series'\n ],\n /**\n * These properties cause isDirtyBox to be set to true when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireDirtyBox: [\n 'backgroundColor',\n 'borderColor',\n 'borderWidth',\n 'borderRadius',\n 'plotBackgroundColor',\n 'plotBackgroundImage',\n 'plotBorderColor',\n 'plotBorderWidth',\n 'plotShadow',\n 'shadow'\n ],\n /**\n * These properties require a full reflow of chart elements, best\n * implemented through running `Chart.setSize` internally (#8190).\n * @private\n */\n propsRequireReflow: [\n 'margin',\n 'marginTop',\n 'marginRight',\n 'marginBottom',\n 'marginLeft',\n 'spacing',\n 'spacingTop',\n 'spacingRight',\n 'spacingBottom',\n 'spacingLeft'\n ],\n /**\n * These properties cause all series to be updated when updating. Can be\n * extended from plugins.\n * @private\n */\n propsRequireUpdateSeries: [\n 'chart.inverted',\n 'chart.polar',\n 'chart.ignoreHiddenSeries',\n 'chart.type',\n 'colors',\n 'plotOptions',\n 'time',\n 'tooltip'\n ]\n });\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback for chart constructors.\n *\n * @callback Highcharts.ChartCallbackFunction\n *\n * @param {Highcharts.Chart} chart\n * Created chart.\n */\n /**\n * Format a number and return a string based on input settings.\n *\n * @callback Highcharts.NumberFormatterCallbackFunction\n *\n * @param {number} number\n * The input number to format.\n *\n * @param {number} decimals\n * The amount of decimals. A value of -1 preserves the amount in the\n * input number.\n *\n * @param {string} [decimalPoint]\n * The decimal point, defaults to the one given in the lang options, or\n * a dot.\n *\n * @param {string} [thousandsSep]\n * The thousands separator, defaults to the one given in the lang\n * options, or a space character.\n *\n * @return {string} The formatted number.\n */\n /**\n * The chart title. The title has an `update` method that allows modifying the\n * options directly or indirectly via `chart.update`.\n *\n * @interface Highcharts.TitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the title.\n *\n * @function Highcharts.TitleObject#update\n *\n * @param {Highcharts.TitleOptions} titleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the title is altered. If doing more\n * operations on the chart, it is a good idea to set redraw to false and\n * call {@link Chart#redraw} after.\n */\n /**\n * The chart subtitle. The subtitle has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.SubtitleObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the subtitle.\n *\n * @function Highcharts.SubtitleObject#update\n *\n * @param {Highcharts.SubtitleOptions} subtitleOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the subtitle is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * The chart caption. The caption has an `update` method that\n * allows modifying the options directly or indirectly via\n * `chart.update`.\n *\n * @interface Highcharts.CaptionObject\n * @extends Highcharts.SVGElement\n */ /**\n * Modify options for the caption.\n *\n * @function Highcharts.CaptionObject#update\n *\n * @param {Highcharts.CaptionOptions} captionOptions\n * Options to modify.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart after the caption is altered. If doing\n * more operations on the chart, it is a good idea to set redraw to false\n * and call {@link Chart#redraw} after.\n */\n /**\n * @interface Highcharts.ChartIsInsideOptionsObject\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#axis\n * @type {Highcharts.Axis|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreX\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#ignoreY\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#inverted\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#paneCoordinates\n * @type {boolean|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#series\n * @type {Highcharts.Series|undefined}\n */ /**\n * @name Highcharts.ChartIsInsideOptionsObject#visiblePlotOnly\n * @type {boolean|undefined}\n */\n ''; // keeps doclets above in JS file\n\n return Chart;\n });\n _registerModule(_modules, 'Extensions/ScrollablePlotArea.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Series/Series.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (A, Axis, Chart, Series, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * Highcharts feature to make the Y axis stay fixed when scrolling the chart\n * horizontally on mobile devices. Supports left and right side axes.\n */\n /*\n WIP on vertical scrollable plot area (#9378). To do:\n - Bottom axis positioning\n - Test with Gantt\n - Look for size optimizing the code\n - API and demos\n */\n const { stop } = A;\n const { addEvent, createElement, defined, merge, pick } = U;\n /* eslint-disable no-invalid-this, valid-jsdoc */\n addEvent(Chart, 'afterSetChartSize', function (e) {\n let scrollablePlotArea = this.options.chart.scrollablePlotArea, scrollableMinWidth = scrollablePlotArea && scrollablePlotArea.minWidth, scrollableMinHeight = scrollablePlotArea && scrollablePlotArea.minHeight, scrollablePixelsX, scrollablePixelsY, corrections;\n if (!this.renderer.forExport) {\n // The amount of pixels to scroll, the difference between chart\n // width and scrollable width\n if (scrollableMinWidth) {\n this.scrollablePixelsX = scrollablePixelsX = Math.max(0, scrollableMinWidth - this.chartWidth);\n if (scrollablePixelsX) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.width = this.plotWidth += scrollablePixelsX;\n if (this.inverted) {\n this.clipBox.height += scrollablePixelsX;\n }\n else {\n this.clipBox.width += scrollablePixelsX;\n }\n corrections = {\n // Corrections for right side\n 1: { name: 'right', value: scrollablePixelsX }\n };\n }\n // Currently we can only do either X or Y\n }\n else if (scrollableMinHeight) {\n this.scrollablePixelsY = scrollablePixelsY = Math.max(0, scrollableMinHeight - this.chartHeight);\n if (defined(scrollablePixelsY)) {\n this.scrollablePlotBox = (this.renderer.scrollablePlotBox = merge(this.plotBox));\n this.plotBox.height = this.plotHeight += scrollablePixelsY;\n if (this.inverted) {\n this.clipBox.width += scrollablePixelsY;\n }\n else {\n this.clipBox.height += scrollablePixelsY;\n }\n corrections = {\n 2: { name: 'bottom', value: scrollablePixelsY }\n };\n }\n }\n if (corrections && !e.skipAxes) {\n this.axes.forEach(function (axis) {\n // For right and bottom axes, only fix the plot line length\n if (corrections[axis.side]) {\n // Get the plot lines right in getPlotLinePath,\n // temporarily set it to the adjusted plot width.\n axis.getPlotLinePath = function () {\n let marginName = corrections[axis.side].name, correctionValue = corrections[axis.side].value, \n // axis.right or axis.bottom\n margin = this[marginName], path;\n // Temporarily adjust\n this[marginName] = margin - correctionValue;\n path = Axis.prototype.getPlotLinePath.apply(this, arguments);\n // Reset\n this[marginName] = margin;\n return path;\n };\n }\n else {\n // Apply the corrected plotWidth\n axis.setAxisSize();\n axis.setAxisTranslation();\n }\n });\n }\n }\n });\n addEvent(Chart, 'render', function () {\n if (this.scrollablePixelsX || this.scrollablePixelsY) {\n if (this.setUpScrolling) {\n this.setUpScrolling();\n }\n this.applyFixed();\n }\n else if (this.fixedDiv) { // Has been in scrollable mode\n this.applyFixed();\n }\n });\n /**\n * @private\n * @function Highcharts.Chart#setUpScrolling\n * @return {void}\n */\n Chart.prototype.setUpScrolling = function () {\n const css = {\n WebkitOverflowScrolling: 'touch',\n overflowX: 'hidden',\n overflowY: 'hidden'\n };\n if (this.scrollablePixelsX) {\n css.overflowX = 'auto';\n }\n if (this.scrollablePixelsY) {\n css.overflowY = 'auto';\n }\n // Insert a container with position relative\n // that scrolling and fixed container renders to (#10555)\n this.scrollingParent = createElement('div', {\n className: 'highcharts-scrolling-parent'\n }, {\n position: 'relative'\n }, this.renderTo);\n // Add the necessary divs to provide scrolling\n this.scrollingContainer = createElement('div', {\n 'className': 'highcharts-scrolling'\n }, css, this.scrollingParent);\n // On scroll, reset the chart position because it applies to the scrolled\n // container\n let lastHoverPoint;\n addEvent(this.scrollingContainer, 'scroll', () => {\n if (this.pointer) {\n delete this.pointer.chartPosition;\n if (this.hoverPoint) {\n lastHoverPoint = this.hoverPoint;\n }\n this.pointer.runPointActions(void 0, lastHoverPoint, true);\n }\n });\n this.innerContainer = createElement('div', {\n 'className': 'highcharts-inner-container'\n }, null, this.scrollingContainer);\n // Now move the container inside\n this.innerContainer.appendChild(this.container);\n // Don't run again\n this.setUpScrolling = null;\n };\n /**\n * These elements are moved over to the fixed renderer and stay fixed when the\n * user scrolls the chart\n * @private\n */\n Chart.prototype.moveFixedElements = function () {\n let container = this.container, fixedRenderer = this.fixedRenderer, fixedSelectors = [\n '.highcharts-breadcrumbs-group',\n '.highcharts-contextbutton',\n '.highcharts-credits',\n '.highcharts-legend',\n '.highcharts-legend-checkbox',\n '.highcharts-navigator-series',\n '.highcharts-navigator-xaxis',\n '.highcharts-navigator-yaxis',\n '.highcharts-navigator',\n '.highcharts-reset-zoom',\n '.highcharts-drillup-button',\n '.highcharts-scrollbar',\n '.highcharts-subtitle',\n '.highcharts-title'\n ], axisClass;\n if (this.scrollablePixelsX && !this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n else if (this.scrollablePixelsX && this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && !this.inverted) {\n axisClass = '.highcharts-xaxis';\n }\n else if (this.scrollablePixelsY && this.inverted) {\n axisClass = '.highcharts-yaxis';\n }\n if (axisClass) {\n fixedSelectors.push(`${axisClass}:not(.highcharts-radial-axis)`, `${axisClass}-labels:not(.highcharts-radial-axis-labels)`);\n }\n fixedSelectors.forEach(function (className) {\n [].forEach.call(container.querySelectorAll(className), function (elem) {\n (elem.namespaceURI === fixedRenderer.SVG_NS ?\n fixedRenderer.box :\n fixedRenderer.box.parentNode).appendChild(elem);\n elem.style.pointerEvents = 'auto';\n });\n });\n };\n /**\n * @private\n * @function Highcharts.Chart#applyFixed\n * @return {void}\n */\n Chart.prototype.applyFixed = function () {\n const firstTime = !this.fixedDiv, chartOptions = this.options.chart, scrollableOptions = chartOptions.scrollablePlotArea, Renderer = RendererRegistry.getRendererType();\n let fixedRenderer, scrollableWidth, scrollableHeight;\n // First render\n if (firstTime) {\n this.fixedDiv = createElement('div', {\n className: 'highcharts-fixed'\n }, {\n position: 'absolute',\n overflow: 'hidden',\n pointerEvents: 'none',\n zIndex: (chartOptions.style && chartOptions.style.zIndex || 0) + 2,\n top: 0\n }, null, true);\n if (this.scrollingContainer) {\n this.scrollingContainer.parentNode.insertBefore(this.fixedDiv, this.scrollingContainer);\n }\n this.renderTo.style.overflow = 'visible';\n this.fixedRenderer = fixedRenderer = new Renderer(this.fixedDiv, this.chartWidth, this.chartHeight, this.options.chart.style);\n // Mask\n this.scrollableMask = fixedRenderer\n .path()\n .attr({\n fill: this.options.chart.backgroundColor || '#fff',\n 'fill-opacity': pick(scrollableOptions.opacity, 0.85),\n zIndex: -1\n })\n .addClass('highcharts-scrollable-mask')\n .add();\n addEvent(this, 'afterShowResetZoom', this.moveFixedElements);\n addEvent(this, 'afterApplyDrilldown', this.moveFixedElements);\n addEvent(this, 'afterLayOutTitles', this.moveFixedElements);\n }\n else {\n // Set the size of the fixed renderer to the visible width\n this.fixedRenderer.setSize(this.chartWidth, this.chartHeight);\n }\n if (this.scrollableDirty || firstTime) {\n this.scrollableDirty = false;\n this.moveFixedElements();\n }\n // Increase the size of the scrollable renderer and background\n scrollableWidth = this.chartWidth + (this.scrollablePixelsX || 0);\n scrollableHeight = this.chartHeight + (this.scrollablePixelsY || 0);\n stop(this.container);\n this.container.style.width = scrollableWidth + 'px';\n this.container.style.height = scrollableHeight + 'px';\n this.renderer.boxWrapper.attr({\n width: scrollableWidth,\n height: scrollableHeight,\n viewBox: [0, 0, scrollableWidth, scrollableHeight].join(' ')\n });\n this.chartBackground.attr({\n width: scrollableWidth,\n height: scrollableHeight\n });\n this.scrollingContainer.style.height = this.chartHeight + 'px';\n // Set scroll position\n if (firstTime) {\n if (scrollableOptions.scrollPositionX) {\n this.scrollingContainer.scrollLeft =\n this.scrollablePixelsX *\n scrollableOptions.scrollPositionX;\n }\n if (scrollableOptions.scrollPositionY) {\n this.scrollingContainer.scrollTop =\n this.scrollablePixelsY *\n scrollableOptions.scrollPositionY;\n }\n }\n // Mask behind the left and right side\n let axisOffset = this.axisOffset, maskTop = this.plotTop - axisOffset[0] - 1, maskLeft = this.plotLeft - axisOffset[3] - 1, maskBottom = this.plotTop + this.plotHeight + axisOffset[2] + 1, maskRight = this.plotLeft + this.plotWidth + axisOffset[1] + 1, maskPlotRight = this.plotLeft + this.plotWidth -\n (this.scrollablePixelsX || 0), maskPlotBottom = this.plotTop + this.plotHeight -\n (this.scrollablePixelsY || 0), d;\n if (this.scrollablePixelsX) {\n d = [\n // Left side\n ['M', 0, maskTop],\n ['L', this.plotLeft - 1, maskTop],\n ['L', this.plotLeft - 1, maskBottom],\n ['L', 0, maskBottom],\n ['Z'],\n // Right side\n ['M', maskPlotRight, maskTop],\n ['L', this.chartWidth, maskTop],\n ['L', this.chartWidth, maskBottom],\n ['L', maskPlotRight, maskBottom],\n ['Z']\n ];\n }\n else if (this.scrollablePixelsY) {\n d = [\n // Top side\n ['M', maskLeft, 0],\n ['L', maskLeft, this.plotTop - 1],\n ['L', maskRight, this.plotTop - 1],\n ['L', maskRight, 0],\n ['Z'],\n // Bottom side\n ['M', maskLeft, maskPlotBottom],\n ['L', maskLeft, this.chartHeight],\n ['L', maskRight, this.chartHeight],\n ['L', maskRight, maskPlotBottom],\n ['Z']\n ];\n }\n else {\n d = [['M', 0, 0]];\n }\n if (this.redrawTrigger !== 'adjustHeight') {\n this.scrollableMask.attr({ d });\n }\n };\n addEvent(Axis, 'afterInit', function () {\n this.chart.scrollableDirty = true;\n });\n addEvent(Series, 'show', function () {\n this.chart.scrollableDirty = true;\n });\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Options for a scrollable plot area. This feature provides a minimum size for\n * the plot area of the chart. If the size gets smaller than this, typically\n * on mobile devices, a native browser scrollbar is presented. This scrollbar\n * provides smooth scrolling for the contents of the plot area, whereas the\n * title, legend and unaffected axes are fixed.\n *\n * Since v7.1.2, a scrollable plot area can be defined for either horizontal or\n * vertical scrolling, depending on whether the `minWidth` or `minHeight`\n * option is set.\n *\n * @sample highcharts/chart/scrollable-plotarea\n * Scrollable plot area\n * @sample highcharts/chart/scrollable-plotarea-vertical\n * Vertically scrollable plot area\n * @sample {gantt} gantt/chart/scrollable-plotarea-vertical\n * Gantt chart with vertically scrollable plot area\n *\n * @since 6.1.0\n * @product highcharts gantt\n * @apioption chart.scrollablePlotArea\n */\n /**\n * The minimum height for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.minHeight\n */\n /**\n * The minimum width for the plot area. If it gets smaller than this, the plot\n * area will become scrollable.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.minWidth\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the left and 1 aligns it to the right.\n * Typically we would use 1 if the chart has right aligned Y axes.\n *\n * @type {number}\n * @since 6.1.0\n * @apioption chart.scrollablePlotArea.scrollPositionX\n */\n /**\n * The initial scrolling position of the scrollable plot area. Ranges from 0 to\n * 1, where 0 aligns the plot area to the top and 1 aligns it to the bottom.\n *\n * @type {number}\n * @since 7.1.2\n * @apioption chart.scrollablePlotArea.scrollPositionY\n */\n /**\n * The opacity of mask applied on one of the sides of the plot\n * area.\n *\n * @sample {highcharts} highcharts/chart/scrollable-plotarea-opacity\n * Disabled opacity for the mask\n *\n * @type {number}\n * @default 0.85\n * @since 7.1.1\n * @apioption chart.scrollablePlotArea.opacity\n */\n (''); // keep doclets above in transpiled file\n\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackItem.js', [_modules['Core/Templating.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (T, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = T;\n const { series: Series } = SeriesRegistry;\n const { destroyObjectProperties, fireEvent, isNumber, merge, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The class for stacks. Each stack, on a specific X value and either negative\n * or positive, has its own stack item.\n * @private\n */\n class StackItem {\n /* *\n *\n * Constructor\n *\n * */\n constructor(axis, options, negativeValue, x, stackOption) {\n const inverted = axis.chart.inverted, reversed = axis.reversed;\n this.axis = axis;\n // The stack goes to the left either if the stack has negative value\n // or when axis is reversed. XOR operator.\n const isNegative = (this.isNegative = !!negativeValue !== !!reversed);\n // Save the options to be able to style the label\n this.options = options = options || {};\n // Save the x value to be able to position the label later\n this.x = x;\n // Initialize total value\n this.total = null;\n this.cumulative = null;\n // This will keep each points' extremes stored by series.index and point\n // index\n this.points = {};\n this.hasValidPoints = false;\n // Save the stack option on the series configuration object,\n // and whether to treat it as percent\n this.stack = stackOption;\n this.leftCliff = 0;\n this.rightCliff = 0;\n // The align options and text align varies on whether the stack is\n // negative and if the chart is inverted or not.\n // First test the user supplied value, then use the dynamic.\n this.alignOptions = {\n align: options.align ||\n (inverted ? (isNegative ? 'left' : 'right') : 'center'),\n verticalAlign: options.verticalAlign ||\n (inverted ? 'middle' : isNegative ? 'bottom' : 'top'),\n y: options.y,\n x: options.x\n };\n this.textAlign =\n options.textAlign ||\n (inverted ? (!isNegative ? 'left' : 'right') : 'center');\n }\n /**\n * @private\n */\n destroy() {\n destroyObjectProperties(this, this.axis);\n }\n /**\n * Renders the stack total label and adds it to the stack label group.\n * @private\n */\n render(group) {\n const chart = this.axis.chart, options = this.options, formatOption = options.format, \n // Format the text in the label.\n str = formatOption ?\n format(formatOption, this, chart) :\n options.formatter.call(this);\n // Change the text to reflect the new total and set visibility to hidden\n // in case the serie is hidden\n if (this.label) {\n this.label.attr({ text: str, visibility: 'hidden' });\n }\n else {\n // Create new label\n this.label = chart.renderer.label(str, null, void 0, options.shape, void 0, void 0, options.useHTML, false, 'stack-labels');\n const attr = {\n r: options.borderRadius || 0,\n text: str,\n // set default padding to 5 as it is in datalabels #12308\n padding: pick(options.padding, 5),\n visibility: 'hidden' // hidden until setOffset is called\n };\n if (!chart.styledMode) {\n attr.fill = options.backgroundColor;\n attr.stroke = options.borderColor;\n attr['stroke-width'] = options.borderWidth;\n this.label.css(options.style || {});\n }\n this.label.attr(attr);\n if (!this.label.added) {\n this.label.add(group); // add to the labels-group\n }\n }\n // Rank it higher than data labels (#8742)\n this.label.labelrank = chart.plotSizeY;\n fireEvent(this, 'afterRender');\n }\n /**\n * Sets the offset that the stack has from the x value and repositions the\n * label.\n * @private\n */\n setOffset(xOffset, width, boxBottom, boxTop, defaultX, xAxis) {\n const { alignOptions, axis, label, options, textAlign } = this, chart = axis.chart, stackBox = this.getStackBox({\n xOffset,\n width,\n boxBottom,\n boxTop,\n defaultX,\n xAxis\n }), { verticalAlign } = alignOptions;\n if (label && stackBox) {\n const labelBox = label.getBBox(), padding = label.padding;\n let isJustify = pick(options.overflow, 'justify') === 'justify', visible;\n // Reset alignOptions property after justify #12337\n alignOptions.x = options.x || 0;\n alignOptions.y = options.y || 0;\n // Calculate the adjusted Stack position, to take into consideration\n // The size if the labelBox and vertical alignment as\n // well as the text alignment. It's need to be done to work with\n // default SVGLabel.align/justify methods.\n const { x, y } = this.adjustStackPosition({\n labelBox,\n verticalAlign,\n textAlign\n });\n stackBox.x -= x;\n stackBox.y -= y;\n // Align the label to the adjusted box.\n label.align(alignOptions, false, stackBox);\n // Check if label is inside the plotArea #12294\n visible = chart.isInsidePlot(label.alignAttr.x + alignOptions.x + x, label.alignAttr.y + alignOptions.y + y);\n if (!visible) {\n isJustify = false;\n }\n if (isJustify) {\n // Justify stackLabel into the alignBox\n Series.prototype.justifyDataLabel.call(axis, label, alignOptions, label.alignAttr, labelBox, stackBox);\n }\n // Add attr to aviod the default animation of justifyDataLabel.\n // Also add correct rotation with its rotation origin. #15129\n label.attr({\n x: label.alignAttr.x,\n y: label.alignAttr.y,\n rotation: options.rotation,\n rotationOriginX: labelBox.width / 2,\n rotationOriginY: labelBox.height / 2\n });\n // Check if the dataLabel should be visible.\n if (pick(!isJustify && options.crop, true)) {\n visible =\n isNumber(label.x) &&\n isNumber(label.y) &&\n chart.isInsidePlot(label.x - padding + label.width, label.y) &&\n chart.isInsidePlot(label.x + padding, label.y);\n }\n label[visible ? 'show' : 'hide']();\n }\n fireEvent(this, 'afterSetOffset', { xOffset, width });\n }\n /**\n * Adjust the stack BBox position, to take into consideration the alignment\n * of the dataLabel. This is necessary to make the stackDataLabel work with\n * core methods like `SVGLabel.adjust` and `Series.justifyDataLabel`.\n * @param AdjustStackPositionProps\n * @return {{x: number, y: number}} Adjusted BBox position of the stack.\n */\n adjustStackPosition({ labelBox, verticalAlign, textAlign }) {\n const factorMap = {\n bottom: 0,\n middle: 1,\n top: 2,\n right: 1,\n center: 0,\n left: -1\n }, verticalAlignFactor = factorMap[verticalAlign], textAlignFactor = factorMap[textAlign];\n return {\n x: labelBox.width / 2 + (labelBox.width / 2) * textAlignFactor,\n y: (labelBox.height / 2) * verticalAlignFactor\n };\n }\n /**\n * Get the bbox of the stack.\n * @private\n * @function Highcharts.StackItem#getStackBox\n * @return {BBoxObject} The x, y, height, width of the stack.\n */\n getStackBox(stackBoxProps) {\n const stackItem = this, axis = this.axis, chart = axis.chart, { boxTop, defaultX, xOffset, width, boxBottom } = stackBoxProps, totalStackValue = axis.stacking.usePercentage ?\n 100 :\n pick(boxTop, this.total, 0), y = axis.toPixels(totalStackValue), xAxis = stackBoxProps.xAxis || chart.xAxis[0], x = pick(defaultX, xAxis.translate(this.x)) + xOffset, yZero = axis.toPixels(boxBottom ||\n (isNumber(axis.min) &&\n axis.logarithmic &&\n axis.logarithmic.lin2log(axis.min)) ||\n 0), height = Math.abs(y - yZero), inverted = chart.inverted, neg = stackItem.isNegative;\n return inverted ?\n {\n x: (neg ? y : y - height) - chart.plotLeft,\n y: xAxis.height - x - width,\n width: height,\n height: width\n } : {\n x: x + xAxis.transB - chart.plotLeft,\n y: (neg ? y - height : y) - chart.plotTop,\n width: width,\n height: height\n };\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Stack of data points\n *\n * @product highcharts\n *\n * @interface Highcharts.StackItemObject\n */ /**\n * Alignment settings\n * @name Highcharts.StackItemObject#alignOptions\n * @type {Highcharts.AlignObject}\n */ /**\n * Related axis\n * @name Highcharts.StackItemObject#axis\n * @type {Highcharts.Axis}\n */ /**\n * Cumulative value of the stacked data points\n * @name Highcharts.StackItemObject#cumulative\n * @type {number}\n */ /**\n * True if on the negative side\n * @name Highcharts.StackItemObject#isNegative\n * @type {boolean}\n */ /**\n * Related SVG element\n * @name Highcharts.StackItemObject#label\n * @type {Highcharts.SVGElement}\n */ /**\n * Related stack options\n * @name Highcharts.StackItemObject#options\n * @type {Highcharts.YAxisStackLabelsOptions}\n */ /**\n * Total value of the stacked data points\n * @name Highcharts.StackItemObject#total\n * @type {number}\n */ /**\n * Shared x value of the stack\n * @name Highcharts.StackItemObject#x\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return StackItem;\n });\n _registerModule(_modules, 'Core/Axis/Stacking/StackingAxis.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Utilities.js']], function (A, Axis, SeriesRegistry, StackItem, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getDeferredAnimation } = A;\n const { series: { prototype: seriesProto } } = SeriesRegistry;\n const { addEvent, correctFloat, defined, destroyObjectProperties, fireEvent, isArray, isNumber, objectEach, pick } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Generate stacks for each series and calculate stacks total values\n *\n * @private\n * @function Highcharts.Chart#getStacks\n */\n function chartGetStacks() {\n const chart = this, inverted = chart.inverted;\n // reset stacks for each yAxis\n chart.yAxis.forEach((axis) => {\n if (axis.stacking && axis.stacking.stacks && axis.hasVisibleSeries) {\n axis.stacking.oldStacks = axis.stacking.stacks;\n }\n });\n chart.series.forEach((series) => {\n const xAxisOptions = series.xAxis && series.xAxis.options || {};\n if (series.options.stacking &&\n (series.visible === true ||\n chart.options.chart.ignoreHiddenSeries === false)) {\n series.stackKey = [\n series.type,\n pick(series.options.stack, ''),\n inverted ? xAxisOptions.top : xAxisOptions.left,\n inverted ? xAxisOptions.height : xAxisOptions.width\n ].join(',');\n }\n });\n }\n /**\n * @private\n */\n function onAxisDestroy() {\n const stacking = this.stacking;\n if (!stacking) {\n return;\n }\n const stacks = stacking.stacks;\n // Destroy each stack total\n objectEach(stacks, function (stack, stackKey) {\n destroyObjectProperties(stack);\n stacks[stackKey] = null;\n });\n if (stacking &&\n stacking.stackTotalGroup) {\n stacking.stackTotalGroup.destroy();\n }\n }\n /**\n * @private\n */\n function onAxisInit() {\n if (this.coll === 'yAxis' && !this.stacking) {\n this.stacking = new AxisAdditions(this);\n }\n }\n /**\n * Get stack indicator, according to it's x-value, to determine points with the\n * same x-value\n *\n * @private\n * @function Highcharts.Series#getStackIndicator\n */\n function seriesGetStackIndicator(stackIndicator, x, index, key) {\n // Update stack indicator, when:\n // first point in a stack || x changed || stack type (negative vs positive)\n // changed:\n if (!defined(stackIndicator) ||\n stackIndicator.x !== x ||\n (key && stackIndicator.stackKey !== key)) {\n stackIndicator = {\n x: x,\n index: 0,\n key: key,\n stackKey: key\n };\n }\n else {\n (stackIndicator).index++;\n }\n stackIndicator.key =\n [index, x, stackIndicator.index].join(',');\n return stackIndicator;\n }\n /**\n * Iterate over all stacks and compute the absolute values to percent\n *\n * @private\n * @function Highcharts.Series#modifyStacks\n */\n function seriesModifyStacks() {\n const series = this, yAxis = series.yAxis, stackKey = series.stackKey, stacks = yAxis.stacking.stacks, processedXData = series.processedXData, stacking = series.options.stacking, stacker = series[stacking + 'Stacker'];\n let stackIndicator;\n if (stacker) { // Modifier function exists (Series.percentStacker etc.)\n [stackKey, '-' + stackKey].forEach((key) => {\n let i = processedXData.length, x, stack, pointExtremes;\n while (i--) {\n x = processedXData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index, key);\n stack = stacks[key] && stacks[key][x];\n pointExtremes =\n stack && stack.points[stackIndicator.key];\n if (pointExtremes) {\n stacker.call(series, pointExtremes, stack, i);\n }\n }\n });\n }\n }\n /**\n * Modifier function for percent stacks. Blows up the stack to 100%.\n *\n * @private\n * @function Highcharts.Series#percentStacker\n */\n function seriesPercentStacker(pointExtremes, stack, i) {\n const totalFactor = stack.total ? 100 / stack.total : 0;\n // Y bottom value\n pointExtremes[0] = correctFloat(pointExtremes[0] * totalFactor);\n // Y value\n pointExtremes[1] = correctFloat(pointExtremes[1] * totalFactor);\n this.stackedYData[i] = pointExtremes[1];\n }\n /**\n * Set grouped points in a stack-like object. When `centerInCategory` is true,\n * and `stacking` is not enabled, we need a pseudo (horizontal) stack in order\n * to handle grouping of points within the same category.\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n * @return {void}\n */\n function seriesSetGroupedPoints() {\n const stacking = this.yAxis.stacking;\n if (this.options.centerInCategory &&\n (this.is('column') || this.is('columnrange')) &&\n // With stacking enabled, we already have stacks that we can compute\n // from\n !this.options.stacking &&\n // With only one series, we don't need to consider centerInCategory\n this.chart.series.length > 1) {\n seriesProto.setStackedPoints.call(this, 'group');\n // After updating, if we now have proper stacks, we must delete the group\n // pseudo stacks (#14986)\n }\n else if (stacking) {\n objectEach(stacking.stacks, (type, key) => {\n if (key.slice(-5) === 'group') {\n objectEach(type, (stack) => stack.destroy());\n delete stacking.stacks[key];\n }\n });\n }\n }\n /**\n * Adds series' points value to corresponding stack\n *\n * @private\n * @function Highcharts.Series#setStackedPoints\n */\n function seriesSetStackedPoints(stackingParam) {\n const chart = this.chart, stacking = stackingParam || this.options.stacking;\n if (!stacking || (this.visible !== true &&\n chart.options.chart.ignoreHiddenSeries !== false)) {\n return;\n }\n const series = this, xData = series.processedXData, yData = series.processedYData, stackedYData = [], yDataLength = yData.length, seriesOptions = series.options, threshold = seriesOptions.threshold, stackThreshold = pick(seriesOptions.startFromThreshold && threshold, 0), stackOption = seriesOptions.stack, stackKey = stackingParam ? `${series.type},${stacking}` : series.stackKey, negKey = '-' + stackKey, negStacks = series.negStacks, yAxis = stacking === 'group' ?\n chart.yAxis[0] :\n series.yAxis, stacks = yAxis.stacking.stacks, oldStacks = yAxis.stacking.oldStacks;\n let stackIndicator, isNegative, stack, other, key, pointKey, i, x, y;\n yAxis.stacking.stacksTouched += 1;\n // loop over the non-null y values and read them into a local array\n for (i = 0; i < yDataLength; i++) {\n x = xData[i];\n y = yData[i];\n stackIndicator = series.getStackIndicator(stackIndicator, x, series.index);\n pointKey = stackIndicator.key;\n // Read stacked values into a stack based on the x value,\n // the sign of y and the stack key. Stacking is also handled for null\n // values (#739)\n isNegative = negStacks && y < (stackThreshold ? 0 : threshold);\n key = isNegative ? negKey : stackKey;\n // Create empty object for this stack if it doesn't exist yet\n if (!stacks[key]) {\n stacks[key] = {};\n }\n // Initialize StackItem for this x\n if (!stacks[key][x]) {\n if (oldStacks[key] &&\n oldStacks[key][x]) {\n stacks[key][x] = oldStacks[key][x];\n stacks[key][x].total = null;\n }\n else {\n stacks[key][x] = new StackItem(yAxis, yAxis.options.stackLabels, !!isNegative, x, stackOption);\n }\n }\n // If the StackItem doesn't exist, create it first\n stack = stacks[key][x];\n if (y !== null) {\n stack.points[pointKey] = stack.points[series.index] =\n [pick(stack.cumulative, stackThreshold)];\n // Record the base of the stack\n if (!defined(stack.cumulative)) {\n stack.base = pointKey;\n }\n stack.touched = yAxis.stacking.stacksTouched;\n // In area charts, if there are multiple points on the same X value,\n // let the area fill the full span of those points\n if (stackIndicator.index > 0 && series.singleStacks === false) {\n stack.points[pointKey][0] =\n stack.points[series.index + ',' + x + ',0'][0];\n }\n // When updating to null, reset the point stack (#7493)\n }\n else {\n stack.points[pointKey] = stack.points[series.index] =\n null;\n }\n // Add value to the stack total\n if (stacking === 'percent') {\n // Percent stacked column, totals are the same for the positive and\n // negative stacks\n other = isNegative ? stackKey : negKey;\n if (negStacks && stacks[other] && stacks[other][x]) {\n other = stacks[other][x];\n stack.total = other.total =\n Math.max(other.total, stack.total) +\n Math.abs(y) ||\n 0;\n // Percent stacked areas\n }\n else {\n stack.total =\n correctFloat(stack.total + (Math.abs(y) || 0));\n }\n }\n else if (stacking === 'group') {\n if (isArray(y)) {\n y = y[0];\n }\n // In this stack, the total is the number of valid points\n if (y !== null) {\n stack.total = (stack.total || 0) + 1;\n }\n }\n else {\n stack.total = correctFloat(stack.total + (y || 0));\n }\n if (stacking === 'group') {\n // This point's index within the stack, pushed to stack.points[1]\n stack.cumulative = (stack.total || 1) - 1;\n }\n else {\n stack.cumulative = correctFloat(pick(stack.cumulative, stackThreshold) +\n (y || 0));\n }\n if (y !== null) {\n stack.points[pointKey].push(stack.cumulative);\n stackedYData[i] = stack.cumulative;\n stack.hasValidPoints = true;\n }\n }\n if (stacking === 'percent') {\n yAxis.stacking.usePercentage = true;\n }\n if (stacking !== 'group') {\n this.stackedYData = stackedYData; // To be used in getExtremes\n }\n // Reset old stacks\n yAxis.stacking.oldStacks = {};\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * Adds stacking support to axes.\n * @private\n * @class\n */\n class AxisAdditions {\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.oldStacks = {};\n this.stacks = {};\n this.stacksTouched = 0;\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Build the stacks from top down\n * @private\n */\n buildStacks() {\n const stacking = this;\n const axis = stacking.axis;\n const axisSeries = axis.series;\n const reversedStacks = axis.options.reversedStacks;\n const len = axisSeries.length;\n let actualSeries, i;\n stacking.usePercentage = false;\n i = len;\n while (i--) {\n actualSeries = axisSeries[reversedStacks ? i : len - i - 1];\n actualSeries.setStackedPoints();\n actualSeries.setGroupedPoints();\n }\n // Loop up again to compute percent and stream stack\n for (i = 0; i < len; i++) {\n axisSeries[i].modifyStacks();\n }\n fireEvent(axis, 'afterBuildStacks');\n }\n /**\n * @private\n */\n cleanStacks() {\n const stacking = this;\n let stacks;\n if (stacking.oldStacks) {\n stacks = stacking.stacks = stacking.oldStacks;\n }\n // reset stacks\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.cumulative = stack.total;\n });\n });\n }\n /**\n * Set all the stacks to initial states and destroy unused ones.\n * @private\n */\n resetStacks() {\n objectEach(this.stacks, (type) => {\n objectEach(type, (stack, x) => {\n // Clean up memory after point deletion (#1044, #4320)\n if (isNumber(stack.touched) &&\n stack.touched < this.stacksTouched) {\n stack.destroy();\n delete type[x];\n // Reset stacks\n }\n else {\n stack.total = null;\n stack.cumulative = null;\n }\n });\n });\n }\n /**\n * @private\n */\n renderStackTotals() {\n const stacking = this, axis = stacking.axis, chart = axis.chart, renderer = chart.renderer, stacks = stacking.stacks, stackLabelsAnim = axis.options.stackLabels &&\n axis.options.stackLabels.animation, animationConfig = getDeferredAnimation(chart, stackLabelsAnim || false), stackTotalGroup = stacking.stackTotalGroup = (stacking.stackTotalGroup ||\n renderer\n .g('stack-labels')\n .attr({\n zIndex: 6,\n opacity: 0\n })\n .add());\n // plotLeft/Top will change when y axis gets wider so we need to\n // translate the stackTotalGroup at every render call. See bug #506\n // and #516\n stackTotalGroup.translate(chart.plotLeft, chart.plotTop);\n // Render each stack total\n objectEach(stacks, function (type) {\n objectEach(type, function (stack) {\n stack.render(stackTotalGroup);\n });\n });\n stackTotalGroup.animate({\n opacity: 1\n }, animationConfig);\n }\n }\n /* *\n *\n * Composition\n *\n * */\n var StackingAxis;\n (function (StackingAxis) {\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends axis with stacking support.\n * @private\n */\n function compose(AxisClass, ChartClass, SeriesClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'destroy', onAxisDestroy);\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n const chartProto = ChartClass.prototype;\n chartProto.getStacks = chartGetStacks;\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.getStackIndicator = seriesGetStackIndicator;\n seriesProto.modifyStacks = seriesModifyStacks;\n seriesProto.percentStacker = seriesPercentStacker;\n seriesProto.setGroupedPoints = seriesSetGroupedPoints;\n seriesProto.setStackedPoints = seriesSetStackedPoints;\n }\n }\n StackingAxis.compose = compose;\n })(StackingAxis || (StackingAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return StackingAxis;\n });\n _registerModule(_modules, 'Series/Line/LineSeries.js', [_modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The line series is the base type and is therefor the series base prototype.\n *\n * @private\n */\n class LineSeries extends Series {\n constructor() {\n /* *\n *\n * Static Functions\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Draw the graph. Called internally when rendering line-like series\n * types. The first time it generates the `series.graph` item and\n * optionally other series-wide items like `series.area` for area\n * charts. On subsequent calls these items are updated with new\n * positions and attributes.\n *\n * @function Highcharts.Series#drawGraph\n */\n drawGraph() {\n const series = this, options = this.options, graphPath = (this.gappedPath || this.getGraphPath).call(this), styledMode = this.chart.styledMode;\n let props = [[\n 'graph',\n 'highcharts-graph'\n ]];\n // Presentational properties\n if (!styledMode) {\n props[0].push((options.lineColor ||\n this.color ||\n \"#cccccc\" /* Palette.neutralColor20 */ // when colorByPoint = true\n ), options.dashStyle);\n }\n props = series.getZonesGraphs(props);\n // Draw the graph\n props.forEach(function (prop, i) {\n const graphKey = prop[0];\n let attribs, graph = series[graphKey];\n const verb = graph ? 'animate' : 'attr';\n if (graph) {\n graph.endX = series.preventGraphAnimation ?\n null :\n graphPath.xMap;\n graph.animate({ d: graphPath });\n }\n else if (graphPath.length) { // #1487\n /**\n * SVG element of area-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone areas, accessible\n * via `series['zone-area-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#area\n * @type {Highcharts.SVGElement|undefined}\n */\n /**\n * SVG element of line-based charts. Can be used for styling\n * purposes. If zones are configured, this element will be\n * hidden and replaced by multiple zone lines, accessible\n * via `series['zone-graph-x']` (where x is a number,\n * starting with 0).\n *\n * @name Highcharts.Series#graph\n * @type {Highcharts.SVGElement|undefined}\n */\n series[graphKey] = graph = series.chart.renderer\n .path(graphPath)\n .addClass(prop[1])\n .attr({ zIndex: 1 }) // #1069\n .add(series.group);\n }\n if (graph && !styledMode) {\n attribs = {\n 'stroke': prop[2],\n 'stroke-width': options.lineWidth || 0,\n // Polygon series use filled graph\n 'fill': (series.fillGraph && series.color) || 'none'\n };\n // Apply dash style\n if (prop[3]) {\n attribs.dashstyle = prop[3];\n // The reason for the `else if` is that linecaps don't mix well\n // with dashstyle. The gaps get partially filled by the\n // linecap.\n }\n else if (options.linecap !== 'square') {\n attribs['stroke-linecap'] =\n attribs['stroke-linejoin'] = 'round';\n }\n graph[verb](attribs)\n // Add shadow to normal series (0) or to first\n // zone (1) #3932\n .shadow((i < 2) && options.shadow);\n }\n // Helpers for animation\n if (graph) {\n graph.startX = graphPath.xMap;\n graph.isArea = graphPath.isArea; // For arearange animation\n }\n });\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get the graph path.\n *\n * @private\n */\n getGraphPath(points, nullsAsZeroes, connectCliffs) {\n const series = this, options = series.options, graphPath = [], xMap = [];\n let gap, step = options.step;\n points = points || series.points;\n // Bottom of a stack is reversed\n const reversed = points.reversed;\n if (reversed) {\n points.reverse();\n }\n // Reverse the steps (#5004)\n step = {\n right: 1,\n center: 2\n }[step] || (step && 3);\n if (step && reversed) {\n step = 4 - step;\n }\n // Remove invalid points, especially in spline (#5015)\n points = this.getValidPoints(points, false, !(options.connectNulls && !nullsAsZeroes && !connectCliffs));\n // Build the line\n points.forEach(function (point, i) {\n const plotX = point.plotX, plotY = point.plotY, lastPoint = points[i - 1], isNull = point.isNull || typeof plotY !== 'number';\n // the path to this point from the previous\n let pathToPoint;\n if ((point.leftCliff || (lastPoint && lastPoint.rightCliff)) &&\n !connectCliffs) {\n gap = true; // ... and continue\n }\n // Line series, nullsAsZeroes is not handled\n if (isNull && !defined(nullsAsZeroes) && i > 0) {\n gap = !options.connectNulls;\n // Area series, nullsAsZeroes is set\n }\n else if (isNull && !nullsAsZeroes) {\n gap = true;\n }\n else {\n if (i === 0 || gap) {\n pathToPoint = [[\n 'M',\n point.plotX,\n point.plotY\n ]];\n // Generate the spline as defined in the SplineSeries object\n }\n else if (series.getPointSpline) {\n pathToPoint = [series.getPointSpline(points, point, i)];\n }\n else if (step) {\n if (step === 1) { // right\n pathToPoint = [[\n 'L',\n lastPoint.plotX,\n plotY\n ]];\n }\n else if (step === 2) { // center\n pathToPoint = [[\n 'L',\n (lastPoint.plotX + plotX) / 2,\n lastPoint.plotY\n ], [\n 'L',\n (lastPoint.plotX + plotX) / 2,\n plotY\n ]];\n }\n else {\n pathToPoint = [[\n 'L',\n plotX,\n lastPoint.plotY\n ]];\n }\n pathToPoint.push([\n 'L',\n plotX,\n plotY\n ]);\n }\n else {\n // normal line to next point\n pathToPoint = [[\n 'L',\n plotX,\n plotY\n ]];\n }\n // Prepare for animation. When step is enabled, there are\n // two path nodes for each x value.\n xMap.push(point.x);\n if (step) {\n xMap.push(point.x);\n if (step === 2) { // step = center (#8073)\n xMap.push(point.x);\n }\n }\n graphPath.push.apply(graphPath, pathToPoint);\n gap = false;\n }\n });\n graphPath.xMap = xMap;\n series.graphPath = graphPath;\n return graphPath;\n }\n // eslint-disable-next-line valid-jsdoc\n /**\n * Get zones properties for building graphs. Extendable by series with\n * multiple lines within one series.\n *\n * @private\n */\n getZonesGraphs(props) {\n // Add the zone properties if any\n this.zones.forEach(function (zone, i) {\n const propset = [\n 'zone-graph-' + i,\n 'highcharts-graph highcharts-zone-graph-' + i + ' ' +\n (zone.className || '')\n ];\n if (!this.chart.styledMode) {\n propset.push((zone.color || this.color), (zone.dashStyle || this.options.dashStyle));\n }\n props.push(propset);\n }, this);\n return props;\n }\n }\n LineSeries.defaultOptions = merge(Series.defaultOptions, \n /**\n * General options for all series types.\n *\n * @optionparent plotOptions.series\n */\n {\n legendSymbol: 'lineMarker'\n });\n SeriesRegistry.registerSeriesType('line', LineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A line series displays information as a series of data points connected by\n * straight line segments.\n *\n * @sample {highcharts} highcharts/demo/line-basic/\n * Line chart\n * @sample {highstock} stock/demo/basic-line/\n * Line chart\n *\n * @extends plotOptions.series\n * @product highcharts highstock\n * @apioption plotOptions.line\n */\n /**\n * The SVG value used for the `stroke-linecap` and `stroke-linejoin`\n * of a line graph. Round means that lines are rounded in the ends and\n * bends.\n *\n * @type {Highcharts.SeriesLinecapValue}\n * @default round\n * @since 3.0.7\n * @apioption plotOptions.line.linecap\n */\n /**\n * A `line` series. If the [type](#series.line.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.line\n * @excluding dataParser,dataURL\n * @product highcharts highstock\n * @apioption series.line\n */\n /**\n * An array of data points for the series. For the `line` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 1],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.line.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * **Note:** In TypeScript you have to extend `PointOptionsObject` with an\n * additional declaration to allow custom data types:\n * ```ts\n * declare module `highcharts` {\n * interface PointOptionsObject {\n * custom: Record;\n * }\n * }\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @declare Highcharts.PointOptionsObject\n * @type {Array|null|*>}\n * @apioption series.line.data\n */\n /**\n * An additional, individual class name for the data point's graphic\n * representation. Changes to a point's color will also be reflected in a\n * chart's legend and tooltip.\n *\n * @sample {highcharts} highcharts/css/point-series-classname\n *\n * @type {string}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.className\n */\n /**\n * Individual color for the point. By default the color is pulled from\n * the global `colors` array.\n *\n * In styled mode, the `color` option doesn't take effect. Instead, use\n * `colorIndex`.\n *\n * @sample {highcharts} highcharts/point/color/\n * Mark the highest point\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock gantt\n * @apioption series.line.data.color\n */\n /**\n * A specific color index to use for the point, so its graphic representations\n * are given the class name `highcharts-color-{n}`. In styled mode this will\n * change the color of the graphic. In non-styled mode, the color is set by the\n * `fill` attribute, so the change in class name won't have a visual effect by\n * default.\n *\n * Since v11, CSS variables on the form `--highcharts-color-{n}` make changing\n * the color scheme very convenient.\n *\n * @sample {highcharts} highcharts/css/colorindex/\n * Series and point color index\n *\n * @type {number}\n * @since 5.0.0\n * @product highcharts gantt\n * @apioption series.line.data.colorIndex\n */\n /**\n * A reserved subspace to store options and values for customized functionality.\n * Here you can add additional data for your own event callbacks and formatter\n * callbacks.\n *\n * @sample {highcharts} highcharts/point/custom/\n * Point and series with custom data\n *\n * @type {Highcharts.Dictionary<*>}\n * @apioption series.line.data.custom\n */\n /**\n * Individual data label for each point. The options are the same as\n * the ones for [plotOptions.series.dataLabels](\n * #plotOptions.series.dataLabels).\n *\n * @sample highcharts/point/datalabels/\n * Show a label for the last value\n *\n * @declare Highcharts.DataLabelsOptions\n * @extends plotOptions.line.dataLabels\n * @product highcharts highstock gantt\n * @apioption series.line.data.dataLabels\n */\n /**\n * A description of the point to add to the screen reader information\n * about the point.\n *\n * @type {string}\n * @since 5.0.0\n * @requires modules/accessibility\n * @apioption series.line.data.description\n */\n /**\n * An id for the point. This can be used after render time to get a\n * pointer to the point object through `chart.get()`.\n *\n * @sample {highcharts} highcharts/point/id/\n * Remove an id'd point\n *\n * @type {string}\n * @since 1.2.0\n * @product highcharts highstock gantt\n * @apioption series.line.data.id\n */\n /**\n * The rank for this point's data label in case of collision. If two\n * data labels are about to overlap, only the one with the highest `labelrank`\n * will be drawn.\n *\n * @type {number}\n * @apioption series.line.data.labelrank\n */\n /**\n * The name of the point as shown in the legend, tooltip, dataLabels, etc.\n *\n * @see [xAxis.uniqueNames](#xAxis.uniqueNames)\n *\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Point names\n *\n * @type {string}\n * @apioption series.line.data.name\n */\n /**\n * Whether the data point is selected initially.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock gantt\n * @apioption series.line.data.selected\n */\n /**\n * The x value of the point. For datetime axes, the X value is the timestamp\n * in milliseconds since 1970.\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.line.data.x\n */\n /**\n * The y value of the point.\n *\n * @type {number|null}\n * @product highcharts highstock\n * @apioption series.line.data.y\n */\n /**\n * The individual point events.\n *\n * @extends plotOptions.series.point.events\n * @product highcharts highstock gantt\n * @apioption series.line.data.events\n */\n /**\n * Options for the point markers of line-like series.\n *\n * @declare Highcharts.PointMarkerOptionsObject\n * @extends plotOptions.series.marker\n * @product highcharts highstock\n * @apioption series.line.data.marker\n */\n ''; // include precedent doclets in transpilat\n\n return LineSeries;\n });\n _registerModule(_modules, 'Series/Area/AreaSeries.js', [_modules['Core/Color/Color.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (Color, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { seriesTypes: { line: LineSeries } } = SeriesRegistry;\n const { extend, merge, objectEach, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Area series type.\n *\n * @private\n * @class\n * @name AreaSeries\n *\n * @augments LineSeries\n */\n class AreaSeries extends LineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Draw the graph and the underlying area. This method calls the Series\n * base function and adds the area. The areaPath is calculated in the\n * getSegmentPath method called from Series.prototype.drawGraph.\n * @private\n */\n drawGraph() {\n // Define or reset areaPath\n this.areaPath = [];\n // Call the base method\n super.drawGraph.apply(this);\n // Define local variables\n const series = this, areaPath = this.areaPath, options = this.options, zones = this.zones, props = [[\n 'area',\n 'highcharts-area',\n this.color,\n options.fillColor\n ]]; // area name, main color, fill color\n zones.forEach(function (zone, i) {\n props.push([\n 'zone-area-' + i,\n 'highcharts-area highcharts-zone-area-' + i + ' ' +\n zone.className,\n zone.color || series.color,\n zone.fillColor || options.fillColor\n ]);\n });\n props.forEach(function (prop) {\n const areaKey = prop[0], attribs = {};\n let area = series[areaKey];\n const verb = area ? 'animate' : 'attr';\n // Create or update the area\n if (area) { // update\n area.endX = series.preventGraphAnimation ?\n null :\n areaPath.xMap;\n area.animate({ d: areaPath });\n }\n else { // create\n attribs.zIndex = 0; // #1069\n area = series[areaKey] = series.chart.renderer\n .path(areaPath)\n .addClass(prop[1])\n .add(series.group);\n area.isArea = true;\n }\n if (!series.chart.styledMode) {\n // If there is fillColor defined for the area, set it\n if (prop[3]) {\n attribs.fill = prop[3];\n }\n else {\n // Otherwise, we set it to the series color and add\n // fill-opacity (#18939)\n attribs.fill = prop[2];\n attribs['fill-opacity'] = pick(options.fillOpacity, 0.75);\n }\n }\n area[verb](attribs);\n area.startX = areaPath.xMap;\n area.shiftUnit = options.step ? 2 : 1;\n });\n }\n /**\n * @private\n */\n getGraphPath(points) {\n const getGraphPath = LineSeries.prototype.getGraphPath, options = this.options, stacking = options.stacking, yAxis = this.yAxis, bottomPoints = [], graphPoints = [], seriesIndex = this.index, stacks = yAxis.stacking.stacks[this.stackKey], threshold = options.threshold, translatedThreshold = Math.round(// #10909\n yAxis.getThreshold(options.threshold)), connectNulls = pick(// #10574\n options.connectNulls, stacking === 'percent'), \n // To display null points in underlying stacked series, this\n // series graph must be broken, and the area also fall down to\n // fill the gap left by the null point. #2069\n addDummyPoints = function (i, otherI, side) {\n const point = points[i], stackedValues = stacking &&\n stacks[point.x].points[seriesIndex], nullVal = point[side + 'Null'] || 0, cliffVal = point[side + 'Cliff'] || 0;\n let top, bottom, isNull = true;\n if (cliffVal || nullVal) {\n top = (nullVal ?\n stackedValues[0] :\n stackedValues[1]) + cliffVal;\n bottom = stackedValues[0] + cliffVal;\n isNull = !!nullVal;\n }\n else if (!stacking &&\n points[otherI] &&\n points[otherI].isNull) {\n top = bottom = threshold;\n }\n // Add to the top and bottom line of the area\n if (typeof top !== 'undefined') {\n graphPoints.push({\n plotX: plotX,\n plotY: top === null ?\n translatedThreshold :\n yAxis.getThreshold(top),\n isNull: isNull,\n isCliff: true\n });\n bottomPoints.push({\n plotX: plotX,\n plotY: bottom === null ?\n translatedThreshold :\n yAxis.getThreshold(bottom),\n doCurve: false // #1041, gaps in areaspline areas\n });\n }\n };\n let plotX, isNull, yBottom;\n // Find what points to use\n points = points || this.points;\n // Fill in missing points\n if (stacking) {\n points = this.getStackPoints(points);\n }\n for (let i = 0, iEnd = points.length; i < iEnd; ++i) {\n // Reset after series.update of stacking property (#12033)\n if (!stacking) {\n points[i].leftCliff = points[i].rightCliff =\n points[i].leftNull = points[i].rightNull = void 0;\n }\n isNull = points[i].isNull;\n plotX = pick(points[i].rectPlotX, points[i].plotX);\n yBottom = stacking ?\n pick(points[i].yBottom, translatedThreshold) :\n translatedThreshold;\n if (!isNull || connectNulls) {\n if (!connectNulls) {\n addDummyPoints(i, i - 1, 'left');\n }\n // Skip null point when stacking is false and connectNulls\n // true\n if (!(isNull && !stacking && connectNulls)) {\n graphPoints.push(points[i]);\n bottomPoints.push({\n x: i,\n plotX: plotX,\n plotY: yBottom\n });\n }\n if (!connectNulls) {\n addDummyPoints(i, i + 1, 'right');\n }\n }\n }\n const topPath = getGraphPath.call(this, graphPoints, true, true);\n bottomPoints.reversed = true;\n const bottomPath = getGraphPath.call(this, bottomPoints, true, true);\n const firstBottomPoint = bottomPath[0];\n if (firstBottomPoint && firstBottomPoint[0] === 'M') {\n bottomPath[0] = ['L', firstBottomPoint[1], firstBottomPoint[2]];\n }\n const areaPath = topPath.concat(bottomPath);\n if (areaPath.length) {\n areaPath.push(['Z']);\n }\n // TODO: don't set leftCliff and rightCliff when connectNulls?\n const graphPath = getGraphPath\n .call(this, graphPoints, false, connectNulls);\n areaPath.xMap = topPath.xMap;\n this.areaPath = areaPath;\n return graphPath;\n }\n /**\n * Return an array of stacked points, where null and missing points are\n * replaced by dummy points in order for gaps to be drawn correctly in\n * stacks.\n * @private\n */\n getStackPoints(points) {\n const series = this, segment = [], keys = [], xAxis = this.xAxis, yAxis = this.yAxis, stack = yAxis.stacking.stacks[this.stackKey], pointMap = {}, yAxisSeries = yAxis.series, seriesLength = yAxisSeries.length, upOrDown = yAxis.options.reversedStacks ? 1 : -1, seriesIndex = yAxisSeries.indexOf(series);\n points = points || this.points;\n if (this.options.stacking) {\n for (let i = 0; i < points.length; i++) {\n // Reset after point update (#7326)\n points[i].leftNull = points[i].rightNull = void 0;\n // Create a map where we can quickly look up the points by\n // their X values.\n pointMap[points[i].x] = points[i];\n }\n // Sort the keys (#1651)\n objectEach(stack, function (stackX, x) {\n // nulled after switching between\n // grouping and not (#1651, #2336)\n if (stackX.total !== null) {\n keys.push(x);\n }\n });\n keys.sort(function (a, b) {\n return a - b;\n });\n const visibleSeries = yAxisSeries.map((s) => s.visible);\n keys.forEach(function (x, idx) {\n let y = 0, stackPoint, stackedValues;\n if (pointMap[x] && !pointMap[x].isNull) {\n segment.push(pointMap[x]);\n // Find left and right cliff. -1 goes left, 1 goes\n // right.\n [-1, 1].forEach(function (direction) {\n const nullName = direction === 1 ?\n 'rightNull' :\n 'leftNull', cliffName = direction === 1 ?\n 'rightCliff' :\n 'leftCliff', otherStack = stack[keys[idx + direction]];\n let cliff = 0;\n // If there is a stack next to this one,\n // to the left or to the right...\n if (otherStack) {\n let i = seriesIndex;\n // Can go either up or down,\n // depending on reversedStacks\n while (i >= 0 && i < seriesLength) {\n const si = yAxisSeries[i].index;\n stackPoint = otherStack.points[si];\n if (!stackPoint) {\n // If the next point in this series is\n // missing, mark the point with\n // point.leftNull or point.rightNull = true.\n if (si === series.index) {\n pointMap[x][nullName] = true;\n // If there are missing points in the next\n // stack in any of the series below this\n // one, we need to substract the missing\n // values and add a hiatus to the left or\n // right.\n }\n else if (visibleSeries[i]) {\n stackedValues = stack[x].points[si];\n if (stackedValues) {\n cliff -= (stackedValues[1] -\n stackedValues[0]);\n }\n }\n }\n // When reversedStacks is true, loop up,\n // else loop down\n i += upOrDown;\n }\n }\n pointMap[x][cliffName] = cliff;\n });\n // There is no point for this X value in this series, so we\n // insert a dummy point in order for the areas to be drawn\n // correctly.\n }\n else {\n // Loop down the stack to find the series below this\n // one that has a value (#1991)\n let i = seriesIndex;\n while (i >= 0 && i < seriesLength) {\n const si = yAxisSeries[i].index;\n stackPoint = stack[x].points[si];\n if (stackPoint) {\n y = stackPoint[1];\n break;\n }\n // When reversedStacks is true, loop up, else loop\n // down\n i += upOrDown;\n }\n y = pick(y, 0);\n y = yAxis.translate(// #6272\n y, 0, 1, 0, 1);\n segment.push({\n isNull: true,\n plotX: xAxis.translate(// #6272\n x, 0, 0, 0, 1),\n x: x,\n plotY: y,\n yBottom: y\n });\n }\n });\n }\n return segment;\n }\n }\n /**\n * The area series type.\n *\n * @sample {highcharts} highcharts/demo/area-basic/\n * Area chart\n * @sample {highstock} stock/demo/area/\n * Area chart\n *\n * @extends plotOptions.line\n * @excluding useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.area\n */\n AreaSeries.defaultOptions = merge(LineSeries.defaultOptions, {\n /**\n * @see [fillColor](#plotOptions.area.fillColor)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @apioption plotOptions.area.color\n */\n /**\n * Fill color or gradient for the area. When `null`, the series' `color`\n * is used with the series' `fillOpacity`.\n *\n * In styled mode, the fill color can be set with the `.highcharts-area`\n * class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillOpacity](#plotOptions.area.fillOpacity)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-default/\n * Null by default\n * @sample {highcharts} highcharts/plotoptions/area-fillcolor-gradient/\n * Gradient\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.fillColor\n */\n /**\n * Fill opacity for the area. When you set an explicit `fillColor`,\n * the `fillOpacity` is not applied. Instead, you should define the\n * opacity in the `fillColor` with an rgba color definition. The\n * `fillOpacity` setting, also the default setting, overrides the alpha\n * component of the `color` setting.\n *\n * In styled mode, the fill opacity can be set with the\n * `.highcharts-area` class name.\n *\n * @see [color](#plotOptions.area.color)\n * @see [fillColor](#plotOptions.area.fillColor)\n *\n * @sample {highcharts} highcharts/plotoptions/area-fillopacity/\n * Automatic fill color and fill opacity of 0.1\n *\n * @type {number}\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @product highcharts highstock\n * @apioption plotOptions.area.fillOpacity\n */\n /**\n * A separate color for the graph line. By default the line takes the\n * `color` of the series, but the lineColor setting allows setting a\n * separate color for the line without altering the `fillColor`.\n *\n * In styled mode, the line stroke can be set with the\n * `.highcharts-graph` class name.\n *\n * @sample {highcharts} highcharts/plotoptions/area-linecolor/\n * Dark gray line\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption plotOptions.area.lineColor\n */\n /**\n * A separate color for the negative part of the area.\n *\n * In styled mode, a negative color is set with the\n * `.highcharts-negative` class name.\n *\n * @see [negativeColor](#plotOptions.area.negativeColor)\n *\n * @sample {highcharts} highcharts/css/series-negative-color/\n * Negative color in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 3.0\n * @product highcharts\n * @apioption plotOptions.area.negativeFillColor\n */\n /**\n * Whether the whole area or just the line should respond to mouseover\n * tooltips and other mouse or touch events.\n *\n * @sample {highcharts|highstock} highcharts/plotoptions/area-trackbyarea/\n * Display the tooltip when the area is hovered\n *\n * @type {boolean}\n * @default false\n * @since 1.1.6\n * @product highcharts highstock\n * @apioption plotOptions.area.trackByArea\n */\n /**\n * The Y axis value to serve as the base for the area, for\n * distinguishing between values above and below a threshold. The area\n * between the graph and the threshold is filled.\n *\n * * If a number is given, the Y axis will scale to the threshold.\n * * If `null`, the scaling behaves like a line series with fill between\n * the graph and the Y axis minimum.\n * * If `Infinity` or `-Infinity`, the area between the graph and the\n * corresponding Y axis extreme is filled (since v6.1.0).\n *\n * @sample {highcharts} highcharts/plotoptions/area-threshold/\n * A threshold of 100\n * @sample {highcharts} highcharts/plotoptions/area-threshold-infinity/\n * A threshold of Infinity\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts highstock\n */\n threshold: 0,\n legendSymbol: 'rectangle'\n });\n extend(AreaSeries.prototype, {\n singleStacks: false\n });\n SeriesRegistry.registerSeriesType('area', AreaSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `area` series. If the [type](#series.area.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.area\n * @excluding dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.area\n */\n /**\n * @see [fillColor](#series.area.fillColor)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.color\n */\n /**\n * An array of data points for the series. For the `area` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` * and `pointInterval` given in the series options. If the\n * axis has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 7],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.area.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.area.data\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillOpacity](#series.area.fillOpacity)\n *\n * @apioption series.area.fillColor\n */\n /**\n * @see [color](#series.area.color)\n * @see [fillColor](#series.area.fillColor)\n *\n * @default {highcharts} 0.75\n * @default {highstock} 0.75\n * @apioption series.area.fillOpacity\n */\n ''; // adds doclets above to transpilat\n\n return AreaSeries;\n });\n _registerModule(_modules, 'Series/Spline/SplineSeries.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { line: LineSeries } = SeriesRegistry.seriesTypes;\n const { merge, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Spline series type.\n *\n * @private\n */\n class SplineSeries extends LineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the spline segment from a given point's previous neighbour to the\n * given point.\n *\n * @private\n * @function Highcharts.seriesTypes.spline#getPointSpline\n */\n getPointSpline(points, point, i) {\n const \n // 1 means control points midway between points, 2 means 1/3\n // from the point, 3 is 1/4 etc\n smoothing = 1.5, denom = smoothing + 1, plotX = point.plotX || 0, plotY = point.plotY || 0, lastPoint = points[i - 1], nextPoint = points[i + 1];\n let leftContX, leftContY, rightContX, rightContY;\n /**\n * @private\n */\n function doCurve(otherPoint) {\n return otherPoint &&\n !otherPoint.isNull &&\n otherPoint.doCurve !== false &&\n // #6387, area splines next to null:\n !point.isCliff;\n }\n // Find control points\n if (doCurve(lastPoint) && doCurve(nextPoint)) {\n const lastX = lastPoint.plotX || 0, lastY = lastPoint.plotY || 0, nextX = nextPoint.plotX || 0, nextY = nextPoint.plotY || 0;\n let correction = 0;\n leftContX = (smoothing * plotX + lastX) / denom;\n leftContY = (smoothing * plotY + lastY) / denom;\n rightContX = (smoothing * plotX + nextX) / denom;\n rightContY = (smoothing * plotY + nextY) / denom;\n // Have the two control points make a straight line through main\n // point\n if (rightContX !== leftContX) { // #5016, division by zero\n correction = (((rightContY - leftContY) *\n (rightContX - plotX)) /\n (rightContX - leftContX) + plotY - rightContY);\n }\n leftContY += correction;\n rightContY += correction;\n // to prevent false extremes, check that control points are\n // between neighbouring points' y values\n if (leftContY > lastY && leftContY > plotY) {\n leftContY = Math.max(lastY, plotY);\n // mirror of left control point\n rightContY = 2 * plotY - leftContY;\n }\n else if (leftContY < lastY && leftContY < plotY) {\n leftContY = Math.min(lastY, plotY);\n rightContY = 2 * plotY - leftContY;\n }\n if (rightContY > nextY && rightContY > plotY) {\n rightContY = Math.max(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n else if (rightContY < nextY && rightContY < plotY) {\n rightContY = Math.min(nextY, plotY);\n leftContY = 2 * plotY - rightContY;\n }\n // record for drawing in next point\n point.rightContX = rightContX;\n point.rightContY = rightContY;\n }\n // Visualize control points for debugging\n /*\n if (leftContX) {\n this.chart.renderer.circle(\n leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', leftContX + this.chart.plotLeft,\n leftContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'red',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n if (rightContX) {\n this.chart.renderer.circle(\n rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 2\n )\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n fill: 'none',\n zIndex: 9\n })\n .add();\n this.chart.renderer.path(['M', rightContX + this.chart.plotLeft,\n rightContY + this.chart.plotTop,\n 'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\n .attr({\n stroke: 'green',\n 'stroke-width': 2,\n zIndex: 9\n })\n .add();\n }\n // */\n const ret = [\n 'C',\n pick(lastPoint.rightContX, lastPoint.plotX, 0),\n pick(lastPoint.rightContY, lastPoint.plotY, 0),\n pick(leftContX, plotX, 0),\n pick(leftContY, plotY, 0),\n plotX,\n plotY\n ];\n // reset for updating series later\n lastPoint.rightContX = lastPoint.rightContY = void 0;\n return ret;\n }\n }\n /**\n * A spline series is a special type of line series, where the segments\n * between the data points are smoothed.\n *\n * @sample {highcharts} highcharts/demo/spline-irregular-time/\n * Spline chart\n * @sample {highstock} stock/demo/spline/\n * Spline chart\n *\n * @extends plotOptions.series\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @optionparent plotOptions.spline\n */\n SplineSeries.defaultOptions = merge(LineSeries.defaultOptions);\n SeriesRegistry.registerSeriesType('spline', SplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `spline` series. If the [type](#series.spline.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.spline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.spline\n */\n /**\n * An array of data points for the series. For the `spline` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 9],\n * [1, 2],\n * [2, 8]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.spline.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 0,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.spline.data\n */\n ''; // adds doclets above intro transpilat\n\n return SplineSeries;\n });\n _registerModule(_modules, 'Series/AreaSpline/AreaSplineSeries.js', [_modules['Series/Spline/SplineSeries.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SplineSeries, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { area: AreaSeries, area: { prototype: areaProto } } = SeriesRegistry.seriesTypes;\n const { extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * AreaSpline series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.areaspline\n *\n * @augments Highcharts.Series\n */\n class AreaSplineSeries extends SplineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.points = void 0;\n this.options = void 0;\n }\n }\n AreaSplineSeries.defaultOptions = merge(SplineSeries.defaultOptions, AreaSeries.defaultOptions);\n extend(AreaSplineSeries.prototype, {\n getGraphPath: areaProto.getGraphPath,\n getStackPoints: areaProto.getStackPoints,\n drawGraph: areaProto.drawGraph\n });\n SeriesRegistry.registerSeriesType('areaspline', AreaSplineSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * The area spline series is an area series where the graph between the\n * points is smoothed into a spline.\n *\n * @sample {highcharts} highcharts/demo/areaspline/\n * Area spline chart\n * @sample {highstock} stock/demo/areaspline/\n * Area spline chart\n *\n * @extends plotOptions.area\n * @excluding step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption plotOptions.areaspline\n */\n /**\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.color\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillOpacity](#plotOptions.areaspline.fillOpacity)\n *\n * @apioption plotOptions.areaspline.fillColor\n */\n /**\n * @see [color](#plotOptions.areaspline.color)\n * @see [fillColor](#plotOptions.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption plotOptions.areaspline.fillOpacity\n */\n /**\n * A `areaspline` series. If the [type](#series.areaspline.type) option\n * is not specified, it is inherited from [chart.type](#chart.type).\n *\n *\n * @extends series,plotOptions.areaspline\n * @excluding dataParser, dataURL, step, boostThreshold, boostBlending\n * @product highcharts highstock\n * @apioption series.areaspline\n */\n /**\n * @see [fillColor](#series.areaspline.fillColor)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.color\n */\n /**\n * An array of data points for the series. For the `areaspline` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 10],\n * [1, 9],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.areaspline.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 4,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.areaspline.data\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillOpacity](#series.areaspline.fillOpacity)\n *\n * @apioption series.areaspline.fillColor\n */\n /**\n * @see [color](#series.areaspline.color)\n * @see [fillColor](#series.areaspline.fillColor)\n *\n * @default 0.75\n * @apioption series.areaspline.fillOpacity\n */\n ''; // adds doclets above into transpilat\n\n return AreaSplineSeries;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Column series display one column per value along an X axis.\n *\n * @sample {highcharts} highcharts/demo/column-basic/\n * Column chart\n * @sample {highstock} stock/demo/column/\n * Column chart\n *\n * @extends plotOptions.line\n * @excluding connectEnds, connectNulls, gapSize, gapUnit, linecap,\n * lineWidth, marker, step, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.column\n */\n const ColumnSeriesDefaults = {\n /**\n * The corner radius of the border surrounding each column or bar. A number\n * signifies pixels. A percentage string, like for example `50%`, signifies\n * a relative size. For columns this is relative to the column width, for\n * pies it is relative to the radius and the inner radius.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderradius/\n * Rounded columns\n * @sample highcharts/plotoptions/series-border-radius\n * Column and pie with rounded border\n *\n * @type {number|string|Highcharts.BorderRadiusOptionsObject}\n * @product highcharts highstock gantt\n */\n borderRadius: 3,\n /**\n * When using automatic point colors pulled from the global\n * [colors](colors) or series-specific\n * [plotOptions.column.colors](series.colors) collections, this option\n * determines whether the chart should receive one color per series or\n * one color per point.\n *\n * In styled mode, the `colors` or `series.colors` arrays are not\n * supported, and instead this option gives the points individual color\n * class names on the form `highcharts-color-{n}`.\n *\n * @see [series colors](#plotOptions.column.colors)\n *\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-false/\n * False by default\n * @sample {highcharts} highcharts/plotoptions/column-colorbypoint-true/\n * True\n *\n * @type {boolean}\n * @default false\n * @since 2.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colorByPoint\n */\n /**\n * A series specific or series type specific color set to apply instead\n * of the global [colors](#colors) when [colorByPoint](\n * #plotOptions.column.colorByPoint) is true.\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.colors\n */\n /**\n * When `true`, the columns will center in the category, ignoring null\n * or missing points. When `false`, space will be reserved for null or\n * missing points.\n *\n * @sample {highcharts} highcharts/series-column/centerincategory/\n * Center in category\n *\n * @since 8.0.1\n * @product highcharts highstock gantt\n */\n centerInCategory: false,\n /**\n * Padding between each value groups, in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-default/\n * 0.2 by default\n * @sample {highcharts} highcharts/plotoptions/column-grouppadding-none/\n * No group padding - all columns are evenly spaced\n *\n * @product highcharts highstock gantt\n */\n groupPadding: 0.2,\n /**\n * Whether to group non-stacked columns or to let them render\n * independent of each other. Non-grouped columns will be laid out\n * individually and overlap each other.\n *\n * @sample {highcharts} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n * @sample {highstock} highcharts/plotoptions/column-grouping-false/\n * Grouping disabled\n *\n * @type {boolean}\n * @default true\n * @since 2.3.0\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.grouping\n */\n /** @ignore-option */\n marker: null,\n /**\n * The maximum allowed pixel width for a column, translated to the\n * height of a bar in a bar chart. This prevents the columns from\n * becoming too wide when there is a small number of points in the\n * chart.\n *\n * @see [pointWidth](#plotOptions.column.pointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n * @sample {highstock} highcharts/plotoptions/column-maxpointwidth-20/\n * Limited to 50\n *\n * @type {number}\n * @since 4.1.8\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.maxPointWidth\n */\n /**\n * Padding between each column or bar, in x axis units.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-default/\n * 0.1 by default\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-025/\n * 0.25\n * @sample {highcharts} highcharts/plotoptions/column-pointpadding-none/\n * 0 for tightly packed columns\n *\n * @product highcharts highstock gantt\n */\n pointPadding: 0.1,\n /**\n * A pixel value specifying a fixed width for each column or bar point.\n * When set to `undefined`, the width is calculated from the\n * `pointPadding` and `groupPadding`. The width effects the dimension\n * that is not based on the point value. For column series it is the\n * hoizontal length and for bar series it is the vertical length.\n *\n * @see [maxPointWidth](#plotOptions.column.maxPointWidth)\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointwidth-20/\n * 20px wide columns regardless of chart width or the amount of\n * data points\n *\n * @type {number}\n * @since 1.2.5\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.pointWidth\n */\n /**\n * A pixel value specifying a fixed width for the column or bar.\n * Overrides pointWidth on the series.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @default undefined\n * @since 7.0.0\n * @product highcharts highstock gantt\n * @apioption series.column.data.pointWidth\n */\n /**\n * The minimal height for a column or width for a bar. By default,\n * 0 values are not shown. To visualize a 0 (or close to zero) point,\n * set the minimal point length to a pixel value like 3\\. In stacked\n * column charts, minPointLength might not be respected for tightly\n * packed values.\n *\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength/\n * Zero base value\n * @sample {highcharts} highcharts/plotoptions/column-minpointlength-pos-and-neg/\n * Positive and negative close to zero values\n *\n * @product highcharts highstock gantt\n */\n minPointLength: 0,\n /**\n * When the series contains less points than the crop threshold, all\n * points are drawn, event if the points fall outside the visible plot\n * area at the current zoom. The advantage of drawing all points\n * (including markers and columns), is that animation is performed on\n * updates. On the other hand, when the series contains more points than\n * the crop threshold, the series data is cropped to only contain points\n * that fall within the plot area. The advantage of cropping away\n * invisible points is to increase performance on large series.\n *\n * @product highcharts highstock gantt\n */\n cropThreshold: 50,\n /**\n * The X axis range that each point is valid for. This determines the\n * width of the column. On a categorized axis, the range will be 1\n * by default (one category unit). On linear and datetime axes, the\n * range will be computed as the distance between the two closest data\n * points.\n *\n * The default `null` means it is computed automatically, but this\n * option can be used to override the automatic value.\n *\n * This option is set by default to 1 if data sorting is enabled.\n *\n * @sample {highcharts} highcharts/plotoptions/column-pointrange/\n * Set the point range to one day on a data set with one week\n * between the points\n *\n * @type {number|null}\n * @since 2.3\n * @product highcharts highstock gantt\n */\n pointRange: null,\n states: {\n /**\n * Options for the hovered point. These settings override the normal\n * state options when a point is moused over or touched.\n *\n * @extends plotOptions.series.states.hover\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock gantt\n */\n hover: {\n /** @ignore-option */\n halo: false,\n /**\n * A specific border color for the hovered point. Defaults to\n * inherit the normal state border color.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.borderColor\n */\n /**\n * A specific color for the hovered point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts gantt\n * @apioption plotOptions.column.states.hover.color\n */\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode, the hover brightening is by default replaced\n * with a fill-opacity set in the `.highcharts-point:hover`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-states-hover-brightness/\n * Brighten by 0.5\n *\n * @product highcharts highstock gantt\n */\n brightness: 0.1\n },\n /**\n * Options for the selected point. These settings override the\n * normal state options when a point is selected.\n *\n * @extends plotOptions.series.states.select\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock gantt\n */\n select: {\n /**\n * A specific color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @product highcharts highstock gantt\n */\n color: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * A specific border color for the selected point.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highcharts highstock gantt\n */\n borderColor: \"#000000\" /* Palette.neutralColor100 */\n }\n },\n dataLabels: {\n align: void 0,\n verticalAlign: void 0,\n /**\n * The y position offset of the label relative to the point in\n * pixels.\n *\n * @type {number}\n */\n y: void 0\n },\n // false doesn't work well: https://jsfiddle.net/highcharts/hz8fopan/14/\n /** @ignore-option */\n startFromThreshold: true,\n stickyTracking: false,\n tooltip: {\n distance: 6\n },\n /**\n * The Y axis value to serve as the base for the columns, for\n * distinguishing between values above and below a threshold. If `null`,\n * the columns extend from the padding Y axis minimum.\n *\n * @type {number|null}\n * @since 2.0\n * @product highcharts\n */\n threshold: 0,\n /**\n * The width of the border surrounding each column or bar. Defaults to\n * `1` when there is room for a border, but to `0` when the columns are\n * so dense that a border would cover the next column.\n *\n * In styled mode, the stroke width can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @default undefined\n * @product highcharts highstock gantt\n * @apioption plotOptions.column.borderWidth\n */\n /**\n * The color of the border surrounding each column or bar.\n *\n * In styled mode, the border stroke can be set with the\n * `.highcharts-point` rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highstock gantt\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */\n };\n /**\n * A `column` series. If the [type](#series.column.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.column\n * @excluding connectNulls, dataParser, dataURL, gapSize, gapUnit, linecap,\n * lineWidth, marker, connectEnds, step\n * @product highcharts highstock\n * @apioption series.column\n */\n /**\n * An array of data points for the series. For the `column` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 6],\n * [1, 2],\n * [2, 6]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.column.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 9,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 6,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker\n * @product highcharts highstock\n * @apioption series.column.data\n */\n /**\n * The color of the border surrounding the column or bar.\n *\n * In styled mode, the border stroke can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-bordercolor/\n * Dark gray border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highcharts highstock\n * @apioption series.column.data.borderColor\n */\n /**\n * The width of the border surrounding the column or bar.\n *\n * In styled mode, the stroke width can be set with the `.highcharts-point`\n * rule.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderwidth/\n * 2px black border\n *\n * @type {number}\n * @product highcharts highstock\n * @apioption series.column.data.borderWidth\n */\n /**\n * A name for the dash style to use for the column or bar. Overrides\n * dashStyle on the series.\n *\n * In styled mode, the stroke dash-array can be set with the same classes as\n * listed under [data.color](#series.column.data.color).\n *\n * @see [series.pointWidth](#plotOptions.column.dashStyle)\n *\n * @type {Highcharts.DashStyleValue}\n * @apioption series.column.data.dashStyle\n */\n /**\n * A pixel value specifying a fixed width for the column or bar. Overrides\n * pointWidth on the series. The width effects the dimension that is not based\n * on the point value.\n *\n * @see [series.pointWidth](#plotOptions.column.pointWidth)\n *\n * @type {number}\n * @apioption series.column.data.pointWidth\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.hover\n */\n /**\n * @excluding halo, lineWidth, lineWidthPlus, marker\n * @product highcharts highstock\n * @apioption series.column.states.select\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Column/ColumnSeries.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Color/Color.js'], _modules['Series/Column/ColumnSeriesDefaults.js'], _modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (A, Color, ColumnSeriesDefaults, H, Series, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { animObject } = A;\n const { parse: color } = Color;\n const { hasTouch, noop } = H;\n const { clamp, defined, extend, fireEvent, isArray, isNumber, merge, pick, objectEach, relativeLength } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The column series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.column\n *\n * @augments Highcharts.Series\n */\n class ColumnSeries extends Series {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.borderWidth = void 0;\n this.data = void 0;\n this.group = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animate the column heights one by one from zero.\n *\n * @private\n * @function Highcharts.seriesTypes.column#animate\n *\n * @param {boolean} init\n * Whether to initialize the animation or run it\n */\n animate(init) {\n const series = this, yAxis = this.yAxis, yAxisPos = yAxis.pos, options = series.options, inverted = this.chart.inverted, attr = {}, translateProp = inverted ?\n 'translateX' :\n 'translateY';\n let translateStart, translatedThreshold;\n if (init) {\n attr.scaleY = 0.001;\n translatedThreshold = clamp(yAxis.toPixels(options.threshold), yAxisPos, yAxisPos + yAxis.len);\n if (inverted) {\n attr.translateX = translatedThreshold - yAxis.len;\n }\n else {\n attr.translateY = translatedThreshold;\n }\n // apply finnal clipping (used in Highcharts Stock) (#7083)\n // animation is done by scaleY, so cliping is for panes\n if (series.clipBox) {\n series.setClip();\n }\n series.group.attr(attr);\n }\n else { // run the animation\n translateStart = Number(series.group.attr(translateProp));\n series.group.animate({ scaleY: 1 }, extend(animObject(series.options.animation), {\n // Do the scale synchronously to ensure smooth\n // updating (#5030, #7228)\n step: function (val, fx) {\n if (series.group) {\n attr[translateProp] = translateStart +\n fx.pos * (yAxisPos - translateStart);\n series.group.attr(attr);\n }\n }\n }));\n }\n }\n /**\n * Initialize the series. Extends the basic Series.init method by\n * marking other series of the same type as dirty.\n *\n * @private\n * @function Highcharts.seriesTypes.column#init\n */\n init(chart, options) {\n super.init.apply(this, arguments);\n const series = this;\n chart = series.chart;\n // if the series is added dynamically, force redraw of other\n // series affected by a new column\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n }\n /**\n * Return the width and x offset of the columns adjusted for grouping,\n * groupPadding, pointPadding, pointWidth etc.\n *\n * @private\n * @function Highcharts.seriesTypes.column#getColumnMetrics\n */\n getColumnMetrics() {\n const series = this, options = series.options, xAxis = series.xAxis, yAxis = series.yAxis, reversedStacks = xAxis.options.reversedStacks, \n // Keep backward compatibility: reversed xAxis had reversed\n // stacks\n reverseStacks = (xAxis.reversed && !reversedStacks) ||\n (!xAxis.reversed && reversedStacks), stackGroups = {};\n let stackKey, columnCount = 0;\n // Get the total number of column type series. This is called on\n // every series. Consider moving this logic to a chart.orderStacks()\n // function and call it on init, addSeries and removeSeries\n if (options.grouping === false) {\n columnCount = 1;\n }\n else {\n series.chart.series.forEach(function (otherSeries) {\n const otherYAxis = otherSeries.yAxis, otherOptions = otherSeries.options;\n let columnIndex;\n if (otherSeries.type === series.type &&\n (otherSeries.visible ||\n !series.chart.options.chart.ignoreHiddenSeries) &&\n yAxis.len === otherYAxis.len &&\n yAxis.pos === otherYAxis.pos) { // #642, #2086\n if (otherOptions.stacking &&\n otherOptions.stacking !== 'group') {\n stackKey = otherSeries.stackKey;\n if (typeof stackGroups[stackKey] ===\n 'undefined') {\n stackGroups[stackKey] = columnCount++;\n }\n columnIndex = stackGroups[stackKey];\n }\n else if (otherOptions.grouping !== false) { // #1162\n columnIndex = columnCount++;\n }\n otherSeries.columnIndex = columnIndex;\n }\n });\n }\n const categoryWidth = Math.min(Math.abs(xAxis.transA) * ((xAxis.ordinal && xAxis.ordinal.slope) ||\n options.pointRange ||\n xAxis.closestPointRange ||\n xAxis.tickInterval ||\n 1), // #2610\n xAxis.len // #1535\n ), groupPadding = categoryWidth * options.groupPadding, groupWidth = categoryWidth - 2 * groupPadding, pointOffsetWidth = groupWidth / (columnCount || 1), pointWidth = Math.min(options.maxPointWidth || xAxis.len, pick(options.pointWidth, pointOffsetWidth * (1 - 2 * options.pointPadding))), pointPadding = (pointOffsetWidth - pointWidth) / 2, \n // #1251, #3737\n colIndex = (series.columnIndex || 0) + (reverseStacks ? 1 : 0), pointXOffset = pointPadding +\n (groupPadding +\n colIndex * pointOffsetWidth -\n (categoryWidth / 2)) * (reverseStacks ? -1 : 1);\n // Save it for reading in linked series (Error bars particularly)\n series.columnMetrics = {\n width: pointWidth,\n offset: pointXOffset,\n paddedWidth: pointOffsetWidth,\n columnCount\n };\n return series.columnMetrics;\n }\n /**\n * Make the columns crisp. The edges are rounded to the nearest full\n * pixel.\n *\n * @private\n * @function Highcharts.seriesTypes.column#crispCol\n */\n crispCol(x, y, w, h) {\n const chart = this.chart, borderWidth = this.borderWidth, xCrisp = -(borderWidth % 2 ? 0.5 : 0);\n let right, yCrisp = borderWidth % 2 ? 0.5 : 1;\n // Horizontal. We need to first compute the exact right edge, then\n // round it and compute the width from there.\n if (this.options.crisp) {\n right = Math.round(x + w) + xCrisp;\n x = Math.round(x) + xCrisp;\n w = right - x;\n }\n // Vertical\n const bottom = Math.round(y + h) + yCrisp, fromTop = Math.abs(y) <= 0.5 && bottom > 0.5; // #4504, #4656\n y = Math.round(y) + yCrisp;\n h = bottom - y;\n // Top edges are exceptions\n if (fromTop && h) { // #5146\n y -= 1;\n h += 1;\n }\n return {\n x: x,\n y: y,\n width: w,\n height: h\n };\n }\n /**\n * Adjust for missing columns, according to the `centerInCategory`\n * option. Missing columns are either single points or stacks where the\n * point or points are either missing or null.\n *\n * @private\n * @function Highcharts.seriesTypes.column#adjustForMissingColumns\n * @param {number} x\n * The x coordinate of the column, left side\n *\n * @param {number} pointWidth\n * The pointWidth, already computed upstream\n *\n * @param {Highcharts.ColumnPoint} point\n * The point instance\n *\n * @param {Highcharts.ColumnMetricsObject} metrics\n * The series-wide column metrics\n *\n * @return {number}\n * The adjusted x position, or the original if not adjusted\n */\n adjustForMissingColumns(x, pointWidth, point, metrics) {\n const stacking = this.options.stacking;\n if (!point.isNull && metrics.columnCount > 1) {\n const reversedStacks = this.yAxis.options.reversedStacks;\n let indexInCategory = 0, totalInCategory = reversedStacks ? 0 : -metrics.columnCount;\n // Loop over all the stacks on the Y axis. When stacking is enabled,\n // these are real point stacks. When stacking is not enabled, but\n // `centerInCategory` is true, there is one stack handling the\n // grouping of points in each category. This is done in the\n // `setGroupedPoints` function.\n objectEach(this.yAxis.stacking && this.yAxis.stacking.stacks, (stack) => {\n if (typeof point.x === 'number') {\n const stackItem = stack[point.x.toString()];\n if (stackItem) {\n const pointValues = stackItem.points[this.index];\n // If true `stacking` is enabled, count the total\n // number of non-null stacks in the category, and\n // note which index this point is within those\n // stacks.\n if (stacking) {\n if (pointValues) {\n indexInCategory = totalInCategory;\n }\n if (stackItem.hasValidPoints) {\n reversedStacks ? // #16169\n totalInCategory++ : totalInCategory--;\n }\n // If `stacking` is not enabled, look for the index\n }\n else if (isArray(pointValues)) {\n // If there are multiple points with the same X\n // then gather all series in category, and\n // assign index\n let seriesIndexes = Object\n .keys(stackItem.points)\n .filter((pointKey) => \n // Filter out duplicate X's\n !pointKey.match(',') &&\n // Filter out null points\n stackItem.points[pointKey] &&\n stackItem.points[pointKey].length > 1)\n .map(parseFloat)\n .sort((a, b) => b - a);\n indexInCategory = seriesIndexes.indexOf(this.index);\n totalInCategory = seriesIndexes.length;\n }\n }\n }\n });\n // Compute the adjusted x position\n const boxWidth = (totalInCategory - 1) * metrics.paddedWidth +\n pointWidth;\n x = (point.plotX || 0) + boxWidth / 2 - pointWidth -\n indexInCategory * metrics.paddedWidth;\n }\n return x;\n }\n /**\n * Translate each point to the plot area coordinate system and find\n * shape positions\n *\n * @private\n * @function Highcharts.seriesTypes.column#translate\n */\n translate() {\n const series = this, chart = series.chart, options = series.options, dense = series.dense =\n series.closestPointRange * series.xAxis.transA < 2, borderWidth = series.borderWidth = pick(options.borderWidth, dense ? 0 : 1 // #3635\n ), xAxis = series.xAxis, yAxis = series.yAxis, threshold = options.threshold, minPointLength = pick(options.minPointLength, 5), metrics = series.getColumnMetrics(), seriesPointWidth = metrics.width, seriesXOffset = series.pointXOffset = metrics.offset, dataMin = series.dataMin, dataMax = series.dataMax;\n // postprocessed for border width\n let seriesBarW = series.barW =\n Math.max(seriesPointWidth, 1 + 2 * borderWidth), translatedThreshold = series.translatedThreshold =\n yAxis.getThreshold(threshold);\n if (chart.inverted) {\n translatedThreshold -= 0.5; // #3355\n }\n // When the pointPadding is 0, we want the columns to be packed\n // tightly, so we allow individual columns to have individual sizes.\n // When pointPadding is greater, we strive for equal-width columns\n // (#2694).\n if (options.pointPadding) {\n seriesBarW = Math.ceil(seriesBarW);\n }\n Series.prototype.translate.apply(series);\n // Record the new values\n series.points.forEach(function (point) {\n const yBottom = pick(point.yBottom, translatedThreshold), safeDistance = 999 + Math.abs(yBottom), plotX = point.plotX || 0, \n // Don't draw too far outside plot area (#1303, #2241,\n // #4264)\n plotY = clamp(point.plotY, -safeDistance, yAxis.len + safeDistance), stackBox = point.stackBox;\n let up, barY = Math.min(plotY, yBottom), barH = Math.max(plotY, yBottom) - barY, pointWidth = seriesPointWidth, barX = plotX + seriesXOffset, barW = seriesBarW;\n // Handle options.minPointLength\n if (minPointLength && Math.abs(barH) < minPointLength) {\n barH = minPointLength;\n up = (!yAxis.reversed && !point.negative) ||\n (yAxis.reversed && point.negative);\n // Reverse zeros if there's no positive value in the series\n // in visible range (#7046)\n if (isNumber(threshold) &&\n isNumber(dataMax) &&\n point.y === threshold &&\n dataMax <= threshold &&\n // and if there's room for it (#7311)\n (yAxis.min || 0) < threshold &&\n // if all points are the same value (i.e zero) not draw\n // as negative points (#10646), but only if there's room\n // for it (#14876)\n (dataMin !== dataMax || (yAxis.max || 0) <= threshold)) {\n up = !up;\n point.negative = !point.negative;\n }\n // If stacked...\n barY = (Math.abs(barY - translatedThreshold) > minPointLength ?\n // ...keep position\n yBottom - minPointLength :\n // #1485, #4051\n translatedThreshold -\n (up ? minPointLength : 0));\n }\n // Handle point.options.pointWidth\n // @todo Handle grouping/stacking too. Calculate offset properly\n if (defined(point.options.pointWidth)) {\n pointWidth = barW =\n Math.ceil(point.options.pointWidth);\n barX -= Math.round((pointWidth - seriesPointWidth) / 2);\n }\n // Adjust for null or missing points\n if (options.centerInCategory) {\n barX = series.adjustForMissingColumns(barX, pointWidth, point, metrics);\n }\n // Cache for access in polar\n point.barX = barX;\n point.pointWidth = pointWidth;\n // Fix the tooltip on center of grouped columns (#1216, #424,\n // #3648)\n point.tooltipPos = chart.inverted ?\n [\n clamp(yAxis.len + yAxis.pos - chart.plotLeft - plotY, yAxis.pos - chart.plotLeft, yAxis.len + yAxis.pos - chart.plotLeft),\n xAxis.len + xAxis.pos - chart.plotTop - barX - barW / 2,\n barH\n ] :\n [\n xAxis.left - chart.plotLeft + barX + barW / 2,\n clamp(plotY + yAxis.pos -\n chart.plotTop, yAxis.pos - chart.plotTop, yAxis.len + yAxis.pos - chart.plotTop),\n barH\n ];\n // Register shape type and arguments to be used in drawPoints. Allow\n // `shapeType` defined on `pointClass` level.\n point.shapeType = series.pointClass.prototype.shapeType ||\n 'roundedRect';\n point.shapeArgs = series.crispCol(barX, \n // #3169, drilldown from null must have a position to work from.\n // #6585, dataLabel should be placed on xAxis, not floating in\n // the middle of the chart.\n point.isNull ? translatedThreshold : barY, barW, point.isNull ? 0 : barH);\n });\n // Fire a specific event after column translate. We could instead apply\n // all the column logic in an `afterTranslate` event handler, but there\n // are so many other series types that use the column translation, that\n // it is more convenient to have a specific event for it.\n fireEvent(this, 'afterColumnTranslate');\n }\n /**\n * Columns have no graph\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawGraph\n */\n drawGraph() {\n this.group[this.dense ? 'addClass' : 'removeClass']('highcharts-dense-data');\n }\n /**\n * Get presentational attributes\n *\n * @private\n * @function Highcharts.seriesTypes.column#pointAttribs\n */\n pointAttribs(point, state) {\n const options = this.options, p2o = this.pointAttrToOptions || {}, strokeOption = p2o.stroke || 'borderColor', strokeWidthOption = p2o['stroke-width'] || 'borderWidth';\n let stateOptions, zone, brightness, fill = (point && point.color) || this.color, \n // set to fill when borderColor null:\n stroke = ((point && point[strokeOption]) ||\n options[strokeOption] ||\n fill), dashstyle = (point && point.options.dashStyle) || options.dashStyle, strokeWidth = (point && point[strokeWidthOption]) ||\n options[strokeWidthOption] ||\n this[strokeWidthOption] || 0, opacity = pick(point && point.opacity, options.opacity, 1);\n // Handle zone colors\n if (point && this.zones.length) {\n zone = point.getZone();\n // When zones are present, don't use point.color (#4267).\n // Changed order (#6527), added support for colorAxis (#10670)\n fill = (point.options.color ||\n (zone && (zone.color || point.nonZonedColor)) ||\n this.color);\n if (zone) {\n stroke = zone.borderColor || stroke;\n dashstyle = zone.dashStyle || dashstyle;\n strokeWidth = zone.borderWidth || strokeWidth;\n }\n }\n // Select or hover states\n if (state && point) {\n stateOptions = merge(options.states[state], \n // #6401\n point.options.states &&\n point.options.states[state] ||\n {});\n brightness = stateOptions.brightness;\n fill =\n stateOptions.color || (typeof brightness !== 'undefined' &&\n color(fill)\n .brighten(stateOptions.brightness)\n .get()) || fill;\n stroke = stateOptions[strokeOption] || stroke;\n strokeWidth =\n stateOptions[strokeWidthOption] || strokeWidth;\n dashstyle = stateOptions.dashStyle || dashstyle;\n opacity = pick(stateOptions.opacity, opacity);\n }\n const ret = {\n fill: fill,\n stroke: stroke,\n 'stroke-width': strokeWidth,\n opacity: opacity\n };\n if (dashstyle) {\n ret.dashstyle = dashstyle;\n }\n return ret;\n }\n /**\n * Draw the columns. For bars, the series.group is rotated, so the same\n * coordinates apply for columns and bars. This method is inherited by\n * scatter series.\n *\n * @private\n * @function Highcharts.seriesTypes.column#drawPoints\n */\n drawPoints(points = this.points) {\n const series = this, chart = this.chart, options = series.options, renderer = chart.renderer, animationLimit = options.animationLimit || 250;\n let shapeArgs;\n // draw the columns\n points.forEach(function (point) {\n const plotY = point.plotY;\n let graphic = point.graphic, hasGraphic = !!graphic, verb = graphic && chart.pointCount < animationLimit ?\n 'animate' : 'attr';\n if (isNumber(plotY) && point.y !== null) {\n shapeArgs = point.shapeArgs;\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (graphic && point.hasNewShapeType()) {\n graphic = graphic.destroy();\n }\n // Set starting position for point sliding animation.\n if (series.enabledDataSorting) {\n point.startXPos = series.xAxis.reversed ?\n -(shapeArgs ? (shapeArgs.width || 0) : 0) :\n series.xAxis.width;\n }\n if (!graphic) {\n point.graphic = graphic =\n renderer[point.shapeType](shapeArgs)\n .add(point.group || series.group);\n if (graphic &&\n series.enabledDataSorting &&\n chart.hasRendered &&\n chart.pointCount < animationLimit) {\n graphic.attr({\n x: point.startXPos\n });\n hasGraphic = true;\n verb = 'animate';\n }\n }\n if (graphic && hasGraphic) { // update\n graphic[verb](merge(shapeArgs));\n }\n // Presentational\n if (!chart.styledMode) {\n graphic[verb](series.pointAttribs(point, (point.selected && 'select')))\n .shadow(point.allowShadow !== false && options.shadow);\n }\n if (graphic) {\n graphic.addClass(point.getClassName(), true);\n graphic.attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n }\n }\n else if (graphic) {\n point.graphic = graphic.destroy(); // #1269\n }\n });\n }\n /**\n * Draw the tracker for a point.\n * @private\n */\n drawTracker(points = this.points) {\n const series = this, chart = series.chart, pointer = chart.pointer, onMouseOver = function (e) {\n const point = pointer.getPointFromEvent(e);\n // undefined on graph in scatterchart\n if (typeof point !== 'undefined' &&\n series.options.enableMouseTracking) {\n pointer.isDirectTouch = true;\n point.onMouseOver(e);\n }\n };\n let dataLabels;\n // Add reference to the point\n points.forEach(function (point) {\n dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n if (point.graphic) {\n point.graphic.element.point = point;\n }\n dataLabels.forEach(function (dataLabel) {\n if (dataLabel.div) {\n dataLabel.div.point = point;\n }\n else {\n dataLabel.element.point = point;\n }\n });\n });\n // Add the event listeners, we need to do this only once\n if (!series._hasTracking) {\n series.trackerGroups.forEach(function (key) {\n if (series[key]) {\n // we don't always have dataLabelsGroup\n series[key]\n .addClass('highcharts-tracker')\n .on('mouseover', onMouseOver)\n .on('mouseout', function (e) {\n pointer.onTrackerMouseOut(e);\n });\n if (hasTouch) {\n series[key].on('touchstart', onMouseOver);\n }\n if (!chart.styledMode && series.options.cursor) {\n series[key]\n .css({ cursor: series.options.cursor });\n }\n }\n });\n series._hasTracking = true;\n }\n fireEvent(this, 'afterDrawTracker');\n }\n /**\n * Remove this series from the chart\n *\n * @private\n * @function Highcharts.seriesTypes.column#remove\n */\n remove() {\n const series = this, chart = series.chart;\n // column and bar series affects other series of the same type\n // as they are either stacked or grouped\n if (chart.hasRendered) {\n chart.series.forEach(function (otherSeries) {\n if (otherSeries.type === series.type) {\n otherSeries.isDirty = true;\n }\n });\n }\n Series.prototype.remove.apply(series, arguments);\n }\n }\n ColumnSeries.defaultOptions = merge(Series.defaultOptions, ColumnSeriesDefaults);\n extend(ColumnSeries.prototype, {\n cropShoulder: 0,\n // When tooltip is not shared, this series (and derivatives) requires\n // direct touch/hover. KD-tree does not apply.\n directTouch: true,\n getSymbol: noop,\n // use separate negative stacks, unlike area stacks where a negative\n // point is substracted from previous (#1910)\n negStacks: true,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('column', ColumnSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Adjusted width and x offset of the columns for grouping.\n *\n * @private\n * @interface Highcharts.ColumnMetricsObject\n */ /**\n * Width of the columns.\n * @name Highcharts.ColumnMetricsObject#width\n * @type {number}\n */ /**\n * Offset of the columns.\n * @name Highcharts.ColumnMetricsObject#offset\n * @type {number}\n */\n ''; // detach doclets above\n\n return ColumnSeries;\n });\n _registerModule(_modules, 'Core/Series/DataLabel.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Templating.js'], _modules['Core/Utilities.js']], function (A, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getDeferredAnimation } = A;\n const { format } = F;\n const { defined, extend, fireEvent, isArray, isString, merge, objectEach, pick, splat } = U;\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable valid-jsdoc */\n var DataLabel;\n (function (DataLabel) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Align each individual data label.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n const series = this, chart = this.chart, inverted = this.isCartesian && chart.inverted, enabledDataSorting = this.enabledDataSorting, plotX = point.plotX, plotY = point.plotY, rotation = options.rotation, align = options.align, isInsidePlot = defined(plotX) &&\n defined(plotY) &&\n chart.isInsidePlot(plotX, Math.round(plotY), {\n inverted,\n paneCoordinates: true,\n series\n }), setStartPos = (alignOptions) => {\n if (enabledDataSorting && series.xAxis && !justify) {\n series.setDataLabelStartPos(point, dataLabel, isNew, isInsidePlot, alignOptions);\n }\n };\n let baseline, rotCorr, // rotation correction\n // Math.round for rounding errors (#2683), alignTo to allow column\n // labels (#2700)\n alignAttr, // the final position;\n justify = pick(options.overflow, (enabledDataSorting ? 'none' : 'justify')) === 'justify', visible = this.visible &&\n point.visible !== false &&\n defined(plotX) &&\n (point.series.forceDL ||\n (enabledDataSorting && !justify) ||\n isInsidePlot ||\n (\n // If the data label is inside the align box, it is\n // enough that parts of the align box is inside the\n // plot area (#12370). When stacking, it is always\n // inside regardless of the option (#15148).\n pick(options.inside, !!this.options.stacking) &&\n alignTo &&\n chart.isInsidePlot(plotX, inverted ?\n alignTo.x + 1 :\n alignTo.y + alignTo.height - 1, {\n inverted,\n paneCoordinates: true,\n series\n })));\n const pos = point.pos();\n if (visible && pos) {\n if (rotation) {\n dataLabel.attr({ align });\n }\n let bBox = dataLabel.getBBox(true), bBoxCorrection = [0, 0];\n baseline = chart.renderer.fontMetrics(dataLabel).b;\n // The alignment box is a singular point\n alignTo = extend({\n x: pos[0],\n y: Math.round(pos[1]),\n width: 0,\n height: 0\n }, alignTo);\n // Add the text size for alignment calculation\n extend(options, {\n width: bBox.width,\n height: bBox.height\n });\n // Allow a hook for changing alignment in the last moment, then do\n // the alignment\n if (rotation) {\n justify = false; // Not supported for rotated text\n rotCorr = chart.renderer.rotCorr(baseline, rotation); // #3723\n alignAttr = {\n x: (alignTo.x +\n (options.x || 0) +\n alignTo.width / 2 +\n rotCorr.x),\n y: (alignTo.y +\n (options.y || 0) +\n { top: 0, middle: 0.5, bottom: 1 }[options.verticalAlign] *\n alignTo.height)\n };\n bBoxCorrection = [\n bBox.x - Number(dataLabel.attr('x')),\n bBox.y - Number(dataLabel.attr('y'))\n ];\n setStartPos(alignAttr); // data sorting\n dataLabel[isNew ? 'attr' : 'animate'](alignAttr);\n }\n else {\n setStartPos(alignTo); // data sorting\n dataLabel.align(options, void 0, alignTo);\n alignAttr = dataLabel.alignAttr;\n }\n // Handle justify or crop\n if (justify && alignTo.height >= 0) { // #8830\n this.justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew);\n // Now check that the data label is within the plot area\n }\n else if (pick(options.crop, true)) {\n let { x, y } = alignAttr;\n x += bBoxCorrection[0];\n y += bBoxCorrection[1];\n // Uncomment this block to visualize the bounding boxes used for\n // determining visibility\n /*\n chart.renderer.rect(\n chart.plotLeft + alignAttr.x + bBox.x,\n chart.plotTop + alignAttr.y + bBox.y + 9999,\n bBox.width,\n bBox.height\n ).attr({\n stroke: 'rgba(0, 0, 0, 0.3)',\n 'stroke-width': 0.5\n }).add();\n chart.renderer.circle(\n chart.plotLeft + alignAttr.x,\n chart.plotTop + alignAttr.y,\n 2\n ).attr({\n fill: 'red',\n zIndex: 20\n }).add();\n // */\n visible =\n chart.isInsidePlot(x, y, {\n paneCoordinates: true,\n series\n }) &&\n chart.isInsidePlot(x + bBox.width, y + bBox.height, {\n paneCoordinates: true,\n series\n });\n }\n // When we're using a shape, make it possible with a connector or an\n // arrow pointing to thie point\n if (options.shape && !rotation) {\n dataLabel[isNew ? 'attr' : 'animate']({\n anchorX: pos[0],\n anchorY: pos[1]\n });\n }\n }\n // To use alignAttr property in hideOverlappingLabels\n if (isNew && enabledDataSorting) {\n dataLabel.placed = false;\n }\n // Show or hide based on the final aligned position\n if (!visible && (!enabledDataSorting || justify)) {\n dataLabel.hide();\n dataLabel.placed = false; // don't animate back in\n }\n else {\n dataLabel.show();\n }\n }\n /**\n * Handle the dataLabels.filter option.\n * @private\n */\n function applyFilter(point, options) {\n const filter = options.filter;\n if (filter) {\n const op = filter.operator;\n const prop = point[filter.property];\n const val = filter.value;\n if ((op === '>' && prop > val) ||\n (op === '<' && prop < val) ||\n (op === '>=' && prop >= val) ||\n (op === '<=' && prop <= val) ||\n (op === '==' && prop == val) || // eslint-disable-line eqeqeq\n (op === '===' && prop === val)) {\n return true;\n }\n return false;\n }\n return true;\n }\n /**\n * @private\n */\n function compose(SeriesClass) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.initDataLabelsGroup = initDataLabelsGroup;\n seriesProto.initDataLabels = initDataLabels;\n seriesProto.alignDataLabel = alignDataLabel;\n seriesProto.drawDataLabels = drawDataLabels;\n seriesProto.justifyDataLabel = justifyDataLabel;\n seriesProto.setDataLabelStartPos = setDataLabelStartPos;\n }\n }\n DataLabel.compose = compose;\n /**\n * Create the SVGElement group for dataLabels\n * @private\n */\n function initDataLabelsGroup() {\n return this.plotGroup('dataLabelsGroup', 'data-labels', this.hasRendered ? 'inherit' : 'hidden', // #5133, #10220\n this.options.dataLabels.zIndex || 6);\n }\n /**\n * Init the data labels with the correct animation\n * @private\n */\n function initDataLabels(animationConfig) {\n const series = this, hasRendered = series.hasRendered || 0;\n // Create a separate group for the data labels to avoid rotation\n const dataLabelsGroup = this.initDataLabelsGroup()\n .attr({ opacity: +hasRendered }); // #3300\n if (!hasRendered && dataLabelsGroup) {\n if (series.visible) { // #2597, #3023, #3024\n dataLabelsGroup.show();\n }\n if (series.options.animation) {\n dataLabelsGroup.animate({ opacity: 1 }, animationConfig);\n }\n else {\n dataLabelsGroup.attr({ opacity: 1 });\n }\n }\n return dataLabelsGroup;\n }\n /**\n * Draw the data labels\n * @private\n */\n function drawDataLabels(points = this.points) {\n var _a,\n _b;\n const series = this, chart = series.chart, seriesOptions = series.options, renderer = chart.renderer, { backgroundColor, plotBackgroundColor } = chart.options.chart, plotOptions = chart.options.plotOptions, contrastColor = renderer.getContrast((isString(plotBackgroundColor) && plotBackgroundColor) ||\n (isString(backgroundColor) && backgroundColor) ||\n \"#000000\" /* Palette.neutralColor100 */);\n let seriesDlOptions = seriesOptions.dataLabels, pointOptions, dataLabelsGroup;\n const firstDLOptions = splat(seriesDlOptions)[0], dataLabelAnim = firstDLOptions.animation, animationConfig = firstDLOptions.defer ?\n getDeferredAnimation(chart, dataLabelAnim, series) :\n { defer: 0, duration: 0 };\n // Merge in plotOptions.dataLabels for series\n seriesDlOptions = mergeArrays(mergeArrays((_a = plotOptions === null || plotOptions === void 0 ? void 0 : plotOptions.series) === null || _a === void 0 ? void 0 : _a.dataLabels, (_b = plotOptions === null || plotOptions === void 0 ? void 0 : plotOptions[series.type]) === null || _b === void 0 ? void 0 : _b.dataLabels), seriesDlOptions);\n fireEvent(this, 'drawDataLabels');\n if (isArray(seriesDlOptions) ||\n seriesDlOptions.enabled ||\n series._hasPointLabels) {\n dataLabelsGroup = this.initDataLabels(animationConfig);\n // Make the labels for each point\n points.forEach((point) => {\n var _a;\n const dataLabels = point.dataLabels || [];\n // Merge in series options for the point.\n // @note dataLabelAttribs (like pointAttribs) would eradicate\n // the need for dlOptions, and simplify the section below.\n pointOptions = splat(mergeArrays(seriesDlOptions, \n // dlOptions is used in treemaps\n point.dlOptions || ((_a = point.options) === null || _a === void 0 ? void 0 : _a.dataLabels)));\n // Handle each individual data label for this point\n pointOptions.forEach((labelOptions, i) => {\n var _a;\n // Options for one datalabel\n const labelEnabled = (labelOptions.enabled &&\n // #2282, #4641, #7112, #10049\n (!point.isNull || point.dataLabelOnNull) &&\n applyFilter(point, labelOptions)), connector = point.connectors ?\n point.connectors[i] :\n point.connector, style = labelOptions.style || {};\n let labelConfig, formatString, labelText, rotation, attr = {}, dataLabel = dataLabels[i], isNew = !dataLabel;\n const labelDistance = pick(labelOptions.distance, point.labelDistance);\n if (labelEnabled) {\n // Create individual options structure that can be\n // extended without affecting others\n formatString = pick(labelOptions[point.formatPrefix + 'Format'], labelOptions.format);\n labelConfig = point.getLabelConfig();\n labelText = defined(formatString) ?\n format(formatString, labelConfig, chart) :\n (labelOptions[point.formatPrefix + 'Formatter'] ||\n labelOptions.formatter).call(labelConfig, labelOptions);\n rotation = labelOptions.rotation;\n if (!chart.styledMode) {\n // Determine the color\n style.color = pick(labelOptions.color, style.color, isString(series.color) ? series.color : void 0, \"#000000\" /* Palette.neutralColor100 */);\n // Get automated contrast color\n if (style.color === 'contrast') {\n point.contrastColor = renderer.getContrast((point.color || series.color));\n style.color = ((!defined(labelDistance) &&\n labelOptions.inside) ||\n (labelDistance || 0) < 0 ||\n seriesOptions.stacking) ?\n point.contrastColor :\n contrastColor;\n }\n else {\n delete point.contrastColor;\n }\n if (seriesOptions.cursor) {\n style.cursor = seriesOptions.cursor;\n }\n }\n attr = {\n r: labelOptions.borderRadius || 0,\n rotation,\n padding: labelOptions.padding,\n zIndex: 1\n };\n if (!chart.styledMode) {\n const { backgroundColor, borderColor } = labelOptions;\n attr.fill = backgroundColor === 'auto' ?\n point.color :\n backgroundColor;\n attr.stroke = borderColor === 'auto' ?\n point.color :\n borderColor;\n attr['stroke-width'] = labelOptions.borderWidth;\n }\n // Remove unused attributes (#947)\n objectEach(attr, (val, name) => {\n if (typeof val === 'undefined') {\n delete attr[name];\n }\n });\n }\n // If the point is outside the plot area, or the label\n // changes properties that we cannot change, destroy it and\n // build a new one below. #678, #820.\n if (dataLabel && (!labelEnabled ||\n !defined(labelText) ||\n !!dataLabel.div !== !!labelOptions.useHTML ||\n (\n // Change from no rotation to rotation and\n // vice versa. Don't use defined() because\n // rotation = 0 means also rotation = undefined\n (!dataLabel.rotation ||\n !labelOptions.rotation) &&\n dataLabel.rotation !== labelOptions.rotation))) {\n dataLabel = void 0;\n isNew = true;\n if (connector && point.connector) {\n point.connector = point.connector.destroy();\n if (point.connectors) {\n // Remove point.connectors if this was the last\n // one\n if (point.connectors.length === 1) {\n delete point.connectors;\n }\n else {\n delete point.connectors[i];\n }\n }\n }\n }\n // Individual labels are disabled if the are explicitly\n // disabled in the point options, or if they fall outside\n // the plot area.\n if (labelEnabled && defined(labelText)) {\n if (!dataLabel) {\n // Create new label element\n dataLabel = rotation ?\n // Labels don't rotate, use text element\n renderer.text(labelText, 0, 0, labelOptions.useHTML)\n .addClass('highcharts-data-label') :\n // We can use label\n renderer.label(labelText, 0, 0, labelOptions.shape, void 0, void 0, labelOptions.useHTML, void 0, 'data-label');\n if (dataLabel) {\n dataLabel.addClass(' highcharts-data-label-color-' +\n point.colorIndex +\n ' ' + (labelOptions.className || '') +\n ( // #3398\n labelOptions.useHTML ?\n ' highcharts-tracker' :\n ''));\n }\n }\n else {\n // Use old element and just update text\n attr.text = labelText;\n }\n // Store data label options for later access\n if (dataLabel) {\n dataLabel.options = labelOptions;\n dataLabel.attr(attr);\n if (!chart.styledMode) {\n // Styles must be applied before add in order to\n // read text bounding box\n dataLabel.css(style).shadow(labelOptions.shadow);\n }\n const textPathOptions = labelOptions[point.formatPrefix + 'TextPath'] || labelOptions.textPath;\n if (textPathOptions && !labelOptions.useHTML) {\n dataLabel.setTextPath(((_a = point.getDataLabelPath) === null || _a === void 0 ? void 0 : _a.call(point, dataLabel)) ||\n point.graphic, textPathOptions);\n if (point.dataLabelPath &&\n !textPathOptions.enabled) {\n // clean the DOM\n point.dataLabelPath = (point.dataLabelPath.destroy());\n }\n }\n if (!dataLabel.added) {\n dataLabel.add(dataLabelsGroup);\n }\n // Now the data label is created and placed at 0,0,\n // so we need to align it\n series.alignDataLabel(point, dataLabel, labelOptions, void 0, isNew);\n dataLabel.isActive = true;\n if (dataLabels[i] && dataLabels[i] !== dataLabel) {\n dataLabels[i].destroy();\n }\n dataLabels[i] = dataLabel;\n }\n }\n });\n // Destroy and remove the inactive ones\n let j = dataLabels.length;\n while (j--) {\n if (dataLabels[j].isActive) {\n dataLabels[j].isActive = false;\n }\n else {\n dataLabels[j].destroy();\n dataLabels.splice(j, 1);\n }\n }\n // Write back\n point.dataLabel = dataLabels[0];\n point.dataLabels = dataLabels;\n });\n }\n fireEvent(this, 'afterDrawDataLabels');\n }\n /**\n * If data labels fall partly outside the plot area, align them back in, in\n * a way that doesn't hide the point.\n * @private\n */\n function justifyDataLabel(dataLabel, options, alignAttr, bBox, alignTo, isNew) {\n const chart = this.chart, align = options.align, verticalAlign = options.verticalAlign, padding = dataLabel.box ? 0 : (dataLabel.padding || 0);\n let { x = 0, y = 0 } = options, off, justified;\n // Off left\n off = (alignAttr.x || 0) + padding;\n if (off < 0) {\n if (align === 'right' && x >= 0) {\n options.align = 'left';\n options.inside = true;\n }\n else {\n x -= off;\n }\n justified = true;\n }\n // Off right\n off = (alignAttr.x || 0) + bBox.width - padding;\n if (off > chart.plotWidth) {\n if (align === 'left' && x <= 0) {\n options.align = 'right';\n options.inside = true;\n }\n else {\n x += chart.plotWidth - off;\n }\n justified = true;\n }\n // Off top\n off = alignAttr.y + padding;\n if (off < 0) {\n if (verticalAlign === 'bottom' && y >= 0) {\n options.verticalAlign = 'top';\n options.inside = true;\n }\n else {\n y -= off;\n }\n justified = true;\n }\n // Off bottom\n off = (alignAttr.y || 0) + bBox.height - padding;\n if (off > chart.plotHeight) {\n if (verticalAlign === 'top' && y <= 0) {\n options.verticalAlign = 'bottom';\n options.inside = true;\n }\n else {\n y += chart.plotHeight - off;\n }\n justified = true;\n }\n if (justified) {\n options.x = x;\n options.y = y;\n dataLabel.placed = !isNew;\n dataLabel.align(options, void 0, alignTo);\n }\n return justified;\n }\n /**\n * Merge two objects that can be arrays. If one of them is an array, the\n * other is merged into each element. If both are arrays, each element is\n * merged by index. If neither are arrays, we use normal merge.\n * @private\n */\n function mergeArrays(one, two) {\n let res = [], i;\n if (isArray(one) && !isArray(two)) {\n res = one.map(function (el) {\n return merge(el, two);\n });\n }\n else if (isArray(two) && !isArray(one)) {\n res = two.map(function (el) {\n return merge(one, el);\n });\n }\n else if (!isArray(one) && !isArray(two)) {\n res = merge(one, two);\n }\n else if (isArray(one) && isArray(two)) {\n i = Math.max(one.length, two.length);\n while (i--) {\n res[i] = merge(one[i], two[i]);\n }\n }\n return res;\n }\n /**\n * Set starting position for data label sorting animation.\n * @private\n */\n function setDataLabelStartPos(point, dataLabel, isNew, isInside, alignOptions) {\n const chart = this.chart, inverted = chart.inverted, xAxis = this.xAxis, reversed = xAxis.reversed, labelCenter = inverted ? dataLabel.height / 2 : dataLabel.width / 2, pointWidth = point.pointWidth, halfWidth = pointWidth ? pointWidth / 2 : 0;\n dataLabel.startXPos = inverted ?\n alignOptions.x :\n (reversed ?\n -labelCenter - halfWidth :\n xAxis.width - labelCenter + halfWidth);\n dataLabel.startYPos = inverted ?\n (reversed ?\n this.yAxis.height - labelCenter + halfWidth :\n -labelCenter - halfWidth) : alignOptions.y;\n // We need to handle visibility in case of sorting point outside plot\n // area\n if (!isInside) {\n dataLabel\n .attr({ opacity: 1 })\n .animate({ opacity: 0 }, void 0, dataLabel.hide);\n }\n else if (dataLabel.visibility === 'hidden') {\n dataLabel.show();\n dataLabel\n .attr({ opacity: 0 })\n .animate({ opacity: 1 });\n }\n // Save start position on first render, but do not change position\n if (!chart.hasRendered) {\n return;\n }\n // Set start position\n if (isNew) {\n dataLabel.attr({ x: dataLabel.startXPos, y: dataLabel.startYPos });\n }\n dataLabel.placed = true;\n }\n })(DataLabel || (DataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback JavaScript function to format the data label as a string. Note that\n * if a `format` is defined, the format takes precedence and the formatter is\n * ignored.\n *\n * @callback Highcharts.DataLabelsFormatterCallbackFunction\n *\n * @param {Highcharts.PointLabelObject} this\n * Data label context to format\n *\n * @param {Highcharts.DataLabelsOptions} options\n * [API options](/highcharts/plotOptions.series.dataLabels) of the data label\n *\n * @return {number|string|null|undefined}\n * Formatted data label text\n */\n /**\n * Values for handling data labels that flow outside the plot area.\n *\n * @typedef {\"allow\"|\"justify\"} Highcharts.DataLabelsOverflowValue\n */\n ''; // keeps doclets above in JS file\n\n return DataLabel;\n });\n _registerModule(_modules, 'Series/Column/ColumnDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { series: Series } = SeriesRegistry;\n const { merge, pick } = U;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Override the basic data label alignment by adjusting for the position of\n * the column.\n * @private\n */\n function alignDataLabel(point, dataLabel, options, alignTo, isNew) {\n let inverted = this.chart.inverted, series = point.series, xLen = (series.xAxis ? series.xAxis.len : this.chart.plotSizeX) || 0, yLen = (series.yAxis ? series.yAxis.len : this.chart.plotSizeY) || 0, \n // data label box for alignment\n dlBox = point.dlBox || point.shapeArgs, below = pick(point.below, // range series\n point.plotY >\n pick(this.translatedThreshold, yLen)), \n // draw it inside the box?\n inside = pick(options.inside, !!this.options.stacking), overshoot;\n // Align to the column itself, or the top of it\n if (dlBox) { // Area range uses this method but not alignTo\n alignTo = merge(dlBox);\n if (alignTo.y < 0) {\n alignTo.height += alignTo.y;\n alignTo.y = 0;\n }\n // If parts of the box overshoots outside the plot area, modify the\n // box to center the label inside\n overshoot = alignTo.y + alignTo.height - yLen;\n if (overshoot > 0 && overshoot < alignTo.height) {\n alignTo.height -= overshoot;\n }\n if (inverted) {\n alignTo = {\n x: yLen - alignTo.y - alignTo.height,\n y: xLen - alignTo.x - alignTo.width,\n width: alignTo.height,\n height: alignTo.width\n };\n }\n // Compute the alignment box\n if (!inside) {\n if (inverted) {\n alignTo.x += below ? 0 : alignTo.width;\n alignTo.width = 0;\n }\n else {\n alignTo.y += below ? alignTo.height : 0;\n alignTo.height = 0;\n }\n }\n }\n // When alignment is undefined (typically columns and bars), display the\n // individual point below or above the point depending on the threshold\n options.align = pick(options.align, !inverted || inside ? 'center' : below ? 'right' : 'left');\n options.verticalAlign = pick(options.verticalAlign, inverted || inside ? 'middle' : below ? 'top' : 'bottom');\n // Call the parent method\n Series.prototype.alignDataLabel.call(this, point, dataLabel, options, alignTo, isNew);\n // If label was justified and we have contrast, set it:\n if (options.inside && point.contrastColor) {\n dataLabel.css({\n color: point.contrastColor\n });\n }\n }\n /** @private */\n function compose(ColumnSeriesClass) {\n DataLabel.compose(Series);\n if (U.pushUnique(composedMembers, ColumnSeriesClass)) {\n ColumnSeriesClass.prototype.alignDataLabel = alignDataLabel;\n }\n }\n ColumnDataLabel.compose = compose;\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Series/Bar/BarSeries.js', [_modules['Series/Column/ColumnSeries.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ColumnSeries, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Bar series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.bar\n *\n * @augments Highcharts.Series\n */\n class BarSeries extends ColumnSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n }\n /**\n * A bar series is a special type of column series where the columns are\n * horizontal.\n *\n * @sample highcharts/demo/bar-basic/\n * Bar chart\n *\n * @extends plotOptions.column\n * @product highcharts\n * @optionparent plotOptions.bar\n */\n BarSeries.defaultOptions = merge(ColumnSeries.defaultOptions, {\n // nothing here yet\n });\n extend(BarSeries.prototype, {\n inverted: true\n });\n SeriesRegistry.registerSeriesType('bar', BarSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A `bar` series. If the [type](#series.bar.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.bar\n * @excluding connectNulls, dashStyle, dataParser, dataURL, gapSize, gapUnit,\n * linecap, lineWidth, marker, connectEnds, step\n * @product highcharts\n * @apioption series.bar\n */\n /**\n * An array of data points for the series. For the `bar` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 5],\n * [1, 10],\n * [2, 3]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.bar.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 10,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.column.data\n * @product highcharts\n * @apioption series.bar.data\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.hover\n */\n /**\n * @excluding halo,lineWidth,lineWidthPlus,marker\n * @product highcharts highstock\n * @apioption series.bar.states.select\n */\n ''; // gets doclets above into transpilat\n\n return BarSeries;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A scatter plot uses cartesian coordinates to display values for two\n * variables for a set of data.\n *\n * @sample {highcharts} highcharts/demo/scatter/\n * Scatter plot\n *\n * @extends plotOptions.line\n * @excluding cropThreshold, pointPlacement, shadow, useOhlcData\n * @product highcharts highstock\n * @optionparent plotOptions.scatter\n */\n const ScatterSeriesDefaults = {\n /**\n * The width of the line connecting the data points.\n *\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-none/\n * 0 by default\n * @sample {highcharts} highcharts/plotoptions/scatter-linewidth-1/\n * 1px\n *\n * @product highcharts highstock\n */\n lineWidth: 0,\n findNearestPointBy: 'xy',\n /**\n * Apply a jitter effect for the rendered markers. When plotting\n * discrete values, a little random noise may help telling the points\n * apart. The jitter setting applies a random displacement of up to `n`\n * axis units in either direction. So for example on a horizontal X\n * axis, setting the `jitter.x` to 0.24 will render the point in a\n * random position between 0.24 units to the left and 0.24 units to the\n * right of the true axis position. On a category axis, setting it to\n * 0.5 will fill up the bin and make the data appear continuous.\n *\n * When rendered on top of a box plot or a column series, a jitter value\n * of 0.24 will correspond to the underlying series' default\n * [groupPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.groupPadding)\n * and [pointPadding](\n * https://api.highcharts.com/highcharts/plotOptions.column.pointPadding)\n * settings.\n *\n * @sample {highcharts} highcharts/demo/scatter-jitter\n * Jitter on a scatter plot\n *\n * @sample {highcharts} highcharts/series-scatter/jitter-boxplot\n * Jittered scatter plot on top of a box plot\n *\n * @product highcharts highstock\n * @since 7.0.2\n */\n jitter: {\n /**\n * The maximal X offset for the random jitter effect.\n */\n x: 0,\n /**\n * The maximal Y offset for the random jitter effect.\n */\n y: 0\n },\n marker: {\n enabled: true // Overrides auto-enabling in line series (#3647)\n },\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series, or out of the plot area. When false, the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @type {boolean}\n * @default false\n * @product highcharts highstock highmaps\n * @apioption plotOptions.scatter.stickyTracking\n */\n /**\n * A configuration object for the tooltip rendering of each single\n * series. Properties are inherited from [tooltip](#tooltip).\n * Overridable properties are `headerFormat`, `pointFormat`,\n * `yDecimals`, `xDateFormat`, `yPrefix` and `ySuffix`. Unlike other\n * series, in a scatter plot the series.name by default shows in the\n * headerFormat and point.x and point.y in the pointFormat.\n *\n * @product highcharts highstock highmaps\n */\n tooltip: {\n /**\n * @product highcharts highstock\n */\n headerFormat: '\\u25CF ' +\n ' {series.name}
',\n pointFormat: 'x: {point.x}
y: {point.y}
'\n }\n };\n /**\n * A `scatter` series. If the [type](#series.scatter.type) option is\n * not specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.scatter\n * @excluding cropThreshold, dataParser, dataURL, useOhlcData\n * @product highcharts highstock\n * @apioption series.scatter\n */\n /**\n * An array of data points for the series. For the `scatter` series\n * type, points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. The `x` values will be automatically\n * calculated, either starting at 0 and incremented by 1, or from\n * `pointStart` and `pointInterval` given in the series options. If the axis\n * has categories, these will be used. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of arrays with 2 values. In this case, the values correspond to\n * `x,y`. If the first value is a string, it is applied as the name of the\n * point, and the `x` value is inferred.\n * ```js\n * data: [\n * [0, 0],\n * [1, 8],\n * [2, 9]\n * ]\n * ```\n *\n * 3. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.scatter.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * y: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * y: 4,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @product highcharts highstock\n * @apioption series.scatter.data\n */\n ''; // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Scatter/ScatterSeries.js', [_modules['Series/Scatter/ScatterSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ScatterSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: ColumnSeries, line: LineSeries } = SeriesRegistry.seriesTypes;\n const { addEvent, extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Scatter series type.\n *\n * @private\n */\n class ScatterSeries extends LineSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Optionally add the jitter effect.\n * @private\n */\n applyJitter() {\n const series = this, jitter = this.options.jitter, len = this.points.length;\n /**\n * Return a repeatable, pseudo-random number based on an integer\n * seed.\n * @private\n */\n function unrandom(seed) {\n const rand = Math.sin(seed) * 10000;\n return rand - Math.floor(rand);\n }\n if (jitter) {\n this.points.forEach(function (point, i) {\n ['x', 'y'].forEach(function (dim, j) {\n let axis, plotProp = 'plot' + dim.toUpperCase(), min, max, translatedJitter;\n if (jitter[dim] && !point.isNull) {\n axis = series[dim + 'Axis'];\n translatedJitter =\n jitter[dim] * axis.transA;\n if (axis && !axis.isLog) {\n // Identify the outer bounds of the jitter range\n min = Math.max(0, point[plotProp] - translatedJitter);\n max = Math.min(axis.len, point[plotProp] + translatedJitter);\n // Find a random position within this range\n point[plotProp] = min +\n (max - min) * unrandom(i + j * len);\n // Update clientX for the tooltip k-d-tree\n if (dim === 'x') {\n point.clientX = point.plotX;\n }\n }\n }\n });\n });\n }\n }\n /**\n * @private\n */\n drawGraph() {\n if (this.options.lineWidth) {\n super.drawGraph();\n }\n else if (this.graph) {\n this.graph = this.graph.destroy();\n }\n }\n }\n ScatterSeries.defaultOptions = merge(LineSeries.defaultOptions, ScatterSeriesDefaults);\n extend(ScatterSeries.prototype, {\n drawTracker: ColumnSeries.prototype.drawTracker,\n sorted: false,\n requireSorting: false,\n noSharedTooltip: true,\n trackerGroups: ['group', 'markerGroup', 'dataLabelsGroup'],\n takeOrdinalPosition: false // #2342\n });\n /* *\n *\n * Events\n *\n * */\n /* eslint-disable no-invalid-this */\n addEvent(ScatterSeries, 'afterTranslate', function () {\n this.applyJitter();\n });\n SeriesRegistry.registerSeriesType('scatter', ScatterSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return ScatterSeries;\n });\n _registerModule(_modules, 'Series/CenteredUtilities.js', [_modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (H, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { deg2rad } = H;\n const { fireEvent, isNumber, pick, relativeLength } = U;\n /**\n * @private\n */\n var CenteredUtilities;\n (function (CenteredUtilities) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Get the center of the pie based on the size and center options relative\n * to the plot area. Borrowed by the polar and gauge series types.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getCenter\n */\n function getCenter() {\n const options = this.options, chart = this.chart, slicingRoom = 2 * (options.slicedOffset || 0), plotWidth = chart.plotWidth - 2 * slicingRoom, plotHeight = chart.plotHeight - 2 * slicingRoom, centerOption = options.center, smallestSize = Math.min(plotWidth, plotHeight), thickness = options.thickness;\n let handleSlicingRoom, size = options.size, innerSize = options.innerSize || 0, i, value;\n if (typeof size === 'string') {\n size = parseFloat(size);\n }\n if (typeof innerSize === 'string') {\n innerSize = parseFloat(innerSize);\n }\n const positions = [\n pick(centerOption[0], '50%'),\n pick(centerOption[1], '50%'),\n // Prevent from negative values\n pick(size && size < 0 ? void 0 : options.size, '100%'),\n pick(innerSize && innerSize < 0 ? void 0 : options.innerSize || 0, '0%')\n ];\n // No need for inner size in angular (gauges) series but still required\n // for pie series\n if (chart.angular && !(this instanceof Series)) {\n positions[3] = 0;\n }\n for (i = 0; i < 4; ++i) {\n value = positions[i];\n handleSlicingRoom = i < 2 || (i === 2 && /%$/.test(value));\n // i == 0: centerX, relative to width\n // i == 1: centerY, relative to height\n // i == 2: size, relative to smallestSize\n // i == 3: innerSize, relative to size\n positions[i] = relativeLength(value, [plotWidth, plotHeight, smallestSize, positions[2]][i]) + (handleSlicingRoom ? slicingRoom : 0);\n }\n // innerSize cannot be larger than size (#3632)\n if (positions[3] > positions[2]) {\n positions[3] = positions[2];\n }\n // thickness overrides innerSize, need to be less than pie size (#6647)\n if (isNumber(thickness) &&\n thickness * 2 < positions[2] && thickness > 0) {\n positions[3] = positions[2] - thickness * 2;\n }\n fireEvent(this, 'afterGetCenter', { positions });\n return positions;\n }\n CenteredUtilities.getCenter = getCenter;\n /**\n * getStartAndEndRadians - Calculates start and end angles in radians.\n * Used in series types such as pie and sunburst.\n *\n * @private\n * @function Highcharts.CenteredSeriesMixin.getStartAndEndRadians\n *\n * @param {number} [start]\n * Start angle in degrees.\n *\n * @param {number} [end]\n * Start angle in degrees.\n *\n * @return {Highcharts.RadianAngles}\n * Returns an object containing start and end angles as radians.\n */\n function getStartAndEndRadians(start, end) {\n const startAngle = isNumber(start) ? start : 0, // must be a number\n endAngle = ((isNumber(end) && // must be a number\n end > startAngle && // must be larger than the start angle\n // difference must be less than 360 degrees\n (end - startAngle) < 360) ?\n end :\n startAngle + 360), correction = -90;\n return {\n start: deg2rad * (startAngle + correction),\n end: deg2rad * (endAngle + correction)\n };\n }\n CenteredUtilities.getStartAndEndRadians = getStartAndEndRadians;\n })(CenteredUtilities || (CenteredUtilities = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @private\n * @interface Highcharts.RadianAngles\n */ /**\n * @name Highcharts.RadianAngles#end\n * @type {number}\n */ /**\n * @name Highcharts.RadianAngles#start\n * @type {number}\n */\n ''; // keeps doclets above in JS file\n\n return CenteredUtilities;\n });\n _registerModule(_modules, 'Series/Pie/PiePoint.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Series/Point.js'], _modules['Core/Utilities.js']], function (A, Point, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { setAnimation } = A;\n const { addEvent, defined, extend, isNumber, pick, relativeLength } = U;\n /* *\n *\n * Class\n *\n * */\n class PiePoint extends Point {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.labelDistance = void 0;\n this.options = void 0;\n this.series = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Extendable method for getting the path of the connector between the\n * data label and the pie slice.\n * @private\n */\n getConnectorPath() {\n const labelPosition = this.labelPosition, options = this.series.options.dataLabels, predefinedShapes = this.connectorShapes;\n let connectorShape = options.connectorShape;\n // find out whether to use the predefined shape\n if (predefinedShapes[connectorShape]) {\n connectorShape = predefinedShapes[connectorShape];\n }\n return connectorShape.call(this, {\n // pass simplified label position object for user's convenience\n x: labelPosition.computed.x,\n y: labelPosition.computed.y,\n alignment: labelPosition.alignment\n }, labelPosition.connectorPosition, options);\n }\n /**\n * @private\n */\n getTranslate() {\n return this.sliced ? this.slicedTranslation : {\n translateX: 0,\n translateY: 0\n };\n }\n /**\n * @private\n */\n haloPath(size) {\n const shapeArgs = this.shapeArgs;\n return this.sliced || !this.visible ?\n [] :\n this.series.chart.renderer.symbols.arc(shapeArgs.x, shapeArgs.y, shapeArgs.r + size, shapeArgs.r + size, {\n // Substract 1px to ensure the background is not bleeding\n // through between the halo and the slice (#7495).\n innerR: shapeArgs.r - 1,\n start: shapeArgs.start,\n end: shapeArgs.end,\n borderRadius: shapeArgs.borderRadius\n });\n }\n /**\n * Initialize the pie slice.\n * @private\n */\n init() {\n super.init.apply(this, arguments);\n this.name = pick(this.name, 'Slice');\n // add event listener for select\n const toggleSlice = (e) => {\n this.slice(e.type === 'select');\n };\n addEvent(this, 'select', toggleSlice);\n addEvent(this, 'unselect', toggleSlice);\n return this;\n }\n /**\n * Negative points are not valid (#1530, #3623, #5322)\n * @private\n */\n isValid() {\n return isNumber(this.y) && this.y >= 0;\n }\n /**\n * Toggle the visibility of a pie slice or other data point. Note that this\n * method is available only for some series, like pie, treemap and sunburst.\n *\n * @function Highcharts.Point#setVisible\n *\n * @param {boolean} [vis]\n * True to show the pie slice or other data point, false to hide. If\n * undefined, the visibility is toggled.\n *\n * @param {boolean} [redraw] Whether to redraw the chart after the point is\n * altered. If doing more operations on the chart, it is a good idea to set\n * redraw to false and call {@link Chart#redraw|chart.redraw()} after.\n *\n */\n setVisible(vis, redraw) {\n const series = this.series, chart = series.chart, ignoreHiddenPoint = series.options.ignoreHiddenPoint;\n redraw = pick(redraw, ignoreHiddenPoint);\n if (vis !== this.visible) {\n // If called without an argument, toggle visibility\n this.visible = this.options.visible = vis =\n typeof vis === 'undefined' ? !this.visible : vis;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n // Show and hide associated elements. This is performed\n // regardless of redraw or not, because chart.redraw only\n // handles full series.\n ['graphic', 'dataLabel', 'connector'].forEach((key) => {\n if (this[key]) {\n this[key][vis ? 'show' : 'hide'](vis);\n }\n });\n if (this.legendItem) {\n chart.legend.colorizeItem(this, vis);\n }\n // #4170, hide halo after hiding point\n if (!vis && this.state === 'hover') {\n this.setState('');\n }\n // Handle ignore hidden slices\n if (ignoreHiddenPoint) {\n series.isDirty = true;\n }\n if (redraw) {\n chart.redraw();\n }\n }\n }\n /**\n * Set or toggle whether the slice is cut out from the pie.\n * @private\n *\n * @param {boolean} sliced\n * When undefined, the slice state is toggled.\n *\n * @param {boolean} [redraw]\n * Whether to redraw the chart. True by default.\n *\n * @param {boolean|Partial} [animation]\n * Animation options.\n */\n slice(sliced, redraw, animation) {\n const series = this.series, chart = series.chart;\n setAnimation(animation, chart);\n // redraw is true by default\n redraw = pick(redraw, true);\n /**\n * Pie series only. Whether to display a slice offset from the\n * center.\n * @name Highcharts.Point#sliced\n * @type {boolean|undefined}\n */\n // if called without an argument, toggle\n this.sliced = this.options.sliced = sliced =\n defined(sliced) ? sliced : !this.sliced;\n // update userOptions.data\n series.options.data[series.data.indexOf(this)] =\n this.options;\n if (this.graphic) {\n this.graphic.animate(this.getTranslate());\n }\n }\n }\n extend(PiePoint.prototype, {\n connectorShapes: {\n // only one available before v7.0.0\n fixedOffset: function (labelPosition, connectorPosition, options) {\n const breakAt = connectorPosition.breakAt, touchingSliceAt = connectorPosition.touchingSliceAt, lineSegment = options.softConnector ? [\n 'C',\n // 1st control point (of the curve)\n labelPosition.x +\n // 5 gives the connector a little horizontal bend\n (labelPosition.alignment === 'left' ? -5 : 5),\n labelPosition.y,\n 2 * breakAt.x - touchingSliceAt.x,\n 2 * breakAt.y - touchingSliceAt.y,\n breakAt.x,\n breakAt.y //\n ] : [\n 'L',\n breakAt.x,\n breakAt.y\n ];\n // assemble the path\n return ([\n ['M', labelPosition.x, labelPosition.y],\n lineSegment,\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ]);\n },\n straight: function (labelPosition, connectorPosition) {\n const touchingSliceAt = connectorPosition.touchingSliceAt;\n // direct line to the slice\n return [\n ['M', labelPosition.x, labelPosition.y],\n ['L', touchingSliceAt.x, touchingSliceAt.y]\n ];\n },\n crookedLine: function (labelPosition, connectorPosition, options) {\n const { breakAt, touchingSliceAt } = connectorPosition, { series } = this, [cx, cy, diameter] = series.center, r = diameter / 2, plotWidth = series.chart.plotWidth, plotLeft = series.chart.plotLeft, leftAligned = labelPosition.alignment === 'left', { x, y } = labelPosition;\n let crookX = breakAt.x;\n if (options.crookDistance) {\n const crookDistance = relativeLength(// % to fraction\n options.crookDistance, 1);\n crookX = leftAligned ?\n cx +\n r +\n (plotWidth + plotLeft - cx - r) * (1 - crookDistance) :\n plotLeft + (cx - r) * crookDistance;\n // When the crookDistance option is undefined, make the bend in the\n // intersection between the radial line in the middle of the slice,\n // and the extension of the label position.\n }\n else {\n crookX = cx + (cy - y) * Math.tan((this.angle || 0) - Math.PI / 2);\n }\n const path = [['M', x, y]];\n // The crookedLine formula doesn't make sense if the path overlaps\n // the label - use straight line instead in that case\n if (leftAligned ?\n (crookX <= x && crookX >= breakAt.x) :\n (crookX >= x && crookX <= breakAt.x)) {\n path.push(['L', crookX, y]);\n }\n path.push(['L', breakAt.x, breakAt.y], ['L', touchingSliceAt.x, touchingSliceAt.y]);\n return path;\n }\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return PiePoint;\n });\n _registerModule(_modules, 'Series/Pie/PieSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * A pie chart is a circular graphic which is divided into slices to\n * illustrate numerical proportion.\n *\n * @sample highcharts/demo/pie-basic/\n * Pie chart\n *\n * @extends plotOptions.line\n * @excluding animationLimit, boostThreshold, connectEnds, connectNulls,\n * cropThreshold, dashStyle, dataSorting, dragDrop,\n * findNearestPointBy, getExtremesFromAll, label, lineWidth,\n * linkedTo, marker, negativeColor, pointInterval,\n * pointIntervalUnit, pointPlacement, pointStart,\n * softThreshold, stacking, step, threshold, turboThreshold,\n * zoneAxis, zones, dataSorting, boostBlending\n * @product highcharts highmaps\n * @optionparent plotOptions.pie\n *\n * @private\n */\n const PieSeriesDefaults = {\n /**\n * The corner radius of the border surrounding each slice. A number\n * signifies pixels. A percentage string, like for example `50%`, signifies\n * a size relative to the radius and the inner radius.\n *\n * @sample highcharts/plotoptions/series-border-radius\n * Column and pie with rounded border\n *\n * @since 11.0.0\n *\n * @type {number|string|Highcharts.BorderRadiusOptionsObject}\n */\n borderRadius: 3,\n /**\n * @excluding legendItemClick\n * @apioption plotOptions.pie.events\n */\n /**\n * Fires when the checkbox next to the point name in the legend is\n * clicked. One parameter, event, is passed to the function. The state\n * of the checkbox is found by event.checked. The checked item is found\n * by event.item. Return false to prevent the default action which is to\n * toggle the select state of the series.\n *\n * @sample {highcharts} highcharts/plotoptions/series-events-checkboxclick/\n * Alert checkbox status\n *\n * @type {Function}\n * @since 1.2.0\n * @product highcharts highmaps\n * @context Highcharts.Point\n * @apioption plotOptions.pie.events.checkboxClick\n */\n /**\n * Fires when the legend item belonging to the pie point (slice) is\n * clicked. The `this` keyword refers to the point itself. One\n * parameter, `event`, is passed to the function, containing common\n * event information. The default action is to toggle the visibility of\n * the point. This can be prevented by calling `event.preventDefault()`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-point-events-legenditemclick/\n * Confirm toggle visibility\n *\n * @type {Highcharts.PointLegendItemClickCallbackFunction}\n * @since 1.2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.point.events.legendItemClick\n */\n /**\n * The center of the pie chart relative to the plot area. Can be\n * percentages or pixel values. The default behaviour (as of 3.0) is to\n * center the pie so that all slices and data labels are within the plot\n * area. As a consequence, the pie may actually jump around in a chart\n * with dynamic values, as the data labels move. In that case, the\n * center should be explicitly set, for example to `[\"50%\", \"50%\"]`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-center/\n * Centered at 100, 100\n *\n * @type {Array<(number|string|null),(number|string|null)>}\n * @default [null, null]\n * @product highcharts highmaps\n *\n * @private\n */\n center: [null, null],\n /**\n * The color of the pie series. A pie series is represented as an empty\n * circle if the total sum of its values is 0. Use this property to\n * define the color of its border.\n *\n * In styled mode, the color can be defined by the\n * [colorIndex](#plotOptions.series.colorIndex) option. Also, the series\n * color can be set with the `.highcharts-series`,\n * `.highcharts-color-{n}`, `.highcharts-{type}-series` or\n * `.highcharts-series-{n}` class, or individual classes given by the\n * `className` option.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n * @apioption plotOptions.pie.color\n */\n /**\n * @product highcharts\n *\n * @private\n */\n clip: false,\n /**\n * @ignore-option\n *\n * @private\n */\n colorByPoint: true,\n /**\n * A series specific or series type specific color set to use instead\n * of the global [colors](#colors).\n *\n * @sample {highcharts} highcharts/demo/pie-monochrome/\n * Set default colors for all pies\n *\n * @type {Array}\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.colors\n */\n /**\n * @declare Highcharts.SeriesPieDataLabelsOptionsObject\n * @extends plotOptions.series.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @private\n */\n dataLabels: {\n /**\n * Alignment method for data labels. Possible values are:\n *\n * - `plotEdges`: Each label touches the nearest vertical edge of\n * the plot area.\n *\n * - `connectors`: Connectors have the same x position and the\n * widest label of each half (left & right) touches the nearest\n * vertical edge of the plot area.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-connectors/\n * alignTo: connectors\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-alignto-plotedges/\n * alignTo: plotEdges\n *\n * @type {string}\n * @since 7.0.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.alignTo\n */\n allowOverlap: true,\n /**\n * The color of the line connecting the data label to the pie slice.\n * The default color is the same as the point's color.\n *\n * In styled mode, the connector stroke is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorcolor/\n * Blue connectors\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorColor\n */\n /**\n * The distance from the data label to the connector. Note that\n * data labels also have a default `padding`, so in order for the\n * connector to touch the text, the `padding` must also be 0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorpadding/\n * No padding\n *\n * @since 2.1\n * @product highcharts highmaps\n */\n connectorPadding: 5,\n /**\n * Specifies the method that is used to generate the connector path.\n * Highcharts provides 3 built-in connector shapes: `'crookedLine'`\n * (default since v11), `'fixedOffset'` and `'straight'`.\n *\n * Users can provide their own method by passing a function instead of a\n * string. Three arguments are passed to the callback:\n *\n * - An object that holds the information about the coordinates of the\n * label (`x` & `y` properties) and how the label is located in\n * relation to the pie (`alignment` property). `alignment` can by one\n * of the following: `'left'` (pie on the left side of the data\n * label), `'right'` (pie on the right side of the data label) or\n * `'center'` (data label overlaps the pie).\n *\n * - An object that holds the information about the position of the\n * connector. Its `touchingSliceAt` porperty tells the position of\n * the place where the connector touches the slice.\n *\n * - Data label options\n *\n * The function has to return an SVG path definition in array form (see\n * the example).\n *\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-connectorshape-string/\n * connectorShape is a String\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-connectorshape-function/\n * connectorShape is a function\n *\n * @type {string|Function}\n * @since 7.0.0\n * @product highcharts highmaps\n */\n connectorShape: 'crookedLine',\n /**\n * The width of the line connecting the data label to the pie slice.\n *\n * In styled mode, the connector stroke width is given in the\n * `.highcharts-data-label-connector` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-connectorwidth-disabled/\n * Disable the connector\n * @sample {highcharts} highcharts/css/pie-point/\n * Styled connectors\n *\n * @type {number}\n * @default 1\n * @since 2.1\n * @product highcharts highmaps\n * @apioption plotOptions.pie.dataLabels.connectorWidth\n */\n /**\n * Works only if `connectorShape` is `'crookedLine'`. It defines how\n * far from the vertical plot edge the coonnector path should be\n * crooked. With the default, `undefined`, the crook is placed so that\n * the horizontal line from the label intersects with the radial line\n * extending through the center of the pie slice.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-crookdistance/\n * crookDistance set to 90%\n *\n * @since 7.0.0\n * @product highcharts highmaps\n */\n crookDistance: void 0,\n /**\n * The distance of the data label from the pie's edge. Negative\n * numbers put the data label on top of the pie slices. Can also be\n * defined as a percentage of pie's radius. Connectors are only\n * shown for data labels outside the pie.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-distance/\n * Data labels on top of the pie\n *\n * @type {number|string}\n * @since 2.1\n * @product highcharts highmaps\n */\n distance: 30,\n enabled: true,\n /**\n * A\n * [format string](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * for the data label. Available variables are the same as for\n * `formatter`.\n *\n * @sample {highcharts} highcharts/plotoptions/series-datalabels-format/\n * Add a unit\n *\n * @type {string}\n * @default undefined\n * @since 3.0\n * @apioption plotOptions.pie.dataLabels.format\n */\n // eslint-disable-next-line valid-jsdoc\n /**\n * Callback JavaScript function to format the data label. Note that\n * if a `format` is defined, the format takes precedence and the\n * formatter is ignored.\n *\n * @type {Highcharts.DataLabelsFormatterCallbackFunction}\n * @default function () { return this.point.isNull ? void 0 : this.point.name; }\n */\n formatter: function () {\n return this.point.isNull ? void 0 : this.point.name;\n },\n /**\n * Whether to render the connector as a soft arc or a line with a sharp\n * break. Works only if `connectorShape` equals to `fixedOffset`.\n *\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-softconnector-true/\n * Soft\n * @sample {highcharts}\n * highcharts/plotoptions/pie-datalabels-softconnector-false/\n * Non soft\n *\n * @since 2.1.7\n * @product highcharts highmaps\n */\n softConnector: true,\n /**\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow\n * Long labels truncated with an ellipsis\n * @sample {highcharts} highcharts/plotoptions/pie-datalabels-overflow-wrap\n * Long labels are wrapped\n *\n * @type {Highcharts.CSSObject}\n * @apioption plotOptions.pie.dataLabels.style\n */\n x: 0\n },\n /**\n * If the total sum of the pie's values is 0, the series is represented\n * as an empty circle . The `fillColor` option defines the color of that\n * circle. Use [pie.borderWidth](#plotOptions.pie.borderWidth) to set\n * the border thickness.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-emptyseries/\n * Empty pie series\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @private\n */\n fillColor: void 0,\n /**\n * The end angle of the pie in degrees where 0 is top and 90 is right.\n * Defaults to `startAngle` plus 360.\n *\n * @sample {highcharts} highcharts/demo/pie-semi-circle/\n * Semi-circle donut\n *\n * @type {number}\n * @since 1.3.6\n * @product highcharts highmaps\n * @apioption plotOptions.pie.endAngle\n */\n /**\n * Thickness describing the ring size for a donut type chart,\n * overriding [innerSize](#plotOptions.pie.innerSize).\n *\n * @type {number}\n * @default undefined\n * @product highcharts\n * @since 10.1.0\n * @apioption plotOptions.pie.thickness\n * @private\n */\n /**\n * Equivalent to [chart.ignoreHiddenSeries](#chart.ignoreHiddenSeries),\n * this option tells whether the series shall be redrawn as if the\n * hidden point were `null`.\n *\n * The default value changed from `false` to `true` with Highcharts\n * 3.0.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-ignorehiddenpoint/\n * True, the hiddden point is ignored\n *\n * @since 2.3.0\n * @product highcharts highmaps\n *\n * @private\n */\n ignoreHiddenPoint: true,\n /**\n * @ignore-option\n *\n * @private\n */\n inactiveOtherPoints: true,\n /**\n * The size of the inner diameter for the pie. A size greater than 0\n * renders a donut chart. Can be a percentage or pixel value.\n * Percentages are relative to the pie size. Pixel values are given as\n * integers. Setting overridden by thickness.\n *\n *\n * Note: in Highcharts < 4.1.2, the percentage was relative to the plot\n * area, not the pie size.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-80px/\n * 80px inner size\n * @sample {highcharts} highcharts/plotoptions/pie-innersize-50percent/\n * 50% of the plot area\n * @sample {highcharts} highcharts/demo/3d-pie-donut/\n * 3D donut\n *\n * @type {number|string}\n * @default 0\n * @since 2.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.innerSize\n */\n /**\n * @ignore-option\n *\n * @private\n */\n legendType: 'point',\n /**\n * @ignore-option\n *\n * @private\n */\n marker: null,\n /**\n * The minimum size for a pie in response to auto margins. The pie will\n * try to shrink to make room for data labels in side the plot area,\n * but only to this size.\n *\n * @type {number|string}\n * @default 80\n * @since 3.0\n * @product highcharts highmaps\n * @apioption plotOptions.pie.minSize\n */\n /**\n * The diameter of the pie relative to the plot area. Can be a\n * percentage or pixel value. Pixel values are given as integers. The\n * default behaviour (as of 3.0) is to scale to the plot area and give\n * room for data labels within the plot area.\n * [slicedOffset](#plotOptions.pie.slicedOffset) is also included in the\n * default size calculation. As a consequence, the size of the pie may\n * vary when points are updated and data labels more around. In that\n * case it is best to set a fixed value, for example `\"75%\"`.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-size/\n * Smaller pie\n *\n * @type {number|string|null}\n * @product highcharts highmaps\n *\n * @private\n */\n size: null,\n /**\n * Whether to display this particular series or series type in the\n * legend. Since 2.1, pies are not shown in the legend by default.\n *\n * @sample {highcharts} highcharts/plotoptions/series-showinlegend/\n * One series in the legend, one hidden\n *\n * @product highcharts highmaps\n *\n * @private\n */\n showInLegend: false,\n /**\n * If a point is sliced, moved out from the center, how many pixels\n * should it be moved?.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-slicedoffset-20/\n * 20px offset\n *\n * @product highcharts highmaps\n *\n * @private\n */\n slicedOffset: 10,\n /**\n * The start angle of the pie slices in degrees where 0 is top and 90\n * right.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-startangle-90/\n * Start from right\n *\n * @type {number}\n * @default 0\n * @since 2.3.4\n * @product highcharts highmaps\n * @apioption plotOptions.pie.startAngle\n */\n /**\n * Sticky tracking of mouse events. When true, the `mouseOut` event\n * on a series isn't triggered until the mouse moves over another\n * series, or out of the plot area. When false, the `mouseOut` event on\n * a series is triggered when the mouse leaves the area around the\n * series' graph or markers. This also implies the tooltip. When\n * `stickyTracking` is false and `tooltip.shared` is false, the tooltip\n * will be hidden when moving the mouse between series.\n *\n * @product highcharts highmaps\n *\n * @private\n */\n stickyTracking: false,\n tooltip: {\n followPointer: true\n },\n /**\n * The color of the border surrounding each slice. When `null`, the\n * border takes the same color as the slice fill. This can be used\n * together with a `borderWidth` to fill drawing gaps created by\n * antialiazing artefacts in borderless pies.\n *\n * In styled mode, the border stroke is given in the `.highcharts-point`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-bordercolor-black/\n * Black border\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highcharts highmaps\n *\n * @private\n */\n borderColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The width of the border surrounding each slice.\n *\n * When setting the border width to 0, there may be small gaps between\n * the slices due to SVG antialiasing artefacts. To work around this,\n * keep the border width at 0.5 or 1, but set the `borderColor` to\n * `null` instead.\n *\n * In styled mode, the border stroke width is given in the\n * `.highcharts-point` class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-borderwidth/\n * 3px border\n *\n * @product highcharts highmaps\n *\n * @private\n */\n borderWidth: 1,\n /**\n * @ignore-option\n * @private\n */\n lineWidth: void 0,\n states: {\n /**\n * @extends plotOptions.series.states.hover\n * @excluding marker, lineWidth, lineWidthPlus\n * @product highcharts highmaps\n */\n hover: {\n /**\n * How much to brighten the point on interaction. Requires the\n * main color to be defined in hex or rgb(a) format.\n *\n * In styled mode, the hover brightness is by default replaced\n * by a fill-opacity given in the `.highcharts-point-hover`\n * class.\n *\n * @sample {highcharts} highcharts/plotoptions/pie-states-hover-brightness/\n * Brightened by 0.5\n *\n * @product highcharts highmaps\n */\n brightness: 0.1\n }\n }\n };\n /**\n * A `pie` series. If the [type](#series.pie.type) option is not specified,\n * it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.pie\n * @excluding cropThreshold, dataParser, dataURL, linkedTo, stack, xAxis, yAxis,\n * dataSorting, step, boostThreshold, boostBlending\n * @product highcharts highmaps\n * @apioption series.pie\n */\n /**\n * An array of data points for the series. For the `pie` series type,\n * points can be given in the following ways:\n *\n * 1. An array of numerical values. In this case, the numerical values will be\n * interpreted as `y` options. Example:\n * ```js\n * data: [0, 5, 3, 5]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.pie.turboThreshold),\n * this option is not available.\n * ```js\n * data: [{\n * y: 1,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * y: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @sample {highcharts} highcharts/chart/reflow-true/\n * Numerical values\n * @sample {highcharts} highcharts/series/data-array-of-arrays/\n * Arrays of numeric x and y\n * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/\n * Arrays of datetime x and y\n * @sample {highcharts} highcharts/series/data-array-of-name-value/\n * Arrays of point.name and y\n * @sample {highcharts} highcharts/series/data-array-of-objects/\n * Config objects\n *\n * @type {Array|null|*>}\n * @extends series.line.data\n * @excluding marker, x\n * @product highcharts highmaps\n * @apioption series.pie.data\n */\n /**\n * @type {Highcharts.SeriesPieDataLabelsOptionsObject}\n * @product highcharts highmaps\n * @apioption series.pie.data.dataLabels\n */\n /**\n * The sequential index of the data point in the legend.\n *\n * @type {number}\n * @product highcharts highmaps\n * @apioption series.pie.data.legendIndex\n */\n /**\n * Whether to display a slice offset from the center.\n *\n * @sample {highcharts} highcharts/point/sliced/\n * One sliced point\n *\n * @type {boolean}\n * @product highcharts highmaps\n * @apioption series.pie.data.sliced\n */\n /**\n * @extends plotOptions.pie.dataLabels\n * @excluding align, allowOverlap, inside, staggerLines, step\n * @product highcharts highmaps\n * @apioption series.pie.dataLabels\n */\n /**\n * @excluding legendItemClick\n * @product highcharts highmaps\n * @apioption series.pie.events\n */\n ''; // placeholder for transpiled doclets above\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Pie/PieSeries.js', [_modules['Series/CenteredUtilities.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Core/Globals.js'], _modules['Series/Pie/PiePoint.js'], _modules['Series/Pie/PieSeriesDefaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/Symbols.js'], _modules['Core/Utilities.js']], function (CU, ColumnSeries, H, PiePoint, PieSeriesDefaults, Series, SeriesRegistry, Symbols, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getStartAndEndRadians } = CU;\n const { noop } = H;\n const { clamp, extend, fireEvent, merge, pick, relativeLength } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Pie series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.pie\n *\n * @augments Highcharts.Series\n */\n class PieSeries extends Series {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.center = void 0;\n this.data = void 0;\n this.maxLabelDistance = void 0;\n this.options = void 0;\n this.points = void 0;\n /* eslint-enable valid-jsdoc */\n }\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Animates the pies in.\n * @private\n */\n animate(init) {\n const series = this, points = series.points, startAngleRad = series.startAngleRad;\n if (!init) {\n points.forEach(function (point) {\n const graphic = point.graphic, args = point.shapeArgs;\n if (graphic && args) {\n // start values\n graphic.attr({\n // animate from inner radius (#779)\n r: pick(point.startR, (series.center && series.center[3] / 2)),\n start: startAngleRad,\n end: startAngleRad\n });\n // animate\n graphic.animate({\n r: args.r,\n start: args.start,\n end: args.end\n }, series.options.animation);\n }\n });\n }\n }\n /**\n * Called internally to draw auxiliary graph in pie-like series in\n * situtation when the default graph is not sufficient enough to present\n * the data well. Auxiliary graph is saved in the same object as\n * regular graph.\n * @private\n */\n drawEmpty() {\n const start = this.startAngleRad, end = this.endAngleRad, options = this.options;\n let centerX, centerY;\n // Draw auxiliary graph if there're no visible points.\n if (this.total === 0 && this.center) {\n centerX = this.center[0];\n centerY = this.center[1];\n if (!this.graph) {\n this.graph = this.chart.renderer\n .arc(centerX, centerY, this.center[1] / 2, 0, start, end)\n .addClass('highcharts-empty-series')\n .add(this.group);\n }\n this.graph.attr({\n d: Symbols.arc(centerX, centerY, this.center[2] / 2, 0, {\n start,\n end,\n innerR: this.center[3] / 2\n })\n });\n if (!this.chart.styledMode) {\n this.graph.attr({\n 'stroke-width': options.borderWidth,\n fill: options.fillColor || 'none',\n stroke: options.color || \"#cccccc\" /* Palette.neutralColor20 */\n });\n }\n }\n else if (this.graph) { // Destroy the graph object.\n this.graph = this.graph.destroy();\n }\n }\n /**\n * Slices in pie chart are initialized in DOM, but it's shapes and\n * animations are normally run in `drawPoints()`.\n * @private\n */\n drawPoints() {\n const renderer = this.chart.renderer;\n this.points.forEach(function (point) {\n // When updating a series between 2d and 3d or cartesian and\n // polar, the shape type changes.\n if (point.graphic && point.hasNewShapeType()) {\n point.graphic = point.graphic.destroy();\n }\n if (!point.graphic) {\n point.graphic = renderer[point.shapeType](point.shapeArgs)\n .add(point.series.group);\n point.delayedRendering = true;\n }\n });\n }\n /**\n * Extend the generatePoints method by adding total and percentage\n * properties to each point\n * @private\n */\n generatePoints() {\n super.generatePoints();\n this.updateTotals();\n }\n /**\n * Utility for getting the x value from a given y, used for\n * anticollision logic in data labels. Added point for using specific\n * points' label distance.\n * @private\n */\n getX(y, left, point) {\n const center = this.center, \n // Variable pie has individual radius\n radius = this.radii ?\n this.radii[point.index] || 0 :\n center[2] / 2;\n const angle = Math.asin(clamp((y - center[1]) / (radius + point.labelDistance), -1, 1));\n const x = center[0] +\n (left ? -1 : 1) *\n (Math.cos(angle) * (radius + point.labelDistance)) +\n (point.labelDistance > 0 ?\n (left ? -1 : 1) * this.options.dataLabels.padding :\n 0);\n return x;\n }\n /**\n * Define hasData function for non-cartesian series. Returns true if the\n * series has points at all.\n * @private\n */\n hasData() {\n return !!this.processedXData.length; // != 0\n }\n /**\n * Draw the data points\n * @private\n */\n redrawPoints() {\n const series = this, chart = series.chart;\n let groupTranslation, graphic, pointAttr, shapeArgs;\n this.drawEmpty();\n // Apply the drop-shadow to the group because otherwise each element\n // would cast a shadow on others\n if (series.group && !chart.styledMode) {\n series.group.shadow(series.options.shadow);\n }\n // draw the slices\n series.points.forEach(function (point) {\n const animateTo = {};\n graphic = point.graphic;\n if (!point.isNull && graphic) {\n shapeArgs = point.shapeArgs;\n // If the point is sliced, use special translation, else use\n // plot area translation\n groupTranslation = point.getTranslate();\n if (!chart.styledMode) {\n pointAttr = series.pointAttribs(point, (point.selected && 'select'));\n }\n // Draw the slice\n if (!point.delayedRendering) {\n graphic\n .setRadialReference(series.center);\n if (!chart.styledMode) {\n merge(true, animateTo, pointAttr);\n }\n merge(true, animateTo, shapeArgs, groupTranslation);\n graphic.animate(animateTo);\n }\n else {\n graphic\n .setRadialReference(series.center)\n .attr(shapeArgs)\n .attr(groupTranslation);\n if (!chart.styledMode) {\n graphic\n .attr(pointAttr)\n .attr({ 'stroke-linejoin': 'round' });\n }\n point.delayedRendering = false;\n }\n graphic\n .attr({\n visibility: point.visible ? 'inherit' : 'hidden'\n });\n graphic.addClass(point.getClassName(), true);\n }\n else if (graphic) {\n point.graphic = graphic.destroy();\n }\n });\n }\n /**\n * Utility for sorting data labels.\n * @private\n */\n sortByAngle(points, sign) {\n points.sort(function (a, b) {\n return ((typeof a.angle !== 'undefined') &&\n (b.angle - a.angle) * sign);\n });\n }\n /**\n * Do translation for pie slices\n * @private\n */\n translate(positions) {\n fireEvent(this, 'translate');\n this.generatePoints();\n const series = this, precision = 1000, // issue #172\n options = series.options, slicedOffset = options.slicedOffset, connectorOffset = slicedOffset + (options.borderWidth || 0), radians = getStartAndEndRadians(options.startAngle, options.endAngle), startAngleRad = series.startAngleRad = radians.start, endAngleRad = series.endAngleRad = radians.end, circ = endAngleRad - startAngleRad, // 2 * Math.PI,\n points = series.points, labelDistance = options.dataLabels.distance, ignoreHiddenPoint = options.ignoreHiddenPoint, len = points.length;\n let finalConnectorOffset, start, end, angle, \n // the x component of the radius vector for a given point\n radiusX, radiusY, i, point, cumulative = 0;\n // Get positions - either an integer or a percentage string must be\n // given. If positions are passed as a parameter, we're in a\n // recursive loop for adjusting space for data labels.\n if (!positions) {\n series.center = positions = series.getCenter();\n }\n // Calculate the geometry for each point\n for (i = 0; i < len; i++) {\n point = points[i];\n // set start and end angle\n start = startAngleRad + (cumulative * circ);\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n cumulative += point.percentage / 100;\n }\n end = startAngleRad + (cumulative * circ);\n // set the shape\n const shapeArgs = {\n x: positions[0],\n y: positions[1],\n r: positions[2] / 2,\n innerR: positions[3] / 2,\n start: Math.round(start * precision) / precision,\n end: Math.round(end * precision) / precision\n };\n point.shapeType = 'arc';\n point.shapeArgs = shapeArgs;\n // Used for distance calculation for specific point.\n point.labelDistance = pick((point.options.dataLabels &&\n point.options.dataLabels.distance), labelDistance);\n // Compute point.labelDistance if it's defined as percentage\n // of slice radius (#8854)\n point.labelDistance = relativeLength(point.labelDistance, shapeArgs.r);\n // Saved for later dataLabels distance calculation.\n series.maxLabelDistance = Math.max(series.maxLabelDistance || 0, point.labelDistance);\n // The angle must stay within -90 and 270 (#2645)\n angle = (end + start) / 2;\n if (angle > 1.5 * Math.PI) {\n angle -= 2 * Math.PI;\n }\n else if (angle < -Math.PI / 2) {\n angle += 2 * Math.PI;\n }\n // Center for the sliced out slice\n point.slicedTranslation = {\n translateX: Math.round(Math.cos(angle) * slicedOffset),\n translateY: Math.round(Math.sin(angle) * slicedOffset)\n };\n // set the anchor point for tooltips\n radiusX = Math.cos(angle) * positions[2] / 2;\n radiusY = Math.sin(angle) * positions[2] / 2;\n point.tooltipPos = [\n positions[0] + radiusX * 0.7,\n positions[1] + radiusY * 0.7\n ];\n point.half = angle < -Math.PI / 2 || angle > Math.PI / 2 ?\n 1 :\n 0;\n point.angle = angle;\n // Set the anchor point for data labels. Use point.labelDistance\n // instead of labelDistance // #1174\n // finalConnectorOffset - not override connectorOffset value.\n finalConnectorOffset = Math.min(connectorOffset, point.labelDistance / 5); // #1678\n point.labelPosition = {\n natural: {\n // initial position of the data label - it's utilized for\n // finding the final position for the label\n x: positions[0] + radiusX + Math.cos(angle) *\n point.labelDistance,\n y: positions[1] + radiusY + Math.sin(angle) *\n point.labelDistance\n },\n computed: {\n // used for generating connector path -\n // initialized later in drawDataLabels function\n // x: undefined,\n // y: undefined\n },\n // left - pie on the left side of the data label\n // right - pie on the right side of the data label\n // center - data label overlaps the pie\n alignment: point.labelDistance < 0 ?\n 'center' : point.half ? 'right' : 'left',\n connectorPosition: {\n breakAt: {\n x: positions[0] + radiusX + Math.cos(angle) *\n finalConnectorOffset,\n y: positions[1] + radiusY + Math.sin(angle) *\n finalConnectorOffset\n },\n touchingSliceAt: {\n x: positions[0] + radiusX,\n y: positions[1] + radiusY\n }\n }\n };\n }\n fireEvent(series, 'afterTranslate');\n }\n /**\n * Recompute total chart sum and update percentages of points.\n * @private\n */\n updateTotals() {\n const points = this.points, len = points.length, ignoreHiddenPoint = this.options.ignoreHiddenPoint;\n let i, point, total = 0;\n // Get the total sum\n for (i = 0; i < len; i++) {\n point = points[i];\n if (point.isValid() &&\n (!ignoreHiddenPoint || point.visible)) {\n total += point.y;\n }\n }\n this.total = total;\n // Set each point's properties\n for (i = 0; i < len; i++) {\n point = points[i];\n point.percentage =\n (total > 0 && (point.visible || !ignoreHiddenPoint)) ?\n point.y / total * 100 :\n 0;\n point.total = total;\n }\n }\n }\n PieSeries.defaultOptions = merge(Series.defaultOptions, PieSeriesDefaults);\n extend(PieSeries.prototype, {\n axisTypes: [],\n directTouch: true,\n drawGraph: void 0,\n drawTracker: ColumnSeries.prototype.drawTracker,\n getCenter: CU.getCenter,\n getSymbol: noop,\n isCartesian: false,\n noSharedTooltip: true,\n pointAttribs: ColumnSeries.prototype.pointAttribs,\n pointClass: PiePoint,\n requireSorting: false,\n searchPoint: noop,\n trackerGroups: ['group', 'dataLabelsGroup']\n });\n SeriesRegistry.registerSeriesType('pie', PieSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return PieSeries;\n });\n _registerModule(_modules, 'Series/Pie/PieDataLabel.js', [_modules['Core/Series/DataLabel.js'], _modules['Core/Globals.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (DataLabel, H, R, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { noop } = H;\n const { distribute } = R;\n const { series: Series } = SeriesRegistry;\n const { arrayMax, clamp, defined, merge, pick, relativeLength } = U;\n /* *\n *\n * Composition\n *\n * */\n var ColumnDataLabel;\n (function (ColumnDataLabel) {\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n const dataLabelPositioners = {\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionY: function (point) {\n return point.top + point.distributeBox.pos;\n },\n // get the x - use the natural x position for labels near the\n // top and bottom, to prevent the top and botton slice\n // connectors from touching each other on either side\n // Based on the value computed in Highcharts' distribute algorithm.\n radialDistributionX: function (series, point, y, naturalY) {\n return series.getX(y < point.top + 2 || y > point.bottom - 2 ?\n naturalY :\n y, point.half, point);\n },\n // dataLabels.distance determines the x position of the label\n justify: function (point, radius, seriesCenter) {\n return seriesCenter[0] + (point.half ? -1 : 1) *\n (radius + point.labelDistance);\n },\n // Left edges of the left-half labels touch the left edge of the plot\n // area. Right edges of the right-half labels touch the right edge of\n // the plot area.\n alignToPlotEdges: function (dataLabel, half, plotWidth, plotLeft) {\n const dataLabelWidth = dataLabel.getBBox().width;\n return half ? dataLabelWidth + plotLeft :\n plotWidth - dataLabelWidth - plotLeft;\n },\n // Connectors of each side end in the same x position. Labels are\n // aligned to them. Left edge of the widest left-half label touches the\n // left edge of the plot area. Right edge of the widest right-half label\n // touches the right edge of the plot area.\n alignToConnectors: function (points, half, plotWidth, plotLeft) {\n let maxDataLabelWidth = 0, dataLabelWidth;\n // find widest data label\n points.forEach(function (point) {\n dataLabelWidth = point.dataLabel.getBBox().width;\n if (dataLabelWidth > maxDataLabelWidth) {\n maxDataLabelWidth = dataLabelWidth;\n }\n });\n return half ? maxDataLabelWidth + plotLeft :\n plotWidth - maxDataLabelWidth - plotLeft;\n }\n };\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /** @private */\n function compose(PieSeriesClass) {\n DataLabel.compose(Series);\n if (U.pushUnique(composedMembers, PieSeriesClass)) {\n const pieProto = PieSeriesClass.prototype;\n pieProto.dataLabelPositioners = dataLabelPositioners;\n pieProto.alignDataLabel = noop;\n pieProto.drawDataLabels = drawDataLabels;\n pieProto.placeDataLabels = placeDataLabels;\n pieProto.verifyDataLabelOverflow = verifyDataLabelOverflow;\n }\n }\n ColumnDataLabel.compose = compose;\n /**\n * Override the base drawDataLabels method by pie specific functionality\n * @private\n */\n function drawDataLabels() {\n const series = this, data = series.data, chart = series.chart, options = series.options.dataLabels || {}, connectorPadding = options.connectorPadding, plotWidth = chart.plotWidth, plotHeight = chart.plotHeight, plotLeft = chart.plotLeft, maxWidth = Math.round(chart.chartWidth / 3), seriesCenter = series.center, radius = seriesCenter[2] / 2, centerY = seriesCenter[1], halves = [\n [],\n [] // left\n ], overflow = [0, 0, 0, 0], // top, right, bottom, left\n dataLabelPositioners = series.dataLabelPositioners;\n let point, connectorWidth, connector, dataLabel, dataLabelWidth, \n // labelPos,\n labelPosition, labelHeight, \n // divide the points into right and left halves for anti collision\n x, y, visibility, j, pointDataLabelsOptions;\n // get out if not enabled\n if (!series.visible ||\n (!options.enabled &&\n !series._hasPointLabels)) {\n return;\n }\n // Reset all labels that have been shortened\n data.forEach(function (point) {\n if (point.dataLabel && point.visible && point.dataLabel.shortened) {\n point.dataLabel\n .attr({\n width: 'auto'\n }).css({\n width: 'auto',\n textOverflow: 'clip'\n });\n point.dataLabel.shortened = false;\n }\n });\n // run parent method\n Series.prototype.drawDataLabels.apply(series);\n data.forEach(function (point) {\n if (point.dataLabel) {\n if (point.visible) { // #407, #2510\n // Arrange points for detection collision\n halves[point.half].push(point);\n // Reset positions (#4905)\n point.dataLabel._pos = null;\n // Avoid long labels squeezing the pie size too far down\n if (!defined(options.style.width) &&\n !defined(point.options.dataLabels &&\n point.options.dataLabels.style &&\n point.options.dataLabels.style.width)) {\n if (point.dataLabel.getBBox().width > maxWidth) {\n point.dataLabel.css({\n // Use a fraction of the maxWidth to avoid\n // wrapping close to the end of the string.\n width: Math.round(maxWidth * 0.7) + 'px'\n });\n point.dataLabel.shortened = true;\n }\n }\n }\n else {\n point.dataLabel = point.dataLabel.destroy();\n // Workaround to make pies destroy multiple datalabels\n // correctly. This logic needs rewriting to support multiple\n // datalabels fully.\n if (point.dataLabels && point.dataLabels.length === 1) {\n delete point.dataLabels;\n }\n }\n }\n });\n /* Loop over the points in each half, starting from the top and bottom\n * of the pie to detect overlapping labels.\n */\n halves.forEach((points, i) => {\n const length = points.length, positions = [];\n let top, bottom, naturalY, sideOverflow, size = 0, distributionLength;\n if (!length) {\n return;\n }\n // Sort by angle\n series.sortByAngle(points, i - 0.5);\n // Only do anti-collision when we have dataLabels outside the pie\n // and have connectors. (#856)\n if (series.maxLabelDistance > 0) {\n top = Math.max(0, centerY - radius - series.maxLabelDistance);\n bottom = Math.min(centerY + radius + series.maxLabelDistance, chart.plotHeight);\n points.forEach(function (point) {\n // check if specific points' label is outside the pie\n if (point.labelDistance > 0 && point.dataLabel) {\n // point.top depends on point.labelDistance value\n // Used for calculation of y value in getX method\n point.top = Math.max(0, centerY - radius - point.labelDistance);\n point.bottom = Math.min(centerY + radius + point.labelDistance, chart.plotHeight);\n size = point.dataLabel.getBBox().height || 21;\n // point.positionsIndex is needed for getting index of\n // parameter related to specific point inside positions\n // array - not every point is in positions array.\n point.distributeBox = {\n target: point.labelPosition.natural.y -\n point.top + size / 2,\n size,\n rank: point.y\n };\n positions.push(point.distributeBox);\n }\n });\n distributionLength = bottom + size - top;\n distribute(positions, distributionLength, distributionLength / 5);\n }\n // Now the used slots are sorted, fill them up sequentially\n for (j = 0; j < length; j++) {\n point = points[j];\n // labelPos = point.labelPos;\n labelPosition = point.labelPosition;\n dataLabel = point.dataLabel;\n visibility = point.visible === false ? 'hidden' : 'inherit';\n naturalY = labelPosition.natural.y;\n y = naturalY;\n if (positions && defined(point.distributeBox)) {\n if (typeof point.distributeBox.pos === 'undefined') {\n visibility = 'hidden';\n }\n else {\n labelHeight = point.distributeBox.size;\n // Find label's y position\n y = dataLabelPositioners\n .radialDistributionY(point);\n }\n }\n // It is needed to delete point.positionIndex for\n // dynamically added points etc.\n delete point.positionIndex; // @todo unused\n // Find label's x position\n // justify is undocumented in the API - preserve support for it\n if (options.justify) {\n x = dataLabelPositioners.justify(point, radius, seriesCenter);\n }\n else {\n switch (options.alignTo) {\n case 'connectors':\n x = dataLabelPositioners.alignToConnectors(points, i, plotWidth, plotLeft);\n break;\n case 'plotEdges':\n x = dataLabelPositioners.alignToPlotEdges(dataLabel, i, plotWidth, plotLeft);\n break;\n default:\n x = dataLabelPositioners.radialDistributionX(series, point, y, naturalY);\n }\n }\n // Record the placement and visibility\n dataLabel._attr = {\n visibility: visibility,\n align: labelPosition.alignment\n };\n pointDataLabelsOptions = point.options.dataLabels || {};\n dataLabel._pos = {\n x: (x +\n pick(pointDataLabelsOptions.x, options.x) + // (#12985)\n ({\n left: connectorPadding,\n right: -connectorPadding\n }[labelPosition.alignment] || 0)),\n y: (y +\n pick(pointDataLabelsOptions.y, options.y) - // (#12985)\n // Vertically center\n dataLabel.getBBox().height / 2)\n };\n // labelPos.x = x;\n // labelPos.y = y;\n if (labelPosition) {\n labelPosition.computed.x = x;\n labelPosition.computed.y = y;\n }\n // Detect overflowing data labels\n if (pick(options.crop, true)) {\n dataLabelWidth = dataLabel.getBBox().width;\n sideOverflow = null;\n // Overflow left\n if (x - dataLabelWidth < connectorPadding &&\n i === 1 // left half\n ) {\n sideOverflow = Math.round(dataLabelWidth - x + connectorPadding);\n overflow[3] = Math.max(sideOverflow, overflow[3]);\n // Overflow right\n }\n else if (x + dataLabelWidth > plotWidth - connectorPadding &&\n i === 0 // right half\n ) {\n sideOverflow = Math.round(x + dataLabelWidth - plotWidth + connectorPadding);\n overflow[1] = Math.max(sideOverflow, overflow[1]);\n }\n // Overflow top\n if (y - labelHeight / 2 < 0) {\n overflow[0] = Math.max(Math.round(-y + labelHeight / 2), overflow[0]);\n // Overflow left\n }\n else if (y + labelHeight / 2 > plotHeight) {\n overflow[2] = Math.max(Math.round(y + labelHeight / 2 - plotHeight), overflow[2]);\n }\n dataLabel.sideOverflow = sideOverflow;\n }\n } // for each point\n }); // for each half\n // Do not apply the final placement and draw the connectors until we\n // have verified that labels are not spilling over.\n if (arrayMax(overflow) === 0 ||\n this.verifyDataLabelOverflow(overflow)) {\n // Place the labels in the final position\n this.placeDataLabels();\n this.points.forEach(function (point) {\n // #8864: every connector can have individual options\n pointDataLabelsOptions =\n merge(options, point.options.dataLabels);\n connectorWidth =\n pick(pointDataLabelsOptions.connectorWidth, 1);\n // Draw the connector\n if (connectorWidth) {\n let isNew;\n connector = point.connector;\n dataLabel = point.dataLabel;\n if (dataLabel &&\n dataLabel._pos &&\n point.visible &&\n point.labelDistance > 0) {\n visibility = dataLabel._attr.visibility;\n isNew = !connector;\n if (isNew) {\n point.connector = connector = chart.renderer\n .path()\n .addClass('highcharts-data-label-connector ' +\n ' highcharts-color-' + point.colorIndex +\n (point.className ?\n ' ' + point.className :\n ''))\n .add(series.dataLabelsGroup);\n if (!chart.styledMode) {\n connector.attr({\n 'stroke-width': connectorWidth,\n 'stroke': (pointDataLabelsOptions.connectorColor ||\n point.color ||\n \"#666666\" /* Palette.neutralColor60 */)\n });\n }\n }\n connector[isNew ? 'attr' : 'animate']({\n d: point.getConnectorPath()\n });\n connector.attr('visibility', visibility);\n }\n else if (connector) {\n point.connector = connector.destroy();\n }\n }\n });\n }\n }\n /**\n * Perform the final placement of the data labels after we have verified\n * that they fall within the plot area.\n * @private\n */\n function placeDataLabels() {\n this.points.forEach(function (point) {\n let dataLabel = point.dataLabel, _pos;\n if (dataLabel && point.visible) {\n _pos = dataLabel._pos;\n if (_pos) {\n // Shorten data labels with ellipsis if they still overflow\n // after the pie has reached minSize (#223).\n if (dataLabel.sideOverflow) {\n dataLabel._attr.width =\n Math.max(dataLabel.getBBox().width -\n dataLabel.sideOverflow, 0);\n dataLabel.css({\n width: dataLabel._attr.width + 'px',\n textOverflow: ((this.options.dataLabels.style || {})\n .textOverflow ||\n 'ellipsis')\n });\n dataLabel.shortened = true;\n }\n dataLabel.attr(dataLabel._attr);\n dataLabel[dataLabel.moved ? 'animate' : 'attr'](_pos);\n dataLabel.moved = true;\n }\n else if (dataLabel) {\n dataLabel.attr({ y: -9999 });\n }\n }\n // Clear for update\n delete point.distributeBox;\n }, this);\n }\n /**\n * Verify whether the data labels are allowed to draw, or we should run more\n * translation and data label positioning to keep them inside the plot area.\n * Returns true when data labels are ready to draw.\n * @private\n */\n function verifyDataLabelOverflow(overflow) {\n let center = this.center, options = this.options, centerOption = options.center, minSize = options.minSize || 80, newSize = minSize, \n // If a size is set, return true and don't try to shrink the pie\n // to fit the labels.\n ret = options.size !== null;\n if (!ret) {\n // Handle horizontal size and center\n if (centerOption[0] !== null) { // Fixed center\n newSize = Math.max(center[2] -\n Math.max(overflow[1], overflow[3]), minSize);\n }\n else { // Auto center\n newSize = Math.max(\n // horizontal overflow\n center[2] - overflow[1] - overflow[3], minSize);\n // horizontal center\n center[0] += (overflow[3] - overflow[1]) / 2;\n }\n // Handle vertical size and center\n if (centerOption[1] !== null) { // Fixed center\n newSize = clamp(newSize, minSize, center[2] - Math.max(overflow[0], overflow[2]));\n }\n else { // Auto center\n newSize = clamp(newSize, minSize, \n // vertical overflow\n center[2] - overflow[0] - overflow[2]);\n // vertical center\n center[1] += (overflow[0] - overflow[2]) / 2;\n }\n // If the size must be decreased, we need to run translate and\n // drawDataLabels again\n if (newSize < center[2]) {\n center[2] = newSize;\n center[3] = Math.min(// #3632\n options.thickness ?\n Math.max(0, newSize - options.thickness * 2) :\n Math.max(0, relativeLength(options.innerSize || 0, newSize)), newSize); // #6647\n this.translate(center);\n if (this.drawDataLabels) {\n this.drawDataLabels();\n }\n // Else, return true to indicate that the pie and its labels is\n // within the plot area\n }\n else {\n ret = true;\n }\n }\n return ret;\n }\n })(ColumnDataLabel || (ColumnDataLabel = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ColumnDataLabel;\n });\n _registerModule(_modules, 'Extensions/OverlappingDataLabels.js', [_modules['Core/Chart/Chart.js'], _modules['Core/Utilities.js']], function (Chart, U) {\n /* *\n *\n * Highcharts module to hide overlapping data labels.\n * This module is included in Highcharts.\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, fireEvent, isArray, isNumber, objectEach, pick } = U;\n /**\n * Internal type\n * @private\n */\n /* eslint-disable no-invalid-this */\n // Collect potensial overlapping data labels. Stack labels probably don't need\n // to be considered because they are usually accompanied by data labels that lie\n // inside the columns.\n addEvent(Chart, 'render', function collectAndHide() {\n let chart = this, labels = [];\n // Consider external label collectors\n (this.labelCollectors || []).forEach(function (collector) {\n labels = labels.concat(collector());\n });\n (this.yAxis || []).forEach(function (yAxis) {\n if (yAxis.stacking &&\n yAxis.options.stackLabels &&\n !yAxis.options.stackLabels.allowOverlap) {\n objectEach(yAxis.stacking.stacks, function (stack) {\n objectEach(stack, function (stackItem) {\n if (stackItem.label) {\n labels.push(stackItem.label);\n }\n });\n });\n }\n });\n (this.series || []).forEach(function (series) {\n const dlOptions = series.options.dataLabels;\n if (series.visible &&\n !(dlOptions.enabled === false && !series._hasPointLabels)) { // #3866\n const push = (points) => points.forEach((point) => {\n if (point.visible) {\n const dataLabels = (isArray(point.dataLabels) ?\n point.dataLabels :\n (point.dataLabel ? [point.dataLabel] : []));\n dataLabels.forEach(function (label) {\n const options = label.options;\n label.labelrank = pick(options.labelrank, point.labelrank, point.shapeArgs && point.shapeArgs.height); // #4118\n if (!options.allowOverlap) {\n labels.push(label);\n }\n else { // #13449\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n hideOrShow(label, chart);\n }\n });\n }\n });\n push(series.nodes || []);\n push(series.points);\n }\n });\n this.hideOverlappingLabels(labels);\n });\n /**\n * Hide overlapping labels. Labels are moved and faded in and out on zoom to\n * provide a smooth visual imression.\n *\n * @private\n * @function Highcharts.Chart#hideOverlappingLabels\n * @param {Array} labels\n * Rendered data labels\n * @requires modules/overlapping-datalabels\n */\n Chart.prototype.hideOverlappingLabels = function (labels) {\n let chart = this, len = labels.length, ren = chart.renderer, label, i, j, label1, label2, box1, box2, isLabelAffected = false, isIntersectRect = function (box1, box2) {\n return !(box2.x >= box1.x + box1.width ||\n box2.x + box2.width <= box1.x ||\n box2.y >= box1.y + box1.height ||\n box2.y + box2.height <= box1.y);\n }, \n // Get the box with its position inside the chart, as opposed to getBBox\n // that only reports the position relative to the parent.\n getAbsoluteBox = function (label) {\n let pos, parent, bBox, \n // Substract the padding if no background or border (#4333)\n padding = label.box ? 0 : (label.padding || 0), lineHeightCorrection = 0, xOffset = 0, boxWidth, alignValue;\n if (label &&\n (!label.alignAttr || label.placed)) {\n pos = label.alignAttr || {\n x: label.attr('x'),\n y: label.attr('y')\n };\n parent = label.parentGroup;\n // Get width and height if pure text nodes (stack labels)\n if (!label.width) {\n bBox = label.getBBox();\n label.width = bBox.width;\n label.height = bBox.height;\n // Labels positions are computed from top left corner, so we\n // need to substract the text height from text nodes too.\n lineHeightCorrection = ren.fontMetrics(label.element).h;\n }\n boxWidth = label.width - 2 * padding;\n alignValue = {\n left: '0',\n center: '0.5',\n right: '1'\n }[label.alignValue];\n if (alignValue) {\n xOffset = +alignValue * boxWidth;\n }\n else if (isNumber(label.x) &&\n Math.round(label.x) !== label.translateX) {\n xOffset = label.x - label.translateX;\n }\n return {\n x: pos.x + (parent.translateX || 0) + padding -\n (xOffset || 0),\n y: pos.y + (parent.translateY || 0) + padding -\n lineHeightCorrection,\n width: label.width - 2 * padding,\n height: label.height - 2 * padding\n };\n }\n };\n for (i = 0; i < len; i++) {\n label = labels[i];\n if (label) {\n // Mark with initial opacity\n label.oldOpacity = label.opacity;\n label.newOpacity = 1;\n label.absoluteBox = getAbsoluteBox(label);\n }\n }\n // Prevent a situation in a gradually rising slope, that each label will\n // hide the previous one because the previous one always has lower rank.\n labels.sort(function (a, b) {\n return (b.labelrank || 0) - (a.labelrank || 0);\n });\n // Detect overlapping labels\n for (i = 0; i < len; i++) {\n label1 = labels[i];\n box1 = label1 && label1.absoluteBox;\n for (j = i + 1; j < len; ++j) {\n label2 = labels[j];\n box2 = label2 && label2.absoluteBox;\n if (box1 &&\n box2 &&\n label1 !== label2 && // #6465, polar chart with connectEnds\n label1.newOpacity !== 0 &&\n label2.newOpacity !== 0 &&\n // #15863 dataLabels are no longer hidden by translation\n label1.visibility !== 'hidden' &&\n label2.visibility !== 'hidden') {\n if (isIntersectRect(box1, box2)) {\n (label1.labelrank < label2.labelrank ? label1 : label2)\n .newOpacity = 0;\n }\n }\n }\n }\n // Hide or show\n labels.forEach(function (label) {\n if (hideOrShow(label, chart)) {\n isLabelAffected = true;\n }\n });\n if (isLabelAffected) {\n fireEvent(chart, 'afterHideAllOverlappingLabels');\n }\n };\n /**\n * Hide or show labels based on opacity.\n *\n * @private\n * @function hideOrShow\n * @param {Highcharts.SVGElement} label\n * The label.\n * @param {Highcharts.Chart} chart\n * The chart that contains the label.\n * @return {boolean}\n * Whether label is affected\n */\n function hideOrShow(label, chart) {\n let complete, newOpacity, isLabelAffected = false;\n if (label) {\n newOpacity = label.newOpacity;\n if (label.oldOpacity !== newOpacity) {\n // Make sure the label is completely hidden to avoid catching clicks\n // (#4362)\n if (label.alignAttr && label.placed) { // data labels\n label[newOpacity ? 'removeClass' : 'addClass']('highcharts-data-label-hidden');\n complete = function () {\n if (!chart.styledMode) {\n label.css({\n pointerEvents: newOpacity ? 'auto' : 'none'\n });\n }\n };\n isLabelAffected = true;\n // Animate or set the opacity\n label.alignAttr.opacity = newOpacity;\n label[label.isOld ? 'animate' : 'attr'](label.alignAttr, null, complete);\n fireEvent(chart, 'afterHideOverlappingLabel');\n }\n else { // other labels, tick labels\n label.attr({\n opacity: newOpacity\n });\n }\n }\n label.isOld = true;\n }\n return isLabelAffected;\n }\n\n });\n _registerModule(_modules, 'Extensions/BorderRadius.js', [_modules['Core/Defaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (D, Series, SeriesRegistry, SVGElement, SVGRenderer, U) {\n /* *\n *\n * Highcharts Border Radius module\n *\n * Author: Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { seriesTypes } = SeriesRegistry;\n const { addEvent, extend, isObject, merge, relativeLength } = U;\n /* *\n *\n * Constants\n *\n * */\n const defaultBorderRadiusOptions = {\n radius: 0,\n scope: 'stack',\n where: void 0\n };\n const optionsToObject = (options, seriesBROptions) => {\n if (!isObject(options)) {\n options = { radius: options || 0 };\n }\n return merge(defaultBorderRadiusOptions, seriesBROptions, options);\n };\n const applyBorderRadius = (path, i, r) => {\n const a = path[i];\n let b = path[i + 1];\n if (b[0] === 'Z') {\n b = path[0];\n }\n let line, arc, fromLineToArc;\n // From straight line to arc\n if ((a[0] === 'M' || a[0] === 'L') && b[0] === 'A') {\n line = a;\n arc = b;\n fromLineToArc = true;\n // From arc to straight line\n }\n else if (a[0] === 'A' && (b[0] === 'M' || b[0] === 'L')) {\n line = b;\n arc = a;\n }\n if (line && arc && arc.params) {\n const bigR = arc[1], \n // In our use cases, outer pie slice arcs are clockwise and inner\n // arcs (donut/sunburst etc) are anti-clockwise\n clockwise = arc[5], params = arc.params, { start, end, cx, cy } = params;\n // Some geometric constants\n const relativeR = clockwise ? (bigR - r) : (bigR + r), \n // The angle, on the big arc, that the border radius arc takes up\n angleOfBorderRadius = relativeR ? Math.asin(r / relativeR) : 0, angleOffset = clockwise ?\n angleOfBorderRadius :\n -angleOfBorderRadius, \n // The distance along the radius of the big arc to the starting\n // point of the small border radius arc\n distanceBigCenterToStartArc = (Math.cos(angleOfBorderRadius) *\n relativeR);\n // From line to arc\n if (fromLineToArc) {\n // Update the cache\n params.start = start + angleOffset;\n // First move to the start position at the radial line. We want to\n // start one borderRadius closer to the center.\n line[1] = cx + distanceBigCenterToStartArc * Math.cos(start);\n line[2] = cy + distanceBigCenterToStartArc * Math.sin(start);\n // Now draw an arc towards the point where the small circle touches\n // the great circle.\n path.splice(i + 1, 0, [\n 'A',\n r,\n r,\n 0,\n 0,\n 1,\n cx + bigR * Math.cos(params.start),\n cy + bigR * Math.sin(params.start)\n ]);\n // From arc to line\n }\n else {\n // Update the cache\n params.end = end - angleOffset;\n // End the big arc a bit earlier\n arc[6] = cx + bigR * Math.cos(params.end);\n arc[7] = cy + bigR * Math.sin(params.end);\n // Draw a small arc towards a point on the end angle, but one\n // borderRadius closer to the center relative to the perimeter.\n path.splice(i + 1, 0, [\n 'A',\n r,\n r,\n 0,\n 0,\n 1,\n cx + distanceBigCenterToStartArc * Math.cos(end),\n cy + distanceBigCenterToStartArc * Math.sin(end)\n ]);\n }\n // Long or short arc must be reconsidered because we have modified the\n // start and end points\n arc[4] = Math.abs(params.end - params.start) < Math.PI ? 0 : 1;\n }\n };\n /* *\n *\n * Modifications\n *\n * */\n // Check if the module has already been imported\n // @todo implement as composition\n if (SVGElement.symbolCustomAttribs.indexOf('borderRadius') === -1) {\n SVGElement.symbolCustomAttribs.push('borderRadius', 'brBoxHeight', 'brBoxY');\n // Extend arc with borderRadius\n const arc = SVGRenderer.prototype.symbols.arc;\n SVGRenderer.prototype.symbols.arc = function (x, y, w, h, options = {}) {\n const path = arc(x, y, w, h, options), { innerR = 0, r = w, start = 0, end = 0 } = options;\n if (options.open || !options.borderRadius) {\n return path;\n }\n const alpha = end - start, sinHalfAlpha = Math.sin(alpha / 2), borderRadius = Math.max(Math.min(relativeLength(options.borderRadius || 0, r - innerR), \n // Cap to half the sector radius\n (r - innerR) / 2, \n // For smaller pie slices, cap to the largest small circle that\n // can be fitted within the sector\n (r * sinHalfAlpha) / (1 + sinHalfAlpha)), 0), \n // For the inner radius, we need an extra cap because the inner arc\n // is shorter than the outer arc\n innerBorderRadius = Math.min(borderRadius, 2 * (alpha / Math.PI) * innerR);\n // Apply turn-by-turn border radius. Start at the end since we're\n // splicing in arc segments.\n let i = path.length - 1;\n while (i--) {\n applyBorderRadius(path, i, i > 1 ? innerBorderRadius : borderRadius);\n }\n return path;\n };\n // Extend roundedRect with individual cutting through rOffset\n const roundedRect = SVGRenderer.prototype.symbols.roundedRect;\n SVGRenderer.prototype.symbols.roundedRect = function (x, y, width, height, options = {}) {\n const path = roundedRect(x, y, width, height, options), { r = 0, brBoxHeight = height, brBoxY = y } = options, brOffsetTop = y - brBoxY, brOffsetBtm = (brBoxY + brBoxHeight) - (y + height), \n // When the distance to the border-radius box is greater than the r\n // itself, it means no border radius. The -0.1 accounts for float\n // rounding errors.\n rTop = (brOffsetTop - r) > -0.1 ? 0 : r, rBtm = (brOffsetBtm - r) > -0.1 ? 0 : r, cutTop = Math.max(rTop && brOffsetTop, 0), cutBtm = Math.max(rBtm && brOffsetBtm, 0);\n /*\n\n The naming of control points:\n\n / a -------- b \\\n / \\\n h c\n | |\n | |\n | |\n g d\n \\ /\n \\ f -------- e /\n\n */\n const a = [x + rTop, y], b = [x + width - rTop, y], c = [x + width, y + rTop], d = [\n x + width, y + height - rBtm\n ], e = [\n x + width - rBtm,\n y + height\n ], f = [x + rBtm, y + height], g = [x, y + height - rBtm], h = [x, y + rTop];\n const applyPythagoras = (r, altitude) => Math.sqrt(Math.pow(r, 2) - Math.pow(altitude, 2));\n // Inside stacks, cut off part of the top\n if (cutTop) {\n const base = applyPythagoras(rTop, rTop - cutTop);\n a[0] -= base;\n b[0] += base;\n c[1] = h[1] = y + rTop - cutTop;\n }\n // Column is lower than the radius. Cut off bottom inside the top\n // radius.\n if (height < rTop - cutTop) {\n const base = applyPythagoras(rTop, rTop - cutTop - height);\n c[0] = d[0] = x + width - rTop + base;\n e[0] = Math.min(c[0], e[0]);\n f[0] = Math.max(d[0], f[0]);\n g[0] = h[0] = x + rTop - base;\n c[1] = h[1] = y + height;\n }\n // Inside stacks, cut off part of the bottom\n if (cutBtm) {\n const base = applyPythagoras(rBtm, rBtm - cutBtm);\n e[0] += base;\n f[0] -= base;\n d[1] = g[1] = y + height - rBtm + cutBtm;\n }\n // Cut off top inside the bottom radius\n if (height < rBtm - cutBtm) {\n const base = applyPythagoras(rBtm, rBtm - cutBtm - height);\n c[0] = d[0] = x + width - rBtm + base;\n b[0] = Math.min(c[0], b[0]);\n a[0] = Math.max(d[0], a[0]);\n g[0] = h[0] = x + rBtm - base;\n d[1] = g[1] = y;\n }\n // Preserve the box for data labels\n path.length = 0;\n path.push(['M', ...a], \n // top side\n ['L', ...b], \n // top right corner\n ['A', rTop, rTop, 0, 0, 1, ...c], \n // right side\n ['L', ...d], \n // bottom right corner\n ['A', rBtm, rBtm, 0, 0, 1, ...e], \n // bottom side\n ['L', ...f], \n // bottom left corner\n ['A', rBtm, rBtm, 0, 0, 1, ...g], \n // left side\n ['L', ...h], \n // top left corner\n ['A', rTop, rTop, 0, 0, 1, ...a], ['Z']);\n return path;\n };\n addEvent(seriesTypes.pie, 'afterTranslate', function () {\n const borderRadius = optionsToObject(this.options.borderRadius);\n for (const point of this.points) {\n const shapeArgs = point.shapeArgs;\n if (shapeArgs) {\n shapeArgs.borderRadius = relativeLength(borderRadius.radius, (shapeArgs.r || 0) - ((shapeArgs.innerR) || 0));\n }\n }\n });\n addEvent(Series, 'afterColumnTranslate', function () {\n var _a,\n _b;\n if (this.options.borderRadius &&\n !(this.chart.is3d && this.chart.is3d())) {\n const { options, yAxis } = this, percent = options.stacking === 'percent', seriesDefault = (_b = (_a = defaultOptions.plotOptions) === null || _a === void 0 ? void 0 : _a[this.type]) === null || _b === void 0 ? void 0 : _b.borderRadius, borderRadius = optionsToObject(options.borderRadius, isObject(seriesDefault) ? seriesDefault : {}), reversed = yAxis.options.reversed;\n for (const point of this.points) {\n const { shapeArgs } = point;\n if (point.shapeType === 'roundedRect' && shapeArgs) {\n const { width = 0, height = 0, y = 0 } = shapeArgs;\n let brBoxY = y, brBoxHeight = height;\n // It would be nice to refactor StackItem.getStackBox/\n // setOffset so that we could get a reliable box out of\n // it. Currently it is close if we remove the label\n // offset, but we still need to run crispCol and also\n // flip it if inverted, so atm it is simpler to do it\n // like the below.\n if (borderRadius.scope === 'stack' &&\n point.stackTotal) {\n const stackEnd = yAxis.translate(percent ? 100 : point.stackTotal, false, true, false, true), stackThreshold = yAxis.translate(options.threshold || 0, false, true, false, true), box = this.crispCol(0, Math.min(stackEnd, stackThreshold), 0, Math.abs(stackEnd - stackThreshold));\n brBoxY = box.y;\n brBoxHeight = box.height;\n }\n const flip = (point.negative ? -1 : 1) *\n (reversed ? -1 : 1) === -1;\n // Handle the where option\n let where = borderRadius.where;\n // Waterfall, hanging columns should have rounding on\n // all sides\n if (!where &&\n this.is('waterfall') &&\n Math.abs((point.yBottom || 0) -\n (this.translatedThreshold || 0)) > this.borderWidth) {\n where = 'all';\n }\n if (!where) {\n where = 'end';\n }\n // Get the radius\n const r = Math.min(relativeLength(borderRadius.radius, width), width / 2, \n // Cap to the height, but not if where is `end`\n where === 'all' ? height / 2 : Infinity) || 0;\n // If the `where` option is 'end', cut off the\n // rectangles by making the border-radius box one r\n // greater, so that the imaginary radius falls outside\n // the rectangle.\n if (where === 'end') {\n if (flip) {\n brBoxY -= r;\n brBoxHeight += r;\n }\n else {\n brBoxHeight += r;\n }\n }\n extend(shapeArgs, { brBoxHeight, brBoxY, r });\n }\n }\n }\n }, {\n // After columnrange and polar column modifications\n order: 9\n });\n }\n /* *\n *\n * Default Export\n *\n * */\n const BorderRadius = {\n optionsToObject\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Detailed options for border radius.\n *\n * @sample {highcharts} highcharts/plotoptions/column-borderradius/\n * Rounded columns\n * @sample highcharts/plotoptions/series-border-radius\n * Column and pie with rounded border\n *\n * @interface Highcharts.BorderRadiusOptionsObject\n */ /**\n * The border radius. A number signifies pixels. A percentage string, like for\n * example `50%`, signifies a relative size. For columns this is relative to the\n * column width, for pies it is relative to the radius and the inner radius.\n *\n * @name Highcharts.BorderRadiusOptionsObject#radius\n * @type {string|number}\n */ /**\n * The scope of the rounding for column charts. In a stacked column chart, the\n * value `point` means each single point will get rounded corners. The value\n * `stack` means the rounding will apply to the full stack, so that only points\n * close to the top or bottom will receive rounding.\n *\n * @name Highcharts.BorderRadiusOptionsObject#scope\n * @validvalue [\"point\", \"stack\"]\n * @type {string}\n */ /**\n * For column charts, where in the point or stack to apply rounding. The `end`\n * value means only those corners at the point value will be rounded, leaving\n * the corners at the base or threshold unrounded. This is the most intuitive\n * behaviour. The `all` value means also the base will be rounded.\n *\n * @name Highcharts.BorderRadiusOptionsObject#where\n * @validvalue [\"all\", \"end\"]\n * @type {string}\n * @default end\n */\n (''); // keeps doclets above in JS file\n\n return BorderRadius;\n });\n _registerModule(_modules, 'Core/Responsive.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { diffObjects, extend, find, isArray, isObject, merge, objectEach, pick, splat, uniqueKey } = U;\n /* *\n *\n * Composition\n *\n * */\n var Responsive;\n (function (Responsive) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(ChartClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n extend(ChartClass.prototype, {\n matchResponsiveRule,\n setResponsive\n });\n }\n return ChartClass;\n }\n Responsive.compose = compose;\n /**\n * Handle a single responsiveness rule.\n *\n * @private\n * @function Highcharts.Chart#matchResponsiveRule\n * @param {Highcharts.ResponsiveRulesOptions} rule\n * @param {Array} matches\n */\n function matchResponsiveRule(rule, matches) {\n const condition = rule.condition, fn = condition.callback || function () {\n return (this.chartWidth <= pick(condition.maxWidth, Number.MAX_VALUE) &&\n this.chartHeight <= pick(condition.maxHeight, Number.MAX_VALUE) &&\n this.chartWidth >= pick(condition.minWidth, 0) &&\n this.chartHeight >= pick(condition.minHeight, 0));\n };\n if (fn.call(this)) {\n matches.push(rule._id);\n }\n }\n /**\n * Update the chart based on the current chart/document size and options\n * for responsiveness.\n *\n * @private\n * @function Highcharts.Chart#setResponsive\n * @param {boolean} [redraw=true]\n * @param {boolean} [reset=false]\n * Reset by un-applying all rules. Chart.update resets all rules before\n * applying updated options.\n */\n function setResponsive(redraw, reset) {\n const options = this.options.responsive, currentResponsive = this.currentResponsive;\n let ruleIds = [], undoOptions;\n if (!reset && options && options.rules) {\n options.rules.forEach((rule) => {\n if (typeof rule._id === 'undefined') {\n rule._id = uniqueKey();\n }\n this.matchResponsiveRule(rule, ruleIds /* , redraw */);\n }, this);\n }\n // Merge matching rules\n const mergedOptions = merge(...ruleIds\n .map((ruleId) => find((options || {}).rules || [], (rule) => (rule._id === ruleId)))\n .map((rule) => (rule && rule.chartOptions)));\n mergedOptions.isResponsiveOptions = true;\n // Stringified key for the rules that currently apply.\n ruleIds = (ruleIds.toString() || void 0);\n const currentRuleIds = (currentResponsive && currentResponsive.ruleIds);\n // Changes in what rules apply\n if (ruleIds !== currentRuleIds) {\n // Undo previous rules. Before we apply a new set of rules, we\n // need to roll back completely to base options (#6291).\n if (currentResponsive) {\n this.update(currentResponsive.undoOptions, redraw, true);\n }\n if (ruleIds) {\n // Get undo-options for matching rules. The `undoOptions``\n // hold the current values before they are changed by the\n // `mergedOptions`.\n undoOptions = diffObjects(mergedOptions, this.options, true, this.collectionsWithUpdate);\n undoOptions.isResponsiveOptions = true;\n this.currentResponsive = {\n ruleIds: ruleIds,\n mergedOptions: mergedOptions,\n undoOptions: undoOptions\n };\n this.update(mergedOptions, redraw, true);\n }\n else {\n this.currentResponsive = void 0;\n }\n }\n }\n })(Responsive || (Responsive = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A callback function to gain complete control on when the responsive rule\n * applies.\n *\n * @callback Highcharts.ResponsiveCallbackFunction\n *\n * @param {Highcharts.Chart} this\n * Chart context.\n *\n * @return {boolean}\n * Return `true` if it applies.\n */\n (''); // keeps doclets above in JS file\n /* *\n *\n * API Options\n *\n * */\n /**\n * Allows setting a set of rules to apply for different screen or chart\n * sizes. Each rule specifies additional chart options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @since 5.0.0\n * @apioption responsive\n */\n /**\n * A set of rules for responsive settings. The rules are executed from\n * the top down.\n *\n * @sample {highcharts} highcharts/responsive/axis/\n * Axis changes\n * @sample {highstock} highcharts/responsive/axis/\n * Axis changes\n * @sample {highmaps} highcharts/responsive/axis/\n * Axis changes\n *\n * @type {Array<*>}\n * @since 5.0.0\n * @apioption responsive.rules\n */\n /**\n * A full set of chart options to apply as overrides to the general\n * chart options. The chart options are applied when the given rule\n * is active.\n *\n * A special case is configuration objects that take arrays, for example\n * [xAxis](#xAxis), [yAxis](#yAxis) or [series](#series). For these\n * collections, an `id` option is used to map the new option set to\n * an existing object. If an existing object of the same id is not found,\n * the item of the same indexupdated. So for example, setting `chartOptions`\n * with two series items without an `id`, will cause the existing chart's\n * two series to be updated with respective options.\n *\n * @sample {highstock} stock/demo/responsive/\n * Stock chart\n * @sample highcharts/responsive/axis/\n * Axis\n * @sample highcharts/responsive/legend/\n * Legend\n * @sample highcharts/responsive/classname/\n * Class name\n *\n * @type {Highcharts.Options}\n * @since 5.0.0\n * @apioption responsive.rules.chartOptions\n */\n /**\n * Under which conditions the rule applies.\n *\n * @since 5.0.0\n * @apioption responsive.rules.condition\n */\n /**\n * A callback function to gain complete control on when the responsive\n * rule applies. Return `true` if it applies. This opens for checking\n * against other metrics than the chart size, for example the document\n * size or other elements.\n *\n * @type {Highcharts.ResponsiveCallbackFunction}\n * @since 5.0.0\n * @context Highcharts.Chart\n * @apioption responsive.rules.condition.callback\n */\n /**\n * The responsive rule applies if the chart height is less than this.\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxHeight\n */\n /**\n * The responsive rule applies if the chart width is less than this.\n *\n * @sample highcharts/responsive/axis/\n * Max width is 500\n *\n * @type {number}\n * @since 5.0.0\n * @apioption responsive.rules.condition.maxWidth\n */\n /**\n * The responsive rule applies if the chart height is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minHeight\n */\n /**\n * The responsive rule applies if the chart width is greater than this.\n *\n * @type {number}\n * @default 0\n * @since 5.0.0\n * @apioption responsive.rules.condition.minWidth\n */\n (''); // keeps doclets above in JS file\n\n return Responsive;\n });\n _registerModule(_modules, 'masters/highcharts.src.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js'], _modules['Core/Defaults.js'], _modules['Core/Animation/Fx.js'], _modules['Core/Animation/AnimationUtilities.js'], _modules['Core/Renderer/HTML/AST.js'], _modules['Core/Templating.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Renderer/HTML/HTMLElement.js'], _modules['Core/Renderer/HTML/HTMLRenderer.js'], _modules['Core/Axis/Axis.js'], _modules['Core/Axis/DateTimeAxis.js'], _modules['Core/Axis/LogarithmicAxis.js'], _modules['Core/Axis/PlotLineOrBand/PlotLineOrBand.js'], _modules['Core/Axis/Tick.js'], _modules['Core/Tooltip.js'], _modules['Core/Series/Point.js'], _modules['Core/Pointer.js'], _modules['Core/Legend/Legend.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Axis/Stacking/StackingAxis.js'], _modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Series/Series.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Series/Column/ColumnSeries.js'], _modules['Series/Column/ColumnDataLabel.js'], _modules['Series/Pie/PieSeries.js'], _modules['Series/Pie/PieDataLabel.js'], _modules['Core/Series/DataLabel.js'], _modules['Core/Responsive.js'], _modules['Core/Color/Color.js'], _modules['Core/Time.js']], function (Highcharts, Utilities, Defaults, Fx, Animation, AST, Templating, RendererUtilities, SVGElement, SVGRenderer, HTMLElement, HTMLRenderer, Axis, DateTimeAxis, LogarithmicAxis, PlotLineOrBand, Tick, Tooltip, Point, Pointer, Legend, Chart, StackingAxis, StackItem, Series, SeriesRegistry, ColumnSeries, ColumnDataLabel, PieSeries, PieDataLabel, DataLabel, Responsive, Color, Time) {\n\n const G = Highcharts;\n // Animation\n G.animate = Animation.animate;\n G.animObject = Animation.animObject;\n G.getDeferredAnimation = Animation.getDeferredAnimation;\n G.setAnimation = Animation.setAnimation;\n G.stop = Animation.stop;\n G.timers = Fx.timers;\n // Classes\n G.AST = AST;\n G.Axis = Axis;\n G.Chart = Chart;\n G.chart = Chart.chart;\n G.Fx = Fx;\n G.Legend = Legend;\n G.PlotLineOrBand = PlotLineOrBand;\n G.Point = Point;\n G.Pointer = Pointer;\n G.Series = Series;\n G.StackItem = StackItem;\n G.SVGElement = SVGElement;\n G.SVGRenderer = SVGRenderer;\n G.Templating = Templating;\n G.Tick = Tick;\n G.Time = Time;\n G.Tooltip = Tooltip;\n // Color\n G.Color = Color;\n G.color = Color.parse;\n // Compositions\n HTMLRenderer.compose(SVGRenderer);\n HTMLElement.compose(SVGElement);\n Pointer.compose(Chart);\n Legend.compose(Chart);\n // DefaultOptions\n G.defaultOptions = Defaults.defaultOptions;\n G.getOptions = Defaults.getOptions;\n G.time = Defaults.defaultTime;\n G.setOptions = Defaults.setOptions;\n // Format Utilities\n G.dateFormat = Templating.dateFormat;\n G.format = Templating.format;\n G.numberFormat = Templating.numberFormat;\n // Utilities\n G.addEvent = Utilities.addEvent;\n G.arrayMax = Utilities.arrayMax;\n G.arrayMin = Utilities.arrayMin;\n G.attr = Utilities.attr;\n G.clearTimeout = Utilities.clearTimeout;\n G.correctFloat = Utilities.correctFloat;\n G.createElement = Utilities.createElement;\n G.css = Utilities.css;\n G.defined = Utilities.defined;\n G.destroyObjectProperties = Utilities.destroyObjectProperties;\n G.discardElement = Utilities.discardElement;\n G.distribute = RendererUtilities.distribute;\n G.erase = Utilities.erase;\n G.error = Utilities.error;\n G.extend = Utilities.extend;\n G.extendClass = Utilities.extendClass;\n G.find = Utilities.find;\n G.fireEvent = Utilities.fireEvent;\n G.getMagnitude = Utilities.getMagnitude;\n G.getStyle = Utilities.getStyle;\n G.inArray = Utilities.inArray;\n G.isArray = Utilities.isArray;\n G.isClass = Utilities.isClass;\n G.isDOMElement = Utilities.isDOMElement;\n G.isFunction = Utilities.isFunction;\n G.isNumber = Utilities.isNumber;\n G.isObject = Utilities.isObject;\n G.isString = Utilities.isString;\n G.keys = Utilities.keys;\n G.merge = Utilities.merge;\n G.normalizeTickInterval = Utilities.normalizeTickInterval;\n G.objectEach = Utilities.objectEach;\n G.offset = Utilities.offset;\n G.pad = Utilities.pad;\n G.pick = Utilities.pick;\n G.pInt = Utilities.pInt;\n G.relativeLength = Utilities.relativeLength;\n G.removeEvent = Utilities.removeEvent;\n G.seriesType = SeriesRegistry.seriesType;\n G.splat = Utilities.splat;\n G.stableSort = Utilities.stableSort;\n G.syncTimeout = Utilities.syncTimeout;\n G.timeUnits = Utilities.timeUnits;\n G.uniqueKey = Utilities.uniqueKey;\n G.useSerialIds = Utilities.useSerialIds;\n G.wrap = Utilities.wrap;\n // Compositions\n ColumnDataLabel.compose(ColumnSeries);\n DataLabel.compose(Series);\n DateTimeAxis.compose(Axis);\n LogarithmicAxis.compose(Axis);\n PieDataLabel.compose(PieSeries);\n PlotLineOrBand.compose(Axis);\n Responsive.compose(Chart);\n StackingAxis.compose(Axis, Chart, Series);\n Tooltip.compose(Pointer);\n // Default Export\n\n return G;\n });\n _registerModule(_modules, 'Core/Axis/BrokenAxis.js', [_modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Utilities.js']], function (StackItem, U) {\n /* *\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, find, fireEvent, isArray, isNumber, pick } = U;\n /* *\n *\n * Composition\n *\n * */\n /**\n * Axis with support of broken data rows.\n * @private\n */\n var BrokenAxis;\n (function (BrokenAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Adds support for broken axes.\n * @private\n */\n function compose(AxisClass, SeriesClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('brokenAxis');\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'afterInit', onAxisAfterInit);\n addEvent(AxisClass, 'afterSetTickPositions', onAxisAfterSetTickPositions);\n addEvent(AxisClass, 'afterSetOptions', onAxisAfterSetOptions);\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.drawBreaks = seriesDrawBreaks;\n seriesProto.gappedPath = seriesGappedPath;\n addEvent(SeriesClass, 'afterGeneratePoints', onSeriesAfterGeneratePoints);\n addEvent(SeriesClass, 'afterRender', onSeriesAfterRender);\n }\n return AxisClass;\n }\n BrokenAxis.compose = compose;\n /**\n * @private\n */\n function onAxisAfterInit() {\n if (typeof this.brokenAxis !== 'undefined') {\n this.brokenAxis.setBreaks(this.options.breaks, false);\n }\n }\n /**\n * Force Axis to be not-ordinal when breaks are defined.\n * @private\n */\n function onAxisAfterSetOptions() {\n const axis = this;\n if (axis.brokenAxis && axis.brokenAxis.hasBreaks) {\n axis.options.ordinal = false;\n }\n }\n /**\n * @private\n */\n function onAxisAfterSetTickPositions() {\n const axis = this, brokenAxis = axis.brokenAxis;\n if (brokenAxis &&\n brokenAxis.hasBreaks) {\n const tickPositions = axis.tickPositions, info = axis.tickPositions.info, newPositions = [];\n for (let i = 0; i < tickPositions.length; i++) {\n if (!brokenAxis.isInAnyBreak(tickPositions[i])) {\n newPositions.push(tickPositions[i]);\n }\n }\n axis.tickPositions = newPositions;\n axis.tickPositions.info = info;\n }\n }\n /**\n * @private\n */\n function onAxisInit() {\n const axis = this;\n if (!axis.brokenAxis) {\n axis.brokenAxis = new Additions(axis);\n }\n }\n /**\n * @private\n */\n function onSeriesAfterGeneratePoints() {\n const { isDirty, options: { connectNulls }, points, xAxis, yAxis } = this;\n // Set, or reset visibility of the points. Axis.setBreaks marks\n // the series as isDirty\n if (isDirty) {\n let i = points.length;\n while (i--) {\n const point = points[i];\n // Respect nulls inside the break (#4275)\n const nullGap = point.y === null && connectNulls === false;\n const isPointInBreak = (!nullGap && ((xAxis &&\n xAxis.brokenAxis &&\n xAxis.brokenAxis.isInAnyBreak(point.x, true)) || (yAxis &&\n yAxis.brokenAxis &&\n yAxis.brokenAxis.isInAnyBreak(point.y, true))));\n // Set point.visible if in any break.\n // If not in break, reset visible to original value.\n point.visible = isPointInBreak ?\n false :\n point.options.visible !== false;\n }\n }\n }\n /**\n * @private\n */\n function onSeriesAfterRender() {\n this.drawBreaks(this.xAxis, ['x']);\n this.drawBreaks(this.yAxis, pick(this.pointArrayMap, ['y']));\n }\n /**\n * @private\n */\n function seriesDrawBreaks(axis, keys) {\n const series = this, points = series.points;\n let breaks, threshold, eventName, y;\n if (axis && // #5950\n axis.brokenAxis &&\n axis.brokenAxis.hasBreaks) {\n const brokenAxis = axis.brokenAxis;\n keys.forEach(function (key) {\n breaks = brokenAxis && brokenAxis.breakArray || [];\n threshold = axis.isXAxis ?\n axis.min :\n pick(series.options.threshold, axis.min);\n points.forEach(function (point) {\n y = pick(point['stack' + key.toUpperCase()], point[key]);\n breaks.forEach(function (brk) {\n if (isNumber(threshold) && isNumber(y)) {\n eventName = false;\n if ((threshold < brk.from && y > brk.to) ||\n (threshold > brk.from && y < brk.from)) {\n eventName = 'pointBreak';\n }\n else if ((threshold < brk.from &&\n y > brk.from &&\n y < brk.to) || (threshold > brk.from &&\n y > brk.to &&\n y < brk.from)) {\n eventName = 'pointInBreak';\n }\n if (eventName) {\n fireEvent(axis, eventName, { point, brk });\n }\n }\n });\n });\n });\n }\n }\n /**\n * Extend getGraphPath by identifying gaps in the data so that we\n * can draw a gap in the line or area. This was moved from ordinal\n * axis module to broken axis module as of #5045.\n *\n * @private\n * @function Highcharts.Series#gappedPath\n *\n * @return {Highcharts.SVGPathArray}\n * Gapped path\n */\n function seriesGappedPath() {\n const currentDataGrouping = this.currentDataGrouping, groupingSize = currentDataGrouping && currentDataGrouping.gapSize, points = this.points.slice(), yAxis = this.yAxis;\n let gapSize = this.options.gapSize, i = points.length - 1, stack;\n /**\n * Defines when to display a gap in the graph, together with the\n * [gapUnit](plotOptions.series.gapUnit) option.\n *\n * In case when `dataGrouping` is enabled, points can be grouped\n * into a larger time span. This can make the grouped points to\n * have a greater distance than the absolute value of `gapSize`\n * property, which will result in disappearing graph completely.\n * To prevent this situation the mentioned distance between\n * grouped points is used instead of previously defined\n * `gapSize`.\n *\n * In practice, this option is most often used to visualize gaps\n * in time series. In a stock chart, intraday data is available\n * for daytime hours, while gaps will appear in nights and\n * weekends.\n *\n * @see [gapUnit](plotOptions.series.gapUnit)\n * @see [xAxis.breaks](#xAxis.breaks)\n *\n * @sample {highstock} stock/plotoptions/series-gapsize/\n * Setting the gap size to 2 introduces gaps for weekends in\n * daily datasets.\n *\n * @type {number}\n * @default 0\n * @product highstock\n * @requires modules/broken-axis\n * @apioption plotOptions.series.gapSize\n */\n /**\n * Together with [gapSize](plotOptions.series.gapSize), this\n * option defines where to draw gaps in the graph.\n *\n * When the `gapUnit` is `\"relative\"` (default), a gap size of 5\n * means that if the distance between two points is greater than\n * 5 times that of the two closest points, the graph will be\n * broken.\n *\n * When the `gapUnit` is `\"value\"`, the gap is based on absolute\n * axis values, which on a datetime axis is milliseconds. This\n * also applies to the navigator series that inherits gap\n * options from the base series.\n *\n * @see [gapSize](plotOptions.series.gapSize)\n *\n * @type {string}\n * @default relative\n * @since 5.0.13\n * @product highstock\n * @validvalue [\"relative\", \"value\"]\n * @requires modules/broken-axis\n * @apioption plotOptions.series.gapUnit\n */\n if (gapSize && i > 0) { // #5008\n // Gap unit is relative\n if (this.options.gapUnit !== 'value') {\n gapSize *= this.basePointRange;\n }\n // Setting a new gapSize in case dataGrouping is enabled\n // (#7686)\n if (groupingSize &&\n groupingSize > gapSize &&\n // Except when DG is forced (e.g. from other series)\n // and has lower granularity than actual points (#11351)\n groupingSize >= this.basePointRange) {\n gapSize = groupingSize;\n }\n // extension for ordinal breaks\n let current, next;\n while (i--) {\n // Reassign next if it is not visible\n if (!(next && next.visible !== false)) {\n next = points[i + 1];\n }\n current = points[i];\n // Skip iteration if one of the points is not visible\n if (next.visible === false || current.visible === false) {\n continue;\n }\n if (next.x - current.x > gapSize) {\n const xRange = (current.x + next.x) / 2;\n points.splice(// insert after this one\n i + 1, 0, {\n isNull: true,\n x: xRange\n });\n // For stacked chart generate empty stack items, #6546\n if (yAxis.stacking && this.options.stacking) {\n stack = yAxis.stacking.stacks[this.stackKey][xRange] = new StackItem(yAxis, yAxis.options.stackLabels, false, xRange, this.stack);\n stack.total = 0;\n }\n }\n // Assign current to next for the upcoming iteration\n next = current;\n }\n }\n // Call base method\n return this.getGraphPath(points);\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Provides support for broken axes.\n * @private\n * @class\n */\n class Additions {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n static isInBreak(brk, val) {\n const repeat = brk.repeat || Infinity, from = brk.from, length = brk.to - brk.from, test = (val >= from ?\n (val - from) % repeat :\n repeat - ((from - val) % repeat));\n let ret;\n if (!brk.inclusive) {\n ret = test < length && test !== 0;\n }\n else {\n ret = test <= length;\n }\n return ret;\n }\n /**\n * @private\n */\n static lin2Val(val) {\n const axis = this;\n const brokenAxis = axis.brokenAxis;\n const breakArray = brokenAxis && brokenAxis.breakArray;\n if (!breakArray || !isNumber(val)) {\n return val;\n }\n let nval = val, brk, i;\n for (i = 0; i < breakArray.length; i++) {\n brk = breakArray[i];\n if (brk.from >= nval) {\n break;\n }\n else if (brk.to < nval) {\n nval += brk.len;\n }\n else if (Additions.isInBreak(brk, nval)) {\n nval += brk.len;\n }\n }\n return nval;\n }\n /**\n * @private\n */\n static val2Lin(val) {\n const axis = this;\n const brokenAxis = axis.brokenAxis;\n const breakArray = brokenAxis && brokenAxis.breakArray;\n if (!breakArray || !isNumber(val)) {\n return val;\n }\n let nval = val, brk, i;\n for (i = 0; i < breakArray.length; i++) {\n brk = breakArray[i];\n if (brk.to <= val) {\n nval -= brk.len;\n }\n else if (brk.from >= val) {\n break;\n }\n else if (Additions.isInBreak(brk, val)) {\n nval -= (val - brk.from);\n break;\n }\n }\n return nval;\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.hasBreaks = false;\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Returns the first break found where the x is larger then break.from\n * and smaller then break.to.\n *\n * @param {number} x\n * The number which should be within a break.\n *\n * @param {Array} breaks\n * The array of breaks to search within.\n *\n * @return {Highcharts.XAxisBreaksOptions|undefined}\n * Returns the first break found that matches, returns false if no break\n * is found.\n */\n findBreakAt(x, breaks) {\n return find(breaks, function (b) {\n return b.from < x && x < b.to;\n });\n }\n /**\n * @private\n */\n isInAnyBreak(val, testKeep) {\n const brokenAxis = this, axis = brokenAxis.axis, breaks = axis.options.breaks || [];\n let i = breaks.length, inbrk, keep, ret;\n if (i && isNumber(val)) {\n while (i--) {\n if (Additions.isInBreak(breaks[i], val)) {\n inbrk = true;\n if (!keep) {\n keep = pick(breaks[i].showPoints, !axis.isXAxis);\n }\n }\n }\n if (inbrk && testKeep) {\n ret = inbrk && !keep;\n }\n else {\n ret = inbrk;\n }\n }\n return ret;\n }\n /**\n * Dynamically set or unset breaks in an axis. This function in lighter\n * than usin Axis.update, and it also preserves animation.\n *\n * @private\n * @function Highcharts.Axis#setBreaks\n *\n * @param {Array} [breaks]\n * The breaks to add. When `undefined` it removes existing breaks.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart immediately.\n */\n setBreaks(breaks, redraw) {\n const brokenAxis = this;\n const axis = brokenAxis.axis;\n const hasBreaks = (isArray(breaks) && !!breaks.length);\n axis.isDirty = brokenAxis.hasBreaks !== hasBreaks;\n brokenAxis.hasBreaks = hasBreaks;\n if (breaks !== axis.options.breaks) {\n axis.options.breaks = axis.userOptions.breaks = breaks;\n }\n axis.forceRedraw = true; // Force recalculation in setScale\n // Recalculate series related to the axis.\n axis.series.forEach(function (series) {\n series.isDirty = true;\n });\n if (!hasBreaks && axis.val2lin === Additions.val2Lin) {\n // Revert to prototype functions\n delete axis.val2lin;\n delete axis.lin2val;\n }\n if (hasBreaks) {\n axis.userOptions.ordinal = false;\n axis.lin2val = Additions.lin2Val;\n axis.val2lin = Additions.val2Lin;\n axis.setExtremes = function (newMin, newMax, redraw, animation, eventArguments) {\n // If trying to set extremes inside a break, extend min to\n // after, and max to before the break ( #3857 )\n if (brokenAxis.hasBreaks) {\n const breaks = (this.options.breaks || []);\n let axisBreak;\n while ((axisBreak = brokenAxis.findBreakAt(newMin, breaks))) {\n newMin = axisBreak.to;\n }\n while ((axisBreak = brokenAxis.findBreakAt(newMax, breaks))) {\n newMax = axisBreak.from;\n }\n // If both min and max is within the same break.\n if (newMax < newMin) {\n newMax = newMin;\n }\n }\n axis.constructor.prototype.setExtremes.call(this, newMin, newMax, redraw, animation, eventArguments);\n };\n axis.setAxisTranslation = function () {\n axis.constructor.prototype.setAxisTranslation.call(this);\n brokenAxis.unitLength = void 0;\n if (brokenAxis.hasBreaks) {\n const breaks = axis.options.breaks || [], \n // Temporary one:\n breakArrayT = [], breakArray = [], pointRangePadding = pick(axis.pointRangePadding, 0);\n let length = 0, inBrk, repeat, min = axis.userMin || axis.min, max = axis.userMax || axis.max, start, i;\n // Min & max check (#4247)\n breaks.forEach(function (brk) {\n repeat = brk.repeat || Infinity;\n if (isNumber(min) && isNumber(max)) {\n if (Additions.isInBreak(brk, min)) {\n min += ((brk.to % repeat) -\n (min % repeat));\n }\n if (Additions.isInBreak(brk, max)) {\n max -= ((max % repeat) -\n (brk.from % repeat));\n }\n }\n });\n // Construct an array holding all breaks in the axis\n breaks.forEach(function (brk) {\n start = brk.from;\n repeat = brk.repeat || Infinity;\n if (isNumber(min) && isNumber(max)) {\n while (start - repeat > min) {\n start -= repeat;\n }\n while (start < min) {\n start += repeat;\n }\n for (i = start; i < max; i += repeat) {\n breakArrayT.push({\n value: i,\n move: 'in'\n });\n breakArrayT.push({\n value: i + brk.to - brk.from,\n move: 'out',\n size: brk.breakSize\n });\n }\n }\n });\n breakArrayT.sort(function (a, b) {\n return ((a.value === b.value) ?\n ((a.move === 'in' ? 0 : 1) -\n (b.move === 'in' ? 0 : 1)) :\n a.value - b.value);\n });\n // Simplify the breaks\n inBrk = 0;\n start = min;\n breakArrayT.forEach(function (brk) {\n inBrk += (brk.move === 'in' ? 1 : -1);\n if (inBrk === 1 && brk.move === 'in') {\n start = brk.value;\n }\n if (inBrk === 0 && isNumber(start)) {\n breakArray.push({\n from: start,\n to: brk.value,\n len: brk.value - start - (brk.size || 0)\n });\n length += (brk.value -\n start -\n (brk.size || 0));\n }\n });\n brokenAxis.breakArray = breakArray;\n // Used with staticScale, and below the actual axis\n // length, when breaks are substracted.\n if (isNumber(min) &&\n isNumber(max) &&\n isNumber(axis.min)) {\n brokenAxis.unitLength = max - min - length +\n pointRangePadding;\n fireEvent(axis, 'afterBreaks');\n if (axis.staticScale) {\n axis.transA = axis.staticScale;\n }\n else if (brokenAxis.unitLength) {\n axis.transA *=\n (max - axis.min + pointRangePadding) /\n brokenAxis.unitLength;\n }\n if (pointRangePadding) {\n axis.minPixelPadding =\n axis.transA * (axis.minPointOffset || 0);\n }\n axis.min = min;\n axis.max = max;\n }\n }\n };\n }\n if (pick(redraw, true)) {\n axis.chart.redraw();\n }\n }\n }\n BrokenAxis.Additions = Additions;\n })(BrokenAxis || (BrokenAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return BrokenAxis;\n });\n _registerModule(_modules, 'masters/modules/broken-axis.src.js', [_modules['Core/Globals.js'], _modules['Core/Axis/BrokenAxis.js']], function (Highcharts, BrokenAxis) {\n\n const G = Highcharts;\n // Compositions\n BrokenAxis.compose(G.Axis, G.Series);\n\n });\n _registerModule(_modules, 'Extensions/DataGrouping/ApproximationRegistry.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Define the available approximation types. The data grouping\n * approximations takes an array or numbers as the first parameter. In case\n * of ohlc, four arrays are sent in as four parameters. Each array consists\n * only of numbers. In case null values belong to the group, the property\n * .hasNulls will be set to true on the array.\n *\n * @product highstock\n *\n * @private\n */\n const ApproximationRegistry = {\n // approximations added programmatically\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ApproximationRegistry;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/ApproximationDefaults.js', [_modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Core/Utilities.js']], function (ApproximationRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { arrayMax, arrayMin, correctFloat, extend, isNumber } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function average(arr) {\n const len = arr.length;\n let ret = sum(arr);\n // If we have a number, return it divided by the length. If not,\n // return null or undefined based on what the sum method finds.\n if (isNumber(ret) && len) {\n ret = correctFloat(ret / len);\n }\n return ret;\n }\n /**\n * The same as average, but for series with multiple values, like area ranges.\n * @private\n */\n function averages() {\n const ret = [];\n [].forEach.call(arguments, function (arr) {\n ret.push(average(arr));\n });\n // Return undefined when first elem. is undefined and let\n // sum method handle null (#7377)\n return typeof ret[0] === 'undefined' ? void 0 : ret;\n }\n /**\n * @private\n */\n function close(arr) {\n return arr.length ?\n arr[arr.length - 1] :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function high(arr) {\n return arr.length ?\n arrayMax(arr) :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * HLC, OHLC and range are special cases where a multidimensional array is input\n * and an array is output.\n * @private\n */\n function hlc(high, low, close) {\n high = ApproximationRegistry.high(high);\n low = ApproximationRegistry.low(low);\n close = ApproximationRegistry.close(close);\n if (isNumber(high) ||\n isNumber(low) ||\n isNumber(close)) {\n return [high, low, close];\n }\n }\n /**\n * @private\n */\n function low(arr) {\n return arr.length ?\n arrayMin(arr) :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function ohlc(open, high, low, close) {\n open = ApproximationRegistry.open(open);\n high = ApproximationRegistry.high(high);\n low = ApproximationRegistry.low(low);\n close = ApproximationRegistry.close(close);\n if (isNumber(open) ||\n isNumber(high) ||\n isNumber(low) ||\n isNumber(close)) {\n return [open, high, low, close];\n }\n }\n /**\n * @private\n */\n function open(arr) {\n return arr.length ? arr[0] : (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function range(low, high) {\n low = ApproximationRegistry.low(low);\n high = ApproximationRegistry.high(high);\n if (isNumber(low) || isNumber(high)) {\n return [low, high];\n }\n if (low === null && high === null) {\n return null;\n }\n // else, return is undefined\n }\n /**\n * @private\n */\n function sum(arr) {\n let len = arr.length, ret;\n // 1. it consists of nulls exclusive\n if (!len && arr.hasNulls) {\n ret = null;\n // 2. it has a length and real values\n }\n else if (len) {\n ret = 0;\n while (len--) {\n ret += arr[len];\n }\n }\n // 3. it has zero length, so just return undefined\n // => doNothing()\n return ret;\n }\n /* *\n *\n * Default Export\n *\n * */\n const ApproximationDefaults = {\n average,\n averages,\n close,\n high,\n hlc,\n low,\n ohlc,\n open,\n range,\n sum\n };\n extend(ApproximationRegistry, ApproximationDefaults);\n\n return ApproximationDefaults;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Common options\n * @private\n */\n const common = {\n // enabled: null, // (true for stock charts, false for basic),\n // forced: undefined,\n groupPixelWidth: 2,\n // the first one is the point or start value, the second is the start\n // value if we're dealing with range, the third one is the end value if\n // dealing with a range\n dateTimeLabelFormats: {\n millisecond: [\n '%A, %e %b, %H:%M:%S.%L',\n '%A, %e %b, %H:%M:%S.%L',\n '-%H:%M:%S.%L'\n ],\n second: [\n '%A, %e %b, %H:%M:%S',\n '%A, %e %b, %H:%M:%S',\n '-%H:%M:%S'\n ],\n minute: [\n '%A, %e %b, %H:%M',\n '%A, %e %b, %H:%M',\n '-%H:%M'\n ],\n hour: [\n '%A, %e %b, %H:%M',\n '%A, %e %b, %H:%M',\n '-%H:%M'\n ],\n day: [\n '%A, %e %b %Y',\n '%A, %e %b',\n '-%A, %e %b %Y'\n ],\n week: [\n 'Week from %A, %e %b %Y',\n '%A, %e %b',\n '-%A, %e %b %Y'\n ],\n month: [\n '%B %Y',\n '%B',\n '-%B %Y'\n ],\n year: [\n '%Y',\n '%Y',\n '-%Y'\n ]\n }\n // smoothed = false, // enable this for navigator series only\n };\n /**\n * Extends common options\n * @private\n */\n const seriesSpecific = {\n line: {},\n spline: {},\n area: {},\n areaspline: {},\n arearange: {},\n column: {\n groupPixelWidth: 10\n },\n columnrange: {\n groupPixelWidth: 10\n },\n candlestick: {\n groupPixelWidth: 10\n },\n ohlc: {\n groupPixelWidth: 5\n },\n hlc: {\n groupPixelWidth: 5\n // Move to HeikinAshiSeries.ts aftre refactoring data grouping.\n },\n heikinashi: {\n groupPixelWidth: 10\n }\n };\n /**\n * Units are defined in a separate array to allow complete overriding in\n * case of a user option.\n * @private\n */\n const units = [\n [\n 'millisecond',\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n ], [\n 'second',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'minute',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'hour',\n [1, 2, 3, 4, 6, 8, 12]\n ], [\n 'day',\n [1]\n ], [\n 'week',\n [1]\n ], [\n 'month',\n [1, 3, 6]\n ], [\n 'year',\n null\n ]\n ];\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingDefaults = {\n common,\n seriesSpecific,\n units\n };\n\n return DataGroupingDefaults;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingAxisComposition.js', [_modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Core/Utilities.js']], function (DataGroupingDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, extend, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let AxisConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Check the groupPixelWidth and apply the grouping if needed.\n * Fired only after processing the data.\n *\n * @product highstock\n *\n * @function Highcharts.Axis#applyGrouping\n */\n function applyGrouping(e) {\n const axis = this, series = axis.series;\n // Reset the groupPixelWidth for all series, #17141.\n series.forEach(function (series) {\n series.groupPixelWidth = void 0; // #2110\n });\n series.forEach(function (series) {\n series.groupPixelWidth = (axis.getGroupPixelWidth &&\n axis.getGroupPixelWidth());\n if (series.groupPixelWidth) {\n series.hasProcessed = true; // #2692\n }\n // Fire independing on series.groupPixelWidth to always set a proper\n // dataGrouping state, (#16238)\n series.applyGrouping(!!e.hasExtremesChanged);\n });\n }\n /**\n * @private\n */\n function compose(AxisClass) {\n AxisConstructor = AxisClass;\n if (U.pushUnique(composedMembers, AxisClass)) {\n addEvent(AxisClass, 'afterSetScale', onAfterSetScale);\n // When all series are processed, calculate the group pixel width and\n // then if this value is different than zero apply groupings.\n addEvent(AxisClass, 'postProcessData', applyGrouping);\n extend(AxisClass.prototype, {\n applyGrouping,\n getGroupPixelWidth,\n setDataGrouping\n });\n }\n }\n /**\n * Get the data grouping pixel width based on the greatest defined individual\n * width of the axis' series, and if whether one of the axes need grouping.\n * @private\n */\n function getGroupPixelWidth() {\n const series = this.series;\n let i = series.length, groupPixelWidth = 0, doGrouping = false, dataLength, dgOptions;\n // If one of the series needs grouping, apply it to all (#1634)\n while (i--) {\n dgOptions = series[i].options.dataGrouping;\n if (dgOptions) { // #2692\n // If multiple series are compared on the same x axis, give them the\n // same group pixel width (#334)\n groupPixelWidth = Math.max(groupPixelWidth, \n // Fallback to commonOptions (#9693)\n pick(dgOptions.groupPixelWidth, DataGroupingDefaults.common.groupPixelWidth));\n dataLength = (series[i].processedXData || series[i].data).length;\n // Execute grouping if the amount of points is greater than the\n // limit defined in groupPixelWidth\n if (series[i].groupPixelWidth ||\n (dataLength >\n (this.chart.plotSizeX / groupPixelWidth)) ||\n (dataLength && dgOptions.forced)) {\n doGrouping = true;\n }\n }\n }\n return doGrouping ? groupPixelWidth : 0;\n }\n /**\n * When resetting the scale reset the hasProccessed flag to avoid taking\n * previous data grouping of neighbour series into accound when determining\n * group pixel width (#2692).\n * @private\n */\n function onAfterSetScale() {\n this.series.forEach(function (series) {\n series.hasProcessed = false;\n });\n }\n /**\n * Highcharts Stock only. Force data grouping on all the axis' series.\n *\n * @product highstock\n *\n * @function Highcharts.Axis#setDataGrouping\n *\n * @param {boolean|Highcharts.DataGroupingOptionsObject} [dataGrouping]\n * A `dataGrouping` configuration. Use `false` to disable data grouping\n * dynamically.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for a later call to\n * {@link Chart#redraw}.\n */\n function setDataGrouping(dataGrouping, redraw) {\n const axis = this;\n let i;\n redraw = pick(redraw, true);\n if (!dataGrouping) {\n dataGrouping = {\n forced: false,\n units: null\n };\n }\n // Axis is instantiated, update all series\n if (this instanceof AxisConstructor) {\n i = this.series.length;\n while (i--) {\n this.series[i].update({\n dataGrouping: dataGrouping\n }, false);\n }\n // Axis not yet instanciated, alter series options\n }\n else {\n this.chart.options.series.forEach(function (seriesOptions) {\n // Merging dataGrouping options with already defined options #16759\n seriesOptions.dataGrouping = typeof dataGrouping === 'boolean' ?\n dataGrouping :\n merge(dataGrouping, seriesOptions.dataGrouping);\n });\n }\n // Clear ordinal slope, so we won't accidentaly use the old one (#7827)\n if (axis.ordinal) {\n axis.ordinal.slope = void 0;\n }\n if (redraw) {\n this.chart.redraw();\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingAxisComposition = {\n compose\n };\n\n return DataGroupingAxisComposition;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingSeriesComposition.js', [_modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Core/Axis/DateTimeAxis.js'], _modules['Core/Defaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ApproximationRegistry, DataGroupingDefaults, DateTimeAxis, D, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { series: { prototype: seriesProto } } = SeriesRegistry;\n const { addEvent, defined, error, extend, isNumber, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const baseGeneratePoints = seriesProto.generatePoints;\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function adjustExtremes(xAxis, groupedXData) {\n // Make sure the X axis extends to show the first group (#2533)\n // But only for visible series (#5493, #6393)\n if (defined(groupedXData[0]) &&\n isNumber(xAxis.min) &&\n isNumber(xAxis.dataMin) &&\n groupedXData[0] < xAxis.min) {\n if ((!defined(xAxis.options.min) &&\n xAxis.min <= xAxis.dataMin) ||\n xAxis.min === xAxis.dataMin) {\n xAxis.min = Math.min(groupedXData[0], xAxis.min);\n }\n xAxis.dataMin = Math.min(groupedXData[0], xAxis.dataMin);\n }\n // When the last anchor set, change the extremes that\n // the last point is visible (#12455).\n if (defined(groupedXData[groupedXData.length - 1]) &&\n isNumber(xAxis.max) &&\n isNumber(xAxis.dataMax) &&\n groupedXData[groupedXData.length - 1] > xAxis.max) {\n if ((!defined(xAxis.options.max) &&\n isNumber(xAxis.dataMax) &&\n xAxis.max >= xAxis.dataMax) || xAxis.max === xAxis.dataMax) {\n xAxis.max = Math.max(groupedXData[groupedXData.length - 1], xAxis.max);\n }\n xAxis.dataMax = Math.max(groupedXData[groupedXData.length - 1], xAxis.dataMax);\n }\n }\n /**\n * @private\n */\n function anchorPoints(series, groupedXData, xMax) {\n const options = series.options, dataGroupingOptions = options.dataGrouping, totalRange = (series.currentDataGrouping && series.currentDataGrouping.gapSize);\n let i;\n // DataGrouping x-coordinates.\n if (dataGroupingOptions && series.xData && totalRange && series.groupMap) {\n const groupedDataLength = groupedXData.length - 1, anchor = dataGroupingOptions.anchor, firstAnchor = pick(dataGroupingOptions.firstAnchor, anchor), lastAnchor = pick(dataGroupingOptions.lastAnchor, anchor);\n // Anchor points that are not extremes.\n if (anchor && anchor !== 'start') {\n const shiftInterval = (totalRange *\n { middle: 0.5, end: 1 }[anchor]);\n i = groupedXData.length - 1;\n while (i-- && i > 0) {\n groupedXData[i] += shiftInterval;\n }\n }\n // Change the first point position, but only when it is\n // the first point in the data set not in the current zoom.\n if (firstAnchor &&\n firstAnchor !== 'start' &&\n series.xData[0] >= groupedXData[0]) {\n const groupStart = series.groupMap[0].start, groupLength = series.groupMap[0].length;\n let firstGroupstEnd;\n if (isNumber(groupStart) && isNumber(groupLength)) {\n firstGroupstEnd = groupStart + (groupLength - 1);\n }\n groupedXData[0] = {\n middle: groupedXData[0] + 0.5 * totalRange,\n end: groupedXData[0] + totalRange,\n firstPoint: series.xData[0],\n lastPoint: firstGroupstEnd && series.xData[firstGroupstEnd]\n }[firstAnchor];\n }\n // Change the last point position but only when it is\n // the last point in the data set not in the current zoom.\n if (lastAnchor &&\n lastAnchor !== 'start' &&\n totalRange &&\n groupedXData[groupedDataLength] >= xMax - totalRange) {\n const lastGroupStart = series.groupMap[series.groupMap.length - 1].start;\n groupedXData[groupedDataLength] = {\n middle: groupedXData[groupedDataLength] + 0.5 * totalRange,\n end: groupedXData[groupedDataLength] + totalRange,\n firstPoint: lastGroupStart && series.xData[lastGroupStart],\n lastPoint: series.xData[series.xData.length - 1]\n }[lastAnchor];\n }\n }\n }\n /**\n * For the processed data, calculate the grouped data if needed.\n *\n * @private\n * @function Highcharts.Series#applyGrouping\n */\n function applyGrouping(hasExtremesChanged) {\n const series = this, chart = series.chart, options = series.options, dataGroupingOptions = options.dataGrouping, groupingEnabled = series.allowDG !== false && dataGroupingOptions &&\n pick(dataGroupingOptions.enabled, chart.options.isStock), visible = (series.visible || !chart.options.chart.ignoreHiddenSeries), lastDataGrouping = this.currentDataGrouping;\n let currentDataGrouping, croppedData, revertRequireSorting = false;\n // Data needs to be sorted for dataGrouping\n if (groupingEnabled && !series.requireSorting) {\n series.requireSorting = revertRequireSorting = true;\n }\n // Skip if skipDataGrouping method returns false or if grouping is disabled\n // (in that order).\n const skip = skipDataGrouping(series, hasExtremesChanged) === false || !groupingEnabled;\n // Revert original requireSorting value if changed\n if (revertRequireSorting) {\n series.requireSorting = false;\n }\n if (!skip) {\n series.destroyGroupedData();\n const processedXData = dataGroupingOptions.groupAll ?\n series.xData :\n series.processedXData, processedYData = dataGroupingOptions.groupAll ?\n series.yData :\n series.processedYData, plotSizeX = chart.plotSizeX, xAxis = series.xAxis, ordinal = xAxis.options.ordinal, groupPixelWidth = series.groupPixelWidth;\n let i, hasGroupedData;\n // Execute grouping if the amount of points is greater than the limit\n // defined in groupPixelWidth\n if (groupPixelWidth &&\n processedXData &&\n processedXData.length &&\n plotSizeX) {\n hasGroupedData = true;\n // Force recreation of point instances in series.translate, #5699\n series.isDirty = true;\n series.points = null; // #6709\n const extremes = xAxis.getExtremes(), xMin = extremes.min, xMax = extremes.max, groupIntervalFactor = (ordinal &&\n xAxis.ordinal &&\n xAxis.ordinal.getGroupIntervalFactor(xMin, xMax, series)) || 1, interval = (groupPixelWidth * (xMax - xMin) / plotSizeX) *\n groupIntervalFactor, groupPositions = xAxis.getTimeTicks(DateTimeAxis.Additions.prototype.normalizeTimeTickInterval(interval, dataGroupingOptions.units ||\n DataGroupingDefaults.units), \n // Processed data may extend beyond axis (#4907)\n Math.min(xMin, processedXData[0]), Math.max(xMax, processedXData[processedXData.length - 1]), xAxis.options.startOfWeek, processedXData, series.closestPointRange), groupedData = seriesProto.groupData.apply(series, [\n processedXData,\n processedYData,\n groupPositions,\n dataGroupingOptions.approximation\n ]);\n let groupedXData = groupedData.groupedXData, groupedYData = groupedData.groupedYData, gapSize = 0;\n // The smoothed option is deprecated, instead, there is a fallback\n // to the new anchoring mechanism. #12455.\n if (dataGroupingOptions &&\n dataGroupingOptions.smoothed &&\n groupedXData.length) {\n dataGroupingOptions.firstAnchor = 'firstPoint';\n dataGroupingOptions.anchor = 'middle';\n dataGroupingOptions.lastAnchor = 'lastPoint';\n error(32, false, chart, {\n 'dataGrouping.smoothed': 'use dataGrouping.anchor'\n });\n }\n anchorPoints(series, groupedXData, xMax);\n // Record what data grouping values were used\n for (i = 1; i < groupPositions.length; i++) {\n // The grouped gapSize needs to be the largest distance between\n // the group to capture varying group sizes like months or DST\n // crossing (#10000). Also check that the gap is not at the\n // start of a segment.\n if (!groupPositions.info.segmentStarts ||\n groupPositions.info.segmentStarts.indexOf(i) === -1) {\n gapSize = Math.max(groupPositions[i] - groupPositions[i - 1], gapSize);\n }\n }\n currentDataGrouping = groupPositions.info;\n currentDataGrouping.gapSize = gapSize;\n series.closestPointRange = groupPositions.info.totalRange;\n series.groupMap = groupedData.groupMap;\n if (visible) {\n adjustExtremes(xAxis, groupedXData);\n }\n // We calculated all group positions but we should render\n // only the ones within the visible range\n if (dataGroupingOptions.groupAll) {\n // Keep the reference to all grouped points\n // for further calculation (eg. heikinashi).\n series.allGroupedData = groupedYData;\n croppedData = series.cropData(groupedXData, groupedYData, xAxis.min, xAxis.max, 1 // Ordinal xAxis will remove left-most points otherwise\n );\n groupedXData = croppedData.xData;\n groupedYData = croppedData.yData;\n series.cropStart = croppedData.start; // #15005\n }\n // Set series props\n series.processedXData = groupedXData;\n series.processedYData = groupedYData;\n }\n else {\n series.groupMap = null;\n }\n series.hasGroupedData = hasGroupedData;\n series.currentDataGrouping = currentDataGrouping;\n series.preventGraphAnimation =\n (lastDataGrouping && lastDataGrouping.totalRange) !==\n (currentDataGrouping && currentDataGrouping.totalRange);\n }\n }\n /**\n * @private\n */\n function compose(SeriesClass) {\n const PointClass = SeriesClass.prototype.pointClass;\n if (U.pushUnique(composedMembers, PointClass)) {\n // Override point prototype to throw a warning when trying to update\n // grouped points.\n addEvent(PointClass, 'update', function () {\n if (this.dataGroup) {\n error(24, false, this.series.chart);\n return false;\n }\n });\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'afterSetOptions', onAfterSetOptions);\n addEvent(SeriesClass, 'destroy', destroyGroupedData);\n extend(SeriesClass.prototype, {\n applyGrouping,\n destroyGroupedData,\n generatePoints,\n getDGApproximation,\n groupData\n });\n }\n }\n /**\n * Destroy the grouped data points. #622, #740\n * @private\n */\n function destroyGroupedData() {\n // Clear previous groups\n if (this.groupedData) {\n this.groupedData.forEach(function (point, i) {\n if (point) {\n this.groupedData[i] = point.destroy ?\n point.destroy() : null;\n }\n }, this);\n // Clears all:\n // - `this.groupedData`\n // - `this.points`\n // - `preserve` object in series.update()\n this.groupedData.length = 0;\n }\n }\n /**\n * Override the generatePoints method by adding a reference to grouped data\n * @private\n */\n function generatePoints() {\n baseGeneratePoints.apply(this);\n // Record grouped data in order to let it be destroyed the next time\n // processData runs\n this.destroyGroupedData(); // #622\n this.groupedData = this.hasGroupedData ? this.points : null;\n }\n /**\n * Set default approximations to the prototypes if present. Properties are\n * inherited down. Can be overridden for individual series types.\n * @private\n */\n function getDGApproximation() {\n if (this.is('arearange')) {\n return 'range';\n }\n if (this.is('ohlc')) {\n return 'ohlc';\n }\n if (this.is('hlc')) {\n return 'hlc';\n }\n if (\n // #18974, default approximation for cumulative\n // should be `sum` when `dataGrouping` is enabled\n this.is('column') ||\n this.options.cumulative) {\n return 'sum';\n }\n return 'average';\n }\n /**\n * Highcharts Stock only. Takes parallel arrays of x and y data and groups the\n * data into intervals defined by groupPositions, a collection of starting x\n * values for each group.\n *\n * @product highstock\n *\n * @function Highcharts.Series#groupData\n * @param {Array} xData\n * Parallel array of x data.\n * @param {Array<(number|null|undefined)>|Array>} yData\n * Parallel array of y data.\n * @param {Array} groupPositions\n * Group positions.\n * @param {string|Function} [approximation]\n * Approximation to use.\n * @return {Highcharts.DataGroupingResultObject}\n * Mapped groups.\n */\n function groupData(xData, yData, groupPositions, approximation) {\n const series = this, data = series.data, dataOptions = series.options && series.options.data, groupedXData = [], groupedYData = [], groupMap = [], dataLength = xData.length, \n // when grouping the fake extended axis for panning,\n // we don't need to consider y\n handleYData = !!yData, values = [], pointArrayMap = series.pointArrayMap, pointArrayMapLength = pointArrayMap && pointArrayMap.length, extendedPointArrayMap = ['x'].concat(pointArrayMap || ['y']), groupAll = (this.options.dataGrouping &&\n this.options.dataGrouping.groupAll);\n let pointX, pointY, groupedY, pos = 0, start = 0;\n const approximationFn = (typeof approximation === 'function' ?\n approximation :\n approximation && ApproximationRegistry[approximation] ?\n ApproximationRegistry[approximation] :\n ApproximationRegistry[(series.getDGApproximation && series.getDGApproximation() ||\n 'average')]);\n // Calculate values array size from pointArrayMap length\n if (pointArrayMapLength) {\n let len = pointArrayMap.length;\n while (len--) {\n values.push([]);\n }\n }\n else {\n values.push([]);\n }\n const valuesLen = pointArrayMapLength || 1;\n for (let i = 0; i <= dataLength; i++) {\n // Start with the first point within the X axis range (#2696)\n if (xData[i] < groupPositions[0]) {\n continue; // with next point\n }\n // when a new group is entered, summarize and initialize\n // the previous group\n while ((typeof groupPositions[pos + 1] !== 'undefined' &&\n xData[i] >= groupPositions[pos + 1]) ||\n i === dataLength) { // get the last group\n // get group x and y\n pointX = groupPositions[pos];\n series.dataGroupInfo = {\n start: groupAll ? start : (series.cropStart + start),\n length: values[0].length\n };\n groupedY = approximationFn.apply(series, values);\n // By default, let options of the first grouped point be passed over\n // to the grouped point. This allows preserving properties like\n // `name` and `color` or custom properties. Implementers can\n // override this from the approximation function, where they can\n // write custom options to `this.dataGroupInfo.options`.\n if (series.pointClass && !defined(series.dataGroupInfo.options)) {\n // Convert numbers and arrays into objects\n series.dataGroupInfo.options = merge(series.pointClass.prototype\n .optionsToObject.call({ series: series }, series.options.data[series.cropStart + start]));\n // Make sure the raw data (x, y, open, high etc) is not copied\n // over and overwriting approximated data.\n extendedPointArrayMap.forEach(function (key) {\n delete series.dataGroupInfo.options[key];\n });\n }\n // push the grouped data\n if (typeof groupedY !== 'undefined') {\n groupedXData.push(pointX);\n groupedYData.push(groupedY);\n groupMap.push(series.dataGroupInfo);\n }\n // reset the aggregate arrays\n start = i;\n for (let j = 0; j < valuesLen; j++) {\n values[j].length = 0; // faster than values[j] = []\n values[j].hasNulls = false;\n }\n // Advance on the group positions\n pos += 1;\n // don't loop beyond the last group\n if (i === dataLength) {\n break;\n }\n }\n // break out\n if (i === dataLength) {\n break;\n }\n // for each raw data point, push it to an array that contains all values\n // for this specific group\n if (pointArrayMap) {\n const index = (series.options.dataGrouping &&\n series.options.dataGrouping.groupAll ?\n i : series.cropStart + i), point = (data && data[index]) ||\n series.pointClass.prototype.applyOptions.apply({\n series: series\n }, [dataOptions[index]]);\n let val;\n for (let j = 0; j < pointArrayMapLength; j++) {\n val = point[pointArrayMap[j]];\n if (isNumber(val)) {\n values[j].push(val);\n }\n else if (val === null) {\n values[j].hasNulls = true;\n }\n }\n }\n else {\n pointY = handleYData ? yData[i] : null;\n if (isNumber(pointY)) {\n values[0].push(pointY);\n }\n else if (pointY === null) {\n values[0].hasNulls = true;\n }\n }\n }\n return {\n groupedXData,\n groupedYData,\n groupMap\n };\n }\n /**\n * Handle default options for data grouping. This must be set at runtime because\n * some series types are defined after this.\n * @private\n */\n function onAfterSetOptions(e) {\n const options = e.options, type = this.type, plotOptions = this.chart.options.plotOptions, \n // External series, for example technical indicators should also inherit\n // commonOptions which are not available outside this module\n baseOptions = (this.useCommonDataGrouping &&\n DataGroupingDefaults.common), seriesSpecific = DataGroupingDefaults.seriesSpecific;\n let defaultOptions = D.defaultOptions.plotOptions[type].dataGrouping;\n if (plotOptions && (seriesSpecific[type] || baseOptions)) { // #1284\n const rangeSelector = this.chart.rangeSelector;\n if (!defaultOptions) {\n defaultOptions = merge(DataGroupingDefaults.common, seriesSpecific[type]);\n }\n options.dataGrouping = merge(baseOptions, defaultOptions, plotOptions.series && plotOptions.series.dataGrouping, // #1228\n // Set by the StockChart constructor:\n plotOptions[type].dataGrouping, this.userOptions.dataGrouping, !options.isInternal &&\n rangeSelector &&\n isNumber(rangeSelector.selected) &&\n rangeSelector.buttonOptions[rangeSelector.selected].dataGrouping);\n }\n }\n /**\n * @private\n */\n function skipDataGrouping(series, force) {\n return !(series.isCartesian &&\n !series.isDirty &&\n !series.xAxis.isDirty &&\n !series.yAxis.isDirty &&\n !force);\n }\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingSeriesComposition = {\n compose,\n groupData\n };\n\n return DataGroupingSeriesComposition;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGrouping.js', [_modules['Extensions/DataGrouping/DataGroupingAxisComposition.js'], _modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Extensions/DataGrouping/DataGroupingSeriesComposition.js'], _modules['Core/Templating.js'], _modules['Core/Utilities.js']], function (DataGroupingAxisComposition, DataGroupingDefaults, DataGroupingSeriesComposition, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = F;\n const { addEvent, extend, isNumber } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AxisClass, SeriesClass, TooltipClass) {\n DataGroupingAxisComposition.compose(AxisClass);\n DataGroupingSeriesComposition.compose(SeriesClass);\n if (TooltipClass &&\n U.pushUnique(composedMembers, TooltipClass)) {\n addEvent(TooltipClass, 'headerFormatter', onTooltipHeaderFormatter);\n }\n }\n /**\n * Extend the original method, make the tooltip's header reflect the grouped\n * range.\n * @private\n */\n function onTooltipHeaderFormatter(e) {\n const chart = this.chart, time = chart.time, labelConfig = e.labelConfig, series = labelConfig.series, options = series.options, tooltipOptions = series.tooltipOptions, dataGroupingOptions = options.dataGrouping, xAxis = series.xAxis;\n let xDateFormat = tooltipOptions.xDateFormat, xDateFormatEnd, currentDataGrouping, dateTimeLabelFormats, labelFormats, formattedKey, formatString = tooltipOptions[e.isFooter ? 'footerFormat' : 'headerFormat'];\n // apply only to grouped series\n if (xAxis &&\n xAxis.options.type === 'datetime' &&\n dataGroupingOptions &&\n isNumber(labelConfig.key)) {\n // set variables\n currentDataGrouping = series.currentDataGrouping;\n dateTimeLabelFormats = dataGroupingOptions.dateTimeLabelFormats ||\n // Fallback to commonOptions (#9693)\n DataGroupingDefaults.common.dateTimeLabelFormats;\n // if we have grouped data, use the grouping information to get the\n // right format\n if (currentDataGrouping) {\n labelFormats =\n dateTimeLabelFormats[currentDataGrouping.unitName];\n if (currentDataGrouping.count === 1) {\n xDateFormat = labelFormats[0];\n }\n else {\n xDateFormat = labelFormats[1];\n xDateFormatEnd = labelFormats[2];\n }\n // if not grouped, and we don't have set the xDateFormat option, get the\n // best fit, so if the least distance between points is one minute, show\n // it, but if the least distance is one day, skip hours and minutes etc.\n }\n else if (!xDateFormat && dateTimeLabelFormats && xAxis.dateTime) {\n xDateFormat = xAxis.dateTime.getXDateFormat(labelConfig.x, tooltipOptions.dateTimeLabelFormats);\n }\n // now format the key\n formattedKey = time.dateFormat(xDateFormat, labelConfig.key);\n if (xDateFormatEnd) {\n formattedKey += time.dateFormat(xDateFormatEnd, labelConfig.key + currentDataGrouping.totalRange - 1);\n }\n // Replace default header style with class name\n if (series.chart.styledMode) {\n formatString = this.styledModeFormat(formatString);\n }\n // return the replaced format\n e.text = format(formatString, {\n point: extend(labelConfig.point, { key: formattedKey }),\n series: series\n }, chart);\n e.preventDefault();\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingComposition = {\n compose,\n groupData: DataGroupingSeriesComposition.groupData\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"average\"|\"averages\"|\"open\"|\"high\"|\"low\"|\"close\"|\"sum\"} Highcharts.DataGroupingApproximationValue\n */\n /**\n * The position of the point inside the group.\n *\n * @typedef {\"start\"|\"middle\"|\"end\"} Highcharts.DataGroupingAnchor\n */\n /**\n * The position of the first or last point in the series inside the group.\n *\n * @typedef {\"start\"|\"middle\"|\"end\"|\"firstPoint\"|\"lastPoint\"} Highcharts.DataGroupingAnchorExtremes\n */\n /**\n * Highcharts Stock only.\n *\n * @product highstock\n * @interface Highcharts.DataGroupingInfoObject\n */ /**\n * @name Highcharts.DataGroupingInfoObject#length\n * @type {number}\n */ /**\n * @name Highcharts.DataGroupingInfoObject#options\n * @type {Highcharts.SeriesOptionsType|undefined}\n */ /**\n * @name Highcharts.DataGroupingInfoObject#start\n * @type {number}\n */\n /**\n * Highcharts Stock only.\n *\n * @product highstock\n * @interface Highcharts.DataGroupingResultObject\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupedXData\n * @type {Array}\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupedYData\n * @type {Array<(number|null|undefined)>|Array>}\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupMap\n * @type {Array}\n */\n /**\n * Highcharts Stock only. If a point object is created by data\n * grouping, it doesn't reflect actual points in the raw\n * data. In this case, the `dataGroup` property holds\n * information that points back to the raw data.\n *\n * - `dataGroup.start` is the index of the first raw data\n * point in the group.\n *\n * - `dataGroup.length` is the amount of points in the\n * group.\n *\n * @sample stock/members/point-datagroup\n * Click to inspect raw data points\n *\n * @product highstock\n *\n * @name Highcharts.Point#dataGroup\n * @type {Highcharts.DataGroupingInfoObject|undefined}\n */\n (''); // detach doclets above\n /* *\n *\n * API Options\n *\n * */\n /**\n * Data grouping is the concept of sampling the data values into larger\n * blocks in order to ease readability and increase performance of the\n * JavaScript charts. Highcharts Stock by default applies data grouping when\n * the points become closer than a certain pixel value, determined by\n * the `groupPixelWidth` option.\n *\n * If data grouping is applied, the grouping information of grouped\n * points can be read from the [Point.dataGroup](\n * /class-reference/Highcharts.Point#dataGroup). If point options other than\n * the data itself are set, for example `name` or `color` or custom properties,\n * the grouping logic doesn't know how to group it. In this case the options of\n * the first point instance are copied over to the group point. This can be\n * altered through a custom `approximation` callback function.\n *\n * @declare Highcharts.DataGroupingOptionsObject\n * @product highstock\n * @requires product:highstock\n * @requires module:modules/datagrouping\n * @apioption plotOptions.series.dataGrouping\n */\n /**\n * Specifies how the points should be located on the X axis inside the group.\n * Points that are extremes can be set separately. Available options:\n *\n * - `start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * - `middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * - `end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-anchor\n * Changing the point x-coordinate inside the group.\n *\n * @see [dataGrouping.firstAnchor](#plotOptions.series.dataGrouping.firstAnchor)\n * @see [dataGrouping.lastAnchor](#plotOptions.series.dataGrouping.lastAnchor)\n *\n * @type {Highcharts.DataGroupingAnchor}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.anchor\n */\n /**\n * The method of approximation inside a group. When for example 30 days\n * are grouped into one month, this determines what value should represent\n * the group. Possible values are \"average\", \"averages\", \"open\", \"high\",\n * \"low\", \"close\" and \"sum\". For OHLC and candlestick series the approximation\n * is \"ohlc\" by default, which finds the open, high, low and close values\n * within all the grouped data. For ranges, the approximation is \"range\",\n * which finds the low and high values. For multi-dimensional data,\n * like ranges and OHLC, \"averages\" will compute the average for each\n * dimension.\n *\n * Custom aggregate methods can be added by assigning a callback function\n * as the approximation. This function takes a numeric array as the\n * argument and should return a single numeric value or `null`. Note\n * that the numeric array will never contain null values, only true\n * numbers. Instead, if null values are present in the raw data, the\n * numeric array will have an `.hasNulls` property set to `true`. For\n * single-value data sets the data is available in the first argument\n * of the callback function. For OHLC data sets, all the open values\n * are in the first argument, all high values in the second etc.\n *\n * Since v4.2.7, grouping meta data is available in the approximation\n * callback from `this.dataGroupInfo`. It can be used to extract information\n * from the raw data.\n *\n * Defaults to `average` for line-type series, `sum` for columns, `range`\n * for range series, `hlc` for HLC, and `ohlc` for OHLC and candlestick.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-approximation\n * Approximation callback with custom data\n * @sample {highstock} stock/plotoptions/series-datagrouping-simple-approximation\n * Simple approximation demo\n *\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @apioption plotOptions.series.dataGrouping.approximation\n */\n /**\n * Datetime formats for the header of the tooltip in a stock chart.\n * The format can vary within a chart depending on the currently selected\n * time range and the current data grouping.\n *\n * The default formats are:\n * ```js\n * {\n * millisecond: [\n * '%A, %e %b, %H:%M:%S.%L', '%A, %e %b, %H:%M:%S.%L', '-%H:%M:%S.%L'\n * ],\n * second: ['%A, %e %b, %H:%M:%S', '%A, %e %b, %H:%M:%S', '-%H:%M:%S'],\n * minute: ['%A, %e %b, %H:%M', '%A, %e %b, %H:%M', '-%H:%M'],\n * hour: ['%A, %e %b, %H:%M', '%A, %e %b, %H:%M', '-%H:%M'],\n * day: ['%A, %e %b %Y', '%A, %e %b', '-%A, %e %b %Y'],\n * week: ['Week from %A, %e %b %Y', '%A, %e %b', '-%A, %e %b %Y'],\n * month: ['%B %Y', '%B', '-%B %Y'],\n * year: ['%Y', '%Y', '-%Y']\n * }\n * ```\n *\n * For each of these array definitions, the first item is the format\n * used when the active time span is one unit. For instance, if the\n * current data applies to one week, the first item of the week array\n * is used. The second and third items are used when the active time\n * span is more than two units. For instance, if the current data applies\n * to two weeks, the second and third item of the week array are used,\n * and applied to the start and end date of the time span.\n *\n * @type {Object}\n * @apioption plotOptions.series.dataGrouping.dateTimeLabelFormats\n */\n /**\n * Enable or disable data grouping.\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.dataGrouping.enabled\n */\n /**\n * Specifies how the first grouped point is positioned on the xAxis.\n * If firstAnchor and/or lastAnchor are defined, then those options take\n * precedence over anchor for the first and/or last grouped points.\n * Available options:\n *\n * -`start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * -`middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * -`end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * -`firstPoint` the first point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:13)\n *\n * -`lastPoint` the last point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-first-anchor\n * Applying first and last anchor.\n *\n * @see [dataGrouping.anchor](#plotOptions.series.dataGrouping.anchor)\n *\n * @type {Highcharts.DataGroupingAnchorExtremes}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.firstAnchor\n */\n /**\n * When data grouping is forced, it runs no matter how small the intervals\n * are. This can be handy for example when the sum should be calculated\n * for values appearing at random times within each hour.\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataGrouping.forced\n */\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no grouping\n * is performed. If however the series contains so many points that\n * the spacing is less than the groupPixelWidth, Highcharts will try\n * to group it into appropriate groups so that each is more or less\n * two pixels wide. If multiple series with different group pixel widths\n * are drawn on the same x axis, all series will take the greatest width.\n * For example, line series have 2px default group width, while column\n * series have 10px. If combined, both the line and the column will\n * have 10px by default.\n *\n * @type {number}\n * @default 2\n * @apioption plotOptions.series.dataGrouping.groupPixelWidth\n */\n /**\n * By default only points within the visible range are grouped. Enabling this\n * option will force data grouping to calculate all grouped points for a given\n * dataset. That option prevents for example a column series from calculating\n * a grouped point partially. The effect is similar to\n * [Series.getExtremesFromAll](#plotOptions.series.getExtremesFromAll) but does\n * not affect yAxis extremes.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-groupall/\n * Two series with the same data but different groupAll setting\n *\n * @type {boolean}\n * @default false\n * @since 6.1.0\n * @apioption plotOptions.series.dataGrouping.groupAll\n */\n /**\n * Specifies how the last grouped point is positioned on the xAxis.\n * If firstAnchor and/or lastAnchor are defined, then those options take\n * precedence over anchor for the first and/or last grouped points.\n * Available options:\n *\n * -`start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * -`middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * -`end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * -`firstPoint` the first point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:13)\n *\n * -`lastPoint` the last point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-first-anchor\n * Applying first and last anchor.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-last-anchor\n * Applying the last anchor in the chart with live data.\n *\n * @see [dataGrouping.anchor](#plotOptions.series.dataGrouping.anchor)\n *\n * @type {Highcharts.DataGroupingAnchorExtremes}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.lastAnchor\n */\n /**\n * Normally, a group is indexed by the start of that group, so for example\n * when 30 daily values are grouped into one month, that month's x value\n * will be the 1st of the month. This apparently shifts the data to\n * the left. When the smoothed option is true, this is compensated for.\n * The data is shifted to the middle of the group, and min and max\n * values are preserved. Internally, this is used in the Navigator series.\n *\n * @type {boolean}\n * @default false\n * @deprecated\n * @apioption plotOptions.series.dataGrouping.smoothed\n */\n /**\n * An array determining what time intervals the data is allowed to be\n * grouped to. Each array item is an array where the first value is\n * the time unit and the second value another array of allowed multiples.\n *\n * Defaults to:\n * ```js\n * units: [[\n * 'millisecond', // unit name\n * [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n * ], [\n * 'second',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'minute',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'hour',\n * [1, 2, 3, 4, 6, 8, 12]\n * ], [\n * 'day',\n * [1]\n * ], [\n * 'week',\n * [1]\n * ], [\n * 'month',\n * [1, 3, 6]\n * ], [\n * 'year',\n * null\n * ]]\n * ```\n *\n * @type {Array|null)>>}\n * @apioption plotOptions.series.dataGrouping.units\n */\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no grouping\n * is performed. If however the series contains so many points that\n * the spacing is less than the groupPixelWidth, Highcharts will try\n * to group it into appropriate groups so that each is more or less\n * two pixels wide. Defaults to `10`.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-grouppixelwidth/\n * Two series with the same data density but different groupPixelWidth\n *\n * @type {number}\n * @default 10\n * @apioption plotOptions.column.dataGrouping.groupPixelWidth\n */\n ''; // required by JSDoc parsing\n\n return DataGroupingComposition;\n });\n _registerModule(_modules, 'masters/modules/datagrouping.src.js', [_modules['Core/Globals.js'], _modules['Extensions/DataGrouping/ApproximationDefaults.js'], _modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Extensions/DataGrouping/DataGrouping.js']], function (Highcharts, ApproximationDefaults, ApproximationRegistry, DataGrouping) {\n\n const G = Highcharts;\n G.dataGrouping = {\n approximationDefaults: ApproximationDefaults,\n approximations: ApproximationRegistry\n };\n DataGrouping.compose(G.Axis, G.Series, G.Tooltip);\n\n });\n _registerModule(_modules, 'Extensions/MouseWheelZoom/MouseWheelZoom.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2023 Torstein Honsi, Askel Eirik Johansson\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, isObject, pick, defined, merge } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedClasses = [], defaultOptions = {\n enabled: true,\n sensitivity: 1.1\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n const optionsToObject = (options) => {\n if (!isObject(options)) {\n return merge(defaultOptions, { enabled: defined(options) ? options : true });\n }\n return merge(defaultOptions, options);\n };\n /**\n * @private\n */\n const fitToBox = function (inner, outer) {\n if (inner.x + inner.width > outer.x + outer.width) {\n if (inner.width > outer.width) {\n inner.width = outer.width;\n inner.x = outer.x;\n }\n else {\n inner.x = outer.x + outer.width - inner.width;\n }\n }\n if (inner.width > outer.width) {\n inner.width = outer.width;\n }\n if (inner.x < outer.x) {\n inner.x = outer.x;\n }\n // y and height\n if (inner.y + inner.height > outer.y + outer.height) {\n if (inner.height > outer.height) {\n inner.height = outer.height;\n inner.y = outer.y;\n }\n else {\n inner.y = outer.y + outer.height - inner.height;\n }\n }\n if (inner.height > outer.height) {\n inner.height = outer.height;\n }\n if (inner.y < outer.y) {\n inner.y = outer.y;\n }\n return inner;\n };\n let wheelTimer, originalOptions;\n /**\n * @private\n */\n const zoomBy = function (chart, howMuch, centerXArg, centerYArg, mouseX, mouseY, options) {\n const xAxis = chart.xAxis[0], yAxis = chart.yAxis[0], type = pick(options.type, chart.options.chart.zooming.type, 'x'), zoomX = /x/.test(type), zoomY = /y/.test(type);\n if (defined(xAxis.max) && defined(xAxis.min) &&\n defined(yAxis.max) && defined(yAxis.min) &&\n defined(xAxis.dataMax) && defined(xAxis.dataMin) &&\n defined(yAxis.dataMax) && defined(yAxis.dataMin)) {\n if (zoomY) {\n // Options interfering with yAxis zoom by setExtremes() returning\n // integers by default.\n if (defined(wheelTimer)) {\n clearTimeout(wheelTimer);\n }\n const { startOnTick, endOnTick } = yAxis.options;\n if (!originalOptions) {\n originalOptions = { startOnTick, endOnTick };\n }\n if (startOnTick || endOnTick) {\n yAxis.setOptions({ startOnTick: false, endOnTick: false });\n }\n wheelTimer = setTimeout(() => {\n if (originalOptions) {\n yAxis.setOptions(originalOptions);\n // Set the extremes to the same as they already are, but now\n // with the original startOnTick and endOnTick. We need\n // `forceRedraw` otherwise it will detect that the values\n // haven't changed. We do not use a simple yAxis.update()\n // because it will destroy the ticks and prevent animation.\n const { min, max } = yAxis.getExtremes();\n yAxis.forceRedraw = true;\n yAxis.setExtremes(min, max);\n originalOptions = void 0;\n }\n }, 400);\n }\n if (chart.inverted) {\n const emulateRoof = yAxis.pos + yAxis.len;\n // Get the correct values\n centerXArg = xAxis.toValue(mouseY);\n centerYArg = yAxis.toValue(mouseX);\n // Swapping x and y for simplicity when chart is inverted.\n const tmp = mouseX;\n mouseX = mouseY;\n mouseY = emulateRoof - tmp + yAxis.pos;\n }\n let fixToX = mouseX ? ((mouseX - xAxis.pos) / xAxis.len) : 0.5;\n if (xAxis.reversed && !chart.inverted ||\n chart.inverted && !xAxis.reversed) {\n // We are taking into account that xAxis automatically gets\n // reversed when chart.inverted\n fixToX = 1 - fixToX;\n }\n let fixToY = 1 - (mouseY ? ((mouseY - yAxis.pos) / yAxis.len) : 0.5);\n if (yAxis.reversed) {\n fixToY = 1 - fixToY;\n }\n const xRange = xAxis.max - xAxis.min, centerX = pick(centerXArg, xAxis.min + xRange / 2), newXRange = xRange * howMuch, yRange = yAxis.max - yAxis.min, centerY = pick(centerYArg, yAxis.min + yRange / 2), newYRange = yRange * howMuch, newXMin = centerX - newXRange * fixToX, newYMin = centerY - newYRange * fixToY, dataRangeX = xAxis.dataMax - xAxis.dataMin, dataRangeY = yAxis.dataMax - yAxis.dataMin, outerX = xAxis.dataMin - dataRangeX * xAxis.options.minPadding, outerWidth = dataRangeX + dataRangeX * xAxis.options.minPadding +\n dataRangeX * xAxis.options.maxPadding, outerY = yAxis.dataMin - dataRangeY * yAxis.options.minPadding, outerHeight = dataRangeY + dataRangeY * yAxis.options.minPadding +\n dataRangeY * yAxis.options.maxPadding, newExt = fitToBox({\n x: newXMin,\n y: newYMin,\n width: newXRange,\n height: newYRange\n }, {\n x: outerX,\n y: outerY,\n width: outerWidth,\n height: outerHeight\n }), zoomOut = (newExt.x <= outerX &&\n newExt.width >=\n outerWidth &&\n newExt.y <= outerY &&\n newExt.height >= outerHeight);\n // Zoom\n if (defined(howMuch) && !zoomOut) {\n if (zoomX) {\n xAxis.setExtremes(newExt.x, newExt.x + newExt.width, false);\n }\n if (zoomY) {\n yAxis.setExtremes(newExt.y, newExt.y + newExt.height, false);\n }\n // Reset zoom\n }\n else {\n if (zoomX) {\n xAxis.setExtremes(void 0, void 0, false);\n }\n if (zoomY) {\n yAxis.setExtremes(void 0, void 0, false);\n }\n }\n chart.redraw(false);\n }\n };\n /**\n * @private\n */\n function onAfterGetContainer() {\n const chart = this, wheelZoomOptions = optionsToObject(chart.options.chart.zooming.mouseWheel);\n if (wheelZoomOptions.enabled) {\n addEvent(this.container, 'wheel', (e) => {\n e = this.pointer.normalize(e);\n // Firefox uses e.detail, WebKit and IE uses deltaX, deltaY, deltaZ.\n if (chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop)) {\n const wheelSensitivity = pick(wheelZoomOptions.sensitivity, 1.1), delta = e.detail || ((e.deltaY || 0) / 120);\n zoomBy(chart, Math.pow(wheelSensitivity, delta), chart.xAxis[0].toValue(e.chartX), chart.yAxis[0].toValue(e.chartY), e.chartX, e.chartY, wheelZoomOptions);\n }\n // prevent page scroll\n if (e.preventDefault) {\n e.preventDefault();\n }\n });\n }\n }\n /**\n * @private\n */\n function compose(ChartClass) {\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n addEvent(ChartClass, 'afterGetContainer', onAfterGetContainer);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const MouseWheelZoomComposition = {\n compose\n };\n /* *\n *\n * API Options\n *\n * */\n /**\n * The mouse wheel zoom is a feature included in Highcharts Stock, but is\n * also available for Highcharts Core as a module. Zooming with the mouse wheel\n * is enabled by default. It can be disabled by setting this option to\n * `false`.\n *\n * @type {boolean|object}\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @sample {highcharts} highcharts/mouse-wheel-zoom/enabled\n * Enable or disable\n * @sample {highstock} stock/mouse-wheel-zoom/enabled\n * Enable or disable\n * @apioption chart.zooming.mouseWheel\n */\n /**\n * Zooming with the mouse wheel can be disabled by setting this option to\n * `false`.\n *\n * @type {boolean}\n * @default true\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @apioption chart.zooming.mouseWheel.enabled\n */\n /**\n * Adjust the sensitivity of the zoom. Sensitivity of mouse wheel or trackpad\n * scrolling. `1` is no sensitivity, while with `2`, one mouse wheel delta will\n * zoom in `50%`.\n *\n * @type {number}\n * @default 1.1\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @sample {highcharts} highcharts/mouse-wheel-zoom/sensitivity\n * Change mouse wheel zoom sensitivity\n * @sample {highstock} stock/mouse-wheel-zoom/sensitivity\n * Change mouse wheel zoom sensitivity\n * @apioption chart.zooming.mouseWheel.sensitivity\n */\n /**\n * Decides in what dimensions the user can zoom scrolling the wheel.\n * Can be one of `x`, `y` or `xy`. If not specified here, it will inherit the\n * type from [chart.zooming.type](chart.zooming.type).\n *\n * Note that particularly with mouse wheel in the y direction, the zoom is\n * affected by the default [yAxis.startOnTick](#yAxis.startOnTick) and\n * [endOnTick]((#yAxis.endOnTick)) settings. In order to respect these settings,\n * the zoom level will adjust after the user has stopped zooming. To prevent\n * this, consider setting `startOnTick` and `endOnTick` to `false`.\n *\n * @type {string}\n * @default x\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @apioption chart.zooming.mouseWheel.type\n */\n (''); // Keeps doclets above in JS file\n\n return MouseWheelZoomComposition;\n });\n _registerModule(_modules, 'masters/modules/mouse-wheel-zoom.src.js', [_modules['Core/Globals.js'], _modules['Extensions/MouseWheelZoom/MouseWheelZoom.js']], function (Highcharts, MouseWheelZoom) {\n\n const G = Highcharts;\n MouseWheelZoom.compose(G.Chart);\n\n });\n _registerModule(_modules, 'Series/DataModifyComposition.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Series/Point.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (Axis, Point, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { prototype: { tooltipFormatter: pointTooltipFormatter } } = Point;\n const { addEvent, arrayMax, arrayMin, correctFloat, defined, isArray, isNumber, isString, pick } = U;\n /* *\n *\n * Composition\n *\n * */\n var DataModifyComposition;\n (function (DataModifyComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Extends the series, axis and point classes with\n * compare and cumulative support.\n *\n * @private\n *\n * @param SeriesClass\n * Series class to use.\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param PointClass\n * Point class to use.\n */\n function compose(SeriesClass, AxisClass, PointClass) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.setCompare = seriesSetCompare;\n seriesProto.setCumulative = seriesSetCumulative;\n addEvent(SeriesClass, 'afterInit', afterInit);\n addEvent(SeriesClass, 'afterGetExtremes', afterGetExtremes);\n addEvent(SeriesClass, 'afterProcessData', afterProcessData);\n }\n if (U.pushUnique(composedMembers, AxisClass)) {\n const axisProto = AxisClass.prototype;\n axisProto.setCompare = axisSetCompare;\n axisProto.setModifier = setModifier;\n axisProto.setCumulative = axisSetCumulative;\n }\n if (U.pushUnique(composedMembers, PointClass)) {\n const pointProto = PointClass.prototype;\n pointProto.tooltipFormatter = tooltipFormatter;\n }\n return SeriesClass;\n }\n DataModifyComposition.compose = compose;\n /* ********************************************************************** *\n * Start shared compare and cumulative logic *\n * ********************************************************************** */\n /**\n * Shared code for the axis.setCompare() and the axis.setCumulative()\n * methods. Inits the 'compare' or the 'cumulative' mode.\n * @private\n */\n function setModifier(mode, modeState, redraw) {\n if (!this.isXAxis) {\n this.series.forEach(function (series) {\n if (mode === 'compare' &&\n typeof modeState !== 'boolean') {\n series.setCompare(modeState, false);\n }\n else if (mode === 'cumulative' &&\n !isString(modeState)) {\n series.setCumulative(modeState, false);\n }\n });\n if (pick(redraw, true)) {\n this.chart.redraw();\n }\n }\n }\n /**\n * Extend the tooltip formatter by adding support for the point.change\n * variable as well as the changeDecimals option.\n *\n * @ignore\n * @function Highcharts.Point#tooltipFormatter\n *\n * @param {string} pointFormat\n */\n function tooltipFormatter(pointFormat) {\n const point = this, { numberFormatter } = point.series.chart, replace = function (value) {\n pointFormat = pointFormat.replace('{point.' + value + '}', (point[value] > 0 && value === 'change' ? '+' : '') +\n numberFormatter(point[value], pick(point.series.tooltipOptions.changeDecimals, 2)));\n };\n if (defined(point.change)) {\n replace('change');\n }\n if (defined(point.cumulativeSum)) {\n replace('cumulativeSum');\n }\n return pointTooltipFormatter.apply(this, [pointFormat]);\n }\n /**\n * Extend series.init by adding a methods to modify the y values used\n * for plotting on the y axis. For compare mode, this method is called both\n * from the axis when finding dataMin and dataMax,\n * and from the series.translate method.\n *\n * @ignore\n * @function Highcharts.Series#init\n */\n function afterInit() {\n const compare = this.options.compare;\n let dataModify;\n if (compare === 'percent' ||\n compare === 'value' ||\n this.options.cumulative) {\n dataModify = new Additions(this);\n if (compare === 'percent' || compare === 'value') {\n // Set comparison mode\n dataModify.initCompare(compare);\n }\n else {\n // Set Cumulative Sum mode\n dataModify.initCumulative();\n }\n }\n this.dataModify = dataModify;\n }\n /**\n * Adjust the extremes (compare and cumulative modify the data).\n * @private\n */\n function afterGetExtremes(e) {\n const dataExtremes = e.dataExtremes, activeYData = dataExtremes.activeYData;\n if (this.dataModify && dataExtremes) {\n let extremes;\n if (this.options.compare) {\n extremes = [\n this.dataModify.modifyValue(dataExtremes.dataMin),\n this.dataModify.modifyValue(dataExtremes.dataMax)\n ];\n }\n else if (this.options.cumulative &&\n isArray(activeYData) &&\n // If only one y visible, sum doesn't change\n // so no need to change extremes\n activeYData.length >= 2) {\n extremes = Additions.getCumulativeExtremes(activeYData);\n }\n if (extremes) {\n dataExtremes.dataMin = arrayMin(extremes);\n dataExtremes.dataMax = arrayMax(extremes);\n }\n }\n }\n /* ********************************************************************** *\n * End shared compare and cumulative logic *\n * ********************************************************************** */\n /* ********************************************************************** *\n * Start value compare logic *\n * ********************************************************************** */\n /**\n * Highcharts Stock only. Set the\n * [compare](https://api.highcharts.com/highstock/plotOptions.series.compare)\n * mode of the series after render time.\n * In most cases it is more useful running\n * {@link Axis#setCompare} on the X axis to update all its series.\n *\n * @function Highcharts.Series#setCompare\n *\n * @param {string|null} [compare]\n * Can be one of `undefined` (default), `null`, `\"percent\"`\n * or `\"value\"`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function seriesSetCompare(compare, redraw) {\n // Survive to export, #5485 (and for options generally)\n this.options.compare = this.userOptions.compare = compare;\n // Fire series.init() that will set or delete series.dataModify\n this.update({}, pick(redraw, true));\n if (this.dataModify && (compare === 'value' || compare === 'percent')) {\n this.dataModify.initCompare(compare);\n }\n else {\n // When disabling, clear the points\n this.points.forEach((point) => {\n delete point.change;\n });\n }\n }\n /**\n * Extend series.processData by finding the first y value in the plot area,\n * used for comparing the following values\n *\n * @ignore\n * @function Highcharts.Series#processData\n */\n function afterProcessData() {\n const series = this;\n if (series.xAxis && // not pies\n series.processedYData &&\n series.dataModify) {\n const processedXData = series.processedXData, processedYData = series.processedYData, length = processedYData.length, compareStart = series.options.compareStart === true ? 0 : 1;\n let keyIndex = -1, i;\n // For series with more than one value (range, OHLC etc), compare\n // against close or the pointValKey (#4922, #3112, #9854)\n if (series.pointArrayMap) {\n keyIndex = series.pointArrayMap.indexOf(series.options.pointValKey || series.pointValKey || 'y');\n }\n // find the first value for comparison\n for (i = 0; i < length - compareStart; i++) {\n const compareValue = processedYData[i] && keyIndex > -1 ?\n processedYData[i][keyIndex] : processedYData[i];\n if (isNumber(compareValue) &&\n compareValue !== 0 &&\n processedXData[i + compareStart] >= (series.xAxis.min || 0)) {\n series.dataModify.compareValue = compareValue;\n break;\n }\n }\n }\n }\n /**\n * Highcharts Stock only. Set the compare mode on all series\n * belonging to a Y axis.\n *\n * @see [plotOptions.series.compare](https://api.highcharts.com/highstock/plotOptions.series.compare)\n *\n * @sample stock/members/axis-setcompare/\n * Set compare\n *\n * @function Highcharts.Axis#setCompare\n *\n * @param {string|null} [compare]\n * The compare mode. Can be one of `undefined` (default), `null`,\n * `\"value\"` or `\"percent\"`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function axisSetCompare(compare, redraw) {\n this.setModifier('compare', compare, redraw);\n }\n /* ********************************************************************** *\n * End value compare logic *\n * ********************************************************************** */\n /* ********************************************************************** *\n * Start Cumulative Sum logic, author: Rafal Sebestjanski *\n * ********************************************************************** */\n /**\n * Highcharts Stock only. Set the\n * [cumulative](https://api.highcharts.com/highstock/plotOptions.series.cumulative)\n * mode of the series after render time.\n * In most cases it is more useful running\n * {@link Axis#setCumulative} on the Y axis to update all its series.\n *\n * @function Highcharts.Series#setCumulative\n *\n * @param {boolean} [cumulative=false]\n * Either enable or disable Cumulative Sum mode.\n * Can be one of `false` (default) or `true`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function seriesSetCumulative(cumulative, redraw) {\n // Set default value to false\n cumulative = pick(cumulative, false);\n // Survive to export, #5485 (and for options generally)\n this.options.cumulative = this.userOptions.cumulative = cumulative;\n // Fire series.init() that will set or delete series.dataModify\n this.update({}, pick(redraw, true));\n // If should, turn on the Cumulative Sum mode\n if (this.dataModify) {\n this.dataModify.initCumulative();\n }\n else {\n // When disabling, clear the points\n this.points.forEach((point) => {\n delete point.cumulativeSum;\n });\n }\n }\n /**\n * Highcharts Stock only. Set the cumulative mode on all series\n * belonging to a Y axis.\n *\n * @see [plotOptions.series.cumulative](https://api.highcharts.com/highstock/plotOptions.series.cumulative)\n *\n * @sample stock/members/axis-setcumulative/\n * Set cumulative\n *\n * @function Highcharts.Axis#setCumulative\n *\n * @param {boolean} [cumulative]\n * Whether to disable or enable the cumulative mode.\n * Can be one of `undefined` (default, treated as `false`),\n * `false` or `true`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function axisSetCumulative(cumulative, redraw) {\n this.setModifier('cumulative', cumulative, redraw);\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * @private\n */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n /**\n * @private\n */\n constructor(series) {\n this.series = series;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n modifyValue() {\n return 0;\n }\n /**\n * @ignore\n * @function Highcharts.Series#getCumulativeExtremes\n *\n * @param {Array} [activeYData]\n * An array cointaining all the points' y values\n * in a visible range.\n */\n static getCumulativeExtremes(activeYData) {\n let cumulativeDataMin = Infinity, cumulativeDataMax = -Infinity;\n activeYData.reduce((prev, cur) => {\n const sum = prev + cur;\n cumulativeDataMin = Math.min(cumulativeDataMin, sum, prev);\n cumulativeDataMax = Math.max(cumulativeDataMax, sum, prev);\n return sum;\n });\n return [cumulativeDataMin, cumulativeDataMax];\n }\n /**\n * @ignore\n * @function Highcharts.Series#initCompare\n *\n * @param {string} [compare]\n * Can be one of `\"percent\"` or `\"value\"`.\n */\n initCompare(compare) {\n // Set the modifyValue method\n this.modifyValue = function (value, index) {\n if (value === null) {\n value = 0;\n }\n const compareValue = this.compareValue;\n if (typeof value !== 'undefined' &&\n typeof compareValue !== 'undefined') { // #2601, #5814\n // Get the modified value\n if (compare === 'value') {\n value -= compareValue;\n // Compare percent\n }\n else {\n const compareBase = this.series.options.compareBase;\n value = 100 * (value / compareValue) -\n (compareBase === 100 ? 0 : 100);\n }\n // record for tooltip etc.\n if (typeof index !== 'undefined') {\n const point = this.series.points[index];\n if (point) {\n point.change = value;\n }\n }\n return value;\n }\n return 0;\n };\n }\n /**\n * @ignore\n * @function Highcharts.Series#initCumulative\n */\n initCumulative() {\n // Set the modifyValue method\n this.modifyValue = function (value, index) {\n if (value === null) {\n value = 0;\n }\n if (value !== void 0 && index !== void 0) {\n const prevPoint = index > 0 ?\n this.series.points[index - 1] : null;\n // Get the modified value\n if (prevPoint && prevPoint.cumulativeSum) {\n value = correctFloat(prevPoint.cumulativeSum + value);\n }\n // Record for tooltip etc.\n const point = this.series.points[index];\n if (point) {\n point.cumulativeSum = value;\n }\n return value;\n }\n return 0;\n };\n }\n }\n DataModifyComposition.Additions = Additions;\n })(DataModifyComposition || (DataModifyComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Compare the values of the series against the first non-null, non-\n * zero value in the visible range. The y axis will show percentage\n * or absolute change depending on whether `compare` is set to `\"percent\"`\n * or `\"value\"`. When this is applied to multiple series, it allows\n * comparing the development of the series against each other. Adds\n * a `change` field to every point object.\n *\n * @see [compareBase](#plotOptions.series.compareBase)\n * @see [Axis.setCompare()](/class-reference/Highcharts.Axis#setCompare)\n * @see [Series.setCompare()](/class-reference/Highcharts.Series#setCompare)\n *\n * @sample {highstock} stock/plotoptions/series-compare-percent/\n * Percent\n * @sample {highstock} stock/plotoptions/series-compare-value/\n * Value\n *\n * @type {string}\n * @since 1.0.1\n * @product highstock\n * @validvalue [\"percent\", \"value\"]\n * @apioption plotOptions.series.compare\n */\n /**\n * Defines if comparison should start from the first point within the visible\n * range or should start from the first point **before** the range.\n *\n * In other words, this flag determines if first point within the visible range\n * will have 0% (`compareStart=true`) or should have been already calculated\n * according to the previous point (`compareStart=false`).\n *\n * @sample {highstock} stock/plotoptions/series-comparestart/\n * Calculate compare within visible range\n *\n * @type {boolean}\n * @default false\n * @since 6.0.0\n * @product highstock\n * @apioption plotOptions.series.compareStart\n */\n /**\n * When [compare](#plotOptions.series.compare) is `percent`, this option\n * dictates whether to use 0 or 100 as the base of comparison.\n *\n * @sample {highstock} stock/plotoptions/series-comparebase/\n * Compare base is 100\n *\n * @type {number}\n * @default 0\n * @since 5.0.6\n * @product highstock\n * @validvalue [0, 100]\n * @apioption plotOptions.series.compareBase\n */\n /**\n * Cumulative Sum feature replaces points' values with the following formula:\n * `sum of all previous points' values + current point's value`.\n * Works only for points in a visible range.\n * Adds the `cumulativeSum` field to each point object that can be accessed\n * e.g. in the [tooltip.pointFormat](https://api.highcharts.com/highstock/tooltip.pointFormat).\n *\n * With `dataGrouping` enabled, default grouping approximation is set to `sum`.\n *\n * @see [Axis.setCumulative()](/class-reference/Highcharts.Axis#setCumulative)\n * @see [Series.setCumulative()](/class-reference/Highcharts.Series#setCumulative)\n *\n * @sample {highstock} stock/plotoptions/series-cumulative-sum/\n * Cumulative Sum\n *\n * @type {boolean}\n * @default false\n * @since 9.3.0\n * @product highstock\n * @apioption plotOptions.series.cumulative\n */\n ''; // keeps doclets above in transpiled file\n\n return DataModifyComposition;\n });\n _registerModule(_modules, 'Core/Axis/NavigatorAxisComposition.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isTouchDevice } = H;\n const { addEvent, correctFloat, defined, isNumber, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function onAxisInit() {\n const axis = this;\n if (!axis.navigatorAxis) {\n axis.navigatorAxis = new NavigatorAxisAdditions(axis);\n }\n }\n /**\n * For Stock charts, override selection zooming with some special features\n * because X axis zooming is already allowed by the Navigator and Range\n * selector.\n * @private\n */\n function onAxisZoom(e) {\n const axis = this, chart = axis.chart, chartOptions = chart.options, navigator = chartOptions.navigator, navigatorAxis = axis.navigatorAxis, pinchType = chart.zooming.pinchType, rangeSelector = chartOptions.rangeSelector, zoomType = chart.zooming.type;\n if (axis.isXAxis && ((navigator && navigator.enabled) ||\n (rangeSelector && rangeSelector.enabled))) {\n // For y only zooming, ignore the X axis completely\n if (zoomType === 'y') {\n e.zoomed = false;\n // For xy zooming, record the state of the zoom before zoom\n // selection, then when the reset button is pressed, revert to\n // this state. This should apply only if the chart is\n // initialized with a range (#6612), otherwise zoom all the way\n // out.\n }\n else if (((!isTouchDevice && zoomType === 'xy') ||\n (isTouchDevice && pinchType === 'xy')) &&\n axis.options.range) {\n const previousZoom = navigatorAxis.previousZoom;\n if (defined(e.newMin)) {\n navigatorAxis.previousZoom = [axis.min, axis.max];\n }\n else if (previousZoom) {\n e.newMin = previousZoom[0];\n e.newMax = previousZoom[1];\n navigatorAxis.previousZoom = void 0;\n }\n }\n }\n if (typeof e.zoomed !== 'undefined') {\n e.preventDefault();\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n * @class\n */\n class NavigatorAxisAdditions {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n static compose(AxisClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('navigatorAxis');\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'zoom', onAxisZoom);\n }\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n destroy() {\n this.axis = void 0;\n }\n /**\n * Add logic to normalize the zoomed range in order to preserve the pressed\n * state of range selector buttons\n *\n * @private\n * @function Highcharts.Axis#toFixedRange\n */\n toFixedRange(pxMin, pxMax, fixedMin, fixedMax) {\n const axis = this.axis, chart = axis.chart;\n let newMin = pick(fixedMin, axis.translate(pxMin, true, !axis.horiz)), newMax = pick(fixedMax, axis.translate(pxMax, true, !axis.horiz));\n const fixedRange = chart && chart.fixedRange, halfPointRange = (axis.pointRange || 0) / 2;\n // Add/remove half point range to/from the extremes (#1172)\n if (!defined(fixedMin)) {\n newMin = correctFloat(newMin + halfPointRange);\n }\n if (!defined(fixedMax)) {\n newMax = correctFloat(newMax - halfPointRange);\n }\n // Make sure panning to the edges does not decrease the zoomed range\n if (fixedRange && axis.dataMin && axis.dataMax) {\n if (newMax >= axis.dataMax) {\n newMin = correctFloat(axis.dataMax - fixedRange);\n }\n if (newMin <= axis.dataMin) {\n newMax = correctFloat(axis.dataMin + fixedRange);\n }\n }\n if (!isNumber(newMin) || !isNumber(newMax)) { // #1195, #7411\n newMin = newMax = void 0;\n }\n return {\n min: newMin,\n max: newMax\n };\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return NavigatorAxisAdditions;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorDefaults.js', [_modules['Core/Color/Color.js'], _modules['Core/Series/SeriesRegistry.js']], function (Color, SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { seriesTypes } = SeriesRegistry;\n /* *\n *\n * Constants\n *\n * */\n /**\n * The navigator is a small series below the main series, displaying\n * a view of the entire data set. It provides tools to zoom in and\n * out on parts of the data as well as panning across the dataset.\n *\n * @product highstock gantt\n * @optionparent navigator\n */\n const NavigatorDefaults = {\n /**\n * Whether the navigator and scrollbar should adapt to updated data\n * in the base X axis. When loading data async, as in the demo below,\n * this should be `false`. Otherwise new data will trigger navigator\n * redraw, which will cause unwanted looping. In the demo below, the\n * data in the navigator is set only once. On navigating, only the main\n * chart content is updated.\n *\n * @sample {highstock} stock/demo/lazy-loading/\n * Set to false with async data loading\n *\n * @type {boolean}\n * @default true\n * @apioption navigator.adaptToUpdatedData\n */\n /**\n * An integer identifying the index to use for the base series, or a\n * string representing the id of the series.\n *\n * **Note**: As of Highcharts 5.0, this is now a deprecated option.\n * Prefer [series.showInNavigator](#plotOptions.series.showInNavigator).\n *\n * @see [series.showInNavigator](#plotOptions.series.showInNavigator)\n *\n * @deprecated\n * @type {number|string}\n * @default 0\n * @apioption navigator.baseSeries\n */\n /**\n * Enable or disable the navigator.\n *\n * @sample {highstock} stock/navigator/enabled/\n * Disable the navigator\n *\n * @type {boolean}\n * @default true\n * @apioption navigator.enabled\n */\n /**\n * When the chart is inverted, whether to draw the navigator on the\n * opposite side.\n *\n * @type {boolean}\n * @default false\n * @since 5.0.8\n * @apioption navigator.opposite\n */\n /**\n * The height of the navigator.\n *\n * @sample {highstock} stock/navigator/height/\n * A higher navigator\n */\n height: 40,\n /**\n * The distance from the nearest element, the X axis or X axis labels.\n *\n * @sample {highstock} stock/navigator/margin/\n * A margin of 2 draws the navigator closer to the X axis labels\n */\n margin: 25,\n /**\n * Whether the mask should be inside the range marking the zoomed\n * range, or outside. In Highcharts Stock 1.x it was always `false`.\n *\n * @sample {highstock} stock/navigator/maskinside-false/\n * False, mask outside\n *\n * @since 2.0\n */\n maskInside: true,\n /**\n * Options for the handles for dragging the zoomed area.\n *\n * @sample {highstock} stock/navigator/handles/\n * Colored handles\n */\n handles: {\n /**\n * Width for handles.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n */\n width: 7,\n /**\n * Height for handles.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n */\n height: 15,\n /**\n * Array to define shapes of handles. 0-index for left, 1-index for\n * right.\n *\n * Additionally, the URL to a graphic can be given on this form:\n * `url(graphic.png)`. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export\n * server.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols`. The callback is then\n * used by its method name, as shown in the demo.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @type {Array}\n * @default [\"navigator-handle\", \"navigator-handle\"]\n * @since 6.0.0\n */\n symbols: ['navigator-handle', 'navigator-handle'],\n /**\n * Allows to enable/disable handles.\n *\n * @since 6.0.0\n */\n enabled: true,\n /**\n * The width for the handle border and the stripes inside.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n * @apioption navigator.handles.lineWidth\n */\n lineWidth: 1,\n /**\n * The fill for the handle.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * The stroke for the handle border and the stripes inside.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#999999\" /* Palette.neutralColor40 */\n },\n /**\n * The color of the mask covering the areas of the navigator series\n * that are currently not visible in the main series. The default\n * color is bluish with an opacity of 0.3 to see the series below.\n *\n * @see In styled mode, the mask is styled with the\n * `.highcharts-navigator-mask` and\n * `.highcharts-navigator-mask-inside` classes.\n *\n * @sample {highstock} stock/navigator/maskfill/\n * Blue, semi transparent mask\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default rgba(102,133,194,0.3)\n */\n maskFill: color(\"#667aff\" /* Palette.highlightColor60 */).setOpacity(0.3).get(),\n /**\n * The color of the line marking the currently zoomed area in the\n * navigator.\n *\n * @sample {highstock} stock/navigator/outline/\n * 2px blue outline\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n */\n outlineColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The width of the line marking the currently zoomed area in the\n * navigator.\n *\n * @see In styled mode, the outline stroke width is set with the\n * `.highcharts-navigator-outline` class.\n *\n * @sample {highstock} stock/navigator/outline/\n * 2px blue outline\n *\n * @type {number}\n */\n outlineWidth: 1,\n /**\n * Options for the navigator series. Available options are the same\n * as any series, documented at [plotOptions](#plotOptions.series)\n * and [series](#series).\n *\n * Unless data is explicitly defined on navigator.series, the data\n * is borrowed from the first series in the chart.\n *\n * Default series options for the navigator series are:\n * ```js\n * series: {\n * type: 'areaspline',\n * fillOpacity: 0.05,\n * dataGrouping: {\n * smoothed: true\n * },\n * lineWidth: 1,\n * marker: {\n * enabled: false\n * }\n * }\n * ```\n *\n * @see In styled mode, the navigator series is styled with the\n * `.highcharts-navigator-series` class.\n *\n * @sample {highstock} stock/navigator/series-data/\n * Using a separate data set for the navigator\n * @sample {highstock} stock/navigator/series/\n * A green navigator series\n *\n * @type {*|Array<*>|Highcharts.SeriesOptionsType|Array}\n */\n series: {\n /**\n * The type of the navigator series.\n *\n * Heads up:\n * In column-type navigator, zooming is limited to at least one\n * point with its `pointRange`.\n *\n * @sample {highstock} stock/navigator/column/\n * Column type navigator\n *\n * @type {string}\n * @default {highstock} `areaspline` if defined, otherwise `line`\n * @default {gantt} gantt\n */\n type: (typeof seriesTypes.areaspline === 'undefined' ?\n 'line' :\n 'areaspline'),\n /**\n * The fill opacity of the navigator series.\n */\n fillOpacity: 0.05,\n /**\n * The pixel line width of the navigator series.\n */\n lineWidth: 1,\n /**\n * @ignore-option\n */\n compare: null,\n /**\n * @ignore-option\n */\n sonification: {\n enabled: false\n },\n /**\n * Unless data is explicitly defined, the data is borrowed from the\n * first series in the chart.\n *\n * @type {Array|object|null>}\n * @product highstock\n * @apioption navigator.series.data\n */\n /**\n * Data grouping options for the navigator series.\n *\n * @extends plotOptions.series.dataGrouping\n */\n dataGrouping: {\n approximation: 'average',\n enabled: true,\n groupPixelWidth: 2,\n // Replace smoothed property by anchors, #12455.\n firstAnchor: 'firstPoint',\n anchor: 'middle',\n lastAnchor: 'lastPoint',\n // Day and week differs from plotOptions.series.dataGrouping\n units: [\n ['millisecond', [1, 2, 5, 10, 20, 25, 50, 100, 200, 500]],\n ['second', [1, 2, 5, 10, 15, 30]],\n ['minute', [1, 2, 5, 10, 15, 30]],\n ['hour', [1, 2, 3, 4, 6, 8, 12]],\n ['day', [1, 2, 3, 4]],\n ['week', [1, 2, 3]],\n ['month', [1, 3, 6]],\n ['year', null]\n ]\n },\n /**\n * Data label options for the navigator series. Data labels are\n * disabled by default on the navigator series.\n *\n * @extends plotOptions.series.dataLabels\n */\n dataLabels: {\n enabled: false,\n zIndex: 2 // #1839\n },\n id: 'highcharts-navigator-series',\n className: 'highcharts-navigator-series',\n /**\n * Sets the fill color of the navigator series.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption navigator.series.color\n */\n /**\n * Line color for the navigator series. Allows setting the color\n * while disallowing the default candlestick setting.\n *\n * @type {Highcharts.ColorString|null}\n */\n lineColor: null,\n marker: {\n enabled: false\n },\n /**\n * Since Highcharts Stock v8, default value is the same as default\n * `pointRange` defined for a specific type (e.g. `null` for\n * column type).\n *\n * In Highcharts Stock version < 8, defaults to 0.\n *\n * @extends plotOptions.series.pointRange\n * @type {number|null}\n * @apioption navigator.series.pointRange\n */\n /**\n * The threshold option. Setting it to 0 will make the default\n * navigator area series draw its area from the 0 value and up.\n *\n * @type {number|null}\n */\n threshold: null\n },\n /**\n * Enable or disable navigator sticking to right, while adding new\n * points. If `undefined`, the navigator sticks to the axis maximum only\n * if it was already at the maximum prior to adding points.\n *\n * @type {boolean}\n * @default undefined\n * @since 10.2.1\n * @sample {highstock} stock/navigator/sticktomax-false/\n * stickToMax set to false\n * @apioption navigator.stickToMax\n */\n /**\n * Options for the navigator X axis. Default series options for the\n * navigator xAxis are:\n * ```js\n * xAxis: {\n * tickWidth: 0,\n * lineWidth: 0,\n * gridLineWidth: 1,\n * tickPixelInterval: 200,\n * labels: {\n * align: 'left',\n * style: {\n * color: '#888'\n * },\n * x: 3,\n * y: -4\n * }\n * }\n * ```\n *\n * @extends xAxis\n * @excluding linkedTo, maxZoom, minRange, opposite, range, scrollbar,\n * showEmpty, maxRange\n */\n xAxis: {\n /**\n * Additional range on the right side of the xAxis. Works similar to\n * xAxis.maxPadding, but value is set in milliseconds.\n * Can be set for both, main xAxis and navigator's xAxis.\n *\n * @since 6.0.0\n */\n overscroll: 0,\n className: 'highcharts-navigator-xaxis',\n tickLength: 0,\n lineWidth: 0,\n gridLineColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n gridLineWidth: 1,\n tickPixelInterval: 200,\n labels: {\n align: 'left',\n /**\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @ignore */\n color: \"#000000\" /* Palette.neutralColor100 */,\n /** @ignore */\n fontSize: '0.7em',\n /** @ignore */\n opacity: 0.6,\n /** @ignore */\n textOutline: '2px contrast'\n },\n x: 3,\n y: -4\n },\n crosshair: false\n },\n /**\n * Options for the navigator Y axis. Default series options for the\n * navigator yAxis are:\n * ```js\n * yAxis: {\n * gridLineWidth: 0,\n * startOnTick: false,\n * endOnTick: false,\n * minPadding: 0.1,\n * maxPadding: 0.1,\n * labels: {\n * enabled: false\n * },\n * title: {\n * text: null\n * },\n * tickWidth: 0\n * }\n * ```\n *\n * @extends yAxis\n * @excluding height, linkedTo, maxZoom, minRange, ordinal, range,\n * showEmpty, scrollbar, top, units, maxRange, minLength,\n * maxLength, resize\n */\n yAxis: {\n className: 'highcharts-navigator-yaxis',\n gridLineWidth: 0,\n startOnTick: false,\n endOnTick: false,\n minPadding: 0.1,\n maxPadding: 0.1,\n labels: {\n enabled: false\n },\n crosshair: false,\n title: {\n text: null\n },\n tickLength: 0,\n tickWidth: 0\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Maximum range which can be set using the navigator's handles.\n * Opposite of [xAxis.minRange](#xAxis.minRange).\n *\n * @sample {highstock} stock/navigator/maxrange/\n * Defined max and min range\n *\n * @type {number}\n * @since 6.0.0\n * @product highstock gantt\n * @apioption xAxis.maxRange\n */\n (''); // keeps doclets above in JS file\n\n return NavigatorDefaults;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorSymbols.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Draw one of the handles on the side of the zoomed range in the navigator.\n * @private\n */\n function navigatorHandle(_x, _y, width, height, options = {}) {\n const halfWidth = options.width ? options.width / 2 : width, markerPosition = Math.round(halfWidth / 3) + 0.5;\n height = options.height || height;\n return [\n ['M', -halfWidth - 1, 0.5],\n ['L', halfWidth, 0.5],\n ['L', halfWidth, height + 0.5],\n ['L', -halfWidth - 1, height + 0.5],\n ['L', -halfWidth - 1, 0.5],\n ['M', -markerPosition, 4],\n ['L', -markerPosition, height - 3],\n ['M', markerPosition - 1, 4],\n ['L', markerPosition - 1, height - 3]\n ];\n }\n /* *\n *\n * Default Export\n *\n * */\n const NavigatorSymbols = {\n 'navigator-handle': navigatorHandle\n };\n\n return NavigatorSymbols;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorComposition.js', [_modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/NavigatorAxisComposition.js'], _modules['Stock/Navigator/NavigatorDefaults.js'], _modules['Stock/Navigator/NavigatorSymbols.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (D, H, NavigatorAxisAdditions, NavigatorDefaults, NavigatorSymbols, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions, setOptions } = D;\n const { isTouchDevice } = H;\n const { getRendererType } = RendererRegistry;\n const { addEvent, extend, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let NavigatorConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AxisClass, ChartClass, NavigatorClass, SeriesClass) {\n NavigatorAxisAdditions.compose(AxisClass);\n NavigatorConstructor = NavigatorClass;\n if (U.pushUnique(composedMembers, ChartClass)) {\n const chartProto = ChartClass.prototype;\n chartProto.callbacks.push(onChartCallback);\n addEvent(ChartClass, 'afterAddSeries', onChartAfterAddSeries);\n addEvent(ChartClass, 'afterSetChartSize', onChartAfterSetChartSize);\n addEvent(ChartClass, 'afterUpdate', onChartAfterUpdate);\n addEvent(ChartClass, 'beforeRender', onChartBeforeRender);\n addEvent(ChartClass, 'beforeShowResetZoom', onChartBeforeShowResetZoom);\n addEvent(ChartClass, 'update', onChartUpdate);\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'afterUpdate', onSeriesAfterUpdate);\n }\n if (U.pushUnique(composedMembers, getRendererType)) {\n extend(getRendererType().prototype.symbols, NavigatorSymbols);\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n extend(defaultOptions, { navigator: NavigatorDefaults });\n }\n }\n /**\n * Handle adding new series.\n * @private\n */\n function onChartAfterAddSeries() {\n if (this.navigator) {\n // Recompute which series should be shown in navigator, and add them\n this.navigator.setBaseSeries(null, false);\n }\n }\n /**\n * For stock charts, extend the Chart.setChartSize method so that we can set the\n * final top position of the navigator once the height of the chart, including\n * the legend, is determined. #367. We can't use Chart.getMargins, because\n * labels offsets are not calculated yet.\n * @private\n */\n function onChartAfterSetChartSize() {\n var _a;\n const legend = this.legend, navigator = this.navigator;\n let legendOptions, xAxis, yAxis;\n if (navigator) {\n legendOptions = legend && legend.options;\n xAxis = navigator.xAxis;\n yAxis = navigator.yAxis;\n const { scrollbarHeight, scrollButtonSize } = navigator;\n // Compute the top position\n if (this.inverted) {\n navigator.left = navigator.opposite ?\n this.chartWidth - scrollbarHeight -\n navigator.height :\n this.spacing[3] + scrollbarHeight;\n navigator.top = this.plotTop + scrollButtonSize;\n }\n else {\n navigator.left = pick(xAxis.left, this.plotLeft + scrollButtonSize);\n navigator.top = navigator.navigatorOptions.top ||\n this.chartHeight -\n navigator.height -\n scrollbarHeight -\n (((_a = this.scrollbar) === null || _a === void 0 ? void 0 : _a.options.margin) || 0) -\n this.spacing[2] -\n (this.rangeSelector && this.extraBottomMargin ?\n this.rangeSelector.getHeight() :\n 0) -\n ((legendOptions &&\n legendOptions.verticalAlign === 'bottom' &&\n legendOptions.layout !== 'proximate' && // #13392\n legendOptions.enabled &&\n !legendOptions.floating) ?\n legend.legendHeight +\n pick(legendOptions.margin, 10) :\n 0) -\n (this.titleOffset ? this.titleOffset[2] : 0);\n }\n if (xAxis && yAxis) { // false if navigator is disabled (#904)\n if (this.inverted) {\n xAxis.options.left = yAxis.options.left = navigator.left;\n }\n else {\n xAxis.options.top = yAxis.options.top = navigator.top;\n }\n xAxis.setAxisSize();\n yAxis.setAxisSize();\n }\n }\n }\n /**\n * Initialize navigator, if no scrolling exists yet.\n * @private\n */\n function onChartAfterUpdate(event) {\n if (!this.navigator && !this.scroller &&\n (this.options.navigator.enabled ||\n this.options.scrollbar.enabled)) {\n this.scroller = this.navigator = new NavigatorConstructor(this);\n if (pick(event.redraw, true)) {\n this.redraw(event.animation); // #7067\n }\n }\n }\n /**\n * Initialize navigator for stock charts\n * @private\n */\n function onChartBeforeRender() {\n const options = this.options;\n if (options.navigator.enabled ||\n options.scrollbar.enabled) {\n this.scroller = this.navigator = new NavigatorConstructor(this);\n }\n }\n /**\n * For Stock charts. For x only zooming, do not to create the zoom button\n * because X axis zooming is already allowed by the Navigator and Range\n * selector. (#9285)\n * @private\n */\n function onChartBeforeShowResetZoom() {\n const chartOptions = this.options, navigator = chartOptions.navigator, rangeSelector = chartOptions.rangeSelector;\n if (((navigator && navigator.enabled) ||\n (rangeSelector && rangeSelector.enabled)) &&\n ((!isTouchDevice &&\n this.zooming.type === 'x') ||\n (isTouchDevice && this.zooming.pinchType === 'x'))) {\n return false;\n }\n }\n /**\n * @private\n */\n function onChartCallback(chart) {\n const navigator = chart.navigator;\n // Initialize the navigator\n if (navigator && chart.xAxis[0]) {\n const extremes = chart.xAxis[0].getExtremes();\n navigator.render(extremes.min, extremes.max);\n }\n }\n /**\n * Merge options, if no scrolling exists yet\n * @private\n */\n function onChartUpdate(e) {\n const navigatorOptions = (e.options.navigator || {}), scrollbarOptions = (e.options.scrollbar || {});\n if (!this.navigator && !this.scroller &&\n (navigatorOptions.enabled || scrollbarOptions.enabled)) {\n merge(true, this.options.navigator, navigatorOptions);\n merge(true, this.options.scrollbar, scrollbarOptions);\n delete e.options.navigator;\n delete e.options.scrollbar;\n }\n }\n /**\n * Handle updating series\n * @private\n */\n function onSeriesAfterUpdate() {\n if (this.chart.navigator && !this.options.isInternal) {\n this.chart.navigator.setBaseSeries(null, false);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const NavigatorComposition = {\n compose\n };\n\n return NavigatorComposition;\n });\n _registerModule(_modules, 'Core/Axis/ScrollbarAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, defined, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Creates scrollbars if enabled.\n * @private\n */\n class ScrollbarAxis {\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * Attaches to axis events to create scrollbars if enabled.\n *\n * @private\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param ScrollbarClass\n * Scrollbar class to use.\n */\n static compose(AxisClass, ScrollbarClass) {\n if (!U.pushUnique(composedMembers, AxisClass)) {\n return AxisClass;\n }\n const getExtremes = (axis) => {\n const axisMin = pick(axis.options && axis.options.min, axis.min);\n const axisMax = pick(axis.options && axis.options.max, axis.max);\n return {\n axisMin,\n axisMax,\n scrollMin: defined(axis.dataMin) ?\n Math.min(axisMin, axis.min, axis.dataMin, pick(axis.threshold, Infinity)) : axisMin,\n scrollMax: defined(axis.dataMax) ?\n Math.max(axisMax, axis.max, axis.dataMax, pick(axis.threshold, -Infinity)) : axisMax\n };\n };\n // Wrap axis initialization and create scrollbar if enabled:\n addEvent(AxisClass, 'afterInit', function () {\n const axis = this;\n if (axis.options &&\n axis.options.scrollbar &&\n axis.options.scrollbar.enabled) {\n // Predefined options:\n axis.options.scrollbar.vertical = !axis.horiz;\n axis.options.startOnTick = axis.options.endOnTick = false;\n axis.scrollbar = new ScrollbarClass(axis.chart.renderer, axis.options.scrollbar, axis.chart);\n addEvent(axis.scrollbar, 'changed', function (e) {\n let { axisMin, axisMax, scrollMin: unitedMin, scrollMax: unitedMax } = getExtremes(axis), range = unitedMax - unitedMin, to, from;\n // #12834, scroll when show/hide series, wrong extremes\n if (!defined(axisMin) || !defined(axisMax)) {\n return;\n }\n if ((axis.horiz && !axis.reversed) ||\n (!axis.horiz && axis.reversed)) {\n to = unitedMin + range * this.to;\n from = unitedMin + range * this.from;\n }\n else {\n // y-values in browser are reversed, but this also\n // applies for reversed horizontal axis:\n to = unitedMin + range * (1 - this.from);\n from = unitedMin + range * (1 - this.to);\n }\n if (this.shouldUpdateExtremes(e.DOMType)) {\n // #17977, set animation to undefined instead of true\n const animate = e.DOMType === 'mousemove' ||\n e.DOMType === 'touchmove' ? false : void 0;\n axis.setExtremes(from, to, true, animate, e);\n }\n else {\n // When live redraw is disabled, don't change extremes\n // Only change the position of the scollbar thumb\n this.setRange(this.from, this.to);\n }\n });\n }\n });\n // Wrap rendering axis, and update scrollbar if one is created:\n addEvent(AxisClass, 'afterRender', function () {\n let axis = this, { scrollMin, scrollMax } = getExtremes(axis), scrollbar = axis.scrollbar, offset = (axis.axisTitleMargin + (axis.titleOffset || 0)), scrollbarsOffsets = axis.chart.scrollbarsOffsets, axisMargin = axis.options.margin || 0, offsetsIndex, from, to;\n if (scrollbar) {\n if (axis.horiz) {\n // Reserve space for labels/title\n if (!axis.opposite) {\n scrollbarsOffsets[1] += offset;\n }\n scrollbar.position(axis.left, (axis.top +\n axis.height +\n 2 +\n scrollbarsOffsets[1] -\n (axis.opposite ? axisMargin : 0)), axis.width, axis.height);\n // Next scrollbar should reserve space for margin (if set)\n if (!axis.opposite) {\n scrollbarsOffsets[1] += axisMargin;\n }\n offsetsIndex = 1;\n }\n else {\n // Reserve space for labels/title\n if (axis.opposite) {\n scrollbarsOffsets[0] += offset;\n }\n let xPosition;\n if (!scrollbar.options.opposite) {\n xPosition = axis.opposite ? 0 : axisMargin;\n }\n else {\n xPosition = axis.left +\n axis.width +\n 2 +\n scrollbarsOffsets[0] -\n (axis.opposite ? 0 : axisMargin);\n }\n scrollbar.position(xPosition, axis.top, axis.width, axis.height);\n // Next scrollbar should reserve space for margin (if set)\n if (axis.opposite) {\n scrollbarsOffsets[0] += axisMargin;\n }\n offsetsIndex = 0;\n }\n scrollbarsOffsets[offsetsIndex] += scrollbar.size +\n (scrollbar.options.margin || 0);\n if (isNaN(scrollMin) ||\n isNaN(scrollMax) ||\n !defined(axis.min) ||\n !defined(axis.max) ||\n axis.min === axis.max // #10733\n ) {\n // default action: when extremes are the same or there is\n // not extremes on the axis, but scrollbar exists, make it\n // full size\n scrollbar.setRange(0, 1);\n }\n else {\n from = ((axis.min - scrollMin) /\n (scrollMax - scrollMin));\n to = ((axis.max - scrollMin) /\n (scrollMax - scrollMin));\n if ((axis.horiz && !axis.reversed) ||\n (!axis.horiz && axis.reversed)) {\n scrollbar.setRange(from, to);\n }\n else {\n // inverse vertical axis\n scrollbar.setRange(1 - to, 1 - from);\n }\n }\n }\n });\n // Make space for a scrollbar:\n addEvent(AxisClass, 'afterGetOffset', function () {\n const axis = this, scrollbar = axis.scrollbar, opposite = scrollbar && !scrollbar.options.opposite, index = axis.horiz ? 2 : opposite ? 3 : 1;\n if (scrollbar) {\n // reset scrollbars offsets\n axis.chart.scrollbarsOffsets = [0, 0];\n axis.chart.axisOffset[index] +=\n scrollbar.size + (scrollbar.options.margin || 0);\n }\n });\n return AxisClass;\n }\n }\n\n return ScrollbarAxis;\n });\n _registerModule(_modules, 'Stock/Scrollbar/ScrollbarDefaults.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isTouchDevice } = H;\n /* *\n *\n * Constant\n *\n * */\n /**\n *\n * The scrollbar is a means of panning over the X axis of a stock chart.\n * Scrollbars can also be applied to other types of axes.\n *\n * Another approach to scrollable charts is the [chart.scrollablePlotArea](\n * https://api.highcharts.com/highcharts/chart.scrollablePlotArea) option that\n * is especially suitable for simpler cartesian charts on mobile.\n *\n * In styled mode, all the presentational options for the\n * scrollbar are replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample stock/yaxis/inverted-bar-scrollbar/\n * A scrollbar on a simple bar chart\n *\n * @product highstock gantt\n * @optionparent scrollbar\n *\n * @private\n */\n const ScrollbarDefaults = {\n /**\n * The height of the scrollbar. If `buttonsEnabled` is true , the height\n * also applies to the width of the scroll arrows so that they are always\n * squares.\n *\n * @sample stock/scrollbar/style/\n * Non-default height\n *\n * @type {number}\n */\n height: 10,\n /**\n * The border rounding radius of the bar.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n barBorderRadius: 5,\n /**\n * The corner radius of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n buttonBorderRadius: 0,\n /**\n * Enable or disable the buttons at the end of the scrollbar.\n *\n * @since 11.0.0\n */\n buttonsEnabled: false,\n /**\n * Enable or disable the scrollbar.\n *\n * @sample stock/scrollbar/enabled/\n * Disable the scrollbar, only use navigator\n *\n * @type {boolean}\n * @default true\n * @apioption scrollbar.enabled\n */\n /**\n * Whether to redraw the main chart as the scrollbar or the navigator\n * zoomed window is moved. Defaults to `true` for modern browsers and\n * `false` for legacy IE browsers as well as mobile devices.\n *\n * @sample stock/scrollbar/liveredraw\n * Setting live redraw to false\n *\n * @type {boolean}\n * @since 1.3\n */\n liveRedraw: void 0,\n /**\n * The margin between the scrollbar and its axis when the scrollbar is\n * applied directly to an axis, or the navigator in case that is enabled.\n * Defaults to 10 for axis, 0 for navigator.\n *\n * @type {number|undefined}\n */\n margin: void 0,\n /**\n * The minimum width of the scrollbar.\n *\n * @since 1.2.5\n */\n minWidth: 6,\n /** @ignore-option */\n opposite: true,\n /**\n * Whether to show or hide the scrollbar when the scrolled content is\n * zoomed out to it full extent.\n *\n * @type {boolean}\n * @default true\n * @apioption scrollbar.showFull\n */\n step: 0.2,\n /**\n * The z index of the scrollbar group.\n */\n zIndex: 3,\n /**\n * The background color of the scrollbar itself.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n barBackgroundColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The width of the bar's border.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n barBorderWidth: 0,\n /**\n * The color of the scrollbar's border.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n barBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The color of the small arrow inside the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonArrowColor: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * The color of scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonBackgroundColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n /**\n * The color of the border of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The border width of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n buttonBorderWidth: 1,\n /**\n * The color of the small rifles in the middle of the scrollbar.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n rifleColor: 'none',\n /**\n * The color of the track background.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n trackBackgroundColor: 'rgba(255, 255, 255, 0.001)',\n /**\n * The color of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n trackBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The corner radius of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n trackBorderRadius: 5,\n /**\n * The width of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n trackBorderWidth: 1\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ScrollbarDefaults;\n });\n _registerModule(_modules, 'Stock/Scrollbar/Scrollbar.js', [_modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/ScrollbarAxis.js'], _modules['Stock/Scrollbar/ScrollbarDefaults.js'], _modules['Core/Utilities.js']], function (D, H, ScrollbarAxis, ScrollbarDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { addEvent, correctFloat, defined, destroyObjectProperties, fireEvent, merge, pick, removeEvent } = U;\n /* *\n *\n * Constants\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * A reusable scrollbar, internally used in Highcharts Stock's\n * navigator and optionally on individual axes.\n *\n * @private\n * @class\n * @name Highcharts.Scrollbar\n * @param {Highcharts.SVGRenderer} renderer\n * @param {Highcharts.ScrollbarOptions} options\n * @param {Highcharts.Chart} chart\n */\n class Scrollbar {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AxisClass) {\n ScrollbarAxis.compose(AxisClass, Scrollbar);\n }\n /**\n * When we have vertical scrollbar, rifles and arrow in buttons should be\n * rotated. The same method is used in Navigator's handles, to rotate them.\n *\n * @function Highcharts.swapXY\n *\n * @param {Highcharts.SVGPathArray} path\n * Path to be rotated.\n *\n * @param {boolean} [vertical]\n * If vertical scrollbar, swap x-y values.\n *\n * @return {Highcharts.SVGPathArray}\n * Rotated path.\n *\n * @requires modules/stock\n */\n static swapXY(path, vertical) {\n if (vertical) {\n path.forEach((seg) => {\n const len = seg.length;\n let temp;\n for (let i = 0; i < len; i += 2) {\n temp = seg[i + 1];\n if (typeof temp === 'number') {\n seg[i + 1] = seg[i + 2];\n seg[i + 2] = temp;\n }\n }\n });\n }\n return path;\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(renderer, options, chart) {\n /* *\n *\n * Properties\n *\n * */\n this._events = [];\n this.chart = void 0;\n this.chartX = 0;\n this.chartY = 0;\n this.from = 0;\n this.group = void 0;\n this.options = void 0;\n this.renderer = void 0;\n this.scrollbar = void 0;\n this.scrollbarButtons = [];\n this.scrollbarGroup = void 0;\n this.scrollbarLeft = 0;\n this.scrollbarRifles = void 0;\n this.scrollbarStrokeWidth = 1;\n this.scrollbarTop = 0;\n this.size = 0;\n this.to = 0;\n this.track = void 0;\n this.trackBorderWidth = 1;\n this.userOptions = void 0;\n this.x = 0;\n this.y = 0;\n this.init(renderer, options, chart);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set up the mouse and touch events for the Scrollbar\n *\n * @private\n * @function Highcharts.Scrollbar#addEvents\n */\n addEvents() {\n const buttonsOrder = this.options.inverted ? [1, 0] : [0, 1], buttons = this.scrollbarButtons, bar = this.scrollbarGroup.element, track = this.track.element, mouseDownHandler = this.mouseDownHandler.bind(this), mouseMoveHandler = this.mouseMoveHandler.bind(this), mouseUpHandler = this.mouseUpHandler.bind(this);\n // Mouse events\n const _events = [\n [\n buttons[buttonsOrder[0]].element,\n 'click',\n this.buttonToMinClick.bind(this)\n ],\n [\n buttons[buttonsOrder[1]].element,\n 'click',\n this.buttonToMaxClick.bind(this)\n ],\n [track, 'click', this.trackClick.bind(this)],\n [bar, 'mousedown', mouseDownHandler],\n [bar.ownerDocument, 'mousemove', mouseMoveHandler],\n [bar.ownerDocument, 'mouseup', mouseUpHandler]\n ];\n // Touch events\n if (H.hasTouch) {\n _events.push([bar, 'touchstart', mouseDownHandler], [bar.ownerDocument, 'touchmove', mouseMoveHandler], [bar.ownerDocument, 'touchend', mouseUpHandler]);\n }\n // Add them all\n _events.forEach(function (args) {\n addEvent.apply(null, args);\n });\n this._events = _events;\n }\n buttonToMaxClick(e) {\n const scroller = this;\n const range = ((scroller.to - scroller.from) *\n pick(scroller.options.step, 0.2));\n scroller.updatePosition(scroller.from + range, scroller.to + range);\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n }\n buttonToMinClick(e) {\n const scroller = this;\n const range = correctFloat(scroller.to - scroller.from) *\n pick(scroller.options.step, 0.2);\n scroller.updatePosition(correctFloat(scroller.from - range), correctFloat(scroller.to - range));\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n }\n /**\n * Get normalized (0-1) cursor position over the scrollbar\n *\n * @private\n * @function Highcharts.Scrollbar#cursorToScrollbarPosition\n *\n * @param {*} normalizedEvent\n * normalized event, with chartX and chartY values\n *\n * @return {Highcharts.Dictionary}\n * Local position {chartX, chartY}\n */\n cursorToScrollbarPosition(normalizedEvent) {\n const scroller = this, options = scroller.options, minWidthDifference = options.minWidth > scroller.calculatedWidth ?\n options.minWidth :\n 0; // minWidth distorts translation\n return {\n chartX: (normalizedEvent.chartX - scroller.x -\n scroller.xOffset) /\n (scroller.barWidth - minWidthDifference),\n chartY: (normalizedEvent.chartY - scroller.y -\n scroller.yOffset) /\n (scroller.barWidth - minWidthDifference)\n };\n }\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.Scrollbar#destroy\n */\n destroy() {\n const scroller = this, navigator = scroller.chart.scroller;\n // Disconnect events added in addEvents\n scroller.removeEvents();\n // Destroy properties\n [\n 'track',\n 'scrollbarRifles',\n 'scrollbar',\n 'scrollbarGroup',\n 'group'\n ].forEach(function (prop) {\n if (scroller[prop] && scroller[prop].destroy) {\n scroller[prop] = scroller[prop].destroy();\n }\n });\n // #6421, chart may have more scrollbars\n if (navigator && scroller === navigator.scrollbar) {\n navigator.scrollbar = null;\n // Destroy elements in collection\n destroyObjectProperties(navigator.scrollbarButtons);\n }\n }\n /**\n * Draw the scrollbar buttons with arrows\n *\n * @private\n * @function Highcharts.Scrollbar#drawScrollbarButton\n * @param {number} index\n * 0 is left, 1 is right\n */\n drawScrollbarButton(index) {\n const scroller = this, renderer = scroller.renderer, scrollbarButtons = scroller.scrollbarButtons, options = scroller.options, size = scroller.size, group = renderer.g().add(scroller.group);\n scrollbarButtons.push(group);\n if (options.buttonsEnabled) {\n // Create a rectangle for the scrollbar button\n const rect = renderer.rect()\n .addClass('highcharts-scrollbar-button')\n .add(group);\n // Presentational attributes\n if (!scroller.chart.styledMode) {\n rect.attr({\n stroke: options.buttonBorderColor,\n 'stroke-width': options.buttonBorderWidth,\n fill: options.buttonBackgroundColor\n });\n }\n // Place the rectangle based on the rendered stroke width\n rect.attr(rect.crisp({\n x: -0.5,\n y: -0.5,\n // +1 to compensate for crispifying in rect method\n width: size + 1,\n height: size + 1,\n r: options.buttonBorderRadius\n }, rect.strokeWidth()));\n // Button arrow\n const arrow = renderer\n .path(Scrollbar.swapXY([[\n 'M',\n size / 2 + (index ? -1 : 1),\n size / 2 - 3\n ], [\n 'L',\n size / 2 + (index ? -1 : 1),\n size / 2 + 3\n ], [\n 'L',\n size / 2 + (index ? 2 : -2),\n size / 2\n ]], options.vertical))\n .addClass('highcharts-scrollbar-arrow')\n .add(scrollbarButtons[index]);\n if (!scroller.chart.styledMode) {\n arrow.attr({\n fill: options.buttonArrowColor\n });\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Scrollbar#init\n * @param {Highcharts.SVGRenderer} renderer\n * @param {Highcharts.ScrollbarOptions} options\n * @param {Highcharts.Chart} chart\n */\n init(renderer, options, chart) {\n const scroller = this;\n scroller.scrollbarButtons = [];\n scroller.renderer = renderer;\n scroller.userOptions = options;\n scroller.options = merge(ScrollbarDefaults, defaultOptions.scrollbar, options);\n scroller.options.margin = pick(scroller.options.margin, 10);\n scroller.chart = chart;\n // backward compatibility\n scroller.size = pick(scroller.options.size, scroller.options.height);\n // Init\n if (options.enabled) {\n scroller.render();\n scroller.addEvents();\n }\n }\n mouseDownHandler(e) {\n const scroller = this, normalizedEvent = scroller.chart.pointer.normalize(e), mousePosition = scroller.cursorToScrollbarPosition(normalizedEvent);\n scroller.chartX = mousePosition.chartX;\n scroller.chartY = mousePosition.chartY;\n scroller.initPositions = [scroller.from, scroller.to];\n scroller.grabbedCenter = true;\n }\n /**\n * Event handler for the mouse move event.\n * @private\n */\n mouseMoveHandler(e) {\n const scroller = this, normalizedEvent = scroller.chart.pointer.normalize(e), options = scroller.options, direction = options.vertical ?\n 'chartY' : 'chartX', initPositions = scroller.initPositions || [];\n let scrollPosition, chartPosition, change;\n // In iOS, a mousemove event with e.pageX === 0 is fired when\n // holding the finger down in the center of the scrollbar. This\n // should be ignored.\n if (scroller.grabbedCenter &&\n // #4696, scrollbar failed on Android\n (!e.touches || e.touches[0][direction] !== 0)) {\n chartPosition = scroller.cursorToScrollbarPosition(normalizedEvent)[direction];\n scrollPosition = scroller[direction];\n change = chartPosition - scrollPosition;\n scroller.hasDragged = true;\n scroller.updatePosition(initPositions[0] + change, initPositions[1] + change);\n if (scroller.hasDragged) {\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMType: e.type,\n DOMEvent: e\n });\n }\n }\n }\n /**\n * Event handler for the mouse up event.\n * @private\n */\n mouseUpHandler(e) {\n const scroller = this;\n if (scroller.hasDragged) {\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMType: e.type,\n DOMEvent: e\n });\n }\n scroller.grabbedCenter =\n scroller.hasDragged =\n scroller.chartX =\n scroller.chartY = null;\n }\n /**\n * Position the scrollbar, method called from a parent with defined\n * dimensions.\n *\n * @private\n * @function Highcharts.Scrollbar#position\n * @param {number} x\n * x-position on the chart\n * @param {number} y\n * y-position on the chart\n * @param {number} width\n * width of the scrollbar\n * @param {number} height\n * height of the scorllbar\n */\n position(x, y, width, height) {\n const scroller = this, options = scroller.options, { buttonsEnabled, margin = 0, vertical } = options, method = scroller.rendered ? 'animate' : 'attr';\n let xOffset = height, yOffset = 0;\n // Make the scrollbar visible when it is repositioned, #15763.\n scroller.group.show();\n scroller.x = x;\n scroller.y = y + this.trackBorderWidth;\n scroller.width = width; // width with buttons\n scroller.height = height;\n scroller.xOffset = xOffset;\n scroller.yOffset = yOffset;\n // If Scrollbar is a vertical type, swap options:\n if (vertical) {\n scroller.width = scroller.yOffset = width = yOffset = scroller.size;\n scroller.xOffset = xOffset = 0;\n scroller.yOffset = yOffset = buttonsEnabled ? scroller.size : 0;\n // width without buttons\n scroller.barWidth = height - (buttonsEnabled ? width * 2 : 0);\n scroller.x = x = x + margin;\n }\n else {\n scroller.height = height = scroller.size;\n scroller.xOffset = xOffset = buttonsEnabled ? scroller.size : 0;\n // width without buttons\n scroller.barWidth = width - (buttonsEnabled ? height * 2 : 0);\n scroller.y = scroller.y + margin;\n }\n // Set general position for a group:\n scroller.group[method]({\n translateX: x,\n translateY: scroller.y\n });\n // Resize background/track:\n scroller.track[method]({\n width: width,\n height: height\n });\n // Move right/bottom button to its place:\n scroller.scrollbarButtons[1][method]({\n translateX: vertical ? 0 : width - xOffset,\n translateY: vertical ? height - yOffset : 0\n });\n }\n /**\n * Removes the event handlers attached previously with addEvents.\n *\n * @private\n * @function Highcharts.Scrollbar#removeEvents\n */\n removeEvents() {\n this._events.forEach(function (args) {\n removeEvent.apply(null, args);\n });\n this._events.length = 0;\n }\n /**\n * Render scrollbar with all required items.\n *\n * @private\n * @function Highcharts.Scrollbar#render\n */\n render() {\n const scroller = this, renderer = scroller.renderer, options = scroller.options, size = scroller.size, styledMode = scroller.chart.styledMode, group = renderer.g('scrollbar')\n .attr({\n zIndex: options.zIndex\n })\n .hide() // initially hide the scrollbar #15863\n .add();\n // Draw the scrollbar group\n scroller.group = group;\n // Draw the scrollbar track:\n scroller.track = renderer.rect()\n .addClass('highcharts-scrollbar-track')\n .attr({\n r: options.trackBorderRadius || 0,\n height: size,\n width: size\n }).add(group);\n if (!styledMode) {\n scroller.track.attr({\n fill: options.trackBackgroundColor,\n stroke: options.trackBorderColor,\n 'stroke-width': options.trackBorderWidth\n });\n }\n const trackBorderWidth = scroller.trackBorderWidth =\n scroller.track.strokeWidth();\n scroller.track.attr({\n x: -trackBorderWidth % 2 / 2,\n y: -trackBorderWidth % 2 / 2\n });\n // Draw the scrollbar itself\n scroller.scrollbarGroup = renderer.g().add(group);\n scroller.scrollbar = renderer.rect()\n .addClass('highcharts-scrollbar-thumb')\n .attr({\n height: size - trackBorderWidth,\n width: size - trackBorderWidth,\n r: options.barBorderRadius || 0\n }).add(scroller.scrollbarGroup);\n scroller.scrollbarRifles = renderer\n .path(Scrollbar.swapXY([\n ['M', -3, size / 4],\n ['L', -3, 2 * size / 3],\n ['M', 0, size / 4],\n ['L', 0, 2 * size / 3],\n ['M', 3, size / 4],\n ['L', 3, 2 * size / 3]\n ], options.vertical))\n .addClass('highcharts-scrollbar-rifles')\n .add(scroller.scrollbarGroup);\n if (!styledMode) {\n scroller.scrollbar.attr({\n fill: options.barBackgroundColor,\n stroke: options.barBorderColor,\n 'stroke-width': options.barBorderWidth\n });\n scroller.scrollbarRifles.attr({\n stroke: options.rifleColor,\n 'stroke-width': 1\n });\n }\n scroller.scrollbarStrokeWidth = scroller.scrollbar.strokeWidth();\n scroller.scrollbarGroup.translate(-scroller.scrollbarStrokeWidth % 2 / 2, -scroller.scrollbarStrokeWidth % 2 / 2);\n // Draw the buttons:\n scroller.drawScrollbarButton(0);\n scroller.drawScrollbarButton(1);\n }\n /**\n * Set scrollbar size, with a given scale.\n *\n * @private\n * @function Highcharts.Scrollbar#setRange\n * @param {number} from\n * scale (0-1) where bar should start\n * @param {number} to\n * scale (0-1) where bar should end\n */\n setRange(from, to) {\n const scroller = this, options = scroller.options, vertical = options.vertical, minWidth = options.minWidth, fullWidth = scroller.barWidth, method = (this.rendered &&\n !this.hasDragged &&\n !(this.chart.navigator && this.chart.navigator.hasDragged)) ? 'animate' : 'attr';\n if (!defined(fullWidth)) {\n return;\n }\n const toPX = fullWidth * Math.min(to, 1);\n let fromPX, newSize;\n from = Math.max(from, 0);\n fromPX = Math.ceil(fullWidth * from);\n scroller.calculatedWidth = newSize = correctFloat(toPX - fromPX);\n // We need to recalculate position, if minWidth is used\n if (newSize < minWidth) {\n fromPX = (fullWidth - minWidth + newSize) * from;\n newSize = minWidth;\n }\n const newPos = Math.floor(fromPX + scroller.xOffset + scroller.yOffset);\n const newRiflesPos = newSize / 2 - 0.5; // -0.5 -> rifle line width / 2\n // Store current position:\n scroller.from = from;\n scroller.to = to;\n if (!vertical) {\n scroller.scrollbarGroup[method]({\n translateX: newPos\n });\n scroller.scrollbar[method]({\n width: newSize\n });\n scroller.scrollbarRifles[method]({\n translateX: newRiflesPos\n });\n scroller.scrollbarLeft = newPos;\n scroller.scrollbarTop = 0;\n }\n else {\n scroller.scrollbarGroup[method]({\n translateY: newPos\n });\n scroller.scrollbar[method]({\n height: newSize\n });\n scroller.scrollbarRifles[method]({\n translateY: newRiflesPos\n });\n scroller.scrollbarTop = newPos;\n scroller.scrollbarLeft = 0;\n }\n if (newSize <= 12) {\n scroller.scrollbarRifles.hide();\n }\n else {\n scroller.scrollbarRifles.show();\n }\n // Show or hide the scrollbar based on the showFull setting\n if (options.showFull === false) {\n if (from <= 0 && to >= 1) {\n scroller.group.hide();\n }\n else {\n scroller.group.show();\n }\n }\n scroller.rendered = true;\n }\n /**\n * Checks if the extremes should be updated in response to a scrollbar\n * change event.\n *\n * @private\n * @function Highcharts.Scrollbar#shouldUpdateExtremes\n */\n shouldUpdateExtremes(eventType) {\n return (pick(this.options.liveRedraw, H.svg &&\n !H.isTouchDevice &&\n !this.chart.boosted) ||\n // Mouseup always should change extremes\n eventType === 'mouseup' ||\n eventType === 'touchend' ||\n // Internal events\n !defined(eventType));\n }\n trackClick(e) {\n const scroller = this;\n const normalizedEvent = scroller.chart.pointer.normalize(e), range = scroller.to - scroller.from, top = scroller.y + scroller.scrollbarTop, left = scroller.x + scroller.scrollbarLeft;\n if ((scroller.options.vertical && normalizedEvent.chartY > top) ||\n (!scroller.options.vertical && normalizedEvent.chartX > left)) {\n // On the top or on the left side of the track:\n scroller.updatePosition(scroller.from + range, scroller.to + range);\n }\n else {\n // On the bottom or the right side of the track:\n scroller.updatePosition(scroller.from - range, scroller.to - range);\n }\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n }\n /**\n * Update the scrollbar with new options\n *\n * @private\n * @function Highcharts.Scrollbar#update\n * @param {Highcharts.ScrollbarOptions} options\n */\n update(options) {\n this.destroy();\n this.init(this.chart.renderer, merge(true, this.options, options), this.chart);\n }\n /**\n * Update position option in the Scrollbar, with normalized 0-1 scale\n *\n * @private\n * @function Highcharts.Scrollbar#updatePosition\n * @param {number} from\n * @param {number} to\n */\n updatePosition(from, to) {\n if (to > 1) {\n from = correctFloat(1 - correctFloat(to - from));\n to = 1;\n }\n if (from < 0) {\n to = correctFloat(to - from);\n from = 0;\n }\n this.from = from;\n this.to = to;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Scrollbar.defaultOptions = ScrollbarDefaults;\n /* *\n *\n * Registry\n *\n * */\n defaultOptions.scrollbar = merge(true, Scrollbar.defaultOptions, defaultOptions.scrollbar);\n /* *\n *\n * Default Export\n *\n * */\n\n return Scrollbar;\n });\n _registerModule(_modules, 'Stock/Navigator/Navigator.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/NavigatorAxisComposition.js'], _modules['Stock/Navigator/NavigatorComposition.js'], _modules['Stock/Scrollbar/Scrollbar.js'], _modules['Core/Utilities.js']], function (Axis, D, H, NavigatorAxisAdditions, NavigatorComposition, Scrollbar, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { hasTouch, isTouchDevice } = H;\n const { addEvent, clamp, correctFloat, defined, destroyObjectProperties, erase, extend, find, isArray, isNumber, merge, pick, removeEvent, splat } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Finding the min or max of a set of variables where we don't know if they are\n * defined, is a pattern that is repeated several places in Highcharts. Consider\n * making this a global utility method.\n * @private\n */\n function numExt(extreme, ...args) {\n const numbers = [].filter.call(args, isNumber);\n if (numbers.length) {\n return Math[extreme].apply(0, numbers);\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The Navigator class\n *\n * @private\n * @class\n * @name Highcharts.Navigator\n *\n * @param {Highcharts.Chart} chart\n * Chart object\n */\n class Navigator {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AxisClass, ChartClass, SeriesClass) {\n NavigatorComposition.compose(AxisClass, ChartClass, Navigator, SeriesClass);\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart) {\n /* *\n *\n * Properties\n *\n * */\n this.baseSeries = void 0;\n this.chart = void 0;\n this.handles = void 0;\n this.height = void 0;\n this.left = void 0;\n this.navigatorEnabled = void 0;\n this.navigatorGroup = void 0;\n this.navigatorOptions = void 0;\n this.navigatorSeries = void 0;\n this.navigatorSize = void 0;\n this.opposite = void 0;\n this.outline = void 0;\n this.range = void 0;\n this.rendered = void 0;\n this.scrollbarHeight = 0;\n this.scrollButtonSize = void 0;\n this.shades = void 0;\n this.size = void 0;\n this.top = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zoomedMax = void 0;\n this.zoomedMin = void 0;\n this.init(chart);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Draw one of the handles on the side of the zoomed range in the navigator.\n *\n * @private\n * @function Highcharts.Navigator#drawHandle\n *\n * @param {number} x\n * The x center for the handle\n *\n * @param {number} index\n * 0 for left and 1 for right\n *\n * @param {boolean|undefined} inverted\n * Flag for chart.inverted\n *\n * @param {string} verb\n * Use 'animate' or 'attr'\n */\n drawHandle(x, index, inverted, verb) {\n const navigator = this, height = navigator.navigatorOptions.handles.height;\n // Place it\n navigator.handles[index][verb](inverted ? {\n translateX: Math.round(navigator.left + navigator.height / 2),\n translateY: Math.round(navigator.top + parseInt(x, 10) + 0.5 - height)\n } : {\n translateX: Math.round(navigator.left + parseInt(x, 10)),\n translateY: Math.round(navigator.top + navigator.height / 2 - height / 2 - 1)\n });\n }\n /**\n * Render outline around the zoomed range\n *\n * @private\n * @function Highcharts.Navigator#drawOutline\n *\n * @param {number} zoomedMin\n * in pixels position where zoomed range starts\n *\n * @param {number} zoomedMax\n * in pixels position where zoomed range ends\n *\n * @param {boolean|undefined} inverted\n * flag if chart is inverted\n *\n * @param {string} verb\n * use 'animate' or 'attr'\n */\n drawOutline(zoomedMin, zoomedMax, inverted, verb) {\n const navigator = this, maskInside = navigator.navigatorOptions.maskInside, outlineWidth = navigator.outline.strokeWidth(), halfOutline = outlineWidth / 2, outlineCorrection = (outlineWidth % 2) / 2, // #5800\n scrollButtonSize = navigator.scrollButtonSize, navigatorSize = navigator.size, navigatorTop = navigator.top, height = navigator.height, lineTop = navigatorTop - halfOutline, lineBtm = navigatorTop + height;\n let left = navigator.left, verticalMin, path;\n if (inverted) {\n verticalMin = navigatorTop + zoomedMax + outlineCorrection;\n zoomedMax = navigatorTop + zoomedMin + outlineCorrection;\n path = [\n [\n 'M',\n left + height,\n navigatorTop - scrollButtonSize - outlineCorrection\n ],\n // top right of zoomed range\n ['L', left + height, verticalMin],\n ['L', left, verticalMin],\n ['M', left, zoomedMax],\n ['L', left + height, zoomedMax],\n [\n 'L',\n left + height,\n navigatorTop + navigatorSize + scrollButtonSize\n ]\n ];\n if (maskInside) {\n path.push(\n // upper left of zoomed range\n ['M', left + height, verticalMin - halfOutline], \n // upper right of z.r.\n [\n 'L',\n left + height,\n zoomedMax + halfOutline\n ]);\n }\n }\n else {\n left -= scrollButtonSize;\n zoomedMin += left + scrollButtonSize - outlineCorrection;\n zoomedMax += left + scrollButtonSize - outlineCorrection;\n path = [\n // left\n ['M', left, lineTop],\n // upper left of zoomed range\n ['L', zoomedMin, lineTop],\n // lower left of z.r.\n ['L', zoomedMin, lineBtm],\n // lower right of z.r.\n ['M', zoomedMax, lineBtm],\n // upper right of z.r.\n ['L', zoomedMax, lineTop],\n // right\n [\n 'L',\n left + navigatorSize + scrollButtonSize * 2,\n navigatorTop + halfOutline\n ]\n ];\n if (maskInside) {\n path.push(\n // upper left of zoomed range\n ['M', zoomedMin - halfOutline, lineTop], \n // upper right of z.r.\n ['L', zoomedMax + halfOutline, lineTop]);\n }\n }\n navigator.outline[verb]({\n d: path\n });\n }\n /**\n * Render outline around the zoomed range\n *\n * @private\n * @function Highcharts.Navigator#drawMasks\n *\n * @param {number} zoomedMin\n * in pixels position where zoomed range starts\n *\n * @param {number} zoomedMax\n * in pixels position where zoomed range ends\n *\n * @param {boolean|undefined} inverted\n * flag if chart is inverted\n *\n * @param {string} verb\n * use 'animate' or 'attr'\n */\n drawMasks(zoomedMin, zoomedMax, inverted, verb) {\n const navigator = this, left = navigator.left, top = navigator.top, navigatorHeight = navigator.height;\n let height, width, x, y;\n // Determine rectangle position & size\n // According to (non)inverted position:\n if (inverted) {\n x = [left, left, left];\n y = [top, top + zoomedMin, top + zoomedMax];\n width = [navigatorHeight, navigatorHeight, navigatorHeight];\n height = [\n zoomedMin,\n zoomedMax - zoomedMin,\n navigator.size - zoomedMax\n ];\n }\n else {\n x = [left, left + zoomedMin, left + zoomedMax];\n y = [top, top, top];\n width = [\n zoomedMin,\n zoomedMax - zoomedMin,\n navigator.size - zoomedMax\n ];\n height = [navigatorHeight, navigatorHeight, navigatorHeight];\n }\n navigator.shades.forEach((shade, i) => {\n shade[verb]({\n x: x[i],\n y: y[i],\n width: width[i],\n height: height[i]\n });\n });\n }\n /**\n * Generate DOM elements for a navigator:\n *\n * - main navigator group\n *\n * - all shades\n *\n * - outline\n *\n * - handles\n *\n * @private\n * @function Highcharts.Navigator#renderElements\n */\n renderElements() {\n const navigator = this, navigatorOptions = navigator.navigatorOptions, maskInside = navigatorOptions.maskInside, chart = navigator.chart, inverted = chart.inverted, renderer = chart.renderer, mouseCursor = {\n cursor: inverted ? 'ns-resize' : 'ew-resize'\n }, \n // Create the main navigator group\n navigatorGroup = navigator.navigatorGroup = renderer\n .g('navigator')\n .attr({\n zIndex: 8,\n visibility: 'hidden'\n })\n .add();\n // Create masks, each mask will get events and fill:\n [\n !maskInside,\n maskInside,\n !maskInside\n ].forEach((hasMask, index) => {\n const shade = renderer.rect()\n .addClass('highcharts-navigator-mask' +\n (index === 1 ? '-inside' : '-outside'))\n .add(navigatorGroup);\n if (!chart.styledMode) {\n shade.attr({\n fill: hasMask ?\n navigatorOptions.maskFill :\n 'rgba(0,0,0,0)'\n });\n if (index === 1) {\n shade.css(mouseCursor);\n }\n }\n navigator.shades[index] = shade;\n });\n // Create the outline:\n navigator.outline = renderer.path()\n .addClass('highcharts-navigator-outline')\n .add(navigatorGroup);\n if (!chart.styledMode) {\n navigator.outline.attr({\n 'stroke-width': navigatorOptions.outlineWidth,\n stroke: navigatorOptions.outlineColor\n });\n }\n // Create the handlers:\n if (navigatorOptions.handles && navigatorOptions.handles.enabled) {\n const handlesOptions = navigatorOptions.handles, { height, width } = handlesOptions;\n [0, 1].forEach((index) => {\n navigator.handles[index] = renderer.symbol(handlesOptions.symbols[index], -width / 2 - 1, 0, width, height, handlesOptions);\n if (chart.inverted) {\n navigator.handles[index].attr({\n rotation: 90,\n rotationOriginX: Math.floor(-width / 2),\n rotationOriginY: (height + width) / 2\n });\n }\n // zIndex = 6 for right handle, 7 for left.\n // Can't be 10, because of the tooltip in inverted chart #2908\n navigator.handles[index].attr({ zIndex: 7 - index })\n .addClass('highcharts-navigator-handle ' +\n 'highcharts-navigator-handle-' +\n ['left', 'right'][index]).add(navigatorGroup);\n if (!chart.styledMode) {\n navigator.handles[index]\n .attr({\n fill: handlesOptions.backgroundColor,\n stroke: handlesOptions.borderColor,\n 'stroke-width': handlesOptions.lineWidth\n })\n .css(mouseCursor);\n }\n });\n }\n }\n /**\n * Update navigator\n *\n * @private\n * @function Highcharts.Navigator#update\n *\n * @param {Highcharts.NavigatorOptions} options\n * Options to merge in when updating navigator\n */\n update(options) {\n // Remove references to old navigator series in base series\n (this.series || []).forEach((series) => {\n if (series.baseSeries) {\n delete series.baseSeries.navigatorSeries;\n }\n });\n // Destroy and rebuild navigator\n this.destroy();\n const chartOptions = this.chart.options;\n merge(true, chartOptions.navigator, options);\n this.init(this.chart);\n }\n /**\n * Render the navigator\n *\n * @private\n * @function Highcharts.Navigator#render\n * @param {number} min\n * X axis value minimum\n * @param {number} max\n * X axis value maximum\n * @param {number} [pxMin]\n * Pixel value minimum\n * @param {number} [pxMax]\n * Pixel value maximum\n */\n render(min, max, pxMin, pxMax) {\n const navigator = this, chart = navigator.chart, xAxis = navigator.xAxis, pointRange = xAxis.pointRange || 0, scrollbarXAxis = xAxis.navigatorAxis.fake ? chart.xAxis[0] : xAxis, navigatorEnabled = navigator.navigatorEnabled, rendered = navigator.rendered, inverted = chart.inverted, minRange = chart.xAxis[0].minRange, maxRange = chart.xAxis[0].options.maxRange, scrollButtonSize = navigator.scrollButtonSize;\n let navigatorWidth, scrollbarLeft, scrollbarTop, scrollbarHeight = navigator.scrollbarHeight, navigatorSize, verb;\n // Don't redraw while moving the handles (#4703).\n if (this.hasDragged && !defined(pxMin)) {\n return;\n }\n min = correctFloat(min - pointRange / 2);\n max = correctFloat(max + pointRange / 2);\n // Don't render the navigator until we have data (#486, #4202, #5172).\n if (!isNumber(min) || !isNumber(max)) {\n // However, if navigator was already rendered, we may need to resize\n // it. For example hidden series, but visible navigator (#6022).\n if (rendered) {\n pxMin = 0;\n pxMax = pick(xAxis.width, scrollbarXAxis.width);\n }\n else {\n return;\n }\n }\n navigator.left = pick(xAxis.left, \n // in case of scrollbar only, without navigator\n chart.plotLeft + scrollButtonSize +\n (inverted ? chart.plotWidth : 0));\n let zoomedMax = navigator.size = navigatorSize = pick(xAxis.len, (inverted ? chart.plotHeight : chart.plotWidth) -\n 2 * scrollButtonSize);\n if (inverted) {\n navigatorWidth = scrollbarHeight;\n }\n else {\n navigatorWidth = navigatorSize + 2 * scrollButtonSize;\n }\n // Get the pixel position of the handles\n pxMin = pick(pxMin, xAxis.toPixels(min, true));\n pxMax = pick(pxMax, xAxis.toPixels(max, true));\n // Verify (#1851, #2238)\n if (!isNumber(pxMin) || Math.abs(pxMin) === Infinity) {\n pxMin = 0;\n pxMax = navigatorWidth;\n }\n // Are we below the minRange? (#2618, #6191)\n const newMin = xAxis.toValue(pxMin, true), newMax = xAxis.toValue(pxMax, true), currentRange = Math.abs(correctFloat(newMax - newMin));\n if (currentRange < minRange) {\n if (this.grabbedLeft) {\n pxMin = xAxis.toPixels(newMax - minRange - pointRange, true);\n }\n else if (this.grabbedRight) {\n pxMax = xAxis.toPixels(newMin + minRange + pointRange, true);\n }\n }\n else if (defined(maxRange) &&\n correctFloat(currentRange - pointRange) > maxRange) {\n if (this.grabbedLeft) {\n pxMin = xAxis.toPixels(newMax - maxRange - pointRange, true);\n }\n else if (this.grabbedRight) {\n pxMax = xAxis.toPixels(newMin + maxRange + pointRange, true);\n }\n }\n // Handles are allowed to cross, but never exceed the plot area\n navigator.zoomedMax = clamp(Math.max(pxMin, pxMax), 0, zoomedMax);\n navigator.zoomedMin = clamp(navigator.fixedWidth ?\n navigator.zoomedMax - navigator.fixedWidth :\n Math.min(pxMin, pxMax), 0, zoomedMax);\n navigator.range = navigator.zoomedMax - navigator.zoomedMin;\n zoomedMax = Math.round(navigator.zoomedMax);\n const zoomedMin = Math.round(navigator.zoomedMin);\n if (navigatorEnabled) {\n navigator.navigatorGroup.attr({\n visibility: 'inherit'\n });\n // Place elements\n verb = rendered && !navigator.hasDragged ? 'animate' : 'attr';\n navigator.drawMasks(zoomedMin, zoomedMax, inverted, verb);\n navigator.drawOutline(zoomedMin, zoomedMax, inverted, verb);\n if (navigator.navigatorOptions.handles.enabled) {\n navigator.drawHandle(zoomedMin, 0, inverted, verb);\n navigator.drawHandle(zoomedMax, 1, inverted, verb);\n }\n }\n if (navigator.scrollbar) {\n if (inverted) {\n scrollbarTop = navigator.top - scrollButtonSize;\n scrollbarLeft = navigator.left - scrollbarHeight +\n (navigatorEnabled || !scrollbarXAxis.opposite ? 0 :\n // Multiple axes has offsets:\n (scrollbarXAxis.titleOffset || 0) +\n // Self margin from the axis.title\n scrollbarXAxis.axisTitleMargin);\n scrollbarHeight = navigatorSize + 2 * scrollButtonSize;\n }\n else {\n scrollbarTop = navigator.top + (navigatorEnabled ?\n navigator.height :\n -scrollbarHeight);\n scrollbarLeft = navigator.left - scrollButtonSize;\n }\n // Reposition scrollbar\n navigator.scrollbar.position(scrollbarLeft, scrollbarTop, navigatorWidth, scrollbarHeight);\n // Keep scale 0-1\n navigator.scrollbar.setRange(\n // Use real value, not rounded because range can be very small\n // (#1716)\n navigator.zoomedMin / (navigatorSize || 1), navigator.zoomedMax / (navigatorSize || 1));\n }\n navigator.rendered = true;\n }\n /**\n * Set up the mouse and touch events for the navigator\n *\n * @private\n * @function Highcharts.Navigator#addMouseEvents\n */\n addMouseEvents() {\n const navigator = this, chart = navigator.chart, container = chart.container;\n let eventsToUnbind = [], mouseMoveHandler, mouseUpHandler;\n /**\n * Create mouse events' handlers.\n * Make them as separate functions to enable wrapping them:\n */\n navigator.mouseMoveHandler = mouseMoveHandler = function (e) {\n navigator.onMouseMove(e);\n };\n navigator.mouseUpHandler = mouseUpHandler = function (e) {\n navigator.onMouseUp(e);\n };\n // Add shades and handles mousedown events\n eventsToUnbind = navigator.getPartsEvents('mousedown');\n // Add mouse move and mouseup events. These are bind to doc/container,\n // because Navigator.grabbedSomething flags are stored in mousedown\n // events\n eventsToUnbind.push(addEvent(chart.renderTo, 'mousemove', mouseMoveHandler), addEvent(container.ownerDocument, 'mouseup', mouseUpHandler));\n // Touch events\n if (hasTouch) {\n eventsToUnbind.push(addEvent(chart.renderTo, 'touchmove', mouseMoveHandler), addEvent(container.ownerDocument, 'touchend', mouseUpHandler));\n eventsToUnbind.concat(navigator.getPartsEvents('touchstart'));\n }\n navigator.eventsToUnbind = eventsToUnbind;\n // Data events\n if (navigator.series && navigator.series[0]) {\n eventsToUnbind.push(addEvent(navigator.series[0].xAxis, 'foundExtremes', function () {\n chart.navigator.modifyNavigatorAxisExtremes();\n }));\n }\n }\n /**\n * Generate events for handles and masks\n *\n * @private\n * @function Highcharts.Navigator#getPartsEvents\n *\n * @param {string} eventName\n * Event name handler, 'mousedown' or 'touchstart'\n *\n * @return {Array}\n * An array of functions to remove navigator functions from the\n * events again.\n */\n getPartsEvents(eventName) {\n const navigator = this, events = [];\n ['shades', 'handles'].forEach(function (name) {\n navigator[name].forEach(function (navigatorItem, index) {\n events.push(addEvent(navigatorItem.element, eventName, function (e) {\n navigator[name + 'Mousedown'](e, index);\n }));\n });\n });\n return events;\n }\n /**\n * Mousedown on a shaded mask, either:\n *\n * - will be stored for future drag&drop\n *\n * - will directly shift to a new range\n *\n * @private\n * @function Highcharts.Navigator#shadesMousedown\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n *\n * @param {number} index\n * Index of a mask in Navigator.shades array\n */\n shadesMousedown(e, index) {\n e = this.chart.pointer.normalize(e);\n const navigator = this, chart = navigator.chart, xAxis = navigator.xAxis, zoomedMin = navigator.zoomedMin, navigatorSize = navigator.size, range = navigator.range;\n let navigatorPosition = navigator.left, chartX = e.chartX, fixedMax, fixedMin, ext, left;\n // For inverted chart, swap some options:\n if (chart.inverted) {\n chartX = e.chartY;\n navigatorPosition = navigator.top;\n }\n if (index === 1) {\n // Store information for drag&drop\n navigator.grabbedCenter = chartX;\n navigator.fixedWidth = range;\n navigator.dragOffset = chartX - zoomedMin;\n }\n else {\n // Shift the range by clicking on shaded areas\n left = chartX - navigatorPosition - range / 2;\n if (index === 0) {\n left = Math.max(0, left);\n }\n else if (index === 2 && left + range >= navigatorSize) {\n left = navigatorSize - range;\n if (navigator.reversedExtremes) {\n // #7713\n left -= range;\n fixedMin = navigator.getUnionExtremes().dataMin;\n }\n else {\n // #2293, #3543\n fixedMax = navigator.getUnionExtremes().dataMax;\n }\n }\n if (left !== zoomedMin) { // it has actually moved\n navigator.fixedWidth = range; // #1370\n ext = xAxis.navigatorAxis.toFixedRange(left, left + range, fixedMin, fixedMax);\n if (defined(ext.min)) { // #7411\n chart.xAxis[0].setExtremes(Math.min(ext.min, ext.max), Math.max(ext.min, ext.max), true, null, // auto animation\n { trigger: 'navigator' });\n }\n }\n }\n }\n /**\n * Mousedown on a handle mask.\n * Will store necessary information for drag&drop.\n *\n * @private\n * @function Highcharts.Navigator#handlesMousedown\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n * @param {number} index\n * Index of a handle in Navigator.handles array\n */\n handlesMousedown(e, index) {\n e = this.chart.pointer.normalize(e);\n const navigator = this, chart = navigator.chart, baseXAxis = chart.xAxis[0], \n // For reversed axes, min and max are changed,\n // so the other extreme should be stored\n reverse = navigator.reversedExtremes;\n if (index === 0) {\n // Grab the left handle\n navigator.grabbedLeft = true;\n navigator.otherHandlePos = navigator.zoomedMax;\n navigator.fixedExtreme = reverse ? baseXAxis.min : baseXAxis.max;\n }\n else {\n // Grab the right handle\n navigator.grabbedRight = true;\n navigator.otherHandlePos = navigator.zoomedMin;\n navigator.fixedExtreme = reverse ? baseXAxis.max : baseXAxis.min;\n }\n chart.fixedRange = null;\n }\n /**\n * Mouse move event based on x/y mouse position.\n *\n * @private\n * @function Highcharts.Navigator#onMouseMove\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n */\n onMouseMove(e) {\n const navigator = this, chart = navigator.chart, navigatorSize = navigator.navigatorSize, range = navigator.range, dragOffset = navigator.dragOffset, inverted = chart.inverted;\n let left = navigator.left, chartX;\n // In iOS, a mousemove event with e.pageX === 0 is fired when holding\n // the finger down in the center of the scrollbar. This should be\n // ignored.\n if (!e.touches || e.touches[0].pageX !== 0) { // #4696\n e = chart.pointer.normalize(e);\n chartX = e.chartX;\n // Swap some options for inverted chart\n if (inverted) {\n left = navigator.top;\n chartX = e.chartY;\n }\n // Drag left handle or top handle\n if (navigator.grabbedLeft) {\n navigator.hasDragged = true;\n navigator.render(0, 0, chartX - left, navigator.otherHandlePos);\n // Drag right handle or bottom handle\n }\n else if (navigator.grabbedRight) {\n navigator.hasDragged = true;\n navigator.render(0, 0, navigator.otherHandlePos, chartX - left);\n // Drag scrollbar or open area in navigator\n }\n else if (navigator.grabbedCenter) {\n navigator.hasDragged = true;\n if (chartX < dragOffset) { // outside left\n chartX = dragOffset;\n // outside right\n }\n else if (chartX >\n navigatorSize + dragOffset - range) {\n chartX = navigatorSize + dragOffset - range;\n }\n navigator.render(0, 0, chartX - dragOffset, chartX - dragOffset + range);\n }\n if (navigator.hasDragged &&\n navigator.scrollbar &&\n pick(navigator.scrollbar.options.liveRedraw, \n // By default, don't run live redraw on touch\n // devices or if the chart is in boost.\n !isTouchDevice &&\n !this.chart.boosted)) {\n e.DOMType = e.type;\n setTimeout(function () {\n navigator.onMouseUp(e);\n }, 0);\n }\n }\n }\n /**\n * Mouse up event based on x/y mouse position.\n *\n * @private\n * @function Highcharts.Navigator#onMouseUp\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n */\n onMouseUp(e) {\n const navigator = this, chart = navigator.chart, xAxis = navigator.xAxis, scrollbar = navigator.scrollbar, DOMEvent = e.DOMEvent || e, inverted = chart.inverted, verb = navigator.rendered && !navigator.hasDragged ?\n 'animate' : 'attr';\n let zoomedMax, zoomedMin, unionExtremes, fixedMin, fixedMax, ext;\n if (\n // MouseUp is called for both, navigator and scrollbar (that order),\n // which causes calling afterSetExtremes twice. Prevent first call\n // by checking if scrollbar is going to set new extremes (#6334)\n (navigator.hasDragged && (!scrollbar || !scrollbar.hasDragged)) ||\n e.trigger === 'scrollbar') {\n unionExtremes = navigator.getUnionExtremes();\n // When dragging one handle, make sure the other one doesn't change\n if (navigator.zoomedMin === navigator.otherHandlePos) {\n fixedMin = navigator.fixedExtreme;\n }\n else if (navigator.zoomedMax === navigator.otherHandlePos) {\n fixedMax = navigator.fixedExtreme;\n }\n // Snap to right edge (#4076)\n if (navigator.zoomedMax === navigator.size) {\n fixedMax = navigator.reversedExtremes ?\n unionExtremes.dataMin :\n unionExtremes.dataMax;\n }\n // Snap to left edge (#7576)\n if (navigator.zoomedMin === 0) {\n fixedMin = navigator.reversedExtremes ?\n unionExtremes.dataMax :\n unionExtremes.dataMin;\n }\n ext = xAxis.navigatorAxis.toFixedRange(navigator.zoomedMin, navigator.zoomedMax, fixedMin, fixedMax);\n if (defined(ext.min)) {\n chart.xAxis[0].setExtremes(Math.min(ext.min, ext.max), Math.max(ext.min, ext.max), true, \n // Run animation when clicking buttons, scrollbar track etc,\n // but not when dragging handles or scrollbar\n navigator.hasDragged ? false : null, {\n trigger: 'navigator',\n triggerOp: 'navigator-drag',\n DOMEvent: DOMEvent // #1838\n });\n }\n }\n if (e.DOMType !== 'mousemove' &&\n e.DOMType !== 'touchmove') {\n navigator.grabbedLeft = navigator.grabbedRight =\n navigator.grabbedCenter = navigator.fixedWidth =\n navigator.fixedExtreme = navigator.otherHandlePos =\n navigator.hasDragged = navigator.dragOffset = null;\n }\n // Update position of navigator shades, outline and handles (#12573)\n if (navigator.navigatorEnabled &&\n isNumber(navigator.zoomedMin) &&\n isNumber(navigator.zoomedMax)) {\n zoomedMin = Math.round(navigator.zoomedMin);\n zoomedMax = Math.round(navigator.zoomedMax);\n if (navigator.shades) {\n navigator.drawMasks(zoomedMin, zoomedMax, inverted, verb);\n }\n if (navigator.outline) {\n navigator.drawOutline(zoomedMin, zoomedMax, inverted, verb);\n }\n if (navigator.navigatorOptions.handles.enabled &&\n Object.keys(navigator.handles).length ===\n navigator.handles.length) {\n navigator.drawHandle(zoomedMin, 0, inverted, verb);\n navigator.drawHandle(zoomedMax, 1, inverted, verb);\n }\n }\n }\n /**\n * Removes the event handlers attached previously with addEvents.\n *\n * @private\n * @function Highcharts.Navigator#removeEvents\n */\n removeEvents() {\n if (this.eventsToUnbind) {\n this.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n this.eventsToUnbind = void 0;\n }\n this.removeBaseSeriesEvents();\n }\n /**\n * Remove data events.\n *\n * @private\n * @function Highcharts.Navigator#removeBaseSeriesEvents\n */\n removeBaseSeriesEvents() {\n const baseSeries = this.baseSeries || [];\n if (this.navigatorEnabled && baseSeries[0]) {\n if (this.navigatorOptions.adaptToUpdatedData !== false) {\n baseSeries.forEach(function (series) {\n removeEvent(series, 'updatedData', this.updatedDataHandler);\n }, this);\n }\n // We only listen for extremes-events on the first baseSeries\n if (baseSeries[0].xAxis) {\n removeEvent(baseSeries[0].xAxis, 'foundExtremes', this.modifyBaseAxisExtremes);\n }\n }\n }\n /**\n * Initialize the Navigator object\n *\n * @private\n * @function Highcharts.Navigator#init\n */\n init(chart) {\n const chartOptions = chart.options, navigatorOptions = chartOptions.navigator || {}, navigatorEnabled = navigatorOptions.enabled, scrollbarOptions = chartOptions.scrollbar || {}, scrollbarEnabled = scrollbarOptions.enabled, height = navigatorEnabled && navigatorOptions.height || 0, scrollbarHeight = scrollbarEnabled && scrollbarOptions.height || 0, scrollButtonSize = scrollbarOptions.buttonsEnabled && scrollbarHeight || 0;\n this.handles = [];\n this.shades = [];\n this.chart = chart;\n this.setBaseSeries();\n this.height = height;\n this.scrollbarHeight = scrollbarHeight;\n this.scrollButtonSize = scrollButtonSize;\n this.scrollbarEnabled = scrollbarEnabled;\n this.navigatorEnabled = navigatorEnabled;\n this.navigatorOptions = navigatorOptions;\n this.scrollbarOptions = scrollbarOptions;\n this.opposite = pick(navigatorOptions.opposite, Boolean(!navigatorEnabled && chart.inverted)); // #6262\n const navigator = this, baseSeries = navigator.baseSeries, xAxisIndex = chart.xAxis.length, yAxisIndex = chart.yAxis.length, baseXaxis = baseSeries && baseSeries[0] && baseSeries[0].xAxis ||\n chart.xAxis[0] || { options: {} };\n chart.isDirtyBox = true;\n if (navigator.navigatorEnabled) {\n // an x axis is required for scrollbar also\n navigator.xAxis = new Axis(chart, merge({\n // inherit base xAxis' break and ordinal options\n breaks: baseXaxis.options.breaks,\n ordinal: baseXaxis.options.ordinal\n }, navigatorOptions.xAxis, {\n id: 'navigator-x-axis',\n yAxis: 'navigator-y-axis',\n type: 'datetime',\n index: xAxisIndex,\n isInternal: true,\n offset: 0,\n keepOrdinalPadding: true,\n startOnTick: false,\n endOnTick: false,\n minPadding: 0,\n maxPadding: 0,\n zoomEnabled: false\n }, chart.inverted ? {\n offsets: [scrollButtonSize, 0, -scrollButtonSize, 0],\n width: height\n } : {\n offsets: [0, -scrollButtonSize, 0, scrollButtonSize],\n height: height\n }), 'xAxis');\n navigator.yAxis = new Axis(chart, merge(navigatorOptions.yAxis, {\n id: 'navigator-y-axis',\n alignTicks: false,\n offset: 0,\n index: yAxisIndex,\n isInternal: true,\n reversed: pick((navigatorOptions.yAxis &&\n navigatorOptions.yAxis.reversed), (chart.yAxis[0] && chart.yAxis[0].reversed), false),\n zoomEnabled: false\n }, chart.inverted ? {\n width: height\n } : {\n height: height\n }), 'yAxis');\n // If we have a base series, initialize the navigator series\n if (baseSeries || navigatorOptions.series.data) {\n navigator.updateNavigatorSeries(false);\n // If not, set up an event to listen for added series\n }\n else if (chart.series.length === 0) {\n navigator.unbindRedraw = addEvent(chart, 'beforeRedraw', function () {\n // We've got one, now add it as base\n if (chart.series.length > 0 && !navigator.series) {\n navigator.setBaseSeries();\n navigator.unbindRedraw(); // reset\n }\n });\n }\n navigator.reversedExtremes = (chart.inverted && !navigator.xAxis.reversed) || (!chart.inverted && navigator.xAxis.reversed);\n // Render items, so we can bind events to them:\n navigator.renderElements();\n // Add mouse events\n navigator.addMouseEvents();\n // in case of scrollbar only, fake an x axis to get translation\n }\n else {\n navigator.xAxis = {\n chart,\n navigatorAxis: {\n fake: true\n },\n translate: function (value, reverse) {\n const axis = chart.xAxis[0], ext = axis.getExtremes(), scrollTrackWidth = axis.len - 2 * scrollButtonSize, min = numExt('min', axis.options.min, ext.dataMin), valueRange = numExt('max', axis.options.max, ext.dataMax) - min;\n return reverse ?\n // from pixel to value\n (value * valueRange / scrollTrackWidth) + min :\n // from value to pixel\n scrollTrackWidth * (value - min) / valueRange;\n },\n toPixels: function (value) {\n return this.translate(value);\n },\n toValue: function (value) {\n return this.translate(value, true);\n }\n };\n navigator.xAxis.navigatorAxis.axis = navigator.xAxis;\n navigator.xAxis.navigatorAxis.toFixedRange = (NavigatorAxisAdditions.prototype.toFixedRange.bind(navigator.xAxis.navigatorAxis));\n }\n // Initialize the scrollbar\n if (chart.options.scrollbar.enabled) {\n const options = merge(chart.options.scrollbar, { vertical: chart.inverted });\n if (!isNumber(options.margin) && navigator.navigatorEnabled) {\n options.margin = chart.inverted ? -3 : 3;\n }\n chart.scrollbar = navigator.scrollbar = new Scrollbar(chart.renderer, options, chart);\n addEvent(navigator.scrollbar, 'changed', function (e) {\n const range = navigator.size, to = range * this.to, from = range * this.from;\n navigator.hasDragged = navigator.scrollbar.hasDragged;\n navigator.render(0, 0, from, to);\n if (this.shouldUpdateExtremes(e.DOMType)) {\n setTimeout(function () {\n navigator.onMouseUp(e);\n });\n }\n });\n }\n // Add data events\n navigator.addBaseSeriesEvents();\n // Add redraw events\n navigator.addChartEvents();\n }\n /**\n * Get the union data extremes of the chart - the outer data extremes of the\n * base X axis and the navigator axis.\n *\n * @private\n * @function Highcharts.Navigator#getUnionExtremes\n */\n getUnionExtremes(returnFalseOnNoBaseSeries) {\n const baseAxis = this.chart.xAxis[0], navAxis = this.xAxis, navAxisOptions = navAxis.options, baseAxisOptions = baseAxis.options;\n let ret;\n if (!returnFalseOnNoBaseSeries || baseAxis.dataMin !== null) {\n ret = {\n dataMin: pick(// #4053\n navAxisOptions && navAxisOptions.min, numExt('min', baseAxisOptions.min, baseAxis.dataMin, navAxis.dataMin, navAxis.min)),\n dataMax: pick(navAxisOptions && navAxisOptions.max, numExt('max', baseAxisOptions.max, baseAxis.dataMax, navAxis.dataMax, navAxis.max))\n };\n }\n return ret;\n }\n /**\n * Set the base series and update the navigator series from this. With a bit\n * of modification we should be able to make this an API method to be called\n * from the outside\n *\n * @private\n * @function Highcharts.Navigator#setBaseSeries\n * @param {Highcharts.SeriesOptionsType} [baseSeriesOptions]\n * Additional series options for a navigator\n * @param {boolean} [redraw]\n * Whether to redraw after update.\n */\n setBaseSeries(baseSeriesOptions, redraw) {\n const chart = this.chart, baseSeries = this.baseSeries = [];\n baseSeriesOptions = (baseSeriesOptions ||\n chart.options && chart.options.navigator.baseSeries ||\n (chart.series.length ?\n // Find the first non-navigator series (#8430)\n find(chart.series, (s) => (!s.options.isInternal)).index :\n 0));\n // Iterate through series and add the ones that should be shown in\n // navigator.\n (chart.series || []).forEach((series, i) => {\n if (\n // Don't include existing nav series\n !series.options.isInternal &&\n (series.options.showInNavigator ||\n (i === baseSeriesOptions ||\n series.options.id === baseSeriesOptions) &&\n series.options.showInNavigator !== false)) {\n baseSeries.push(series);\n }\n });\n // When run after render, this.xAxis already exists\n if (this.xAxis && !this.xAxis.navigatorAxis.fake) {\n this.updateNavigatorSeries(true, redraw);\n }\n }\n /**\n * Update series in the navigator from baseSeries, adding new if does not\n * exist.\n *\n * @private\n * @function Highcharts.Navigator.updateNavigatorSeries\n */\n updateNavigatorSeries(addEvents, redraw) {\n const navigator = this, chart = navigator.chart, baseSeries = navigator.baseSeries, navSeriesMixin = {\n enableMouseTracking: false,\n index: null,\n linkedTo: null,\n group: 'nav',\n padXAxis: false,\n xAxis: 'navigator-x-axis',\n yAxis: 'navigator-y-axis',\n showInLegend: false,\n stacking: void 0,\n isInternal: true,\n states: {\n inactive: {\n opacity: 1\n }\n }\n }, \n // Remove navigator series that are no longer in the baseSeries\n navigatorSeries = navigator.series =\n (navigator.series || []).filter((navSeries) => {\n const base = navSeries.baseSeries;\n if (baseSeries.indexOf(base) < 0) { // Not in array\n // If there is still a base series connected to this\n // series, remove event handler and reference.\n if (base) {\n removeEvent(base, 'updatedData', navigator.updatedDataHandler);\n delete base.navigatorSeries;\n }\n // Kill the nav series. It may already have been\n // destroyed (#8715).\n if (navSeries.chart) {\n navSeries.destroy();\n }\n return false;\n }\n return true;\n });\n let baseOptions, mergedNavSeriesOptions, chartNavigatorSeriesOptions = navigator.navigatorOptions.series, baseNavigatorOptions;\n // Go through each base series and merge the options to create new\n // series\n if (baseSeries && baseSeries.length) {\n baseSeries.forEach((base) => {\n const linkedNavSeries = base.navigatorSeries, userNavOptions = extend(\n // Grab color and visibility from base as default\n {\n color: base.color,\n visible: base.visible\n }, !isArray(chartNavigatorSeriesOptions) ?\n chartNavigatorSeriesOptions :\n defaultOptions.navigator.series);\n // Don't update if the series exists in nav and we have disabled\n // adaptToUpdatedData.\n if (linkedNavSeries &&\n navigator.navigatorOptions.adaptToUpdatedData === false) {\n return;\n }\n navSeriesMixin.name = 'Navigator ' + baseSeries.length;\n baseOptions = base.options || {};\n baseNavigatorOptions = baseOptions.navigatorOptions || {};\n // The dataLabels options are not merged correctly\n // if the settings are an array, #13847.\n userNavOptions.dataLabels = splat(userNavOptions.dataLabels);\n mergedNavSeriesOptions = merge(baseOptions, navSeriesMixin, userNavOptions, baseNavigatorOptions);\n // Once nav series type is resolved, pick correct pointRange\n mergedNavSeriesOptions.pointRange = pick(\n // Stricte set pointRange in options\n userNavOptions.pointRange, baseNavigatorOptions.pointRange, \n // Fallback to default values, e.g. `null` for column\n defaultOptions.plotOptions[mergedNavSeriesOptions.type || 'line'].pointRange);\n // Merge data separately. Do a slice to avoid mutating the\n // navigator options from base series (#4923).\n const navigatorSeriesData = baseNavigatorOptions.data || userNavOptions.data;\n navigator.hasNavigatorData =\n navigator.hasNavigatorData || !!navigatorSeriesData;\n mergedNavSeriesOptions.data =\n navigatorSeriesData ||\n baseOptions.data && baseOptions.data.slice(0);\n // Update or add the series\n if (linkedNavSeries && linkedNavSeries.options) {\n linkedNavSeries.update(mergedNavSeriesOptions, redraw);\n }\n else {\n base.navigatorSeries = chart.initSeries(mergedNavSeriesOptions);\n base.navigatorSeries.baseSeries = base; // Store ref\n navigatorSeries.push(base.navigatorSeries);\n }\n });\n }\n // If user has defined data (and no base series) or explicitly defined\n // navigator.series as an array, we create these series on top of any\n // base series.\n if (chartNavigatorSeriesOptions.data &&\n !(baseSeries && baseSeries.length) ||\n isArray(chartNavigatorSeriesOptions)) {\n navigator.hasNavigatorData = false;\n // Allow navigator.series to be an array\n chartNavigatorSeriesOptions =\n splat(chartNavigatorSeriesOptions);\n chartNavigatorSeriesOptions.forEach((userSeriesOptions, i) => {\n navSeriesMixin.name =\n 'Navigator ' + (navigatorSeries.length + 1);\n mergedNavSeriesOptions = merge(defaultOptions.navigator.series, {\n // Since we don't have a base series to pull color from,\n // try to fake it by using color from series with same\n // index. Otherwise pull from the colors array. We need\n // an explicit color as otherwise updates will increment\n // color counter and we'll get a new color for each\n // update of the nav series.\n color: chart.series[i] &&\n !chart.series[i].options.isInternal &&\n chart.series[i].color ||\n chart.options.colors[i] ||\n chart.options.colors[0]\n }, navSeriesMixin, userSeriesOptions);\n mergedNavSeriesOptions.data = userSeriesOptions.data;\n if (mergedNavSeriesOptions.data) {\n navigator.hasNavigatorData = true;\n navigatorSeries.push(chart.initSeries(mergedNavSeriesOptions));\n }\n });\n }\n if (addEvents) {\n this.addBaseSeriesEvents();\n }\n }\n /**\n * Add data events.\n * For example when main series is updated we need to recalculate extremes\n *\n * @private\n * @function Highcharts.Navigator#addBaseSeriesEvent\n */\n addBaseSeriesEvents() {\n const navigator = this, baseSeries = navigator.baseSeries || [];\n // Bind modified extremes event to first base's xAxis only.\n // In event of > 1 base-xAxes, the navigator will ignore those.\n // Adding this multiple times to the same axis is no problem, as\n // duplicates should be discarded by the browser.\n if (baseSeries[0] && baseSeries[0].xAxis) {\n baseSeries[0].eventsToUnbind.push(addEvent(baseSeries[0].xAxis, 'foundExtremes', this.modifyBaseAxisExtremes));\n }\n baseSeries.forEach((base) => {\n // Link base series show/hide to navigator series visibility\n base.eventsToUnbind.push(addEvent(base, 'show', function () {\n if (this.navigatorSeries) {\n this.navigatorSeries.setVisible(true, false);\n }\n }));\n base.eventsToUnbind.push(addEvent(base, 'hide', function () {\n if (this.navigatorSeries) {\n this.navigatorSeries.setVisible(false, false);\n }\n }));\n // Respond to updated data in the base series, unless explicitily\n // not adapting to data changes.\n if (this.navigatorOptions.adaptToUpdatedData !== false) {\n if (base.xAxis) {\n base.eventsToUnbind.push(addEvent(base, 'updatedData', this.updatedDataHandler));\n }\n }\n // Handle series removal\n base.eventsToUnbind.push(addEvent(base, 'remove', function () {\n if (this.navigatorSeries) {\n erase(navigator.series, this.navigatorSeries);\n if (defined(this.navigatorSeries.options)) {\n this.navigatorSeries.remove(false);\n }\n delete this.navigatorSeries;\n }\n }));\n });\n }\n /**\n * Get minimum from all base series connected to the navigator\n * @private\n * @param {number} currentSeriesMin\n * Minium from the current series\n * @return {number}\n * Minimum from all series\n */\n getBaseSeriesMin(currentSeriesMin) {\n return this.baseSeries.reduce(function (min, series) {\n // (#10193)\n return Math.min(min, series.xData && series.xData.length ?\n series.xData[0] : min);\n }, currentSeriesMin);\n }\n /**\n * Set the navigator x axis extremes to reflect the total. The navigator\n * extremes should always be the extremes of the union of all series in the\n * chart as well as the navigator series.\n *\n * @private\n * @function Highcharts.Navigator#modifyNavigatorAxisExtremes\n */\n modifyNavigatorAxisExtremes() {\n const xAxis = this.xAxis;\n if (typeof xAxis.getExtremes !== 'undefined') {\n const unionExtremes = this.getUnionExtremes(true);\n if (unionExtremes &&\n (unionExtremes.dataMin !== xAxis.min ||\n unionExtremes.dataMax !== xAxis.max)) {\n xAxis.min = unionExtremes.dataMin;\n xAxis.max = unionExtremes.dataMax;\n }\n }\n }\n /**\n * Hook to modify the base axis extremes with information from the Navigator\n *\n * @private\n * @function Highcharts.Navigator#modifyBaseAxisExtremes\n */\n modifyBaseAxisExtremes() {\n const baseXAxis = this, navigator = baseXAxis.chart.navigator, baseExtremes = baseXAxis.getExtremes(), baseMin = baseExtremes.min, baseMax = baseExtremes.max, baseDataMin = baseExtremes.dataMin, baseDataMax = baseExtremes.dataMax, range = baseMax - baseMin, stickToMin = navigator.stickToMin, stickToMax = navigator.stickToMax, overscroll = pick(baseXAxis.options.overscroll, 0), navigatorSeries = navigator.series && navigator.series[0], hasSetExtremes = !!baseXAxis.setExtremes, \n // When the extremes have been set by range selector button, don't\n // stick to min or max. The range selector buttons will handle the\n // extremes. (#5489)\n unmutable = baseXAxis.eventArgs &&\n baseXAxis.eventArgs.trigger === 'rangeSelectorButton';\n let newMax, newMin;\n if (!unmutable) {\n // If the zoomed range is already at the min, move it to the right\n // as new data comes in\n if (stickToMin) {\n newMin = baseDataMin;\n newMax = newMin + range;\n }\n // If the zoomed range is already at the max, move it to the right\n // as new data comes in\n if (stickToMax) {\n newMax = baseDataMax + overscroll;\n // If stickToMin is true, the new min value is set above\n if (!stickToMin) {\n newMin = Math.max(baseDataMin, // don't go below data extremes (#13184)\n newMax - range, navigator.getBaseSeriesMin(navigatorSeries && navigatorSeries.xData ?\n navigatorSeries.xData[0] :\n -Number.MAX_VALUE));\n }\n }\n // Update the extremes\n if (hasSetExtremes && (stickToMin || stickToMax)) {\n if (isNumber(newMin)) {\n baseXAxis.min = baseXAxis.userMin = newMin;\n baseXAxis.max = baseXAxis.userMax = newMax;\n }\n }\n }\n // Reset\n navigator.stickToMin =\n navigator.stickToMax = null;\n }\n /**\n * Handler for updated data on the base series. When data is modified, the\n * navigator series must reflect it. This is called from the Chart.redraw\n * function before axis and series extremes are computed.\n *\n * @private\n * @function Highcharts.Navigator#updateDataHandler\n */\n updatedDataHandler() {\n const navigator = this.chart.navigator, baseSeries = this, navigatorSeries = this.navigatorSeries, shouldStickToMax = navigator.reversedExtremes ?\n Math.round(navigator.zoomedMin) === 0 :\n Math.round(navigator.zoomedMax) >= Math.round(navigator.size);\n // If the scrollbar is scrolled all the way to the right, keep right as\n // new data comes in, unless user set navigator.stickToMax to false.\n navigator.stickToMax = pick(this.chart.options.navigator &&\n this.chart.options.navigator.stickToMax, shouldStickToMax);\n navigator.stickToMin = navigator.shouldStickToMin(baseSeries, navigator);\n // Set the navigator series data to the new data of the base series\n if (navigatorSeries && !navigator.hasNavigatorData) {\n navigatorSeries.options.pointStart = baseSeries.xData[0];\n navigatorSeries.setData(baseSeries.options.data, false, null, false); // #5414\n }\n }\n /**\n * Detect if the zoomed area should stick to the minimum, #14742.\n *\n * @private\n * @function Highcharts.Navigator#shouldStickToMin\n */\n shouldStickToMin(baseSeries, navigator) {\n const xDataMin = navigator.getBaseSeriesMin(baseSeries.xData[0]), xAxis = baseSeries.xAxis, max = xAxis.max, min = xAxis.min, range = xAxis.options.range;\n let stickToMin = true;\n if (isNumber(max) && isNumber(min)) {\n // If range declared, stick to the minimum only if the range\n // is smaller than the data set range.\n if (range && max - xDataMin > 0) {\n stickToMin = max - xDataMin < range;\n }\n else {\n // If the current axis minimum falls outside the new\n // updated dataset, we must adjust.\n stickToMin = min <= xDataMin;\n }\n }\n else {\n stickToMin = false; // #15864\n }\n return stickToMin;\n }\n /**\n * Add chart events, like redrawing navigator, when chart requires that.\n *\n * @private\n * @function Highcharts.Navigator#addChartEvents\n */\n addChartEvents() {\n if (!this.eventsToUnbind) {\n this.eventsToUnbind = [];\n }\n this.eventsToUnbind.push(\n // Move the scrollbar after redraw, like after data updata even if\n // axes don't redraw\n addEvent(this.chart, 'redraw', function () {\n const navigator = this.navigator, xAxis = navigator && (navigator.baseSeries &&\n navigator.baseSeries[0] &&\n navigator.baseSeries[0].xAxis ||\n this.xAxis[0]); // #5709, #13114\n if (xAxis) {\n navigator.render(xAxis.min, xAxis.max);\n }\n }), \n // Make room for the navigator, can be placed around the chart:\n addEvent(this.chart, 'getMargins', function () {\n let chart = this, navigator = chart.navigator, marginName = navigator.opposite ?\n 'plotTop' : 'marginBottom';\n if (chart.inverted) {\n marginName = navigator.opposite ?\n 'marginRight' : 'plotLeft';\n }\n chart[marginName] =\n (chart[marginName] || 0) + (navigator.navigatorEnabled || !chart.inverted ?\n navigator.height + navigator.scrollbarHeight :\n 0) + navigator.navigatorOptions.margin;\n }));\n }\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.Navigator#destroy\n */\n destroy() {\n // Disconnect events added in addEvents\n this.removeEvents();\n if (this.xAxis) {\n erase(this.chart.xAxis, this.xAxis);\n erase(this.chart.axes, this.xAxis);\n }\n if (this.yAxis) {\n erase(this.chart.yAxis, this.yAxis);\n erase(this.chart.axes, this.yAxis);\n }\n // Destroy series\n (this.series || []).forEach((s) => {\n if (s.destroy) {\n s.destroy();\n }\n });\n // Destroy properties\n [\n 'series', 'xAxis', 'yAxis', 'shades', 'outline', 'scrollbarTrack',\n 'scrollbarRifles', 'scrollbarGroup', 'scrollbar', 'navigatorGroup',\n 'rendered'\n ].forEach((prop) => {\n if (this[prop] && this[prop].destroy) {\n this[prop].destroy();\n }\n this[prop] = null;\n });\n // Destroy elements in collection\n [this.handles].forEach((coll) => {\n destroyObjectProperties(coll);\n });\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return Navigator;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelectorDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Declarations\n *\n * */\n /**\n * Language object. The language object is global and it can't be set\n * on each chart initialization. Instead, use `Highcharts.setOptions` to\n * set it before any chart is initialized.\n *\n * ```js\n * Highcharts.setOptions({\n * lang: {\n * months: [\n * 'Janvier', 'Février', 'Mars', 'Avril',\n * 'Mai', 'Juin', 'Juillet', 'Août',\n * 'Septembre', 'Octobre', 'Novembre', 'Décembre'\n * ],\n * weekdays: [\n * 'Dimanche', 'Lundi', 'Mardi', 'Mercredi',\n * 'Jeudi', 'Vendredi', 'Samedi'\n * ]\n * }\n * });\n * ```\n *\n * @optionparent lang\n */\n const lang = {\n /**\n * The text for the label for the range selector buttons.\n *\n * @product highstock gantt\n */\n rangeSelectorZoom: 'Zoom',\n /**\n * The text for the label for the \"from\" input box in the range\n * selector. Since v9.0, this string is empty as the label is not\n * rendered by default.\n *\n * @product highstock gantt\n */\n rangeSelectorFrom: '',\n /**\n * The text for the label for the \"to\" input box in the range selector.\n *\n * @product highstock gantt\n */\n rangeSelectorTo: '→'\n };\n /**\n * The range selector is a tool for selecting ranges to display within\n * the chart. It provides buttons to select preconfigured ranges in\n * the chart, like 1 day, 1 week, 1 month etc. It also provides input\n * boxes where min and max dates can be manually input.\n *\n * @product highstock gantt\n * @optionparent rangeSelector\n */\n const rangeSelector = {\n /**\n * Whether to enable all buttons from the start. By default buttons are\n * only enabled if the corresponding time range exists on the X axis,\n * but enabling all buttons allows for dynamically loading different\n * time ranges.\n *\n * @sample {highstock} stock/rangeselector/allbuttonsenabled-true/\n * All buttons enabled\n *\n * @since 2.0.3\n */\n allButtonsEnabled: false,\n /**\n * An array of configuration objects for the buttons.\n *\n * Defaults to:\n * ```js\n * buttons: [{\n * type: 'month',\n * count: 1,\n * text: '1m',\n * title: 'View 1 month'\n * }, {\n * type: 'month',\n * count: 3,\n * text: '3m',\n * title: 'View 3 months'\n * }, {\n * type: 'month',\n * count: 6,\n * text: '6m',\n * title: 'View 6 months'\n * }, {\n * type: 'ytd',\n * text: 'YTD',\n * title: 'View year to date'\n * }, {\n * type: 'year',\n * count: 1,\n * text: '1y',\n * title: 'View 1 year'\n * }, {\n * type: 'all',\n * text: 'All',\n * title: 'View all'\n * }]\n * ```\n *\n * @sample {highstock} stock/rangeselector/datagrouping/\n * Data grouping by buttons\n *\n * @type {Array<*>}\n */\n buttons: void 0,\n /**\n * How many units of the defined type the button should span. If `type`\n * is \"month\" and `count` is 3, the button spans three months.\n *\n * @type {number}\n * @default 1\n * @apioption rangeSelector.buttons.count\n */\n /**\n * Fires when clicking on the rangeSelector button. One parameter,\n * event, is passed to the function, containing common event\n * information.\n *\n * ```js\n * click: function(e) {\n * console.log(this);\n * }\n * ```\n *\n * Return false to stop default button's click action.\n *\n * @sample {highstock} stock/rangeselector/button-click/\n * Click event on the button\n *\n * @type {Highcharts.RangeSelectorClickCallbackFunction}\n * @apioption rangeSelector.buttons.events.click\n */\n /**\n * Additional range (in milliseconds) added to the end of the calculated\n * time span.\n *\n * @sample {highstock} stock/rangeselector/min-max-offsets/\n * Button offsets\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @apioption rangeSelector.buttons.offsetMax\n */\n /**\n * Additional range (in milliseconds) added to the start of the\n * calculated time span.\n *\n * @sample {highstock} stock/rangeselector/min-max-offsets/\n * Button offsets\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @apioption rangeSelector.buttons.offsetMin\n */\n /**\n * When buttons apply dataGrouping on a series, by default zooming\n * in/out will deselect buttons and unset dataGrouping. Enable this\n * option to keep buttons selected when extremes change.\n *\n * @sample {highstock} stock/rangeselector/preserve-datagrouping/\n * Different preserveDataGrouping settings\n *\n * @type {boolean}\n * @default false\n * @since 6.1.2\n * @apioption rangeSelector.buttons.preserveDataGrouping\n */\n /**\n * A custom data grouping object for each button.\n *\n * @see [series.dataGrouping](#plotOptions.series.dataGrouping)\n *\n * @sample {highstock} stock/rangeselector/datagrouping/\n * Data grouping by range selector buttons\n *\n * @type {*}\n * @extends plotOptions.series.dataGrouping\n * @apioption rangeSelector.buttons.dataGrouping\n */\n /**\n * The text for the button itself.\n *\n * @type {string}\n * @apioption rangeSelector.buttons.text\n */\n /**\n * Explanation for the button, shown as a tooltip on hover, and used by\n * assistive technology.\n *\n * @type {string}\n * @apioption rangeSelector.buttons.title\n */\n /**\n * Defined the time span for the button. Can be one of `millisecond`,\n * `second`, `minute`, `hour`, `day`, `week`, `month`, `year`, `ytd`,\n * and `all`.\n *\n * @type {Highcharts.RangeSelectorButtonTypeValue}\n * @apioption rangeSelector.buttons.type\n */\n /**\n * The space in pixels between the buttons in the range selector.\n */\n buttonSpacing: 5,\n /**\n * Whether to collapse the range selector buttons into a dropdown when\n * there is not enough room to show everything in a single row, instead\n * of dividing the range selector into multiple rows.\n * Can be one of the following:\n * - `always`: Always collapse\n * - `responsive`: Only collapse when there is not enough room\n * - `never`: Never collapse\n *\n * @sample {highstock} stock/rangeselector/dropdown/\n * Dropdown option\n *\n * @validvalue [\"always\", \"responsive\", \"never\"]\n * @since 9.0.0\n */\n dropdown: 'responsive',\n /**\n * Enable or disable the range selector. Default to `true` for stock\n * charts, using the `stockChart` factory.\n *\n * @sample {highstock} stock/rangeselector/enabled/\n * Disable the range selector\n *\n * @type {boolean|undefined}\n * @default {highstock} true\n */\n enabled: void 0,\n /**\n * The vertical alignment of the rangeselector box. Allowed properties\n * are `top`, `middle`, `bottom`.\n *\n * @sample {highstock} stock/rangeselector/vertical-align-middle/\n * Middle\n * @sample {highstock} stock/rangeselector/vertical-align-bottom/\n * Bottom\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 6.0.0\n */\n verticalAlign: 'top',\n /**\n * A collection of attributes for the buttons. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width`, as well as `style`,\n * a collection of CSS properties for the text.\n *\n * The object can also be extended with states, so you can set\n * presentational options for `hover`, `select` or `disabled` button\n * states.\n *\n * CSS styles for the text label.\n *\n * In styled mode, the buttons are styled by the\n * `.highcharts-range-selector-buttons .highcharts-button` rule with its\n * different states.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.SVGAttributes}\n */\n buttonTheme: {\n /** @ignore */\n width: 28,\n /** @ignore */\n height: 18,\n /** @ignore */\n padding: 2,\n /** @ignore */\n zIndex: 7 // #484, #852\n },\n /**\n * When the rangeselector is floating, the plot area does not reserve\n * space for it. This opens for positioning anywhere on the chart.\n *\n * @sample {highstock} stock/rangeselector/floating/\n * Placing the range selector between the plot area and the\n * navigator\n *\n * @since 6.0.0\n */\n floating: false,\n /**\n * The x offset of the range selector relative to its horizontal\n * alignment within `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @since 6.0.0\n */\n x: 0,\n /**\n * The y offset of the range selector relative to its horizontal\n * alignment within `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @since 6.0.0\n */\n y: 0,\n /**\n * Deprecated. The height of the range selector. Currently it is\n * calculated dynamically.\n *\n * @deprecated\n * @type {number|undefined}\n * @since 2.1.9\n */\n height: void 0,\n /**\n * The border color of the date input boxes.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.ColorString}\n * @since 1.3.7\n */\n inputBoxBorderColor: 'none',\n /**\n * The pixel height of the date input boxes.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @since 1.3.7\n */\n inputBoxHeight: 17,\n /**\n * The pixel width of the date input boxes. When `undefined`, the width\n * is fitted to the rendered content.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {number|undefined}\n * @since 1.3.7\n */\n inputBoxWidth: void 0,\n /**\n * The date format in the input boxes when not selected for editing.\n * Defaults to `%e %b %Y`.\n *\n * This is used to determine which type of input to show,\n * `datetime-local`, `date` or `time` and falling back to `text` when\n * the browser does not support the input type or the format contains\n * milliseconds.\n *\n * @sample {highstock} stock/rangeselector/input-type/\n * Input types\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n */\n inputDateFormat: '%e %b %Y',\n /**\n * A custom callback function to parse values entered in the input boxes\n * and return a valid JavaScript time as milliseconds since 1970.\n * The first argument passed is a value to parse,\n * second is a boolean indicating use of the UTC time.\n *\n * This will only get called for inputs of type `text`. Since v8.2.3,\n * the input type is dynamically determined based on the granularity\n * of the `inputDateFormat` and the browser support.\n *\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n * @type {Highcharts.RangeSelectorParseCallbackFunction}\n * @since 1.3.3\n */\n inputDateParser: void 0,\n /**\n * The date format in the input boxes when they are selected for\n * editing. This must be a format that is recognized by JavaScript\n * Date.parse.\n *\n * This will only be used for inputs of type `text`. Since v8.2.3,\n * the input type is dynamically determined based on the granularity\n * of the `inputDateFormat` and the browser support.\n *\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n */\n inputEditDateFormat: '%Y-%m-%d',\n /**\n * Enable or disable the date input boxes.\n */\n inputEnabled: true,\n /**\n * Positioning for the input boxes. Allowed properties are `align`,\n * `x` and `y`.\n *\n * @since 1.2.4\n */\n inputPosition: {\n /**\n * The alignment of the input box. Allowed properties are `left`,\n * `center`, `right`.\n *\n * @sample {highstock} stock/rangeselector/input-button-position/\n * Alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 6.0.0\n */\n align: 'right',\n /**\n * X offset of the input row.\n */\n x: 0,\n /**\n * Y offset of the input row.\n */\n y: 0\n },\n /**\n * The space in pixels between the labels and the date input boxes in\n * the range selector.\n *\n * @since 9.0.0\n */\n inputSpacing: 5,\n /**\n * The index of the button to appear pre-selected.\n *\n * @type {number}\n */\n selected: void 0,\n /**\n * Positioning for the button row.\n *\n * @since 1.2.4\n */\n buttonPosition: {\n /**\n * The alignment of the input box. Allowed properties are `left`,\n * `center`, `right`.\n *\n * @sample {highstock} stock/rangeselector/input-button-position/\n * Alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 6.0.0\n */\n align: 'left',\n /**\n * X offset of the button row.\n */\n x: 0,\n /**\n * Y offset of the button row.\n */\n y: 0\n },\n /**\n * CSS for the HTML inputs in the range selector.\n *\n * In styled mode, the inputs are styled by the\n * `.highcharts-range-input text` rule in SVG mode, and\n * `input.highcharts-range-selector` when active.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.CSSObject}\n * @apioption rangeSelector.inputStyle\n */\n inputStyle: {\n /** @ignore */\n color: \"#334eff\" /* Palette.highlightColor80 */,\n /** @ignore */\n cursor: 'pointer',\n /** @ignore */\n fontSize: '0.8em'\n },\n /**\n * CSS styles for the labels - the Zoom, From and To texts.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-range-label` class.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.CSSObject}\n */\n labelStyle: {\n /** @ignore */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /** @ignore */\n fontSize: '0.8em'\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n const RangeSelectorDefaults = {\n lang,\n rangeSelector\n };\n\n return RangeSelectorDefaults;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelectorComposition.js', [_modules['Core/Defaults.js'], _modules['Stock/RangeSelector/RangeSelectorDefaults.js'], _modules['Core/Utilities.js']], function (D, RangeSelectorDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions, setOptions } = D;\n const { addEvent, defined, extend, find, isNumber, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const chartDestroyEvents = [];\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let RangeSelectorConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the axis min value based on the range option and the current max. For\n * stock charts this is extended via the {@link RangeSelector} so that if the\n * selected range is a multiple of months or years, it is compensated for\n * various month lengths.\n *\n * @private\n * @function Highcharts.Axis#minFromRange\n * @return {number|undefined}\n * The new minimum value.\n */\n function axisMinFromRange() {\n const rangeOptions = this.range, type = rangeOptions.type, max = this.max, time = this.chart.time, \n // Get the true range from a start date\n getTrueRange = function (base, count) {\n const timeName = type === 'year' ?\n 'FullYear' : 'Month';\n const date = new time.Date(base);\n const basePeriod = time.get(timeName, date);\n time.set(timeName, date, basePeriod + count);\n if (basePeriod === time.get(timeName, date)) {\n time.set('Date', date, 0); // #6537\n }\n return date.getTime() - base;\n };\n let min, range;\n if (isNumber(rangeOptions)) {\n min = max - rangeOptions;\n range = rangeOptions;\n }\n else if (rangeOptions) {\n min = max + getTrueRange(max, -(rangeOptions.count || 1));\n // Let the fixedRange reflect initial settings (#5930)\n if (this.chart) {\n this.chart.fixedRange = max - min;\n }\n }\n const dataMin = pick(this.dataMin, Number.MIN_VALUE);\n if (!isNumber(min)) {\n min = dataMin;\n }\n if (min <= dataMin) {\n min = dataMin;\n if (typeof range === 'undefined') { // #4501\n range = getTrueRange(min, rangeOptions.count);\n }\n this.newMax = Math.min(min + range, pick(this.dataMax, Number.MAX_VALUE));\n }\n if (!isNumber(max)) {\n min = void 0;\n }\n else if (!isNumber(rangeOptions) &&\n rangeOptions &&\n rangeOptions._offsetMin) {\n min += rangeOptions._offsetMin;\n }\n return min;\n }\n /**\n * @private\n */\n function compose(AxisClass, ChartClass, RangeSelectorClass) {\n RangeSelectorConstructor = RangeSelectorClass;\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.prototype.minFromRange = axisMinFromRange;\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'afterGetContainer', onChartAfterGetContainer);\n addEvent(ChartClass, 'beforeRender', onChartBeforeRender);\n addEvent(ChartClass, 'destroy', onChartDestroy);\n addEvent(ChartClass, 'getMargins', onChartGetMargins);\n addEvent(ChartClass, 'render', onChartRender);\n addEvent(ChartClass, 'update', onChartUpdate);\n const chartProto = ChartClass.prototype;\n chartProto.callbacks.push(onChartCallback);\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n extend(defaultOptions, { rangeSelector: RangeSelectorDefaults.rangeSelector });\n extend(defaultOptions.lang, RangeSelectorDefaults.lang);\n }\n }\n /**\n * Initialize rangeselector for stock charts\n * @private\n */\n function onChartAfterGetContainer() {\n if (this.options.rangeSelector &&\n this.options.rangeSelector.enabled) {\n this.rangeSelector = new RangeSelectorConstructor(this);\n }\n }\n /**\n * @private\n */\n function onChartBeforeRender() {\n const chart = this, axes = chart.axes, rangeSelector = chart.rangeSelector;\n if (rangeSelector) {\n if (isNumber(rangeSelector.deferredYTDClick)) {\n rangeSelector.clickButton(rangeSelector.deferredYTDClick);\n delete rangeSelector.deferredYTDClick;\n }\n axes.forEach((axis) => {\n axis.updateNames();\n axis.setScale();\n });\n chart.getAxisMargins();\n rangeSelector.render();\n const verticalAlign = rangeSelector.options.verticalAlign;\n if (!rangeSelector.options.floating) {\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n }\n }\n /**\n * @private\n */\n function onChartCallback(chart) {\n let extremes, legend, alignTo, verticalAlign;\n const rangeSelector = chart.rangeSelector, redraw = () => {\n if (rangeSelector) {\n extremes = chart.xAxis[0].getExtremes();\n legend = chart.legend;\n verticalAlign = (rangeSelector &&\n rangeSelector.options.verticalAlign);\n if (isNumber(extremes.min)) {\n rangeSelector.render(extremes.min, extremes.max);\n }\n // Re-align the legend so that it's below the rangeselector\n if (legend.display &&\n verticalAlign === 'top' &&\n verticalAlign === legend.options.verticalAlign) {\n // Create a new alignment box for the legend.\n alignTo = merge(chart.spacingBox);\n if (legend.options.layout === 'vertical') {\n alignTo.y = chart.plotTop;\n }\n else {\n alignTo.y += rangeSelector.getHeight();\n }\n legend.group.placed = false; // Don't animate the alignment.\n legend.align(alignTo);\n }\n }\n };\n if (rangeSelector) {\n const events = find(chartDestroyEvents, (e) => e[0] === chart);\n if (!events) {\n chartDestroyEvents.push([chart, [\n // redraw the scroller on setExtremes\n addEvent(chart.xAxis[0], 'afterSetExtremes', function (e) {\n if (rangeSelector) {\n rangeSelector.render(e.min, e.max);\n }\n }),\n // redraw the scroller chart resize\n addEvent(chart, 'redraw', redraw)\n ]]);\n }\n // do it now\n redraw();\n }\n }\n /**\n * Remove resize/afterSetExtremes at chart destroy.\n * @private\n */\n function onChartDestroy() {\n for (let i = 0, iEnd = chartDestroyEvents.length; i < iEnd; ++i) {\n const events = chartDestroyEvents[i];\n if (events[0] === this) {\n events[1].forEach((unbind) => unbind());\n chartDestroyEvents.splice(i, 1);\n return;\n }\n }\n }\n function onChartGetMargins() {\n const rangeSelector = this.rangeSelector;\n if (rangeSelector) {\n const rangeSelectorHeight = rangeSelector.getHeight();\n if (this.extraTopMargin) {\n this.plotTop += rangeSelectorHeight;\n }\n if (this.extraBottomMargin) {\n this.marginBottom += rangeSelectorHeight;\n }\n }\n }\n /**\n * @private\n */\n function onChartRender() {\n const chart = this, rangeSelector = chart.rangeSelector;\n if (rangeSelector && !rangeSelector.options.floating) {\n rangeSelector.render();\n const verticalAlign = rangeSelector.options.verticalAlign;\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n }\n /**\n * @private\n */\n function onChartUpdate(e) {\n const chart = this, options = e.options, optionsRangeSelector = options.rangeSelector, extraBottomMarginWas = this.extraBottomMargin, extraTopMarginWas = this.extraTopMargin;\n let rangeSelector = chart.rangeSelector;\n if (optionsRangeSelector &&\n optionsRangeSelector.enabled &&\n !defined(rangeSelector) &&\n this.options.rangeSelector) {\n this.options.rangeSelector.enabled = true;\n this.rangeSelector = rangeSelector = new RangeSelectorConstructor(this);\n }\n this.extraBottomMargin = false;\n this.extraTopMargin = false;\n if (rangeSelector) {\n onChartCallback(this);\n const verticalAlign = (optionsRangeSelector &&\n optionsRangeSelector.verticalAlign) || (rangeSelector.options && rangeSelector.options.verticalAlign);\n if (!rangeSelector.options.floating) {\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n if (this.extraBottomMargin !== extraBottomMarginWas ||\n this.extraTopMargin !== extraTopMarginWas) {\n this.isDirtyBox = true;\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const RangeSelectorComposition = {\n compose\n };\n\n return RangeSelectorComposition;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelector.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Stock/RangeSelector/RangeSelectorComposition.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (Axis, D, H, RangeSelectorComposition, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { addEvent, createElement, css, defined, destroyObjectProperties, discardElement, extend, fireEvent, isNumber, merge, objectEach, pad, pick, pInt, splat } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the preferred input type based on a date format string.\n *\n * @private\n * @function preferredInputType\n */\n function preferredInputType(format) {\n const ms = format.indexOf('%L') !== -1;\n if (ms) {\n return 'text';\n }\n const date = ['a', 'A', 'd', 'e', 'w', 'b', 'B', 'm', 'o', 'y', 'Y']\n .some((char) => format.indexOf('%' + char) !== -1);\n const time = ['H', 'k', 'I', 'l', 'M', 'S']\n .some((char) => format.indexOf('%' + char) !== -1);\n if (date && time) {\n return 'datetime-local';\n }\n if (date) {\n return 'date';\n }\n if (time) {\n return 'time';\n }\n return 'text';\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The range selector.\n *\n * @private\n * @class\n * @name Highcharts.RangeSelector\n * @param {Highcharts.Chart} chart\n */\n class RangeSelector {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n static compose(AxisClass, ChartClass) {\n RangeSelectorComposition.compose(AxisClass, ChartClass, RangeSelector);\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart) {\n /* *\n *\n * Properties\n *\n * */\n this.buttons = void 0;\n this.buttonOptions = RangeSelector.prototype.defaultButtons;\n this.initialButtonGroupWidth = 0;\n this.options = void 0;\n this.chart = chart;\n this.init(chart);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * The method to run when one of the buttons in the range selectors is\n * clicked\n *\n * @private\n * @function Highcharts.RangeSelector#clickButton\n * @param {number} i\n * The index of the button\n * @param {boolean} [redraw]\n */\n clickButton(i, redraw) {\n const rangeSelector = this, chart = rangeSelector.chart, rangeOptions = rangeSelector.buttonOptions[i], baseAxis = chart.xAxis[0], unionExtremes = (chart.scroller && chart.scroller.getUnionExtremes()) || baseAxis || {}, type = rangeOptions.type, dataGrouping = rangeOptions.dataGrouping;\n let dataMin = unionExtremes.dataMin, dataMax = unionExtremes.dataMax, newMin, newMax = baseAxis && Math.round(Math.min(baseAxis.max, pick(dataMax, baseAxis.max))), // #1568\n baseXAxisOptions, range = rangeOptions._range, rangeMin, minSetting, rangeSetting, ctx, ytdExtremes, addOffsetMin = true;\n // chart has no data, base series is removed\n if (dataMin === null || dataMax === null) {\n return;\n }\n // Set the fixed range before range is altered\n chart.fixedRange = range;\n rangeSelector.setSelected(i);\n // Apply dataGrouping associated to button\n if (dataGrouping) {\n this.forcedDataGrouping = true;\n Axis.prototype.setDataGrouping.call(baseAxis || { chart: this.chart }, dataGrouping, false);\n this.frozenStates = rangeOptions.preserveDataGrouping;\n }\n // Apply range\n if (type === 'month' || type === 'year') {\n if (!baseAxis) {\n // This is set to the user options and picked up later when the\n // axis is instantiated so that we know the min and max.\n range = rangeOptions;\n }\n else {\n ctx = {\n range: rangeOptions,\n max: newMax,\n chart: chart,\n dataMin: dataMin,\n dataMax: dataMax\n };\n newMin = baseAxis.minFromRange.call(ctx);\n if (isNumber(ctx.newMax)) {\n newMax = ctx.newMax;\n }\n // #15799: offsetMin is added in minFromRange so that it works\n // with pre-selected buttons as well\n addOffsetMin = false;\n }\n // Fixed times like minutes, hours, days\n }\n else if (range) {\n newMin = Math.max(newMax - range, dataMin);\n newMax = Math.min(newMin + range, dataMax);\n addOffsetMin = false;\n }\n else if (type === 'ytd') {\n // On user clicks on the buttons, or a delayed action running from\n // the beforeRender event (below), the baseAxis is defined.\n if (baseAxis) {\n // When \"ytd\" is the pre-selected button for the initial view,\n // its calculation is delayed and rerun in the beforeRender\n // event (below). When the series are initialized, but before\n // the chart is rendered, we have access to the xData array\n // (#942).\n if (typeof dataMax === 'undefined' ||\n typeof dataMin === 'undefined') {\n dataMin = Number.MAX_VALUE;\n dataMax = Number.MIN_VALUE;\n chart.series.forEach((series) => {\n // reassign it to the last item\n const xData = series.xData;\n if (xData) {\n dataMin = Math.min(xData[0], dataMin);\n dataMax = Math.max(xData[xData.length - 1], dataMax);\n }\n });\n redraw = false;\n }\n ytdExtremes = rangeSelector.getYTDExtremes(dataMax, dataMin, chart.time.useUTC);\n newMin = rangeMin = ytdExtremes.min;\n newMax = ytdExtremes.max;\n // \"ytd\" is pre-selected. We don't yet have access to processed\n // point and extremes data (things like pointStart and pointInterval\n // are missing), so we delay the process (#942)\n }\n else {\n rangeSelector.deferredYTDClick = i;\n return;\n }\n }\n else if (type === 'all' && baseAxis) {\n // If the navigator exist and the axis range is declared reset that\n // range and from now on only use the range set by a user, #14742.\n if (chart.navigator && chart.navigator.baseSeries[0]) {\n chart.navigator.baseSeries[0].xAxis.options.range = void 0;\n }\n newMin = dataMin;\n newMax = dataMax;\n }\n if (addOffsetMin && rangeOptions._offsetMin && defined(newMin)) {\n newMin += rangeOptions._offsetMin;\n }\n if (rangeOptions._offsetMax && defined(newMax)) {\n newMax += rangeOptions._offsetMax;\n }\n if (this.dropdown) {\n this.dropdown.selectedIndex = i + 1;\n }\n // Update the chart\n if (!baseAxis) {\n // Axis not yet instanciated. Temporarily set min and range\n // options and remove them on chart load (#4317).\n baseXAxisOptions = splat(chart.options.xAxis)[0];\n rangeSetting = baseXAxisOptions.range;\n baseXAxisOptions.range = range;\n minSetting = baseXAxisOptions.min;\n baseXAxisOptions.min = rangeMin;\n addEvent(chart, 'load', function resetMinAndRange() {\n baseXAxisOptions.range = rangeSetting;\n baseXAxisOptions.min = minSetting;\n });\n }\n else {\n // Existing axis object. Set extremes after render time.\n baseAxis.setExtremes(newMin, newMax, pick(redraw, true), void 0, // auto animation\n {\n trigger: 'rangeSelectorButton',\n rangeSelectorButton: rangeOptions\n });\n }\n fireEvent(this, 'afterBtnClick');\n }\n /**\n * Set the selected option. This method only sets the internal flag, it\n * doesn't update the buttons or the actual zoomed range.\n *\n * @private\n * @function Highcharts.RangeSelector#setSelected\n * @param {number} [selected]\n */\n setSelected(selected) {\n this.selected = this.options.selected = selected;\n }\n /**\n * Initialize the range selector\n *\n * @private\n * @function Highcharts.RangeSelector#init\n * @param {Highcharts.Chart} chart\n */\n init(chart) {\n const rangeSelector = this, options = chart.options.rangeSelector, buttonOptions = (options.buttons || rangeSelector.defaultButtons.slice()), selectedOption = options.selected, blurInputs = function () {\n const minInput = rangeSelector.minInput, maxInput = rangeSelector.maxInput;\n // #3274 in some case blur is not defined\n if (minInput && (minInput.blur)) {\n fireEvent(minInput, 'blur');\n }\n if (maxInput && (maxInput.blur)) {\n fireEvent(maxInput, 'blur');\n }\n };\n rangeSelector.chart = chart;\n rangeSelector.options = options;\n rangeSelector.buttons = [];\n rangeSelector.buttonOptions = buttonOptions;\n this.eventsToUnbind = [];\n this.eventsToUnbind.push(addEvent(chart.container, 'mousedown', blurInputs));\n this.eventsToUnbind.push(addEvent(chart, 'resize', blurInputs));\n // Extend the buttonOptions with actual range\n buttonOptions.forEach(rangeSelector.computeButtonRange);\n // zoomed range based on a pre-selected button index\n if (typeof selectedOption !== 'undefined' &&\n buttonOptions[selectedOption]) {\n this.clickButton(selectedOption, false);\n }\n this.eventsToUnbind.push(addEvent(chart, 'load', function () {\n // If a data grouping is applied to the current button, release it\n // when extremes change\n if (chart.xAxis && chart.xAxis[0]) {\n addEvent(chart.xAxis[0], 'setExtremes', function (e) {\n if (this.max - this.min !==\n chart.fixedRange &&\n e.trigger !== 'rangeSelectorButton' &&\n e.trigger !== 'updatedData' &&\n rangeSelector.forcedDataGrouping &&\n !rangeSelector.frozenStates) {\n this.setDataGrouping(false, false);\n }\n });\n }\n }));\n }\n /**\n * Dynamically update the range selector buttons after a new range has been\n * set\n *\n * @private\n * @function Highcharts.RangeSelector#updateButtonStates\n */\n updateButtonStates() {\n const rangeSelector = this, chart = this.chart, dropdown = this.dropdown, baseAxis = chart.xAxis[0], actualRange = Math.round(baseAxis.max - baseAxis.min), hasNoData = !baseAxis.hasVisibleSeries, day = 24 * 36e5, // A single day in milliseconds\n unionExtremes = (chart.scroller &&\n chart.scroller.getUnionExtremes()) || baseAxis, dataMin = unionExtremes.dataMin, dataMax = unionExtremes.dataMax, ytdExtremes = rangeSelector.getYTDExtremes(dataMax, dataMin, chart.time.useUTC), ytdMin = ytdExtremes.min, ytdMax = ytdExtremes.max, selected = rangeSelector.selected, allButtonsEnabled = rangeSelector.options.allButtonsEnabled, buttons = rangeSelector.buttons;\n let selectedExists = isNumber(selected);\n rangeSelector.buttonOptions.forEach((rangeOptions, i) => {\n const range = rangeOptions._range, type = rangeOptions.type, count = rangeOptions.count || 1, button = buttons[i], offsetRange = rangeOptions._offsetMax -\n rangeOptions._offsetMin, isSelected = i === selected, \n // Disable buttons where the range exceeds what is allowed in\n // the current view\n isTooGreatRange = range >\n dataMax - dataMin, \n // Disable buttons where the range is smaller than the minimum\n // range\n isTooSmallRange = range < baseAxis.minRange;\n let state = 0, \n // Do not select the YTD button if not explicitly told so\n isYTDButNotSelected = false, \n // Disable the All button if we're already showing all\n isAllButAlreadyShowingAll = false, isSameRange = range === actualRange;\n // Months and years have a variable range so we check the extremes\n if ((type === 'month' || type === 'year') &&\n (actualRange + 36e5 >=\n { month: 28, year: 365 }[type] * day * count - offsetRange) &&\n (actualRange - 36e5 <=\n { month: 31, year: 366 }[type] * day * count + offsetRange)) {\n isSameRange = true;\n }\n else if (type === 'ytd') {\n isSameRange = (ytdMax - ytdMin + offsetRange) === actualRange;\n isYTDButNotSelected = !isSelected;\n }\n else if (type === 'all') {\n isSameRange = (baseAxis.max - baseAxis.min >=\n dataMax - dataMin);\n isAllButAlreadyShowingAll = (!isSelected &&\n selectedExists &&\n isSameRange);\n }\n // The new zoom area happens to match the range for a button - mark\n // it selected. This happens when scrolling across an ordinal gap.\n // It can be seen in the intraday demos when selecting 1h and scroll\n // across the night gap.\n const disable = (!allButtonsEnabled &&\n (isTooGreatRange ||\n isTooSmallRange ||\n isAllButAlreadyShowingAll ||\n hasNoData));\n const select = ((isSelected && isSameRange) ||\n (isSameRange && !selectedExists && !isYTDButNotSelected) ||\n (isSelected && rangeSelector.frozenStates));\n if (disable) {\n state = 3;\n }\n else if (select) {\n selectedExists = true; // Only one button can be selected\n state = 2;\n }\n // If state has changed, update the button\n if (button.state !== state) {\n button.setState(state);\n if (dropdown) {\n dropdown.options[i + 1].disabled = disable;\n if (state === 2) {\n dropdown.selectedIndex = i + 1;\n }\n }\n // Reset (#9209)\n if (state === 0 && selected === i) {\n rangeSelector.setSelected();\n }\n }\n });\n }\n /**\n * Compute and cache the range for an individual button\n *\n * @private\n * @function Highcharts.RangeSelector#computeButtonRange\n * @param {Highcharts.RangeSelectorButtonsOptions} rangeOptions\n */\n computeButtonRange(rangeOptions) {\n const type = rangeOptions.type, count = rangeOptions.count || 1, \n // these time intervals have a fixed number of milliseconds, as\n // opposed to month, ytd and year\n fixedTimes = {\n millisecond: 1,\n second: 1000,\n minute: 60 * 1000,\n hour: 3600 * 1000,\n day: 24 * 3600 * 1000,\n week: 7 * 24 * 3600 * 1000\n };\n // Store the range on the button object\n if (fixedTimes[type]) {\n rangeOptions._range = fixedTimes[type] * count;\n }\n else if (type === 'month' || type === 'year') {\n rangeOptions._range = {\n month: 30,\n year: 365\n }[type] * 24 * 36e5 * count;\n }\n rangeOptions._offsetMin = pick(rangeOptions.offsetMin, 0);\n rangeOptions._offsetMax = pick(rangeOptions.offsetMax, 0);\n rangeOptions._range +=\n rangeOptions._offsetMax - rangeOptions._offsetMin;\n }\n /**\n * Get the unix timestamp of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#getInputValue\n */\n getInputValue(name) {\n const input = name === 'min' ? this.minInput : this.maxInput;\n const options = this.chart.options\n .rangeSelector;\n const time = this.chart.time;\n if (input) {\n return ((input.type === 'text' && options.inputDateParser) ||\n this.defaultInputDateParser)(input.value, time.useUTC, time);\n }\n return 0;\n }\n /**\n * Set the internal and displayed value of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#setInputValue\n */\n setInputValue(name, inputTime) {\n const options = this.options, time = this.chart.time, input = name === 'min' ? this.minInput : this.maxInput, dateBox = name === 'min' ? this.minDateBox : this.maxDateBox;\n if (input) {\n const hcTimeAttr = input.getAttribute('data-hc-time');\n let updatedTime = defined(hcTimeAttr) ? Number(hcTimeAttr) : void 0;\n if (defined(inputTime)) {\n const previousTime = updatedTime;\n if (defined(previousTime)) {\n input.setAttribute('data-hc-time-previous', previousTime);\n }\n input.setAttribute('data-hc-time', inputTime);\n updatedTime = inputTime;\n }\n input.value = time.dateFormat((this.inputTypeFormats[input.type] ||\n options.inputEditDateFormat), updatedTime);\n if (dateBox) {\n dateBox.attr({\n text: time.dateFormat(options.inputDateFormat, updatedTime)\n });\n }\n }\n }\n /**\n * Set the min and max value of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#setInputExtremes\n */\n setInputExtremes(name, min, max) {\n const input = name === 'min' ? this.minInput : this.maxInput;\n if (input) {\n const format = this.inputTypeFormats[input.type];\n const time = this.chart.time;\n if (format) {\n const newMin = time.dateFormat(format, min);\n if (input.min !== newMin) {\n input.min = newMin;\n }\n const newMax = time.dateFormat(format, max);\n if (input.max !== newMax) {\n input.max = newMax;\n }\n }\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#showInput\n * @param {string} name\n */\n showInput(name) {\n const dateBox = name === 'min' ? this.minDateBox : this.maxDateBox;\n const input = name === 'min' ? this.minInput : this.maxInput;\n if (input && dateBox && this.inputGroup) {\n const isTextInput = input.type === 'text';\n const { translateX, translateY } = this.inputGroup;\n const { inputBoxWidth } = this.options;\n css(input, {\n width: isTextInput ?\n ((dateBox.width + (inputBoxWidth ? -2 : 20)) + 'px') :\n 'auto',\n height: (dateBox.height - 2) + 'px',\n border: '2px solid silver'\n });\n if (isTextInput && inputBoxWidth) {\n css(input, {\n left: (translateX + dateBox.x) + 'px',\n top: translateY + 'px'\n });\n // Inputs of types date, time or datetime-local should be centered\n // on top of the dateBox\n }\n else {\n css(input, {\n left: Math.min(Math.round(dateBox.x +\n translateX -\n (input.offsetWidth - dateBox.width) / 2), this.chart.chartWidth - input.offsetWidth) + 'px',\n top: (translateY - (input.offsetHeight - dateBox.height) / 2) + 'px'\n });\n }\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#hideInput\n * @param {string} name\n */\n hideInput(name) {\n const input = name === 'min' ? this.minInput : this.maxInput;\n if (input) {\n css(input, {\n top: '-9999em',\n border: 0,\n width: '1px',\n height: '1px'\n });\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#defaultInputDateParser\n */\n defaultInputDateParser(inputDate, useUTC, time) {\n const hasTimezone = (str) => str.length > 6 &&\n (str.lastIndexOf('-') === str.length - 6 ||\n str.lastIndexOf('+') === str.length - 6);\n let input = inputDate.split('/').join('-').split(' ').join('T');\n if (input.indexOf('T') === -1) {\n input += 'T00:00';\n }\n if (useUTC) {\n input += 'Z';\n }\n else if (H.isSafari && !hasTimezone(input)) {\n const offset = new Date(input).getTimezoneOffset() / 60;\n input += offset <= 0 ? `+${pad(-offset)}:00` : `-${pad(offset)}:00`;\n }\n let date = Date.parse(input);\n // If the value isn't parsed directly to a value by the\n // browser's Date.parse method, try\n // parsing it a different way\n if (!isNumber(date)) {\n const parts = inputDate.split('-');\n date = Date.UTC(pInt(parts[0]), pInt(parts[1]) - 1, pInt(parts[2]));\n }\n if (time && useUTC && isNumber(date)) {\n date += time.getTimezoneOffset(date);\n }\n return date;\n }\n /**\n * Draw either the 'from' or the 'to' HTML input box of the range selector\n *\n * @private\n * @function Highcharts.RangeSelector#drawInput\n */\n drawInput(name) {\n const { chart, div, inputGroup } = this;\n const rangeSelector = this, chartStyle = chart.renderer.style || {}, renderer = chart.renderer, options = chart.options.rangeSelector, lang = defaultOptions.lang, isMin = name === 'min';\n /**\n * @private\n */\n function updateExtremes() {\n const { maxInput, minInput } = rangeSelector, chartAxis = chart.xAxis[0], dataAxis = chart.scroller && chart.scroller.xAxis ?\n chart.scroller.xAxis :\n chartAxis, dataMin = dataAxis.dataMin, dataMax = dataAxis.dataMax;\n let value = rangeSelector.getInputValue(name);\n if (value !== Number(input.getAttribute('data-hc-time-previous')) &&\n isNumber(value)) {\n input.setAttribute('data-hc-time-previous', value);\n // Validate the extremes. If it goes beyound the data min or\n // max, use the actual data extreme (#2438).\n if (isMin && maxInput && isNumber(dataMin)) {\n if (value > Number(maxInput.getAttribute('data-hc-time'))) {\n value = void 0;\n }\n else if (value < dataMin) {\n value = dataMin;\n }\n }\n else if (minInput && isNumber(dataMax)) {\n if (value < Number(minInput.getAttribute('data-hc-time'))) {\n value = void 0;\n }\n else if (value > dataMax) {\n value = dataMax;\n }\n }\n // Set the extremes\n if (typeof value !== 'undefined') { // @todo typof undefined\n chartAxis.setExtremes(isMin ? value : chartAxis.min, isMin ? chartAxis.max : value, void 0, void 0, { trigger: 'rangeSelectorInput' });\n }\n }\n }\n // Create the text label\n const text = lang[isMin ? 'rangeSelectorFrom' : 'rangeSelectorTo'] || '';\n const label = renderer\n .label(text, 0)\n .addClass('highcharts-range-label')\n .attr({\n padding: text ? 2 : 0,\n height: text ? options.inputBoxHeight : 0\n })\n .add(inputGroup);\n // Create an SVG label that shows updated date ranges and and records\n // click events that bring in the HTML input.\n const dateBox = renderer\n .label('', 0)\n .addClass('highcharts-range-input')\n .attr({\n padding: 2,\n width: options.inputBoxWidth,\n height: options.inputBoxHeight,\n 'text-align': 'center'\n })\n .on('click', function () {\n // If it is already focused, the onfocus event doesn't fire\n // (#3713)\n rangeSelector.showInput(name);\n rangeSelector[name + 'Input'].focus();\n });\n if (!chart.styledMode) {\n dateBox.attr({\n stroke: options.inputBoxBorderColor,\n 'stroke-width': 1\n });\n }\n dateBox.add(inputGroup);\n // Create the HTML input element. This is rendered as 1x1 pixel then set\n // to the right size when focused.\n const input = createElement('input', {\n name: name,\n className: 'highcharts-range-selector'\n }, void 0, div);\n // #14788: Setting input.type to an unsupported type throws in IE, so\n // we need to use setAttribute instead\n input.setAttribute('type', preferredInputType(options.inputDateFormat || '%e %b %Y'));\n if (!chart.styledMode) {\n // Styles\n label.css(merge(chartStyle, options.labelStyle));\n dateBox.css(merge({\n color: \"#333333\" /* Palette.neutralColor80 */\n }, chartStyle, options.inputStyle));\n css(input, extend({\n position: 'absolute',\n border: 0,\n boxShadow: '0 0 15px rgba(0,0,0,0.3)',\n width: '1px',\n height: '1px',\n padding: 0,\n textAlign: 'center',\n fontSize: chartStyle.fontSize,\n fontFamily: chartStyle.fontFamily,\n top: '-9999em' // #4798\n }, options.inputStyle));\n }\n // Blow up the input box\n input.onfocus = () => {\n rangeSelector.showInput(name);\n };\n // Hide away the input box\n input.onblur = () => {\n // update extermes only when inputs are active\n if (input === H.doc.activeElement) { // Only when focused\n // Update also when no `change` event is triggered, like when\n // clicking inside the SVG (#4710)\n updateExtremes();\n }\n // #10404 - move hide and blur outside focus\n rangeSelector.hideInput(name);\n rangeSelector.setInputValue(name);\n input.blur(); // #4606\n };\n let keyDown = false;\n // handle changes in the input boxes\n input.onchange = () => {\n // Update extremes and blur input when clicking date input calendar\n if (!keyDown) {\n updateExtremes();\n rangeSelector.hideInput(name);\n input.blur();\n }\n };\n input.onkeypress = (event) => {\n // IE does not fire onchange on enter\n if (event.keyCode === 13) {\n updateExtremes();\n }\n };\n input.onkeydown = (event) => {\n keyDown = true;\n // Arrow keys\n if (event.keyCode === 38 || event.keyCode === 40) {\n updateExtremes();\n }\n };\n input.onkeyup = () => {\n keyDown = false;\n };\n return { dateBox, input, label };\n }\n /**\n * Get the position of the range selector buttons and inputs. This can be\n * overridden from outside for custom positioning.\n *\n * @private\n * @function Highcharts.RangeSelector#getPosition\n */\n getPosition() {\n const chart = this.chart, options = chart.options.rangeSelector, top = options.verticalAlign === 'top' ?\n chart.plotTop - chart.axisOffset[0] :\n 0; // set offset only for varticalAlign top\n return {\n buttonTop: top + options.buttonPosition.y,\n inputTop: top + options.inputPosition.y - 10\n };\n }\n /**\n * Get the extremes of YTD. Will choose dataMax if its value is lower than\n * the current timestamp. Will choose dataMin if its value is higher than\n * the timestamp for the start of current year.\n *\n * @private\n * @function Highcharts.RangeSelector#getYTDExtremes\n * @return {*}\n * Returns min and max for the YTD\n */\n getYTDExtremes(dataMax, dataMin, useUTC) {\n const time = this.chart.time, now = new time.Date(dataMax), year = time.get('FullYear', now), startOfYear = useUTC ?\n time.Date.UTC(year, 0, 1) : // eslint-disable-line new-cap\n +new time.Date(year, 0, 1), min = Math.max(dataMin, startOfYear), ts = now.getTime();\n return {\n max: Math.min(dataMax || ts, ts),\n min\n };\n }\n /**\n * Render the range selector including the buttons and the inputs. The first\n * time render is called, the elements are created and positioned. On\n * subsequent calls, they are moved and updated.\n *\n * @private\n * @function Highcharts.RangeSelector#render\n * @param {number} [min]\n * X axis minimum\n * @param {number} [max]\n * X axis maximum\n */\n render(min, max) {\n const chart = this.chart, renderer = chart.renderer, container = chart.container, chartOptions = chart.options, options = chartOptions.rangeSelector, \n // Place inputs above the container\n inputsZIndex = pick(chartOptions.chart.style &&\n chartOptions.chart.style.zIndex, 0) + 1, inputEnabled = options.inputEnabled, rendered = this.rendered;\n if (options.enabled === false) {\n return;\n }\n // create the elements\n if (!rendered) {\n this.group = renderer.g('range-selector-group')\n .attr({\n zIndex: 7\n })\n .add();\n this.div = createElement('div', void 0, {\n position: 'relative',\n height: 0,\n zIndex: inputsZIndex\n });\n if (this.buttonOptions.length) {\n this.renderButtons();\n }\n // First create a wrapper outside the container in order to make\n // the inputs work and make export correct\n if (container.parentNode) {\n container.parentNode.insertBefore(this.div, container);\n }\n if (inputEnabled) {\n // Create the group to keep the inputs\n this.inputGroup = renderer.g('input-group').add(this.group);\n const minElems = this.drawInput('min');\n this.minDateBox = minElems.dateBox;\n this.minLabel = minElems.label;\n this.minInput = minElems.input;\n const maxElems = this.drawInput('max');\n this.maxDateBox = maxElems.dateBox;\n this.maxLabel = maxElems.label;\n this.maxInput = maxElems.input;\n }\n }\n if (inputEnabled) {\n // Set or reset the input values\n this.setInputValue('min', min);\n this.setInputValue('max', max);\n const unionExtremes = (chart.scroller && chart.scroller.getUnionExtremes()) || chart.xAxis[0] || {};\n if (defined(unionExtremes.dataMin) &&\n defined(unionExtremes.dataMax)) {\n const minRange = chart.xAxis[0].minRange || 0;\n this.setInputExtremes('min', unionExtremes.dataMin, Math.min(unionExtremes.dataMax, this.getInputValue('max')) - minRange);\n this.setInputExtremes('max', Math.max(unionExtremes.dataMin, this.getInputValue('min')) + minRange, unionExtremes.dataMax);\n }\n // Reflow\n if (this.inputGroup) {\n let x = 0;\n [\n this.minLabel,\n this.minDateBox,\n this.maxLabel,\n this.maxDateBox\n ].forEach((label) => {\n if (label) {\n const { width } = label.getBBox();\n if (width) {\n label.attr({ x });\n x += width + options.inputSpacing;\n }\n }\n });\n }\n }\n this.alignElements();\n this.rendered = true;\n }\n /**\n * Render the range buttons. This only runs the first time, later the\n * positioning is laid out in alignElements.\n *\n * @private\n * @function Highcharts.RangeSelector#renderButtons\n */\n renderButtons() {\n const { buttons, chart, options } = this;\n const lang = defaultOptions.lang;\n const renderer = chart.renderer;\n const buttonTheme = merge(options.buttonTheme);\n const states = buttonTheme && buttonTheme.states;\n // Prevent the button from resetting the width when the button state\n // changes since we need more control over the width when collapsing\n // the buttons\n const width = buttonTheme.width || 28;\n delete buttonTheme.width;\n delete buttonTheme.states;\n this.buttonGroup = renderer.g('range-selector-buttons').add(this.group);\n const dropdown = this.dropdown = createElement('select', void 0, {\n position: 'absolute',\n width: '1px',\n height: '1px',\n padding: 0,\n border: 0,\n top: '-9999em',\n cursor: 'pointer',\n opacity: 0.0001\n }, this.div);\n // Prevent page zoom on iPhone\n addEvent(dropdown, 'touchstart', () => {\n dropdown.style.fontSize = '16px';\n });\n // Forward events from select to button\n [\n [H.isMS ? 'mouseover' : 'mouseenter'],\n [H.isMS ? 'mouseout' : 'mouseleave'],\n ['change', 'click']\n ].forEach(([from, to]) => {\n addEvent(dropdown, from, () => {\n const button = buttons[this.currentButtonIndex()];\n if (button) {\n fireEvent(button.element, to || from);\n }\n });\n });\n this.zoomText = renderer\n .label((lang && lang.rangeSelectorZoom) || '', 0)\n .attr({\n padding: options.buttonTheme.padding,\n height: options.buttonTheme.height,\n paddingLeft: 0,\n paddingRight: 0\n })\n .add(this.buttonGroup);\n if (!this.chart.styledMode) {\n this.zoomText.css(options.labelStyle);\n buttonTheme['stroke-width'] = pick(buttonTheme['stroke-width'], 0);\n }\n createElement('option', {\n textContent: this.zoomText.textStr,\n disabled: true\n }, void 0, dropdown);\n this.buttonOptions.forEach((rangeOptions, i) => {\n createElement('option', {\n textContent: rangeOptions.title || rangeOptions.text\n }, void 0, dropdown);\n buttons[i] = renderer\n .button(rangeOptions.text, 0, 0, (e) => {\n // extract events from button object and call\n const buttonEvents = (rangeOptions.events && rangeOptions.events.click);\n let callDefaultEvent;\n if (buttonEvents) {\n callDefaultEvent =\n buttonEvents.call(rangeOptions, e);\n }\n if (callDefaultEvent !== false) {\n this.clickButton(i);\n }\n this.isActive = true;\n }, buttonTheme, states && states.hover, states && states.select, states && states.disabled)\n .attr({\n 'text-align': 'center',\n width\n })\n .add(this.buttonGroup);\n if (rangeOptions.title) {\n buttons[i].attr('title', rangeOptions.title);\n }\n });\n }\n /**\n * Align the elements horizontally and vertically.\n *\n * @private\n * @function Highcharts.RangeSelector#alignElements\n */\n alignElements() {\n const { buttonGroup, buttons, chart, group, inputGroup, options, zoomText } = this;\n const chartOptions = chart.options;\n const navButtonOptions = (chartOptions.exporting &&\n chartOptions.exporting.enabled !== false &&\n chartOptions.navigation &&\n chartOptions.navigation.buttonOptions);\n const { buttonPosition, inputPosition, verticalAlign } = options;\n // Get the X offset required to avoid overlapping with the exporting\n // button. This is is used both by the buttonGroup and the inputGroup.\n const getXOffsetForExportButton = (group, position) => {\n if (navButtonOptions &&\n this.titleCollision(chart) &&\n verticalAlign === 'top' &&\n position.align === 'right' && ((position.y -\n group.getBBox().height - 12) <\n ((navButtonOptions.y || 0) +\n (navButtonOptions.height || 0) +\n chart.spacing[0]))) {\n return -40;\n }\n return 0;\n };\n let plotLeft = chart.plotLeft;\n if (group && buttonPosition && inputPosition) {\n let translateX = buttonPosition.x - chart.spacing[3];\n if (buttonGroup) {\n this.positionButtons();\n if (!this.initialButtonGroupWidth) {\n let width = 0;\n if (zoomText) {\n width += zoomText.getBBox().width + 5;\n }\n buttons.forEach((button, i) => {\n width += button.width;\n if (i !== buttons.length - 1) {\n width += options.buttonSpacing;\n }\n });\n this.initialButtonGroupWidth = width;\n }\n plotLeft -= chart.spacing[3];\n this.updateButtonStates();\n // Detect collision between button group and exporting\n const xOffsetForExportButton = getXOffsetForExportButton(buttonGroup, buttonPosition);\n this.alignButtonGroup(xOffsetForExportButton);\n // Skip animation\n group.placed = buttonGroup.placed = chart.hasLoaded;\n }\n let xOffsetForExportButton = 0;\n if (inputGroup) {\n // Detect collision between the input group and exporting button\n xOffsetForExportButton = getXOffsetForExportButton(inputGroup, inputPosition);\n if (inputPosition.align === 'left') {\n translateX = plotLeft;\n }\n else if (inputPosition.align === 'right') {\n translateX = -Math.max(chart.axisOffset[1], -xOffsetForExportButton);\n }\n // Update the alignment to the updated spacing box\n inputGroup.align({\n y: inputPosition.y,\n width: inputGroup.getBBox().width,\n align: inputPosition.align,\n // fix wrong getBBox() value on right align\n x: inputPosition.x + translateX - 2\n }, true, chart.spacingBox);\n // Skip animation\n inputGroup.placed = chart.hasLoaded;\n }\n this.handleCollision(xOffsetForExportButton);\n // Vertical align\n group.align({\n verticalAlign\n }, true, chart.spacingBox);\n const alignTranslateY = group.alignAttr.translateY;\n // Set position\n let groupHeight = group.getBBox().height + 20; // # 20 padding\n let translateY = 0;\n // Calculate bottom position\n if (verticalAlign === 'bottom') {\n const legendOptions = chart.legend && chart.legend.options;\n const legendHeight = (legendOptions &&\n legendOptions.verticalAlign === 'bottom' &&\n legendOptions.enabled &&\n !legendOptions.floating ?\n (chart.legend.legendHeight +\n pick(legendOptions.margin, 10)) :\n 0);\n groupHeight = groupHeight + legendHeight - 20;\n translateY = (alignTranslateY -\n groupHeight -\n (options.floating ? 0 : options.y) -\n (chart.titleOffset ? chart.titleOffset[2] : 0) -\n 10 // 10 spacing\n );\n }\n if (verticalAlign === 'top') {\n if (options.floating) {\n translateY = 0;\n }\n if (chart.titleOffset && chart.titleOffset[0]) {\n translateY = chart.titleOffset[0];\n }\n translateY += ((chart.margin[0] - chart.spacing[0]) || 0);\n }\n else if (verticalAlign === 'middle') {\n if (inputPosition.y === buttonPosition.y) {\n translateY = alignTranslateY;\n }\n else if (inputPosition.y || buttonPosition.y) {\n if (inputPosition.y < 0 ||\n buttonPosition.y < 0) {\n translateY -= Math.min(inputPosition.y, buttonPosition.y);\n }\n else {\n translateY = alignTranslateY - groupHeight;\n }\n }\n }\n group.translate(options.x, options.y + Math.floor(translateY));\n // Translate HTML inputs\n const { minInput, maxInput, dropdown } = this;\n if (options.inputEnabled && minInput && maxInput) {\n minInput.style.marginTop = group.translateY + 'px';\n maxInput.style.marginTop = group.translateY + 'px';\n }\n if (dropdown) {\n dropdown.style.marginTop = group.translateY + 'px';\n }\n }\n }\n /**\n * Align the button group horizontally and vertically.\n *\n * @private\n * @function Highcharts.RangeSelector#alignButtonGroup\n * @param {number} xOffsetForExportButton\n * @param {number} [width]\n */\n alignButtonGroup(xOffsetForExportButton, width) {\n const { chart, options, buttonGroup, buttons } = this;\n const { buttonPosition } = options;\n const plotLeft = chart.plotLeft - chart.spacing[3];\n let translateX = buttonPosition.x - chart.spacing[3];\n if (buttonPosition.align === 'right') {\n translateX += xOffsetForExportButton - plotLeft; // #13014\n }\n else if (buttonPosition.align === 'center') {\n translateX -= plotLeft / 2;\n }\n if (buttonGroup) {\n // Align button group\n buttonGroup.align({\n y: buttonPosition.y,\n width: pick(width, this.initialButtonGroupWidth),\n align: buttonPosition.align,\n x: translateX\n }, true, chart.spacingBox);\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#positionButtons\n */\n positionButtons() {\n const { buttons, chart, options, zoomText } = this;\n const verb = chart.hasLoaded ? 'animate' : 'attr';\n const { buttonPosition } = options;\n const plotLeft = chart.plotLeft;\n let buttonLeft = plotLeft;\n if (zoomText && zoomText.visibility !== 'hidden') {\n // #8769, allow dynamically updating margins\n zoomText[verb]({\n x: pick(plotLeft + buttonPosition.x, plotLeft)\n });\n // Button start position\n buttonLeft += buttonPosition.x +\n zoomText.getBBox().width + 5;\n }\n for (let i = 0, iEnd = this.buttonOptions.length; i < iEnd; ++i) {\n if (buttons[i].visibility !== 'hidden') {\n buttons[i][verb]({ x: buttonLeft });\n // increase button position for the next button\n buttonLeft += buttons[i].width + options.buttonSpacing;\n }\n else {\n buttons[i][verb]({ x: plotLeft });\n }\n }\n }\n /**\n * Handle collision between the button group and the input group\n *\n * @private\n * @function Highcharts.RangeSelector#handleCollision\n *\n * @param {number} xOffsetForExportButton\n * The X offset of the group required to make room for the\n * exporting button\n */\n handleCollision(xOffsetForExportButton) {\n const { chart, buttonGroup, inputGroup } = this;\n const { buttonPosition, dropdown, inputPosition } = this.options;\n const maxButtonWidth = () => {\n let buttonWidth = 0;\n this.buttons.forEach((button) => {\n const bBox = button.getBBox();\n if (bBox.width > buttonWidth) {\n buttonWidth = bBox.width;\n }\n });\n return buttonWidth;\n };\n const groupsOverlap = (buttonGroupWidth) => {\n if (inputGroup && buttonGroup) {\n const inputGroupX = (inputGroup.alignAttr.translateX +\n inputGroup.alignOptions.x -\n xOffsetForExportButton +\n // getBBox for detecing left margin\n inputGroup.getBBox().x +\n // 2px padding to not overlap input and label\n 2);\n const inputGroupWidth = inputGroup.alignOptions.width;\n const buttonGroupX = buttonGroup.alignAttr.translateX +\n buttonGroup.getBBox().x;\n return (buttonGroupX + buttonGroupWidth > inputGroupX) &&\n (inputGroupX + inputGroupWidth > buttonGroupX) &&\n (buttonPosition.y <\n (inputPosition.y +\n inputGroup.getBBox().height));\n }\n return false;\n };\n const moveInputsDown = () => {\n if (inputGroup && buttonGroup) {\n inputGroup.attr({\n translateX: inputGroup.alignAttr.translateX + (chart.axisOffset[1] >= -xOffsetForExportButton ?\n 0 :\n -xOffsetForExportButton),\n translateY: inputGroup.alignAttr.translateY +\n buttonGroup.getBBox().height + 10\n });\n }\n };\n if (buttonGroup) {\n if (dropdown === 'always') {\n this.collapseButtons(xOffsetForExportButton);\n if (groupsOverlap(maxButtonWidth())) {\n // Move the inputs down if there is still a collision\n // after collapsing the buttons\n moveInputsDown();\n }\n return;\n }\n if (dropdown === 'never') {\n this.expandButtons();\n }\n }\n // Detect collision\n if (inputGroup && buttonGroup) {\n if ((inputPosition.align === buttonPosition.align) ||\n // 20 is minimal spacing between elements\n groupsOverlap(this.initialButtonGroupWidth + 20)) {\n if (dropdown === 'responsive') {\n this.collapseButtons(xOffsetForExportButton);\n if (groupsOverlap(maxButtonWidth())) {\n moveInputsDown();\n }\n }\n else {\n moveInputsDown();\n }\n }\n else if (dropdown === 'responsive') {\n this.expandButtons();\n }\n }\n else if (buttonGroup && dropdown === 'responsive') {\n if (this.initialButtonGroupWidth > chart.plotWidth) {\n this.collapseButtons(xOffsetForExportButton);\n }\n else {\n this.expandButtons();\n }\n }\n }\n /**\n * Collapse the buttons and put the select element on top.\n *\n * @private\n * @function Highcharts.RangeSelector#collapseButtons\n * @param {number} xOffsetForExportButton\n */\n collapseButtons(xOffsetForExportButton) {\n const { buttons, buttonOptions, chart, dropdown, options, zoomText } = this;\n const userButtonTheme = (chart.userOptions.rangeSelector &&\n chart.userOptions.rangeSelector.buttonTheme) || {};\n const getAttribs = (text) => ({\n text: text ? `${text} ▾` : '▾',\n width: 'auto',\n paddingLeft: pick(options.buttonTheme.paddingLeft, userButtonTheme.padding, 8),\n paddingRight: pick(options.buttonTheme.paddingRight, userButtonTheme.padding, 8)\n });\n if (zoomText) {\n zoomText.hide();\n }\n let hasActiveButton = false;\n buttonOptions.forEach((rangeOptions, i) => {\n const button = buttons[i];\n if (button.state !== 2) {\n button.hide();\n }\n else {\n button.show();\n button.attr(getAttribs(rangeOptions.text));\n hasActiveButton = true;\n }\n });\n if (!hasActiveButton) {\n if (dropdown) {\n dropdown.selectedIndex = 0;\n }\n buttons[0].show();\n buttons[0].attr(getAttribs(this.zoomText && this.zoomText.textStr));\n }\n const { align } = options.buttonPosition;\n this.positionButtons();\n if (align === 'right' || align === 'center') {\n this.alignButtonGroup(xOffsetForExportButton, buttons[this.currentButtonIndex()].getBBox().width);\n }\n this.showDropdown();\n }\n /**\n * Show all the buttons and hide the select element.\n *\n * @private\n * @function Highcharts.RangeSelector#expandButtons\n */\n expandButtons() {\n const { buttons, buttonOptions, options, zoomText } = this;\n this.hideDropdown();\n if (zoomText) {\n zoomText.show();\n }\n buttonOptions.forEach((rangeOptions, i) => {\n const button = buttons[i];\n button.show();\n button.attr({\n text: rangeOptions.text,\n width: options.buttonTheme.width || 28,\n paddingLeft: pick(options.buttonTheme.paddingLeft, 'unset'),\n paddingRight: pick(options.buttonTheme.paddingRight, 'unset')\n });\n if (button.state < 2) {\n button.setState(0);\n }\n });\n this.positionButtons();\n }\n /**\n * Get the index of the visible button when the buttons are collapsed.\n *\n * @private\n * @function Highcharts.RangeSelector#currentButtonIndex\n */\n currentButtonIndex() {\n const { dropdown } = this;\n if (dropdown && dropdown.selectedIndex > 0) {\n return dropdown.selectedIndex - 1;\n }\n return 0;\n }\n /**\n * Position the select element on top of the button.\n *\n * @private\n * @function Highcharts.RangeSelector#showDropdown\n */\n showDropdown() {\n const { buttonGroup, buttons, chart, dropdown } = this;\n if (buttonGroup && dropdown) {\n const { translateX, translateY } = buttonGroup;\n const bBox = buttons[this.currentButtonIndex()].getBBox();\n css(dropdown, {\n left: (chart.plotLeft + translateX) + 'px',\n top: (translateY + 0.5) + 'px',\n width: bBox.width + 'px',\n height: bBox.height + 'px'\n });\n this.hasVisibleDropdown = true;\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#hideDropdown\n */\n hideDropdown() {\n const { dropdown } = this;\n if (dropdown) {\n css(dropdown, {\n top: '-9999em',\n width: '1px',\n height: '1px'\n });\n this.hasVisibleDropdown = false;\n }\n }\n /**\n * Extracts height of range selector\n *\n * @private\n * @function Highcharts.RangeSelector#getHeight\n * @return {number}\n * Returns rangeSelector height\n */\n getHeight() {\n const rangeSelector = this, options = rangeSelector.options, rangeSelectorGroup = rangeSelector.group, inputPosition = options.inputPosition, buttonPosition = options.buttonPosition, yPosition = options.y, buttonPositionY = buttonPosition.y, inputPositionY = inputPosition.y;\n let rangeSelectorHeight = 0;\n if (options.height) {\n return options.height;\n }\n // Align the elements before we read the height in case we're switching\n // between wrapped and non-wrapped layout\n this.alignElements();\n rangeSelectorHeight = rangeSelectorGroup ?\n // 13px to keep back compatibility\n (rangeSelectorGroup.getBBox(true).height) + 13 +\n yPosition :\n 0;\n const minPosition = Math.min(inputPositionY, buttonPositionY);\n if ((inputPositionY < 0 && buttonPositionY < 0) ||\n (inputPositionY > 0 && buttonPositionY > 0)) {\n rangeSelectorHeight += Math.abs(minPosition);\n }\n return rangeSelectorHeight;\n }\n /**\n * Detect collision with title or subtitle\n *\n * @private\n * @function Highcharts.RangeSelector#titleCollision\n * @return {boolean}\n * Returns collision status\n */\n titleCollision(chart) {\n return !(chart.options.title.text ||\n chart.options.subtitle.text);\n }\n /**\n * Update the range selector with new options\n *\n * @private\n * @function Highcharts.RangeSelector#update\n * @param {Highcharts.RangeSelectorOptions} options\n */\n update(options) {\n const chart = this.chart;\n merge(true, chart.options.rangeSelector, options);\n this.destroy();\n this.init(chart);\n this.render();\n }\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.RangeSelector#destroy\n */\n destroy() {\n const rSelector = this, minInput = rSelector.minInput, maxInput = rSelector.maxInput;\n if (rSelector.eventsToUnbind) {\n rSelector.eventsToUnbind.forEach((unbind) => unbind());\n rSelector.eventsToUnbind = void 0;\n }\n // Destroy elements in collections\n destroyObjectProperties(rSelector.buttons);\n // Clear input element events\n if (minInput) {\n minInput.onfocus = minInput.onblur = minInput.onchange = null;\n }\n if (maxInput) {\n maxInput.onfocus = maxInput.onblur = maxInput.onchange = null;\n }\n // Destroy HTML and SVG elements\n objectEach(rSelector, function (val, key) {\n if (val && key !== 'chart') {\n if (val instanceof SVGElement) {\n // SVGElement\n val.destroy();\n }\n else if (val instanceof window.HTMLElement) {\n // HTML element\n discardElement(val);\n }\n }\n if (val !== RangeSelector.prototype[key]) {\n rSelector[key] = null;\n }\n }, this);\n }\n }\n extend(RangeSelector.prototype, {\n /**\n * The default buttons for pre-selecting time frames.\n * @private\n */\n defaultButtons: [{\n type: 'month',\n count: 1,\n text: '1m',\n title: 'View 1 month'\n }, {\n type: 'month',\n count: 3,\n text: '3m',\n title: 'View 3 months'\n }, {\n type: 'month',\n count: 6,\n text: '6m',\n title: 'View 6 months'\n }, {\n type: 'ytd',\n text: 'YTD',\n title: 'View year to date'\n }, {\n type: 'year',\n count: 1,\n text: '1y',\n title: 'View 1 year'\n }, {\n type: 'all',\n text: 'All',\n title: 'View all'\n }],\n /**\n * The date formats to use when setting min, max and value on date inputs.\n * @private\n */\n inputTypeFormats: {\n 'datetime-local': '%Y-%m-%dT%H:%M:%S',\n 'date': '%Y-%m-%d',\n 'time': '%H:%M:%S'\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Define the time span for the button\n *\n * @typedef {\"all\"|\"day\"|\"hour\"|\"millisecond\"|\"minute\"|\"month\"|\"second\"|\"week\"|\"year\"|\"ytd\"} Highcharts.RangeSelectorButtonTypeValue\n */\n /**\n * Callback function to react on button clicks.\n *\n * @callback Highcharts.RangeSelectorClickCallbackFunction\n *\n * @param {global.Event} e\n * Event arguments.\n *\n * @param {boolean|undefined}\n * Return false to cancel the default button event.\n */\n /**\n * Callback function to parse values entered in the input boxes and return a\n * valid JavaScript time as milliseconds since 1970.\n *\n * @callback Highcharts.RangeSelectorParseCallbackFunction\n *\n * @param {string} value\n * Input value to parse.\n *\n * @return {number}\n * Parsed JavaScript time value.\n */\n (''); // keeps doclets above in JS file\n\n return RangeSelector;\n });\n _registerModule(_modules, 'Core/Axis/OrdinalAxis.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (Axis, H, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, correctFloat, css, defined, error, pick, timeUnits } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* eslint-disable valid-jsdoc */\n /* *\n *\n * Composition\n *\n * */\n /**\n * Extends the axis with ordinal support.\n * @private\n */\n var OrdinalAxis;\n (function (OrdinalAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends the axis with ordinal support.\n *\n * @private\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param ChartClass\n * Chart class to use.\n *\n * @param SeriesClass\n * Series class to use.\n */\n function compose(AxisClass, SeriesClass, ChartClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n const axisProto = AxisClass.prototype;\n axisProto.getTimeTicks = getTimeTicks;\n axisProto.index2val = index2val;\n axisProto.lin2val = lin2val;\n axisProto.val2lin = val2lin;\n // Record this to prevent overwriting by broken-axis module (#5979)\n axisProto.ordinal2lin = axisProto.val2lin;\n addEvent(AxisClass, 'afterInit', onAxisAfterInit);\n addEvent(AxisClass, 'foundExtremes', onAxisFoundExtremes);\n addEvent(AxisClass, 'afterSetScale', onAxisAfterSetScale);\n addEvent(AxisClass, 'initialAxisTranslation', onAxisInitialAxisTranslation);\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'pan', onChartPan);\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'updatedData', onSeriesUpdatedData);\n }\n return AxisClass;\n }\n OrdinalAxis.compose = compose;\n /**\n * In an ordinal axis, there might be areas with dense consentrations of\n * points, then large gaps between some. Creating equally distributed\n * ticks over this entire range may lead to a huge number of ticks that\n * will later be removed. So instead, break the positions up in\n * segments, find the tick positions for each segment then concatenize\n * them. This method is used from both data grouping logic and X axis\n * tick position logic.\n * @private\n */\n function getTimeTicks(normalizedInterval, min, max, startOfWeek, positions = [], closestDistance = 0, findHigherRanks) {\n const higherRanks = {}, tickPixelIntervalOption = this.options.tickPixelInterval, time = this.chart.time, \n // Record all the start positions of a segment, to use when\n // deciding what's a gap in the data.\n segmentStarts = [];\n let end, segmentPositions, hasCrossedHigherRank, info, outsideMax, start = 0, groupPositions = [], lastGroupPosition = -Number.MAX_VALUE;\n // The positions are not always defined, for example for ordinal\n // positions when data has regular interval (#1557, #2090)\n if ((!this.options.ordinal && !this.options.breaks) ||\n !positions ||\n positions.length < 3 ||\n typeof min === 'undefined') {\n return time.getTimeTicks.apply(time, arguments);\n }\n // Analyze the positions array to split it into segments on gaps\n // larger than 5 times the closest distance. The closest distance is\n // already found at this point, so we reuse that instead of\n // computing it again.\n const posLength = positions.length;\n for (end = 0; end < posLength; end++) {\n outsideMax = end && positions[end - 1] > max;\n if (positions[end] < min) { // Set the last position before min\n start = end;\n }\n if (end === posLength - 1 ||\n positions[end + 1] - positions[end] > closestDistance * 5 ||\n outsideMax) {\n // For each segment, calculate the tick positions from the\n // getTimeTicks utility function. The interval will be the\n // same regardless of how long the segment is.\n if (positions[end] > lastGroupPosition) { // #1475\n segmentPositions = time.getTimeTicks(normalizedInterval, positions[start], positions[end], startOfWeek);\n // Prevent duplicate groups, for example for multiple\n // segments within one larger time frame (#1475)\n while (segmentPositions.length &&\n segmentPositions[0] <= lastGroupPosition) {\n segmentPositions.shift();\n }\n if (segmentPositions.length) {\n lastGroupPosition =\n segmentPositions[segmentPositions.length - 1];\n }\n segmentStarts.push(groupPositions.length);\n groupPositions = groupPositions.concat(segmentPositions);\n }\n // Set start of next segment\n start = end + 1;\n }\n if (outsideMax) {\n break;\n }\n }\n // Get the grouping info from the last of the segments. The info is\n // the same for all segments.\n if (segmentPositions) {\n info = segmentPositions.info;\n // Optionally identify ticks with higher rank, for example\n // when the ticks have crossed midnight.\n if (findHigherRanks && info.unitRange <= timeUnits.hour) {\n end = groupPositions.length - 1;\n // Compare points two by two\n for (start = 1; start < end; start++) {\n if (time.dateFormat('%d', groupPositions[start]) !==\n time.dateFormat('%d', groupPositions[start - 1])) {\n higherRanks[groupPositions[start]] = 'day';\n hasCrossedHigherRank = true;\n }\n }\n // If the complete array has crossed midnight, we want\n // to mark the first positions also as higher rank\n if (hasCrossedHigherRank) {\n higherRanks[groupPositions[0]] = 'day';\n }\n info.higherRanks = higherRanks;\n }\n // Save the info\n info.segmentStarts = segmentStarts;\n groupPositions.info = info;\n }\n else {\n error(12, false, this.chart);\n }\n // Don't show ticks within a gap in the ordinal axis, where the\n // space between two points is greater than a portion of the tick\n // pixel interval\n if (findHigherRanks && defined(tickPixelIntervalOption)) {\n const length = groupPositions.length, translatedArr = [], distances = [];\n let itemToRemove, translated, lastTranslated, medianDistance, distance, i = length;\n // Find median pixel distance in order to keep a reasonably even\n // distance between ticks (#748)\n while (i--) {\n translated = this.translate(groupPositions[i]);\n if (lastTranslated) {\n distances[i] = lastTranslated - translated;\n }\n translatedArr[i] = lastTranslated = translated;\n }\n distances.sort();\n medianDistance = distances[Math.floor(distances.length / 2)];\n if (medianDistance < tickPixelIntervalOption * 0.6) {\n medianDistance = null;\n }\n // Now loop over again and remove ticks where needed\n i = groupPositions[length - 1] > max ? length - 1 : length; // #817\n lastTranslated = void 0;\n while (i--) {\n translated = translatedArr[i];\n distance = Math.abs(lastTranslated - translated);\n // #4175 - when axis is reversed, the distance, is negative but\n // tickPixelIntervalOption positive, so we need to compare the\n // same values\n // Remove ticks that are closer than 0.6 times the pixel\n // interval from the one to the right, but not if it is close to\n // the median distance (#748).\n if (lastTranslated &&\n distance < tickPixelIntervalOption * 0.8 &&\n (medianDistance === null || distance < medianDistance * 0.8)) {\n // Is this a higher ranked position with a normal\n // position to the right?\n if (higherRanks[groupPositions[i]] &&\n !higherRanks[groupPositions[i + 1]]) {\n // Yes: remove the lower ranked neighbour to the\n // right\n itemToRemove = i + 1;\n lastTranslated = translated; // #709\n }\n else {\n // No: remove this one\n itemToRemove = i;\n }\n groupPositions.splice(itemToRemove, 1);\n }\n else {\n lastTranslated = translated;\n }\n }\n }\n return groupPositions;\n }\n /**\n * Get axis position of given index of the extended ordinal positions.\n * Used only when panning an ordinal axis.\n *\n * @private\n * @function Highcharts.Axis#index2val\n * @param {number} index\n * The index value of searched point\n */\n function index2val(index) {\n const axis = this, ordinal = axis.ordinal, \n // Context could be changed to extendedOrdinalPositions.\n ordinalPositions = ordinal.positions;\n // The visible range contains only equally spaced values.\n if (!ordinalPositions) {\n return index;\n }\n let i = ordinalPositions.length - 1, distance;\n if (index < 0) { // out of range, in effect panning to the left\n index = ordinalPositions[0];\n }\n else if (index > i) { // out of range, panning to the right\n index = ordinalPositions[i];\n }\n else { // split it up\n i = Math.floor(index);\n distance = index - i; // the decimal\n }\n if (typeof distance !== 'undefined' &&\n typeof ordinalPositions[i] !== 'undefined') {\n return ordinalPositions[i] + (distance ?\n distance *\n (ordinalPositions[i + 1] - ordinalPositions[i]) :\n 0);\n }\n return index;\n }\n /**\n * Translate from linear (internal) to axis value.\n *\n * @private\n * @function Highcharts.Axis#lin2val\n * @param {number} val\n * The linear abstracted value.\n */\n function lin2val(val) {\n const axis = this, ordinal = axis.ordinal, localMin = axis.old ? axis.old.min : axis.min, localA = axis.old ? axis.old.transA : axis.transA;\n let positions = ordinal.positions; // for the current visible range\n // The visible range contains only equally spaced values.\n if (!positions) {\n return val;\n }\n // Convert back from modivied value to pixels. // #15970\n const pixelVal = correctFloat((val - localMin) * localA +\n axis.minPixelPadding), isInside = val >= positions[0] &&\n val <= positions[positions.length - 1];\n // If the value is not inside the plot area, use the extended positions.\n // (array contains also points that are outside of the plotArea).\n if (!isInside) {\n // When iterating for the first time,\n // get the extended ordinal positional and assign them.\n if (!ordinal.extendedOrdinalPositions) {\n ordinal.extendedOrdinalPositions = (ordinal.getExtendedPositions());\n }\n positions = ordinal.extendedOrdinalPositions;\n }\n // In some cases (especially in early stages of the chart creation) the\n // getExtendedPositions might return undefined.\n if (positions && positions.length) {\n const indexOf = positions.indexOf(val);\n const index = indexOf !== -1 ? indexOf : correctFloat(ordinal.getIndexOfPoint(pixelVal, positions)), mantissa = correctFloat(index % 1);\n // Check if the index is inside position array. If true,\n // read/approximate value for that exact index.\n if (index >= 0 && index <= positions.length - 1) {\n const leftNeighbour = positions[Math.floor(index)], rightNeighbour = positions[Math.ceil(index)], distance = rightNeighbour - leftNeighbour;\n return positions[Math.floor(index)] + mantissa * distance;\n }\n // For cases when the index is not in the extended ordinal position\n // array, like when the value we are looking for exceed the\n // available data, approximate that value based on the calculated\n // slope.\n const positionsLength = positions.length, firstPositionsValue = positions[0], lastPositionsValue = positions[positionsLength - 1], slope = (lastPositionsValue - firstPositionsValue) / (positionsLength - 1);\n if (index < 0) {\n return firstPositionsValue + slope * index;\n }\n return lastPositionsValue + slope * (index - positionsLength);\n }\n return val;\n }\n /**\n * Internal function to calculate the precise index in ordinalPositions\n * array.\n * @private\n */\n function getIndexInArray(ordinalPositions, val) {\n const index = OrdinalAxis.Additions.findIndexOf(ordinalPositions, val, true);\n if (ordinalPositions[index] === val) {\n return index;\n }\n const percent = (val - ordinalPositions[index]) /\n (ordinalPositions[index + 1] - ordinalPositions[index]);\n return index + percent;\n }\n /**\n * @private\n */\n function onAxisAfterInit() {\n const axis = this;\n if (!axis.ordinal) {\n axis.ordinal = new OrdinalAxis.Additions(axis);\n }\n }\n /**\n * @private\n */\n function onAxisFoundExtremes() {\n const axis = this;\n if (axis.isXAxis &&\n defined(axis.options.overscroll) &&\n axis.max === axis.dataMax &&\n (\n // Panning is an execption. We don't want to apply\n // overscroll when panning over the dataMax\n !axis.chart.mouseIsDown ||\n axis.isInternal) && (\n // Scrollbar buttons are the other execption:\n !axis.eventArgs ||\n axis.eventArgs && axis.eventArgs.trigger !== 'navigator')) {\n axis.max += axis.options.overscroll;\n // Live data and buttons require translation for the min:\n if (!axis.isInternal && defined(axis.userMin)) {\n axis.min += axis.options.overscroll;\n }\n }\n }\n /**\n * For ordinal axis, that loads data async, redraw axis after data is\n * loaded. If we don't do that, axis will have the same extremes as\n * previously, but ordinal positions won't be calculated. See #10290\n * @private\n */\n function onAxisAfterSetScale() {\n const axis = this;\n if (axis.horiz && !axis.isDirty) {\n axis.isDirty = axis.isOrdinal &&\n axis.chart.navigator &&\n !axis.chart.navigator.adaptToUpdatedData;\n }\n }\n /**\n * @private\n */\n function onAxisInitialAxisTranslation() {\n const axis = this;\n if (axis.ordinal) {\n axis.ordinal.beforeSetTickPositions();\n axis.tickInterval = axis.ordinal.postProcessTickInterval(axis.tickInterval);\n }\n }\n /**\n * Extending the Chart.pan method for ordinal axes\n * @private\n */\n function onChartPan(e) {\n const chart = this, xAxis = chart.xAxis[0], overscroll = xAxis.options.overscroll, chartX = e.originalEvent.chartX, panning = chart.options.chart.panning;\n let runBase = false;\n if (panning &&\n panning.type !== 'y' &&\n xAxis.options.ordinal &&\n xAxis.series.length) {\n const mouseDownX = chart.mouseDownX, extremes = xAxis.getExtremes(), dataMax = extremes.dataMax, min = extremes.min, max = extremes.max, hoverPoints = chart.hoverPoints, closestPointRange = (xAxis.closestPointRange ||\n (xAxis.ordinal && xAxis.ordinal.overscrollPointsRange)), pointPixelWidth = (xAxis.translationSlope *\n (xAxis.ordinal.slope || closestPointRange)), \n // how many ordinal units did we move?\n movedUnits = Math.round((mouseDownX - chartX) / pointPixelWidth), \n // get index of all the chart's points\n extendedOrdinalPositions = xAxis.ordinal.getExtendedPositions(), extendedAxis = {\n ordinal: {\n positions: extendedOrdinalPositions,\n extendedOrdinalPositions: extendedOrdinalPositions\n }\n }, index2val = xAxis.index2val, val2lin = xAxis.val2lin;\n let trimmedRange, ordinalPositions, searchAxisLeft, searchAxisRight;\n // we have an ordinal axis, but the data is equally spaced\n if (!extendedAxis.ordinal.positions) {\n runBase = true;\n }\n else if (Math.abs(movedUnits) > 1) {\n // Remove active points for shared tooltip\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n if (movedUnits < 0) {\n searchAxisLeft = extendedAxis;\n searchAxisRight = xAxis.ordinal.positions ?\n xAxis : extendedAxis;\n }\n else {\n searchAxisLeft = xAxis.ordinal.positions ?\n xAxis : extendedAxis;\n searchAxisRight = extendedAxis;\n }\n // In grouped data series, the last ordinal position represents\n // the grouped data, which is to the left of the real data max.\n // If we don't compensate for this, we will be allowed to pan\n // grouped data series passed the right of the plot area.\n ordinalPositions = searchAxisRight.ordinal.positions;\n if (dataMax >\n ordinalPositions[ordinalPositions.length - 1]) {\n ordinalPositions.push(dataMax);\n }\n // Get the new min and max values by getting the ordinal index\n // for the current extreme, then add the moved units and\n // translate back to values. This happens on the extended\n // ordinal positions if the new position is out of range, else\n // it happens on the current x axis which is smaller and faster.\n chart.fixedRange = max - min;\n trimmedRange = xAxis.navigatorAxis\n .toFixedRange(void 0, void 0, index2val.apply(searchAxisLeft, [\n val2lin.apply(searchAxisLeft, [min, true]) +\n movedUnits\n ]), index2val.apply(searchAxisRight, [\n val2lin.apply(searchAxisRight, [max, true]) +\n movedUnits\n ]));\n // Apply it if it is within the available data range\n if (trimmedRange.min >= Math.min(extremes.dataMin, min) &&\n trimmedRange.max <= Math.max(dataMax, max) +\n overscroll) {\n xAxis.setExtremes(trimmedRange.min, trimmedRange.max, true, false, { trigger: 'pan' });\n }\n chart.mouseDownX = chartX; // set new reference for next run\n css(chart.container, { cursor: 'move' });\n }\n }\n else {\n runBase = true;\n }\n // revert to the linear chart.pan version\n if (runBase || (panning && /y/.test(panning.type))) {\n if (overscroll) {\n xAxis.max = xAxis.dataMax + overscroll;\n }\n }\n else {\n e.preventDefault();\n }\n }\n /**\n * @private\n */\n function onSeriesUpdatedData() {\n const xAxis = this.xAxis;\n // Destroy the extended ordinal index on updated data\n // and destroy extendedOrdinalPositions, #16055.\n if (xAxis && xAxis.options.ordinal) {\n delete xAxis.ordinal.index;\n delete xAxis.ordinal.extendedOrdinalPositions;\n }\n }\n /**\n * Translate from a linear axis value to the corresponding ordinal axis\n * position. If there are no gaps in the ordinal axis this will be the\n * same. The translated value is the value that the point would have if\n * the axis was linear, using the same min and max.\n *\n * @private\n * @function Highcharts.Axis#val2lin\n * @param {number} val\n * The axis value.\n * @param {boolean} [toIndex]\n * Whether to return the index in the ordinalPositions or the new value.\n */\n function val2lin(val, toIndex) {\n const axis = this, ordinal = axis.ordinal, ordinalPositions = ordinal.positions;\n let slope = ordinal.slope, extendedOrdinalPositions = ordinal.extendedOrdinalPositions;\n if (!ordinalPositions) {\n return val;\n }\n const ordinalLength = ordinalPositions.length;\n let ordinalIndex;\n // If the searched value is inside visible plotArea, ivastigate the\n // value basing on ordinalPositions.\n if (ordinalPositions[0] <= val &&\n ordinalPositions[ordinalLength - 1] >= val) {\n ordinalIndex = getIndexInArray(ordinalPositions, val);\n // final return value is based on ordinalIndex\n }\n else {\n if (!extendedOrdinalPositions) {\n extendedOrdinalPositions =\n ordinal.getExtendedPositions &&\n ordinal.getExtendedPositions();\n ordinal.extendedOrdinalPositions = extendedOrdinalPositions;\n }\n if (!(extendedOrdinalPositions && extendedOrdinalPositions.length)) {\n return val;\n }\n const length = extendedOrdinalPositions.length;\n if (!slope) {\n slope =\n (extendedOrdinalPositions[length - 1] -\n extendedOrdinalPositions[0]) /\n length;\n }\n // OriginalPointReference is equal to the index of\n // first point of ordinalPositions in extendedOrdinalPositions.\n const originalPositionsReference = getIndexInArray(extendedOrdinalPositions, ordinalPositions[0]);\n // If the searched value is outside the visiblePlotArea,\n // check if it is inside extendedOrdinalPositions.\n if (val >= extendedOrdinalPositions[0] &&\n val <=\n extendedOrdinalPositions[length - 1]) {\n // Return Value\n ordinalIndex = getIndexInArray(extendedOrdinalPositions, val) -\n originalPositionsReference;\n }\n else {\n // Since ordinal.slope is the average distance between 2\n // points on visible plotArea, this can be used to calculete\n // the approximate position of the point, which is outside\n // the extededOrdinalPositions.\n if (val < extendedOrdinalPositions[0]) {\n const diff = extendedOrdinalPositions[0] - val, approximateIndexOffset = diff / slope;\n ordinalIndex =\n -originalPositionsReference -\n approximateIndexOffset;\n }\n else {\n const diff = val -\n extendedOrdinalPositions[length - 1], approximateIndexOffset = diff / slope;\n ordinalIndex =\n approximateIndexOffset +\n length -\n originalPositionsReference;\n }\n }\n }\n return toIndex ? ordinalIndex : slope * (ordinalIndex || 0) +\n ordinal.offset;\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * @private\n */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n /**\n * @private\n */\n constructor(axis) {\n this.index = {};\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Calculate the ordinal positions before tick positions are calculated.\n * @private\n */\n beforeSetTickPositions() {\n const axis = this.axis, ordinal = axis.ordinal, extremes = axis.getExtremes(), min = extremes.min, max = extremes.max, hasBreaks = axis.isXAxis && !!axis.options.breaks, isOrdinal = axis.options.ordinal, ignoreHiddenSeries = axis.chart.options.chart.ignoreHiddenSeries;\n let len, uniqueOrdinalPositions, dist, minIndex, maxIndex, slope, i, ordinalPositions = [], overscrollPointsRange = Number.MAX_VALUE, useOrdinal = false, adjustOrdinalExtremesPoints = false, isBoosted = false;\n // Apply the ordinal logic\n if (isOrdinal || hasBreaks) { // #4167 YAxis is never ordinal ?\n let distanceBetweenPoint = 0;\n axis.series.forEach(function (series, i) {\n uniqueOrdinalPositions = [];\n // For an axis with multiple series, check if the distance\n // between points is identical throughout all series.\n if (i > 0 &&\n series.options.id !== 'highcharts-navigator-series' &&\n series.processedXData.length > 1) {\n adjustOrdinalExtremesPoints =\n distanceBetweenPoint !== series.processedXData[1] -\n series.processedXData[0];\n }\n distanceBetweenPoint =\n series.processedXData[1] - series.processedXData[0];\n if (series.boosted) {\n isBoosted = series.boosted;\n }\n if ((!ignoreHiddenSeries || series.visible !== false) &&\n (series\n .takeOrdinalPosition !== false ||\n hasBreaks)) {\n // concatenate the processed X data into the existing\n // positions, or the empty array\n ordinalPositions = ordinalPositions.concat(series.processedXData);\n len = ordinalPositions.length;\n // remove duplicates (#1588)\n ordinalPositions.sort(function (a, b) {\n // without a custom function it is sorted as strings\n return a - b;\n });\n overscrollPointsRange = Math.min(overscrollPointsRange, pick(\n // Check for a single-point series:\n series.closestPointRange, overscrollPointsRange));\n if (len) {\n i = 0;\n while (i < len - 1) {\n if (ordinalPositions[i] !==\n ordinalPositions[i + 1]) {\n uniqueOrdinalPositions.push(ordinalPositions[i + 1]);\n }\n i++;\n }\n // Check first item:\n if (uniqueOrdinalPositions[0] !==\n ordinalPositions[0]) {\n uniqueOrdinalPositions.unshift(ordinalPositions[0]);\n }\n ordinalPositions = uniqueOrdinalPositions;\n }\n }\n });\n // If the distance between points is not identical throughout\n // all series, remove the first and last ordinal position to\n // avoid enabling ordinal logic when it is not needed, #17405.\n // Only for boosted series because changes are negligible.\n if (adjustOrdinalExtremesPoints && isBoosted) {\n ordinalPositions.pop();\n ordinalPositions.shift();\n }\n // cache the length\n len = ordinalPositions.length;\n // Check if we really need the overhead of mapping axis data\n // against the ordinal positions. If the series consist of\n // evenly spaced data any way, we don't need any ordinal logic.\n if (len > 2) { // two points have equal distance by default\n dist = ordinalPositions[1] - ordinalPositions[0];\n i = len - 1;\n while (i-- && !useOrdinal) {\n if (ordinalPositions[i + 1] - ordinalPositions[i] !==\n dist) {\n useOrdinal = true;\n }\n }\n // When zooming in on a week, prevent axis padding for\n // weekends even though the data within the week is evenly\n // spaced.\n if (!axis.options.keepOrdinalPadding &&\n (ordinalPositions[0] - min > dist ||\n (max -\n ordinalPositions[ordinalPositions.length - 1]) > dist)) {\n useOrdinal = true;\n }\n }\n else if (axis.options.overscroll) {\n if (len === 2) {\n // Exactly two points, distance for overscroll is fixed:\n overscrollPointsRange =\n ordinalPositions[1] - ordinalPositions[0];\n }\n else if (len === 1) {\n // We have just one point, closest distance is unknown.\n // Assume then it is last point and overscrolled range:\n overscrollPointsRange = axis.options.overscroll;\n ordinalPositions = [\n ordinalPositions[0],\n ordinalPositions[0] + overscrollPointsRange\n ];\n }\n else {\n // In case of zooming in on overscrolled range, stick to\n // the old range:\n overscrollPointsRange = ordinal.overscrollPointsRange;\n }\n }\n // Record the slope and offset to compute the linear values from\n // the array index. Since the ordinal positions may exceed the\n // current range, get the start and end positions within it\n // (#719, #665b)\n if (useOrdinal || axis.forceOrdinal) {\n if (axis.options.overscroll) {\n ordinal.overscrollPointsRange = overscrollPointsRange;\n ordinalPositions = ordinalPositions.concat(ordinal.getOverscrollPositions());\n }\n // Register\n ordinal.positions = ordinalPositions;\n // This relies on the ordinalPositions being set. Use\n // Math.max and Math.min to prevent padding on either sides\n // of the data.\n minIndex = axis.ordinal2lin(// #5979\n Math.max(min, ordinalPositions[0]), true);\n maxIndex = Math.max(axis.ordinal2lin(Math.min(max, ordinalPositions[ordinalPositions.length - 1]), true), 1); // #3339\n // Set the slope and offset of the values compared to the\n // indices in the ordinal positions\n ordinal.slope = slope = (max - min) / (maxIndex - minIndex);\n ordinal.offset = min - (minIndex * slope);\n }\n else {\n ordinal.overscrollPointsRange = pick(axis.closestPointRange, ordinal.overscrollPointsRange);\n ordinal.positions = axis.ordinal.slope = ordinal.offset =\n void 0;\n }\n }\n axis.isOrdinal = isOrdinal && useOrdinal; // #3818, #4196, #4926\n ordinal.groupIntervalFactor = null; // reset for next run\n }\n /**\n * Faster way of using the Array.indexOf method.\n * Works for sorted arrays only with unique values.\n *\n * @param {Array} sortedArray\n * The sorted array inside which we are looking for.\n * @param {number} key\n * The key to being found.\n * @param {boolean} indirectSearch\n * In case of lack of the point in the array, should return\n * value be equal to -1 or the closest smaller index.\n * @private\n */\n static findIndexOf(sortedArray, key, indirectSearch) {\n let start = 0, end = sortedArray.length - 1, middle;\n while (start < end) {\n middle = Math.ceil((start + end) / 2);\n // Key found as the middle element.\n if (sortedArray[middle] <= key) {\n // Continue searching to the right.\n start = middle;\n }\n else {\n // Continue searching to the left.\n end = middle - 1;\n }\n }\n if (sortedArray[start] === key) {\n return start;\n }\n // Key could not be found.\n return !indirectSearch ? -1 : start;\n }\n /**\n * Get the ordinal positions for the entire data set. This is necessary\n * in chart panning because we need to find out what points or data\n * groups are available outside the visible range. When a panning\n * operation starts, if an index for the given grouping does not exists,\n * it is created and cached. This index is deleted on updated data, so\n * it will be regenerated the next time a panning operation starts.\n * @private\n */\n getExtendedPositions() {\n const ordinal = this, axis = ordinal.axis, axisProto = axis.constructor.prototype, chart = axis.chart, grouping = axis.series[0].currentDataGrouping, key = grouping ?\n grouping.count + grouping.unitName :\n 'raw', overscroll = axis.options.overscroll, extremes = axis.getExtremes();\n let fakeAxis, fakeSeries = void 0, ordinalIndex = ordinal.index;\n // If this is the first time, or the ordinal index is deleted by\n // updatedData,\n // create it.\n if (!ordinalIndex) {\n ordinalIndex = ordinal.index = {};\n }\n if (!ordinalIndex[key]) {\n // Create a fake axis object where the extended ordinal\n // positions are emulated\n fakeAxis = {\n series: [],\n chart: chart,\n forceOrdinal: false,\n getExtremes: function () {\n return {\n min: extremes.dataMin,\n max: extremes.dataMax + overscroll\n };\n },\n getGroupPixelWidth: axisProto.getGroupPixelWidth,\n getTimeTicks: axisProto.getTimeTicks,\n options: {\n ordinal: true\n },\n ordinal: {\n getGroupIntervalFactor: this.getGroupIntervalFactor\n },\n ordinal2lin: axisProto.ordinal2lin,\n getIndexOfPoint: axisProto.getIndexOfPoint,\n val2lin: axisProto.val2lin // #2590\n };\n fakeAxis.ordinal.axis = fakeAxis;\n // Add the fake series to hold the full data, then apply\n // processData to it\n axis.series.forEach(function (series) {\n fakeSeries = {\n xAxis: fakeAxis,\n xData: series.xData.slice(),\n chart: chart,\n destroyGroupedData: H.noop,\n getProcessedData: Series.prototype.getProcessedData,\n applyGrouping: Series.prototype.applyGrouping\n };\n fakeSeries.xData = fakeSeries.xData.concat(ordinal.getOverscrollPositions());\n fakeSeries.options = {\n dataGrouping: grouping ? {\n firstAnchor: 'firstPoint',\n anchor: 'middle',\n lastAnchor: 'lastPoint',\n enabled: true,\n forced: true,\n // doesn't matter which, use the fastest\n approximation: 'open',\n units: [[\n grouping.unitName,\n [grouping.count]\n ]]\n } : {\n enabled: false\n }\n };\n fakeAxis.series.push(fakeSeries);\n series.processData.apply(fakeSeries);\n });\n // Force to use the ordinal when points are evenly spaced (e.g.\n // weeks), #3825.\n if ((fakeSeries.closestPointRange !==\n fakeSeries.basePointRange) &&\n fakeSeries.currentDataGrouping) {\n fakeAxis.forceOrdinal = true;\n }\n // Run beforeSetTickPositions to compute the ordinalPositions\n axis.ordinal.beforeSetTickPositions.apply({ axis: fakeAxis });\n // Cache it\n ordinalIndex[key] = fakeAxis.ordinal.positions;\n }\n return ordinalIndex[key];\n }\n /**\n * Find the factor to estimate how wide the plot area would have been if\n * ordinal gaps were included. This value is used to compute an imagined\n * plot width in order to establish the data grouping interval.\n *\n * A real world case is the intraday-candlestick example. Without this\n * logic, it would show the correct data grouping when viewing a range\n * within each day, but once moving the range to include the gap between\n * two days, the interval would include the cut-away night hours and the\n * data grouping would be wrong. So the below method tries to compensate\n * by identifying the most common point interval, in this case days.\n *\n * An opposite case is presented in issue #718. We have a long array of\n * daily data, then one point is appended one hour after the last point.\n * We expect the data grouping not to change.\n *\n * In the future, if we find cases where this estimation doesn't work\n * optimally, we might need to add a second pass to the data grouping\n * logic, where we do another run with a greater interval if the number\n * of data groups is more than a certain fraction of the desired group\n * count.\n * @private\n */\n getGroupIntervalFactor(xMin, xMax, series) {\n const ordinal = this, axis = ordinal.axis, processedXData = series.processedXData, len = processedXData.length, distances = [];\n let median, i, groupIntervalFactor = ordinal.groupIntervalFactor;\n // Only do this computation for the first series, let the other\n // inherit it (#2416)\n if (!groupIntervalFactor) {\n // Register all the distances in an array\n for (i = 0; i < len - 1; i++) {\n distances[i] = (processedXData[i + 1] -\n processedXData[i]);\n }\n // Sort them and find the median\n distances.sort(function (a, b) {\n return a - b;\n });\n median = distances[Math.floor(len / 2)];\n // Compensate for series that don't extend through the entire\n // axis extent. #1675.\n xMin = Math.max(xMin, processedXData[0]);\n xMax = Math.min(xMax, processedXData[len - 1]);\n ordinal.groupIntervalFactor = groupIntervalFactor =\n (len * median) / (xMax - xMin);\n }\n // Return the factor needed for data grouping\n return groupIntervalFactor;\n }\n /**\n * Get index of point inside the ordinal positions array.\n *\n * @private\n * @param {number} val\n * The pixel value of a point.\n *\n * @param {Array} [ordinallArray]\n * An array of all points available on the axis for the given data set.\n * Either ordinalPositions if the value is inside the plotArea or\n * extendedOrdinalPositions if not.\n */\n getIndexOfPoint(val, ordinalArray) {\n const ordinal = this, axis = ordinal.axis, firstPointVal = ordinal.positions ? ordinal.positions[0] : 0;\n // Check whether the series has at least one point inside the chart\n const hasPointsInside = function (series) {\n return series.points.some((point) => !!point.isInside);\n };\n let firstPointX;\n // When more series assign to axis, find the smallest one, #15987.\n axis.series.forEach((series) => {\n var _a;\n const firstPoint = (_a = series.points) === null || _a === void 0 ? void 0 : _a[0];\n if (defined(firstPoint === null || firstPoint === void 0 ? void 0 : firstPoint.plotX) &&\n (firstPoint.plotX < firstPointX ||\n !defined(firstPointX)) &&\n hasPointsInside(series)) {\n firstPointX = firstPoint.plotX;\n }\n });\n // If undefined, give a default value\n firstPointX !== null && firstPointX !== void 0 ? firstPointX : (firstPointX = axis.minPixelPadding);\n // Distance in pixels between two points on the ordinal axis in the\n // current zoom.\n const ordinalPointPixelInterval = axis.translationSlope * (ordinal.slope ||\n axis.closestPointRange ||\n ordinal.overscrollPointsRange), \n // toValue for the first point.\n shiftIndex = correctFloat((val - firstPointX) / ordinalPointPixelInterval);\n return Additions.findIndexOf(ordinalArray, firstPointVal, true) + shiftIndex;\n }\n /**\n * Get ticks for an ordinal axis within a range where points don't\n * exist. It is required when overscroll is enabled. We can't base on\n * points, because we may not have any, so we use approximated\n * pointRange and generate these ticks between Axis.dataMax,\n * Axis.dataMax + Axis.overscroll evenly spaced. Used in panning and\n * navigator scrolling.\n * @private\n */\n getOverscrollPositions() {\n const ordinal = this, axis = ordinal.axis, extraRange = axis.options.overscroll, distance = ordinal.overscrollPointsRange, positions = [];\n let max = axis.dataMax;\n if (defined(distance)) {\n // Max + pointRange because we need to scroll to the last\n while (max <= axis.dataMax + extraRange) {\n max += distance;\n positions.push(max);\n }\n }\n return positions;\n }\n /**\n * Make the tick intervals closer because the ordinal gaps make the\n * ticks spread out or cluster.\n * @private\n */\n postProcessTickInterval(tickInterval) {\n // Problem: https://jsfiddle.net/highcharts/FQm4E/1/. This is a case\n // where this algorithm doesn't work optimally. In this case, the\n // tick labels are spread out per week, but all the gaps reside\n // within weeks. So we have a situation where the labels are courser\n // than the ordinal gaps, and thus the tick interval should not be\n // altered.\n const ordinal = this, axis = ordinal.axis, ordinalSlope = ordinal.slope;\n let ret;\n if (ordinalSlope) {\n if (!axis.options.breaks) {\n ret = (tickInterval /\n (ordinalSlope / axis.closestPointRange));\n }\n else {\n ret = axis.closestPointRange || tickInterval; // #7275\n }\n }\n else {\n ret = tickInterval;\n }\n return ret;\n }\n }\n OrdinalAxis.Additions = Additions;\n })(OrdinalAxis || (OrdinalAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return OrdinalAxis;\n });\n _registerModule(_modules, 'Series/HLC/HLCPoint.js', [_modules['Core/Series/SeriesRegistry.js']], function (SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: { prototype: { pointClass: ColumnPoint } } } = SeriesRegistry.seriesTypes;\n /* *\n *\n * Class\n *\n * */\n class HLCPoint extends ColumnPoint {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.close = void 0;\n this.high = void 0;\n this.low = void 0;\n this.options = void 0;\n this.plotClose = void 0;\n this.series = void 0;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCPoint;\n });\n _registerModule(_modules, 'Series/HLC/HLCSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * An HLC chart is a style of financial chart used to describe price\n * movements over time. It displays high, low and close values per\n * data point.\n *\n * @sample stock/demo/hlc/\n * HLC chart\n *\n * @extends plotOptions.column\n * @excluding borderColor, borderRadius, borderWidth, crisp, stacking,\n * stack\n * @product highstock\n * @optionparent plotOptions.hlc\n */\n const HLCSeriesDefaults = {\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no\n * grouping is performed. If however the series contains so many points\n * that the spacing is less than the groupPixelWidth, Highcharts will\n * try to group it into appropriate groups so that each is more or less\n * two pixels wide. Defaults to `5`.\n *\n * @type {number}\n * @default 5\n * @product highstock\n * @apioption plotOptions.hlc.dataGrouping.groupPixelWidth\n */\n /**\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @default hlc\n * @product highstock\n * @apioption plotOptions.hlc.dataGrouping.approximation\n */\n /**\n * @default close\n * @apioption plotOptions.hlc.colorKey\n */\n /**\n * The pixel width of the line/border. Defaults to `1`.\n *\n * @sample {highstock} stock/plotoptions/hlc-linewidth/\n * A greater line width\n *\n * @type {number}\n * @default 1\n * @product highstock\n *\n * @public\n */\n lineWidth: 1,\n tooltip: {\n pointFormat: '\\u25CF ' +\n ' {series.name}
' +\n 'High: {point.high}
' +\n 'Low: {point.low}
' +\n 'Close: {point.close}
'\n },\n /**\n * @type {number|null}\n */\n threshold: null,\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The pixel width of the line representing the HLC point.\n *\n * @type {number}\n * @default 3\n * @product highstock\n */\n lineWidth: 3\n }\n },\n /**\n * Determines which one of `high`, `low`, `close` values should\n * be represented as `point.y`, which is later used to set dataLabel\n * position and [compare](#plotOptions.series.compare).\n *\n * @sample {highstock} stock/plotoptions/hlc-pointvalkey/\n * Possible values\n *\n * @declare Highcharts.OptionsHLCPointValKeyValue\n * @type {string}\n * @default close\n * @validvalue [\"high\", \"low\", \"close\"]\n * @product highstock\n * @apioption plotOptions.hlc.pointValKey\n */\n /**\n * @default close\n * @apioption plotOptions.hlc.colorKey\n */\n stickyTracking: true\n };\n /**\n * A `hlc` series. If the [type](#series.hlc.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.hlc\n * @excluding dataParser, dataURL\n * @product highstock\n * @apioption series.hlc\n */\n /**\n * An array of data points for the series. For the `hlc` series type,\n * points can be given in the following ways:\n *\n * 1. An array of arrays with 4 or 3 values. In this case, the values correspond\n * to `x,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length of 3\\.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 5, 6, 7],\n * [1, 4, 8, 2],\n * [2, 3, 4, 10]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.hlc.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * high: 4,\n * low: 5,\n * close: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * high: 3,\n * low: 6,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number>|*>}\n * @extends series.arearange.data\n * @excluding y, marker\n * @product highstock\n * @apioption series.hlc.data\n */\n /**\n * The closing value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.hlc.data.close\n */\n (''); // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCSeriesDefaults;\n });\n _registerModule(_modules, 'Series/HLC/HLCSeries.js', [_modules['Series/HLC/HLCPoint.js'], _modules['Series/HLC/HLCSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (HLCPoint, HLCSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: ColumnSeries } = SeriesRegistry.seriesTypes;\n const { extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The hlc series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.hlc\n *\n * @augments Highcharts.Series\n */\n class HLCSeries extends ColumnSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n this.yData = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extend the path if close is not between high and low.\n *\n * @param {SVGPath} path the path array of the point\n * @param {number} halfStrokeWidth\n * @param {number} value value of the point to which the stem should be extended\n */\n extendStem(path, halfStrokeWidth, value) {\n const start = path[0];\n const end = path[1];\n // We don't need to worry about crisp - close value\n // is already crisped and halfStrokeWidth should remove it.\n if (typeof start[2] === 'number') {\n start[2] = Math.max(value + halfStrokeWidth, start[2]);\n }\n if (typeof end[2] === 'number') {\n end[2] = Math.min(value - halfStrokeWidth, end[2]);\n }\n }\n /**\n * Function to create SVGPath of the point based on the\n * plot positions of this point.\n * @private\n */\n getPointPath(point, graphic) {\n // crisp vector coordinates\n const strokeWidth = graphic.strokeWidth(), series = point.series, crispCorr = (strokeWidth % 2) / 2, \n // #2596:\n crispX = Math.round(point.plotX) - crispCorr, halfWidth = Math.round(point.shapeArgs.width / 2);\n let plotClose = point.plotClose;\n // the vertical stem\n const path = [\n ['M', crispX, Math.round(point.yBottom)],\n ['L', crispX, Math.round(point.plotHigh)]\n ];\n // close\n if (point.close !== null) {\n plotClose = Math.round(point.plotClose) + crispCorr;\n path.push(['M', crispX, plotClose], ['L', crispX + halfWidth, plotClose]);\n series.extendStem(path, strokeWidth / 2, plotClose);\n }\n return path;\n }\n /**\n * Draw single point\n * @private\n */\n drawSinglePoint(point) {\n const series = point.series, chart = series.chart;\n let path, graphic = point.graphic;\n if (typeof point.plotY !== 'undefined') {\n // Create and/or update the graphic\n if (!graphic) {\n point.graphic = graphic = chart.renderer.path()\n .add(series.group);\n }\n if (!chart.styledMode) {\n graphic.attr(series.pointAttribs(point, (point.selected && 'select'))); // #3897\n }\n // crisp vector coordinates\n path = series.getPointPath(point, graphic);\n graphic[!graphic ? 'attr' : 'animate']({ d: path })\n .addClass(point.getClassName(), true);\n }\n }\n /**\n * Draw the data points\n * @private\n */\n drawPoints() {\n this.points.forEach(this.drawSinglePoint);\n }\n /**\n * @private\n * @function Highcharts.seriesTypes.hlc#init\n */\n init() {\n super.init.apply(this, arguments);\n this.options.stacking = void 0; // #8817\n }\n /**\n * Postprocess mapping between options and SVG attributes\n * @private\n */\n pointAttribs(point, state) {\n const attribs = super.pointAttribs.call(this, point, state);\n delete attribs.fill;\n return attribs;\n }\n toYData(point) {\n // return a plain array for speedy calculation\n return [point.high, point.low, point.close];\n }\n /**\n * Translate data points from raw values x and y to plotX and plotY\n *\n * @private\n * @function Highcharts.seriesTypes.hlc#translate\n */\n translate() {\n const series = this, yAxis = series.yAxis, names = (this.pointArrayMap && this.pointArrayMap.slice()) || [], translated = names.map((name) => `plot${name.charAt(0).toUpperCase() + name.slice(1)}`);\n translated.push('yBottom');\n names.push('low');\n super.translate.apply(series);\n // Do the translation\n series.points.forEach(function (point) {\n names.forEach(function (name, i) {\n let value = point[name];\n if (value !== null) {\n if (series.dataModify) {\n value = series.dataModify.modifyValue(value);\n }\n point[translated[i]] =\n yAxis.toPixels(value, true);\n }\n });\n // Align the tooltip to the high value to avoid covering the\n // point\n point.tooltipPos[1] =\n point.plotHigh + yAxis.pos - series.chart.plotTop;\n });\n }\n }\n HLCSeries.defaultOptions = merge(ColumnSeries.defaultOptions, HLCSeriesDefaults);\n extend(HLCSeries.prototype, {\n pointClass: HLCPoint,\n animate: null,\n directTouch: false,\n pointArrayMap: ['high', 'low', 'close'],\n pointAttrToOptions: {\n stroke: 'color',\n 'stroke-width': 'lineWidth'\n },\n pointValKey: 'close'\n });\n SeriesRegistry.registerSeriesType('hlc', HLCSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCSeries;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCPoint.js', [_modules['Core/Series/SeriesRegistry.js']], function (SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { seriesTypes: { hlc: HLCSeries } } = SeriesRegistry;\n /* *\n *\n * Class\n *\n * */\n class OHLCPoint extends HLCSeries.prototype.pointClass {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.open = void 0;\n this.options = void 0;\n this.plotOpen = void 0;\n this.series = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extend the parent method by adding up or down to the class name.\n * @private\n * @function Highcharts.seriesTypes.ohlc#getClassName\n */\n getClassName() {\n return super.getClassName.call(this) +\n (this.open < this.close ?\n ' highcharts-point-up' :\n ' highcharts-point-down');\n }\n /**\n * Save upColor as point color (#14826).\n * @private\n * @function Highcharts.seriesTypes.ohlc#resolveUpColor\n */\n resolveUpColor() {\n if (this.open < this.close &&\n !this.options.color &&\n this.series.options.upColor) {\n this.color = this.series.options.upColor;\n }\n }\n /**\n * Extend the parent method by saving upColor.\n * @private\n * @function Highcharts.seriesTypes.ohlc#resolveColor\n */\n resolveColor() {\n super.resolveColor();\n this.resolveUpColor();\n }\n /**\n * Extend the parent method by saving upColor.\n * @private\n * @function Highcharts.seriesTypes.ohlc#getZone\n *\n * @return {Highcharts.SeriesZonesOptionsObject}\n * The zone item.\n */\n getZone() {\n const zone = super.getZone();\n this.resolveUpColor();\n return zone;\n }\n /**\n * Extend the parent method by resolving up/down colors (#15849)\n * @private\n **/\n applyOptions() {\n super.applyOptions.apply(this, arguments);\n if (this.resolveColor) {\n this.resolveColor();\n }\n return this;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCPoint;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * An OHLC chart is a style of financial chart used to describe price\n * movements over time. It displays open, high, low and close values per\n * data point.\n *\n * @sample stock/demo/ohlc\n * OHLC chart\n *\n * @extends plotOptions.hlc\n * @product highstock\n * @optionparent plotOptions.ohlc\n */\n const OHLCSeriesDefaults = {\n /**\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @default ohlc\n * @product highstock\n * @apioption plotOptions.ohlc.dataGrouping.approximation\n */\n /**\n * Determines which one of `open`, `high`, `low`, `close` values should\n * be represented as `point.y`, which is later used to set dataLabel\n * position and [compare](#plotOptions.series.compare).\n *\n * @declare Highcharts.OptionsPointValKeyValue\n * @default close\n * @validvalue [\"open\", \"high\", \"low\", \"close\"]\n * @product highstock\n * @apioption plotOptions.ohlc.pointValKey\n */\n /**\n * Line color for up points.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n * @apioption plotOptions.ohlc.upColor\n */\n tooltip: {\n pointFormat: '\\u25CF ' +\n ' {series.name}
' +\n 'Open: {point.open}
' +\n 'High: {point.high}
' +\n 'Low: {point.low}
' +\n 'Close: {point.close}
'\n }\n };\n /**\n * The parameter allows setting line series type and use OHLC indicators.\n * Data in OHLC format is required.\n *\n * @sample {highstock} stock/indicators/use-ohlc-data\n * Use OHLC data format to plot line chart\n *\n * @type {boolean}\n * @product highstock\n * @apioption plotOptions.line.useOhlcData\n */\n /**\n * A `ohlc` series. If the [type](#series.ohlc.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.ohlc\n * @excluding dataParser, dataURL\n * @product highstock\n * @apioption series.ohlc\n */\n /**\n * An array of data points for the series. For the `ohlc` series type,\n * points can be given in the following ways:\n *\n * 1. An array of arrays with 5 or 4 values. In this case, the values correspond\n * to `x,open,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length 4\\.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 6, 5, 6, 7],\n * [1, 9, 4, 8, 2],\n * [2, 6, 3, 4, 10]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.ohlc.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * open: 3,\n * high: 4,\n * low: 5,\n * close: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * open: 4,\n * high: 3,\n * low: 6,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number,number>|*>}\n * @extends series.arearange.data\n * @excluding y, marker\n * @product highstock\n * @apioption series.ohlc.data\n */\n /**\n * The closing value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.ohlc.data.close\n */\n /**\n * The opening value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.ohlc.data.open\n */\n ''; // adds doclets above to transpilat\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCSeriesDefaults;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCSeries.js', [_modules['Series/OHLC/OHLCPoint.js'], _modules['Series/OHLC/OHLCSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (OHLCPoint, OHLCSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { seriesTypes: { hlc: HLCSeries } } = SeriesRegistry;\n const { addEvent, extend, merge } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function onSeriesAfterSetOptions(e) {\n const options = e.options, dataGrouping = options.dataGrouping;\n if (dataGrouping &&\n options.useOhlcData &&\n options.id !== 'highcharts-navigator-series') {\n dataGrouping.approximation = 'ohlc';\n }\n }\n /**\n * Add useOhlcData option\n * @private\n */\n function onSeriesInit(eventOptions) {\n // eslint-disable-next-line no-invalid-this\n const series = this, options = eventOptions.options;\n if (options.useOhlcData &&\n options.id !== 'highcharts-navigator-series') {\n extend(series, {\n pointValKey: OHLCSeries.prototype.pointValKey,\n // keys: ohlcProto.keys, // @todo potentially nonsense\n pointArrayMap: OHLCSeries.prototype.pointArrayMap,\n toYData: OHLCSeries.prototype.toYData\n });\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The ohlc series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.ohlc\n *\n * @augments Highcharts.Series\n */\n class OHLCSeries extends HLCSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Static Functions\n *\n * */\n static compose(SeriesClass, ..._args) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'afterSetOptions', onSeriesAfterSetOptions);\n addEvent(SeriesClass, 'init', onSeriesInit);\n }\n }\n /* *\n *\n * Functions\n *\n * */\n getPointPath(point, graphic) {\n const path = super.getPointPath(point, graphic), strokeWidth = graphic.strokeWidth(), crispCorr = (strokeWidth % 2) / 2, crispX = Math.round(point.plotX) - crispCorr, halfWidth = Math.round(point.shapeArgs.width / 2);\n let plotOpen = point.plotOpen;\n // crisp vector coordinates\n if (point.open !== null) {\n plotOpen = Math.round(point.plotOpen) + crispCorr;\n path.push(['M', crispX, plotOpen], ['L', crispX - halfWidth, plotOpen]);\n super.extendStem(path, strokeWidth / 2, plotOpen);\n }\n return path;\n }\n /**\n * Postprocess mapping between options and SVG attributes\n * @private\n */\n pointAttribs(point, state) {\n const attribs = super.pointAttribs.call(this, point, state), options = this.options;\n delete attribs.fill;\n if (!point.options.color &&\n options.upColor &&\n point.open < point.close) {\n attribs.stroke = options.upColor;\n }\n return attribs;\n }\n toYData(point) {\n // return a plain array for speedy calculation\n return [point.open, point.high, point.low, point.close];\n }\n }\n OHLCSeries.defaultOptions = merge(HLCSeries.defaultOptions, OHLCSeriesDefaults);\n extend(OHLCSeries.prototype, {\n pointClass: OHLCPoint,\n pointArrayMap: ['open', 'high', 'low', 'close']\n });\n SeriesRegistry.registerSeriesType('ohlc', OHLCSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCSeries;\n });\n _registerModule(_modules, 'Series/Candlestick/CandlestickSeriesDefaults.js', [_modules['Core/Defaults.js'], _modules['Core/Utilities.js']], function (D, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { merge } = U;\n /* *\n *\n * API Options\n *\n * */\n /**\n * A candlestick chart is a style of financial chart used to describe\n * price movements over time.\n *\n * @sample stock/demo/candlestick/\n * Candlestick chart\n *\n * @extends plotOptions.ohlc\n * @excluding borderColor,borderRadius,borderWidth\n * @product highstock\n * @optionparent plotOptions.candlestick\n */\n const CandlestickSeriesDefaults = {\n /**\n * The specific line color for up candle sticks. The default is to\n * inherit the general `lineColor` setting.\n *\n * @sample {highstock} stock/plotoptions/candlestick-linecolor/\n * Candlestick line colors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 1.3.6\n * @product highstock\n * @apioption plotOptions.candlestick.upLineColor\n */\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The pixel width of the line/border around the\n * candlestick.\n *\n * @product highstock\n */\n lineWidth: 2\n }\n },\n /**\n * @type {number|null}\n * @product highstock\n */\n threshold: null,\n /**\n * The color of the line/border of the candlestick.\n *\n * In styled mode, the line stroke can be set with the\n * `.highcharts-candlestick-series .highcahrts-point` rule.\n *\n * @see [upLineColor](#plotOptions.candlestick.upLineColor)\n *\n * @sample {highstock} stock/plotoptions/candlestick-linecolor/\n * Candlestick line colors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highstock\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The pixel width of the candlestick line/border. Defaults to `1`.\n *\n *\n * In styled mode, the line stroke width can be set with the\n * `.highcharts-candlestick-series .highcahrts-point` rule.\n *\n * @product highstock\n */\n lineWidth: 1,\n /**\n * The fill color of the candlestick when values are rising.\n *\n * In styled mode, the up color can be set with the\n * `.highcharts-candlestick-series .highcharts-point-up` rule.\n *\n * @sample {highstock} stock/plotoptions/candlestick-color/\n * Custom colors\n * @sample {highstock} highcharts/css/candlestick/\n * Colors in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highstock\n */\n upColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * @product highstock\n */\n stickyTracking: true\n };\n /**\n * A `candlestick` series. If the [type](#series.candlestick.type)\n * option is not specified, it is inherited from [chart.type](\n * #chart.type).\n *\n * @type {*}\n * @extends series,plotOptions.candlestick\n * @excluding dataParser, dataURL, marker\n * @product highstock\n * @apioption series.candlestick\n */\n /**\n * An array of data points for the series. For the `candlestick` series\n * type, points can be given in the following ways:\n *\n * 1. An array of arrays with 5 or 4 values. In this case, the values correspond\n * to `x,open,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length 4.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 7, 2, 0, 4],\n * [1, 1, 4, 2, 8],\n * [2, 3, 3, 9, 3]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.candlestick.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * open: 9,\n * high: 2,\n * low: 4,\n * close: 6,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * open: 1,\n * high: 4,\n * low: 7,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number,number>|*>}\n * @extends series.ohlc.data\n * @excluding y\n * @product highstock\n * @apioption series.candlestick.data\n */\n ''; // adds doclets above to transpilat\n /* *\n *\n * Default Export\n *\n * */\n\n return CandlestickSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Candlestick/CandlestickSeries.js', [_modules['Series/Candlestick/CandlestickSeriesDefaults.js'], _modules['Core/Defaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (CandlestickSeriesDefaults, D, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { column: ColumnSeries, ohlc: OHLCSeries } = SeriesRegistry.seriesTypes;\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The candlestick series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.candlestick\n *\n * @augments Highcharts.seriesTypes.ohlc\n */\n class CandlestickSeries extends OHLCSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Postprocess mapping between options and SVG attributes\n *\n * @private\n * @function Highcharts.seriesTypes.candlestick#pointAttribs\n */\n pointAttribs(point, state) {\n const attribs = ColumnSeries.prototype.pointAttribs.call(this, point, state), options = this.options, isUp = point.open < point.close, stroke = options.lineColor || this.color, color = point.color || this.color; // (#14826)\n attribs['stroke-width'] = options.lineWidth;\n attribs.fill = point.options.color ||\n (isUp ? (options.upColor || color) : color);\n attribs.stroke = point.options.lineColor ||\n (isUp ? (options.upLineColor || stroke) : stroke);\n // Select or hover states\n if (state) {\n const stateOptions = options.states[state];\n attribs.fill = stateOptions.color || attribs.fill;\n attribs.stroke = stateOptions.lineColor || attribs.stroke;\n attribs['stroke-width'] =\n stateOptions.lineWidth || attribs['stroke-width'];\n }\n return attribs;\n }\n /**\n * Draw the data points.\n *\n * @private\n * @function Highcharts.seriesTypes.candlestick#drawPoints\n */\n drawPoints() {\n const series = this, points = series.points, chart = series.chart, reversedYAxis = series.yAxis.reversed;\n for (const point of points) {\n let graphic = point.graphic, plotOpen, plotClose, topBox, bottomBox, hasTopWhisker, hasBottomWhisker, crispCorr, crispX, path, halfWidth;\n const isNew = !graphic;\n if (typeof point.plotY !== 'undefined') {\n if (!graphic) {\n point.graphic = graphic = chart.renderer.path()\n .add(series.group);\n }\n if (!series.chart.styledMode) {\n graphic\n .attr(series.pointAttribs(point, (point.selected && 'select'))) // #3897\n .shadow(series.options.shadow);\n }\n // Crisp vector coordinates\n crispCorr = (graphic.strokeWidth() % 2) / 2;\n // #2596:\n crispX = Math.round(point.plotX) - crispCorr;\n plotOpen = point.plotOpen;\n plotClose = point.plotClose;\n topBox = Math.min(plotOpen, plotClose);\n bottomBox = Math.max(plotOpen, plotClose);\n halfWidth = Math.round(point.shapeArgs.width / 2);\n hasTopWhisker = reversedYAxis ?\n bottomBox !== point.yBottom :\n Math.round(topBox) !==\n Math.round(point.plotHigh);\n hasBottomWhisker = reversedYAxis ?\n Math.round(topBox) !==\n Math.round(point.plotHigh) :\n bottomBox !== point.yBottom;\n topBox = Math.round(topBox) + crispCorr;\n bottomBox = Math.round(bottomBox) + crispCorr;\n // Create the path. Due to a bug in Chrome 49, the path is\n // first instanciated with no values, then the values\n // pushed. For unknown reasons, instanciating the path array\n // with all the values would lead to a crash when updating\n // frequently (#5193).\n path = [];\n path.push(['M', crispX - halfWidth, bottomBox], ['L', crispX - halfWidth, topBox], ['L', crispX + halfWidth, topBox], ['L', crispX + halfWidth, bottomBox], ['Z'], // Ensure a nice rectangle #2602\n ['M', crispX, topBox], [\n 'L',\n // #460, #2094\n crispX,\n hasTopWhisker ?\n Math.round(reversedYAxis ?\n point.yBottom :\n point.plotHigh) :\n topBox\n ], ['M', crispX, bottomBox], [\n 'L',\n // #460, #2094\n crispX,\n hasBottomWhisker ?\n Math.round(reversedYAxis ?\n point.plotHigh :\n point.yBottom) :\n bottomBox\n ]);\n graphic[isNew ? 'attr' : 'animate']({ d: path })\n .addClass(point.getClassName(), true);\n }\n }\n }\n }\n CandlestickSeries.defaultOptions = merge(OHLCSeries.defaultOptions, defaultOptions.plotOptions, { tooltip: OHLCSeries.defaultOptions.tooltip }, CandlestickSeriesDefaults);\n SeriesRegistry.registerSeriesType('candlestick', CandlestickSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return CandlestickSeries;\n });\n _registerModule(_modules, 'Series/Flags/FlagsPoint.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: { prototype: { pointClass: ColumnPoint } } } = SeriesRegistry.seriesTypes;\n const { isNumber } = U;\n /* *\n *\n * Class\n *\n * */\n class FlagsPoint extends ColumnPoint {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.options = void 0;\n this.series = void 0;\n this.ttBelow = false;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n isValid() {\n // #9233 - Prevent from treating flags as null points (even if\n // they have no y values defined).\n return isNumber(this.y) || typeof this.y === 'undefined';\n }\n /**\n * @private\n */\n hasNewShapeType() {\n const shape = this.options.shape || this.series.options.shape;\n return this.graphic && shape && shape !== this.graphic.symbolKey;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsPoint;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Flags are used to mark events in stock charts. They can be added on the\n * timeline, or attached to a specific series.\n *\n * @sample stock/demo/flags-general/\n * Flags on a line series\n *\n * @extends plotOptions.column\n * @excluding animation, borderColor, borderRadius, borderWidth,\n * colorByPoint, cropThreshold, dataGrouping, pointPadding,\n * pointWidth, turboThreshold\n * @product highstock\n * @optionparent plotOptions.flags\n */\n const FlagsSeriesDefaults = {\n /**\n * In case the flag is placed on a series, on what point key to place\n * it. Line and columns have one key, `y`. In range or OHLC-type series,\n * however, the flag can optionally be placed on the `open`, `high`,\n * `low` or `close` key.\n *\n * @sample {highstock} stock/plotoptions/flags-onkey/\n * Range series, flag on high\n *\n * @type {string}\n * @default y\n * @since 4.2.2\n * @product highstock\n * @validvalue [\"y\", \"open\", \"high\", \"low\", \"close\"]\n * @apioption plotOptions.flags.onKey\n */\n /**\n * The id of the series that the flags should be drawn on. If no id\n * is given, the flags are drawn on the x axis.\n *\n * @sample {highstock} stock/plotoptions/flags/\n * Flags on series and on x axis\n *\n * @type {string}\n * @product highstock\n * @apioption plotOptions.flags.onSeries\n */\n pointRange: 0,\n /**\n * Whether the flags are allowed to overlap sideways. If `false`, the\n * flags are moved sideways using an algorithm that seeks to place every\n * flag as close as possible to its original position.\n *\n * @sample {highstock} stock/plotoptions/flags-allowoverlapx\n * Allow sideways overlap\n *\n * @since 6.0.4\n */\n allowOverlapX: false,\n /**\n * The shape of the marker. Can be one of \"flag\", \"circlepin\",\n * \"squarepin\", or an image of the format `url(/path-to-image.jpg)`.\n * Individual shapes can also be set for each point.\n *\n * @sample {highstock} stock/plotoptions/flags/\n * Different shapes\n *\n * @type {Highcharts.FlagsShapeValue}\n * @product highstock\n */\n shape: 'flag',\n /**\n * When multiple flags in the same series fall on the same value, this\n * number determines the vertical offset between them.\n *\n * @sample {highstock} stock/plotoptions/flags-stackdistance/\n * A greater stack distance\n *\n * @product highstock\n */\n stackDistance: 12,\n /**\n * Text alignment for the text inside the flag.\n *\n * @since 5.0.0\n * @product highstock\n * @validvalue [\"left\", \"center\", \"right\"]\n */\n textAlign: 'center',\n /**\n * Specific tooltip options for flag series. Flag series tooltips are\n * different from most other types in that a flag doesn't have a data\n * value, so the tooltip rather displays the `text` option for each\n * point.\n *\n * @extends plotOptions.series.tooltip\n * @excluding changeDecimals, valueDecimals, valuePrefix, valueSuffix\n * @product highstock\n */\n tooltip: {\n pointFormat: '{point.text}'\n },\n /**\n * @type {number|null}\n */\n threshold: null,\n /**\n * The text to display on each flag. This can be defined on series\n * level, or individually for each point. Defaults to `\"A\"`.\n *\n * @type {string}\n * @default A\n * @product highstock\n * @apioption plotOptions.flags.title\n */\n /**\n * The y position of the top left corner of the flag relative to either\n * the series (if onSeries is defined), or the x axis. Defaults to\n * `-30`.\n *\n * @product highstock\n */\n y: -30,\n /**\n * Whether to use HTML to render the flag texts. Using HTML allows for\n * advanced formatting, images and reliable bi-directional text\n * rendering. Note that exported images won't respect the HTML, and that\n * HTML won't respect Z-index settings.\n *\n * @type {boolean}\n * @default false\n * @since 1.3\n * @product highstock\n * @apioption plotOptions.flags.useHTML\n */\n /**\n * Fixed width of the flag's shape. By default, width is autocalculated\n * according to the flag's title.\n *\n * @sample {highstock} stock/demo/flags-shapes/\n * Flags with fixed width\n *\n * @type {number}\n * @product highstock\n * @apioption plotOptions.flags.width\n */\n /**\n * Fixed height of the flag's shape. By default, height is\n * autocalculated according to the flag's title.\n *\n * @type {number}\n * @product highstock\n * @apioption plotOptions.flags.height\n */\n /**\n * The fill color for the flags.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n fillColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The color of the line/border of the flag.\n *\n * In styled mode, the stroke is set in the\n * `.highcharts-flag-series.highcharts-point` rule.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highstock\n * @apioption plotOptions.flags.lineColor\n */\n /**\n * The pixel width of the flag's line/border.\n *\n * @product highstock\n */\n lineWidth: 1,\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The color of the line/border of the flag.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The fill or background color of the flag.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n fillColor: \"#ccd3ff\" /* Palette.highlightColor20 */\n }\n },\n /**\n * The text styles of the flag.\n *\n * In styled mode, the styles are set in the\n * `.highcharts-flag-series .highcharts-point` rule.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontSize\": \"11px\", \"fontWeight\": \"bold\"}\n * @product highstock\n */\n style: {\n /** @ignore-option */\n fontSize: '0.7em',\n /** @ignore-option */\n fontWeight: 'bold'\n }\n };\n /**\n * A `flags` series. If the [type](#series.flags.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.flags\n * @excluding animation, borderColor, borderRadius, borderWidth, colorByPoint,\n * connectNulls, cropThreshold, dashStyle, dataGrouping, dataParser,\n * dataURL, gapSize, gapUnit, linecap, lineWidth, marker,\n * pointPadding, pointWidth, step, turboThreshold, useOhlcData\n * @product highstock\n * @apioption series.flags\n */\n /**\n * An array of data points for the series. For the `flags` series type,\n * points can be given in the following ways:\n *\n * 1. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.flags.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * title: \"A\",\n * text: \"First event\"\n * }, {\n * x: 1,\n * title: \"B\",\n * text: \"Second event\"\n * }]\n * ```\n *\n * @type {Array<*>}\n * @extends series.line.data\n * @excluding dataLabels, marker, name, y\n * @product highstock\n * @apioption series.flags.data\n */\n /**\n * The fill color of an individual flag. By default it inherits from\n * the series color.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n * @apioption series.flags.data.fillColor\n */\n /**\n * The longer text to be shown in the flag's tooltip.\n *\n * @type {string}\n * @product highstock\n * @apioption series.flags.data.text\n */\n /**\n * The short text to be shown on the flag.\n *\n * @type {string}\n * @product highstock\n * @apioption series.flags.data.title\n */\n ''; // keeps doclets above in transpiled file\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSymbols.js', [_modules['Core/Renderer/RendererRegistry.js']], function (RendererRegistry) {\n /* *\n *\n * Imports\n *\n * */\n /* *\n *\n * Composition\n *\n * */\n var FlagsSymbols;\n (function (FlagsSymbols) {\n /* *\n *\n * Constants\n *\n * */\n const modifiedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(SVGRendererClass) {\n if (modifiedMembers.indexOf(SVGRendererClass) === -1) {\n modifiedMembers.push(SVGRendererClass);\n const symbols = SVGRendererClass.prototype.symbols;\n symbols.flag = flag;\n createPinSymbol(symbols, 'circle');\n createPinSymbol(symbols, 'square');\n }\n const RendererClass = RendererRegistry.getRendererType();\n // The symbol callbacks are generated on the SVGRenderer object in all\n // browsers.\n if (modifiedMembers.indexOf(RendererClass)) {\n modifiedMembers.push(RendererClass);\n }\n }\n FlagsSymbols.compose = compose;\n /**\n * Create the flag icon with anchor.\n * @private\n */\n function flag(x, y, w, h, options) {\n const anchorX = (options && options.anchorX) || x, anchorY = (options && options.anchorY) || y;\n // To do: unwanted any cast because symbols.circle has wrong type, it\n // actually returns an SVGPathArray\n const path = this.circle(anchorX - 1, anchorY - 1, 2, 2);\n path.push(['M', anchorX, anchorY], ['L', x, y + h], ['L', x, y], ['L', x + w, y], ['L', x + w, y + h], ['L', x, y + h], ['Z']);\n return path;\n }\n /**\n * Create the circlepin and squarepin icons with anchor.\n * @private\n */\n function createPinSymbol(symbols, shape) {\n symbols[(shape + 'pin')] = function (x, y, w, h, options) {\n const anchorX = options && options.anchorX, anchorY = options && options.anchorY;\n let path;\n // For single-letter flags, make sure circular flags are not taller\n // than their width\n if (shape === 'circle' && h > w) {\n x -= Math.round((h - w) / 2);\n w = h;\n }\n path = (symbols[shape])(x, y, w, h);\n if (anchorX && anchorY) {\n /**\n * If the label is below the anchor, draw the connecting line\n * from the top edge of the label, otherwise start drawing from\n * the bottom edge\n */\n let labelX = anchorX;\n if (shape === 'circle') {\n labelX = x + w / 2;\n }\n else {\n const startSeg = path[0];\n const endSeg = path[1];\n if (startSeg[0] === 'M' && endSeg[0] === 'L') {\n labelX = (startSeg[1] + endSeg[1]) / 2;\n }\n }\n const labelY = (y > anchorY) ? y : y + h;\n path.push([\n 'M',\n labelX,\n labelY\n ], [\n 'L',\n anchorX,\n anchorY\n ]);\n path = path.concat(symbols.circle(anchorX - 1, anchorY - 1, 2, 2));\n }\n return path;\n };\n }\n })(FlagsSymbols || (FlagsSymbols = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsSymbols;\n });\n _registerModule(_modules, 'Series/OnSeriesComposition.js', [_modules['Series/Column/ColumnSeries.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (ColumnSeries, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { prototype: columnProto } = ColumnSeries;\n const { prototype: seriesProto } = Series;\n const { defined, stableSort } = U;\n /* *\n *\n * Composition\n *\n * */\n var OnSeriesComposition;\n (function (OnSeriesComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Properties\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(SeriesClass) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.getPlotBox = getPlotBox;\n seriesProto.translate = translate;\n }\n return SeriesClass;\n }\n OnSeriesComposition.compose = compose;\n /**\n * Override getPlotBox. If the onSeries option is valid, return the plot box\n * of the onSeries, otherwise proceed as usual.\n *\n * @private\n */\n function getPlotBox(name) {\n return seriesProto.getPlotBox.call((this.options.onSeries &&\n this.chart.get(this.options.onSeries)) || this, name);\n }\n OnSeriesComposition.getPlotBox = getPlotBox;\n /**\n * Extend the translate method by placing the point on the related series\n *\n * @private\n */\n function translate() {\n columnProto.translate.apply(this);\n const series = this, options = series.options, chart = series.chart, points = series.points, optionsOnSeries = options.onSeries, onSeries = (optionsOnSeries &&\n chart.get(optionsOnSeries)), step = onSeries && onSeries.options.step, onData = (onSeries && onSeries.points), inverted = chart.inverted, xAxis = series.xAxis, yAxis = series.yAxis;\n let cursor = points.length - 1, point, lastPoint, onKey = options.onKey || 'y', i = onData && onData.length, xOffset = 0, leftPoint, lastX, rightPoint, currentDataGrouping, distanceRatio;\n // relate to a master series\n if (onSeries && onSeries.visible && i) {\n xOffset = (onSeries.pointXOffset || 0) + (onSeries.barW || 0) / 2;\n currentDataGrouping = onSeries.currentDataGrouping;\n lastX = (onData[i - 1].x +\n (currentDataGrouping ? currentDataGrouping.totalRange : 0)); // #2374\n // sort the data points\n stableSort(points, (a, b) => (a.x - b.x));\n onKey = 'plot' + onKey[0].toUpperCase() + onKey.substr(1);\n while (i-- && points[cursor]) {\n leftPoint = onData[i];\n point = points[cursor];\n point.y = leftPoint.y;\n if (leftPoint.x <= point.x &&\n typeof leftPoint[onKey] !== 'undefined') {\n if (point.x <= lastX) { // #803\n point.plotY = leftPoint[onKey];\n // interpolate between points, #666\n if (leftPoint.x < point.x &&\n !step) {\n rightPoint = onData[i + 1];\n if (rightPoint &&\n typeof rightPoint[onKey] !== 'undefined') {\n // the distance ratio, between 0 and 1\n distanceRatio =\n (point.x - leftPoint.x) /\n (rightPoint.x - leftPoint.x);\n point.plotY +=\n distanceRatio *\n // the plotY distance\n (rightPoint[onKey] - leftPoint[onKey]);\n point.y +=\n distanceRatio *\n (rightPoint.y - leftPoint.y);\n }\n }\n }\n cursor--;\n i++; // check again for points in the same x position\n if (cursor < 0) {\n break;\n }\n }\n }\n }\n // Add plotY position and handle stacking\n points.forEach((point, i) => {\n let stackIndex;\n point.plotX += xOffset; // #2049\n // Undefined plotY means the point is either on axis, outside series\n // range or hidden series. If the series is outside the range of the\n // x axis it should fall through with an undefined plotY, but then\n // we must remove the shapeArgs (#847). For inverted charts, we need\n // to calculate position anyway, because series.invertGroups is not\n // defined\n if (typeof point.plotY === 'undefined' || inverted) {\n if (point.plotX >= 0 &&\n point.plotX <= xAxis.len) {\n // We're inside xAxis range\n if (inverted) {\n point.plotY = xAxis.translate(point.x, 0, 1, 0, 1);\n point.plotX = defined(point.y) ?\n yAxis.translate(point.y, 0, 0, 0, 1) :\n 0;\n }\n else {\n point.plotY = (xAxis.opposite ? 0 : series.yAxis.len) +\n xAxis.offset; // For the windbarb demo\n }\n }\n else {\n point.shapeArgs = {}; // 847\n }\n }\n // if multiple flags appear at the same x, order them into a stack\n lastPoint = points[i - 1];\n if (lastPoint && lastPoint.plotX === point.plotX) {\n if (typeof lastPoint.stackIndex === 'undefined') {\n lastPoint.stackIndex = 0;\n }\n stackIndex = lastPoint.stackIndex + 1;\n }\n point.stackIndex = stackIndex; // #3639\n });\n this.onSeries = onSeries;\n }\n OnSeriesComposition.translate = translate;\n })(OnSeriesComposition || (OnSeriesComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return OnSeriesComposition;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSeries.js', [_modules['Series/Flags/FlagsPoint.js'], _modules['Series/Flags/FlagsSeriesDefaults.js'], _modules['Series/Flags/FlagsSymbols.js'], _modules['Core/Globals.js'], _modules['Series/OnSeriesComposition.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (FlagsPoint, FlagsSeriesDefaults, FlagsSymbols, H, OnSeriesComposition, R, SeriesRegistry, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { noop } = H;\n const { distribute } = R;\n const { series: Series, seriesTypes: { column: ColumnSeries } } = SeriesRegistry;\n const { addEvent, defined, extend, merge, objectEach, wrap } = U;\n /* *\n *\n * Classes\n *\n * */\n /**\n * The Flags series.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.flags\n *\n * @augments Highcharts.Series\n */\n class FlagsSeries extends ColumnSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Disable animation, but keep clipping (#8546).\n * @private\n */\n animate(init) {\n if (init) {\n this.setClip();\n }\n }\n /**\n * Draw the markers.\n * @private\n */\n drawPoints() {\n const series = this, points = series.points, chart = series.chart, renderer = chart.renderer, inverted = chart.inverted, options = series.options, optionsY = options.y, yAxis = series.yAxis, boxesMap = {}, boxes = [];\n let plotX, plotY, shape, i, point, graphic, stackIndex, anchorY, attribs, outsideRight, centered;\n i = points.length;\n while (i--) {\n point = points[i];\n outsideRight =\n (inverted ? point.plotY : point.plotX) >\n series.xAxis.len;\n plotX = point.plotX;\n stackIndex = point.stackIndex;\n shape = point.options.shape || options.shape;\n plotY = point.plotY;\n if (typeof plotY !== 'undefined') {\n plotY = point.plotY + optionsY -\n (typeof stackIndex !== 'undefined' &&\n (stackIndex * options.stackDistance));\n }\n // skip connectors for higher level stacked points\n point.anchorX = stackIndex ? void 0 : point.plotX;\n anchorY = stackIndex ? void 0 : point.plotY;\n centered = shape !== 'flag';\n graphic = point.graphic;\n // Only draw the point if y is defined and the flag is within\n // the visible area\n if (typeof plotY !== 'undefined' &&\n plotX >= 0 &&\n !outsideRight) {\n // #15384\n if (graphic && point.hasNewShapeType()) {\n graphic = graphic.destroy();\n }\n // Create the flag\n if (!graphic) {\n graphic = point.graphic = renderer.label('', null, null, shape, null, null, options.useHTML)\n .addClass('highcharts-point')\n .add(series.markerGroup);\n // Add reference to the point for tracker (#6303)\n if (point.graphic.div) {\n point.graphic.div.point = point;\n }\n graphic.isNew = true;\n }\n graphic.attr({\n align: centered ? 'center' : 'left',\n width: options.width,\n height: options.height,\n 'text-align': options.textAlign\n });\n if (!chart.styledMode) {\n graphic\n .attr(series.pointAttribs(point))\n .css(merge(options.style, point.style))\n .shadow(options.shadow);\n }\n if (plotX > 0) { // #3119\n plotX -= graphic.strokeWidth() % 2; // #4285\n }\n // Plant the flag\n attribs = {\n y: plotY,\n anchorY: anchorY\n };\n if (options.allowOverlapX) {\n attribs.x = plotX;\n attribs.anchorX = point.anchorX;\n }\n graphic.attr({\n text: point.options.title || options.title || 'A'\n })[graphic.isNew ? 'attr' : 'animate'](attribs);\n // Rig for the distribute function\n if (!options.allowOverlapX) {\n if (!boxesMap[point.plotX]) {\n boxesMap[point.plotX] = {\n align: centered ? 0.5 : 0,\n size: graphic.width,\n target: plotX,\n anchorX: plotX\n };\n }\n else {\n boxesMap[point.plotX].size = Math.max(boxesMap[point.plotX].size, graphic.width);\n }\n }\n // Set the tooltip anchor position\n point.tooltipPos = [\n plotX,\n plotY + yAxis.pos - chart.plotTop\n ]; // #6327\n }\n else if (graphic) {\n point.graphic = graphic.destroy();\n }\n }\n // Handle X-dimension overlapping\n if (!options.allowOverlapX) {\n let maxDistance = 100;\n objectEach(boxesMap, function (box) {\n box.plotX = box.anchorX;\n boxes.push(box);\n maxDistance = Math.max(box.size, maxDistance);\n });\n // If necessary (for overlapping or long labels) distribute it\n // depending on the label width or a hardcoded value, #16041.\n distribute(boxes, inverted ? yAxis.len : this.xAxis.len, maxDistance);\n for (const point of points) {\n const plotX = point.plotX, graphic = point.graphic, box = graphic && boxesMap[plotX];\n if (box && graphic) {\n // Hide flag when its box position is not specified\n // (#8573, #9299)\n if (!defined(box.pos)) {\n graphic.hide().isNew = true;\n }\n else {\n graphic[graphic.isNew ? 'attr' : 'animate']({\n x: box.pos + (box.align || 0) * box.size,\n anchorX: point.anchorX\n }).show().isNew = false;\n }\n }\n }\n }\n // Can be a mix of SVG and HTML and we need events for both (#6303)\n if (options.useHTML && series.markerGroup) {\n wrap(series.markerGroup, 'on', function (proceed) {\n return SVGElement.prototype.on.apply(\n // for HTML\n // eslint-disable-next-line no-invalid-this\n proceed.apply(this, [].slice.call(arguments, 1)), \n // and for SVG\n [].slice.call(arguments, 1));\n });\n }\n }\n /**\n * Extend the column trackers with listeners to expand and contract\n * stacks.\n * @private\n */\n drawTracker() {\n const series = this, points = series.points;\n super.drawTracker();\n /* *\n * Bring each stacked flag up on mouse over, this allows readability\n * of vertically stacked elements as well as tight points on the x\n * axis. #1924.\n */\n for (const point of points) {\n const graphic = point.graphic;\n if (graphic) {\n if (point.unbindMouseOver) {\n point.unbindMouseOver();\n }\n point.unbindMouseOver = addEvent(graphic.element, 'mouseover', function () {\n // Raise this point\n if (point.stackIndex > 0 &&\n !point.raised) {\n point._y = graphic.y;\n graphic.attr({\n y: point._y - 8\n });\n point.raised = true;\n }\n // Revert other raised points\n for (const otherPoint of points) {\n if (otherPoint !== point &&\n otherPoint.raised &&\n otherPoint.graphic) {\n otherPoint.graphic.attr({\n y: otherPoint._y\n });\n otherPoint.raised = false;\n }\n }\n });\n }\n }\n }\n /**\n * Get presentational attributes\n * @private\n */\n pointAttribs(point, state) {\n const options = this.options, color = (point && point.color) || this.color;\n let lineColor = options.lineColor, lineWidth = (point && point.lineWidth), fill = (point && point.fillColor) || options.fillColor;\n if (state) {\n fill = options.states[state].fillColor;\n lineColor = options.states[state].lineColor;\n lineWidth = options.states[state].lineWidth;\n }\n return {\n fill: fill || color,\n stroke: lineColor || color,\n 'stroke-width': lineWidth || options.lineWidth || 0\n };\n }\n /**\n * @private\n */\n setClip() {\n Series.prototype.setClip.apply(this, arguments);\n if (this.options.clip !== false &&\n this.sharedClipKey &&\n this.markerGroup) {\n this.markerGroup.clip(this.chart.sharedClips[this.sharedClipKey]);\n }\n }\n }\n FlagsSeries.compose = FlagsSymbols.compose;\n FlagsSeries.defaultOptions = merge(ColumnSeries.defaultOptions, FlagsSeriesDefaults);\n OnSeriesComposition.compose(FlagsSeries);\n extend(FlagsSeries.prototype, {\n allowDG: false,\n forceCrop: true,\n invertible: false,\n noSharedTooltip: true,\n pointClass: FlagsPoint,\n sorted: false,\n takeOrdinalPosition: false,\n trackerGroups: ['markerGroup'],\n buildKDTree: noop,\n /**\n * Inherit the initialization from base Series.\n * @private\n */\n init: Series.prototype.init\n });\n SeriesRegistry.registerSeriesType('flags', FlagsSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"circlepin\"|\"flag\"|\"squarepin\"} Highcharts.FlagsShapeValue\n */\n ''; // detach doclets above\n\n return FlagsSeries;\n });\n _registerModule(_modules, 'Core/Chart/StockChart.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Templating.js'], _modules['Core/Defaults.js'], _modules['Stock/Navigator/NavigatorDefaults.js'], _modules['Stock/RangeSelector/RangeSelectorDefaults.js'], _modules['Stock/Scrollbar/ScrollbarDefaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (Axis, Chart, F, D, NavigatorDefaults, RangeSelectorDefaults, ScrollbarDefaults, Series, SVGRenderer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = F;\n const { getOptions } = D;\n const { addEvent, clamp, defined, extend, find, isNumber, isString, merge, pick, splat } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Stock-optimized chart. Use {@link Highcharts.Chart|Chart} for common charts.\n *\n * @requires modules/stock\n *\n * @class\n * @name Highcharts.StockChart\n * @extends Highcharts.Chart\n */\n class StockChart extends Chart {\n /**\n * Initializes the chart. The constructor's arguments are passed on\n * directly.\n *\n * @function Highcharts.StockChart#init\n *\n * @param {Highcharts.Options} userOptions\n * Custom options.\n *\n * @param {Function} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded.\n *\n *\n * @emits Highcharts.StockChart#event:init\n * @emits Highcharts.StockChart#event:afterInit\n */\n init(userOptions, callback) {\n const defaultOptions = getOptions(), xAxisOptions = userOptions.xAxis, yAxisOptions = userOptions.yAxis, \n // Always disable startOnTick:true on the main axis when the\n // navigator is enabled (#1090)\n navigatorEnabled = pick(userOptions.navigator && userOptions.navigator.enabled, NavigatorDefaults.enabled, true);\n // Avoid doing these twice\n userOptions.xAxis = userOptions.yAxis = void 0;\n const options = merge({\n chart: {\n panning: {\n enabled: true,\n type: 'x'\n },\n zooming: {\n pinchType: 'x'\n }\n },\n navigator: {\n enabled: navigatorEnabled\n },\n scrollbar: {\n // #4988 - check if setOptions was called\n enabled: pick(ScrollbarDefaults.enabled, true)\n },\n rangeSelector: {\n // #4988 - check if setOptions was called\n enabled: pick(RangeSelectorDefaults.rangeSelector.enabled, true)\n },\n title: {\n text: null\n },\n tooltip: {\n split: pick(defaultOptions.tooltip.split, true),\n crosshairs: true\n },\n legend: {\n enabled: false\n }\n }, userOptions, // user's options\n {\n isStock: true // internal flag\n });\n userOptions.xAxis = xAxisOptions;\n userOptions.yAxis = yAxisOptions;\n // apply X axis options to both single and multi y axes\n options.xAxis = splat(userOptions.xAxis || {}).map(function (xAxisOptions, i) {\n return merge(getDefaultAxisOptions('xAxis', xAxisOptions), defaultOptions.xAxis, // #3802\n // #7690\n defaultOptions.xAxis && defaultOptions.xAxis[i], xAxisOptions, // user options\n getForcedAxisOptions('xAxis', userOptions));\n });\n // apply Y axis options to both single and multi y axes\n options.yAxis = splat(userOptions.yAxis || {}).map(function (yAxisOptions, i) {\n return merge(getDefaultAxisOptions('yAxis', yAxisOptions), defaultOptions.yAxis, // #3802\n // #7690\n defaultOptions.yAxis && defaultOptions.yAxis[i], yAxisOptions // user options\n );\n });\n super.init(options, callback);\n }\n /**\n * Factory for creating different axis types.\n * Extended to add stock defaults.\n *\n * @private\n * @function Highcharts.StockChart#createAxis\n * @param {string} coll\n * An axis type.\n * @param {Chart.CreateAxisOptionsObject} options\n * The axis creation options.\n */\n createAxis(coll, options) {\n options.axis = merge(getDefaultAxisOptions(coll, options.axis), options.axis, getForcedAxisOptions(coll, this.userOptions));\n return super.createAxis(coll, options);\n }\n }\n /* eslint-disable no-invalid-this, valid-jsdoc */\n (function (StockChart) {\n /**\n * Factory function for creating new stock charts. Creates a new\n * {@link Highcharts.StockChart|StockChart} object with different default\n * options than the basic Chart.\n *\n * @example\n * let chart = Highcharts.stockChart('container', {\n * series: [{\n * data: [1, 2, 3, 4, 5, 6, 7, 8, 9],\n * pointInterval: 24 * 60 * 60 * 1000\n * }]\n * });\n *\n * @function Highcharts.stockChart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure as described in the\n * [options reference](https://api.highcharts.com/highstock).\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * A function to execute when the chart object is finished\n * rendering and all external image files (`chart.backgroundImage`,\n * `chart.plotBackgroundImage` etc) are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highstock/chart.events.load)\n * handler is equivalent.\n *\n * @return {Highcharts.StockChart}\n * The chart object.\n */\n function stockChart(a, b, c) {\n return new StockChart(a, b, c);\n }\n StockChart.stockChart = stockChart;\n })(StockChart || (StockChart = {}));\n /**\n * Get stock-specific default axis options.\n *\n * @private\n * @function getDefaultAxisOptions\n */\n function getDefaultAxisOptions(type, options) {\n if (type === 'xAxis') {\n return {\n minPadding: 0,\n maxPadding: 0,\n overscroll: 0,\n ordinal: true,\n title: {\n text: null\n },\n labels: {\n overflow: 'justify'\n },\n showLastLabel: true\n };\n }\n if (type === 'yAxis') {\n return {\n labels: {\n y: -2\n },\n opposite: pick(options.opposite, true),\n showLastLabel: !!(\n // #6104, show last label by default for category axes\n options.categories ||\n options.type === 'category'),\n title: {\n text: null\n }\n };\n }\n return {};\n }\n /**\n * Get stock-specific forced axis options.\n *\n * @private\n * @function getForcedAxisOptions\n */\n function getForcedAxisOptions(type, chartOptions) {\n if (type === 'xAxis') {\n // Always disable startOnTick:true on the main axis when the navigator\n // is enabled (#1090)\n const navigatorEnabled = pick(chartOptions.navigator && chartOptions.navigator.enabled, NavigatorDefaults.enabled, true);\n const axisOptions = {\n type: 'datetime',\n categories: void 0\n };\n if (navigatorEnabled) {\n axisOptions.startOnTick = false;\n axisOptions.endOnTick = false;\n }\n return axisOptions;\n }\n return {};\n }\n /* *\n *\n * Compositions\n *\n * */\n // Handle som Stock-specific series defaults, override the plotOptions before\n // series options are handled.\n addEvent(Series, 'setOptions', function (e) {\n let overrides;\n if (this.chart.options.isStock) {\n if (this.is('column') || this.is('columnrange')) {\n overrides = {\n borderWidth: 0,\n shadow: false\n };\n }\n else if (!this.is('scatter') && !this.is('sma')) {\n overrides = {\n marker: {\n enabled: false,\n radius: 2\n }\n };\n }\n if (overrides) {\n e.plotOptions[this.type] = merge(e.plotOptions[this.type], overrides);\n }\n }\n });\n // Override the automatic label alignment so that the first Y axis' labels are\n // drawn on top of the grid line, and subsequent axes are drawn outside\n addEvent(Axis, 'autoLabelAlign', function (e) {\n const { chart, options } = this, panes = chart._labelPanes = chart._labelPanes || {}, labelOptions = options.labels;\n if (chart.options.isStock && this.coll === 'yAxis') {\n const key = options.top + ',' + options.height;\n // Do it only for the first Y axis of each pane\n if (!panes[key] && labelOptions.enabled) {\n if (labelOptions.distance === 15 && // default\n this.side === 1) {\n labelOptions.distance = 0;\n }\n if (typeof labelOptions.align === 'undefined') {\n labelOptions.align = 'right';\n }\n panes[key] = this;\n e.align = 'right';\n e.preventDefault();\n }\n }\n });\n // Clear axis from label panes (#6071)\n addEvent(Axis, 'destroy', function () {\n const chart = this.chart, key = this.options && (this.options.top + ',' + this.options.height);\n if (key && chart._labelPanes && chart._labelPanes[key] === this) {\n delete chart._labelPanes[key];\n }\n });\n // Override getPlotLinePath to allow for multipane charts\n addEvent(Axis, 'getPlotLinePath', function (e) {\n let axis = this, series = (this.isLinked && !this.series ?\n this.linkedParent.series :\n this.series), chart = axis.chart, renderer = chart.renderer, axisLeft = axis.left, axisTop = axis.top, x1, y1, x2, y2, result = [], axes = [], // #3416 need a default array\n axes2, uniqueAxes, translatedValue = e.translatedValue, value = e.value, force = e.force, transVal;\n /**\n * Return the other axis based on either the axis option or on related\n * series.\n * @private\n */\n function getAxis(coll) {\n const otherColl = coll === 'xAxis' ? 'yAxis' : 'xAxis', opt = axis.options[otherColl];\n // Other axis indexed by number\n if (isNumber(opt)) {\n return [chart[otherColl][opt]];\n }\n // Other axis indexed by id (like navigator)\n if (isString(opt)) {\n return [chart.get(opt)];\n }\n // Auto detect based on existing series\n return series.map(function (s) {\n return s[otherColl];\n });\n }\n if ( // For stock chart, by default render paths across the panes\n // except the case when `acrossPanes` is disabled by user (#6644)\n (chart.options.isStock && e.acrossPanes !== false) &&\n // Ignore in case of colorAxis or zAxis. #3360, #3524, #6720\n axis.coll === 'xAxis' || axis.coll === 'yAxis') {\n e.preventDefault();\n // Get the related axes based on series\n axes = getAxis(axis.coll);\n // Get the related axes based options.*Axis setting #2810\n axes2 = (axis.isXAxis ? chart.yAxis : chart.xAxis);\n axes2.forEach(function (A) {\n if (defined(A.options.id) ?\n A.options.id.indexOf('navigator') === -1 :\n true) {\n const a = (A.isXAxis ? 'yAxis' : 'xAxis'), rax = (defined(A.options[a]) ?\n chart[a][A.options[a]] :\n chart[a][0]);\n if (axis === rax) {\n axes.push(A);\n }\n }\n });\n // Remove duplicates in the axes array. If there are no axes in the axes\n // array, we are adding an axis without data, so we need to populate\n // this with grid lines (#2796).\n uniqueAxes = axes.length ?\n [] :\n [axis.isXAxis ? chart.yAxis[0] : chart.xAxis[0]]; // #3742\n axes.forEach(function (axis2) {\n if (uniqueAxes.indexOf(axis2) === -1 &&\n // Do not draw on axis which overlap completely. #5424\n !find(uniqueAxes, function (unique) {\n return unique.pos === axis2.pos && unique.len === axis2.len;\n })) {\n uniqueAxes.push(axis2);\n }\n });\n transVal = pick(translatedValue, axis.translate(value, void 0, void 0, e.old));\n if (isNumber(transVal)) {\n if (axis.horiz) {\n uniqueAxes.forEach(function (axis2) {\n let skip;\n y1 = axis2.pos;\n y2 = y1 + axis2.len;\n x1 = x2 = Math.round(transVal + axis.transB);\n // outside plot area\n if (force !== 'pass' &&\n (x1 < axisLeft || x1 > axisLeft + axis.width)) {\n if (force) {\n x1 = x2 = clamp(x1, axisLeft, axisLeft + axis.width);\n }\n else {\n skip = true;\n }\n }\n if (!skip) {\n result.push(['M', x1, y1], ['L', x2, y2]);\n }\n });\n }\n else {\n uniqueAxes.forEach(function (axis2) {\n let skip;\n x1 = axis2.pos;\n x2 = x1 + axis2.len;\n y1 = y2 = Math.round(axisTop + axis.height - transVal);\n // outside plot area\n if (force !== 'pass' &&\n (y1 < axisTop || y1 > axisTop + axis.height)) {\n if (force) {\n y1 = y2 = clamp(y1, axisTop, axisTop + axis.height);\n }\n else {\n skip = true;\n }\n }\n if (!skip) {\n result.push(['M', x1, y1], ['L', x2, y2]);\n }\n });\n }\n }\n e.path = result.length > 0 ?\n renderer.crispPolyLine(result, e.lineWidth || 1) :\n // #3557 getPlotLinePath in regular Highcharts also returns null\n null;\n }\n });\n /**\n * Function to crisp a line with multiple segments\n *\n * @private\n * @function Highcharts.SVGRenderer#crispPolyLine\n */\n SVGRenderer.prototype.crispPolyLine = function (points, width) {\n // points format: [['M', 0, 0], ['L', 100, 0]]\n // normalize to a crisp line\n for (let i = 0; i < points.length; i = i + 2) {\n const start = points[i], end = points[i + 1];\n if (start[1] === end[1]) {\n // Substract due to #1129. Now bottom and left axis gridlines behave\n // the same.\n start[1] = end[1] =\n Math.round(start[1]) - (width % 2 / 2);\n }\n if (start[2] === end[2]) {\n start[2] = end[2] =\n Math.round(start[2]) + (width % 2 / 2);\n }\n }\n return points;\n };\n // Wrapper to hide the label\n addEvent(Axis, 'afterHideCrosshair', function () {\n if (this.crossLabel) {\n this.crossLabel = this.crossLabel.hide();\n }\n });\n // Extend crosshairs to also draw the label\n addEvent(Axis, 'afterDrawCrosshair', function (event) {\n // Check if the label has to be drawn\n if (!this.crosshair ||\n !this.crosshair.label ||\n !this.crosshair.label.enabled ||\n !this.cross ||\n !isNumber(this.min) ||\n !isNumber(this.max)) {\n return;\n }\n let chart = this.chart, log = this.logarithmic, options = this.crosshair.label, // the label's options\n horiz = this.horiz, // axis orientation\n opposite = this.opposite, // axis position\n left = this.left, // left position\n top = this.top, // top position\n width = this.width, crossLabel = this.crossLabel, // the svgElement\n posx, posy, crossBox, formatOption = options.format, formatFormat = '', limit, align, tickInside = this.options.tickPosition === 'inside', snap = this.crosshair.snap !== false, offset = 0, \n // Use last available event (#5287)\n e = event.e || (this.cross && this.cross.e), point = event.point, min = this.min, max = this.max;\n if (log) {\n min = log.lin2log(min);\n max = log.lin2log(max);\n }\n align = (horiz ? 'center' : opposite ?\n (this.labelAlign === 'right' ? 'right' : 'left') :\n (this.labelAlign === 'left' ? 'left' : 'center'));\n // If the label does not exist yet, create it.\n if (!crossLabel) {\n crossLabel = this.crossLabel = chart.renderer\n .label('', 0, void 0, options.shape || 'callout')\n .addClass('highcharts-crosshair-label highcharts-color-' + (point && point.series ?\n point.series.colorIndex :\n this.series[0] && this.series[0].colorIndex))\n .attr({\n align: options.align || align,\n padding: pick(options.padding, 8),\n r: pick(options.borderRadius, 3),\n zIndex: 2\n })\n .add(this.labelGroup);\n // Presentational\n if (!chart.styledMode) {\n crossLabel\n .attr({\n fill: options.backgroundColor ||\n point && point.series && point.series.color || // #14888\n \"#666666\" /* Palette.neutralColor60 */,\n stroke: options.borderColor || '',\n 'stroke-width': options.borderWidth || 0\n })\n .css(extend({\n color: \"#ffffff\" /* Palette.backgroundColor */,\n fontWeight: 'normal',\n fontSize: '0.7em',\n textAlign: 'center'\n }, options.style || {}));\n }\n }\n if (horiz) {\n posx = snap ? (point.plotX || 0) + left : e.chartX;\n posy = top + (opposite ? 0 : this.height);\n }\n else {\n posx = left + this.offset + (opposite ? width : 0);\n posy = snap ? (point.plotY || 0) + top : e.chartY;\n }\n if (!formatOption && !options.formatter) {\n if (this.dateTime) {\n formatFormat = '%b %d, %Y';\n }\n formatOption =\n '{value' + (formatFormat ? ':' + formatFormat : '') + '}';\n }\n // Show the label\n const value = snap ?\n (this.isXAxis ? point.x : point.y) :\n this.toValue(horiz ? e.chartX : e.chartY);\n // Crosshair should be rendered within Axis range (#7219). Also, the point\n // of currentPriceIndicator should be inside the plot area, #14879.\n const isInside = point && point.series ?\n point.series.isPointInside(point) :\n (isNumber(value) && value > min && value < max);\n let text = '';\n if (formatOption) {\n text = format(formatOption, { value }, chart);\n }\n else if (options.formatter && isNumber(value)) {\n text = options.formatter.call(this, value);\n }\n crossLabel.attr({\n text,\n x: posx,\n y: posy,\n visibility: isInside ? 'inherit' : 'hidden'\n });\n crossBox = crossLabel.getBBox();\n // now it is placed we can correct its position\n if (isNumber(crossLabel.x) && !horiz && !opposite) {\n posx = crossLabel.x - (crossBox.width / 2);\n }\n if (isNumber(crossLabel.y)) {\n if (horiz) {\n if ((tickInside && !opposite) || (!tickInside && opposite)) {\n posy = crossLabel.y - crossBox.height;\n }\n }\n else {\n posy = crossLabel.y - (crossBox.height / 2);\n }\n }\n // check the edges\n if (horiz) {\n limit = {\n left: left - crossBox.x,\n right: left + this.width - crossBox.x\n };\n }\n else {\n limit = {\n left: this.labelAlign === 'left' ? left : 0,\n right: this.labelAlign === 'right' ?\n left + this.width :\n chart.chartWidth\n };\n }\n // left edge\n if (crossLabel.translateX < limit.left) {\n offset = limit.left - crossLabel.translateX;\n }\n // right edge\n if (crossLabel.translateX + crossBox.width >= limit.right) {\n offset = -(crossLabel.translateX + crossBox.width - limit.right);\n }\n // show the crosslabel\n crossLabel.attr({\n x: posx + offset,\n y: posy,\n // First set x and y, then anchorX and anchorY, when box is actually\n // calculated, #5702\n anchorX: horiz ?\n posx :\n (this.opposite ? 0 : chart.chartWidth),\n anchorY: horiz ?\n (this.opposite ? chart.chartHeight : 0) :\n posy + crossBox.height / 2\n });\n });\n /**\n * Based on the data grouping options decides whether\n * the data should be cropped while processing.\n *\n * @ignore\n * @function Highcharts.Series#forceCropping\n */\n Series.prototype.forceCropping = function () {\n const chart = this.chart, options = this.options, dataGroupingOptions = options.dataGrouping, groupingEnabled = this.allowDG !== false && dataGroupingOptions &&\n pick(dataGroupingOptions.enabled, chart.options.isStock);\n return groupingEnabled;\n };\n addEvent(Chart, 'update', function (e) {\n const options = e.options;\n // Use case: enabling scrollbar from a disabled state.\n // Scrollbar needs to be initialized from a controller, Navigator in this\n // case (#6615)\n if ('scrollbar' in options && this.navigator) {\n merge(true, this.options.scrollbar, options.scrollbar);\n this.navigator.update({});\n delete options.scrollbar;\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return StockChart;\n });\n _registerModule(_modules, 'masters/modules/stock.src.js', [_modules['Core/Globals.js'], _modules['Series/DataModifyComposition.js'], _modules['Stock/Navigator/Navigator.js'], _modules['Stock/RangeSelector/RangeSelector.js'], _modules['Stock/Scrollbar/Scrollbar.js'], _modules['Core/Axis/OrdinalAxis.js'], _modules['Series/OHLC/OHLCSeries.js'], _modules['Series/Flags/FlagsSeries.js'], _modules['Core/Chart/StockChart.js']], function (Highcharts, DataModifyComposition, Navigator, RangeSelector, Scrollbar, OrdinalAxis, OHLCSeries, FlagsSeries, StockChart) {\n\n const G = Highcharts;\n // Classes\n G.Navigator = Navigator;\n G.RangeSelector = RangeSelector;\n G.Scrollbar = Scrollbar;\n G.StockChart = G.stockChart = StockChart.stockChart;\n // Compositions\n DataModifyComposition.compose(G.Series, G.Axis, G.Point);\n FlagsSeries.compose(G.Renderer);\n Navigator.compose(G.Axis, G.Chart, G.Series);\n OHLCSeries.compose(G.Series);\n OrdinalAxis.compose(G.Axis, G.Series, G.Chart);\n RangeSelector.compose(G.Axis, G.Chart);\n Scrollbar.compose(G.Axis);\n\n });\n _registerModule(_modules, 'masters/highstock.src.js', [_modules['masters/highcharts.src.js']], function (Highcharts) {\n\n Highcharts.product = 'Highstock';\n\n return Highcharts;\n });\n _modules['masters/highstock.src.js']._modules = _modules;\n return _modules['masters/highstock.src.js'];\n}));","/**\n * @license Highcharts JS v11.1.0 (2023-06-05)\n *\n * Annotations module\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/modules/annotations-advanced', ['highcharts'], function (Highcharts) {\n factory(Highcharts);\n factory.Highcharts = Highcharts;\n return factory;\n });\n } else {\n factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);\n }\n}(function (Highcharts) {\n 'use strict';\n var _modules = Highcharts ? Highcharts._modules : {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Extensions/Annotations/AnnotationChart.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, erase, find, fireEvent, pick, wrap } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add an annotation to the chart after render time.\n *\n * @sample highcharts/annotations/add-annotation/\n * Add annotation\n *\n * @function Highcharts.Chart#addAnnotation\n *\n * @param {Highcharts.AnnotationsOptions} options\n * The annotation options for the new, detailed annotation.\n *\n * @param {boolean} [redraw]\n *\n * @return {Highcharts.Annotation}\n * The newly generated annotation.\n */\n function chartAddAnnotation(userOptions, redraw) {\n const annotation = this.initAnnotation(userOptions);\n this.options.annotations.push(annotation.options);\n if (pick(redraw, true)) {\n annotation.redraw();\n annotation.graphic.attr({\n opacity: 1\n });\n }\n return annotation;\n }\n /**\n * @private\n */\n function chartCallback() {\n const chart = this;\n chart.plotBoxClip = this.renderer.clipRect(this.plotBox);\n chart.controlPointsGroup = chart.renderer\n .g('control-points')\n .attr({ zIndex: 99 })\n .clip(chart.plotBoxClip)\n .add();\n chart.options.annotations.forEach((annotationOptions, i) => {\n if (\n // Verify that it has not been previously added in a responsive rule\n !chart.annotations.some((annotation) => annotation.options === annotationOptions)) {\n const annotation = chart.initAnnotation(annotationOptions);\n chart.options.annotations[i] = annotation.options;\n }\n });\n chart.drawAnnotations();\n addEvent(chart, 'redraw', chart.drawAnnotations);\n addEvent(chart, 'destroy', function () {\n chart.plotBoxClip.destroy();\n chart.controlPointsGroup.destroy();\n });\n addEvent(chart, 'exportData', function (event) {\n const annotations = chart.annotations, csvColumnHeaderFormatter = ((this.options.exporting &&\n this.options.exporting.csv) ||\n {}).columnHeaderFormatter, \n // If second row doesn't have xValues\n // then it is a title row thus multiple level header is in use.\n multiLevelHeaders = !event.dataRows[1].xValues, annotationHeader = (chart.options.lang &&\n chart.options.lang.exportData &&\n chart.options.lang.exportData.annotationHeader), columnHeaderFormatter = function (index) {\n let s;\n if (csvColumnHeaderFormatter) {\n s = csvColumnHeaderFormatter(index);\n if (s !== false) {\n return s;\n }\n }\n s = annotationHeader + ' ' + index;\n if (multiLevelHeaders) {\n return {\n columnTitle: s,\n topLevelColumnTitle: s\n };\n }\n return s;\n }, startRowLength = event.dataRows[0].length, annotationSeparator = (chart.options.exporting &&\n chart.options.exporting.csv &&\n chart.options.exporting.csv.annotations &&\n chart.options.exporting.csv.annotations.itemDelimiter), joinAnnotations = (chart.options.exporting &&\n chart.options.exporting.csv &&\n chart.options.exporting.csv.annotations &&\n chart.options.exporting.csv.annotations.join);\n annotations.forEach((annotation) => {\n if (annotation.options.labelOptions &&\n annotation.options.labelOptions.includeInDataExport) {\n annotation.labels.forEach((label) => {\n if (label.options.text) {\n const annotationText = label.options.text;\n label.points.forEach((points) => {\n const annotationX = points.x, xAxisIndex = points.series.xAxis ?\n points.series.xAxis.index :\n -1;\n let wasAdded = false;\n // Annotation not connected to any xAxis -\n // add new row.\n if (xAxisIndex === -1) {\n const n = event.dataRows[0].length, newRow = new Array(n);\n for (let i = 0; i < n; ++i) {\n newRow[i] = '';\n }\n newRow.push(annotationText);\n newRow.xValues = [];\n newRow.xValues[xAxisIndex] = annotationX;\n event.dataRows.push(newRow);\n wasAdded = true;\n }\n // Annotation placed on a exported data point\n // - add new column\n if (!wasAdded) {\n event.dataRows.forEach((row) => {\n if (!wasAdded &&\n row.xValues &&\n xAxisIndex !== void 0 &&\n annotationX === row.xValues[xAxisIndex]) {\n if (joinAnnotations &&\n row.length > startRowLength) {\n row[row.length - 1] += (annotationSeparator +\n annotationText);\n }\n else {\n row.push(annotationText);\n }\n wasAdded = true;\n }\n });\n }\n // Annotation not placed on any exported data point,\n // but connected to the xAxis - add new row\n if (!wasAdded) {\n const n = event.dataRows[0].length, newRow = new Array(n);\n for (let i = 0; i < n; ++i) {\n newRow[i] = '';\n }\n newRow[0] = annotationX;\n newRow.push(annotationText);\n newRow.xValues = [];\n if (xAxisIndex !== void 0) {\n newRow.xValues[xAxisIndex] = annotationX;\n }\n event.dataRows.push(newRow);\n }\n });\n }\n });\n }\n });\n let maxRowLen = 0;\n event.dataRows.forEach((row) => {\n maxRowLen = Math.max(maxRowLen, row.length);\n });\n const newRows = maxRowLen - event.dataRows[0].length;\n for (let i = 0; i < newRows; i++) {\n const header = columnHeaderFormatter(i + 1);\n if (multiLevelHeaders) {\n event.dataRows[0].push(header.topLevelColumnTitle);\n event.dataRows[1].push(header.columnTitle);\n }\n else {\n event.dataRows[0].push(header);\n }\n }\n });\n }\n /**\n * @private\n */\n function chartDrawAnnotations() {\n this.plotBoxClip.attr(this.plotBox);\n this.annotations.forEach((annotation) => {\n annotation.redraw();\n annotation.graphic.animate({\n opacity: 1\n }, annotation.animationConfig);\n });\n }\n /**\n * Remove an annotation from the chart.\n *\n * @function Highcharts.Chart#removeAnnotation\n *\n * @param {number|string|Highcharts.Annotation} idOrAnnotation\n * The annotation's id or direct annotation object.\n */\n function chartRemoveAnnotation(idOrAnnotation) {\n const annotations = this.annotations, annotation = (idOrAnnotation.coll === 'annotations') ?\n idOrAnnotation :\n find(annotations, function (annotation) {\n return annotation.options.id === idOrAnnotation;\n });\n if (annotation) {\n fireEvent(annotation, 'remove');\n erase(this.options.annotations, annotation.options);\n erase(annotations, annotation);\n annotation.destroy();\n }\n }\n /**\n * Create lookups initially\n * @private\n */\n function onChartAfterInit() {\n const chart = this;\n chart.annotations = [];\n if (!this.options.annotations) {\n this.options.annotations = [];\n }\n }\n /**\n * @private\n */\n function wrapPointerOnContainerMouseDown(proceed) {\n if (!this.chart.hasDraggedAnnotation) {\n proceed.apply(this, Array.prototype.slice.call(arguments, 1));\n }\n }\n /* *\n *\n * Composition\n *\n * */\n /**\n * @private\n */\n var AnnotationChart;\n (function (AnnotationChart) {\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AnnotationClass, ChartClass, PointerClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'afterInit', onChartAfterInit);\n const chartProto = ChartClass.prototype;\n chartProto.addAnnotation = chartAddAnnotation;\n chartProto.callbacks.push(chartCallback);\n chartProto.collectionsWithInit.annotations = [chartAddAnnotation];\n chartProto.collectionsWithUpdate.push('annotations');\n chartProto.drawAnnotations = chartDrawAnnotations;\n chartProto.removeAnnotation = chartRemoveAnnotation;\n chartProto.initAnnotation = function chartInitAnnotation(userOptions) {\n const Constructor = (AnnotationClass.types[userOptions.type] ||\n AnnotationClass), annotation = new Constructor(this, userOptions);\n this.annotations.push(annotation);\n return annotation;\n };\n }\n if (U.pushUnique(composedMembers, PointerClass)) {\n const pointerProto = PointerClass.prototype;\n wrap(pointerProto, 'onContainerMouseDown', wrapPointerOnContainerMouseDown);\n }\n }\n AnnotationChart.compose = compose;\n })(AnnotationChart || (AnnotationChart = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return AnnotationChart;\n });\n _registerModule(_modules, 'Extensions/Annotations/AnnotationDefaults.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * Imports\n *\n * */\n const { defined } = U;\n /* *\n *\n * API Options\n *\n * */\n /**\n * A basic type of an annotation. It allows to add custom labels\n * or shapes. The items can be tied to points, axis coordinates\n * or chart pixel coordinates.\n *\n * @sample highcharts/annotations/basic/\n * Basic annotations\n * @sample highcharts/demo/annotations/\n * Advanced annotations\n * @sample highcharts/css/annotations\n * Styled mode\n * @sample highcharts/annotations-advanced/controllable\n * Controllable items\n * @sample {highstock} stock/annotations/fibonacci-retracements\n * Custom annotation, Fibonacci retracement\n *\n * @type {Array<*>}\n * @since 6.0.0\n * @requires modules/annotations\n * @optionparent annotations\n */\n const AnnotationDefaults = {\n /**\n * Sets an ID for an annotation. Can be user later when\n * removing an annotation in [Chart#removeAnnotation(id)](\n * /class-reference/Highcharts.Chart#removeAnnotation) method.\n *\n * @type {number|string}\n * @apioption annotations.id\n */\n /**\n * Whether the annotation is visible.\n *\n * @sample highcharts/annotations/visible/\n * Set annotation visibility\n */\n visible: true,\n /**\n * Enable or disable the initial animation when a series is\n * displayed for the `annotation`. The animation can also be set\n * as a configuration object. Please note that this option only\n * applies to the initial animation.\n * For other animations, see [chart.animation](#chart.animation)\n * and the animation parameter under the API methods.\n * The following properties are supported:\n *\n * - `defer`: The animation delay time in milliseconds.\n *\n * @sample {highcharts} highcharts/annotations/defer/\n * Animation defer settings\n * @type {boolean|Partial}\n * @since 8.2.0\n */\n animation: {},\n /**\n * Whether to hide the part of the annotation\n * that is outside the plot area.\n *\n * @sample highcharts/annotations/label-crop-overflow/\n * Crop line annotation\n * @type {boolean}\n * @since 9.3.0\n */\n crop: true,\n /**\n * The animation delay time in milliseconds.\n * Set to `0` renders annotation immediately.\n * As `undefined` inherits defer time from the [series.animation.defer](#plotOptions.series.animation.defer).\n *\n * @type {number}\n * @since 8.2.0\n * @apioption annotations.animation.defer\n */\n /**\n * Allow an annotation to be draggable by a user. Possible\n * values are `'x'`, `'xy'`, `'y'` and `''` (disabled).\n *\n * @sample highcharts/annotations/draggable/\n * Annotations draggable: 'xy'\n *\n * @type {Highcharts.AnnotationDraggableValue}\n */\n draggable: 'xy',\n /**\n * Options for annotation's labels. Each label inherits options\n * from the labelOptions object. An option from the labelOptions\n * can be overwritten by config for a specific label.\n *\n * @requires modules/annotations\n */\n labelOptions: {\n /**\n * The alignment of the annotation's label. If right,\n * the right side of the label should be touching the point.\n *\n * @sample highcharts/annotations/label-position/\n * Set labels position\n *\n * @type {Highcharts.AlignValue}\n */\n align: 'center',\n /**\n * Whether to allow the annotation's labels to overlap.\n * To make the labels less sensitive for overlapping,\n * the can be set to 0.\n *\n * @sample highcharts/annotations/tooltip-like/\n * Hide overlapping labels\n */\n allowOverlap: false,\n /**\n * The background color or gradient for the annotation's\n * label.\n *\n * @sample highcharts/annotations/label-presentation/\n * Set labels graphic options\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: 'rgba(0, 0, 0, 0.75)',\n /**\n * The border color for the annotation's label.\n *\n * @sample highcharts/annotations/label-presentation/\n * Set labels graphic options\n *\n * @type {Highcharts.ColorString}\n */\n borderColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The border radius in pixels for the annotaiton's label.\n *\n * @sample highcharts/annotations/label-presentation/\n * Set labels graphic options\n */\n borderRadius: 3,\n /**\n * The border width in pixels for the annotation's label\n *\n * @sample highcharts/annotations/label-presentation/\n * Set labels graphic options\n */\n borderWidth: 1,\n /**\n * A class name for styling by CSS.\n *\n * @sample highcharts/css/annotations\n * Styled mode annotations\n *\n * @since 6.0.5\n */\n className: 'highcharts-no-tooltip',\n /**\n * Whether to hide the annotation's label\n * that is outside the plot area.\n *\n * @sample highcharts/annotations/label-crop-overflow/\n * Crop or justify labels\n */\n crop: false,\n /**\n * The label's pixel distance from the point.\n *\n * @sample highcharts/annotations/label-position/\n * Set labels position\n *\n * @type {number}\n * @apioption annotations.labelOptions.distance\n */\n /**\n * A\n * [format](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting)\n * string for the data label.\n *\n * @see [plotOptions.series.dataLabels.format](plotOptions.series.dataLabels.format.html)\n *\n * @sample highcharts/annotations/label-text/\n * Set labels text\n *\n * @type {string}\n * @apioption annotations.labelOptions.format\n */\n /**\n * Alias for the format option.\n *\n * @see [format](annotations.labelOptions.format.html)\n *\n * @sample highcharts/annotations/label-text/\n * Set labels text\n *\n * @type {string}\n * @apioption annotations.labelOptions.text\n */\n /**\n * Callback JavaScript function to format the annotation's\n * label. Note that if a `format` or `text` are defined,\n * the format or text take precedence and the formatter is\n * ignored. `This` refers to a point object.\n *\n * @sample highcharts/annotations/label-text/\n * Set labels text\n *\n * @type {Highcharts.FormatterCallbackFunction}\n * @default function () { return defined(this.y) ? this.y : 'Annotation label'; }\n */\n formatter: function () {\n return defined(this.y) ? '' + this.y : 'Annotation label';\n },\n /**\n * Whether the annotation is visible in the exported data\n * table.\n *\n * @sample highcharts/annotations/include-in-data-export/\n * Do not include in the data export\n *\n * @since 8.2.0\n * @requires modules/export-data\n */\n includeInDataExport: true,\n /**\n * How to handle the annotation's label that flow outside\n * the plot area. The justify option aligns the label inside\n * the plot area.\n *\n * @sample highcharts/annotations/label-crop-overflow/\n * Crop or justify labels\n *\n * @validvalue [\"allow\", \"justify\"]\n */\n overflow: 'justify',\n /**\n * When either the borderWidth or the backgroundColor is\n * set, this is the padding within the box.\n *\n * @sample highcharts/annotations/label-presentation/\n * Set labels graphic options\n */\n padding: 5,\n /**\n * The shadow of the box. The shadow can be an object\n * configuration containing `color`, `offsetX`, `offsetY`,\n * `opacity` and `width`.\n *\n * @sample highcharts/annotations/label-presentation/\n * Set labels graphic options\n *\n * @type {boolean|Highcharts.ShadowOptionsObject}\n */\n shadow: false,\n /**\n * The name of a symbol to use for the border around the\n * label. Symbols are predefined functions on the Renderer\n * object.\n *\n * @sample highcharts/annotations/shapes/\n * Available shapes for labels\n */\n shape: 'callout',\n /**\n * Styles for the annotation's label.\n *\n * @see [plotOptions.series.dataLabels.style](plotOptions.series.dataLabels.style.html)\n *\n * @sample highcharts/annotations/label-presentation/\n * Set labels graphic options\n *\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @ignore */\n fontSize: '0.7em',\n /** @ignore */\n fontWeight: 'normal',\n /** @ignore */\n color: 'contrast'\n },\n /**\n * Whether to [use HTML](https://www.highcharts.com/docs/chart-concepts/labels-and-string-formatting#html)\n * to render the annotation's label.\n */\n useHTML: false,\n /**\n * The vertical alignment of the annotation's label.\n *\n * @sample highcharts/annotations/label-position/\n * Set labels position\n *\n * @type {Highcharts.VerticalAlignValue}\n */\n verticalAlign: 'bottom',\n /**\n * The x position offset of the label relative to the point.\n * Note that if a `distance` is defined, the distance takes\n * precedence over `x` and `y` options.\n *\n * @sample highcharts/annotations/label-position/\n * Set labels position\n */\n x: 0,\n /**\n * The y position offset of the label relative to the point.\n * Note that if a `distance` is defined, the distance takes\n * precedence over `x` and `y` options.\n *\n * @sample highcharts/annotations/label-position/\n * Set labels position\n */\n y: -16\n },\n /**\n * An array of labels for the annotation. For options that apply\n * to multiple labels, they can be added to the\n * [labelOptions](annotations.labelOptions.html).\n *\n * @type {Array<*>}\n * @extends annotations.labelOptions\n * @apioption annotations.labels\n */\n /**\n * This option defines the point to which the label will be\n * connected. It can be either the point which exists in the\n * series - it is referenced by the point's id - or a new point\n * with defined x, y properties and optionally axes.\n *\n * @sample highcharts/annotations/mock-point/\n * Attach annotation to a mock point\n * @sample highcharts/annotations/mock-points/\n * Attach annotation to a mock point with different ways\n *\n * @declare Highcharts.AnnotationMockPointOptionsObject\n * @type {\n * string|\n * Highcharts.AnnotationMockPointOptionsObject|\n * Highcharts.AnnotationMockPointFunction\n * }\n * @requires modules/annotations\n * @apioption annotations.labels.point\n */\n /**\n * An array of shapes for the annotation. For options that apply\n * to multiple shapes, then can be added to the\n * [shapeOptions](annotations.shapeOptions.html).\n *\n * @type {Array<*>}\n * @extends annotations.shapeOptions\n * @apioption annotations.shapes\n */\n /**\n * This option defines the point to which the shape will be\n * connected. It can be either the point which exists in the\n * series - it is referenced by the point's id - or a new point\n * with defined x, y properties and optionally axes.\n *\n * @sample highcharts/annotations/mock-points/\n * Attach annotation to a mock point with different ways\n *\n * @declare Highcharts.AnnotationMockPointOptionsObject\n * @type {\n * string|\n * Highcharts.AnnotationMockPointOptionsObject|\n * Highcharts.AnnotationMockPointFunction\n * }\n * @extends annotations.labels.point\n * @requires modules/annotations\n * @apioption annotations.shapes.point\n */\n /**\n * An array of points for the shape\n * or a callback function that returns that shape point.\n *\n * This option is available\n * for shapes which can use multiple points such as path. A\n * point can be either a point object or a point's id.\n *\n * @see [annotations.shapes.point](annotations.shapes.point.html)\n *\n * @type {Array}\n * @extends annotations.labels.point\n * @apioption annotations.shapes.points\n */\n /**\n * The URL for an image to use as the annotation shape. Note,\n * type has to be set to `'image'`.\n *\n * @see [annotations.shapes.type](annotations.shapes.type)\n * @sample highcharts/annotations/shape-src/\n * Define a marker image url for annotations\n *\n * @type {string}\n * @apioption annotations.shapes.src\n */\n /**\n * Id of the marker which will be drawn at the final vertex of\n * the path. Custom markers can be defined in defs property.\n *\n * @see [defs.markers](defs.markers.html)\n *\n * @sample highcharts/annotations/custom-markers/\n * Define a custom marker for annotations\n *\n * @type {string}\n * @apioption annotations.shapes.markerEnd\n */\n /**\n * Id of the marker which will be drawn at the first vertex of\n * the path. Custom markers can be defined in defs property.\n *\n * @see [defs.markers](defs.markers.html)\n *\n * @sample {highcharts} highcharts/annotations/custom-markers/\n * Define a custom marker for annotations\n *\n * @type {string}\n * @apioption annotations.shapes.markerStart\n */\n /**\n * Options for annotation's shapes. Each shape inherits options\n * from the shapeOptions object. An option from the shapeOptions\n * can be overwritten by config for a specific shape.\n *\n * @requires modules/annotations\n */\n shapeOptions: {\n /**\n *\n * The radius of the shape in y direction.\n * Used for the ellipse.\n *\n * @sample highcharts/annotations/ellipse/\n * Ellipse annotation\n *\n * @type {number}\n * @apioption annotations.shapeOptions.ry\n **/\n /**\n *\n * The xAxis index to which the points should be attached.\n * Used for the ellipse.\n *\n * @type {number}\n * @apioption annotations.shapeOptions.xAxis\n **/\n /**\n * The yAxis index to which the points should be attached.\n * Used for the ellipse.\n *\n * @type {number}\n * @apioption annotations.shapeOptions.yAxis\n **/\n /**\n * The width of the shape.\n *\n * @sample highcharts/annotations/shape/\n * Basic shape annotation\n *\n * @type {number}\n * @apioption annotations.shapeOptions.width\n **/\n /**\n * The height of the shape.\n *\n * @sample highcharts/annotations/shape/\n * Basic shape annotation\n *\n * @type {number}\n * @apioption annotations.shapeOptions.height\n */\n /**\n * The type of the shape.\n * Avaliable options are circle, rect and ellipse.\n *\n * @sample highcharts/annotations/shape/\n * Basic shape annotation\n *\n * @sample highcharts/annotations/ellipse/\n * Ellipse annotation\n *\n * @type {string}\n * @default rect\n * @apioption annotations.shapeOptions.type\n */\n /**\n * The URL for an image to use as the annotation shape.\n * Note, type has to be set to `'image'`.\n *\n * @see [annotations.shapeOptions.type](annotations.shapeOptions.type)\n * @sample highcharts/annotations/shape-src/\n * Define a marker image url for annotations\n *\n * @type {string}\n * @apioption annotations.shapeOptions.src\n */\n /**\n * Name of the dash style to use for the shape's stroke.\n *\n * @sample {highcharts} highcharts/plotoptions/series-dashstyle-all/\n * Possible values demonstrated\n *\n * @type {Highcharts.DashStyleValue}\n * @apioption annotations.shapeOptions.dashStyle\n */\n /**\n * The color of the shape's stroke.\n *\n * @sample highcharts/annotations/shape/\n * Basic shape annotation\n *\n * @type {Highcharts.ColorString}\n */\n stroke: 'rgba(0, 0, 0, 0.75)',\n /**\n * The pixel stroke width of the shape.\n *\n * @sample highcharts/annotations/shape/\n * Basic shape annotation\n */\n strokeWidth: 1,\n /**\n * The color of the shape's fill.\n *\n * @sample highcharts/annotations/shape/\n * Basic shape annotation\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n fill: 'rgba(0, 0, 0, 0.75)',\n /**\n * The radius of the shape.\n *\n * @sample highcharts/annotations/shape/\n * Basic shape annotation\n */\n r: 0,\n /**\n * Defines additional snapping area around an annotation\n * making this annotation to focus. Defined in pixels.\n */\n snap: 2\n },\n /**\n * Options for annotation's control points. Each control point\n * inherits options from controlPointOptions object.\n * Options from the controlPointOptions can be overwritten\n * by options in a specific control point.\n *\n * @declare Highcharts.AnnotationControlPointOptionsObject\n * @requires modules/annotations\n */\n controlPointOptions: {\n /**\n * @type {Highcharts.AnnotationControlPointPositionerFunction}\n * @apioption annotations.controlPointOptions.positioner\n */\n /**\n * @type {Highcharts.Dictionary}\n */\n events: {},\n /**\n * @type {Highcharts.SVGAttributes}\n */\n style: {\n cursor: 'pointer',\n fill: \"#ffffff\" /* Palette.backgroundColor */,\n stroke: \"#000000\" /* Palette.neutralColor100 */,\n 'stroke-width': 2\n },\n height: 10,\n symbol: 'circle',\n visible: false,\n width: 10\n },\n /**\n * Event callback when annotation is added to the chart.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @since 7.1.0\n * @apioption annotations.events.add\n */\n /**\n * Event callback when annotation is updated (e.g. drag and\n * droppped or resized by control points).\n *\n * @type {Highcharts.EventCallbackFunction}\n * @since 7.1.0\n * @apioption annotations.events.afterUpdate\n */\n /**\n * Fires when the annotation is clicked.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @since 7.1.0\n * @apioption annotations.events.click\n */\n /**\n * Event callback when annotation is removed from the chart.\n *\n * @type {Highcharts.EventCallbackFunction}\n * @since 7.1.0\n * @apioption annotations.events.remove\n */\n /**\n * Events available in annotations.\n *\n * @requires modules/annotations\n */\n events: {},\n /**\n * The Z index of the annotation.\n */\n zIndex: 6\n }; // typeOptions are expected but not set\n /* *\n *\n * Default Export\n *\n * */\n\n return AnnotationDefaults;\n });\n _registerModule(_modules, 'Extensions/Annotations/EventEmitter.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { doc, isTouchDevice } = H;\n const { addEvent, fireEvent, objectEach, pick, removeEvent } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n */\n class EventEmitter {\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add emitter events.\n * @private\n */\n addEvents() {\n const emitter = this, addMouseDownEvent = function (element) {\n addEvent(element, isTouchDevice ? 'touchstart' : 'mousedown', (e) => {\n emitter.onMouseDown(e);\n }, { passive: false });\n };\n addMouseDownEvent(this.graphic.element);\n (emitter.labels || []).forEach((label) => {\n if (label.options.useHTML && label.graphic.text) {\n // Mousedown event bound to HTML element (#13070).\n addMouseDownEvent(label.graphic.text.element);\n }\n });\n objectEach(emitter.options.events, (event, type) => {\n const eventHandler = function (e) {\n if (type !== 'click' || !emitter.cancelClick) {\n event.call(emitter, emitter.chart.pointer.normalize(e), emitter.target);\n }\n };\n if ((emitter.nonDOMEvents || []).indexOf(type) === -1) {\n emitter.graphic.on(type, eventHandler);\n }\n else {\n addEvent(emitter, type, eventHandler, { passive: false });\n }\n });\n if (emitter.options.draggable) {\n addEvent(emitter, 'drag', emitter.onDrag);\n if (!emitter.graphic.renderer.styledMode) {\n const cssPointer = {\n cursor: {\n x: 'ew-resize',\n y: 'ns-resize',\n xy: 'move'\n }[emitter.options.draggable]\n };\n emitter.graphic.css(cssPointer);\n (emitter.labels || []).forEach((label) => {\n if (label.options.useHTML && label.graphic.text) {\n label.graphic.text.css(cssPointer);\n }\n });\n }\n }\n if (!emitter.isUpdating) {\n fireEvent(emitter, 'add');\n }\n }\n /**\n * Destroy the event emitter.\n */\n destroy() {\n this.removeDocEvents();\n removeEvent(this);\n this.hcEvents = null;\n }\n /**\n * Map mouse move event to the radians.\n * @private\n */\n mouseMoveToRadians(e, cx, cy) {\n let prevDy = e.prevChartY - cy, prevDx = e.prevChartX - cx, dy = e.chartY - cy, dx = e.chartX - cx, temp;\n if (this.chart.inverted) {\n temp = prevDx;\n prevDx = prevDy;\n prevDy = temp;\n temp = dx;\n dx = dy;\n dy = temp;\n }\n return Math.atan2(dy, dx) - Math.atan2(prevDy, prevDx);\n }\n /**\n * Map mouse move to the scale factors.\n * @private\n */\n mouseMoveToScale(e, cx, cy) {\n const prevDx = e.prevChartX - cx, prevDy = e.prevChartY - cy, dx = e.chartX - cx, dy = e.chartY - cy;\n let sx = (dx || 1) / (prevDx || 1), sy = (dy || 1) / (prevDy || 1);\n if (this.chart.inverted) {\n const temp = sy;\n sy = sx;\n sx = temp;\n }\n return {\n x: sx,\n y: sy\n };\n }\n /**\n * Map mouse move event to the distance between two following events.\n * @private\n */\n mouseMoveToTranslation(e) {\n let dx = e.chartX - e.prevChartX, dy = e.chartY - e.prevChartY, temp;\n if (this.chart.inverted) {\n temp = dy;\n dy = dx;\n dx = temp;\n }\n return {\n x: dx,\n y: dy\n };\n }\n /**\n * Drag and drop event. All basic annotations should share this\n * capability as well as the extended ones.\n * @private\n */\n onDrag(e) {\n if (this.chart.isInsidePlot(e.chartX - this.chart.plotLeft, e.chartY - this.chart.plotTop, {\n visiblePlotOnly: true\n })) {\n const translation = this.mouseMoveToTranslation(e);\n if (this.options.draggable === 'x') {\n translation.y = 0;\n }\n if (this.options.draggable === 'y') {\n translation.x = 0;\n }\n const emitter = this;\n if (emitter.points.length) {\n emitter.translate(translation.x, translation.y);\n }\n else {\n emitter.shapes.forEach((shape) => shape.translate(translation.x, translation.y));\n emitter.labels.forEach((label) => label.translate(translation.x, translation.y));\n }\n this.redraw(false);\n }\n }\n /**\n * Mouse down handler.\n * @private\n */\n onMouseDown(e) {\n if (e.preventDefault) {\n e.preventDefault();\n }\n // On right click, do nothing:\n if (e.button === 2) {\n return;\n }\n const emitter = this, pointer = emitter.chart.pointer;\n e = pointer.normalize(e);\n let prevChartX = e.chartX, prevChartY = e.chartY;\n emitter.cancelClick = false;\n emitter.chart.hasDraggedAnnotation = true;\n emitter.removeDrag = addEvent(doc, isTouchDevice ? 'touchmove' : 'mousemove', function (e) {\n emitter.hasDragged = true;\n e = pointer.normalize(e);\n e.prevChartX = prevChartX;\n e.prevChartY = prevChartY;\n fireEvent(emitter, 'drag', e);\n prevChartX = e.chartX;\n prevChartY = e.chartY;\n }, isTouchDevice ? { passive: false } : void 0);\n emitter.removeMouseUp = addEvent(doc, isTouchDevice ? 'touchend' : 'mouseup', function (e) {\n // Sometimes the target is the annotation and sometimes its the\n // controllable\n const annotation = pick(emitter.target && emitter.target.annotation, emitter.target);\n if (annotation) {\n // Keep annotation selected after dragging control point\n annotation.cancelClick = emitter.hasDragged;\n }\n emitter.cancelClick = emitter.hasDragged;\n emitter.hasDragged = false;\n emitter.chart.hasDraggedAnnotation = false;\n // ControlPoints vs Annotation:\n fireEvent(pick(annotation, // #15952\n emitter), 'afterUpdate');\n emitter.onMouseUp(e);\n }, isTouchDevice ? { passive: false } : void 0);\n }\n /**\n * Mouse up handler.\n */\n onMouseUp(_e) {\n const chart = this.chart, annotation = this.target || this, annotationsOptions = chart.options.annotations, index = chart.annotations.indexOf(annotation);\n this.removeDocEvents();\n annotationsOptions[index] = annotation.options;\n }\n /**\n * Remove emitter document events.\n * @private\n */\n removeDocEvents() {\n if (this.removeDrag) {\n this.removeDrag = this.removeDrag();\n }\n if (this.removeMouseUp) {\n this.removeMouseUp = this.removeMouseUp();\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return EventEmitter;\n });\n _registerModule(_modules, 'Extensions/Annotations/ControlPoint.js', [_modules['Extensions/Annotations/EventEmitter.js'], _modules['Core/Utilities.js']], function (EventEmitter, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge, pick } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * A control point class which is a connection between controllable\n * transform methods and a user actions.\n *\n * @requires modules/annotations\n *\n * @class\n * @name Highcharts.AnnotationControlPoint\n *\n * @hideconstructor\n *\n * @param {Highcharts.Chart} chart\n * A chart instance.\n *\n * @param {Highcharts.AnnotationControllable} target\n * A controllable instance which is a target for a control point.\n *\n * @param {Highcharts.AnnotationControlPointOptionsObject} options\n * An options object.\n *\n * @param {number} [index]\n * Point index.\n */\n class ControlPoint extends EventEmitter {\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart, target, options, index) {\n super();\n this.graphic = void 0;\n /**\n * List of events for `anntation.options.events` that should not be\n * added to `annotation.graphic` but to the `annotation`.\n * @private\n * @name Highcharts.AnnotationControlPoint#nonDOMEvents\n * @type {Array}\n */\n this.nonDOMEvents = ['drag'];\n this.chart = chart;\n this.target = target;\n this.options = options;\n this.index = pick(options.index, index);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Destroy the control point.\n * @private\n */\n destroy() {\n super.destroy();\n if (this.graphic) {\n this.graphic = this.graphic.destroy();\n }\n this.chart = null;\n this.target = null;\n this.options = null;\n }\n /**\n * Redraw the control point.\n * @private\n * @param {boolean} [animation]\n */\n redraw(animation) {\n this.graphic[animation ? 'animate' : 'attr'](this.options.positioner.call(this, this.target));\n }\n /**\n * Render the control point.\n * @private\n */\n render() {\n const chart = this.chart, options = this.options;\n this.graphic = chart.renderer\n .symbol(options.symbol, 0, 0, options.width, options.height)\n .add(chart.controlPointsGroup)\n .css(options.style);\n this.setVisibility(options.visible);\n // npm test -- --tests \"highcharts/annotations-advanced/*\"\n this.addEvents();\n }\n /**\n * Set the visibility of the control point.\n *\n * @function Highcharts.AnnotationControlPoint#setVisibility\n *\n * @param {boolean} visible\n * Visibility of the control point.\n *\n */\n setVisibility(visible) {\n this.graphic[visible ? 'show' : 'hide']();\n this.options.visible = visible;\n }\n /**\n * Update the control point.\n *\n * @function Highcharts.AnnotationControlPoint#update\n *\n * @param {Partial} userOptions\n * New options for the control point.\n */\n update(userOptions) {\n const chart = this.chart, target = this.target, index = this.index, options = merge(true, this.options, userOptions);\n this.destroy();\n this.constructor(chart, target, options, index);\n this.render(chart.controlPointsGroup);\n this.redraw();\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Callback to modify annotation's possitioner controls.\n *\n * @callback Highcharts.AnnotationControlPointPositionerFunction\n * @param {Highcharts.AnnotationControlPoint} this\n * @param {Highcharts.AnnotationControllable} target\n * @return {Highcharts.PositionObject}\n */\n (''); // keeps doclets above in JS file\n\n return ControlPoint;\n });\n _registerModule(_modules, 'Extensions/Annotations/MockPoint.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { series: { prototype: seriesProto } } = SeriesRegistry;\n const { defined, fireEvent } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * A trimmed point object which imitates {@link Highchart.Point} class. It is\n * created when there is a need of pointing to some chart's position using axis\n * values or pixel values\n *\n * @requires modules/annotations\n *\n * @private\n * @class\n * @name Highcharts.AnnotationMockPoint\n *\n * @hideconstructor\n *\n * @param {Highcharts.Chart} chart\n * The chart instance.\n *\n * @param {Highcharts.AnnotationControllable|null} target\n * The related controllable.\n *\n * @param {Highcharts.AnnotationMockPointOptionsObject|Function} options\n * The options object.\n */\n class MockPoint {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Create a mock point from a real Highcharts point.\n *\n * @private\n * @static\n *\n * @param {Highcharts.Point} point\n *\n * @return {Highcharts.AnnotationMockPoint}\n * A mock point instance.\n */\n static fromPoint(point) {\n return new MockPoint(point.series.chart, null, {\n x: point.x,\n y: point.y,\n xAxis: point.series.xAxis,\n yAxis: point.series.yAxis\n });\n }\n /**\n * Get the pixel position from the point like object.\n *\n * @private\n * @static\n *\n * @param {Highcharts.AnnotationPointType} point\n *\n * @param {boolean} [paneCoordinates]\n * Whether the pixel position should be relative\n *\n * @return {Highcharts.PositionObject} pixel position\n */\n static pointToPixels(point, paneCoordinates) {\n const series = point.series, chart = series.chart;\n let x = point.plotX || 0, y = point.plotY || 0, plotBox;\n if (chart.inverted) {\n if (point.mock) {\n x = point.plotY;\n y = point.plotX;\n }\n else {\n x = chart.plotWidth - (point.plotY || 0);\n y = chart.plotHeight - (point.plotX || 0);\n }\n }\n if (series && !paneCoordinates) {\n plotBox = series.getPlotBox();\n x += plotBox.translateX;\n y += plotBox.translateY;\n }\n return {\n x: x,\n y: y\n };\n }\n /**\n * Get fresh mock point options from the point like object.\n *\n * @private\n * @static\n *\n * @param {Highcharts.AnnotationPointType} point\n *\n * @return {Highcharts.AnnotationMockPointOptionsObject}\n * A mock point's options.\n */\n static pointToOptions(point) {\n return {\n x: point.x,\n y: point.y,\n xAxis: point.series.xAxis,\n yAxis: point.series.yAxis\n };\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart, target, options) {\n this.plotX = void 0;\n this.plotY = void 0;\n /* *\n *\n * Functions\n *\n * */\n /**\n * A flag indicating that a point is not the real one.\n *\n * @type {boolean}\n * @default true\n */\n this.mock = true;\n /**\n * A mock series instance imitating a real series from a real point.\n *\n * @name Annotation.AnnotationMockPoint#series\n * @type {Highcharts.AnnotationMockSeries}\n */\n this.series = {\n visible: true,\n chart: chart,\n getPlotBox: seriesProto.getPlotBox\n };\n /**\n * @name Annotation.AnnotationMockPoint#target\n * @type {Highcharts.AnnotationControllable|null}\n */\n this.target = target || null;\n /**\n * Options for the mock point.\n *\n * @name Annotation.AnnotationMockPoint#options\n * @type {Highcharts.AnnotationsMockPointOptionsObject}\n */\n this.options = options;\n /**\n * If an xAxis is set it represents the point's value in terms of the\n * xAxis.\n *\n * @name Annotation.AnnotationMockPoint#x\n * @type {number|undefined}\n */\n /**\n * If an yAxis is set it represents the point's value in terms of the\n * yAxis.\n *\n * @name Annotation.AnnotationMockPoint#y\n * @type {number|undefined}\n */\n /**\n * It represents the point's pixel x coordinate relative to its plot\n * box.\n *\n * @name Annotation.AnnotationMockPoint#plotX\n * @type {number|undefined}\n */\n /**\n * It represents the point's pixel y position relative to its plot box.\n *\n * @name Annotation.AnnotationMockPoint#plotY\n * @type {number|undefined}\n */\n /**\n * Whether the point is inside the plot box.\n *\n * @name Annotation.AnnotationMockPoint#isInside\n * @type {boolean|undefined}\n */\n this.applyOptions(this.getOptions());\n }\n /**\n * Apply options for the point.\n * @private\n * @param {Highcharts.AnnotationMockPointOptionsObject} options\n */\n applyOptions(options) {\n this.command = options.command;\n this.setAxis(options, 'x');\n this.setAxis(options, 'y');\n this.refresh();\n }\n /**\n * Returns a label config object - the same as\n * Highcharts.Point.prototype.getLabelConfig\n * @private\n * @return {Highcharts.AnnotationMockLabelOptionsObject}\n * The point's label config\n */\n getLabelConfig() {\n return {\n x: this.x,\n y: this.y,\n point: this\n };\n }\n /**\n * Get the point's options.\n * @private\n * @return {Highcharts.AnnotationMockPointOptionsObject}\n * The mock point's options.\n */\n getOptions() {\n return this.hasDynamicOptions() ?\n this.options(this.target) :\n this.options;\n }\n /**\n * Check if the point has dynamic options.\n * @private\n * @return {boolean}\n * A positive flag if the point has dynamic options.\n */\n hasDynamicOptions() {\n return typeof this.options === 'function';\n }\n /**\n * Check if the point is inside its pane.\n * @private\n * @return {boolean} A flag indicating whether the point is inside the pane.\n */\n isInsidePlot() {\n const plotX = this.plotX, plotY = this.plotY, xAxis = this.series.xAxis, yAxis = this.series.yAxis, e = {\n x: plotX,\n y: plotY,\n isInsidePlot: true,\n options: {}\n };\n if (xAxis) {\n e.isInsidePlot = defined(plotX) && plotX >= 0 && plotX <= xAxis.len;\n }\n if (yAxis) {\n e.isInsidePlot =\n e.isInsidePlot &&\n defined(plotY) &&\n plotY >= 0 && plotY <= yAxis.len;\n }\n fireEvent(this.series.chart, 'afterIsInsidePlot', e);\n return e.isInsidePlot;\n }\n /**\n * Refresh point values and coordinates based on its options.\n * @private\n */\n refresh() {\n const series = this.series, xAxis = series.xAxis, yAxis = series.yAxis, options = this.getOptions();\n if (xAxis) {\n this.x = options.x;\n this.plotX = xAxis.toPixels(options.x, true);\n }\n else {\n this.x = void 0;\n this.plotX = options.x;\n }\n if (yAxis) {\n this.y = options.y;\n this.plotY = yAxis.toPixels(options.y, true);\n }\n else {\n this.y = null;\n this.plotY = options.y;\n }\n this.isInside = this.isInsidePlot();\n }\n /**\n * Refresh point options based on its plot coordinates.\n * @private\n */\n refreshOptions() {\n const series = this.series, xAxis = series.xAxis, yAxis = series.yAxis;\n this.x = this.options.x = xAxis ?\n this.options.x = xAxis.toValue(this.plotX, true) :\n this.plotX;\n this.y = this.options.y = yAxis ?\n yAxis.toValue(this.plotY, true) :\n this.plotY;\n }\n /**\n * Rotate the point.\n * @private\n * @param {number} cx origin x rotation\n * @param {number} cy origin y rotation\n * @param {number} radians\n */\n rotate(cx, cy, radians) {\n if (!this.hasDynamicOptions()) {\n const cos = Math.cos(radians), sin = Math.sin(radians), x = this.plotX - cx, y = this.plotY - cy, tx = x * cos - y * sin, ty = x * sin + y * cos;\n this.plotX = tx + cx;\n this.plotY = ty + cy;\n this.refreshOptions();\n }\n }\n /**\n * Scale the point.\n *\n * @private\n *\n * @param {number} cx\n * Origin x transformation.\n *\n * @param {number} cy\n * Origin y transformation.\n *\n * @param {number} sx\n * Scale factor x.\n *\n * @param {number} sy\n * Scale factor y.\n */\n scale(cx, cy, sx, sy) {\n if (!this.hasDynamicOptions()) {\n const x = this.plotX * sx, y = this.plotY * sy, tx = (1 - sx) * cx, ty = (1 - sy) * cy;\n this.plotX = tx + x;\n this.plotY = ty + y;\n this.refreshOptions();\n }\n }\n /**\n * Set x or y axis.\n * @private\n * @param {Highcharts.AnnotationMockPointOptionsObject} options\n * @param {string} xOrY\n * 'x' or 'y' string literal\n */\n setAxis(options, xOrY) {\n const axisName = (xOrY + 'Axis'), axisOptions = options[axisName], chart = this.series.chart;\n this.series[axisName] =\n typeof axisOptions === 'object' ?\n axisOptions :\n defined(axisOptions) ?\n (chart[axisName][axisOptions] ||\n // @todo v--- (axisName)[axisOptions] ?\n chart.get(axisOptions)) :\n null;\n }\n /**\n * Transform the mock point to an anchor (relative position on the chart).\n * @private\n * @return {Array}\n * A quadruple of numbers which denotes x, y, width and height of the box\n **/\n toAnchor() {\n const anchor = [this.plotX, this.plotY, 0, 0];\n if (this.series.chart.inverted) {\n anchor[0] = this.plotY;\n anchor[1] = this.plotX;\n }\n return anchor;\n }\n /**\n * Translate the point.\n *\n * @private\n *\n * @param {number|undefined} cx\n * Origin x transformation.\n *\n * @param {number|undefined} cy\n * Origin y transformation.\n *\n * @param {number} dx\n * Translation for x coordinate.\n *\n * @param {number} dy\n * Translation for y coordinate.\n **/\n translate(_cx, _cy, dx, dy) {\n if (!this.hasDynamicOptions()) {\n this.plotX += dx;\n this.plotY += dy;\n this.refreshOptions();\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @private\n * @interface Highcharts.AnnotationMockLabelOptionsObject\n */ /**\n * Point instance of the point.\n * @name Highcharts.AnnotationMockLabelOptionsObject#point\n * @type {Highcharts.AnnotationMockPoint}\n */ /**\n * X value translated to x axis scale.\n * @name Highcharts.AnnotationMockLabelOptionsObject#x\n * @type {number|null}\n */ /**\n * Y value translated to y axis scale.\n * @name Highcharts.AnnotationMockLabelOptionsObject#y\n * @type {number|null}\n */\n /**\n * Object of shape point.\n *\n * @interface Highcharts.AnnotationMockPointOptionsObject\n */ /**\n * The x position of the point. Units can be either in axis\n * or chart pixel coordinates.\n *\n * @type {number}\n * @name Highcharts.AnnotationMockPointOptionsObject.x\n */ /**\n * The y position of the point. Units can be either in axis\n * or chart pixel coordinates.\n *\n * @type {number}\n * @name Highcharts.AnnotationMockPointOptionsObject.y\n */ /**\n * This number defines which xAxis the point is connected to.\n * It refers to either the axis id or the index of the axis in\n * the xAxis array. If the option is not configured or the axis\n * is not found the point's x coordinate refers to the chart\n * pixels.\n *\n * @type {number|string|null}\n * @name Highcharts.AnnotationMockPointOptionsObject.xAxis\n */ /**\n * This number defines which yAxis the point is connected to.\n * It refers to either the axis id or the index of the axis in\n * the yAxis array. If the option is not configured or the axis\n * is not found the point's y coordinate refers to the chart\n * pixels.\n *\n * @type {number|string|null}\n * @name Highcharts.AnnotationMockPointOptionsObject.yAxis\n */\n /**\n * Callback function that returns the annotation shape point.\n *\n * @callback Highcharts.AnnotationMockPointFunction\n *\n * @param {Highcharts.Annotation} annotation\n * An annotation instance.\n *\n * @return {Highcharts.AnnotationMockPointOptionsObject}\n * Annotations shape point.\n */\n /**\n * A mock series instance imitating a real series from a real point.\n * @private\n * @interface Highcharts.AnnotationMockSeries\n */ /**\n * Whether a series is visible.\n * @name Highcharts.AnnotationMockSeries#visible\n * @type {boolean}\n */ /**\n * A chart instance.\n * @name Highcharts.AnnotationMockSeries#chart\n * @type {Highcharts.Chart}\n */ /**\n * @name Highcharts.AnnotationMockSeries#getPlotBox\n * @type {Function}\n */\n /**\n * Indicates if this is a mock point for an annotation.\n * @name Highcharts.Point#mock\n * @type {boolean|undefined}\n */\n (''); // keeps doclets above in JS file\n\n return MockPoint;\n });\n _registerModule(_modules, 'Extensions/Annotations/ControlTarget.js', [_modules['Extensions/Annotations/ControlPoint.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (ControlPoint, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Composition Namespace\n *\n * */\n var ControlTarget;\n (function (ControlTarget) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Add control points.\n * @private\n */\n function addControlPoints() {\n const controlPoints = this.controlPoints, controlPointsOptions = this.options.controlPoints || [];\n controlPointsOptions.forEach((controlPointOptions, i) => {\n const options = U.merge(this.options.controlPointOptions, controlPointOptions);\n if (!options.index) {\n options.index = i;\n }\n controlPointsOptions[i] = options;\n controlPoints.push(new ControlPoint(this.chart, this, options));\n });\n }\n /**\n * Returns object which denotes anchor position - relative and absolute.\n * @private\n * @param {Highcharts.AnnotationPointType} point\n * An annotation point.\n *\n * @return {Highcharts.AnnotationAnchorObject}\n * An annotation anchor.\n */\n function anchor(point) {\n const plotBox = point.series.getPlotBox(), chart = point.series.chart, box = point.mock ?\n point.toAnchor() :\n chart.tooltip &&\n chart.tooltip.getAnchor.call({\n chart: point.series.chart\n }, point) ||\n [0, 0, 0, 0], anchor = {\n x: box[0] + (this.options.x || 0),\n y: box[1] + (this.options.y || 0),\n height: box[2] || 0,\n width: box[3] || 0\n };\n return {\n relativePosition: anchor,\n absolutePosition: U.merge(anchor, {\n x: anchor.x + (point.mock ? plotBox.translateX : chart.plotLeft),\n y: anchor.y + (point.mock ? plotBox.translateY : chart.plotTop)\n })\n };\n }\n /**\n * Adds shared functions to be used with targets of ControlPoint.\n * @private\n */\n function compose(ControlTargetClass) {\n if (U.pushUnique(composedMembers, ControlTargetClass)) {\n U.merge(true, ControlTargetClass.prototype, {\n addControlPoints,\n anchor,\n destroyControlTarget,\n getPointsOptions,\n linkPoints,\n point,\n redrawControlPoints,\n renderControlPoints,\n transform,\n transformPoint,\n translate,\n translatePoint\n });\n }\n }\n ControlTarget.compose = compose;\n /**\n * Destroy control points.\n * @private\n */\n function destroyControlTarget() {\n this.controlPoints.forEach((controlPoint) => controlPoint.destroy());\n this.chart = null;\n this.controlPoints = null;\n this.points = null;\n this.options = null;\n if (this.annotation) {\n this.annotation = null;\n }\n }\n /**\n * Get the points options.\n * @private\n * @return {Array}\n * An array of points' options.\n */\n function getPointsOptions() {\n const options = this.options;\n return (options.points ||\n (options.point && U.splat(options.point)));\n }\n /**\n * Find point-like objects based on points options.\n * @private\n * @return {Array}\n * An array of point-like objects.\n */\n function linkPoints() {\n const pointsOptions = this.getPointsOptions(), points = this.points, len = (pointsOptions && pointsOptions.length) || 0;\n let i, point;\n for (i = 0; i < len; i++) {\n point = this.point(pointsOptions[i], points[i]);\n if (!point) {\n points.length = 0;\n return;\n }\n if (point.mock) {\n point.refresh();\n }\n points[i] = point;\n }\n return points;\n }\n /**\n * Map point's options to a point-like object.\n * @private\n * @param {string|Function|Highcharts.AnnotationMockPointOptionsObject|Highcharts.AnnotationPointType} pointOptions\n * Point's options.\n * @param {Highcharts.AnnotationPointType} point\n * A point-like instance.\n * @return {Highcharts.AnnotationPointType|null}\n * If the point is found/set returns this point, otherwise null\n */\n function point(pointOptions, point) {\n if (pointOptions && pointOptions.series) {\n return pointOptions;\n }\n if (!point || point.series === null) {\n if (U.isObject(pointOptions)) {\n point = new MockPoint(this.chart, this, pointOptions);\n }\n else if (U.isString(pointOptions)) {\n point = this.chart.get(pointOptions) || null;\n }\n else if (typeof pointOptions === 'function') {\n const pointConfig = pointOptions.call(point, this);\n point = pointConfig.series ?\n pointConfig :\n new MockPoint(this.chart, this, pointOptions);\n }\n }\n return point;\n }\n /**\n * Redraw control points.\n * @private\n */\n function redrawControlPoints(animation) {\n this.controlPoints.forEach((controlPoint) => controlPoint.redraw(animation));\n }\n /**\n * Render controll points.\n * @private\n */\n function renderControlPoints() {\n this.controlPoints.forEach((controlPoint) => controlPoint.render());\n }\n /**\n * Transform control points with a specific transformation.\n * @private\n * @param {string} transformation\n * A transformation name\n * @param {number|null} cx\n * Origin x transformation\n * @param {number|null} cy\n * Origin y transformation\n * @param {number} p1\n * Param for the transformation\n * @param {number} [p2]\n * Param for the transformation\n */\n function transform(transformation, cx, cy, p1, p2) {\n if (this.chart.inverted) {\n const temp = cx;\n cx = cy;\n cy = temp;\n }\n this.points.forEach((_point, i) => (this.transformPoint(transformation, cx, cy, p1, p2, i)), this);\n }\n /**\n * Transform a point with a specific transformation\n * If a transformed point is a real point it is replaced with\n * the mock point.\n * @private\n * @param {string} transformation\n * A transformation name\n * @param {number|null} cx\n * Origin x transformation\n * @param {number|null} cy\n * Origin y transformation\n * @param {number} p1\n * Param for the transformation\n * @param {number|undefined} p2\n * Param for the transformation\n * @param {number} i\n * Index of the point\n */\n function transformPoint(transformation, cx, cy, p1, p2, i) {\n let point = this.points[i];\n if (!point.mock) {\n point = this.points[i] = MockPoint.fromPoint(point);\n }\n point[transformation](cx, cy, p1, p2);\n }\n /**\n * Translate control points.\n * @private\n * @param {number} dx\n * Translation for x coordinate\n * @param {number} dy\n * Translation for y coordinate\n **/\n function translate(dx, dy) {\n this.transform('translate', null, null, dx, dy);\n }\n /**\n * Translate a specific control point.\n * @private\n * @param {number} dx\n * Translation for x coordinate\n * @param {number} dy\n * Translation for y coordinate\n * @param {number} i\n * Index of the point\n **/\n function translatePoint(dx, dy, i) {\n this.transformPoint('translate', null, null, dx, dy, i);\n }\n })(ControlTarget || (ControlTarget = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ControlTarget;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/Controllable.js', [_modules['Extensions/Annotations/ControlTarget.js'], _modules['Core/Utilities.js']], function (ControlTarget, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * It provides methods for handling points, control points\n * and points transformations.\n * @private\n */\n class Controllable {\n /* *\n *\n * Constructor\n *\n * */\n constructor(annotation, options, index, itemType) {\n this.graphic = void 0;\n this.annotation = annotation;\n this.chart = annotation.chart;\n this.collection = (itemType === 'label' ? 'labels' : 'shapes');\n this.controlPoints = [];\n this.options = options;\n this.points = [];\n this.index = index;\n this.itemType = itemType;\n this.init(annotation, options, index);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Redirect attr usage on the controllable graphic element.\n * @private\n */\n attr(..._args) {\n this.graphic.attr.apply(this.graphic, arguments);\n }\n /**\n * Utility function for mapping item's options\n * to element's attribute\n * @private\n * @param {Highcharts.AnnotationsLabelsOptions|Highcharts.AnnotationsShapesOptions} options\n * @return {Highcharts.SVGAttributes}\n * Mapped options.\n */\n attrsFromOptions(options) {\n const map = this.constructor.attrsMap, attrs = {}, styledMode = this.chart.styledMode;\n let key, mappedKey;\n for (key in options) { // eslint-disable-line guard-for-in\n mappedKey = map[key];\n if (typeof map[key] !== 'undefined' &&\n (!styledMode ||\n ['fill', 'stroke', 'stroke-width']\n .indexOf(mappedKey) === -1)) {\n attrs[mappedKey] = options[key];\n }\n }\n return attrs;\n }\n /**\n * Destroy a controllable.\n * @private\n */\n destroy() {\n if (this.graphic) {\n this.graphic = this.graphic.destroy();\n }\n if (this.tracker) {\n this.tracker = this.tracker.destroy();\n }\n this.destroyControlTarget();\n }\n /**\n * Init the controllable\n * @private\n */\n init(annotation, options, index) {\n this.annotation = annotation;\n this.chart = annotation.chart;\n this.options = options;\n this.points = [];\n this.controlPoints = [];\n this.index = index;\n this.linkPoints();\n this.addControlPoints();\n }\n /**\n * Redraw a controllable.\n * @private\n */\n redraw(animation) {\n this.redrawControlPoints(animation);\n }\n /**\n * Render a controllable.\n * @private\n */\n render(_parentGroup) {\n this.renderControlPoints();\n }\n /**\n * Rotate a controllable.\n * @private\n * @param {number} cx\n * Origin x rotation\n * @param {number} cy\n * Origin y rotation\n * @param {number} radians\n **/\n rotate(cx, cy, radians) {\n this.transform('rotate', cx, cy, radians);\n }\n /**\n * Scale a controllable.\n * @private\n * @param {number} cx\n * Origin x rotation\n * @param {number} cy\n * Origin y rotation\n * @param {number} sx\n * Scale factor x\n * @param {number} sy\n * Scale factor y\n */\n scale(cx, cy, sx, sy) {\n this.transform('scale', cx, cy, sx, sy);\n }\n /**\n * Set control points' visibility.\n * @private\n */\n setControlPointsVisibility(visible) {\n this.controlPoints.forEach((controlPoint) => {\n controlPoint.setVisibility(visible);\n });\n }\n /**\n * Check if a controllable should be rendered/redrawn.\n * @private\n * @return {boolean}\n * Whether a controllable should be drawn.\n */\n shouldBeDrawn() {\n return !!this.points.length;\n }\n /**\n * Translate shape within controllable item.\n * Replaces `controllable.translate` method.\n * @private\n * @param {number} dx\n * Translation for x coordinate\n * @param {number} dy\n * Translation for y coordinate\n * @param {boolean|undefined} translateSecondPoint\n * If the shape has two points attached to it, this option allows you\n * to translate also the second point.\n */\n translateShape(dx, dy, translateSecondPoint) {\n const chart = this.annotation.chart, \n // Annotation.options\n shapeOptions = this.annotation.userOptions, \n // Chart.options.annotations\n annotationIndex = chart.annotations.indexOf(this.annotation), chartOptions = chart.options.annotations[annotationIndex];\n this.translatePoint(dx, dy, 0);\n if (translateSecondPoint) {\n this.translatePoint(dx, dy, 1);\n }\n // Options stored in:\n // - chart (for exporting)\n // - current config (for redraws)\n chartOptions[this.collection][this.index]\n .point = this.options.point;\n shapeOptions[this.collection][this.index]\n .point = this.options.point;\n }\n /**\n * Update a controllable.\n * @private\n */\n update(newOptions) {\n const annotation = this.annotation, options = merge(true, this.options, newOptions), parentGroup = this.graphic.parentGroup, Constructor = this.constructor;\n this.destroy();\n const newControllable = new Constructor(annotation, options, this.index, this.itemType);\n merge(true, this, newControllable);\n this.render(parentGroup);\n this.redraw();\n }\n }\n ControlTarget.compose(Controllable);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * An object which denots a controllable's anchor positions - relative and\n * absolute.\n *\n * @private\n * @interface Highcharts.AnnotationAnchorObject\n */ /**\n * Relative to the plot area position\n * @name Highcharts.AnnotationAnchorObject#relativePosition\n * @type {Highcharts.BBoxObject}\n */ /**\n * Absolute position\n * @name Highcharts.AnnotationAnchorObject#absolutePosition\n * @type {Highcharts.BBoxObject}\n */\n /**\n * @interface Highcharts.AnnotationControllable\n */ /**\n * @name Highcharts.AnnotationControllable#annotation\n * @type {Highcharts.Annotation}\n */ /**\n * @name Highcharts.AnnotationControllable#chart\n * @type {Highcharts.Chart}\n */ /**\n * @name Highcharts.AnnotationControllable#collection\n * @type {string}\n */ /**\n * @private\n * @name Highcharts.AnnotationControllable#controlPoints\n * @type {Array}\n */ /**\n * @name Highcharts.AnnotationControllable#points\n * @type {Array}\n */\n (''); // keeps doclets above in JS file\n\n return Controllable;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/ControllableDefaults.js', [], function () {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /**\n * Options for configuring markers for annotations.\n *\n * An example of the arrow marker:\n *
\n         * {\n         *   arrow: {\n         *     id: 'arrow',\n         *     tagName: 'marker',\n         *     refY: 5,\n         *     refX: 5,\n         *     markerWidth: 10,\n         *     markerHeight: 10,\n         *     children: [{\n         *       tagName: 'path',\n         *       attrs: {\n         *         d: 'M 0 0 L 10 5 L 0 10 Z',\n         *         'stroke-width': 0\n         *       }\n         *     }]\n         *   }\n         * }\n         * 
\n *\n * @sample highcharts/annotations/custom-markers/\n * Define a custom marker for annotations\n *\n * @sample highcharts/css/annotations-markers/\n * Define markers in a styled mode\n *\n * @type {Highcharts.Dictionary}\n * @since 6.0.0\n * @optionparent defs\n */\n const defaultMarkers = {\n /**\n * @type {Highcharts.ASTNode}\n */\n arrow: {\n tagName: 'marker',\n attributes: {\n id: 'arrow',\n refY: 5,\n refX: 9,\n markerWidth: 10,\n markerHeight: 10\n },\n /**\n * @type {Array}\n */\n children: [{\n tagName: 'path',\n attributes: {\n d: 'M 0 0 L 10 5 L 0 10 Z',\n 'stroke-width': 0\n }\n }]\n },\n /**\n * @type {Highcharts.ASTNode}\n */\n 'reverse-arrow': {\n tagName: 'marker',\n attributes: {\n id: 'reverse-arrow',\n refY: 5,\n refX: 1,\n markerWidth: 10,\n markerHeight: 10\n },\n children: [{\n tagName: 'path',\n attributes: {\n // reverse triangle (used as an arrow)\n d: 'M 0 5 L 10 0 L 10 10 Z',\n 'stroke-width': 0\n }\n }]\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n const ControllableDefaults = {\n defaultMarkers\n };\n\n return ControllableDefaults;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/ControllablePath.js', [_modules['Extensions/Annotations/Controllables/Controllable.js'], _modules['Extensions/Annotations/Controllables/ControllableDefaults.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (Controllable, ControllableDefaults, H, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultMarkers } = ControllableDefaults;\n const { addEvent, defined, extend, merge, uniqueKey } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n const markerEndSetter = createMarkerSetter('marker-end');\n const markerStartSetter = createMarkerSetter('marker-start');\n // See TRACKER_FILL in highcharts.src.js\n const TRACKER_FILL = 'rgba(192,192,192,' + (H.svg ? 0.0001 : 0.002) + ')';\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function createMarkerSetter(markerType) {\n return function (value) {\n this.attr(markerType, 'url(#' + value + ')');\n };\n }\n /**\n * @private\n */\n function onChartAfterGetContainer() {\n this.options.defs = merge(defaultMarkers, this.options.defs || {});\n // objectEach(this.options.defs, function (def): void {\n // const attributes = def.attributes;\n // if (\n // def.tagName === 'marker' &&\n // attributes &&\n // attributes.id &&\n // attributes.display !== 'none'\n // ) {\n // this.renderer.addMarker(attributes.id, def);\n // }\n // }, this);\n }\n /**\n * @private\n */\n function svgRendererAddMarker(id, markerOptions) {\n const options = { attributes: { id } };\n const attrs = {\n stroke: markerOptions.color || 'none',\n fill: markerOptions.color || 'rgba(0, 0, 0, 0.75)'\n };\n options.children = (markerOptions.children &&\n markerOptions.children.map(function (child) {\n return merge(attrs, child);\n }));\n const ast = merge(true, {\n attributes: {\n markerWidth: 20,\n markerHeight: 20,\n refX: 0,\n refY: 0,\n orient: 'auto'\n }\n }, markerOptions, options);\n const marker = this.definition(ast);\n marker.id = id;\n return marker;\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * A controllable path class.\n *\n * @requires modules/annotations\n *\n * @private\n * @class\n * @name Highcharts.AnnotationControllablePath\n *\n * @param {Highcharts.Annotation}\n * Related annotation.\n *\n * @param {Highcharts.AnnotationsShapeOptions} options\n * A path's options object.\n *\n * @param {number} index\n * Index of the path.\n */\n class ControllablePath extends Controllable {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(ChartClass, SVGRendererClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'afterGetContainer', onChartAfterGetContainer);\n }\n if (U.pushUnique(composedMembers, SVGRendererClass)) {\n const svgRendererProto = SVGRendererClass.prototype;\n svgRendererProto.addMarker = svgRendererAddMarker;\n }\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(annotation, options, index) {\n super(annotation, options, index, 'shape');\n /* *\n *\n * Properties\n *\n * */\n this.type = 'path';\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Map the controllable path to 'd' path attribute.\n *\n * @return {Highcharts.SVGPathArray|null}\n * A path's d attribute.\n */\n toD() {\n const dOption = this.options.d;\n if (dOption) {\n return typeof dOption === 'function' ?\n dOption.call(this) :\n dOption;\n }\n const points = this.points, len = points.length, d = [];\n let showPath = len, point = points[0], position = showPath && this.anchor(point).absolutePosition, pointIndex = 0, command;\n if (position) {\n d.push(['M', position.x, position.y]);\n while (++pointIndex < len && showPath) {\n point = points[pointIndex];\n command = point.command || 'L';\n position = this.anchor(point).absolutePosition;\n if (command === 'M') {\n d.push([command, position.x, position.y]);\n }\n else if (command === 'L') {\n d.push([command, position.x, position.y]);\n }\n else if (command === 'Z') {\n d.push([command]);\n }\n showPath = point.series.visible;\n }\n }\n return (showPath && this.graphic ?\n this.chart.renderer.crispLine(d, this.graphic.strokeWidth()) :\n null);\n }\n shouldBeDrawn() {\n return super.shouldBeDrawn() || !!this.options.d;\n }\n render(parent) {\n const options = this.options, attrs = this.attrsFromOptions(options);\n this.graphic = this.annotation.chart.renderer\n .path([['M', 0, 0]])\n .attr(attrs)\n .add(parent);\n if (options.className) {\n this.graphic.addClass(options.className);\n }\n this.tracker = this.annotation.chart.renderer\n .path([['M', 0, 0]])\n .addClass('highcharts-tracker-line')\n .attr({\n zIndex: 2\n })\n .add(parent);\n if (!this.annotation.chart.styledMode) {\n this.tracker.attr({\n 'stroke-linejoin': 'round',\n stroke: TRACKER_FILL,\n fill: TRACKER_FILL,\n 'stroke-width': this.graphic.strokeWidth() +\n options.snap * 2\n });\n }\n super.render();\n extend(this.graphic, { markerStartSetter, markerEndSetter });\n this.setMarkers(this);\n }\n redraw(animation) {\n if (this.graphic) {\n const d = this.toD(), action = animation ? 'animate' : 'attr';\n if (d) {\n this.graphic[action]({ d: d });\n this.tracker[action]({ d: d });\n }\n else {\n this.graphic.attr({ d: 'M 0 ' + -9e9 });\n this.tracker.attr({ d: 'M 0 ' + -9e9 });\n }\n this.graphic.placed = this.tracker.placed = !!d;\n }\n super.redraw(animation);\n }\n /**\n * Set markers.\n * @private\n * @param {Highcharts.AnnotationControllablePath} item\n */\n setMarkers(item) {\n const itemOptions = item.options, chart = item.chart, defs = chart.options.defs, fill = itemOptions.fill, color = defined(fill) && fill !== 'none' ?\n fill :\n itemOptions.stroke;\n const setMarker = function (markerType) {\n let markerId = itemOptions[markerType], def, predefinedMarker, key, marker;\n if (markerId) {\n for (key in defs) { // eslint-disable-line guard-for-in\n def = defs[key];\n if ((markerId === (def.attributes && def.attributes.id) ||\n // Legacy, for\n // unit-tests/annotations/annotations-shapes\n markerId === def.id) &&\n def.tagName === 'marker') {\n predefinedMarker = def;\n break;\n }\n }\n if (predefinedMarker) {\n marker = item[markerType] = chart.renderer\n .addMarker((itemOptions.id || uniqueKey()) + '-' + markerId, merge(predefinedMarker, { color: color }));\n item.attr(markerType, marker.getAttribute('id'));\n }\n }\n };\n ['markerStart', 'markerEnd']\n .forEach(setMarker);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * A map object which allows to map options attributes to element attributes\n *\n * @name Highcharts.AnnotationControllablePath.attrsMap\n * @type {Highcharts.Dictionary}\n */\n ControllablePath.attrsMap = {\n dashStyle: 'dashstyle',\n strokeWidth: 'stroke-width',\n stroke: 'stroke',\n fill: 'fill',\n zIndex: 'zIndex'\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ControllablePath;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/ControllableRect.js', [_modules['Extensions/Annotations/Controllables/Controllable.js'], _modules['Extensions/Annotations/Controllables/ControllablePath.js'], _modules['Core/Utilities.js']], function (Controllable, ControllablePath, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * A controllable rect class.\n *\n * @requires modules/annotations\n *\n * @private\n * @class\n * @name Highcharts.AnnotationControllableRect\n *\n * @param {Highcharts.Annotation} annotation\n * An annotation instance.\n *\n * @param {Highcharts.AnnotationsShapeOptions} options\n * A rect's options.\n *\n * @param {number} index\n * Index of the rectangle\n */\n class ControllableRect extends Controllable {\n /* *\n *\n * Constructors\n *\n * */\n constructor(annotation, options, index) {\n super(annotation, options, index, 'shape');\n /* *\n *\n * Properties\n *\n * */\n this.type = 'rect';\n this.translate = super.translateShape;\n }\n /* *\n *\n * Functions\n *\n * */\n render(parent) {\n const attrs = this.attrsFromOptions(this.options);\n this.graphic = this.annotation.chart.renderer\n .rect(0, -9e9, 0, 0)\n .attr(attrs)\n .add(parent);\n super.render();\n }\n redraw(animation) {\n if (this.graphic) {\n const position = this.anchor(this.points[0]).absolutePosition;\n if (position) {\n this.graphic[animation ? 'animate' : 'attr']({\n x: position.x,\n y: position.y,\n width: this.options.width,\n height: this.options.height\n });\n }\n else {\n this.attr({\n x: 0,\n y: -9e9\n });\n }\n this.graphic.placed = Boolean(position);\n }\n super.redraw(animation);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * A map object which allows to map options attributes to element attributes\n *\n * @type {Annotation.ControllableRect.AttrsMap}\n */\n ControllableRect.attrsMap = merge(ControllablePath.attrsMap, {\n width: 'width',\n height: 'height'\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return ControllableRect;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/ControllableCircle.js', [_modules['Extensions/Annotations/Controllables/Controllable.js'], _modules['Extensions/Annotations/Controllables/ControllablePath.js'], _modules['Core/Utilities.js']], function (Controllable, ControllablePath, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * A controllable circle class.\n *\n * @requires modules/annotations\n *\n * @private\n * @class\n * @name Highcharts.AnnotationControllableCircle\n *\n * @param {Highcharts.Annotation} annotation an annotation instance\n * @param {Highcharts.AnnotationsShapeOptions} options a shape's options\n * @param {number} index of the circle\n */\n class ControllableCircle extends Controllable {\n /* *\n *\n * Constructors\n *\n * */\n constructor(annotation, options, index) {\n super(annotation, options, index, 'shape');\n /* *\n *\n * Properties\n *\n * */\n this.type = 'circle';\n this.translate = super.translateShape;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n redraw(animation) {\n if (this.graphic) {\n const position = this.anchor(this.points[0]).absolutePosition;\n if (position) {\n this.graphic[animation ? 'animate' : 'attr']({\n x: position.x,\n y: position.y,\n r: this.options.r\n });\n }\n else {\n this.graphic.attr({\n x: 0,\n y: -9e9\n });\n }\n this.graphic.placed = !!position;\n }\n super.redraw.call(this, animation);\n }\n /**\n * @private\n */\n render(parent) {\n const attrs = this.attrsFromOptions(this.options);\n this.graphic = this.annotation.chart.renderer\n .circle(0, -9e9, 0)\n .attr(attrs)\n .add(parent);\n super.render();\n }\n /**\n * Set the radius.\n * @private\n * @param {number} r\n * A radius to be set\n */\n setRadius(r) {\n this.options.r = r;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * A map object which allows to map options attributes to element\n * attributes.\n *\n * @name Highcharts.AnnotationControllableCircle.attrsMap\n * @type {Highcharts.Dictionary}\n */\n ControllableCircle.attrsMap = merge(ControllablePath.attrsMap, { r: 'r' });\n /* *\n *\n * Default Export\n *\n * */\n\n return ControllableCircle;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/ControllableEllipse.js', [_modules['Extensions/Annotations/Controllables/Controllable.js'], _modules['Extensions/Annotations/Controllables/ControllablePath.js'], _modules['Core/Utilities.js']], function (Controllable, ControllablePath, U) {\n /* *\n *\n * Author: Pawel Lysy\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge, defined } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * A controllable ellipse class.\n *\n * @requires modules/annotations\n *\n * @private\n * @class\n * @name Highcharts.AnnotationControllableEllipse\n *\n * @param {Highcharts.Annotation} annotation an annotation instance\n * @param {Highcharts.AnnotationsShapeOptions} options a shape's options\n * @param {number} index of the Ellipse\n */\n class ControllableEllipse extends Controllable {\n /* *\n *\n * Constructor\n *\n * */\n constructor(annotation, options, index) {\n super(annotation, options, index, 'shape');\n /* *\n *\n * Properties\n *\n * */\n this.type = 'ellipse';\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n init(annotation, options, index) {\n if (defined(options.yAxis)) {\n options.points.forEach((point) => {\n point.yAxis = options.yAxis;\n });\n }\n if (defined(options.xAxis)) {\n options.points.forEach((point) => {\n point.xAxis = options.xAxis;\n });\n }\n super.init(annotation, options, index);\n }\n /**\n * Render the element\n * @private\n * @param parent\n * Parent SVG element.\n */\n render(parent) {\n this.graphic = this.annotation.chart.renderer.createElement('ellipse')\n .attr(this.attrsFromOptions(this.options))\n .add(parent);\n super.render();\n }\n /**\n * Translate the points. Mostly used to handle dragging of the ellipse.\n * @private\n */\n translate(dx, dy) {\n super.translateShape(dx, dy, true);\n }\n /**\n * Get the distance from the line to the point.\n * @private\n * @param point1\n * First point which is on the line\n * @param point2\n * Second point\n * @param x0\n * Point's x value from which you want to calculate the distance from\n * @param y0\n * Point's y value from which you want to calculate the distance from\n */\n getDistanceFromLine(point1, point2, x0, y0) {\n return Math.abs((point2.y - point1.y) * x0 - (point2.x - point1.x) * y0 +\n point2.x * point1.y - point2.y * point1.x) / Math.sqrt((point2.y - point1.y) * (point2.y - point1.y) +\n (point2.x - point1.x) * (point2.x - point1.x));\n }\n /**\n * The fuction calculates the svg attributes of the ellipse, and returns all\n * parameters neccessary to draw the ellipse.\n * @private\n * @param position\n * Absolute position of the first point in points array\n * @param position2\n * Absolute position of the second point in points array\n */\n getAttrs(position, position2) {\n const x1 = position.x, y1 = position.y, x2 = position2.x, y2 = position2.y, cx = (x1 + x2) / 2, cy = (y1 + y2) / 2, rx = Math.sqrt((x1 - x2) * (x1 - x2) / 4 + (y1 - y2) * (y1 - y2) / 4), tan = (y2 - y1) / (x2 - x1);\n let angle = Math.atan(tan) * 180 / Math.PI;\n if (cx < x1) {\n angle += 180;\n }\n const ry = this.getRY();\n return { cx, cy, rx, ry, angle };\n }\n /**\n * Get the value of minor radius of the ellipse.\n * @private\n */\n getRY() {\n const yAxis = this.getYAxis();\n return defined(yAxis) ?\n Math.abs(yAxis.toPixels(this.options.ry) - yAxis.toPixels(0)) :\n this.options.ry;\n }\n /**\n * Get the yAxis object to which the ellipse is pinned.\n * @private\n */\n getYAxis() {\n const yAxisIndex = this.options.yAxis;\n return this.chart.yAxis[yAxisIndex];\n }\n /**\n * Get the absolute coordinates of the MockPoint\n * @private\n * @param point\n * MockPoint that is added through options\n */\n getAbsolutePosition(point) {\n return this.anchor(point).absolutePosition;\n }\n /**\n * Redraw the element\n * @private\n * @param animation\n * Display an annimation\n */\n redraw(animation) {\n if (this.graphic) {\n const position = this.getAbsolutePosition(this.points[0]), position2 = this.getAbsolutePosition(this.points[1]), attrs = this.getAttrs(position, position2);\n if (position) {\n this.graphic[animation ? 'animate' : 'attr']({\n cx: attrs.cx,\n cy: attrs.cy,\n rx: attrs.rx,\n ry: attrs.ry,\n rotation: attrs.angle,\n rotationOriginX: attrs.cx,\n rotationOriginY: attrs.cy\n });\n }\n else {\n this.graphic.attr({\n x: 0,\n y: -9e9\n });\n }\n this.graphic.placed = Boolean(position);\n }\n super.redraw(animation);\n }\n /**\n * Set the radius Y.\n * @private\n * @param {number} ry\n * A radius in y direction to be set\n */\n setYRadius(ry) {\n const shapes = this.annotation.userOptions.shapes;\n this.options.ry = ry;\n if (shapes && shapes[0]) {\n shapes[0].ry = ry;\n shapes[0].ry = ry;\n }\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * A map object which allows to map options attributes to element\n * attributes.\n *\n * @name Highcharts.AnnotationControllableEllipse.attrsMap\n * @type {Highcharts.Dictionary}\n */\n ControllableEllipse.attrsMap = merge(ControllablePath.attrsMap, {\n ry: 'ry'\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return ControllableEllipse;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/ControllableLabel.js', [_modules['Extensions/Annotations/Controllables/Controllable.js'], _modules['Core/Templating.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Controllable, F, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = F;\n const { extend, isNumber, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * General symbol definition for labels with connector\n * @private\n */\n function symbolConnector(x, y, w, h, options) {\n const anchorX = options && options.anchorX, anchorY = options && options.anchorY;\n let path, yOffset, lateral = w / 2;\n if (isNumber(anchorX) && isNumber(anchorY)) {\n path = [['M', anchorX, anchorY]];\n // Prefer 45 deg connectors\n yOffset = y - anchorY;\n if (yOffset < 0) {\n yOffset = -h - yOffset;\n }\n if (yOffset < w) {\n lateral = anchorX < x + (w / 2) ? yOffset : w - yOffset;\n }\n // Anchor below label\n if (anchorY > y + h) {\n path.push(['L', x + lateral, y + h]);\n // Anchor above label\n }\n else if (anchorY < y) {\n path.push(['L', x + lateral, y]);\n // Anchor left of label\n }\n else if (anchorX < x) {\n path.push(['L', x, y + h / 2]);\n // Anchor right of label\n }\n else if (anchorX > x + w) {\n path.push(['L', x + w, y + h / 2]);\n }\n }\n return path || [];\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * A controllable label class.\n *\n * @requires modules/annotations\n *\n * @private\n * @class\n * @name Highcharts.AnnotationControllableLabel\n *\n * @param {Highcharts.Annotation} annotation\n * An annotation instance.\n * @param {Highcharts.AnnotationsLabelOptions} options\n * A label's options.\n * @param {number} index\n * Index of the label.\n */\n class ControllableLabel extends Controllable {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Returns new aligned position based alignment options and box to align to.\n * It is almost a one-to-one copy from SVGElement.prototype.align\n * except it does not use and mutate an element\n *\n * @param {Highcharts.AnnotationAlignObject} alignOptions\n *\n * @param {Highcharts.BBoxObject} box\n *\n * @return {Highcharts.PositionObject}\n * Aligned position.\n */\n static alignedPosition(alignOptions, box) {\n const align = alignOptions.align, vAlign = alignOptions.verticalAlign;\n let x = (box.x || 0) + (alignOptions.x || 0), y = (box.y || 0) + (alignOptions.y || 0), alignFactor, vAlignFactor;\n if (align === 'right') {\n alignFactor = 1;\n }\n else if (align === 'center') {\n alignFactor = 2;\n }\n if (alignFactor) {\n x += (box.width - (alignOptions.width || 0)) / alignFactor;\n }\n if (vAlign === 'bottom') {\n vAlignFactor = 1;\n }\n else if (vAlign === 'middle') {\n vAlignFactor = 2;\n }\n if (vAlignFactor) {\n y += (box.height - (alignOptions.height || 0)) / vAlignFactor;\n }\n return {\n x: Math.round(x),\n y: Math.round(y)\n };\n }\n static compose(SVGRendererClass) {\n if (U.pushUnique(composedMembers, SVGRendererClass)) {\n const svgRendererProto = SVGRendererClass.prototype;\n svgRendererProto.symbols.connector = symbolConnector;\n }\n }\n /**\n * Returns new alignment options for a label if the label is outside the\n * plot area. It is almost a one-to-one copy from\n * Series.prototype.justifyDataLabel except it does not mutate the label and\n * it works with absolute instead of relative position.\n */\n static justifiedOptions(chart, label, alignOptions, alignAttr) {\n const align = alignOptions.align, verticalAlign = alignOptions.verticalAlign, padding = label.box ? 0 : (label.padding || 0), bBox = label.getBBox(), \n //\n options = {\n align: align,\n verticalAlign: verticalAlign,\n x: alignOptions.x,\n y: alignOptions.y,\n width: label.width,\n height: label.height\n }, \n //\n x = (alignAttr.x || 0) - chart.plotLeft, y = (alignAttr.y || 0) - chart.plotTop;\n let off;\n // Off left\n off = x + padding;\n if (off < 0) {\n if (align === 'right') {\n options.align = 'left';\n }\n else {\n options.x = (options.x || 0) - off;\n }\n }\n // Off right\n off = x + bBox.width - padding;\n if (off > chart.plotWidth) {\n if (align === 'left') {\n options.align = 'right';\n }\n else {\n options.x = (options.x || 0) + chart.plotWidth - off;\n }\n }\n // Off top\n off = y + padding;\n if (off < 0) {\n if (verticalAlign === 'bottom') {\n options.verticalAlign = 'top';\n }\n else {\n options.y = (options.y || 0) - off;\n }\n }\n // Off bottom\n off = y + bBox.height - padding;\n if (off > chart.plotHeight) {\n if (verticalAlign === 'top') {\n options.verticalAlign = 'bottom';\n }\n else {\n options.y = (options.y || 0) + chart.plotHeight - off;\n }\n }\n return options;\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(annotation, options, index) {\n super(annotation, options, index, 'label');\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Translate the point of the label by deltaX and deltaY translations.\n * The point is the label's anchor.\n *\n * @param {number} dx translation for x coordinate\n * @param {number} dy translation for y coordinate\n */\n translatePoint(dx, dy) {\n super.translatePoint(dx, dy, 0);\n }\n /**\n * Translate x and y position relative to the label's anchor.\n *\n * @param {number} dx translation for x coordinate\n * @param {number} dy translation for y coordinate\n */\n translate(dx, dy) {\n const chart = this.annotation.chart, \n // Annotation.options\n labelOptions = this.annotation.userOptions, \n // Chart.options.annotations\n annotationIndex = chart.annotations.indexOf(this.annotation), chartAnnotations = chart.options.annotations, chartOptions = chartAnnotations[annotationIndex];\n if (chart.inverted) {\n const temp = dx;\n dx = dy;\n dy = temp;\n }\n // Local options:\n this.options.x += dx;\n this.options.y += dy;\n // Options stored in chart:\n chartOptions[this.collection][this.index].x = this.options.x;\n chartOptions[this.collection][this.index].y = this.options.y;\n labelOptions[this.collection][this.index].x = this.options.x;\n labelOptions[this.collection][this.index].y = this.options.y;\n }\n render(parent) {\n const options = this.options, attrs = this.attrsFromOptions(options), style = options.style;\n this.graphic = this.annotation.chart.renderer\n .label('', 0, -9999, // #10055\n options.shape, null, null, options.useHTML, null, 'annotation-label')\n .attr(attrs)\n .add(parent);\n if (!this.annotation.chart.styledMode) {\n if (style.color === 'contrast') {\n style.color = this.annotation.chart.renderer.getContrast(ControllableLabel.shapesWithoutBackground.indexOf(options.shape) > -1 ? '#FFFFFF' : options.backgroundColor);\n }\n this.graphic\n .css(options.style)\n .shadow(options.shadow);\n }\n if (options.className) {\n this.graphic.addClass(options.className);\n }\n this.graphic.labelrank = options.labelrank;\n super.render();\n }\n redraw(animation) {\n const options = this.options, text = this.text || options.format || options.text, label = this.graphic, point = this.points[0];\n if (!label) {\n this.redraw(animation);\n return;\n }\n label.attr({\n text: text ?\n format(String(text), point.getLabelConfig(), this.annotation.chart) :\n options.formatter.call(point, this)\n });\n const anchor = this.anchor(point);\n const attrs = this.position(anchor);\n if (attrs) {\n label.alignAttr = attrs;\n attrs.anchorX = anchor.absolutePosition.x;\n attrs.anchorY = anchor.absolutePosition.y;\n label[animation ? 'animate' : 'attr'](attrs);\n }\n else {\n label.attr({\n x: 0,\n y: -9999 // #10055\n });\n }\n label.placed = !!attrs;\n super.redraw(animation);\n }\n /**\n * All basic shapes don't support alignTo() method except label.\n * For a controllable label, we need to subtract translation from\n * options.\n */\n anchor(_point) {\n const anchor = super.anchor.apply(this, arguments), x = this.options.x || 0, y = this.options.y || 0;\n anchor.absolutePosition.x -= x;\n anchor.absolutePosition.y -= y;\n anchor.relativePosition.x -= x;\n anchor.relativePosition.y -= y;\n return anchor;\n }\n /**\n * Returns the label position relative to its anchor.\n */\n position(anchor) {\n const item = this.graphic, chart = this.annotation.chart, tooltip = chart.tooltip, point = this.points[0], itemOptions = this.options, anchorAbsolutePosition = anchor.absolutePosition, anchorRelativePosition = anchor.relativePosition;\n let itemPosition, alignTo, itemPosRelativeX, itemPosRelativeY, showItem = point.series.visible &&\n MockPoint.prototype.isInsidePlot.call(point);\n if (item && showItem) {\n const { width = 0, height = 0 } = item;\n if (itemOptions.distance && tooltip) {\n itemPosition = tooltip.getPosition.call({\n chart,\n distance: pick(itemOptions.distance, 16),\n getPlayingField: tooltip.getPlayingField\n }, width, height, {\n plotX: anchorRelativePosition.x,\n plotY: anchorRelativePosition.y,\n negative: point.negative,\n ttBelow: point.ttBelow,\n h: (anchorRelativePosition.height ||\n anchorRelativePosition.width)\n });\n }\n else if (itemOptions.positioner) {\n itemPosition = itemOptions.positioner.call(this);\n }\n else {\n alignTo = {\n x: anchorAbsolutePosition.x,\n y: anchorAbsolutePosition.y,\n width: 0,\n height: 0\n };\n itemPosition = ControllableLabel.alignedPosition(extend(itemOptions, {\n width,\n height\n }), alignTo);\n if (this.options.overflow === 'justify') {\n itemPosition = ControllableLabel.alignedPosition(ControllableLabel.justifiedOptions(chart, item, itemOptions, itemPosition), alignTo);\n }\n }\n if (itemOptions.crop) {\n itemPosRelativeX = itemPosition.x - chart.plotLeft;\n itemPosRelativeY = itemPosition.y - chart.plotTop;\n showItem =\n chart.isInsidePlot(itemPosRelativeX, itemPosRelativeY) &&\n chart.isInsidePlot(itemPosRelativeX + width, itemPosRelativeY + height);\n }\n }\n return showItem ? itemPosition : null;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * A map object which allows to map options attributes to element attributes\n *\n * @type {Highcharts.Dictionary}\n */\n ControllableLabel.attrsMap = {\n backgroundColor: 'fill',\n borderColor: 'stroke',\n borderWidth: 'stroke-width',\n zIndex: 'zIndex',\n borderRadius: 'r',\n padding: 'padding'\n };\n /**\n * Shapes which do not have background - the object is used for proper\n * setting of the contrast color.\n *\n * @type {Array}\n */\n ControllableLabel.shapesWithoutBackground = ['connector'];\n /* *\n *\n * Default Export\n *\n * */\n\n return ControllableLabel;\n });\n _registerModule(_modules, 'Extensions/Annotations/Controllables/ControllableImage.js', [_modules['Extensions/Annotations/Controllables/Controllable.js'], _modules['Extensions/Annotations/Controllables/ControllableLabel.js']], function (Controllable, ControllableLabel) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Class\n *\n * */\n /**\n * A controllable image class.\n *\n * @requires modules/annotations\n *\n * @private\n * @class\n * @name Highcharts.AnnotationControllableImage\n *\n * @param {Highcharts.Annotation} annotation\n * An annotation instance.\n *\n * @param {Highcharts.AnnotationsShapeOptions} options\n * A controllable's options.\n *\n * @param {number} index\n * Index of the image.\n */\n class ControllableImage extends Controllable {\n /* *\n *\n * Constructors\n *\n * */\n constructor(annotation, options, index) {\n super(annotation, options, index, 'shape');\n /* *\n *\n * Properties\n *\n * */\n this.type = 'image';\n this.translate = super.translateShape;\n }\n render(parent) {\n const attrs = this.attrsFromOptions(this.options), options = this.options;\n this.graphic = this.annotation.chart.renderer\n .image(options.src, 0, -9e9, options.width, options.height)\n .attr(attrs)\n .add(parent);\n this.graphic.width = options.width;\n this.graphic.height = options.height;\n super.render();\n }\n redraw(animation) {\n if (this.graphic) {\n const anchor = this.anchor(this.points[0]), position = ControllableLabel.prototype.position.call(this, anchor);\n if (position) {\n this.graphic[animation ? 'animate' : 'attr']({\n x: position.x,\n y: position.y\n });\n }\n else {\n this.graphic.attr({\n x: 0,\n y: -9e9\n });\n }\n this.graphic.placed = Boolean(position);\n }\n super.redraw(animation);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * A map object which allows to map options attributes to element attributes\n *\n * @name Highcharts.AnnotationControllableImage.attrsMap\n * @type {Highcharts.Dictionary}\n */\n ControllableImage.attrsMap = {\n width: 'width',\n height: 'height',\n zIndex: 'zIndex'\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ControllableImage;\n });\n _registerModule(_modules, 'Core/Chart/ChartNavigationComposition.js', [], function () {\n /**\n *\n * (c) 2010-2021 Paweł Fus\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Composition\n *\n * */\n var ChartNavigationComposition;\n (function (ChartNavigationComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(chart) {\n if (!chart.navigation) {\n chart.navigation = new Additions(chart);\n }\n return chart;\n }\n ChartNavigationComposition.compose = compose;\n /* *\n *\n * Class\n *\n * */\n /**\n * Initializes `chart.navigation` object which delegates `update()` methods\n * to all other common classes (used in exporting and navigationBindings).\n * @private\n */\n class Additions {\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart) {\n this.updates = [];\n this.chart = chart;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Registers an `update()` method in the `chart.navigation` object.\n *\n * @private\n * @param {UpdateFunction} updateFn\n * The `update()` method that will be called in `chart.update()`.\n */\n addUpdate(updateFn) {\n this.chart.navigation.updates.push(updateFn);\n }\n /**\n * @private\n */\n update(options, redraw) {\n this.updates.forEach((updateFn) => {\n updateFn.call(this.chart, options, redraw);\n });\n }\n }\n ChartNavigationComposition.Additions = Additions;\n })(ChartNavigationComposition || (ChartNavigationComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ChartNavigationComposition;\n });\n _registerModule(_modules, 'Extensions/Annotations/NavigationBindingsUtilities.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, isNumber, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n /**\n * Define types for editable fields per annotation. There is no need to define\n * numbers, because they won't change their type to string.\n * @private\n */\n const annotationsFieldsTypes = {\n backgroundColor: 'string',\n borderColor: 'string',\n borderRadius: 'string',\n color: 'string',\n fill: 'string',\n fontSize: 'string',\n labels: 'string',\n name: 'string',\n stroke: 'string',\n title: 'string'\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Returns the first xAxis or yAxis that was clicked with its value.\n *\n * @private\n *\n * @param {Array} coords\n * All the chart's x or y axes with a current pointer's axis value.\n *\n * @return {Highcharts.PointerAxisCoordinateObject}\n * Object with a first found axis and its value that pointer\n * is currently pointing.\n */\n function getAssignedAxis(coords) {\n return coords.filter((coord) => {\n const extremes = coord.axis.getExtremes(), axisMin = extremes.min, axisMax = extremes.max, \n // Correct axis edges when axis has series\n // with pointRange (like column)\n minPointOffset = pick(coord.axis.minPointOffset, 0);\n return isNumber(axisMin) && isNumber(axisMax) &&\n coord.value >= (axisMin - minPointOffset) &&\n coord.value <= (axisMax + minPointOffset) &&\n // don't count navigator axis\n !coord.axis.options.isInternal;\n })[0]; // If the axes overlap, return the first axis that was found.\n }\n /**\n * Get field type according to value\n *\n * @private\n *\n * @param {'boolean'|'number'|'string'} value\n * Atomic type (one of: string, number, boolean)\n *\n * @return {'checkbox'|'number'|'text'}\n * Field type (one of: text, number, checkbox)\n */\n function getFieldType(key, value) {\n const predefinedType = annotationsFieldsTypes[key];\n let fieldType = typeof value;\n if (defined(predefinedType)) {\n fieldType = predefinedType;\n }\n return {\n 'string': 'text',\n 'number': 'number',\n 'boolean': 'checkbox'\n }[fieldType];\n }\n /* *\n *\n * Default Export\n *\n * */\n const NavigationBindingUtilities = {\n annotationsFieldsTypes,\n getAssignedAxis,\n getFieldType\n };\n\n return NavigationBindingUtilities;\n });\n _registerModule(_modules, 'Extensions/Annotations/NavigationBindingsDefaults.js', [_modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Core/Utilities.js']], function (NBU, U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getAssignedAxis } = NBU;\n const { isNumber, merge } = U;\n /* *\n *\n * Constants\n *\n * */\n /**\n * @optionparent lang\n */\n const lang = {\n /**\n * Configure the Popup strings in the chart. Requires the\n * `annotations.js` or `annotations-advanced.src.js` module to be\n * loaded.\n * @since 7.0.0\n * @product highcharts highstock\n */\n navigation: {\n /**\n * Translations for all field names used in popup.\n *\n * @product highcharts highstock\n */\n popup: {\n simpleShapes: 'Simple shapes',\n lines: 'Lines',\n circle: 'Circle',\n ellipse: 'Ellipse',\n rectangle: 'Rectangle',\n label: 'Label',\n shapeOptions: 'Shape options',\n typeOptions: 'Details',\n fill: 'Fill',\n format: 'Text',\n strokeWidth: 'Line width',\n stroke: 'Line color',\n title: 'Title',\n name: 'Name',\n labelOptions: 'Label options',\n labels: 'Labels',\n backgroundColor: 'Background color',\n backgroundColors: 'Background colors',\n borderColor: 'Border color',\n borderRadius: 'Border radius',\n borderWidth: 'Border width',\n style: 'Style',\n padding: 'Padding',\n fontSize: 'Font size',\n color: 'Color',\n height: 'Height',\n shapes: 'Shape options'\n }\n }\n };\n /**\n * @optionparent navigation\n * @product highcharts highstock\n */\n const navigation = {\n /**\n * A CSS class name where all bindings will be attached to. Multiple\n * charts on the same page should have separate class names to prevent\n * duplicating events.\n *\n * Default value of versions < 7.0.4 `highcharts-bindings-wrapper`\n *\n * @since 7.0.0\n * @type {string}\n */\n bindingsClassName: 'highcharts-bindings-container',\n /**\n * Bindings definitions for custom HTML buttons. Each binding implements\n * simple event-driven interface:\n *\n * - `className`: classname used to bind event to\n *\n * - `init`: initial event, fired on button click\n *\n * - `start`: fired on first click on a chart\n *\n * - `steps`: array of sequential events fired one after another on each\n * of users clicks\n *\n * - `end`: last event to be called after last step event\n *\n * @type {Highcharts.Dictionary|*}\n *\n * @sample {highstock} stock/stocktools/stocktools-thresholds\n * Custom bindings\n * @sample {highcharts} highcharts/annotations/bindings/\n * Simple binding\n * @sample {highcharts} highcharts/annotations/bindings-custom-annotation/\n * Custom annotation binding\n *\n * @since 7.0.0\n * @requires modules/annotations\n * @product highcharts highstock\n */\n bindings: {\n /**\n * A circle annotation bindings. Includes `start` and one event in\n * `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-circle-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n circleAnnotation: {\n /** @ignore-option */\n className: 'highcharts-circle-annotation',\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis), navigation = this.chart.options.navigation;\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n return this.chart.addAnnotation(merge({\n langKey: 'circle',\n type: 'basicAnnotation',\n shapes: [{\n type: 'circle',\n point: {\n x: coordsX.value,\n y: coordsY.value,\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index\n },\n r: 5\n }]\n }, navigation.annotationsOptions, navigation.bindings.circleAnnotation\n .annotationsOptions));\n },\n /** @ignore-option */\n steps: [\n function (e, annotation) {\n const shapes = annotation.options.shapes, mockPointOpts = ((shapes && shapes[0] && shapes[0].point) ||\n {});\n let distance;\n if (isNumber(mockPointOpts.xAxis) &&\n isNumber(mockPointOpts.yAxis)) {\n const inverted = this.chart.inverted, x = this.chart.xAxis[mockPointOpts.xAxis]\n .toPixels(mockPointOpts.x), y = this.chart.yAxis[mockPointOpts.yAxis]\n .toPixels(mockPointOpts.y);\n distance = Math.max(Math.sqrt(Math.pow(inverted ? y - e.chartX : x - e.chartX, 2) +\n Math.pow(inverted ? x - e.chartY : y - e.chartY, 2)), 5);\n }\n annotation.update({\n shapes: [{\n r: distance\n }]\n });\n }\n ]\n },\n /**\n * A ellipse annotation bindings. Includes `start` and two events in\n * `steps` array. First updates the second point, responsible for a\n * rx width, and second updates the ry width.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-ellipse-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n ellipseAnnotation: {\n className: 'highcharts-ellipse-annotation',\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis), navigation = this.chart.options.navigation;\n if (!coordsX || !coordsY) {\n return;\n }\n return this.chart.addAnnotation(merge({\n langKey: 'ellipse',\n type: 'basicAnnotation',\n shapes: [\n {\n type: 'ellipse',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }],\n ry: 1\n }\n ]\n }, navigation.annotationsOptions, navigation.bindings.ellipseAnnotation\n .annotationOptions));\n },\n steps: [\n function (e, annotation) {\n const target = annotation.shapes[0], position = target.getAbsolutePosition(target.points[1]);\n target.translatePoint(e.chartX - position.x, e.chartY - position.y, 1);\n target.redraw(false);\n },\n function (e, annotation) {\n const target = annotation.shapes[0], position = target.getAbsolutePosition(target.points[0]), position2 = target.getAbsolutePosition(target.points[1]), newR = target.getDistanceFromLine(position, position2, e.chartX, e.chartY), yAxis = target.getYAxis(), newRY = Math.abs(yAxis.toValue(0) - yAxis.toValue(newR));\n target.setYRadius(newRY);\n target.redraw(false);\n }\n ]\n },\n /**\n * A rectangle annotation bindings. Includes `start` and one event\n * in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-rectangle-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n rectangleAnnotation: {\n /** @ignore-option */\n className: 'highcharts-rectangle-annotation',\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, xAxis = coordsX.axis.index, yAxis = coordsY.axis.index, navigation = this.chart.options.navigation;\n return this.chart.addAnnotation(merge({\n langKey: 'rectangle',\n type: 'basicAnnotation',\n shapes: [{\n type: 'path',\n points: [\n { xAxis, yAxis, x, y },\n { xAxis, yAxis, x, y },\n { xAxis, yAxis, x, y },\n { xAxis, yAxis, x, y },\n { command: 'Z' }\n ]\n }]\n }, navigation\n .annotationsOptions, navigation\n .bindings\n .rectangleAnnotation\n .annotationsOptions));\n },\n /** @ignore-option */\n steps: [\n function (e, annotation) {\n const shapes = annotation.options.shapes, points = ((shapes && shapes[0] && shapes[0].points) ||\n []), coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n if (coordsX && coordsY) {\n const x = coordsX.value, y = coordsY.value;\n // Top right point\n points[1].x = x;\n // Bottom right point (cursor position)\n points[2].x = x;\n points[2].y = y;\n // Bottom left\n points[3].y = y;\n annotation.update({\n shapes: [{\n points: points\n }]\n });\n }\n }\n ]\n },\n /**\n * A label annotation bindings. Includes `start` event only.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-label-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n labelAnnotation: {\n /** @ignore-option */\n className: 'highcharts-label-annotation',\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis), navigation = this.chart.options.navigation;\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n return this.chart.addAnnotation(merge({\n langKey: 'label',\n type: 'basicAnnotation',\n labelOptions: {\n format: '{y:.2f}'\n },\n labels: [{\n point: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n x: coordsX.value,\n y: coordsY.value\n },\n overflow: 'none',\n crop: true\n }]\n }, navigation\n .annotationsOptions, navigation\n .bindings\n .labelAnnotation\n .annotationsOptions));\n }\n }\n },\n /**\n * Path where Highcharts will look for icons. Change this to use icons\n * from a different server.\n *\n * @type {string}\n * @default https://code.highcharts.com/11.1.0/gfx/stock-icons/\n * @since 7.1.3\n * @apioption navigation.iconsURL\n */\n /**\n * A `showPopup` event. Fired when selecting for example an annotation.\n *\n * @type {Function}\n * @apioption navigation.events.showPopup\n */\n /**\n * A `closePopup` event. Fired when Popup should be hidden, for example\n * when clicking on an annotation again.\n *\n * @type {Function}\n * @apioption navigation.events.closePopup\n */\n /**\n * Event fired on a button click.\n *\n * @type {Function}\n * @sample highcharts/annotations/gui/\n * Change icon in a dropddown on event\n * @sample highcharts/annotations/gui-buttons/\n * Change button class on event\n * @apioption navigation.events.selectButton\n */\n /**\n * Event fired when button state should change, for example after\n * adding an annotation.\n *\n * @type {Function}\n * @sample highcharts/annotations/gui/\n * Change icon in a dropddown on event\n * @sample highcharts/annotations/gui-buttons/\n * Change button class on event\n * @apioption navigation.events.deselectButton\n */\n /**\n * Events to communicate between Stock Tools and custom GUI.\n *\n * @since 7.0.0\n * @product highcharts highstock\n * @optionparent navigation.events\n */\n events: {},\n /**\n * Additional options to be merged into all annotations.\n *\n * @sample stock/stocktools/navigation-annotation-options\n * Set red color of all line annotations\n *\n * @type {Highcharts.AnnotationsOptions}\n * @extends annotations\n * @exclude crookedLine, elliottWave, fibonacci, infinityLine,\n * measure, pitchfork, tunnel, verticalLine, basicAnnotation\n * @requires modules/annotations\n * @apioption navigation.annotationsOptions\n */\n annotationsOptions: {\n animation: {\n defer: 0\n }\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n const NavigationBindingDefaults = {\n lang,\n navigation\n };\n\n return NavigationBindingDefaults;\n });\n _registerModule(_modules, 'Extensions/Annotations/NavigationBindings.js', [_modules['Core/Chart/ChartNavigationComposition.js'], _modules['Core/Defaults.js'], _modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Extensions/Annotations/NavigationBindingsDefaults.js'], _modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Core/Utilities.js']], function (ChartNavigationComposition, D, F, H, NavigationBindingDefaults, NBU, U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { setOptions } = D;\n const { format } = F;\n const { doc, win } = H;\n const { getFieldType } = NBU;\n const { addEvent, attr, defined, fireEvent, isArray, isFunction, isNumber, isObject, merge, objectEach, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * IE 9-11 polyfill for Element.closest():\n * @private\n */\n function closestPolyfill(el, s) {\n const ElementProto = win.Element.prototype, elementMatches = ElementProto.matches ||\n ElementProto.msMatchesSelector ||\n ElementProto.webkitMatchesSelector;\n let ret = null;\n if (ElementProto.closest) {\n ret = ElementProto.closest.call(el, s);\n }\n else {\n do {\n if (elementMatches.call(el, s)) {\n return el;\n }\n el = el.parentElement || el.parentNode;\n } while (el !== null && el.nodeType === 1);\n }\n return ret;\n }\n /**\n * @private\n */\n function onAnnotationRemove() {\n if (this.chart.navigationBindings) {\n this.chart.navigationBindings.deselectAnnotation();\n }\n }\n /**\n * @private\n */\n function onChartDestroy() {\n if (this.navigationBindings) {\n this.navigationBindings.destroy();\n }\n }\n /**\n * @private\n */\n function onChartLoad() {\n const options = this.options;\n if (options && options.navigation && options.navigation.bindings) {\n this.navigationBindings = new NavigationBindings(this, options.navigation);\n this.navigationBindings.initEvents();\n this.navigationBindings.initUpdate();\n }\n }\n /**\n * @private\n */\n function onChartRender() {\n const navigationBindings = this.navigationBindings, disabledClassName = 'highcharts-disabled-btn';\n if (this && navigationBindings) {\n // Check if the buttons should be enabled/disabled based on\n // visible series.\n let buttonsEnabled = false;\n this.series.forEach((series) => {\n if (!series.options.isInternal && series.visible) {\n buttonsEnabled = true;\n }\n });\n if (this.navigationBindings &&\n this.navigationBindings.container &&\n this.navigationBindings.container[0]) {\n const container = this.navigationBindings.container[0];\n objectEach(navigationBindings.boundClassNames, (value, key) => {\n // Get the HTML element coresponding to the className taken\n // from StockToolsBindings.\n const buttonNode = container.querySelectorAll('.' + key);\n if (buttonNode) {\n for (let i = 0; i < buttonNode.length; i++) {\n const button = buttonNode[i], cls = button.className;\n if (value.noDataState === 'normal') {\n // If button has noDataState: 'normal', and has\n // disabledClassName, remove this className.\n if (cls.indexOf(disabledClassName) !== -1) {\n button.classList.remove(disabledClassName);\n }\n }\n else if (!buttonsEnabled) {\n if (cls.indexOf(disabledClassName) === -1) {\n button.className += ' ' + disabledClassName;\n }\n }\n else {\n // Enable all buttons by deleting the className.\n if (cls.indexOf(disabledClassName) !== -1) {\n button.classList.remove(disabledClassName);\n }\n }\n }\n }\n });\n }\n }\n }\n /**\n * @private\n */\n function onNavigationBindingsClosePopup() {\n this.deselectAnnotation();\n }\n /**\n * @private\n */\n function onNavigationBindingsDeselectButton() {\n this.selectedButtonElement = null;\n }\n /**\n * Show edit-annotation form:\n * @private\n */\n function selectableAnnotation(annotationType) {\n const originalClick = annotationType.prototype.defaultOptions.events &&\n annotationType.prototype.defaultOptions.events.click;\n /**\n * Select and show popup\n * @private\n */\n function selectAndShowPopup(eventArguments) {\n const annotation = this, navigation = annotation.chart.navigationBindings, prevAnnotation = navigation.activeAnnotation;\n if (originalClick) {\n originalClick.call(annotation, eventArguments);\n }\n if (prevAnnotation !== annotation) {\n // Select current:\n navigation.deselectAnnotation();\n navigation.activeAnnotation = annotation;\n annotation.setControlPointsVisibility(true);\n fireEvent(navigation, 'showPopup', {\n annotation: annotation,\n formType: 'annotation-toolbar',\n options: navigation.annotationToFields(annotation),\n onSubmit: function (data) {\n if (data.actionType === 'remove') {\n navigation.activeAnnotation = false;\n navigation.chart.removeAnnotation(annotation);\n }\n else {\n const config = {};\n navigation.fieldsToOptions(data.fields, config);\n navigation.deselectAnnotation();\n const typeOptions = config.typeOptions;\n if (annotation.options.type === 'measure') {\n // Manually disable crooshars according to\n // stroke width of the shape:\n typeOptions.crosshairY.enabled = (typeOptions.crosshairY\n .strokeWidth !== 0);\n typeOptions.crosshairX.enabled = (typeOptions.crosshairX\n .strokeWidth !== 0);\n }\n annotation.update(config);\n }\n }\n });\n }\n else {\n // Deselect current:\n fireEvent(navigation, 'closePopup');\n }\n // Let bubble event to chart.click:\n eventArguments.activeAnnotation = true;\n }\n // #18276, show popup on touchend, but not on touchmove\n let touchStartX, touchStartY;\n function saveCoords(e) {\n touchStartX = e.touches[0].clientX;\n touchStartY = e.touches[0].clientY;\n }\n function checkForTouchmove(e) {\n const hasMoved = touchStartX ? Math.sqrt(Math.pow(touchStartX - e.changedTouches[0].clientX, 2) +\n Math.pow(touchStartY - e.changedTouches[0].clientY, 2)) >= 4 : false;\n if (!hasMoved) {\n selectAndShowPopup.call(this, e);\n }\n }\n merge(true, annotationType.prototype.defaultOptions.events, {\n click: selectAndShowPopup,\n touchstart: saveCoords,\n touchend: checkForTouchmove\n });\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n */\n class NavigationBindings {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AnnotationClass, ChartClass) {\n if (U.pushUnique(composedMembers, AnnotationClass)) {\n addEvent(AnnotationClass, 'remove', onAnnotationRemove);\n // Basic shapes:\n selectableAnnotation(AnnotationClass);\n // Advanced annotations:\n objectEach(AnnotationClass.types, (annotationType) => {\n selectableAnnotation(annotationType);\n });\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'destroy', onChartDestroy);\n addEvent(ChartClass, 'load', onChartLoad);\n addEvent(ChartClass, 'render', onChartRender);\n }\n if (U.pushUnique(composedMembers, NavigationBindings)) {\n addEvent(NavigationBindings, 'closePopup', onNavigationBindingsClosePopup);\n addEvent(NavigationBindings, 'deselectButton', onNavigationBindingsDeselectButton);\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n setOptions(NavigationBindingDefaults);\n }\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart, options) {\n this.boundClassNames = void 0;\n this.selectedButton = void 0;\n this.chart = chart;\n this.options = options;\n this.eventsToUnbind = [];\n this.container =\n this.chart.container.getElementsByClassName(this.options.bindingsClassName || '');\n if (!this.container.length) {\n this.container = doc.getElementsByClassName(this.options.bindingsClassName || '');\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initi all events conencted to NavigationBindings.\n *\n * @private\n * @function Highcharts.NavigationBindings#initEvents\n */\n initEvents() {\n const navigation = this, chart = navigation.chart, bindingsContainer = navigation.container, options = navigation.options;\n // Shorthand object for getting events for buttons:\n navigation.boundClassNames = {};\n objectEach((options.bindings || {}), (value) => {\n navigation.boundClassNames[value.className] = value;\n });\n // Handle multiple containers with the same class names:\n [].forEach.call(bindingsContainer, (subContainer) => {\n navigation.eventsToUnbind.push(addEvent(subContainer, 'click', (event) => {\n const bindings = navigation.getButtonEvents(subContainer, event);\n if (bindings &&\n (!bindings.button.classList\n .contains('highcharts-disabled-btn'))) {\n navigation.bindingsButtonClick(bindings.button, bindings.events, event);\n }\n }));\n });\n objectEach((options.events || {}), (callback, eventName) => {\n if (isFunction(callback)) {\n navigation.eventsToUnbind.push(addEvent(navigation, eventName, callback, { passive: false }));\n }\n });\n navigation.eventsToUnbind.push(addEvent(chart.container, 'click', function (e) {\n if (!chart.cancelClick &&\n chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop, {\n visiblePlotOnly: true\n })) {\n navigation.bindingsChartClick(this, e);\n }\n }));\n navigation.eventsToUnbind.push(addEvent(chart.container, H.isTouchDevice ? 'touchmove' : 'mousemove', function (e) {\n navigation.bindingsContainerMouseMove(this, e);\n }, H.isTouchDevice ? { passive: false } : void 0));\n }\n /**\n * Common chart.update() delegation, shared between bindings and exporting.\n *\n * @private\n * @function Highcharts.NavigationBindings#initUpdate\n */\n initUpdate() {\n const navigation = this;\n ChartNavigationComposition\n .compose(this.chart).navigation\n .addUpdate((options) => {\n navigation.update(options);\n });\n }\n /**\n * Hook for click on a button, method selcts/unselects buttons,\n * then calls `bindings.init` callback.\n *\n * @private\n * @function Highcharts.NavigationBindings#bindingsButtonClick\n *\n * @param {Highcharts.HTMLDOMElement} [button]\n * Clicked button\n *\n * @param {Object} events\n * Events passed down from bindings (`init`, `start`, `step`, `end`)\n *\n * @param {Highcharts.PointerEventObject} clickEvent\n * Browser's click event\n */\n bindingsButtonClick(button, events, clickEvent) {\n const navigation = this, chart = navigation.chart, svgContainer = chart.renderer.boxWrapper;\n let shouldEventBeFired = true;\n if (navigation.selectedButtonElement) {\n if (navigation.selectedButtonElement.classList === button.classList) {\n shouldEventBeFired = false;\n }\n fireEvent(navigation, 'deselectButton', { button: navigation.selectedButtonElement });\n if (navigation.nextEvent) {\n // Remove in-progress annotations adders:\n if (navigation.currentUserDetails &&\n navigation.currentUserDetails.coll === 'annotations') {\n chart.removeAnnotation(navigation.currentUserDetails);\n }\n navigation.mouseMoveEvent = navigation.nextEvent = false;\n }\n }\n if (shouldEventBeFired) {\n navigation.selectedButton = events;\n navigation.selectedButtonElement = button;\n fireEvent(navigation, 'selectButton', { button: button });\n // Call \"init\" event, for example to open modal window\n if (events.init) {\n events.init.call(navigation, button, clickEvent);\n }\n if (events.start || events.steps) {\n chart.renderer.boxWrapper.addClass('highcharts-draw-mode');\n }\n }\n else {\n chart.stockTools &&\n chart.stockTools.toggleButtonActiveClass(button);\n svgContainer.removeClass('highcharts-draw-mode');\n navigation.nextEvent = false;\n navigation.mouseMoveEvent = false;\n navigation.selectedButton = null;\n }\n }\n /**\n * Hook for click on a chart, first click on a chart calls `start` event,\n * then on all subsequent clicks iterate over `steps` array.\n * When finished, calls `end` event.\n *\n * @private\n * @function Highcharts.NavigationBindings#bindingsChartClick\n *\n * @param {Highcharts.Chart} chart\n * Chart that click was performed on.\n *\n * @param {Highcharts.PointerEventObject} clickEvent\n * Browser's click event.\n */\n bindingsChartClick(chart, clickEvent) {\n chart = this.chart;\n const navigation = this, activeAnnotation = navigation.activeAnnotation, selectedButton = navigation.selectedButton, svgContainer = chart.renderer.boxWrapper;\n if (activeAnnotation) {\n // Click outside popups, should close them and deselect the\n // annotation\n if (!activeAnnotation.cancelClick && // #15729\n !clickEvent.activeAnnotation &&\n // Element could be removed in the child action, e.g. button\n clickEvent.target.parentNode &&\n // TO DO: Polyfill for IE11?\n !closestPolyfill(clickEvent.target, '.highcharts-popup')) {\n fireEvent(navigation, 'closePopup');\n }\n else if (activeAnnotation.cancelClick) {\n // Reset cancelClick after the other event handlers have run\n setTimeout(() => {\n activeAnnotation.cancelClick = false;\n }, 0);\n }\n }\n if (!selectedButton || !selectedButton.start) {\n return;\n }\n if (!navigation.nextEvent) {\n // Call init method:\n navigation.currentUserDetails = selectedButton.start.call(navigation, clickEvent);\n // If steps exists (e.g. Annotations), bind them:\n if (navigation.currentUserDetails && selectedButton.steps) {\n navigation.stepIndex = 0;\n navigation.steps = true;\n navigation.mouseMoveEvent = navigation.nextEvent =\n selectedButton.steps[navigation.stepIndex];\n }\n else {\n fireEvent(navigation, 'deselectButton', { button: navigation.selectedButtonElement });\n svgContainer.removeClass('highcharts-draw-mode');\n navigation.steps = false;\n navigation.selectedButton = null;\n // First click is also the last one:\n if (selectedButton.end) {\n selectedButton.end.call(navigation, clickEvent, navigation.currentUserDetails);\n }\n }\n }\n else {\n navigation.nextEvent(clickEvent, navigation.currentUserDetails);\n if (navigation.steps) {\n navigation.stepIndex++;\n if (selectedButton.steps[navigation.stepIndex]) {\n // If we have more steps, bind them one by one:\n navigation.mouseMoveEvent = navigation.nextEvent = selectedButton.steps[navigation.stepIndex];\n }\n else {\n fireEvent(navigation, 'deselectButton', { button: navigation.selectedButtonElement });\n svgContainer.removeClass('highcharts-draw-mode');\n // That was the last step, call end():\n if (selectedButton.end) {\n selectedButton.end.call(navigation, clickEvent, navigation.currentUserDetails);\n }\n navigation.nextEvent = false;\n navigation.mouseMoveEvent = false;\n navigation.selectedButton = null;\n }\n }\n }\n }\n /**\n * Hook for mouse move on a chart's container. It calls current step.\n *\n * @private\n * @function Highcharts.NavigationBindings#bindingsContainerMouseMove\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Chart's container.\n *\n * @param {global.Event} moveEvent\n * Browser's move event.\n */\n bindingsContainerMouseMove(_container, moveEvent) {\n if (this.mouseMoveEvent) {\n this.mouseMoveEvent(moveEvent, this.currentUserDetails);\n }\n }\n /**\n * Translate fields (e.g. `params.period` or `marker.styles.color`) to\n * Highcharts options object (e.g. `{ params: { period } }`).\n *\n * @private\n * @function Highcharts.NavigationBindings#fieldsToOptions\n *\n * @param {Highcharts.Dictionary} fields\n * Fields from popup form.\n *\n * @param {T} config\n * Default config to be modified.\n *\n * @return {T}\n * Modified config\n */\n fieldsToOptions(fields, config) {\n objectEach(fields, (value, field) => {\n const parsedValue = parseFloat(value), path = field.split('.'), pathLength = path.length - 1;\n // If it's a number (not \"format\" options), parse it:\n if (isNumber(parsedValue) &&\n !value.match(/px|em/g) &&\n !field.match(/format/g)) {\n value = parsedValue;\n }\n // Remove values like 0\n if (value !== 'undefined') {\n let parent = config;\n path.forEach((name, index) => {\n const nextName = pick(path[index + 1], '');\n if (pathLength === index) {\n // Last index, put value:\n parent[name] = value;\n }\n else if (!parent[name]) {\n // Create middle property:\n parent[name] = nextName.match(/\\d/g) ? [] : {};\n parent = parent[name];\n }\n else {\n // Jump into next property\n parent = parent[name];\n }\n });\n }\n });\n return config;\n }\n /**\n * Shorthand method to deselect an annotation.\n *\n * @function Highcharts.NavigationBindings#deselectAnnotation\n */\n deselectAnnotation() {\n if (this.activeAnnotation) {\n this.activeAnnotation.setControlPointsVisibility(false);\n this.activeAnnotation = false;\n }\n }\n /**\n * Generates API config for popup in the same format as options for\n * Annotation object.\n *\n * @function Highcharts.NavigationBindings#annotationToFields\n *\n * @param {Highcharts.Annotation} annotation\n * Annotations object\n *\n * @return {Highcharts.Dictionary}\n * Annotation options to be displayed in popup box\n */\n annotationToFields(annotation) {\n const options = annotation.options, editables = NavigationBindings.annotationsEditable, nestedEditables = editables.nestedOptions, type = pick(options.type, options.shapes && options.shapes[0] &&\n options.shapes[0].type, options.labels && options.labels[0] &&\n options.labels[0].type, 'label'), nonEditables = NavigationBindings.annotationsNonEditable[options.langKey] || [], visualOptions = {\n langKey: options.langKey,\n type: type\n };\n /**\n * Nested options traversing. Method goes down to the options and copies\n * allowed options (with values) to new object, which is last parameter:\n * \"parent\".\n *\n * @private\n *\n * @param {*} option\n * Atomic type or object/array\n *\n * @param {string} key\n * Option name, for example \"visible\" or \"x\", \"y\"\n *\n * @param {Object} parentEditables\n * Editables from NavigationBindings.annotationsEditable\n *\n * @param {Object} parent\n * Where new options will be assigned\n */\n function traverse(option, key, parentEditables, parent, parentKey) {\n let nextParent;\n if (parentEditables &&\n option &&\n nonEditables.indexOf(key) === -1 &&\n ((parentEditables.indexOf &&\n parentEditables.indexOf(key)) >= 0 ||\n parentEditables[key] || // nested array\n parentEditables === true // simple array\n )) {\n // Roots:\n if (isArray(option)) {\n parent[key] = [];\n option.forEach((arrayOption, i) => {\n if (!isObject(arrayOption)) {\n // Simple arrays, e.g. [String, Number, Boolean]\n traverse(arrayOption, 0, nestedEditables[key], parent[key], key);\n }\n else {\n // Advanced arrays, e.g. [Object, Object]\n parent[key][i] = {};\n objectEach(arrayOption, (nestedOption, nestedKey) => {\n traverse(nestedOption, nestedKey, nestedEditables[key], parent[key][i], key);\n });\n }\n });\n }\n else if (isObject(option)) {\n nextParent = {};\n if (isArray(parent)) {\n parent.push(nextParent);\n nextParent[key] = {};\n nextParent = nextParent[key];\n }\n else {\n parent[key] = nextParent;\n }\n objectEach(option, (nestedOption, nestedKey) => {\n traverse(nestedOption, nestedKey, key === 0 ?\n parentEditables :\n nestedEditables[key], nextParent, key);\n });\n }\n else {\n // Leaf:\n if (key === 'format') {\n parent[key] = [\n format(option, annotation.labels[0].points[0]).toString(),\n 'text'\n ];\n }\n else if (isArray(parent)) {\n parent.push([option, getFieldType(parentKey, option)]);\n }\n else {\n parent[key] = [option, getFieldType(key, option)];\n }\n }\n }\n }\n objectEach(options, (option, key) => {\n if (key === 'typeOptions') {\n visualOptions[key] = {};\n objectEach(options[key], (typeOption, typeKey) => {\n traverse(typeOption, typeKey, nestedEditables, visualOptions[key], typeKey);\n });\n }\n else {\n traverse(option, key, editables[type], visualOptions, key);\n }\n });\n return visualOptions;\n }\n /**\n * Get all class names for all parents in the element. Iterates until finds\n * main container.\n *\n * @private\n * @function Highcharts.NavigationBindings#getClickedClassNames\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Container that event is bound to.\n *\n * @param {global.Event} event\n * Browser's event.\n *\n * @return {Array>}\n * Array of class names with corresponding elements\n */\n getClickedClassNames(container, event) {\n let element = event.target, classNames = [], elemClassName;\n while (element && element.tagName) {\n elemClassName = attr(element, 'class');\n if (elemClassName) {\n classNames = classNames.concat(elemClassName\n .split(' ')\n // eslint-disable-next-line no-loop-func\n .map((name) => ([name, element])));\n }\n element = element.parentNode;\n if (element === container) {\n return classNames;\n }\n }\n return classNames;\n }\n /**\n * Get events bound to a button. It's a custom event delegation to find all\n * events connected to the element.\n *\n * @private\n * @function Highcharts.NavigationBindings#getButtonEvents\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Container that event is bound to.\n *\n * @param {global.Event} event\n * Browser's event.\n *\n * @return {Object}\n * Object with events (init, start, steps, and end)\n */\n getButtonEvents(container, event) {\n const navigation = this, classNames = this.getClickedClassNames(container, event);\n let bindings;\n classNames.forEach((className) => {\n if (navigation.boundClassNames[className[0]] && !bindings) {\n bindings = {\n events: navigation.boundClassNames[className[0]],\n button: className[1]\n };\n }\n });\n return bindings;\n }\n /**\n * Bindings are just events, so the whole update process is simply\n * removing old events and adding new ones.\n *\n * @private\n * @function Highcharts.NavigationBindings#update\n */\n update(options) {\n this.options = merge(true, this.options, options);\n this.removeEvents();\n this.initEvents();\n }\n /**\n * Remove all events created in the navigation.\n *\n * @private\n * @function Highcharts.NavigationBindings#removeEvents\n */\n removeEvents() {\n this.eventsToUnbind.forEach((unbinder) => unbinder());\n }\n /**\n * @private\n * @function Highcharts.NavigationBindings#destroy\n */\n destroy() {\n this.removeEvents();\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n // Define which options from annotations should show up in edit box:\n NavigationBindings.annotationsEditable = {\n // `typeOptions` are always available\n // Nested and shared options:\n nestedOptions: {\n labelOptions: ['style', 'format', 'backgroundColor'],\n labels: ['style'],\n label: ['style'],\n style: ['fontSize', 'color'],\n background: ['fill', 'strokeWidth', 'stroke'],\n innerBackground: ['fill', 'strokeWidth', 'stroke'],\n outerBackground: ['fill', 'strokeWidth', 'stroke'],\n shapeOptions: ['fill', 'strokeWidth', 'stroke'],\n shapes: ['fill', 'strokeWidth', 'stroke'],\n line: ['strokeWidth', 'stroke'],\n backgroundColors: [true],\n connector: ['fill', 'strokeWidth', 'stroke'],\n crosshairX: ['strokeWidth', 'stroke'],\n crosshairY: ['strokeWidth', 'stroke']\n },\n // Simple shapes:\n circle: ['shapes'],\n ellipse: ['shapes'],\n verticalLine: [],\n label: ['labelOptions'],\n // Measure\n measure: ['background', 'crosshairY', 'crosshairX'],\n // Others:\n fibonacci: [],\n tunnel: ['background', 'line', 'height'],\n pitchfork: ['innerBackground', 'outerBackground'],\n rect: ['shapes'],\n // Crooked lines, elliots, arrows etc:\n crookedLine: [],\n basicAnnotation: ['shapes', 'labelOptions']\n };\n // Define non editable fields per annotation, for example Rectangle inherits\n // options from Measure, but crosshairs are not available\n NavigationBindings.annotationsNonEditable = {\n rectangle: ['crosshairX', 'crosshairY', 'labelOptions'],\n ellipse: ['labelOptions'],\n circle: ['labelOptions']\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A config object for navigation bindings in annotations.\n *\n * @interface Highcharts.NavigationBindingsOptionsObject\n */ /**\n * ClassName of the element for a binding.\n * @name Highcharts.NavigationBindingsOptionsObject#className\n * @type {string|undefined}\n */ /**\n * Last event to be fired after last step event.\n * @name Highcharts.NavigationBindingsOptionsObject#end\n * @type {Function|undefined}\n */ /**\n * Initial event, fired on a button click.\n * @name Highcharts.NavigationBindingsOptionsObject#init\n * @type {Function|undefined}\n */ /**\n * Event fired on first click on a chart.\n * @name Highcharts.NavigationBindingsOptionsObject#start\n * @type {Function|undefined}\n */ /**\n * Last event to be fired after last step event. Array of step events to be\n * called sequentially after each user click.\n * @name Highcharts.NavigationBindingsOptionsObject#steps\n * @type {Array|undefined}\n */\n (''); // keeps doclets above in JS file\n\n return NavigationBindings;\n });\n _registerModule(_modules, 'Shared/BaseForm.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Utilities.js']], function (AST, U) {\n /* *\n *\n * (c) 2009 - 2023 Highsoft AS\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Imports\n *\n * */\n const { addEvent, createElement } = U;\n /* *\n *\n * Class\n *\n * */\n class BaseForm {\n /* *\n *\n * Constructor\n *\n * */\n constructor(parentDiv, iconsURL) {\n this.iconsURL = iconsURL;\n this.container = this.createPopupContainer(parentDiv);\n this.closeButton = this.addCloseButton();\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create popup div container.\n *\n * @param {HTMLElement} parentDiv\n * Parent div to attach popup.\n *\n * @param {string} className\n * Class name of the popup.\n *\n * @return {HTMLElement}\n * Popup div.\n */\n createPopupContainer(parentDiv, className = 'highcharts-popup highcharts-no-tooltip') {\n return createElement('div', { className }, void 0, parentDiv);\n }\n /**\n * Create HTML element and attach click event to close popup.\n *\n * @param {string} className\n * Class name of the close button.\n *\n * @return {HTMLElement}\n * Close button.\n */\n addCloseButton(className = 'highcharts-popup-close') {\n const popup = this, iconsURL = this.iconsURL;\n // Create close popup button.\n const closeButton = createElement('div', { className }, void 0, this.container);\n closeButton.style['background-image'] = 'url(' +\n (iconsURL.match(/png|svg|jpeg|jpg|gif/ig) ?\n iconsURL : iconsURL + 'close.svg') + ')';\n ['click', 'touchstart'].forEach((eventName) => {\n addEvent(closeButton, eventName, popup.closeButtonEvents.bind(popup));\n });\n return closeButton;\n }\n /**\n * Close button events.\n * @return {void}\n */\n closeButtonEvents() {\n this.closePopup();\n }\n /**\n * Reset content of the current popup and show.\n *\n * @param {string} toolbarClass\n * Class name of the toolbar which styles should be reset.\n */\n showPopup(toolbarClass = 'highcharts-annotation-toolbar') {\n const popupDiv = this.container, popupCloseButton = this.closeButton;\n this.type = void 0;\n // Reset content.\n popupDiv.innerHTML = AST.emptyHTML;\n // Reset toolbar styles if exists.\n if (popupDiv.className.indexOf(toolbarClass) >= 0) {\n popupDiv.classList.remove(toolbarClass);\n // reset toolbar inline styles\n popupDiv.removeAttribute('style');\n }\n // Add close button.\n popupDiv.appendChild(popupCloseButton);\n popupDiv.style.display = 'block';\n popupDiv.style.height = '';\n }\n /**\n * Hide popup.\n */\n closePopup() {\n this.container.style.display = 'none';\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return BaseForm;\n });\n _registerModule(_modules, 'Extensions/Annotations/Popup/PopupAnnotations.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * Popup generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { doc, isFirefox } = H;\n const { createElement, isArray, isObject, objectEach, pick, stableSort } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create annotation simple form.\n * It contains fields with param names.\n * @private\n * @param {Highcharts.Chart} chart\n * Chart\n * @param {Object} options\n * Options\n * @param {Function} callback\n * On click callback\n * @param {boolean} [isInit]\n * If it is a form declared for init annotation\n */\n function addForm(chart, options, callback, isInit) {\n if (!chart) {\n return;\n }\n const popupDiv = this.container, lang = this.lang;\n // create title of annotations\n let lhsCol = createElement('h2', {\n className: 'highcharts-popup-main-title'\n }, void 0, popupDiv);\n lhsCol.appendChild(doc.createTextNode(lang[options.langKey] || options.langKey || ''));\n // left column\n lhsCol = createElement('div', {\n className: ('highcharts-popup-lhs-col highcharts-popup-lhs-full')\n }, void 0, popupDiv);\n const bottomRow = createElement('div', {\n className: 'highcharts-popup-bottom-row'\n }, void 0, popupDiv);\n addFormFields.call(this, lhsCol, chart, '', options, [], true);\n this.addButton(bottomRow, isInit ?\n (lang.addButton || 'Add') :\n (lang.saveButton || 'Save'), isInit ? 'add' : 'save', popupDiv, callback);\n }\n /**\n * Create annotation simple form. It contains two buttons\n * (edit / remove) and text label.\n * @private\n * @param {Highcharts.Chart} - chart\n * @param {Highcharts.AnnotationsOptions} - options\n * @param {Function} - on click callback\n */\n function addToolbar(chart, options, callback) {\n const lang = this.lang, popupDiv = this.container, showForm = this.showForm, toolbarClass = 'highcharts-annotation-toolbar';\n // set small size\n if (popupDiv.className.indexOf(toolbarClass) === -1) {\n popupDiv.className += ' ' + toolbarClass;\n }\n // set position\n if (chart) {\n popupDiv.style.top = chart.plotTop + 10 + 'px';\n }\n // create label\n createElement('span', void 0, void 0, popupDiv).appendChild(doc.createTextNode(pick(\n // Advanced annotations:\n lang[options.langKey] || options.langKey, \n // Basic shapes:\n options.shapes && options.shapes[0].type, '')));\n // add buttons\n let button = this.addButton(popupDiv, lang.removeButton || 'Remove', 'remove', popupDiv, callback);\n button.className += ' highcharts-annotation-remove-button';\n button.style['background-image'] = 'url(' +\n this.iconsURL + 'destroy.svg)';\n button = this.addButton(popupDiv, lang.editButton || 'Edit', 'edit', popupDiv, () => {\n showForm.call(this, 'annotation-edit', chart, options, callback);\n });\n button.className += ' highcharts-annotation-edit-button';\n button.style['background-image'] = 'url(' +\n this.iconsURL + 'edit.svg)';\n }\n /**\n * Create annotation's form fields.\n * @private\n * @param {Highcharts.HTMLDOMElement} parentDiv\n * Div where inputs are placed\n * @param {Highcharts.Chart} chart\n * Chart\n * @param {string} parentNode\n * Name of parent to create chain of names\n * @param {Highcharts.AnnotationsOptions} options\n * Options\n * @param {Array} storage\n * Array where all items are stored\n * @param {boolean} [isRoot]\n * Recursive flag for root\n */\n function addFormFields(parentDiv, chart, parentNode, options, storage, isRoot) {\n if (!chart) {\n return;\n }\n const addInput = this.addInput, lang = this.lang;\n let parentFullName, titleName;\n objectEach(options, (value, option) => {\n // create name like params.styles.fontSize\n parentFullName = parentNode !== '' ? parentNode + '.' + option : option;\n if (isObject(value)) {\n if (\n // value is object of options\n !isArray(value) ||\n // array of objects with params. i.e labels in Fibonacci\n (isArray(value) && isObject(value[0]))) {\n titleName = lang[option] || option;\n if (!titleName.match(/\\d/g)) {\n storage.push([\n true,\n titleName,\n parentDiv\n ]);\n }\n addFormFields.call(this, parentDiv, chart, parentFullName, value, storage, false);\n }\n else {\n storage.push([\n this,\n parentFullName,\n 'annotation',\n parentDiv,\n value\n ]);\n }\n }\n });\n if (isRoot) {\n stableSort(storage, (a) => (a[1].match(/format/g) ? -1 : 1));\n if (isFirefox) {\n storage.reverse(); // (#14691)\n }\n storage.forEach((genInput) => {\n if (genInput[0] === true) {\n createElement('span', {\n className: 'highcharts-annotation-title'\n }, void 0, genInput[2]).appendChild(doc.createTextNode(genInput[1]));\n }\n else {\n genInput[4] = {\n value: genInput[4][0],\n type: genInput[4][1]\n };\n addInput.apply(genInput[0], genInput.splice(1));\n }\n });\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const PopupAnnotations = {\n addForm,\n addToolbar\n };\n\n return PopupAnnotations;\n });\n _registerModule(_modules, 'Extensions/Annotations/Popup/PopupIndicators.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Globals.js'], _modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (AST, H, NU, SeriesRegistry, U) {\n /* *\n *\n * Popup generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { doc } = H;\n const { annotationsFieldsTypes } = NU;\n const { seriesTypes } = SeriesRegistry;\n const { addEvent, createElement, defined, isArray, isObject, objectEach, stableSort } = U;\n /* *\n *\n * Enums\n *\n * */\n /**\n * Enum for properties which should have dropdown list.\n * @private\n */\n var DropdownProperties;\n (function (DropdownProperties) {\n DropdownProperties[DropdownProperties[\"params.algorithm\"] = 0] = \"params.algorithm\";\n DropdownProperties[DropdownProperties[\"params.average\"] = 1] = \"params.average\";\n })(DropdownProperties || (DropdownProperties = {}));\n /**\n * List of available algorithms for the specific indicator.\n * @private\n */\n const dropdownParameters = {\n 'algorithm-pivotpoints': ['standard', 'fibonacci', 'camarilla'],\n 'average-disparityindex': ['sma', 'ema', 'dema', 'tema', 'wma']\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create two columns (divs) in HTML.\n * @private\n * @param {Highcharts.HTMLDOMElement} container\n * Container of columns\n * @return {Highcharts.Dictionary}\n * Reference to two HTML columns (lhsCol, rhsCol)\n */\n function addColsContainer(container) {\n // left column\n const lhsCol = createElement('div', {\n className: 'highcharts-popup-lhs-col'\n }, void 0, container);\n // right column\n const rhsCol = createElement('div', {\n className: 'highcharts-popup-rhs-col'\n }, void 0, container);\n // wrapper content\n createElement('div', {\n className: 'highcharts-popup-rhs-col-wrapper'\n }, void 0, rhsCol);\n return {\n lhsCol: lhsCol,\n rhsCol: rhsCol\n };\n }\n /**\n * Create indicator's form. It contains two tabs (ADD and EDIT) with\n * content.\n * @private\n */\n function addForm(chart, _options, callback) {\n const lang = this.lang;\n let buttonParentDiv;\n if (!chart) {\n return;\n }\n // add tabs\n this.tabs.init.call(this, chart);\n // get all tabs content divs\n const tabsContainers = this.container\n .querySelectorAll('.highcharts-tab-item-content');\n // ADD tab\n addColsContainer(tabsContainers[0]);\n addSearchBox.call(this, chart, tabsContainers[0]);\n addIndicatorList.call(this, chart, tabsContainers[0], 'add');\n buttonParentDiv = tabsContainers[0]\n .querySelectorAll('.highcharts-popup-rhs-col')[0];\n this.addButton(buttonParentDiv, lang.addButton || 'add', 'add', buttonParentDiv, callback);\n // EDIT tab\n addColsContainer(tabsContainers[1]);\n addIndicatorList.call(this, chart, tabsContainers[1], 'edit');\n buttonParentDiv = tabsContainers[1]\n .querySelectorAll('.highcharts-popup-rhs-col')[0];\n this.addButton(buttonParentDiv, lang.saveButton || 'save', 'edit', buttonParentDiv, callback);\n this.addButton(buttonParentDiv, lang.removeButton || 'remove', 'remove', buttonParentDiv, callback);\n }\n /**\n * Create typical inputs for chosen indicator. Fields are extracted from\n * defaultOptions (ADD mode) or current indicator (ADD mode). Two extra\n * fields are added:\n * - hidden input - contains indicator type (required for callback)\n * - select - list of series which can be linked with indicator\n * @private\n * @param {Highcharts.Chart} chart\n * Chart\n * @param {Highcharts.Series} series\n * Indicator\n * @param {string} seriesType\n * Indicator type like: sma, ema, etc.\n * @param {Highcharts.HTMLDOMElement} rhsColWrapper\n * Element where created HTML list is added\n */\n function addFormFields(chart, series, seriesType, rhsColWrapper) {\n const fields = series.params || series.options.params;\n // reset current content\n rhsColWrapper.innerHTML = AST.emptyHTML;\n // create title (indicator name in the right column)\n createElement('h3', {\n className: 'highcharts-indicator-title'\n }, void 0, rhsColWrapper).appendChild(doc.createTextNode(getNameType(series, seriesType).indicatorFullName));\n // input type\n createElement('input', {\n type: 'hidden',\n name: 'highcharts-type-' + seriesType,\n value: seriesType\n }, void 0, rhsColWrapper);\n // list all series with id\n listAllSeries.call(this, seriesType, 'series', chart, rhsColWrapper, series, series.linkedParent && series.linkedParent.options.id);\n if (fields.volumeSeriesID) {\n listAllSeries.call(this, seriesType, 'volume', chart, rhsColWrapper, series, series.linkedParent && fields.volumeSeriesID);\n }\n // add param fields\n addParamInputs.call(this, chart, 'params', fields, seriesType, rhsColWrapper);\n }\n /**\n * Create HTML list of all indicators (ADD mode) or added indicators\n * (EDIT mode).\n *\n * @private\n *\n * @param {Highcharts.AnnotationChart} chart\n * The chart object.\n *\n * @param {string} [optionName]\n * Name of the option into which selection is being added.\n *\n * @param {HTMLDOMElement} [parentDiv]\n * HTML parent element.\n *\n * @param {string} listType\n * Type of list depending on the selected bookmark.\n * Might be 'add' or 'edit'.\n *\n * @param {string|undefined} filter\n * Applied filter string from the input.\n * For the first iteration, it's an empty string.\n */\n function addIndicatorList(chart, parentDiv, listType, filter) {\n const popup = this, lang = popup.lang, lhsCol = parentDiv.querySelectorAll('.highcharts-popup-lhs-col')[0], rhsCol = parentDiv.querySelectorAll('.highcharts-popup-rhs-col')[0], isEdit = listType === 'edit', series = (isEdit ?\n chart.series : // EDIT mode\n chart.options.plotOptions || {} // ADD mode\n );\n if (!chart && series) {\n return;\n }\n let item, filteredSeriesArray = [];\n // Filter and sort the series.\n if (!isEdit && !isArray(series)) {\n // Apply filters only for the 'add' indicator list.\n filteredSeriesArray = filterSeries.call(this, series, filter);\n }\n else if (isArray(series)) {\n filteredSeriesArray = filterSeriesArray.call(this, series);\n }\n // Sort indicators alphabeticaly.\n stableSort(filteredSeriesArray, (a, b) => {\n const seriesAName = a.indicatorFullName.toLowerCase(), seriesBName = b.indicatorFullName.toLowerCase();\n return (seriesAName < seriesBName) ?\n -1 : (seriesAName > seriesBName) ? 1 : 0;\n });\n // If the list exists remove it from the DOM\n // in order to create a new one with different filters.\n if (lhsCol.children[1]) {\n lhsCol.children[1].remove();\n }\n // Create wrapper for list.\n const indicatorList = createElement('ul', {\n className: 'highcharts-indicator-list'\n }, void 0, lhsCol);\n const rhsColWrapper = rhsCol.querySelectorAll('.highcharts-popup-rhs-col-wrapper')[0];\n filteredSeriesArray.forEach((seriesSet) => {\n const { indicatorFullName, indicatorType, series } = seriesSet;\n item = createElement('li', {\n className: 'highcharts-indicator-list'\n }, void 0, indicatorList);\n item.appendChild(doc.createTextNode(indicatorFullName));\n ['click', 'touchstart'].forEach((eventName) => {\n addEvent(item, eventName, function () {\n const button = rhsColWrapper.parentNode\n .children[1];\n addFormFields.call(popup, chart, series, indicatorType, rhsColWrapper);\n if (button) {\n button.style.display = 'block';\n }\n // add hidden input with series.id\n if (isEdit && series.options) {\n createElement('input', {\n type: 'hidden',\n name: 'highcharts-id-' + indicatorType,\n value: series.options.id\n }, void 0, rhsColWrapper).setAttribute('highcharts-data-series-id', series.options.id);\n }\n });\n });\n });\n // select first item from the list\n if (indicatorList.childNodes.length > 0) {\n indicatorList.childNodes[0].click();\n }\n else if (!isEdit) {\n AST.setElementHTML(rhsColWrapper.parentNode.children[0], lang.noFilterMatch || '');\n rhsColWrapper.parentNode.children[1]\n .style.display = 'none';\n }\n }\n /**\n * Recurent function which lists all fields, from params object and\n * create them as inputs. Each input has unique `data-name` attribute,\n * which keeps chain of fields i.e params.styles.fontSize.\n * @private\n * @param {Highcharts.Chart} chart\n * Chart\n * @param {string} parentNode\n * Name of parent to create chain of names\n * @param {Highcharts.PopupFieldsDictionary} fields\n * Params which are based for input create\n * @param {string} type\n * Indicator type like: sma, ema, etc.\n * @param {Highcharts.HTMLDOMElement} parentDiv\n * Element where created HTML list is added\n */\n function addParamInputs(chart, parentNode, fields, type, parentDiv) {\n if (!chart) {\n return;\n }\n const addInput = this.addInput;\n objectEach(fields, (value, fieldName) => {\n const predefinedType = annotationsFieldsTypes[fieldName];\n let fieldType = type;\n if (predefinedType) {\n fieldType = predefinedType;\n }\n // create name like params.styles.fontSize\n const parentFullName = parentNode + '.' + fieldName;\n if (defined(value) && // skip if field is unnecessary, #15362\n parentFullName) {\n if (isObject(value)) {\n // (15733) 'Periods' has an arrayed value. Label must be\n // created here.\n addInput.call(this, parentFullName, type, parentDiv, {});\n addParamInputs.call(this, chart, parentFullName, value, type, parentDiv);\n }\n // If the option is listed in dropdown enum,\n // add the selection box for it.\n if (parentFullName in DropdownProperties) {\n // Add selection boxes.\n const selectBox = addSelection.call(this, type, parentFullName, parentDiv);\n // Add possible dropdown options.\n addSelectionOptions.call(this, chart, parentNode, selectBox, type, fieldName, value);\n }\n else if (\n // Skip volume field which is created by addFormFields.\n parentFullName !== 'params.volumeSeriesID' &&\n !isArray(value) // Skip params declared in array.\n ) {\n addInput.call(this, parentFullName, type, parentDiv, {\n value: value,\n type: 'number'\n } // all inputs are text type\n );\n }\n }\n });\n }\n /**\n * Add searchbox HTML element and its' label.\n *\n * @private\n *\n * @param {Highcharts.AnnotationChart} chart\n * The chart object.\n *\n * @param {HTMLDOMElement} parentDiv\n * HTML parent element.\n */\n function addSearchBox(chart, parentDiv) {\n const popup = this, lhsCol = parentDiv.querySelectorAll('.highcharts-popup-lhs-col')[0], options = 'searchIndicators', inputAttributes = {\n value: '',\n type: 'text',\n htmlFor: 'search-indicators',\n labelClassName: 'highcharts-input-search-indicators-label'\n }, clearFilterText = this.lang.clearFilter, inputWrapper = createElement('div', {\n className: 'highcharts-input-wrapper'\n }, void 0, lhsCol);\n const handleInputChange = function (inputText) {\n // Apply some filters.\n addIndicatorList.call(popup, chart, popup.container, 'add', inputText);\n };\n // Add input field with the label and button.\n const input = this.addInput(options, 'input', inputWrapper, inputAttributes), button = createElement('a', {\n textContent: clearFilterText\n }, void 0, inputWrapper);\n input.classList.add('highcharts-input-search-indicators');\n button.classList.add('clear-filter-button');\n // Add input change events.\n addEvent(input, 'input', function (e) {\n handleInputChange(this.value);\n // Show clear filter button.\n if (this.value.length) {\n button.style.display = 'inline-block';\n }\n else {\n button.style.display = 'none';\n }\n });\n // Add clear filter click event.\n ['click', 'touchstart'].forEach((eventName) => {\n addEvent(button, eventName, function () {\n // Clear the input.\n input.value = '';\n handleInputChange('');\n // Hide clear filter button- no longer nececary.\n button.style.display = 'none';\n });\n });\n }\n /**\n * Add selection HTML element and its' label.\n *\n * @private\n *\n * @param {string} indicatorType\n * Type of the indicator i.e. sma, ema...\n *\n * @param {string} [optionName]\n * Name of the option into which selection is being added.\n *\n * @param {HTMLDOMElement} [parentDiv]\n * HTML parent element.\n */\n function addSelection(indicatorType, optionName, parentDiv) {\n const optionParamList = optionName.split('.'), labelText = optionParamList[optionParamList.length - 1], selectName = 'highcharts-' + optionName + '-type-' + indicatorType, lang = this.lang;\n // Add a label for the selection box.\n createElement('label', {\n htmlFor: selectName\n }, null, parentDiv).appendChild(doc.createTextNode(lang[labelText] || optionName));\n // Create a selection box.\n const selectBox = createElement('select', {\n name: selectName,\n className: 'highcharts-popup-field',\n id: 'highcharts-select-' + optionName\n }, null, parentDiv);\n selectBox.setAttribute('id', 'highcharts-select-' + optionName);\n return selectBox;\n }\n /**\n * Get and add selection options.\n *\n * @private\n *\n * @param {Highcharts.AnnotationChart} chart\n * The chart object.\n *\n * @param {string} [optionName]\n * Name of the option into which selection is being added.\n *\n * @param {HTMLSelectElement} [selectBox]\n * HTML select box element to which the options are being added.\n *\n * @param {string|undefined} indicatorType\n * Type of the indicator i.e. sma, ema...\n *\n * @param {string|undefined} parameterName\n * Name of the parameter which should be applied.\n *\n * @param {string|undefined} selectedOption\n * Default value in dropdown.\n */\n function addSelectionOptions(chart, optionName, selectBox, indicatorType, parameterName, selectedOption, currentSeries) {\n // Get and apply selection options for the possible series.\n if (optionName === 'series' || optionName === 'volume') {\n // List all series which have id - mandatory for indicator.\n chart.series.forEach((series) => {\n const seriesOptions = series.options, seriesName = seriesOptions.name ||\n seriesOptions.params ?\n series.name :\n seriesOptions.id || '';\n if (seriesOptions.id !== 'highcharts-navigator-series' &&\n seriesOptions.id !== (currentSeries &&\n currentSeries.options &&\n currentSeries.options.id)) {\n if (!defined(selectedOption) &&\n optionName === 'volume' &&\n series.type === 'column') {\n selectedOption = seriesOptions.id;\n }\n createElement('option', {\n value: seriesOptions.id\n }, void 0, selectBox).appendChild(doc.createTextNode(seriesName));\n }\n });\n }\n else if (indicatorType && parameterName) {\n // Get and apply options for the possible parameters.\n const dropdownKey = parameterName + '-' + indicatorType, parameterOption = dropdownParameters[dropdownKey];\n parameterOption.forEach((element) => {\n createElement('option', {\n value: element\n }, void 0, selectBox).appendChild(doc.createTextNode(element));\n });\n }\n // Add the default dropdown value if defined.\n if (defined(selectedOption)) {\n selectBox.value = selectedOption;\n }\n }\n /**\n * Filter object of series which are not indicators.\n * If the filter string exists, check against it.\n *\n * @private\n *\n * @param {Highcharts.FilteredSeries} series\n * All series are available in the plotOptions.\n *\n * @param {string|undefined} filter\n * Applied filter string from the input.\n * For the first iteration, it's an empty string.\n *\n * @return {Array} filteredSeriesArray\n * Returns array of filtered series based on filter string.\n */\n function filterSeries(series, filter) {\n const popup = this, indicators = popup.indicators, lang = popup.chart && popup.chart.options.lang, indicatorAliases = lang &&\n lang.navigation &&\n lang.navigation.popup &&\n lang.navigation.popup.indicatorAliases, filteredSeriesArray = [];\n let filteredSeries;\n objectEach(series, (series, value) => {\n const seriesOptions = series && series.options;\n // Allow only indicators.\n if (series.params || seriesOptions &&\n seriesOptions.params) {\n const { indicatorFullName, indicatorType } = getNameType(series, value);\n if (filter) {\n // Replace invalid characters.\n const validFilter = filter.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n const regex = new RegExp(validFilter, 'i'), alias = indicatorAliases &&\n indicatorAliases[indicatorType] &&\n indicatorAliases[indicatorType].join(' ') || '';\n if (indicatorFullName.match(regex) ||\n alias.match(regex)) {\n filteredSeries = {\n indicatorFullName,\n indicatorType,\n series: series\n };\n filteredSeriesArray.push(filteredSeries);\n }\n }\n else {\n filteredSeries = {\n indicatorFullName,\n indicatorType,\n series: series\n };\n filteredSeriesArray.push(filteredSeries);\n }\n }\n });\n return filteredSeriesArray;\n }\n /**\n * Filter an array of series and map its names and types.\n *\n * @private\n *\n * @param {Highcharts.FilteredSeries} series\n * All series that are available in the plotOptions.\n *\n * @return {Array} filteredSeriesArray\n * Returns array of filtered series based on filter string.\n */\n function filterSeriesArray(series) {\n const filteredSeriesArray = [];\n // Allow only indicators.\n series.forEach((series) => {\n if (series.is('sma')) {\n filteredSeriesArray.push({\n indicatorFullName: series.name,\n indicatorType: series.type,\n series: series\n });\n }\n });\n return filteredSeriesArray;\n }\n /**\n * Get amount of indicators added to chart.\n * @private\n * @return {number} - Amount of indicators\n */\n function getAmount() {\n let counter = 0;\n this.series.forEach((serie) => {\n if (serie.params ||\n serie.options.params) {\n counter++;\n }\n });\n return counter;\n }\n /**\n * Extract full name and type of requested indicator.\n *\n * @private\n *\n * @param {Highcharts.Series} series\n * Series which name is needed(EDITmode - defaultOptions.series,\n * ADDmode - indicator series).\n *\n * @param {string} [indicatorType]\n * Type of the indicator i.e. sma, ema...\n *\n * @return {Highcharts.Dictionary}\n * Full name and series type.\n */\n function getNameType(series, indicatorType) {\n const options = series.options;\n // add mode\n let seriesName = (seriesTypes[indicatorType] &&\n seriesTypes[indicatorType].prototype.nameBase) ||\n indicatorType.toUpperCase(), seriesType = indicatorType;\n // edit\n if (options && options.type) {\n seriesType = series.options.type;\n seriesName = series.name;\n }\n return {\n indicatorFullName: seriesName,\n indicatorType: seriesType\n };\n }\n /**\n * Create the selection box for the series,\n * add options and apply the default one.\n *\n * @private\n *\n * @param {string} indicatorType\n * Type of the indicator i.e. sma, ema...\n *\n * @param {string} [optionName]\n * Name of the option into which selection is being added.\n *\n * @param {Highcharts.AnnotationChart} chart\n * The chart object.\n *\n * @param {HTMLDOMElement} [parentDiv]\n * HTML parent element.\n *\n * @param {string|undefined} selectedOption\n * Default value in dropdown.\n */\n function listAllSeries(indicatorType, optionName, chart, parentDiv, currentSeries, selectedOption) {\n const popup = this, indicators = popup.indicators;\n // Won't work without the chart.\n if (!chart) {\n return;\n }\n // Add selection boxes.\n const selectBox = addSelection.call(popup, indicatorType, optionName, parentDiv);\n // Add possible dropdown options.\n addSelectionOptions.call(popup, chart, optionName, selectBox, void 0, void 0, void 0, currentSeries);\n // Add the default dropdown value if defined.\n if (defined(selectedOption)) {\n selectBox.value = selectedOption;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const PopupIndicators = {\n addForm,\n getAmount\n };\n\n return PopupIndicators;\n });\n _registerModule(_modules, 'Extensions/Annotations/Popup/PopupTabs.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * Popup generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { doc } = H;\n const { addEvent, createElement } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create tab content\n * @private\n * @return {HTMLDOMElement} - created HTML tab-content element\n */\n function addContentItem() {\n const popupDiv = this.container;\n return createElement('div', {\n // #12100\n className: 'highcharts-tab-item-content highcharts-no-mousewheel'\n }, void 0, popupDiv);\n }\n /**\n * Create tab menu item\n * @private\n * @param {string} tabName\n * `add` or `edit`\n * @param {number} [disableTab]\n * Disable tab when 0\n * @return {Highcharts.HTMLDOMElement}\n * Created HTML tab-menu element\n */\n function addMenuItem(tabName, disableTab) {\n const popupDiv = this.container, lang = this.lang;\n let className = 'highcharts-tab-item';\n if (disableTab === 0) {\n className += ' highcharts-tab-disabled';\n }\n // tab 1\n const menuItem = createElement('span', {\n className\n }, void 0, popupDiv);\n menuItem.appendChild(doc.createTextNode(lang[tabName + 'Button'] || tabName));\n menuItem.setAttribute('highcharts-data-tab-type', tabName);\n return menuItem;\n }\n /**\n * Set all tabs as invisible.\n * @private\n */\n function deselectAll() {\n const popupDiv = this.container, tabs = popupDiv\n .querySelectorAll('.highcharts-tab-item'), tabsContent = popupDiv\n .querySelectorAll('.highcharts-tab-item-content');\n for (let i = 0; i < tabs.length; i++) {\n tabs[i].classList.remove('highcharts-tab-item-active');\n tabsContent[i].classList.remove('highcharts-tab-item-show');\n }\n }\n /**\n * Init tabs. Create tab menu items, tabs containers\n * @private\n * @param {Highcharts.Chart} chart\n * Reference to current chart\n */\n function init(chart) {\n if (!chart) {\n return;\n }\n const indicatorsCount = this.indicators.getAmount.call(chart);\n // create menu items\n const firstTab = addMenuItem.call(this, 'add'); // run by default\n addMenuItem.call(this, 'edit', indicatorsCount);\n // create tabs containers\n addContentItem.call(this);\n addContentItem.call(this);\n switchTabs.call(this, indicatorsCount);\n // activate first tab\n selectTab.call(this, firstTab, 0);\n }\n /**\n * Set tab as visible\n * @private\n * @param {globals.Element} - current tab\n * @param {number} - Index of tab in menu\n */\n function selectTab(tab, index) {\n const allTabs = this.container\n .querySelectorAll('.highcharts-tab-item-content');\n tab.className += ' highcharts-tab-item-active';\n allTabs[index].className += ' highcharts-tab-item-show';\n }\n /**\n * Add click event to each tab\n * @private\n * @param {number} disableTab\n * Disable tab when 0\n */\n function switchTabs(disableTab) {\n const popup = this, popupDiv = this.container, tabs = popupDiv.querySelectorAll('.highcharts-tab-item');\n tabs.forEach((tab, i) => {\n if (disableTab === 0 &&\n tab.getAttribute('highcharts-data-tab-type') === 'edit') {\n return;\n }\n ['click', 'touchstart'].forEach((eventName) => {\n addEvent(tab, eventName, function () {\n // reset class on other elements\n deselectAll.call(popup);\n selectTab.call(popup, this, i);\n });\n });\n });\n }\n /* *\n *\n * Default Export\n *\n * */\n const PopupTabs = {\n init\n };\n\n return PopupTabs;\n });\n _registerModule(_modules, 'Extensions/Annotations/Popup/Popup.js', [_modules['Shared/BaseForm.js'], _modules['Core/Globals.js'], _modules['Core/Defaults.js'], _modules['Extensions/Annotations/Popup/PopupAnnotations.js'], _modules['Extensions/Annotations/Popup/PopupIndicators.js'], _modules['Extensions/Annotations/Popup/PopupTabs.js'], _modules['Core/Utilities.js']], function (BaseForm, H, D, PopupAnnotations, PopupIndicators, PopupTabs, U) {\n /* *\n *\n * Popup generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { doc } = H;\n const { getOptions } = D;\n const { addEvent, createElement, extend, fireEvent, pick } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get values from all inputs and selections then create JSON.\n *\n * @private\n *\n * @param {Highcharts.HTMLDOMElement} parentDiv\n * The container where inputs and selections are created.\n *\n * @param {string} type\n * Type of the popup bookmark (add|edit|remove).\n */\n function getFields(parentDiv, type) {\n const inputList = Array.prototype.slice.call(parentDiv.querySelectorAll('input')), selectList = Array.prototype.slice.call(parentDiv.querySelectorAll('select')), optionSeries = '#highcharts-select-series > option:checked', optionVolume = '#highcharts-select-volume > option:checked', linkedTo = parentDiv.querySelectorAll(optionSeries)[0], volumeTo = parentDiv.querySelectorAll(optionVolume)[0];\n const fieldsOutput = {\n actionType: type,\n linkedTo: linkedTo && linkedTo.getAttribute('value') || '',\n fields: {}\n };\n inputList.forEach((input) => {\n const param = input.getAttribute('highcharts-data-name'), seriesId = input.getAttribute('highcharts-data-series-id');\n // params\n if (seriesId) {\n fieldsOutput.seriesId = input.value;\n }\n else if (param) {\n fieldsOutput.fields[param] = input.value;\n }\n else {\n // type like sma / ema\n fieldsOutput.type = input.value;\n }\n });\n selectList.forEach((select) => {\n const id = select.id;\n // Get inputs only for the parameters, not for series and volume.\n if (id !== 'highcharts-select-series' &&\n id !== 'highcharts-select-volume') {\n const parameter = id.split('highcharts-select-')[1];\n fieldsOutput.fields[parameter] = select.value;\n }\n });\n if (volumeTo) {\n fieldsOutput.fields['params.volumeSeriesID'] = volumeTo\n .getAttribute('value') || '';\n }\n return fieldsOutput;\n }\n /* *\n *\n * Class\n *\n * */\n class Popup extends BaseForm {\n /* *\n *\n * Constructor\n *\n * */\n constructor(parentDiv, iconsURL, chart) {\n super(parentDiv, iconsURL);\n this.chart = chart;\n this.lang = getOptions().lang.navigation.popup;\n addEvent(this.container, 'mousedown', () => {\n const activeAnnotation = chart &&\n chart.navigationBindings &&\n chart.navigationBindings.activeAnnotation;\n if (activeAnnotation) {\n activeAnnotation.cancelClick = true;\n const unbind = addEvent(doc, 'click', () => {\n setTimeout(() => {\n activeAnnotation.cancelClick = false;\n }, 0);\n unbind();\n });\n }\n });\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Create input with label.\n *\n * @private\n *\n * @param {string} option\n * Chain of fields i.e params.styles.fontSize separeted by the dot.\n *\n * @param {string} indicatorType\n * Type of the indicator i.e. sma, ema...\n *\n * @param {HTMLDOMElement} parentDiv\n * HTML parent element.\n *\n * @param {Highcharts.InputAttributes} inputAttributes\n * Attributes of the input.\n *\n * @return {HTMLInputElement}\n * Return created input element.\n */\n addInput(option, indicatorType, parentDiv, inputAttributes) {\n const optionParamList = option.split('.'), optionName = optionParamList[optionParamList.length - 1], lang = this.lang, inputName = 'highcharts-' + indicatorType + '-' + pick(inputAttributes.htmlFor, optionName);\n if (!optionName.match(/^\\d+$/)) {\n // add label\n createElement('label', {\n htmlFor: inputName,\n className: inputAttributes.labelClassName\n }, void 0, parentDiv).appendChild(doc.createTextNode(lang[optionName] || optionName));\n }\n // add input\n const input = createElement('input', {\n name: inputName,\n value: inputAttributes.value,\n type: inputAttributes.type,\n className: 'highcharts-popup-field'\n }, void 0, parentDiv);\n input.setAttribute('highcharts-data-name', option);\n return input;\n }\n closeButtonEvents() {\n if (this.chart) {\n const navigationBindings = this.chart.navigationBindings;\n fireEvent(navigationBindings, 'closePopup');\n if (navigationBindings &&\n navigationBindings.selectedButtonElement) {\n fireEvent(navigationBindings, 'deselectButton', { button: navigationBindings.selectedButtonElement });\n }\n }\n else {\n super.closeButtonEvents();\n }\n }\n /**\n * Create button.\n * @private\n * @param {Highcharts.HTMLDOMElement} parentDiv\n * Container where elements should be added\n * @param {string} label\n * Text placed as button label\n * @param {string} type\n * add | edit | remove\n * @param {Function} callback\n * On click callback\n * @param {Highcharts.HTMLDOMElement} fieldsDiv\n * Container where inputs are generated\n * @return {Highcharts.HTMLDOMElement}\n * HTML button\n */\n addButton(parentDiv, label, type, fieldsDiv, callback) {\n const button = createElement('button', void 0, void 0, parentDiv);\n button.appendChild(doc.createTextNode(label));\n if (callback) {\n ['click', 'touchstart'].forEach((eventName) => {\n addEvent(button, eventName, () => {\n this.closePopup();\n return callback(getFields(fieldsDiv, type));\n });\n });\n }\n return button;\n }\n /**\n * Create content and show popup.\n * @private\n * @param {string} - type of popup i.e indicators\n * @param {Highcharts.Chart} - chart\n * @param {Highcharts.AnnotationsOptions} - options\n * @param {Function} - on click callback\n */\n showForm(type, chart, options, callback) {\n if (!chart) {\n return;\n }\n // show blank popup\n this.showPopup();\n // indicator form\n if (type === 'indicators') {\n this.indicators.addForm.call(this, chart, options, callback);\n }\n // annotation small toolbar\n if (type === 'annotation-toolbar') {\n this.annotations.addToolbar.call(this, chart, options, callback);\n }\n // annotation edit form\n if (type === 'annotation-edit') {\n this.annotations.addForm.call(this, chart, options, callback);\n }\n // flags form - add / edit\n if (type === 'flag') {\n this.annotations.addForm.call(this, chart, options, callback, true);\n }\n this.type = type;\n // Explicit height is needed to make inner elements scrollable\n this.container.style.height = this.container.offsetHeight + 'px';\n }\n }\n extend(Popup.prototype, {\n annotations: PopupAnnotations,\n indicators: PopupIndicators,\n tabs: PopupTabs\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return Popup;\n });\n _registerModule(_modules, 'Extensions/Annotations/Popup/PopupComposition.js', [_modules['Extensions/Annotations/Popup/Popup.js'], _modules['Core/Utilities.js']], function (Popup, U) {\n /* *\n *\n * Popup generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, wrap } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(NagivationBindingsClass, PointerClass) {\n if (U.pushUnique(composedMembers, NagivationBindingsClass)) {\n addEvent(NagivationBindingsClass, 'closePopup', onNavigationBindingsClosePopup);\n addEvent(NagivationBindingsClass, 'showPopup', onNavigationBindingsShowPopup);\n }\n if (U.pushUnique(composedMembers, PointerClass)) {\n wrap(PointerClass.prototype, 'onContainerMouseDown', wrapPointerOnContainerMouserDown);\n }\n }\n /**\n * @private\n */\n function onNavigationBindingsClosePopup() {\n if (this.popup) {\n this.popup.closePopup();\n }\n }\n /**\n * @private\n */\n function onNavigationBindingsShowPopup(config) {\n if (!this.popup) {\n // Add popup to main container\n this.popup = new Popup(this.chart.container, (this.chart.options.navigation.iconsURL ||\n (this.chart.options.stockTools &&\n this.chart.options.stockTools.gui.iconsURL) ||\n 'https://code.highcharts.com/11.1.0/gfx/stock-icons/'), this.chart);\n }\n this.popup.showForm(config.formType, this.chart, config.options, config.onSubmit);\n }\n /**\n * onContainerMouseDown blocks internal popup events, due to e.preventDefault.\n * Related issue #4606\n * @private\n */\n function wrapPointerOnContainerMouserDown(proceed, e) {\n // elements is not in popup\n if (!this.inClass(e.target, 'highcharts-popup')) {\n proceed.apply(this, Array.prototype.slice.call(arguments, 1));\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const PopupComposition = {\n compose\n };\n\n return PopupComposition;\n });\n _registerModule(_modules, 'Extensions/Annotations/Annotation.js', [_modules['Core/Animation/AnimationUtilities.js'], _modules['Extensions/Annotations/AnnotationChart.js'], _modules['Extensions/Annotations/AnnotationDefaults.js'], _modules['Extensions/Annotations/Controllables/ControllableRect.js'], _modules['Extensions/Annotations/Controllables/ControllableCircle.js'], _modules['Extensions/Annotations/Controllables/ControllableEllipse.js'], _modules['Extensions/Annotations/Controllables/ControllablePath.js'], _modules['Extensions/Annotations/Controllables/ControllableImage.js'], _modules['Extensions/Annotations/Controllables/ControllableLabel.js'], _modules['Extensions/Annotations/ControlPoint.js'], _modules['Extensions/Annotations/ControlTarget.js'], _modules['Extensions/Annotations/EventEmitter.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Extensions/Annotations/NavigationBindings.js'], _modules['Extensions/Annotations/Popup/PopupComposition.js'], _modules['Core/Utilities.js']], function (A, AnnotationChart, AnnotationDefaults, ControllableRect, ControllableCircle, ControllableEllipse, ControllablePath, ControllableImage, ControllableLabel, ControlPoint, ControlTarget, EventEmitter, MockPoint, NavigationBindings, PopupComposition, U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getDeferredAnimation } = A;\n const { destroyObjectProperties, erase, fireEvent, merge, pick, splat } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Hide or show annotaiton attached to points.\n * @private\n */\n function adjustVisibility(item) {\n const label = item.graphic, hasVisiblePoints = item.points.some((point) => (point.series.visible !== false &&\n point.visible !== false));\n if (label) {\n if (!hasVisiblePoints) {\n label.hide();\n }\n else if (label.visibility === 'hidden') {\n label.show();\n }\n }\n }\n /**\n * @private\n */\n function getLabelsAndShapesOptions(baseOptions, newOptions) {\n const mergedOptions = {};\n ['labels', 'shapes'].forEach((name) => {\n const someBaseOptions = baseOptions[name];\n if (someBaseOptions) {\n if (newOptions[name]) {\n mergedOptions[name] = splat(newOptions[name]).map(function (basicOptions, i) {\n return merge(someBaseOptions[i], basicOptions);\n });\n }\n else {\n mergedOptions[name] = baseOptions[name];\n }\n }\n });\n return mergedOptions;\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * An annotation class which serves as a container for items like labels or\n * shapes. Created items are positioned on the chart either by linking them to\n * existing points or created mock points\n *\n * @class\n * @name Highcharts.Annotation\n *\n * @param {Highcharts.Chart} chart\n * A chart instance\n * @param {Highcharts.AnnotationsOptions} userOptions\n * The annotation options\n */\n class Annotation extends EventEmitter {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n static compose(ChartClass, PointerClass, SVGRendererClass) {\n AnnotationChart.compose(Annotation, ChartClass, PointerClass);\n ControllableLabel.compose(SVGRendererClass);\n ControllablePath.compose(ChartClass, SVGRendererClass);\n NavigationBindings.compose(Annotation, ChartClass);\n PopupComposition.compose(NavigationBindings, PointerClass);\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart, userOptions) {\n super();\n this.coll = 'annotations';\n this.animationConfig = void 0;\n this.graphic = void 0;\n this.group = void 0;\n this.labelCollector = void 0;\n this.labelsGroup = void 0;\n this.shapesGroup = void 0;\n /**\n * The chart that the annotation belongs to.\n *\n * @name Highcharts.Annotation#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n /**\n * The array of points which defines the annotation.\n * @private\n * @name Highcharts.Annotation#points\n * @type {Array}\n */\n this.points = [];\n /**\n * The array of control points.\n * @private\n * @name Highcharts.Annotation#controlPoints\n * @type {Array}\n */\n this.controlPoints = [];\n this.coll = 'annotations';\n this.index = -1;\n /**\n * The array of labels which belong to the annotation.\n * @private\n * @name Highcharts.Annotation#labels\n * @type {Array}\n */\n this.labels = [];\n /**\n * The array of shapes which belong to the annotation.\n * @private\n * @name Highcharts.Annotation#shapes\n * @type {Array}\n */\n this.shapes = [];\n /**\n * The options for the annotations.\n *\n * @name Highcharts.Annotation#options\n * @type {Highcharts.AnnotationsOptions}\n */\n this.options = merge(this.defaultOptions, userOptions);\n /**\n * The user options for the annotations.\n *\n * @name Highcharts.Annotation#userOptions\n * @type {Highcharts.AnnotationsOptions}\n */\n this.userOptions = userOptions;\n // Handle labels and shapes - those are arrays\n // Merging does not work with arrays (stores reference)\n const labelsAndShapes = getLabelsAndShapesOptions(this.options, userOptions);\n this.options.labels = labelsAndShapes.labels;\n this.options.shapes = labelsAndShapes.shapes;\n /**\n * The callback that reports to the overlapping-labels module which\n * labels it should account for.\n * @private\n * @name Highcharts.Annotation#labelCollector\n * @type {Function}\n */\n /**\n * The group svg element.\n *\n * @name Highcharts.Annotation#group\n * @type {Highcharts.SVGElement}\n */\n /**\n * The group svg element of the annotation's shapes.\n *\n * @name Highcharts.Annotation#shapesGroup\n * @type {Highcharts.SVGElement}\n */\n /**\n * The group svg element of the annotation's labels.\n *\n * @name Highcharts.Annotation#labelsGroup\n * @type {Highcharts.SVGElement}\n */\n this.init(chart, this.options);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n addClipPaths() {\n this.setClipAxes();\n if (this.clipXAxis &&\n this.clipYAxis &&\n this.options.crop // #15399\n ) {\n this.clipRect = this.chart.renderer.clipRect(this.getClipBox());\n }\n }\n /**\n * @private\n */\n addLabels() {\n const labelsOptions = (this.options.labels || []);\n labelsOptions.forEach((labelOptions, i) => {\n const label = this.initLabel(labelOptions, i);\n merge(true, labelsOptions[i], label.options);\n });\n }\n /**\n * @private\n */\n addShapes() {\n const shapes = this.options.shapes || [];\n shapes.forEach((shapeOptions, i) => {\n const shape = this.initShape(shapeOptions, i);\n merge(true, shapes[i], shape.options);\n });\n }\n /**\n * Destroy the annotation. This function does not touch the chart\n * that the annotation belongs to (all annotations are kept in\n * the chart.annotations array) - it is recommended to use\n * {@link Highcharts.Chart#removeAnnotation} instead.\n * @private\n */\n destroy() {\n const chart = this.chart, destroyItem = function (item) {\n item.destroy();\n };\n this.labels.forEach(destroyItem);\n this.shapes.forEach(destroyItem);\n this.clipXAxis = null;\n this.clipYAxis = null;\n erase(chart.labelCollectors, this.labelCollector);\n super.destroy();\n this.destroyControlTarget();\n destroyObjectProperties(this, chart);\n }\n /**\n * Destroy a single item.\n * @private\n */\n destroyItem(item) {\n // erase from shapes or labels array\n erase(this[item.itemType + 's'], item);\n item.destroy();\n }\n /**\n * @private\n */\n getClipBox() {\n if (this.clipXAxis && this.clipYAxis) {\n return {\n x: this.clipXAxis.left,\n y: this.clipYAxis.top,\n width: this.clipXAxis.width,\n height: this.clipYAxis.height\n };\n }\n }\n /**\n * Initialize the annotation properties.\n * @private\n */\n initProperties(chart, userOptions) {\n this.setOptions(userOptions);\n const labelsAndShapes = getLabelsAndShapesOptions(this.options, userOptions);\n this.options.labels = labelsAndShapes.labels;\n this.options.shapes = labelsAndShapes.shapes;\n this.chart = chart;\n this.points = [];\n this.controlPoints = [];\n this.coll = 'annotations';\n this.userOptions = userOptions;\n this.labels = [];\n this.shapes = [];\n }\n /**\n * Initialize the annotation.\n * @private\n */\n init(_annotationOrChart, _userOptions, index = this.index) {\n const chart = this.chart, animOptions = this.options.animation;\n this.index = index;\n this.linkPoints();\n this.addControlPoints();\n this.addShapes();\n this.addLabels();\n this.setLabelCollector();\n this.animationConfig = getDeferredAnimation(chart, animOptions);\n }\n /**\n * Initialisation of a single label\n * @private\n */\n initLabel(labelOptions, index) {\n const options = merge(this.options.labelOptions, {\n controlPointOptions: this.options.controlPointOptions\n }, labelOptions), label = new ControllableLabel(this, options, index);\n label.itemType = 'label';\n this.labels.push(label);\n return label;\n }\n /**\n * Initialisation of a single shape\n * @private\n * @param {Object} shapeOptions\n * a confg object for a single shape\n * @param {number} index\n * annotation may have many shapes, this is the shape's index saved in\n * shapes.index.\n */\n initShape(shapeOptions, index) {\n const options = merge(this.options.shapeOptions, {\n controlPointOptions: this.options.controlPointOptions\n }, shapeOptions), shape = new (Annotation.shapesMap[options.type])(this, options, index);\n shape.itemType = 'shape';\n this.shapes.push(shape);\n return shape;\n }\n /**\n * @private\n */\n redraw(animation) {\n this.linkPoints();\n if (!this.graphic) {\n this.render();\n }\n if (this.clipRect) {\n this.clipRect.animate(this.getClipBox());\n }\n this.redrawItems(this.shapes, animation);\n this.redrawItems(this.labels, animation);\n this.redrawControlPoints(animation);\n }\n /**\n * Redraw a single item.\n * @private\n */\n redrawItem(item, animation) {\n item.linkPoints();\n if (!item.shouldBeDrawn()) {\n this.destroyItem(item);\n }\n else {\n if (!item.graphic) {\n this.renderItem(item);\n }\n item.redraw(pick(animation, true) && item.graphic.placed);\n if (item.points.length) {\n adjustVisibility(item);\n }\n }\n }\n /**\n * @private\n */\n redrawItems(items, animation) {\n let i = items.length;\n // needs a backward loop\n // labels/shapes array might be modified\n // due to destruction of the item\n while (i--) {\n this.redrawItem(items[i], animation);\n }\n }\n /**\n * See {@link Highcharts.Chart#removeAnnotation}.\n * @private\n */\n remove() {\n // Let chart.update() remove annoations on demand\n return this.chart.removeAnnotation(this);\n }\n /**\n * @private\n */\n render() {\n const renderer = this.chart.renderer;\n this.graphic = renderer\n .g('annotation')\n .attr({\n opacity: 0,\n zIndex: this.options.zIndex,\n visibility: this.options.visible ?\n 'inherit' :\n 'hidden'\n })\n .add();\n this.shapesGroup = renderer\n .g('annotation-shapes')\n .add(this.graphic);\n if (this.options.crop) { // #15399\n this.shapesGroup.clip(this.chart.plotBoxClip);\n }\n this.labelsGroup = renderer\n .g('annotation-labels')\n .attr({\n // hideOverlappingLabels requires translation\n translateX: 0,\n translateY: 0\n })\n .add(this.graphic);\n this.addClipPaths();\n if (this.clipRect) {\n this.graphic.clip(this.clipRect);\n }\n // Render shapes and labels before adding events (#13070).\n this.renderItems(this.shapes);\n this.renderItems(this.labels);\n this.addEvents();\n this.renderControlPoints();\n }\n /**\n * @private\n */\n renderItem(item) {\n item.render(item.itemType === 'label' ?\n this.labelsGroup :\n this.shapesGroup);\n }\n /**\n * @private\n */\n renderItems(items) {\n let i = items.length;\n while (i--) {\n this.renderItem(items[i]);\n }\n }\n /**\n * @private\n */\n setClipAxes() {\n const xAxes = this.chart.xAxis, yAxes = this.chart.yAxis, linkedAxes = (this.options.labels || [])\n .concat(this.options.shapes || [])\n .reduce((axes, labelOrShape) => {\n const point = labelOrShape &&\n (labelOrShape.point ||\n (labelOrShape.points && labelOrShape.points[0]));\n return [\n xAxes[point && point.xAxis] || axes[0],\n yAxes[point && point.yAxis] || axes[1]\n ];\n }, []);\n this.clipXAxis = linkedAxes[0];\n this.clipYAxis = linkedAxes[1];\n }\n /**\n * @private\n */\n setControlPointsVisibility(visible) {\n const setItemControlPointsVisibility = function (item) {\n item.setControlPointsVisibility(visible);\n };\n this.controlPoints.forEach((controlPoint) => {\n controlPoint.setVisibility(visible);\n });\n this.shapes.forEach(setItemControlPointsVisibility);\n this.labels.forEach(setItemControlPointsVisibility);\n }\n /**\n * @private\n */\n setLabelCollector() {\n const annotation = this;\n annotation.labelCollector = function () {\n return annotation.labels.reduce(function (labels, label) {\n if (!label.options.allowOverlap) {\n labels.push(label.graphic);\n }\n return labels;\n }, []);\n };\n annotation.chart.labelCollectors.push(annotation.labelCollector);\n }\n /**\n * Set an annotation options.\n * @private\n * @param {Highcharts.AnnotationsOptions} userOptions\n * User options for an annotation\n */\n setOptions(userOptions) {\n this.options = merge(this.defaultOptions, userOptions);\n }\n /**\n * Set the annotation's visibility.\n * @private\n * @param {boolean} [visible]\n * Whether to show or hide an annotation. If the param is omitted, the\n * annotation's visibility is toggled.\n */\n setVisibility(visible) {\n const options = this.options, navigation = this.chart.navigationBindings, visibility = pick(visible, !options.visible);\n this.graphic.attr('visibility', visibility ? 'inherit' : 'hidden');\n if (!visibility) {\n const setItemControlPointsVisibility = function (item) {\n item.setControlPointsVisibility(visibility);\n };\n this.shapes.forEach(setItemControlPointsVisibility);\n this.labels.forEach(setItemControlPointsVisibility);\n if (navigation.activeAnnotation === this &&\n navigation.popup &&\n navigation.popup.type === 'annotation-toolbar') {\n fireEvent(navigation, 'closePopup');\n }\n }\n options.visible = visibility;\n }\n /**\n * Updates an annotation.\n *\n * @function Highcharts.Annotation#update\n *\n * @param {Partial} userOptions\n * New user options for the annotation.\n *\n */\n update(userOptions, redraw) {\n const chart = this.chart, labelsAndShapes = getLabelsAndShapesOptions(this.userOptions, userOptions), userOptionsIndex = chart.annotations.indexOf(this), options = merge(true, this.userOptions, userOptions);\n options.labels = labelsAndShapes.labels;\n options.shapes = labelsAndShapes.shapes;\n this.destroy();\n this.initProperties(chart, options);\n this.init(chart, options);\n // Update options in chart options, used in exporting (#9767):\n chart.options.annotations[userOptionsIndex] = options;\n this.isUpdating = true;\n if (pick(redraw, true)) {\n chart.redraw();\n }\n fireEvent(this, 'afterUpdate');\n this.isUpdating = false;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * @private\n */\n Annotation.ControlPoint = ControlPoint;\n /**\n * @private\n */\n Annotation.MockPoint = MockPoint;\n /**\n * An object uses for mapping between a shape type and a constructor.\n * To add a new shape type extend this object with type name as a key\n * and a constructor as its value.\n */\n Annotation.shapesMap = {\n 'rect': ControllableRect,\n 'circle': ControllableCircle,\n 'ellipse': ControllableEllipse,\n 'path': ControllablePath,\n 'image': ControllableImage\n };\n /**\n * @private\n */\n Annotation.types = {};\n Annotation.prototype.defaultOptions = AnnotationDefaults;\n /**\n * List of events for `annotation.options.events` that should not be\n * added to `annotation.graphic` but to the `annotation`.\n *\n * @private\n * @type {Array}\n */\n Annotation.prototype.nonDOMEvents = ['add', 'afterUpdate', 'drag', 'remove'];\n ControlTarget.compose(Annotation);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Possible directions for draggable annotations. An empty string (`''`)\n * makes the annotation undraggable.\n *\n * @typedef {''|'x'|'xy'|'y'} Highcharts.AnnotationDraggableValue\n * @requires modules/annotations\n */\n /**\n * @private\n * @typedef {\n * Highcharts.AnnotationControllableCircle|\n * Highcharts.AnnotationControllableImage|\n * Highcharts.AnnotationControllablePath|\n * Highcharts.AnnotationControllableRect\n * } Highcharts.AnnotationShapeType\n * @requires modules/annotations\n */\n /**\n * @private\n * @typedef {\n * Highcharts.AnnotationControllableLabel\n * } Highcharts.AnnotationLabelType\n * @requires modules/annotations\n */\n /**\n * A point-like object, a mock point or a point used in series.\n * @private\n * @typedef {\n * Highcharts.AnnotationMockPoint|\n * Highcharts.Point\n * } Highcharts.AnnotationPointType\n * @requires modules/annotations\n */\n /**\n * Shape point as string, object or function.\n *\n * @typedef {\n * string|\n * Highcharts.AnnotationMockPointOptionsObject|\n * Highcharts.AnnotationMockPointFunction\n * } Highcharts.AnnotationShapePointOptions\n */\n (''); // keeps doclets above in JS file\n\n return Annotation;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/BasicAnnotation.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Annotation, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n class BasicAnnotation extends Annotation {\n /* *\n *\n * Functions\n *\n * */\n addControlPoints() {\n const options = this.options, controlPoints = BasicAnnotation.basicControlPoints, annotationType = this.basicType, optionsGroup = (options.labels ||\n options.shapes ||\n []);\n optionsGroup.forEach((group) => {\n group.controlPoints = controlPoints[annotationType];\n });\n }\n init() {\n const options = this.options;\n if (options.shapes) {\n delete options.labelOptions;\n const type = options.shapes[0].type;\n // The rectangle is rendered as a path, whereas other basic shapes\n // are rendered as their respecitve SVG shapes.\n if (type && type !== 'path') {\n this.basicType = type;\n }\n else {\n this.basicType = 'rectangle';\n }\n }\n else {\n delete options.shapes;\n this.basicType = 'label';\n }\n super.init.apply(this, arguments);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n BasicAnnotation.basicControlPoints = {\n label: [{\n symbol: 'triangle-down',\n positioner: function (target) {\n if (!target.graphic.placed) {\n return {\n x: 0,\n y: -9e7\n };\n }\n const xy = MockPoint\n .pointToPixels(target.points[0]);\n return {\n x: xy.x - this.graphic.width / 2,\n y: xy.y - this.graphic.height / 2\n };\n },\n // TRANSLATE POINT/ANCHOR\n events: {\n drag: function (e, target) {\n const xy = this.mouseMoveToTranslation(e);\n target.translatePoint(xy.x, xy.y);\n target.annotation.userOptions.labels[0].point =\n target.options.point;\n target.redraw(false);\n }\n }\n }, {\n symbol: 'square',\n positioner: function (target) {\n if (!target.graphic.placed) {\n return {\n x: 0,\n y: -9e7\n };\n }\n return {\n x: target.graphic.alignAttr.x -\n this.graphic.width / 2,\n y: target.graphic.alignAttr.y -\n this.graphic.height / 2\n };\n },\n // TRANSLATE POSITION WITHOUT CHANGING THE\n // ANCHOR\n events: {\n drag: function (e, target) {\n const xy = this.mouseMoveToTranslation(e);\n target.translate(xy.x, xy.y);\n target.annotation.userOptions.labels[0].point =\n target.options.point;\n target.redraw(false);\n }\n }\n }],\n rectangle: [{\n positioner: function (annotation) {\n const xy = MockPoint\n .pointToPixels(annotation.points[2]);\n return {\n x: xy.x - 4,\n y: xy.y - 4\n };\n },\n events: {\n drag: function (e, target) {\n var _a,\n _b;\n const annotation = target.annotation, coords = this.chart.pointer.getCoordinates(e), points = target.options.points, shapes = annotation.userOptions.shapes, xAxisIndex = ((_a = annotation.clipXAxis) === null || _a === void 0 ? void 0 : _a.index) || 0, yAxisIndex = ((_b = annotation.clipYAxis) === null || _b === void 0 ? void 0 : _b.index) || 0, x = coords.xAxis[xAxisIndex].value, y = coords.yAxis[yAxisIndex].value;\n // Top right point\n points[1].x = x;\n // Bottom right point (cursor position)\n points[2].x = x;\n points[2].y = y;\n // Bottom left\n points[3].y = y;\n if (shapes && shapes[0]) {\n shapes[0].points = target.options.points;\n }\n annotation.redraw(false);\n }\n }\n }],\n circle: [{\n positioner: function (target) {\n const xy = MockPoint.pointToPixels(target.points[0]), r = target.options.r;\n return {\n x: xy.x + r * Math.cos(Math.PI / 4) -\n this.graphic.width / 2,\n y: xy.y + r * Math.sin(Math.PI / 4) -\n this.graphic.height / 2\n };\n },\n events: {\n // TRANSFORM RADIUS ACCORDING TO Y\n // TRANSLATION\n drag: function (e, target) {\n const annotation = target.annotation, position = this.mouseMoveToTranslation(e), shapes = annotation.userOptions.shapes;\n target.setRadius(Math.max(target.options.r +\n position.y /\n Math.sin(Math.PI / 4), 5));\n if (shapes && shapes[0]) {\n shapes[0].r = target.options.r;\n shapes[0].point = target.options.point;\n }\n target.redraw(false);\n }\n }\n }],\n ellipse: [{\n positioner: function (target) {\n const position = target.getAbsolutePosition(target.points[0]);\n return {\n x: position.x - this.graphic.width / 2,\n y: position.y - this.graphic.height / 2\n };\n },\n events: {\n drag: function (e, target) {\n const position = target.getAbsolutePosition(target.points[0]);\n target.translatePoint(e.chartX - position.x, e.chartY - position.y, 0);\n target.redraw(false);\n }\n }\n }, {\n positioner: function (target) {\n const position = target.getAbsolutePosition(target.points[1]);\n return {\n x: position.x - this.graphic.width / 2,\n y: position.y - this.graphic.height / 2\n };\n },\n events: {\n drag: function (e, target) {\n const position = target.getAbsolutePosition(target.points[1]);\n target.translatePoint(e.chartX - position.x, e.chartY - position.y, 1);\n target.redraw(false);\n }\n }\n }, {\n positioner: function (target) {\n const position = target.getAbsolutePosition(target.points[0]), position2 = target.getAbsolutePosition(target.points[1]), attrs = target.getAttrs(position, position2);\n return {\n x: attrs.cx - this.graphic.width / 2 +\n attrs.ry * Math.sin((attrs.angle * Math.PI) / 180),\n y: attrs.cy - this.graphic.height / 2 -\n attrs.ry * Math.cos((attrs.angle * Math.PI) / 180)\n };\n },\n events: {\n drag: function (e, target) {\n const position = target.getAbsolutePosition(target.points[0]), position2 = target.getAbsolutePosition(target.points[1]), newR = target.getDistanceFromLine(position, position2, e.chartX, e.chartY), yAxis = target.getYAxis(), newRY = Math.abs(yAxis.toValue(0) - yAxis.toValue(newR));\n target.setYRadius(newRY);\n target.redraw(false);\n }\n }\n }]\n };\n BasicAnnotation.prototype.defaultOptions = merge(Annotation.prototype.defaultOptions, {});\n Annotation.types.basicAnnotation = BasicAnnotation;\n /* *\n *\n * Default Export\n *\n * */\n\n return BasicAnnotation;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/CrookedLine.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/ControlPoint.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Annotation, ControlPoint, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n class CrookedLine extends Annotation {\n /* *\n *\n * Functions\n *\n * */\n /**\n * Overrides default setter to get axes from typeOptions.\n * @private\n */\n setClipAxes() {\n this.clipXAxis = this.chart.xAxis[this.options.typeOptions.xAxis];\n this.clipYAxis = this.chart.yAxis[this.options.typeOptions.yAxis];\n }\n getPointsOptions() {\n const typeOptions = this.options.typeOptions;\n return (typeOptions.points || []).map((pointOptions) => {\n pointOptions.xAxis = typeOptions.xAxis;\n pointOptions.yAxis = typeOptions.yAxis;\n return pointOptions;\n });\n }\n getControlPointsOptions() {\n return this.getPointsOptions();\n }\n addControlPoints() {\n this.getControlPointsOptions().forEach(function (pointOptions, i) {\n const controlPoint = new ControlPoint(this.chart, this, merge(this.options.controlPointOptions, pointOptions.controlPoint), i);\n this.controlPoints.push(controlPoint);\n pointOptions.controlPoint = controlPoint.options;\n }, this);\n }\n addShapes() {\n const typeOptions = this.options.typeOptions, shape = this.initShape(merge(typeOptions.line, {\n type: 'path',\n points: this.points.map((_point, i) => (function (target) {\n return target.annotation.points[i];\n }))\n }), 0);\n typeOptions.line = shape.options;\n }\n }\n CrookedLine.prototype.defaultOptions = merge(Annotation.prototype.defaultOptions, \n /**\n * A crooked line annotation.\n *\n * @sample highcharts/annotations-advanced/crooked-line/\n * Crooked line\n *\n * @product highstock\n * @optionparent annotations.crookedLine\n */\n {\n /**\n * @extends annotations.labelOptions\n * @apioption annotations.crookedLine.labelOptions\n */\n /**\n * @extends annotations.shapeOptions\n * @apioption annotations.crookedLine.shapeOptions\n */\n /**\n * Additional options for an annotation with the type.\n */\n typeOptions: {\n /**\n * This number defines which xAxis the point is connected to.\n * It refers to either the axis id or the index of the axis\n * in the xAxis array.\n */\n xAxis: 0,\n /**\n * This number defines which yAxis the point is connected to.\n * It refers to either the axis id or the index of the axis\n * in the xAxis array.\n */\n yAxis: 0,\n /**\n * @type {Array<*>}\n * @apioption annotations.crookedLine.typeOptions.points\n */\n /**\n * The x position of the point.\n *\n * @type {number}\n * @apioption annotations.crookedLine.typeOptions.points.x\n */\n /**\n * The y position of the point.\n *\n * @type {number}\n * @apioption annotations.crookedLine.typeOptions.points.y\n */\n /**\n * @type {number}\n * @excluding positioner, events\n * @apioption annotations.crookedLine.typeOptions.points.controlPoint\n */\n /**\n * Line options.\n *\n * @excluding height, point, points, r, type, width\n */\n line: {\n fill: 'none'\n }\n },\n /**\n * @excluding positioner, events\n */\n controlPointOptions: {\n positioner: function (target) {\n const graphic = this.graphic, xy = MockPoint.pointToPixels(target.points[this.index]);\n return {\n x: xy.x - graphic.width / 2,\n y: xy.y - graphic.height / 2\n };\n },\n events: {\n drag: function (e, target) {\n if (target.chart.isInsidePlot(e.chartX - target.chart.plotLeft, e.chartY - target.chart.plotTop, {\n visiblePlotOnly: true\n })) {\n const translation = this.mouseMoveToTranslation(e), typeOptions = target.options.typeOptions;\n target.translatePoint(translation.x, translation.y, this.index);\n // Update options:\n typeOptions.points[this.index].x =\n target.points[this.index].x;\n typeOptions.points[this.index].y =\n target.points[this.index].y;\n target.redraw(false);\n }\n }\n }\n }\n });\n Annotation.types.crookedLine = CrookedLine;\n /* *\n *\n * Default Export\n *\n * */\n\n return CrookedLine;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/ElliottWave.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/Types/CrookedLine.js'], _modules['Core/Utilities.js']], function (Annotation, CrookedLine, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n class ElliottWave extends CrookedLine {\n /* *\n *\n * Functions\n *\n * */\n addLabels() {\n this.getPointsOptions().forEach((point, i) => {\n const typeOptions = this.options.typeOptions, label = this.initLabel(merge(point.label, {\n text: typeOptions.labels[i],\n point: function (target) {\n return target.annotation.points[i];\n }\n }), false);\n point.label = label.options;\n });\n }\n }\n ElliottWave.prototype.defaultOptions = merge(CrookedLine.prototype.defaultOptions, \n /**\n * An elliott wave annotation.\n *\n * @sample highcharts/annotations-advanced/elliott-wave/\n * Elliott wave\n *\n * @extends annotations.crookedLine\n * @product highstock\n * @optionparent annotations.elliottWave\n */\n {\n typeOptions: {\n /**\n * @extends annotations.crookedLine.labelOptions\n * @apioption annotations.elliottWave.typeOptions.points.label\n */\n /**\n * @ignore-option\n */\n labels: ['(0)', '(A)', '(B)', '(C)', '(D)', '(E)'],\n line: {\n strokeWidth: 1\n }\n },\n labelOptions: {\n align: 'center',\n allowOverlap: true,\n crop: true,\n overflow: 'none',\n type: 'rect',\n backgroundColor: 'none',\n borderWidth: 0,\n y: -5\n }\n });\n Annotation.types.elliottWave = ElliottWave;\n /* *\n *\n * Default Export\n *\n * */\n\n return ElliottWave;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/Tunnel.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/ControlPoint.js'], _modules['Extensions/Annotations/Types/CrookedLine.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Annotation, ControlPoint, CrookedLine, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function getSecondCoordinate(p1, p2, x) {\n return (p2.y - p1.y) / (p2.x - p1.x) * (x - p1.x) + p1.y;\n }\n /* *\n *\n * Class\n *\n * */\n class Tunnel extends CrookedLine {\n /* *\n *\n * Functions\n *\n * */\n getPointsOptions() {\n const pointsOptions = CrookedLine.prototype.getPointsOptions.call(this);\n pointsOptions[2] = this.heightPointOptions(pointsOptions[1]);\n pointsOptions[3] = this.heightPointOptions(pointsOptions[0]);\n return pointsOptions;\n }\n getControlPointsOptions() {\n return this.getPointsOptions().slice(0, 2);\n }\n heightPointOptions(pointOptions) {\n const heightPointOptions = merge(pointOptions), typeOptions = this.options.typeOptions;\n heightPointOptions.y += typeOptions.height;\n return heightPointOptions;\n }\n addControlPoints() {\n CrookedLine.prototype.addControlPoints.call(this);\n const options = this.options, typeOptions = options.typeOptions, controlPoint = new ControlPoint(this.chart, this, merge(options.controlPointOptions, typeOptions.heightControlPoint), 2);\n this.controlPoints.push(controlPoint);\n typeOptions.heightControlPoint = controlPoint.options;\n }\n addShapes() {\n this.addLine();\n this.addBackground();\n }\n addLine() {\n const line = this.initShape(merge(this.options.typeOptions.line, {\n type: 'path',\n points: [\n this.points[0],\n this.points[1],\n function (target) {\n const pointOptions = MockPoint.pointToOptions(target.annotation.points[2]);\n pointOptions.command = 'M';\n return pointOptions;\n },\n this.points[3]\n ]\n }), 0);\n this.options.typeOptions.line = line.options;\n }\n addBackground() {\n const background = this.initShape(merge(this.options.typeOptions.background, {\n type: 'path',\n points: this.points.slice()\n }), 1);\n this.options.typeOptions.background = background.options;\n }\n /**\n * Translate start or end (\"left\" or \"right\") side of the tunnel.\n * @private\n * @param {number} dx\n * the amount of x translation\n * @param {number} dy\n * the amount of y translation\n * @param {boolean} [end]\n * whether to translate start or end side\n */\n translateSide(dx, dy, end) {\n const topIndex = Number(end), bottomIndex = topIndex === 0 ? 3 : 2;\n this.translatePoint(dx, dy, topIndex);\n this.translatePoint(dx, dy, bottomIndex);\n }\n /**\n * Translate height of the tunnel.\n * @private\n * @param {number} dh\n * the amount of height translation\n */\n translateHeight(dh) {\n this.translatePoint(0, dh, 2);\n this.translatePoint(0, dh, 3);\n this.options.typeOptions.height = this.points[3].y -\n this.points[0].y;\n this.userOptions.typeOptions.height = this.options.typeOptions.height;\n }\n }\n Tunnel.prototype.defaultOptions = merge(CrookedLine.prototype.defaultOptions, \n /**\n * A tunnel annotation.\n *\n * @extends annotations.crookedLine\n * @sample highcharts/annotations-advanced/tunnel/\n * Tunnel\n * @product highstock\n * @optionparent annotations.tunnel\n */\n {\n typeOptions: {\n /**\n * Background options.\n *\n * @type {Object}\n * @excluding height, point, points, r, type, width, markerEnd,\n * markerStart\n */\n background: {\n fill: 'rgba(130, 170, 255, 0.4)',\n strokeWidth: 0\n },\n line: {\n strokeWidth: 1\n },\n /**\n * The height of the annotation in terms of yAxis.\n */\n height: -2,\n /**\n * Options for the control point which controls\n * the annotation's height.\n *\n * @extends annotations.crookedLine.controlPointOptions\n * @excluding positioner, events\n */\n heightControlPoint: {\n positioner: function (target) {\n const startXY = MockPoint.pointToPixels(target.points[2]), endXY = MockPoint.pointToPixels(target.points[3]), x = (startXY.x + endXY.x) / 2;\n return {\n x: x - this.graphic.width / 2,\n y: getSecondCoordinate(startXY, endXY, x) -\n this.graphic.height / 2\n };\n },\n events: {\n drag: function (e, target) {\n if (target.chart.isInsidePlot(e.chartX - target.chart.plotLeft, e.chartY - target.chart.plotTop, {\n visiblePlotOnly: true\n })) {\n target.translateHeight(this.mouseMoveToTranslation(e).y);\n target.redraw(false);\n }\n }\n }\n }\n },\n /**\n * @extends annotations.crookedLine.controlPointOptions\n * @excluding positioner, events\n */\n controlPointOptions: {\n events: {\n drag: function (e, target) {\n if (target.chart.isInsidePlot(e.chartX - target.chart.plotLeft, e.chartY - target.chart.plotTop, {\n visiblePlotOnly: true\n })) {\n const translation = this.mouseMoveToTranslation(e);\n target.translateSide(translation.x, translation.y, !!this.index);\n target.redraw(false);\n }\n }\n }\n }\n });\n Annotation.types.tunnel = Tunnel;\n /* *\n *\n * Default Export\n *\n * */\n\n return Tunnel;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/InfinityLine.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/Types/CrookedLine.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Annotation, CrookedLine, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n class InfinityLine extends CrookedLine {\n /* *\n *\n * Static Functions\n *\n * */\n static edgePoint(startIndex, endIndex) {\n return function (target) {\n const annotation = target.annotation, type = annotation.options.typeOptions.type;\n let points = annotation.points;\n if (type === 'horizontalLine' || type === 'verticalLine') {\n // Horizontal and vertical lines have only one point,\n // make a copy of it:\n points = [\n points[0],\n new MockPoint(annotation.chart, points[0].target, {\n // add 0 or 1 to x or y depending on type\n x: points[0].x + +(type === 'horizontalLine'),\n y: points[0].y + +(type === 'verticalLine'),\n xAxis: points[0].options.xAxis,\n yAxis: points[0].options.yAxis\n })\n ];\n }\n return InfinityLine.findEdgePoint(points[startIndex], points[endIndex]);\n };\n }\n static findEdgeCoordinate(firstPoint, secondPoint, xOrY, edgePointFirstCoordinate) {\n const xOrYOpposite = xOrY === 'x' ? 'y' : 'x';\n // solves equation for x or y\n // y - y1 = (y2 - y1) / (x2 - x1) * (x - x1)\n return ((secondPoint[xOrY] - firstPoint[xOrY]) *\n (edgePointFirstCoordinate - firstPoint[xOrYOpposite]) /\n (secondPoint[xOrYOpposite] - firstPoint[xOrYOpposite]) +\n firstPoint[xOrY]);\n }\n static findEdgePoint(firstPoint, secondPoint) {\n const chart = firstPoint.series.chart, xAxis = firstPoint.series.xAxis, yAxis = secondPoint.series.yAxis, firstPointPixels = MockPoint.pointToPixels(firstPoint), secondPointPixels = MockPoint.pointToPixels(secondPoint), deltaX = secondPointPixels.x - firstPointPixels.x, deltaY = secondPointPixels.y - firstPointPixels.y, xAxisMin = xAxis.left, xAxisMax = xAxisMin + xAxis.width, yAxisMin = yAxis.top, yAxisMax = yAxisMin + yAxis.height, xLimit = deltaX < 0 ? xAxisMin : xAxisMax, yLimit = deltaY < 0 ? yAxisMin : yAxisMax, edgePoint = {\n x: deltaX === 0 ? firstPointPixels.x : xLimit,\n y: deltaY === 0 ? firstPointPixels.y : yLimit\n };\n let edgePointX, edgePointY, swap;\n if (deltaX !== 0 && deltaY !== 0) {\n edgePointY = InfinityLine.findEdgeCoordinate(firstPointPixels, secondPointPixels, 'y', xLimit);\n edgePointX = InfinityLine.findEdgeCoordinate(firstPointPixels, secondPointPixels, 'x', yLimit);\n if (edgePointY >= yAxisMin && edgePointY <= yAxisMax) {\n edgePoint.x = xLimit;\n edgePoint.y = edgePointY;\n }\n else {\n edgePoint.x = edgePointX;\n edgePoint.y = yLimit;\n }\n }\n edgePoint.x -= chart.plotLeft;\n edgePoint.y -= chart.plotTop;\n if (firstPoint.series.chart.inverted) {\n swap = edgePoint.x;\n edgePoint.x = edgePoint.y;\n edgePoint.y = swap;\n }\n return edgePoint;\n }\n /* *\n *\n * Functions\n *\n * */\n addShapes() {\n const typeOptions = this.options.typeOptions, points = [\n this.points[0],\n InfinityLine.endEdgePoint\n ];\n // Be case-insensitive (#15155) e.g.:\n // - line\n // - horizontalLine\n // - verticalLine\n if (typeOptions.type.match(/line/gi)) {\n points[0] = InfinityLine.startEdgePoint;\n }\n const line = this.initShape(merge(typeOptions.line, {\n type: 'path',\n points: points\n }), 0);\n typeOptions.line = line.options;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n InfinityLine.endEdgePoint = InfinityLine.edgePoint(0, 1);\n InfinityLine.startEdgePoint = InfinityLine.edgePoint(1, 0);\n InfinityLine.prototype.defaultOptions = merge(CrookedLine.prototype.defaultOptions, {});\n Annotation.types.infinityLine = InfinityLine;\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * An infinity line annotation.\n *\n * @sample highcharts/annotations-advanced/infinity-line/\n * Infinity Line\n *\n * @extends annotations.crookedLine\n * @product highstock\n * @apioption annotations.infinityLine\n */\n (''); // keeps doclets above in transpiled file\n\n return InfinityLine;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/TimeCycles.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/Types/CrookedLine.js'], _modules['Extensions/Annotations/ControlPoint.js'], _modules['Core/Utilities.js']], function (Annotation, CrookedLine, ControlPoint, U) {\n /* *\n *\n * Authors: Rafal Sebestjanski and Pawel Lysy\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge, isNumber, defined } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Function to create start of the path.\n * @param {number} x x position of the TimeCycles\n * @param {number} y y position of the TimeCycles\n * @return {string} path\n */\n function getStartingPath(x, y) {\n return ['M', x, y];\n }\n /**\n * Function which generates the path of the halfcircle.\n *\n * @param {number} pixelInterval diameter of the circle in pixels\n * @param {number} numberOfCircles number of cricles\n * @param {number} startX x position of the first circle\n * @param {number} y y position of the bottom of the timeCycles\n * @return {string} path\n *\n */\n function getCirclePath(pixelInterval, numberOfCircles, startX, y) {\n const path = [];\n for (let i = 1; i <= numberOfCircles; i++) {\n path.push([\n 'A',\n pixelInterval / 2,\n pixelInterval / 2,\n 0,\n 1,\n 1,\n startX + i * pixelInterval,\n y\n ]);\n }\n return path;\n }\n /* *\n *\n * Class\n *\n * */\n class TimeCycles extends CrookedLine {\n /* *\n *\n * Functions\n *\n * */\n init(annotation, userOptions, index) {\n if (defined(userOptions.yAxis)) {\n userOptions.points.forEach((point) => {\n point.yAxis = userOptions.yAxis;\n });\n }\n if (defined(userOptions.xAxis)) {\n userOptions.points.forEach((point) => {\n point.xAxis = userOptions.xAxis;\n });\n }\n super.init(annotation, userOptions, index);\n }\n setPath() {\n this.shapes[0].options.d = this.getPath();\n }\n getPath() {\n return [getStartingPath(this.startX, this.y)].concat(getCirclePath(this.pixelInterval, this.numberOfCircles, this.startX, this.y));\n }\n addShapes() {\n const typeOptions = this.options.typeOptions;\n this.setPathProperties();\n const shape = this.initShape(merge(typeOptions.line, {\n type: 'path',\n d: this.getPath(),\n points: this.options.points\n }), 0);\n typeOptions.line = shape.options;\n }\n addControlPoints() {\n const options = this.options, typeOptions = options.typeOptions;\n options.controlPointOptions.style.cursor = this.chart.inverted ?\n 'ns-resize' :\n 'ew-resize';\n typeOptions.controlPointOptions.forEach((option) => {\n const controlPointsOptions = merge(options.controlPointOptions, option);\n const controlPoint = new ControlPoint(this.chart, this, controlPointsOptions, 0);\n this.controlPoints.push(controlPoint);\n });\n }\n setPathProperties() {\n const options = this.options.typeOptions, points = options.points;\n if (!points) {\n return;\n }\n const point1 = points[0], point2 = points[1], xAxisNumber = options.xAxis || 0, yAxisNumber = options.yAxis || 0, xAxis = this.chart.xAxis[xAxisNumber], yAxis = this.chart.yAxis[yAxisNumber], xValue1 = point1.x, yValue = point1.y, xValue2 = point2.x;\n if (!xValue1 || !xValue2) {\n return;\n }\n const y = isNumber(yValue) ?\n yAxis.toPixels(yValue) :\n yAxis.top + yAxis.height, x = isNumber(xValue1) ? xAxis.toPixels(xValue1) : xAxis.left, x2 = isNumber(xValue2) ? xAxis.toPixels(xValue2) : xAxis.left + 30, xAxisLength = xAxis.len, pixelInterval = Math.round(Math.max(Math.abs(x2 - x), 2)), \n // There can be 2 not full circles on the chart, so add 2.\n numberOfCircles = Math.floor(xAxisLength / pixelInterval) + 2, \n // Calculate where the annotation should start drawing relative to\n // first point.\n pixelShift = (Math.floor((x - xAxis.left) / pixelInterval) + 1) * pixelInterval;\n this.startX = x - pixelShift;\n this.y = y;\n this.pixelInterval = pixelInterval;\n this.numberOfCircles = numberOfCircles;\n }\n redraw(animation) {\n this.setPathProperties();\n this.setPath();\n super.redraw(animation);\n }\n }\n TimeCycles.prototype.defaultOptions = merge(CrookedLine.prototype.defaultOptions, \n /**\n * The TimeCycles Annotation\n *\n * @sample highcharts/annotations-advanced/time-cycles/\n * Time Cycles annotation\n *\n * @extends annotations.crookedLine\n * @product highstock\n * @exclude labelOptions\n * @optionparent annotations.timeCycles\n */\n {\n typeOptions: {\n /**\n * @exclude y\n * @product highstock\n * @apioption annotations.timeCycles.typeOptions.points\n */\n controlPointOptions: [{\n positioner: function (target) {\n const point = target.points[0], position = target.anchor(point).absolutePosition;\n return {\n x: position.x - this.graphic.width / 2,\n y: target.y - this.graphic.height\n };\n },\n events: {\n drag: function (e, target) {\n const position = target.anchor(target.points[0]).absolutePosition;\n target.translatePoint(e.chartX - position.x, 0, 0);\n target.redraw(false);\n }\n }\n }, {\n positioner: function (target) {\n const point = target.points[1], position = target.anchor(point).absolutePosition;\n return {\n x: position.x - this.graphic.width / 2,\n y: target.y - this.graphic.height\n };\n },\n events: {\n drag: function (e, target) {\n const position = target.anchor(target.points[1]).absolutePosition;\n target.translatePoint(e.chartX - position.x, 0, 1);\n target.redraw(false);\n }\n }\n }]\n }\n });\n Annotation.types.timeCycles = TimeCycles;\n /* *\n *\n * Default Export\n *\n * */\n\n return TimeCycles;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/Fibonacci.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Extensions/Annotations/Types/Tunnel.js'], _modules['Core/Utilities.js']], function (Annotation, MockPoint, Tunnel, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function createPathDGenerator(retracementIndex, isBackground) {\n return function () {\n const annotation = this.annotation;\n if (!annotation.startRetracements || !annotation.endRetracements) {\n return [];\n }\n const leftTop = this.anchor(annotation.startRetracements[retracementIndex]).absolutePosition, rightTop = this.anchor(annotation.endRetracements[retracementIndex]).absolutePosition, d = [\n ['M', Math.round(leftTop.x), Math.round(leftTop.y)],\n ['L', Math.round(rightTop.x), Math.round(rightTop.y)]\n ];\n if (isBackground) {\n const rightBottom = this.anchor(annotation.endRetracements[retracementIndex - 1]).absolutePosition;\n const leftBottom = this.anchor(annotation.startRetracements[retracementIndex - 1]).absolutePosition;\n d.push(['L', Math.round(rightBottom.x), Math.round(rightBottom.y)], ['L', Math.round(leftBottom.x), Math.round(leftBottom.y)]);\n }\n return d;\n };\n }\n /* *\n *\n * Class\n *\n * */\n class Fibonacci extends Tunnel {\n /* *\n *\n * Functions\n *\n * */\n linkPoints() {\n super.linkPoints();\n this.linkRetracementsPoints();\n return;\n }\n linkRetracementsPoints() {\n const points = this.points, startDiff = points[0].y - points[3].y, endDiff = points[1].y - points[2].y, startX = points[0].x, endX = points[1].x;\n Fibonacci.levels.forEach((level, i) => {\n const startRetracement = points[0].y - startDiff * level, endRetracement = points[1].y - endDiff * level;\n this.startRetracements = this.startRetracements || [];\n this.endRetracements = this.endRetracements || [];\n this.linkRetracementPoint(i, startX, startRetracement, this.startRetracements);\n this.linkRetracementPoint(i, endX, endRetracement, this.endRetracements);\n });\n }\n linkRetracementPoint(pointIndex, x, y, retracements) {\n const point = retracements[pointIndex], typeOptions = this.options.typeOptions;\n if (!point) {\n retracements[pointIndex] = new MockPoint(this.chart, this, {\n x: x,\n y: y,\n xAxis: typeOptions.xAxis,\n yAxis: typeOptions.yAxis\n });\n }\n else {\n point.options.x = x;\n point.options.y = y;\n point.refresh();\n }\n }\n addShapes() {\n Fibonacci.levels.forEach(function (_level, i) {\n const { backgroundColors, lineColor, lineColors } = this.options.typeOptions;\n this.initShape({\n type: 'path',\n d: createPathDGenerator(i),\n stroke: lineColors[i] || lineColor\n }, i);\n if (i > 0) {\n this.initShape({\n type: 'path',\n fill: backgroundColors[i - 1],\n strokeWidth: 0,\n d: createPathDGenerator(i, true)\n });\n }\n }, this);\n }\n addLabels() {\n Fibonacci.levels.forEach(function (level, i) {\n const options = this.options.typeOptions, label = this.initLabel(merge(options.labels[i], {\n point: function (target) {\n const point = MockPoint.pointToOptions(target.annotation.startRetracements[i]);\n return point;\n },\n text: level.toString()\n }));\n options.labels[i] = label.options;\n }, this);\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Fibonacci.levels = [0, 0.236, 0.382, 0.5, 0.618, 0.786, 1];\n Fibonacci.prototype.defaultOptions = merge(Tunnel.prototype.defaultOptions, \n /**\n * A fibonacci annotation.\n *\n * @sample highcharts/annotations-advanced/fibonacci/\n * Fibonacci\n *\n * @extends annotations.crookedLine\n * @product highstock\n * @optionparent annotations.fibonacci\n */\n {\n typeOptions: {\n /**\n * The height of the fibonacci in terms of yAxis.\n */\n height: 2,\n /**\n * An array of background colors:\n * Default to:\n * ```\n * [\n * 'rgba(130, 170, 255, 0.4)',\n * 'rgba(139, 191, 216, 0.4)',\n * 'rgba(150, 216, 192, 0.4)',\n * 'rgba(156, 229, 161, 0.4)',\n * 'rgba(162, 241, 130, 0.4)',\n * 'rgba(169, 255, 101, 0.4)'\n * ]\n * ```\n */\n backgroundColors: [\n 'rgba(130, 170, 255, 0.4)',\n 'rgba(139, 191, 216, 0.4)',\n 'rgba(150, 216, 192, 0.4)',\n 'rgba(156, 229, 161, 0.4)',\n 'rgba(162, 241, 130, 0.4)',\n 'rgba(169, 255, 101, 0.4)'\n ],\n /**\n * The color of line.\n */\n lineColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * An array of colors for the lines.\n */\n lineColors: [],\n /**\n * An array with options for the labels.\n *\n * @type {Array<*>}\n * @extends annotations.crookedLine.labelOptions\n * @apioption annotations.fibonacci.typeOptions.labels\n */\n labels: []\n },\n labelOptions: {\n allowOverlap: true,\n align: 'right',\n backgroundColor: 'none',\n borderWidth: 0,\n crop: false,\n overflow: 'none',\n shape: 'rect',\n style: {\n color: 'grey'\n },\n verticalAlign: 'middle',\n y: 0\n }\n });\n Annotation.types.fibonacci = Fibonacci;\n /* *\n *\n * Default Export\n *\n * */\n\n return Fibonacci;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/FibonacciTimeZones.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/ControlPoint.js'], _modules['Extensions/Annotations/Types/CrookedLine.js'], _modules['Extensions/Annotations/Types/InfinityLine.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Annotation, ControlPoint, CrookedLine, InfinityLine, MockPoint, U) {\n /* *\n *\n * Author: Rafal Sebestjanski\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n Method taken (and slightly changed) from the InfinityLine annotation.\n\n It uses x coordinate to create two mock points on the same x. Then,\n it uses some logic from InfinityLine to find equation of the line passing\n through our two points and, using that equation, it finds and returns\n the coordinates of where the line intersects the plot area edges.\n\n This is being done for each fibonacci time zone line.\n\n\n this point here is found\n |\n v\n |---------*--------------------------------------------------------|\n | |\n | |\n | |\n | |\n | * copy of the primary point |\n | |\n | * primary point (e.g. the one given in options) |\n | |\n |---------*--------------------------------------------------------|\n and this point here is found (intersection with the plot area edge)\n\n * @private\n */\n function edgePoint(startIndex, endIndex, fibonacciIndex) {\n return function (target) {\n const chart = target.annotation.chart, plotLeftOrTop = chart.inverted ? chart.plotTop : chart.plotLeft;\n let points = target.annotation.points;\n const xAxis = points[0].series.xAxis, \n // Distance between the two first lines in pixels\n deltaX = points.length > 1 ?\n points[1].plotX - points[0].plotX : 0, \n // firstLine.x + fibb * offset\n x = xAxis.toValue(points[0].plotX + plotLeftOrTop + fibonacciIndex * deltaX);\n // We need 2 mock points with the same x coordinate, different y\n points = [\n new MockPoint(chart, points[0].target, {\n x: x,\n y: 0,\n xAxis: points[0].options.xAxis,\n yAxis: points[0].options.yAxis\n }),\n new MockPoint(chart, points[0].target, {\n x: x,\n y: 1,\n xAxis: points[0].options.xAxis,\n yAxis: points[0].options.yAxis\n })\n ];\n return InfinityLine.findEdgePoint(points[startIndex], points[endIndex]);\n };\n }\n /* *\n *\n * Class\n *\n * */\n class FibonacciTimeZones extends CrookedLine {\n /* *\n *\n * Functions\n *\n * */\n addShapes() {\n const numberOfLines = 11;\n let fibb = 1, nextFibb = 1;\n for (let i = 0; i < numberOfLines; i++) {\n // The fibb variable equals to 1 twice - correct it in the first\n // iteration so the lines don't overlap\n const correctedFibb = !i ? 0 : fibb, points = [\n edgePoint(1, 0, correctedFibb),\n edgePoint(0, 1, correctedFibb)\n ];\n // Calculate fibbonacci\n nextFibb = fibb + nextFibb;\n fibb = nextFibb - fibb;\n // Save the second line for the control point\n if (i === 1) {\n this.secondLineEdgePoints = [points[0], points[1]];\n }\n this.initShape(merge(this.options.typeOptions.line, {\n type: 'path',\n points: points\n }), i // shape's index. Can be found in annotation.shapes[i].index\n );\n }\n }\n addControlPoints() {\n const options = this.options, typeOptions = options.typeOptions, controlPoint = new ControlPoint(this.chart, this, merge(options.controlPointOptions, typeOptions.controlPointOptions), 0);\n this.controlPoints.push(controlPoint);\n typeOptions.controlPointOptions = controlPoint.options;\n }\n }\n FibonacciTimeZones.prototype.defaultOptions = merge(CrookedLine.prototype.defaultOptions, \n /**\n * The Fibonacci Time Zones annotation.\n *\n * @sample highcharts/annotations-advanced/fibonacci-time-zones/\n * Fibonacci Time Zones\n *\n * @extends annotations.crookedLine\n * @since 9.3.0\n * @product highstock\n * @optionparent annotations.fibonacciTimeZones\n */\n {\n typeOptions: {\n /**\n * @exclude y\n * @since 9.3.0\n * @product highstock\n * @apioption annotations.fibonacciTimeZones.typeOptions.points\n */\n // Options for showing in popup edit\n line: {\n /**\n * The color of the lines.\n *\n * @type {string}\n * @since 9.3.0\n * @default 'rgba(0, 0, 0, 0.75)'\n * @apioption annotations.fibonacciTimeZones.typeOptions.line.stroke\n */\n stroke: 'rgba(0, 0, 0, 0.75)',\n /**\n * The width of the lines.\n *\n * @type {number}\n * @since 9.3.0\n * @default 1\n * @apioption annotations.fibonacciTimeZones.typeOptions.line.strokeWidth\n */\n strokeWidth: 1,\n // Don't inherit fill (don't display in popup edit)\n fill: void 0\n },\n controlPointOptions: {\n positioner: function () {\n // The control point is in the middle of the second line\n const target = this.target, graphic = this.graphic, edgePoints = target.secondLineEdgePoints, args = { annotation: target }, firstEdgePointY = edgePoints[0](args).y, secondEdgePointY = edgePoints[1](args).y, plotLeft = this.chart.plotLeft, plotTop = this.chart.plotTop;\n let x = edgePoints[0](args).x, y = (firstEdgePointY + secondEdgePointY) / 2;\n if (this.chart.inverted) {\n [x, y] = [y, x];\n }\n return {\n x: plotLeft + x - graphic.width / 2,\n y: plotTop + y - graphic.height / 2\n };\n },\n events: {\n drag: function (e, target) {\n const isInsidePlot = target.chart.isInsidePlot(e.chartX - target.chart.plotLeft, e.chartY - target.chart.plotTop, {\n visiblePlotOnly: true\n });\n if (isInsidePlot) {\n const translation = this.mouseMoveToTranslation(e);\n target.translatePoint(translation.x, 0, 1);\n target.redraw(false);\n }\n }\n }\n }\n }\n });\n Annotation.types.fibonacciTimeZones = FibonacciTimeZones;\n /* *\n *\n * Default Export\n *\n * */\n\n return FibonacciTimeZones;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/Pitchfork.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/Types/InfinityLine.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Annotation, InfinityLine, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n class Pitchfork extends InfinityLine {\n /* *\n *\n * Static Functions\n *\n * */\n static outerLineEdgePoint(firstPointIndex) {\n return function (target) {\n const annotation = target.annotation, points = annotation.points;\n return Pitchfork.findEdgePoint(points[firstPointIndex], points[0], new MockPoint(annotation.chart, target, annotation.midPointOptions()));\n };\n }\n static findEdgePoint(point, firstAnglePoint, secondAnglePoint) {\n const angle = Math.atan2((secondAnglePoint.plotY -\n firstAnglePoint.plotY), secondAnglePoint.plotX - firstAnglePoint.plotX), distance = 1e7;\n return {\n x: point.plotX + distance * Math.cos(angle),\n y: point.plotY + distance * Math.sin(angle)\n };\n }\n static middleLineEdgePoint(target) {\n const annotation = target.annotation, points = annotation.points;\n return InfinityLine.findEdgePoint(points[0], new MockPoint(annotation.chart, target, annotation.midPointOptions()));\n }\n /* *\n *\n * Functions\n *\n * */\n midPointOptions() {\n const points = this.points;\n return {\n x: (points[1].x + points[2].x) / 2,\n y: (points[1].y + points[2].y) / 2,\n xAxis: points[0].series.xAxis,\n yAxis: points[0].series.yAxis\n };\n }\n addShapes() {\n this.addLines();\n this.addBackgrounds();\n }\n addLines() {\n this.initShape({\n type: 'path',\n points: [\n this.points[0],\n Pitchfork.middleLineEdgePoint\n ]\n }, 0);\n this.initShape({\n type: 'path',\n points: [\n this.points[1],\n Pitchfork.topLineEdgePoint\n ]\n }, 1);\n this.initShape({\n type: 'path',\n points: [\n this.points[2],\n Pitchfork.bottomLineEdgePoint\n ]\n }, 2);\n }\n addBackgrounds() {\n const shapes = this.shapes, typeOptions = this.options.typeOptions;\n const innerBackground = this.initShape(merge(typeOptions.innerBackground, {\n type: 'path',\n points: [\n function (target) {\n const annotation = target.annotation, points = annotation.points, midPointOptions = annotation.midPointOptions();\n return {\n x: (points[1].x + midPointOptions.x) / 2,\n y: (points[1].y + midPointOptions.y) / 2,\n xAxis: midPointOptions.xAxis,\n yAxis: midPointOptions.yAxis\n };\n },\n shapes[1].points[1],\n shapes[2].points[1],\n function (target) {\n const annotation = target.annotation, points = annotation.points, midPointOptions = annotation.midPointOptions();\n return {\n x: (midPointOptions.x + points[2].x) / 2,\n y: (midPointOptions.y + points[2].y) / 2,\n xAxis: midPointOptions.xAxis,\n yAxis: midPointOptions.yAxis\n };\n }\n ]\n }), 3);\n const outerBackground = this.initShape(merge(typeOptions.outerBackground, {\n type: 'path',\n points: [\n this.points[1],\n shapes[1].points[1],\n shapes[2].points[1],\n this.points[2]\n ]\n }), 4);\n typeOptions.innerBackground = innerBackground.options;\n typeOptions.outerBackground = outerBackground.options;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Pitchfork.topLineEdgePoint = Pitchfork.outerLineEdgePoint(1);\n Pitchfork.bottomLineEdgePoint = Pitchfork.outerLineEdgePoint(0);\n Pitchfork.prototype.defaultOptions = merge(InfinityLine.prototype.defaultOptions, \n /**\n * A pitchfork annotation.\n *\n * @sample highcharts/annotations-advanced/pitchfork/\n * Pitchfork\n *\n * @extends annotations.infinityLine\n * @product highstock\n * @optionparent annotations.pitchfork\n */\n {\n typeOptions: {\n /**\n * Inner background options.\n *\n * @extends annotations.crookedLine.shapeOptions\n * @excluding height, r, type, width\n */\n innerBackground: {\n fill: 'rgba(130, 170, 255, 0.4)',\n strokeWidth: 0\n },\n /**\n * Outer background options.\n *\n * @extends annotations.crookedLine.shapeOptions\n * @excluding height, r, type, width\n */\n outerBackground: {\n fill: 'rgba(156, 229, 161, 0.4)',\n strokeWidth: 0\n }\n }\n });\n Annotation.types.pitchfork = Pitchfork;\n /* *\n *\n * Default Export\n *\n * */\n\n return Pitchfork;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/VerticalLine.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/MockPoint.js'], _modules['Core/Utilities.js']], function (Annotation, MockPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { merge, pick } = U;\n /* *\n *\n * Class\n *\n * */\n class VerticalLine extends Annotation {\n /* *\n *\n * Static Functions\n *\n * */\n static connectorFirstPoint(target) {\n const annotation = target.annotation, chart = annotation.chart, inverted = chart.inverted, point = annotation.points[0], left = pick(point.series.yAxis && point.series.yAxis.left, 0), top = pick(point.series.yAxis && point.series.yAxis.top, 0), offset = annotation.options.typeOptions.label.offset, y = MockPoint.pointToPixels(point, true)[inverted ? 'x' : 'y'];\n return {\n x: point.x,\n xAxis: point.series.xAxis,\n y: y + offset +\n (inverted ? (left - chart.plotLeft) : (top - chart.plotTop))\n };\n }\n static connectorSecondPoint(target) {\n const annotation = target.annotation, chart = annotation.chart, inverted = chart.inverted, typeOptions = annotation.options.typeOptions, point = annotation.points[0], left = pick(point.series.yAxis && point.series.yAxis.left, 0), top = pick(point.series.yAxis && point.series.yAxis.top, 0), y = MockPoint.pointToPixels(point, true)[inverted ? 'x' : 'y'];\n let yOffset = typeOptions.yOffset;\n if (typeOptions.label.offset < 0) {\n yOffset *= -1;\n }\n return {\n x: point.x,\n xAxis: point.series.xAxis,\n y: y + yOffset +\n (inverted ? (left - chart.plotLeft) : (top - chart.plotTop))\n };\n }\n /* *\n *\n * Functions\n *\n * */\n getPointsOptions() {\n return [this.options.typeOptions.point];\n }\n addShapes() {\n const typeOptions = this.options.typeOptions, connector = this.initShape(merge(typeOptions.connector, {\n type: 'path',\n points: [\n VerticalLine.connectorFirstPoint,\n VerticalLine.connectorSecondPoint\n ]\n }), 0);\n typeOptions.connector = connector.options;\n this.userOptions.typeOptions.point = typeOptions.point;\n }\n addLabels() {\n const typeOptions = this.options.typeOptions, labelOptions = typeOptions.label;\n let x = 0, y = labelOptions.offset, verticalAlign = labelOptions.offset < 0 ? 'bottom' : 'top', align = 'center';\n if (this.chart.inverted) {\n x = labelOptions.offset;\n y = 0;\n verticalAlign = 'middle';\n align = labelOptions.offset < 0 ? 'right' : 'left';\n }\n const label = this.initLabel(merge(labelOptions, {\n verticalAlign: verticalAlign,\n align: align,\n x: x,\n y: y\n }));\n typeOptions.label = label.options;\n }\n }\n VerticalLine.prototype.defaultOptions = merge(Annotation.prototype.defaultOptions, \n /**\n * A vertical line annotation.\n *\n * @sample highcharts/annotations-advanced/vertical-line/\n * Vertical line\n *\n * @extends annotations.crookedLine\n * @excluding labels, shapes, controlPointOptions\n * @product highstock\n * @optionparent annotations.verticalLine\n */\n {\n typeOptions: {\n /**\n * @ignore\n */\n yOffset: 10,\n /**\n * Label options.\n *\n * @extends annotations.crookedLine.labelOptions\n */\n label: {\n offset: -40,\n point: function (target) {\n return target.annotation.points[0];\n },\n allowOverlap: true,\n backgroundColor: 'none',\n borderWidth: 0,\n crop: true,\n overflow: 'none',\n shape: 'rect',\n text: '{y:.2f}'\n },\n /**\n * Connector options.\n *\n * @extends annotations.crookedLine.shapeOptions\n * @excluding height, r, type, width\n */\n connector: {\n strokeWidth: 1,\n markerEnd: 'arrow'\n }\n }\n });\n Annotation.types.verticalLine = VerticalLine;\n /* *\n *\n * Default Export\n *\n * */\n\n return VerticalLine;\n });\n _registerModule(_modules, 'Extensions/Annotations/Types/Measure.js', [_modules['Extensions/Annotations/Annotation.js'], _modules['Extensions/Annotations/ControlPoint.js'], _modules['Core/Utilities.js']], function (Annotation, ControlPoint, U) {\n /* *\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, extend, isNumber, merge, pick } = U;\n /* *\n *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function average() {\n let average = '';\n if (this.max !== '' && this.min !== '') {\n average = (this.max + this.min) / 2;\n }\n return average;\n }\n /**\n * @private\n */\n function bins() {\n const series = this.chart.series, ext = getExtremes(this.xAxisMin, this.xAxisMax, this.yAxisMin, this.yAxisMax);\n let bins = 0, isCalculated = false; // to avoid Infinity in formatter\n series.forEach((serie) => {\n if (serie.visible &&\n serie.options.id !== 'highcharts-navigator-series') {\n serie.points.forEach((point) => {\n if (!point.isNull &&\n point.x > ext.xAxisMin &&\n point.x <= ext.xAxisMax &&\n point.y > ext.yAxisMin &&\n point.y <= ext.yAxisMax) {\n bins++;\n isCalculated = true;\n }\n });\n }\n });\n if (!isCalculated) {\n bins = '';\n }\n return bins;\n }\n /**\n * Default formatter of label's content\n * @private\n */\n function defaultFormatter() {\n return 'Min: ' + this.min +\n '
Max: ' + this.max +\n '
Average: ' + this.average +\n '
Bins: ' + this.bins;\n }\n /**\n * Set values for xAxisMin, xAxisMax, yAxisMin, yAxisMax, also\n * when chart is inverted\n * @private\n */\n function getExtremes(xAxisMin, xAxisMax, yAxisMin, yAxisMax) {\n return {\n xAxisMin: Math.min(xAxisMax, xAxisMin),\n xAxisMax: Math.max(xAxisMax, xAxisMin),\n yAxisMin: Math.min(yAxisMax, yAxisMin),\n yAxisMax: Math.max(yAxisMax, yAxisMin)\n };\n }\n /**\n * Set current xAxisMin, xAxisMax, yAxisMin, yAxisMax.\n * Calculations of measure values (min, max, average, bins).\n * @private\n * @param {Highcharts.Axis} axis\n * X or y axis reference\n * @param {number} value\n * Point's value (x or y)\n * @param {number} offset\n * Amount of pixels\n */\n function getPointPos(axis, value, offset) {\n return axis.toValue(axis.toPixels(value) + offset);\n }\n /**\n * Set starting points\n * @private\n */\n function init() {\n const options = this.options.typeOptions, chart = this.chart, inverted = chart.inverted, xAxis = chart.xAxis[options.xAxis], yAxis = chart.yAxis[options.yAxis], bck = options.background, width = inverted ? bck.height : bck.width, height = inverted ? bck.width : bck.height, selectType = options.selectType, top = inverted ? xAxis.left : yAxis.top, // #13664\n left = inverted ? yAxis.top : xAxis.left; // #13664\n this.startXMin = options.point.x;\n this.startYMin = options.point.y;\n if (isNumber(width)) {\n this.startXMax = this.startXMin + width;\n }\n else {\n this.startXMax = getPointPos(xAxis, this.startXMin, parseFloat(width));\n }\n if (isNumber(height)) {\n this.startYMax = this.startYMin - height;\n }\n else {\n this.startYMax = getPointPos(yAxis, this.startYMin, parseFloat(height));\n }\n // x / y selection type\n if (selectType === 'x') {\n this.startYMin = yAxis.toValue(top);\n this.startYMax = yAxis.toValue(top + yAxis.len);\n }\n else if (selectType === 'y') {\n this.startXMin = xAxis.toValue(left);\n this.startXMax = xAxis.toValue(left + xAxis.len);\n }\n }\n /**\n * @private\n */\n function max() {\n const series = this.chart.series, ext = getExtremes(this.xAxisMin, this.xAxisMax, this.yAxisMin, this.yAxisMax);\n let max = -Infinity, isCalculated = false; // to avoid Infinity in formatter\n series.forEach((serie) => {\n if (serie.visible &&\n serie.options.id !== 'highcharts-navigator-series') {\n serie.points.forEach((point) => {\n if (!point.isNull &&\n point.y > max &&\n point.x > ext.xAxisMin &&\n point.x <= ext.xAxisMax &&\n point.y > ext.yAxisMin &&\n point.y <= ext.yAxisMax) {\n max = point.y;\n isCalculated = true;\n }\n });\n }\n });\n if (!isCalculated) {\n max = '';\n }\n return max;\n }\n /**\n * Definitions of calculations (min, max, average, bins)\n * @private\n */\n function min() {\n const series = this.chart.series, ext = getExtremes(this.xAxisMin, this.xAxisMax, this.yAxisMin, this.yAxisMax);\n let min = Infinity, isCalculated = false; // to avoid Infinity in formatter\n series.forEach((serie) => {\n if (serie.visible &&\n serie.options.id !== 'highcharts-navigator-series') {\n serie.points.forEach((point) => {\n if (!point.isNull &&\n point.y < min &&\n point.x > ext.xAxisMin &&\n point.x <= ext.xAxisMax &&\n point.y > ext.yAxisMin &&\n point.y <= ext.yAxisMax) {\n min = point.y;\n isCalculated = true;\n }\n });\n }\n });\n if (!isCalculated) {\n min = '';\n }\n return min;\n }\n /**\n * Set current xAxisMin, xAxisMax, yAxisMin, yAxisMax.\n * Calculations of measure values (min, max, average, bins).\n * @private\n * @param {boolean} [resize]\n * Flag if shape is resized.\n */\n function recalculate(resize) {\n const options = this.options.typeOptions, xAxis = this.chart.xAxis[options.xAxis], yAxis = this.chart.yAxis[options.yAxis], offsetX = this.offsetX, offsetY = this.offsetY;\n this.xAxisMin = getPointPos(xAxis, this.startXMin, offsetX);\n this.xAxisMax = getPointPos(xAxis, this.startXMax, offsetX);\n this.yAxisMin = getPointPos(yAxis, this.startYMin, offsetY);\n this.yAxisMax = getPointPos(yAxis, this.startYMax, offsetY);\n this.min = min.call(this);\n this.max = max.call(this);\n this.average = average.call(this);\n this.bins = bins.call(this);\n if (resize) {\n this.resize(0, 0);\n }\n }\n /**\n * Update position of start points\n * (startXMin, startXMax, startYMin, startYMax)\n * @private\n * @param {boolean} redraw\n * Flag if shape is redraw\n * @param {boolean} resize\n * Flag if shape is resized\n * @param {number} cpIndex\n * Index of controlPoint\n */\n function updateStartPoints(redraw, resize, cpIndex, dx, dy) {\n const options = this.options.typeOptions, selectType = options.selectType, xAxis = this.chart.xAxis[options.xAxis], yAxis = this.chart.yAxis[options.yAxis], startXMin = this.startXMin, startXMax = this.startXMax, startYMin = this.startYMin, startYMax = this.startYMax, offsetX = this.offsetX, offsetY = this.offsetY;\n if (resize) {\n if (selectType === 'x') {\n if (cpIndex === 0) {\n this.startXMin = getPointPos(xAxis, startXMin, dx);\n }\n else {\n this.startXMax = getPointPos(xAxis, startXMax, dx);\n }\n }\n else if (selectType === 'y') {\n if (cpIndex === 0) {\n this.startYMin = getPointPos(yAxis, startYMin, dy);\n }\n else {\n this.startYMax = getPointPos(yAxis, startYMax, dy);\n }\n }\n else {\n this.startXMax = getPointPos(xAxis, startXMax, dx);\n this.startYMax = getPointPos(yAxis, startYMax, dy);\n }\n }\n if (redraw) {\n this.startXMin = getPointPos(xAxis, startXMin, offsetX);\n this.startXMax = getPointPos(xAxis, startXMax, offsetX);\n this.startYMin = getPointPos(yAxis, startYMin, offsetY);\n this.startYMax = getPointPos(yAxis, startYMax, offsetY);\n this.offsetX = 0;\n this.offsetY = 0;\n }\n }\n /* *\n *\n * Class\n *\n * */\n class Measure extends Annotation {\n /* *\n *\n * Functions\n *\n * */\n /**\n * Init annotation object.\n * @private\n */\n init(annotationOrChart, userOptions, index) {\n super.init(annotationOrChart, userOptions, index);\n this.offsetX = 0;\n this.offsetY = 0;\n this.resizeX = 0;\n this.resizeY = 0;\n init.call(this);\n this.addValues();\n this.addShapes();\n }\n /**\n * Overrides default setter to get axes from typeOptions.\n * @private\n */\n setClipAxes() {\n this.clipXAxis = this.chart.xAxis[this.options.typeOptions.xAxis];\n this.clipYAxis = this.chart.yAxis[this.options.typeOptions.yAxis];\n }\n /**\n * Get measure points configuration objects.\n * @private\n */\n pointsOptions() {\n return this.options.points;\n }\n /**\n * Get points configuration objects for shapes.\n * @private\n */\n shapePointsOptions() {\n const options = this.options.typeOptions, xAxis = options.xAxis, yAxis = options.yAxis;\n return [\n {\n x: this.xAxisMin,\n y: this.yAxisMin,\n xAxis: xAxis,\n yAxis: yAxis\n },\n {\n x: this.xAxisMax,\n y: this.yAxisMin,\n xAxis: xAxis,\n yAxis: yAxis\n },\n {\n x: this.xAxisMax,\n y: this.yAxisMax,\n xAxis: xAxis,\n yAxis: yAxis\n },\n {\n x: this.xAxisMin,\n y: this.yAxisMax,\n xAxis: xAxis,\n yAxis: yAxis\n }\n ];\n }\n addControlPoints() {\n const inverted = this.chart.inverted, options = this.options.controlPointOptions, selectType = this.options.typeOptions.selectType;\n if (!defined(this.userOptions.controlPointOptions &&\n this.userOptions.controlPointOptions.style.cursor)) {\n if (selectType === 'x') {\n options.style.cursor = inverted ? 'ns-resize' : 'ew-resize';\n }\n else if (selectType === 'y') {\n options.style.cursor = inverted ? 'ew-resize' : 'ns-resize';\n }\n }\n let controlPoint = new ControlPoint(this.chart, this, this.options.controlPointOptions, 0);\n this.controlPoints.push(controlPoint);\n // add extra controlPoint for horizontal and vertical range\n if (selectType !== 'xy') {\n controlPoint = new ControlPoint(this.chart, this, this.options.controlPointOptions, 1);\n this.controlPoints.push(controlPoint);\n }\n }\n /**\n * Add label with calculated values (min, max, average, bins).\n * @private\n * @param {boolean} [resize]\n * The flag for resize shape\n */\n addValues(resize) {\n const typeOptions = this.options.typeOptions, formatter = typeOptions.label.formatter;\n // set xAxisMin, xAxisMax, yAxisMin, yAxisMax\n recalculate.call(this, resize);\n if (!typeOptions.label.enabled) {\n return;\n }\n if (this.labels.length > 0) {\n this.labels[0].text = ((formatter && formatter.call(this)) ||\n defaultFormatter.call(this));\n }\n else {\n this.initLabel(extend({\n shape: 'rect',\n backgroundColor: 'none',\n color: 'black',\n borderWidth: 0,\n dashStyle: 'Dash',\n overflow: 'allow',\n align: 'left',\n y: 0,\n x: 0,\n verticalAlign: 'top',\n crop: true,\n xAxis: 0,\n yAxis: 0,\n point: function (target) {\n const annotation = target.annotation, options = target.options;\n return {\n x: annotation.xAxisMin,\n y: annotation.yAxisMin,\n xAxis: pick(typeOptions.xAxis, options.xAxis),\n yAxis: pick(typeOptions.yAxis, options.yAxis)\n };\n },\n text: ((formatter && formatter.call(this)) ||\n defaultFormatter.call(this))\n }, typeOptions.label), void 0);\n }\n }\n /**\n * Crosshair, background (rect).\n * @private\n */\n addShapes() {\n this.addCrosshairs();\n this.addBackground();\n }\n /**\n * Add background shape.\n * @private\n */\n addBackground() {\n const shapePoints = this.shapePointsOptions();\n if (typeof shapePoints[0].x === 'undefined') {\n return;\n }\n this.initShape(extend({\n type: 'path',\n points: this.shapePointsOptions()\n }, this.options.typeOptions.background), 2);\n }\n /**\n * Add internal crosshair shapes (on top and bottom).\n * @private\n */\n addCrosshairs() {\n const chart = this.chart, options = this.options.typeOptions, point = this.options.typeOptions.point, xAxis = chart.xAxis[options.xAxis], yAxis = chart.yAxis[options.yAxis], inverted = chart.inverted, defaultOptions = {\n point: point,\n type: 'path'\n };\n let xAxisMin = xAxis.toPixels(this.xAxisMin), xAxisMax = xAxis.toPixels(this.xAxisMax), yAxisMin = yAxis.toPixels(this.yAxisMin), yAxisMax = yAxis.toPixels(this.yAxisMax), pathH = [], pathV = [], crosshairOptionsX, crosshairOptionsY, temp;\n if (inverted) {\n temp = xAxisMin;\n xAxisMin = yAxisMin;\n yAxisMin = temp;\n temp = xAxisMax;\n xAxisMax = yAxisMax;\n yAxisMax = temp;\n }\n // horizontal line\n if (options.crosshairX.enabled) {\n pathH = [[\n 'M',\n xAxisMin,\n yAxisMin + ((yAxisMax - yAxisMin) / 2)\n ], [\n 'L',\n xAxisMax,\n yAxisMin + ((yAxisMax - yAxisMin) / 2)\n ]];\n }\n // vertical line\n if (options.crosshairY.enabled) {\n pathV = [[\n 'M',\n xAxisMin + ((xAxisMax - xAxisMin) / 2),\n yAxisMin\n ], [\n 'L',\n xAxisMin + ((xAxisMax - xAxisMin) / 2),\n yAxisMax\n ]];\n }\n // Update existed crosshair\n if (this.shapes.length > 0) {\n this.shapes[0].options.d = pathH;\n this.shapes[1].options.d = pathV;\n }\n else {\n // Add new crosshairs\n crosshairOptionsX = merge(defaultOptions, options.crosshairX);\n crosshairOptionsY = merge(defaultOptions, options.crosshairY);\n this.initShape(extend({ d: pathH }, crosshairOptionsX), 0);\n this.initShape(extend({ d: pathV }, crosshairOptionsY), 1);\n }\n }\n onDrag(e) {\n const translation = this.mouseMoveToTranslation(e), selectType = this.options.typeOptions.selectType, x = selectType === 'y' ? 0 : translation.x, y = selectType === 'x' ? 0 : translation.y;\n this.translate(x, y);\n this.offsetX += x;\n this.offsetY += y;\n // animation, resize, setStartPoints\n this.redraw(false, false, true);\n }\n /**\n * Translate start or end (\"left\" or \"right\") side of the measure.\n * Update start points (startXMin, startXMax, startYMin, startYMax)\n * @private\n * @param {number} dx\n * the amount of x translation\n * @param {number} dy\n * the amount of y translation\n * @param {number} cpIndex\n * index of control point\n * @param {Highcharts.AnnotationDraggableValue} selectType\n * x / y / xy\n */\n resize(dx, dy, cpIndex, selectType) {\n // background shape\n const bckShape = this.shapes[2];\n if (selectType === 'x') {\n if (cpIndex === 0) {\n bckShape.translatePoint(dx, 0, 0);\n bckShape.translatePoint(dx, dy, 3);\n }\n else {\n bckShape.translatePoint(dx, 0, 1);\n bckShape.translatePoint(dx, dy, 2);\n }\n }\n else if (selectType === 'y') {\n if (cpIndex === 0) {\n bckShape.translatePoint(0, dy, 0);\n bckShape.translatePoint(0, dy, 1);\n }\n else {\n bckShape.translatePoint(0, dy, 2);\n bckShape.translatePoint(0, dy, 3);\n }\n }\n else {\n bckShape.translatePoint(dx, 0, 1);\n bckShape.translatePoint(dx, dy, 2);\n bckShape.translatePoint(0, dy, 3);\n }\n updateStartPoints.call(this, false, true, cpIndex, dx, dy);\n this.options.typeOptions.background.height = Math.abs(this.startYMax - this.startYMin);\n this.options.typeOptions.background.width = Math.abs(this.startXMax - this.startXMin);\n }\n /**\n * Redraw event which render elements and update start points if needed.\n * @private\n * @param {boolean} animation\n * @param {boolean} [resize]\n * flag if resized\n * @param {boolean} [setStartPoints]\n * update position of start points\n */\n redraw(animation, resize, setStartPoints) {\n this.linkPoints();\n if (!this.graphic) {\n this.render();\n }\n if (setStartPoints) {\n updateStartPoints.call(this, true, false);\n }\n // #11174 - clipBox was not recalculate during resize / redraw\n if (this.clipRect) {\n this.clipRect.animate(this.getClipBox());\n }\n this.addValues(resize);\n this.addCrosshairs();\n this.redrawItems(this.shapes, animation);\n this.redrawItems(this.labels, animation);\n // redraw control point to run positioner\n this.controlPoints.forEach((controlPoint) => controlPoint.redraw());\n }\n translate(dx, dy) {\n this.shapes.forEach((item) => item.translate(dx, dy));\n this.options.typeOptions.point = {\n x: this.startXMin,\n y: this.startYMin\n };\n }\n }\n Measure.prototype.defaultOptions = merge(Annotation.prototype.defaultOptions, \n /**\n * A measure annotation.\n *\n * @extends annotations.crookedLine\n * @excluding labels, labelOptions, shapes, shapeOptions\n * @sample highcharts/annotations-advanced/measure/\n * Measure\n * @product highstock\n * @optionparent annotations.measure\n */\n {\n typeOptions: {\n /**\n * Decides in what dimensions the user can resize by dragging the\n * mouse. Can be one of x, y or xy.\n */\n selectType: 'xy',\n /**\n * This number defines which xAxis the point is connected to.\n * It refers to either the axis id or the index of the axis\n * in the xAxis array.\n */\n xAxis: 0,\n /**\n * This number defines which yAxis the point is connected to.\n * It refers to either the axis id or the index of the axis\n * in the yAxis array.\n */\n yAxis: 0,\n background: {\n /**\n * The color of the rectangle.\n */\n fill: 'rgba(130, 170, 255, 0.4)',\n /**\n * The width of border.\n */\n strokeWidth: 0,\n /**\n * The color of border.\n */\n stroke: void 0\n },\n /**\n * Configure a crosshair that is horizontally placed in middle of\n * rectangle.\n *\n */\n crosshairX: {\n /**\n * Enable or disable the horizontal crosshair.\n *\n */\n enabled: true,\n /**\n * The Z index of the crosshair in annotation.\n */\n zIndex: 6,\n /**\n * The dash or dot style of the crosshair's line. For possible\n * values, see\n * [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @type {Highcharts.DashStyleValue}\n * @default Dash\n */\n dashStyle: 'Dash',\n /**\n * The marker-end defines the arrowhead that will be drawn\n * at the final vertex of the given crosshair's path.\n *\n * @type {string}\n * @default arrow\n */\n markerEnd: 'arrow'\n },\n /**\n * Configure a crosshair that is vertically placed in middle of\n * rectangle.\n */\n crosshairY: {\n /**\n * Enable or disable the vertical crosshair.\n *\n */\n enabled: true,\n /**\n * The Z index of the crosshair in annotation.\n */\n zIndex: 6,\n /**\n * The dash or dot style of the crosshair's line. For possible\n * values, see\n * [this demonstration](https://jsfiddle.net/gh/get/library/pure/highcharts/highcharts/tree/master/samples/highcharts/plotoptions/series-dashstyle-all/).\n *\n * @type {Highcharts.DashStyleValue}\n * @default Dash\n * @apioption annotations.measure.typeOptions.crosshairY.dashStyle\n *\n */\n dashStyle: 'Dash',\n /**\n * The marker-end defines the arrowhead that will be drawn\n * at the final vertex of the given crosshair's path.\n *\n * @type {string}\n * @default arrow\n * @validvalue [\"none\", \"arrow\"]\n *\n */\n markerEnd: 'arrow'\n },\n label: {\n /**\n * Enable or disable the label text (min, max, average,\n * bins values).\n *\n * Defaults to true.\n */\n enabled: true,\n /**\n * CSS styles for the measure label.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"#666666\", \"fontSize\": \"11px\"}\n */\n style: {\n fontSize: '0.7em',\n color: \"#666666\" /* Palette.neutralColor60 */\n },\n /**\n * Formatter function for the label text.\n *\n * Available data are:\n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n * \n *\n *
`this.min`The mininimum value of the points in the selected\n * range.
`this.max`The maximum value of the points in the selected\n * range.
`this.average`The average value of the points in the selected\n * range.
`this.bins`The amount of the points in the selected range.
\n *\n * @type {Function}\n *\n */\n formatter: void 0\n }\n },\n controlPointOptions: {\n positioner: function (target) {\n const cpIndex = this.index, chart = target.chart, options = target.options, typeOptions = options.typeOptions, selectType = typeOptions.selectType, controlPointOptions = options.controlPointOptions, inverted = chart.inverted, xAxis = chart.xAxis[typeOptions.xAxis], yAxis = chart.yAxis[typeOptions.yAxis], ext = getExtremes(target.xAxisMin, target.xAxisMax, target.yAxisMin, target.yAxisMax);\n let targetX = target.xAxisMax, targetY = target.yAxisMax, x, y;\n if (selectType === 'x') {\n targetY = (ext.yAxisMax + ext.yAxisMin) / 2;\n // first control point\n if (cpIndex === 0) {\n targetX = target.xAxisMin;\n }\n }\n if (selectType === 'y') {\n targetX = ext.xAxisMin +\n ((ext.xAxisMax - ext.xAxisMin) / 2);\n // first control point\n if (cpIndex === 0) {\n targetY = target.yAxisMin;\n }\n }\n if (inverted) {\n x = yAxis.toPixels(targetY);\n y = xAxis.toPixels(targetX);\n }\n else {\n x = xAxis.toPixels(targetX);\n y = yAxis.toPixels(targetY);\n }\n return {\n x: x - (controlPointOptions.width / 2),\n y: y - (controlPointOptions.height / 2)\n };\n },\n events: {\n drag: function (e, target) {\n const translation = this.mouseMoveToTranslation(e), selectType = target.options.typeOptions.selectType, index = this.index, x = selectType === 'y' ? 0 : translation.x, y = selectType === 'x' ? 0 : translation.y;\n target.resize(x, y, index, selectType);\n target.resizeX += x;\n target.resizeY += y;\n target.redraw(false, true);\n }\n }\n }\n });\n Annotation.types.measure = Measure;\n /* *\n *\n * Default Export\n *\n * */\n\n return Measure;\n });\n _registerModule(_modules, 'masters/modules/annotations-advanced.src.js', [_modules['Core/Globals.js'], _modules['Extensions/Annotations/Annotation.js']], function (Highcharts, Annotation) {\n\n const G = Highcharts;\n G.Annotation = Annotation;\n Annotation.compose(G.Chart, G.Pointer, G.SVGRenderer);\n\n });\n}));","/**\n * @license Highstock JS v11.1.0 (2023-06-05)\n *\n * Drag-panes module\n *\n * (c) 2010-2021 Highsoft AS\n * Author: Kacper Madej\n *\n * License: www.highcharts.com/license\n */\n(function (factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/modules/drag-panes', ['highcharts', 'highcharts/modules/stock'], function (Highcharts) {\n factory(Highcharts);\n factory.Highcharts = Highcharts;\n return factory;\n });\n } else {\n factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);\n }\n}(function (Highcharts) {\n 'use strict';\n var _modules = Highcharts ? Highcharts._modules : {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Extensions/DragPanes/AxisResizerDefaults.js', [], function () {\n /* *\n *\n * Plugin for resizing axes / panes in a chart.\n *\n * (c) 2010-2023 Highsoft AS\n *\n * Author: Kacper Madej\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n const AxisResizerDefaults = {\n /**\n * Minimal size of a resizable axis. Could be set as a percent\n * of plot area or pixel size.\n *\n * @sample {highstock} stock/yaxis/resize-min-max-length\n * minLength and maxLength\n *\n * @type {number|string}\n * @product highstock\n * @requires modules/drag-panes\n * @apioption yAxis.minLength\n */\n minLength: '10%',\n /**\n * Maximal size of a resizable axis. Could be set as a percent\n * of plot area or pixel size.\n *\n * @sample {highstock} stock/yaxis/resize-min-max-length\n * minLength and maxLength\n *\n * @type {number|string}\n * @product highstock\n * @requires modules/drag-panes\n * @apioption yAxis.maxLength\n */\n maxLength: '100%',\n /**\n * Options for axis resizing. It adds a thick line between panes which\n * the user can drag in order to resize the panes.\n *\n * @sample {highstock} stock/demo/candlestick-and-volume\n * Axis resizing enabled\n *\n * @product highstock\n * @requires modules/drag-panes\n * @optionparent yAxis.resize\n */\n resize: {\n /**\n * Contains two arrays of axes that are controlled by control line\n * of the axis.\n *\n * @requires modules/drag-panes\n */\n controlledAxis: {\n /**\n * Array of axes that should move out of the way of resizing\n * being done for the current axis. If not set, the next axis\n * will be used.\n *\n * @sample {highstock} stock/yaxis/multiple-resizers\n * Three panes with resizers\n * @sample {highstock} stock/yaxis/resize-multiple-axes\n * One resizer controlling multiple axes\n *\n * @type {Array}\n * @default []\n * @requires modules/drag-panes\n */\n next: [],\n /**\n * Array of axes that should move with the current axis\n * while resizing.\n *\n * @sample {highstock} stock/yaxis/multiple-resizers\n * Three panes with resizers\n * @sample {highstock} stock/yaxis/resize-multiple-axes\n * One resizer controlling multiple axes\n *\n * @type {Array}\n * @default []\n * @requires modules/drag-panes\n */\n prev: []\n },\n /**\n * Enable or disable resize by drag for the axis.\n *\n * @sample {highstock} stock/demo/candlestick-and-volume\n * Enabled resizer\n *\n * @requires modules/drag-panes\n */\n enabled: false,\n /**\n * Cursor style for the control line.\n *\n * In styled mode use class `highcharts-axis-resizer` instead.\n *\n * @requires modules/drag-panes\n */\n cursor: 'ns-resize',\n /**\n * Color of the control line.\n *\n * In styled mode use class `highcharts-axis-resizer` instead.\n *\n * @sample {highstock} stock/yaxis/styled-resizer\n * Styled resizer\n *\n * @type {Highcharts.ColorString}\n * @requires modules/drag-panes\n */\n lineColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * Dash style of the control line.\n *\n * In styled mode use class `highcharts-axis-resizer` instead.\n *\n * @see For supported options check [dashStyle](#plotOptions.series.dashStyle)\n *\n * @sample {highstock} stock/yaxis/styled-resizer\n * Styled resizer\n *\n * @requires modules/drag-panes\n */\n lineDashStyle: 'Solid',\n /**\n * Width of the control line.\n *\n * In styled mode use class `highcharts-axis-resizer` instead.\n *\n * @sample {highstock} stock/yaxis/styled-resizer\n * Styled resizer\n *\n * @requires modules/drag-panes\n */\n lineWidth: 4,\n /**\n * Horizontal offset of the control line.\n *\n * @sample {highstock} stock/yaxis/styled-resizer\n * Styled resizer\n *\n * @requires modules/drag-panes\n */\n x: 0,\n /**\n * Vertical offset of the control line.\n *\n * @sample {highstock} stock/yaxis/styled-resizer\n * Styled resizer\n *\n * @requires modules/drag-panes\n */\n y: 0\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return AxisResizerDefaults;\n });\n _registerModule(_modules, 'Extensions/DragPanes/AxisResizer.js', [_modules['Extensions/DragPanes/AxisResizerDefaults.js'], _modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (AxisResizerDefaults, H, U) {\n /* *\n *\n * Plugin for resizing axes / panes in a chart.\n *\n * (c) 2010-2023 Highsoft AS\n *\n * Author: Kacper Madej\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { hasTouch } = H;\n const { addEvent, clamp, isNumber, merge, objectEach, relativeLength, wrap } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The AxisResizer class.\n *\n * @private\n * @class\n * @name Highcharts.AxisResizer\n *\n * @param {Highcharts.Axis} axis\n * Main axis for the AxisResizer.\n */\n class AxisResizer {\n /* *\n *\n * Constructor\n *\n * */\n constructor(axis) {\n /* *\n *\n * Properties\n *\n * */\n this.axis = void 0;\n this.controlLine = void 0;\n this.lastPos = void 0;\n this.options = void 0;\n this.init(axis);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the AxisResizer object.\n *\n * @function Highcharts.AxisResizer#init\n *\n * @param {Highcharts.Axis} axis\n * Main axis for the AxisResizer.\n */\n init(axis, update) {\n this.axis = axis;\n this.options = axis.options.resize;\n this.render();\n if (!update) {\n // Add mouse events.\n this.addMouseEvents();\n }\n }\n /**\n * Render the AxisResizer\n *\n * @function Highcharts.AxisResizer#render\n */\n render() {\n const resizer = this, axis = resizer.axis, chart = axis.chart, options = resizer.options, x = options.x || 0, y = options.y, \n // Normalize control line position according to the plot area\n pos = clamp(axis.top + axis.height + y, chart.plotTop, chart.plotTop + chart.plotHeight);\n let attr = {};\n if (!chart.styledMode) {\n attr = {\n cursor: options.cursor,\n stroke: options.lineColor,\n 'stroke-width': options.lineWidth,\n dashstyle: options.lineDashStyle\n };\n }\n // Register current position for future reference.\n resizer.lastPos = pos - y;\n if (!resizer.controlLine) {\n resizer.controlLine = chart.renderer.path()\n .addClass('highcharts-axis-resizer');\n }\n // Add to axisGroup after axis update, because the group is recreated\n // Do .add() before path is calculated because strokeWidth() needs it.\n resizer.controlLine.add(axis.axisGroup);\n const lineWidth = chart.styledMode ?\n resizer.controlLine.strokeWidth() :\n options.lineWidth;\n attr.d = chart.renderer.crispLine([\n ['M', axis.left + x, pos],\n ['L', axis.left + axis.width + x, pos]\n ], lineWidth);\n resizer.controlLine.attr(attr);\n }\n /**\n * Set up the mouse and touch events for the control line.\n *\n * @function Highcharts.AxisResizer#addMouseEvents\n */\n addMouseEvents() {\n const resizer = this, ctrlLineElem = resizer.controlLine.element, container = resizer.axis.chart.container, eventsToUnbind = [];\n let mouseMoveHandler, mouseUpHandler, mouseDownHandler;\n // Create mouse events' handlers.\n // Make them as separate functions to enable wrapping them:\n resizer.mouseMoveHandler = mouseMoveHandler = function (e) {\n resizer.onMouseMove(e);\n };\n resizer.mouseUpHandler = mouseUpHandler = function (e) {\n resizer.onMouseUp(e);\n };\n resizer.mouseDownHandler = mouseDownHandler = function (e) {\n resizer.onMouseDown(e);\n };\n // Add mouse move and mouseup events. These are bind to doc/container,\n // because resizer.grabbed flag is stored in mousedown events.\n eventsToUnbind.push(addEvent(container, 'mousemove', mouseMoveHandler), addEvent(container.ownerDocument, 'mouseup', mouseUpHandler), addEvent(ctrlLineElem, 'mousedown', mouseDownHandler));\n // Touch events.\n if (hasTouch) {\n eventsToUnbind.push(addEvent(container, 'touchmove', mouseMoveHandler), addEvent(container.ownerDocument, 'touchend', mouseUpHandler), addEvent(ctrlLineElem, 'touchstart', mouseDownHandler));\n }\n resizer.eventsToUnbind = eventsToUnbind;\n }\n /**\n * Mouse move event based on x/y mouse position.\n *\n * @function Highcharts.AxisResizer#onMouseMove\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event.\n */\n onMouseMove(e) {\n /*\n * In iOS, a mousemove event with e.pageX === 0 is fired when holding\n * the finger down in the center of the scrollbar. This should\n * be ignored. Borrowed from Navigator.\n */\n if (!e.touches || e.touches[0].pageX !== 0) {\n // Drag the control line\n if (this.grabbed) {\n this.hasDragged = true;\n this.updateAxes(this.axis.chart.pointer.normalize(e).chartY -\n this.options.y);\n }\n }\n }\n /**\n * Mouse up event based on x/y mouse position.\n *\n * @function Highcharts.AxisResizer#onMouseUp\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event.\n */\n onMouseUp(e) {\n if (this.hasDragged) {\n this.updateAxes(this.axis.chart.pointer.normalize(e).chartY -\n this.options.y);\n }\n // Restore runPointActions.\n this.grabbed = this.hasDragged = this.axis.chart.activeResizer =\n null;\n }\n /**\n * Mousedown on a control line.\n * Will store necessary information for drag&drop.\n *\n * @function Highcharts.AxisResizer#onMouseDown\n */\n onMouseDown(e) {\n // Clear all hover effects.\n this.axis.chart.pointer.reset(false, 0);\n // Disable runPointActions.\n this.grabbed = this.axis.chart.activeResizer = true;\n }\n /**\n * Update all connected axes after a change of control line position\n *\n * @function Highcharts.AxisResizer#updateAxes\n *\n * @param {number} chartY\n */\n updateAxes(chartY) {\n const resizer = this, chart = resizer.axis.chart, axes = resizer.options.controlledAxis, nextAxes = axes.next.length === 0 ?\n [chart.yAxis.indexOf(resizer.axis) + 1] : axes.next, \n // Main axis is included in the prev array by default\n prevAxes = [resizer.axis].concat(axes.prev), \n // prev and next configs\n axesConfigs = [], plotTop = chart.plotTop, plotHeight = chart.plotHeight, plotBottom = plotTop + plotHeight, calculatePercent = function (value) {\n return value * 100 / plotHeight + '%';\n }, normalize = function (val, min, max) {\n return Math.round(clamp(val, min, max));\n };\n // Normalize chartY to plot area limits\n chartY = clamp(chartY, plotTop, plotBottom);\n let stopDrag = false, yDelta = chartY - resizer.lastPos;\n // Update on changes of at least 1 pixel in the desired direction\n if (yDelta * yDelta < 1) {\n return;\n }\n // First gather info how axes should behave\n [prevAxes, nextAxes].forEach((axesGroup, isNext) => {\n axesGroup.forEach((axisInfo, i) => {\n // Axes given as array index, axis object or axis id\n const axis = isNumber(axisInfo) ?\n // If it's a number - it's an index\n chart.yAxis[axisInfo] :\n (\n // If it's first elem. in first group\n (!isNext && !i) ?\n // then it's an Axis object\n axisInfo :\n // else it should be an id\n chart.get(axisInfo)), axisOptions = axis && axis.options, optionsToUpdate = {};\n let height, top;\n // Skip if axis is not found\n // or it is navigator's yAxis (#7732)\n if (!axisOptions ||\n axisOptions.id === 'navigator-y-axis') {\n return;\n }\n top = axis.top;\n const minLength = Math.round(relativeLength(axisOptions.minLength, plotHeight)), maxLength = Math.round(relativeLength(axisOptions.maxLength, plotHeight));\n if (isNext) {\n // Try to change height first. yDelta could had changed\n yDelta = chartY - resizer.lastPos;\n // Normalize height to option limits\n height = normalize(axis.len - yDelta, minLength, maxLength);\n // Adjust top, so the axis looks like shrinked from top\n top = axis.top + yDelta;\n // Check for plot area limits\n if (top + height > plotBottom) {\n const hDelta = plotBottom - height - top;\n chartY += hDelta;\n top += hDelta;\n }\n // Fit to plot - when overflowing on top\n if (top < plotTop) {\n top = plotTop;\n if (top + height > plotBottom) {\n height = plotHeight;\n }\n }\n // If next axis meets min length, stop dragging:\n if (height === minLength) {\n stopDrag = true;\n }\n axesConfigs.push({\n axis: axis,\n options: {\n top: calculatePercent(top - plotTop),\n height: calculatePercent(height)\n }\n });\n }\n else {\n // Normalize height to option limits\n height = normalize(chartY - top, minLength, maxLength);\n // If prev axis meets max length, stop dragging:\n if (height === maxLength) {\n stopDrag = true;\n }\n // Check axis size limits\n chartY = top + height;\n axesConfigs.push({\n axis: axis,\n options: {\n height: calculatePercent(height)\n }\n });\n }\n optionsToUpdate.height = height;\n });\n });\n // If we hit the min/maxLength with dragging, don't do anything:\n if (!stopDrag) {\n // Now update axes:\n axesConfigs.forEach(function (config) {\n config.axis.update(config.options, false);\n });\n chart.redraw(false);\n }\n }\n /**\n * Destroy AxisResizer. Clear outside references, clear events,\n * destroy elements, nullify properties.\n *\n * @function Highcharts.AxisResizer#destroy\n */\n destroy() {\n const resizer = this, axis = resizer.axis;\n // Clear resizer in axis\n delete axis.resizer;\n // Clear control line events\n if (this.eventsToUnbind) {\n this.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n }\n // Destroy AxisResizer elements\n resizer.controlLine.destroy();\n // Nullify properties\n objectEach(resizer, function (val, key) {\n resizer[key] = null;\n });\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n // Default options for AxisResizer.\n AxisResizer.resizerOptions = AxisResizerDefaults;\n /* *\n *\n * Default Export\n *\n * */\n\n return AxisResizer;\n });\n _registerModule(_modules, 'Extensions/DragPanes/DragPanes.js', [_modules['Extensions/DragPanes/AxisResizer.js'], _modules['Core/Utilities.js']], function (AxisResizer, U) {\n /* *\n *\n * Plugin for resizing axes / panes in a chart.\n *\n * (c) 2010-2021 Highsoft AS\n *\n * Author: Kacper Madej\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, merge, wrap } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AxisClass, PointerClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n merge(true, AxisClass.defaultOptions, AxisResizer.resizerOptions);\n // Keep resizer reference on axis update\n AxisClass.keepProps.push('resizer');\n addEvent(AxisClass, 'afterRender', onAxisAfterRender);\n addEvent(AxisClass, 'destroy', onAxisDestroy);\n }\n if (U.pushUnique(composedMembers, PointerClass)) {\n wrap(PointerClass.prototype, 'runPointActions', wrapPointerRunPointActions);\n wrap(PointerClass.prototype, 'drag', wrapPointerDrag);\n }\n }\n /**\n * Add new AxisResizer, update or remove it\n * @private\n */\n function onAxisAfterRender() {\n let axis = this, resizer = axis.resizer, resizerOptions = axis.options.resize, enabled;\n if (resizerOptions) {\n enabled = resizerOptions.enabled !== false;\n if (resizer) {\n // Resizer present and enabled\n if (enabled) {\n // Update options\n resizer.init(axis, true);\n // Resizer present, but disabled\n }\n else {\n // Destroy the resizer\n resizer.destroy();\n }\n }\n else {\n // Resizer not present and enabled\n if (enabled) {\n // Add new resizer\n axis.resizer = new AxisResizer(axis);\n }\n // Resizer not present and disabled, so do nothing\n }\n }\n }\n /**\n * Clear resizer on axis remove.\n * @private\n */\n function onAxisDestroy(e) {\n if (!e.keepEvents && this.resizer) {\n this.resizer.destroy();\n }\n }\n /**\n * Prevent default drag action detection while dragging a control line of\n * AxisResizer. (#7563)\n * @private\n */\n function wrapPointerDrag(proceed) {\n if (!this.chart.activeResizer) {\n proceed.apply(this, Array.prototype.slice.call(arguments, 1));\n }\n }\n /**\n * Prevent any hover effects while dragging a control line of AxisResizer.\n * @private\n */\n function wrapPointerRunPointActions(proceed) {\n if (!this.chart.activeResizer) {\n proceed.apply(this, Array.prototype.slice.call(arguments, 1));\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const DragPanes = {\n compose\n };\n\n return DragPanes;\n });\n _registerModule(_modules, 'masters/modules/drag-panes.src.js', [_modules['Core/Globals.js'], _modules['Extensions/DragPanes/AxisResizer.js'], _modules['Extensions/DragPanes/DragPanes.js']], function (Highcharts, AxisResizer, DragPanes) {\n\n const G = Highcharts;\n G.AxisResizer = AxisResizer;\n DragPanes.compose(G.Axis, G.Pointer);\n\n });\n}));","/**\n * @license Highstock JS v11.1.0 (2023-06-05)\n *\n * Advanced Highcharts Stock tools\n *\n * (c) 2010-2021 Highsoft AS\n * Author: Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/modules/full-screen', ['highcharts'], function (Highcharts) {\n factory(Highcharts);\n factory.Highcharts = Highcharts;\n return factory;\n });\n } else {\n factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);\n }\n}(function (Highcharts) {\n 'use strict';\n var _modules = Highcharts ? Highcharts._modules : {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Extensions/Exporting/Fullscreen.js', [_modules['Core/Renderer/HTML/AST.js'], _modules['Core/Utilities.js']], function (AST, U) {\n /* *\n *\n * (c) 2009-2021 Rafal Sebestjanski\n *\n * Full screen for Highcharts\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /**\n * The module allows user to enable display chart in full screen mode.\n * Used in StockTools too.\n * Based on default solutions in browsers.\n */\n /* *\n *\n * Imports\n *\n * */\n const { addEvent, fireEvent } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function onChartBeforeRender() {\n /**\n * @name Highcharts.Chart#fullscreen\n * @type {Highcharts.Fullscreen}\n * @requires modules/full-screen\n */\n this.fullscreen = new Fullscreen(this);\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Handles displaying chart's container in the fullscreen mode.\n *\n * **Note**: Fullscreen is not supported on iPhone due to iOS limitations.\n *\n * @class\n * @name Highcharts.Fullscreen\n *\n * @requires modules/exporting\n */\n class Fullscreen {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * Prepares the chart class to support fullscreen.\n *\n * @param {typeof_Highcharts.Chart} ChartClass\n * The chart class to decorate with fullscreen support.\n */\n static compose(ChartClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n // Initialize fullscreen\n addEvent(ChartClass, 'beforeRender', onChartBeforeRender);\n }\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(chart) {\n /**\n * Chart managed by the fullscreen controller.\n * @name Highcharts.Fullscreen#chart\n * @type {Highcharts.Chart}\n */\n this.chart = chart;\n /**\n * The flag is set to `true` when the chart is displayed in\n * the fullscreen mode.\n *\n * @name Highcharts.Fullscreen#isOpen\n * @type {boolean|undefined}\n * @since 8.0.1\n */\n this.isOpen = false;\n const container = chart.renderTo;\n // Hold event and methods available only for a current browser.\n if (!this.browserProps) {\n if (typeof container.requestFullscreen === 'function') {\n this.browserProps = {\n fullscreenChange: 'fullscreenchange',\n requestFullscreen: 'requestFullscreen',\n exitFullscreen: 'exitFullscreen'\n };\n }\n else if (container.mozRequestFullScreen) {\n this.browserProps = {\n fullscreenChange: 'mozfullscreenchange',\n requestFullscreen: 'mozRequestFullScreen',\n exitFullscreen: 'mozCancelFullScreen'\n };\n }\n else if (container.webkitRequestFullScreen) {\n this.browserProps = {\n fullscreenChange: 'webkitfullscreenchange',\n requestFullscreen: 'webkitRequestFullScreen',\n exitFullscreen: 'webkitExitFullscreen'\n };\n }\n else if (container.msRequestFullscreen) {\n this.browserProps = {\n fullscreenChange: 'MSFullscreenChange',\n requestFullscreen: 'msRequestFullscreen',\n exitFullscreen: 'msExitFullscreen'\n };\n }\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Stops displaying the chart in fullscreen mode.\n * Exporting module required.\n *\n * @since 8.0.1\n *\n * @function Highcharts.Fullscreen#close\n * @return {void}\n * @requires modules/full-screen\n */\n close() {\n const fullscreen = this, chart = fullscreen.chart, optionsChart = chart.options.chart;\n fireEvent(chart, 'fullscreenClose', null, function () {\n // Don't fire exitFullscreen() when user exited\n // using 'Escape' button.\n if (fullscreen.isOpen &&\n fullscreen.browserProps &&\n chart.container.ownerDocument instanceof Document) {\n chart.container.ownerDocument[fullscreen.browserProps.exitFullscreen]();\n }\n // Unbind event as it's necessary only before exiting\n // from fullscreen.\n if (fullscreen.unbindFullscreenEvent) {\n fullscreen.unbindFullscreenEvent = fullscreen\n .unbindFullscreenEvent();\n }\n chart.setSize(fullscreen.origWidth, fullscreen.origHeight, false);\n fullscreen.origWidth = void 0;\n fullscreen.origHeight = void 0;\n optionsChart.width = fullscreen.origWidthOption;\n optionsChart.height = fullscreen.origHeightOption;\n fullscreen.origWidthOption = void 0;\n fullscreen.origHeightOption = void 0;\n fullscreen.isOpen = false;\n fullscreen.setButtonText();\n });\n }\n /**\n * Displays the chart in fullscreen mode.\n * When fired customly by user before exporting context button is created,\n * button's text will not be replaced - it's on the user side.\n * Exporting module required.\n *\n * @since 8.0.1\n *\n * @function Highcharts.Fullscreen#open\n * @return {void}\n * @requires modules/full-screen\n */\n open() {\n const fullscreen = this, chart = fullscreen.chart, optionsChart = chart.options.chart;\n fireEvent(chart, 'fullscreenOpen', null, function () {\n if (optionsChart) {\n fullscreen.origWidthOption = optionsChart.width;\n fullscreen.origHeightOption = optionsChart.height;\n }\n fullscreen.origWidth = chart.chartWidth;\n fullscreen.origHeight = chart.chartHeight;\n // Handle exitFullscreen() method when user clicks 'Escape' button.\n if (fullscreen.browserProps) {\n const unbindChange = addEvent(chart.container.ownerDocument, // chart's document\n fullscreen.browserProps.fullscreenChange, function () {\n // Handle lack of async of browser's\n // fullScreenChange event.\n if (fullscreen.isOpen) {\n fullscreen.isOpen = false;\n fullscreen.close();\n }\n else {\n chart.setSize(null, null, false);\n fullscreen.isOpen = true;\n fullscreen.setButtonText();\n }\n });\n const unbindDestroy = addEvent(chart, 'destroy', unbindChange);\n fullscreen.unbindFullscreenEvent = () => {\n unbindChange();\n unbindDestroy();\n };\n const promise = chart.renderTo[fullscreen.browserProps.requestFullscreen]();\n if (promise) {\n promise['catch'](function () {\n alert(// eslint-disable-line no-alert\n 'Full screen is not supported inside a frame.');\n });\n }\n }\n });\n }\n /**\n * Replaces the exporting context button's text when toogling the\n * fullscreen mode.\n *\n * @private\n *\n * @since 8.0.1\n *\n * @requires modules/full-screen\n */\n setButtonText() {\n const chart = this.chart, exportDivElements = chart.exportDivElements, exportingOptions = chart.options.exporting, menuItems = (exportingOptions &&\n exportingOptions.buttons &&\n exportingOptions.buttons.contextButton.menuItems), lang = chart.options.lang;\n if (exportingOptions &&\n exportingOptions.menuItemDefinitions &&\n lang &&\n lang.exitFullscreen &&\n lang.viewFullscreen &&\n menuItems &&\n exportDivElements) {\n const exportDivElement = exportDivElements[menuItems.indexOf('viewFullscreen')];\n if (exportDivElement) {\n AST.setElementHTML(exportDivElement, !this.isOpen ?\n (exportingOptions.menuItemDefinitions.viewFullscreen\n .text ||\n lang.viewFullscreen) : lang.exitFullscreen);\n }\n }\n }\n /**\n * Toggles displaying the chart in fullscreen mode.\n * By default, when the exporting module is enabled, a context button with\n * a drop down menu in the upper right corner accesses this function.\n * Exporting module required.\n *\n * @since 8.0.1\n *\n * @sample highcharts/members/chart-togglefullscreen/\n * Toggle fullscreen mode from a HTML button\n *\n * @function Highcharts.Fullscreen#toggle\n * @requires modules/full-screen\n */\n toggle() {\n const fullscreen = this;\n if (!fullscreen.isOpen) {\n fullscreen.open();\n }\n else {\n fullscreen.close();\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * Gets fired when closing the fullscreen\n *\n * @callback Highcharts.FullScreenfullscreenCloseCallbackFunction\n *\n * @param {Highcharts.Chart} chart\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n /**\n * Gets fired when opening the fullscreen\n *\n * @callback Highcharts.FullScreenfullscreenOpenCallbackFunction\n *\n * @param {Highcharts.Chart} chart\n * The chart on which the event occured.\n *\n * @param {global.Event} event\n * The event that occured.\n */\n (''); // keeps doclets above separated from following code\n /* *\n *\n * API Options\n *\n * */\n /**\n * Fires when a fullscreen is closed through the context menu item,\n * or a fullscreen is closed on the `Escape` button click,\n * or the `Chart.fullscreen.close` method.\n *\n * @sample highcharts/chart/events-fullscreen\n * Title size change on fullscreen open\n *\n * @type {Highcharts.FullScreenfullscreenCloseCallbackFunction}\n * @since 10.1.0\n * @context Highcharts.Chart\n * @requires modules/full-screen\n * @apioption chart.events.fullscreenClose\n */\n /**\n * Fires when a fullscreen is opened through the context menu item,\n * or the `Chart.fullscreen.open` method.\n *\n * @sample highcharts/chart/events-fullscreen\n * Title size change on fullscreen open\n *\n * @type {Highcharts.FullScreenfullscreenOpenCallbackFunction}\n * @since 10.1.0\n * @context Highcharts.Chart\n * @requires modules/full-screen\n * @apioption chart.events.fullscreenOpen\n */\n (''); // keeps doclets above in transpiled file\n\n return Fullscreen;\n });\n _registerModule(_modules, 'masters/modules/full-screen.src.js', [_modules['Core/Globals.js'], _modules['Extensions/Exporting/Fullscreen.js']], function (Highcharts, Fullscreen) {\n\n const G = Highcharts;\n G.Fullscreen = Fullscreen;\n Fullscreen.compose(G.Chart);\n\n });\n}));","/**\n * @license Highstock JS v11.1.0 (2023-06-05)\n *\n * Advanced Highcharts Stock tools\n *\n * (c) 2010-2021 Highsoft AS\n * Author: Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/modules/price-indicator', ['highcharts', 'highcharts/modules/stock'], function (Highcharts) {\n factory(Highcharts);\n factory.Highcharts = Highcharts;\n return factory;\n });\n } else {\n factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);\n }\n}(function (Highcharts) {\n 'use strict';\n var _modules = Highcharts ? Highcharts._modules : {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Extensions/PriceIndication.js', [_modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (Series, U) {\n /**\n * (c) 2009-2021 Sebastian Bochann\n *\n * Price indicator for Highcharts\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n */\n const { addEvent, isArray, merge } = U;\n /**\n * The line marks the last price from visible range of points.\n *\n * @sample {highstock} stock/indicators/last-visible-price\n * Last visible price\n *\n * @declare Highcharts.SeriesLastVisiblePriceOptionsObject\n * @product highstock\n * @requires modules/price-indicator\n * @apioption plotOptions.series.lastVisiblePrice\n */\n /**\n * Enable or disable the indicator.\n *\n * @type {boolean}\n * @product highstock\n * @default false\n * @apioption plotOptions.series.lastVisiblePrice.enabled\n */\n /**\n * @declare Highcharts.SeriesLastVisiblePriceLabelOptionsObject\n * @extends yAxis.crosshair.label\n * @since 7.0.0\n * @apioption plotOptions.series.lastVisiblePrice.label\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastVisiblePrice.label.align\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastVisiblePrice.label.backgroundColor\n */\n /**\n * The border color for the `lastVisiblePrice` label.\n *\n * @type {Highcharts.ColorType}\n * @since 7.0.0\n * @product highstock\n * @apioption plotOptions.series.lastVisiblePrice.label.borderColor\n */\n /**\n * The border corner radius of the `lastVisiblePrice` label.\n *\n * @type {number}\n * @default 3\n * @since 7.0.0\n * @product highstock\n * @apioption plotOptions.series.lastVisiblePrice.label.borderRadius\n */\n /**\n * Flag to enable `lastVisiblePrice` label.\n *\n *\n * @type {boolean}\n * @default false\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastVisiblePrice.label.enabled\n */\n /**\n * A format string for the `lastVisiblePrice` label. Defaults to `{value}` for\n * numeric axes and `{value:%b %d, %Y}` for datetime axes.\n *\n * @type {string}\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastVisiblePrice.label.format\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastVisiblePrice.label.formatter\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastVisiblePrice.label.padding\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastVisiblePrice.label.shape\n */\n /**\n * Text styles for the `lastVisiblePrice` label.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"white\", \"fontWeight\": \"normal\", \"fontSize\": \"11px\", \"textAlign\": \"center\"}\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastVisiblePrice.label.style\n */\n /**\n * The border width for the `lastVisiblePrice` label.\n *\n * @type {number}\n * @default 0\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastVisiblePrice.label.borderWidth\n */\n /**\n * Padding inside the `lastVisiblePrice` label.\n *\n * @type {number}\n * @default 8\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastVisiblePrice.label.padding\n */\n /**\n * The line marks the last price from all points.\n *\n * @sample {highstock} stock/indicators/last-price\n * Last price\n *\n * @declare Highcharts.SeriesLastPriceOptionsObject\n * @product highstock\n * @requires modules/price-indicator\n * @apioption plotOptions.series.lastPrice\n */\n /**\n * Enable or disable the indicator.\n *\n * @type {boolean}\n * @product highstock\n * @default false\n * @apioption plotOptions.series.lastPrice.enabled\n */\n /**\n * @declare Highcharts.SeriesLastPriceLabelOptionsObject\n * @extends yAxis.crosshair.label\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.align\n * */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.backgroundColor\n * */\n /**\n * The border color of `lastPrice` label.\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.borderColor\n * */\n /**\n * The border radius of `lastPrice` label.\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.borderRadius\n * */\n /**\n * The border width of `lastPrice` label.\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.borderWidth\n * */\n /**\n * Flag to enable `lastPrice` label.\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.enabled\n * */\n /**\n * A format string for the `lastPrice` label. Defaults to `{value}` for\n * numeric axes and `{value:%b %d, %Y}` for datetime axes.\n *\n * @type {string}\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastPrice.label.format\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.formatter\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.padding\n */\n /**\n * @since 7.0.0\n * @apioption plotOptions.series.lastPrice.label.shape\n */\n /**\n * Text styles for the `lastPrice` label.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"color\": \"white\", \"fontWeight\": \"normal\", \"fontSize\": \"11px\", \"textAlign\": \"center\"}\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastPrice.label.style\n */\n /**\n * The border width for the `lastPrice` label.\n *\n * @type {number}\n * @default 0\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastPrice.label.borderWidth\n */\n /**\n * Padding inside the `lastPrice` label.\n *\n * @type {number}\n * @default 8\n * @since 7.0\n * @product highstock\n * @apioption plotOptions.series.lastPrice.label.padding\n */\n /**\n * The color of the line of last price.\n * By default, the line has the same color as the series.\n *\n * @type {string}\n * @product highstock\n * @apioption plotOptions.series.lastPrice.color\n *\n */\n /* eslint-disable no-invalid-this */\n addEvent(Series, 'afterRender', function () {\n const series = this, seriesOptions = series.options, lastVisiblePrice = seriesOptions.lastVisiblePrice, lastPrice = seriesOptions.lastPrice;\n if ((lastVisiblePrice || lastPrice) &&\n seriesOptions.id !== 'highcharts-navigator-series') {\n let xAxis = series.xAxis, yAxis = series.yAxis, origOptions = yAxis.crosshair, origGraphic = yAxis.cross, origLabel = yAxis.crossLabel, points = series.points, yLength = series.yData.length, pLength = points.length, x = series.xData[series.xData.length - 1], y = series.yData[yLength - 1], yValue;\n if (lastPrice && lastPrice.enabled) {\n yAxis.crosshair = yAxis.options.crosshair = seriesOptions.lastPrice;\n if (!series.chart.styledMode &&\n yAxis.crosshair &&\n yAxis.options.crosshair &&\n seriesOptions.lastPrice) {\n // Set the default color from the series, #14888.\n yAxis.crosshair.color = yAxis.options.crosshair.color =\n seriesOptions.lastPrice.color || series.color;\n }\n yAxis.cross = series.lastPrice;\n yValue = isArray(y) ? y[3] : y;\n if (series.lastPriceLabel) {\n series.lastPriceLabel.destroy();\n }\n delete yAxis.crossLabel;\n yAxis.drawCrosshair(null, ({\n x: x,\n y: yValue,\n plotX: xAxis.toPixels(x, true),\n plotY: yAxis.toPixels(yValue, true)\n }));\n // Save price\n if (series.yAxis.cross) {\n series.lastPrice = series.yAxis.cross;\n series.lastPrice.addClass('highcharts-color-' + series.colorIndex); // #15222\n series.lastPrice.y = yValue;\n }\n series.lastPriceLabel = yAxis.crossLabel;\n }\n if (lastVisiblePrice && lastVisiblePrice.enabled && pLength > 0) {\n yAxis.crosshair = yAxis.options.crosshair = merge({\n color: 'transparent' // line invisible by default\n }, seriesOptions.lastVisiblePrice);\n yAxis.cross = series.lastVisiblePrice;\n const lastPoint = points[pLength - 1].isInside ?\n points[pLength - 1] : points[pLength - 2];\n if (series.lastVisiblePriceLabel) {\n series.lastVisiblePriceLabel.destroy();\n }\n // Set to undefined to avoid collision with\n // the yAxis crosshair #11480\n // Delete the crossLabel each time the code is invoked, #13876.\n delete yAxis.crossLabel;\n // Save price\n yAxis.drawCrosshair(null, lastPoint);\n if (yAxis.cross) {\n series.lastVisiblePrice = yAxis.cross;\n if (lastPoint && typeof lastPoint.y === 'number') {\n series.lastVisiblePrice.y = lastPoint.y;\n }\n }\n series.lastVisiblePriceLabel = yAxis.crossLabel;\n }\n // Restore crosshair:\n yAxis.crosshair = yAxis.options.crosshair = origOptions;\n yAxis.cross = origGraphic;\n yAxis.crossLabel = origLabel;\n }\n });\n\n });\n _registerModule(_modules, 'masters/modules/price-indicator.src.js', [], function () {\n\n\n });\n}));","/**\n * @license Highstock JS v11.1.0 (2023-06-05)\n *\n * Advanced Highcharts Stock tools\n *\n * (c) 2010-2021 Highsoft AS\n * Author: Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/modules/stock-tools', ['highcharts', 'highcharts/modules/stock'], function (Highcharts) {\n factory(Highcharts);\n factory.Highcharts = Highcharts;\n return factory;\n });\n } else {\n factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);\n }\n}(function (Highcharts) {\n 'use strict';\n var _modules = Highcharts ? Highcharts._modules : {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Core/Chart/ChartNavigationComposition.js', [], function () {\n /**\n *\n * (c) 2010-2021 Paweł Fus\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Composition\n *\n * */\n var ChartNavigationComposition;\n (function (ChartNavigationComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(chart) {\n if (!chart.navigation) {\n chart.navigation = new Additions(chart);\n }\n return chart;\n }\n ChartNavigationComposition.compose = compose;\n /* *\n *\n * Class\n *\n * */\n /**\n * Initializes `chart.navigation` object which delegates `update()` methods\n * to all other common classes (used in exporting and navigationBindings).\n * @private\n */\n class Additions {\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart) {\n this.updates = [];\n this.chart = chart;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Registers an `update()` method in the `chart.navigation` object.\n *\n * @private\n * @param {UpdateFunction} updateFn\n * The `update()` method that will be called in `chart.update()`.\n */\n addUpdate(updateFn) {\n this.chart.navigation.updates.push(updateFn);\n }\n /**\n * @private\n */\n update(options, redraw) {\n this.updates.forEach((updateFn) => {\n updateFn.call(this.chart, options, redraw);\n });\n }\n }\n ChartNavigationComposition.Additions = Additions;\n })(ChartNavigationComposition || (ChartNavigationComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return ChartNavigationComposition;\n });\n _registerModule(_modules, 'Extensions/Annotations/NavigationBindingsUtilities.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defined, isNumber, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n /**\n * Define types for editable fields per annotation. There is no need to define\n * numbers, because they won't change their type to string.\n * @private\n */\n const annotationsFieldsTypes = {\n backgroundColor: 'string',\n borderColor: 'string',\n borderRadius: 'string',\n color: 'string',\n fill: 'string',\n fontSize: 'string',\n labels: 'string',\n name: 'string',\n stroke: 'string',\n title: 'string'\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * Returns the first xAxis or yAxis that was clicked with its value.\n *\n * @private\n *\n * @param {Array} coords\n * All the chart's x or y axes with a current pointer's axis value.\n *\n * @return {Highcharts.PointerAxisCoordinateObject}\n * Object with a first found axis and its value that pointer\n * is currently pointing.\n */\n function getAssignedAxis(coords) {\n return coords.filter((coord) => {\n const extremes = coord.axis.getExtremes(), axisMin = extremes.min, axisMax = extremes.max, \n // Correct axis edges when axis has series\n // with pointRange (like column)\n minPointOffset = pick(coord.axis.minPointOffset, 0);\n return isNumber(axisMin) && isNumber(axisMax) &&\n coord.value >= (axisMin - minPointOffset) &&\n coord.value <= (axisMax + minPointOffset) &&\n // don't count navigator axis\n !coord.axis.options.isInternal;\n })[0]; // If the axes overlap, return the first axis that was found.\n }\n /**\n * Get field type according to value\n *\n * @private\n *\n * @param {'boolean'|'number'|'string'} value\n * Atomic type (one of: string, number, boolean)\n *\n * @return {'checkbox'|'number'|'text'}\n * Field type (one of: text, number, checkbox)\n */\n function getFieldType(key, value) {\n const predefinedType = annotationsFieldsTypes[key];\n let fieldType = typeof value;\n if (defined(predefinedType)) {\n fieldType = predefinedType;\n }\n return {\n 'string': 'text',\n 'number': 'number',\n 'boolean': 'checkbox'\n }[fieldType];\n }\n /* *\n *\n * Default Export\n *\n * */\n const NavigationBindingUtilities = {\n annotationsFieldsTypes,\n getAssignedAxis,\n getFieldType\n };\n\n return NavigationBindingUtilities;\n });\n _registerModule(_modules, 'Extensions/Annotations/NavigationBindingsDefaults.js', [_modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Core/Utilities.js']], function (NBU, U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getAssignedAxis } = NBU;\n const { isNumber, merge } = U;\n /* *\n *\n * Constants\n *\n * */\n /**\n * @optionparent lang\n */\n const lang = {\n /**\n * Configure the Popup strings in the chart. Requires the\n * `annotations.js` or `annotations-advanced.src.js` module to be\n * loaded.\n * @since 7.0.0\n * @product highcharts highstock\n */\n navigation: {\n /**\n * Translations for all field names used in popup.\n *\n * @product highcharts highstock\n */\n popup: {\n simpleShapes: 'Simple shapes',\n lines: 'Lines',\n circle: 'Circle',\n ellipse: 'Ellipse',\n rectangle: 'Rectangle',\n label: 'Label',\n shapeOptions: 'Shape options',\n typeOptions: 'Details',\n fill: 'Fill',\n format: 'Text',\n strokeWidth: 'Line width',\n stroke: 'Line color',\n title: 'Title',\n name: 'Name',\n labelOptions: 'Label options',\n labels: 'Labels',\n backgroundColor: 'Background color',\n backgroundColors: 'Background colors',\n borderColor: 'Border color',\n borderRadius: 'Border radius',\n borderWidth: 'Border width',\n style: 'Style',\n padding: 'Padding',\n fontSize: 'Font size',\n color: 'Color',\n height: 'Height',\n shapes: 'Shape options'\n }\n }\n };\n /**\n * @optionparent navigation\n * @product highcharts highstock\n */\n const navigation = {\n /**\n * A CSS class name where all bindings will be attached to. Multiple\n * charts on the same page should have separate class names to prevent\n * duplicating events.\n *\n * Default value of versions < 7.0.4 `highcharts-bindings-wrapper`\n *\n * @since 7.0.0\n * @type {string}\n */\n bindingsClassName: 'highcharts-bindings-container',\n /**\n * Bindings definitions for custom HTML buttons. Each binding implements\n * simple event-driven interface:\n *\n * - `className`: classname used to bind event to\n *\n * - `init`: initial event, fired on button click\n *\n * - `start`: fired on first click on a chart\n *\n * - `steps`: array of sequential events fired one after another on each\n * of users clicks\n *\n * - `end`: last event to be called after last step event\n *\n * @type {Highcharts.Dictionary|*}\n *\n * @sample {highstock} stock/stocktools/stocktools-thresholds\n * Custom bindings\n * @sample {highcharts} highcharts/annotations/bindings/\n * Simple binding\n * @sample {highcharts} highcharts/annotations/bindings-custom-annotation/\n * Custom annotation binding\n *\n * @since 7.0.0\n * @requires modules/annotations\n * @product highcharts highstock\n */\n bindings: {\n /**\n * A circle annotation bindings. Includes `start` and one event in\n * `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-circle-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n circleAnnotation: {\n /** @ignore-option */\n className: 'highcharts-circle-annotation',\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis), navigation = this.chart.options.navigation;\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n return this.chart.addAnnotation(merge({\n langKey: 'circle',\n type: 'basicAnnotation',\n shapes: [{\n type: 'circle',\n point: {\n x: coordsX.value,\n y: coordsY.value,\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index\n },\n r: 5\n }]\n }, navigation.annotationsOptions, navigation.bindings.circleAnnotation\n .annotationsOptions));\n },\n /** @ignore-option */\n steps: [\n function (e, annotation) {\n const shapes = annotation.options.shapes, mockPointOpts = ((shapes && shapes[0] && shapes[0].point) ||\n {});\n let distance;\n if (isNumber(mockPointOpts.xAxis) &&\n isNumber(mockPointOpts.yAxis)) {\n const inverted = this.chart.inverted, x = this.chart.xAxis[mockPointOpts.xAxis]\n .toPixels(mockPointOpts.x), y = this.chart.yAxis[mockPointOpts.yAxis]\n .toPixels(mockPointOpts.y);\n distance = Math.max(Math.sqrt(Math.pow(inverted ? y - e.chartX : x - e.chartX, 2) +\n Math.pow(inverted ? x - e.chartY : y - e.chartY, 2)), 5);\n }\n annotation.update({\n shapes: [{\n r: distance\n }]\n });\n }\n ]\n },\n /**\n * A ellipse annotation bindings. Includes `start` and two events in\n * `steps` array. First updates the second point, responsible for a\n * rx width, and second updates the ry width.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-ellipse-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n ellipseAnnotation: {\n className: 'highcharts-ellipse-annotation',\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis), navigation = this.chart.options.navigation;\n if (!coordsX || !coordsY) {\n return;\n }\n return this.chart.addAnnotation(merge({\n langKey: 'ellipse',\n type: 'basicAnnotation',\n shapes: [\n {\n type: 'ellipse',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }],\n ry: 1\n }\n ]\n }, navigation.annotationsOptions, navigation.bindings.ellipseAnnotation\n .annotationOptions));\n },\n steps: [\n function (e, annotation) {\n const target = annotation.shapes[0], position = target.getAbsolutePosition(target.points[1]);\n target.translatePoint(e.chartX - position.x, e.chartY - position.y, 1);\n target.redraw(false);\n },\n function (e, annotation) {\n const target = annotation.shapes[0], position = target.getAbsolutePosition(target.points[0]), position2 = target.getAbsolutePosition(target.points[1]), newR = target.getDistanceFromLine(position, position2, e.chartX, e.chartY), yAxis = target.getYAxis(), newRY = Math.abs(yAxis.toValue(0) - yAxis.toValue(newR));\n target.setYRadius(newRY);\n target.redraw(false);\n }\n ]\n },\n /**\n * A rectangle annotation bindings. Includes `start` and one event\n * in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-rectangle-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n rectangleAnnotation: {\n /** @ignore-option */\n className: 'highcharts-rectangle-annotation',\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, xAxis = coordsX.axis.index, yAxis = coordsY.axis.index, navigation = this.chart.options.navigation;\n return this.chart.addAnnotation(merge({\n langKey: 'rectangle',\n type: 'basicAnnotation',\n shapes: [{\n type: 'path',\n points: [\n { xAxis, yAxis, x, y },\n { xAxis, yAxis, x, y },\n { xAxis, yAxis, x, y },\n { xAxis, yAxis, x, y },\n { command: 'Z' }\n ]\n }]\n }, navigation\n .annotationsOptions, navigation\n .bindings\n .rectangleAnnotation\n .annotationsOptions));\n },\n /** @ignore-option */\n steps: [\n function (e, annotation) {\n const shapes = annotation.options.shapes, points = ((shapes && shapes[0] && shapes[0].points) ||\n []), coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n if (coordsX && coordsY) {\n const x = coordsX.value, y = coordsY.value;\n // Top right point\n points[1].x = x;\n // Bottom right point (cursor position)\n points[2].x = x;\n points[2].y = y;\n // Bottom left\n points[3].y = y;\n annotation.update({\n shapes: [{\n points: points\n }]\n });\n }\n }\n ]\n },\n /**\n * A label annotation bindings. Includes `start` event only.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @default {\"className\": \"highcharts-label-annotation\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n labelAnnotation: {\n /** @ignore-option */\n className: 'highcharts-label-annotation',\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis), navigation = this.chart.options.navigation;\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n return this.chart.addAnnotation(merge({\n langKey: 'label',\n type: 'basicAnnotation',\n labelOptions: {\n format: '{y:.2f}'\n },\n labels: [{\n point: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n x: coordsX.value,\n y: coordsY.value\n },\n overflow: 'none',\n crop: true\n }]\n }, navigation\n .annotationsOptions, navigation\n .bindings\n .labelAnnotation\n .annotationsOptions));\n }\n }\n },\n /**\n * Path where Highcharts will look for icons. Change this to use icons\n * from a different server.\n *\n * @type {string}\n * @default https://code.highcharts.com/11.1.0/gfx/stock-icons/\n * @since 7.1.3\n * @apioption navigation.iconsURL\n */\n /**\n * A `showPopup` event. Fired when selecting for example an annotation.\n *\n * @type {Function}\n * @apioption navigation.events.showPopup\n */\n /**\n * A `closePopup` event. Fired when Popup should be hidden, for example\n * when clicking on an annotation again.\n *\n * @type {Function}\n * @apioption navigation.events.closePopup\n */\n /**\n * Event fired on a button click.\n *\n * @type {Function}\n * @sample highcharts/annotations/gui/\n * Change icon in a dropddown on event\n * @sample highcharts/annotations/gui-buttons/\n * Change button class on event\n * @apioption navigation.events.selectButton\n */\n /**\n * Event fired when button state should change, for example after\n * adding an annotation.\n *\n * @type {Function}\n * @sample highcharts/annotations/gui/\n * Change icon in a dropddown on event\n * @sample highcharts/annotations/gui-buttons/\n * Change button class on event\n * @apioption navigation.events.deselectButton\n */\n /**\n * Events to communicate between Stock Tools and custom GUI.\n *\n * @since 7.0.0\n * @product highcharts highstock\n * @optionparent navigation.events\n */\n events: {},\n /**\n * Additional options to be merged into all annotations.\n *\n * @sample stock/stocktools/navigation-annotation-options\n * Set red color of all line annotations\n *\n * @type {Highcharts.AnnotationsOptions}\n * @extends annotations\n * @exclude crookedLine, elliottWave, fibonacci, infinityLine,\n * measure, pitchfork, tunnel, verticalLine, basicAnnotation\n * @requires modules/annotations\n * @apioption navigation.annotationsOptions\n */\n annotationsOptions: {\n animation: {\n defer: 0\n }\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n const NavigationBindingDefaults = {\n lang,\n navigation\n };\n\n return NavigationBindingDefaults;\n });\n _registerModule(_modules, 'Extensions/Annotations/NavigationBindings.js', [_modules['Core/Chart/ChartNavigationComposition.js'], _modules['Core/Defaults.js'], _modules['Core/Templating.js'], _modules['Core/Globals.js'], _modules['Extensions/Annotations/NavigationBindingsDefaults.js'], _modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Core/Utilities.js']], function (ChartNavigationComposition, D, F, H, NavigationBindingDefaults, NBU, U) {\n /* *\n *\n * (c) 2009-2021 Highsoft, Black Label\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { setOptions } = D;\n const { format } = F;\n const { doc, win } = H;\n const { getFieldType } = NBU;\n const { addEvent, attr, defined, fireEvent, isArray, isFunction, isNumber, isObject, merge, objectEach, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * IE 9-11 polyfill for Element.closest():\n * @private\n */\n function closestPolyfill(el, s) {\n const ElementProto = win.Element.prototype, elementMatches = ElementProto.matches ||\n ElementProto.msMatchesSelector ||\n ElementProto.webkitMatchesSelector;\n let ret = null;\n if (ElementProto.closest) {\n ret = ElementProto.closest.call(el, s);\n }\n else {\n do {\n if (elementMatches.call(el, s)) {\n return el;\n }\n el = el.parentElement || el.parentNode;\n } while (el !== null && el.nodeType === 1);\n }\n return ret;\n }\n /**\n * @private\n */\n function onAnnotationRemove() {\n if (this.chart.navigationBindings) {\n this.chart.navigationBindings.deselectAnnotation();\n }\n }\n /**\n * @private\n */\n function onChartDestroy() {\n if (this.navigationBindings) {\n this.navigationBindings.destroy();\n }\n }\n /**\n * @private\n */\n function onChartLoad() {\n const options = this.options;\n if (options && options.navigation && options.navigation.bindings) {\n this.navigationBindings = new NavigationBindings(this, options.navigation);\n this.navigationBindings.initEvents();\n this.navigationBindings.initUpdate();\n }\n }\n /**\n * @private\n */\n function onChartRender() {\n const navigationBindings = this.navigationBindings, disabledClassName = 'highcharts-disabled-btn';\n if (this && navigationBindings) {\n // Check if the buttons should be enabled/disabled based on\n // visible series.\n let buttonsEnabled = false;\n this.series.forEach((series) => {\n if (!series.options.isInternal && series.visible) {\n buttonsEnabled = true;\n }\n });\n if (this.navigationBindings &&\n this.navigationBindings.container &&\n this.navigationBindings.container[0]) {\n const container = this.navigationBindings.container[0];\n objectEach(navigationBindings.boundClassNames, (value, key) => {\n // Get the HTML element coresponding to the className taken\n // from StockToolsBindings.\n const buttonNode = container.querySelectorAll('.' + key);\n if (buttonNode) {\n for (let i = 0; i < buttonNode.length; i++) {\n const button = buttonNode[i], cls = button.className;\n if (value.noDataState === 'normal') {\n // If button has noDataState: 'normal', and has\n // disabledClassName, remove this className.\n if (cls.indexOf(disabledClassName) !== -1) {\n button.classList.remove(disabledClassName);\n }\n }\n else if (!buttonsEnabled) {\n if (cls.indexOf(disabledClassName) === -1) {\n button.className += ' ' + disabledClassName;\n }\n }\n else {\n // Enable all buttons by deleting the className.\n if (cls.indexOf(disabledClassName) !== -1) {\n button.classList.remove(disabledClassName);\n }\n }\n }\n }\n });\n }\n }\n }\n /**\n * @private\n */\n function onNavigationBindingsClosePopup() {\n this.deselectAnnotation();\n }\n /**\n * @private\n */\n function onNavigationBindingsDeselectButton() {\n this.selectedButtonElement = null;\n }\n /**\n * Show edit-annotation form:\n * @private\n */\n function selectableAnnotation(annotationType) {\n const originalClick = annotationType.prototype.defaultOptions.events &&\n annotationType.prototype.defaultOptions.events.click;\n /**\n * Select and show popup\n * @private\n */\n function selectAndShowPopup(eventArguments) {\n const annotation = this, navigation = annotation.chart.navigationBindings, prevAnnotation = navigation.activeAnnotation;\n if (originalClick) {\n originalClick.call(annotation, eventArguments);\n }\n if (prevAnnotation !== annotation) {\n // Select current:\n navigation.deselectAnnotation();\n navigation.activeAnnotation = annotation;\n annotation.setControlPointsVisibility(true);\n fireEvent(navigation, 'showPopup', {\n annotation: annotation,\n formType: 'annotation-toolbar',\n options: navigation.annotationToFields(annotation),\n onSubmit: function (data) {\n if (data.actionType === 'remove') {\n navigation.activeAnnotation = false;\n navigation.chart.removeAnnotation(annotation);\n }\n else {\n const config = {};\n navigation.fieldsToOptions(data.fields, config);\n navigation.deselectAnnotation();\n const typeOptions = config.typeOptions;\n if (annotation.options.type === 'measure') {\n // Manually disable crooshars according to\n // stroke width of the shape:\n typeOptions.crosshairY.enabled = (typeOptions.crosshairY\n .strokeWidth !== 0);\n typeOptions.crosshairX.enabled = (typeOptions.crosshairX\n .strokeWidth !== 0);\n }\n annotation.update(config);\n }\n }\n });\n }\n else {\n // Deselect current:\n fireEvent(navigation, 'closePopup');\n }\n // Let bubble event to chart.click:\n eventArguments.activeAnnotation = true;\n }\n // #18276, show popup on touchend, but not on touchmove\n let touchStartX, touchStartY;\n function saveCoords(e) {\n touchStartX = e.touches[0].clientX;\n touchStartY = e.touches[0].clientY;\n }\n function checkForTouchmove(e) {\n const hasMoved = touchStartX ? Math.sqrt(Math.pow(touchStartX - e.changedTouches[0].clientX, 2) +\n Math.pow(touchStartY - e.changedTouches[0].clientY, 2)) >= 4 : false;\n if (!hasMoved) {\n selectAndShowPopup.call(this, e);\n }\n }\n merge(true, annotationType.prototype.defaultOptions.events, {\n click: selectAndShowPopup,\n touchstart: saveCoords,\n touchend: checkForTouchmove\n });\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n */\n class NavigationBindings {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AnnotationClass, ChartClass) {\n if (U.pushUnique(composedMembers, AnnotationClass)) {\n addEvent(AnnotationClass, 'remove', onAnnotationRemove);\n // Basic shapes:\n selectableAnnotation(AnnotationClass);\n // Advanced annotations:\n objectEach(AnnotationClass.types, (annotationType) => {\n selectableAnnotation(annotationType);\n });\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'destroy', onChartDestroy);\n addEvent(ChartClass, 'load', onChartLoad);\n addEvent(ChartClass, 'render', onChartRender);\n }\n if (U.pushUnique(composedMembers, NavigationBindings)) {\n addEvent(NavigationBindings, 'closePopup', onNavigationBindingsClosePopup);\n addEvent(NavigationBindings, 'deselectButton', onNavigationBindingsDeselectButton);\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n setOptions(NavigationBindingDefaults);\n }\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart, options) {\n this.boundClassNames = void 0;\n this.selectedButton = void 0;\n this.chart = chart;\n this.options = options;\n this.eventsToUnbind = [];\n this.container =\n this.chart.container.getElementsByClassName(this.options.bindingsClassName || '');\n if (!this.container.length) {\n this.container = doc.getElementsByClassName(this.options.bindingsClassName || '');\n }\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initi all events conencted to NavigationBindings.\n *\n * @private\n * @function Highcharts.NavigationBindings#initEvents\n */\n initEvents() {\n const navigation = this, chart = navigation.chart, bindingsContainer = navigation.container, options = navigation.options;\n // Shorthand object for getting events for buttons:\n navigation.boundClassNames = {};\n objectEach((options.bindings || {}), (value) => {\n navigation.boundClassNames[value.className] = value;\n });\n // Handle multiple containers with the same class names:\n [].forEach.call(bindingsContainer, (subContainer) => {\n navigation.eventsToUnbind.push(addEvent(subContainer, 'click', (event) => {\n const bindings = navigation.getButtonEvents(subContainer, event);\n if (bindings &&\n (!bindings.button.classList\n .contains('highcharts-disabled-btn'))) {\n navigation.bindingsButtonClick(bindings.button, bindings.events, event);\n }\n }));\n });\n objectEach((options.events || {}), (callback, eventName) => {\n if (isFunction(callback)) {\n navigation.eventsToUnbind.push(addEvent(navigation, eventName, callback, { passive: false }));\n }\n });\n navigation.eventsToUnbind.push(addEvent(chart.container, 'click', function (e) {\n if (!chart.cancelClick &&\n chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop, {\n visiblePlotOnly: true\n })) {\n navigation.bindingsChartClick(this, e);\n }\n }));\n navigation.eventsToUnbind.push(addEvent(chart.container, H.isTouchDevice ? 'touchmove' : 'mousemove', function (e) {\n navigation.bindingsContainerMouseMove(this, e);\n }, H.isTouchDevice ? { passive: false } : void 0));\n }\n /**\n * Common chart.update() delegation, shared between bindings and exporting.\n *\n * @private\n * @function Highcharts.NavigationBindings#initUpdate\n */\n initUpdate() {\n const navigation = this;\n ChartNavigationComposition\n .compose(this.chart).navigation\n .addUpdate((options) => {\n navigation.update(options);\n });\n }\n /**\n * Hook for click on a button, method selcts/unselects buttons,\n * then calls `bindings.init` callback.\n *\n * @private\n * @function Highcharts.NavigationBindings#bindingsButtonClick\n *\n * @param {Highcharts.HTMLDOMElement} [button]\n * Clicked button\n *\n * @param {Object} events\n * Events passed down from bindings (`init`, `start`, `step`, `end`)\n *\n * @param {Highcharts.PointerEventObject} clickEvent\n * Browser's click event\n */\n bindingsButtonClick(button, events, clickEvent) {\n const navigation = this, chart = navigation.chart, svgContainer = chart.renderer.boxWrapper;\n let shouldEventBeFired = true;\n if (navigation.selectedButtonElement) {\n if (navigation.selectedButtonElement.classList === button.classList) {\n shouldEventBeFired = false;\n }\n fireEvent(navigation, 'deselectButton', { button: navigation.selectedButtonElement });\n if (navigation.nextEvent) {\n // Remove in-progress annotations adders:\n if (navigation.currentUserDetails &&\n navigation.currentUserDetails.coll === 'annotations') {\n chart.removeAnnotation(navigation.currentUserDetails);\n }\n navigation.mouseMoveEvent = navigation.nextEvent = false;\n }\n }\n if (shouldEventBeFired) {\n navigation.selectedButton = events;\n navigation.selectedButtonElement = button;\n fireEvent(navigation, 'selectButton', { button: button });\n // Call \"init\" event, for example to open modal window\n if (events.init) {\n events.init.call(navigation, button, clickEvent);\n }\n if (events.start || events.steps) {\n chart.renderer.boxWrapper.addClass('highcharts-draw-mode');\n }\n }\n else {\n chart.stockTools &&\n chart.stockTools.toggleButtonActiveClass(button);\n svgContainer.removeClass('highcharts-draw-mode');\n navigation.nextEvent = false;\n navigation.mouseMoveEvent = false;\n navigation.selectedButton = null;\n }\n }\n /**\n * Hook for click on a chart, first click on a chart calls `start` event,\n * then on all subsequent clicks iterate over `steps` array.\n * When finished, calls `end` event.\n *\n * @private\n * @function Highcharts.NavigationBindings#bindingsChartClick\n *\n * @param {Highcharts.Chart} chart\n * Chart that click was performed on.\n *\n * @param {Highcharts.PointerEventObject} clickEvent\n * Browser's click event.\n */\n bindingsChartClick(chart, clickEvent) {\n chart = this.chart;\n const navigation = this, activeAnnotation = navigation.activeAnnotation, selectedButton = navigation.selectedButton, svgContainer = chart.renderer.boxWrapper;\n if (activeAnnotation) {\n // Click outside popups, should close them and deselect the\n // annotation\n if (!activeAnnotation.cancelClick && // #15729\n !clickEvent.activeAnnotation &&\n // Element could be removed in the child action, e.g. button\n clickEvent.target.parentNode &&\n // TO DO: Polyfill for IE11?\n !closestPolyfill(clickEvent.target, '.highcharts-popup')) {\n fireEvent(navigation, 'closePopup');\n }\n else if (activeAnnotation.cancelClick) {\n // Reset cancelClick after the other event handlers have run\n setTimeout(() => {\n activeAnnotation.cancelClick = false;\n }, 0);\n }\n }\n if (!selectedButton || !selectedButton.start) {\n return;\n }\n if (!navigation.nextEvent) {\n // Call init method:\n navigation.currentUserDetails = selectedButton.start.call(navigation, clickEvent);\n // If steps exists (e.g. Annotations), bind them:\n if (navigation.currentUserDetails && selectedButton.steps) {\n navigation.stepIndex = 0;\n navigation.steps = true;\n navigation.mouseMoveEvent = navigation.nextEvent =\n selectedButton.steps[navigation.stepIndex];\n }\n else {\n fireEvent(navigation, 'deselectButton', { button: navigation.selectedButtonElement });\n svgContainer.removeClass('highcharts-draw-mode');\n navigation.steps = false;\n navigation.selectedButton = null;\n // First click is also the last one:\n if (selectedButton.end) {\n selectedButton.end.call(navigation, clickEvent, navigation.currentUserDetails);\n }\n }\n }\n else {\n navigation.nextEvent(clickEvent, navigation.currentUserDetails);\n if (navigation.steps) {\n navigation.stepIndex++;\n if (selectedButton.steps[navigation.stepIndex]) {\n // If we have more steps, bind them one by one:\n navigation.mouseMoveEvent = navigation.nextEvent = selectedButton.steps[navigation.stepIndex];\n }\n else {\n fireEvent(navigation, 'deselectButton', { button: navigation.selectedButtonElement });\n svgContainer.removeClass('highcharts-draw-mode');\n // That was the last step, call end():\n if (selectedButton.end) {\n selectedButton.end.call(navigation, clickEvent, navigation.currentUserDetails);\n }\n navigation.nextEvent = false;\n navigation.mouseMoveEvent = false;\n navigation.selectedButton = null;\n }\n }\n }\n }\n /**\n * Hook for mouse move on a chart's container. It calls current step.\n *\n * @private\n * @function Highcharts.NavigationBindings#bindingsContainerMouseMove\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Chart's container.\n *\n * @param {global.Event} moveEvent\n * Browser's move event.\n */\n bindingsContainerMouseMove(_container, moveEvent) {\n if (this.mouseMoveEvent) {\n this.mouseMoveEvent(moveEvent, this.currentUserDetails);\n }\n }\n /**\n * Translate fields (e.g. `params.period` or `marker.styles.color`) to\n * Highcharts options object (e.g. `{ params: { period } }`).\n *\n * @private\n * @function Highcharts.NavigationBindings#fieldsToOptions\n *\n * @param {Highcharts.Dictionary} fields\n * Fields from popup form.\n *\n * @param {T} config\n * Default config to be modified.\n *\n * @return {T}\n * Modified config\n */\n fieldsToOptions(fields, config) {\n objectEach(fields, (value, field) => {\n const parsedValue = parseFloat(value), path = field.split('.'), pathLength = path.length - 1;\n // If it's a number (not \"format\" options), parse it:\n if (isNumber(parsedValue) &&\n !value.match(/px|em/g) &&\n !field.match(/format/g)) {\n value = parsedValue;\n }\n // Remove values like 0\n if (value !== 'undefined') {\n let parent = config;\n path.forEach((name, index) => {\n const nextName = pick(path[index + 1], '');\n if (pathLength === index) {\n // Last index, put value:\n parent[name] = value;\n }\n else if (!parent[name]) {\n // Create middle property:\n parent[name] = nextName.match(/\\d/g) ? [] : {};\n parent = parent[name];\n }\n else {\n // Jump into next property\n parent = parent[name];\n }\n });\n }\n });\n return config;\n }\n /**\n * Shorthand method to deselect an annotation.\n *\n * @function Highcharts.NavigationBindings#deselectAnnotation\n */\n deselectAnnotation() {\n if (this.activeAnnotation) {\n this.activeAnnotation.setControlPointsVisibility(false);\n this.activeAnnotation = false;\n }\n }\n /**\n * Generates API config for popup in the same format as options for\n * Annotation object.\n *\n * @function Highcharts.NavigationBindings#annotationToFields\n *\n * @param {Highcharts.Annotation} annotation\n * Annotations object\n *\n * @return {Highcharts.Dictionary}\n * Annotation options to be displayed in popup box\n */\n annotationToFields(annotation) {\n const options = annotation.options, editables = NavigationBindings.annotationsEditable, nestedEditables = editables.nestedOptions, type = pick(options.type, options.shapes && options.shapes[0] &&\n options.shapes[0].type, options.labels && options.labels[0] &&\n options.labels[0].type, 'label'), nonEditables = NavigationBindings.annotationsNonEditable[options.langKey] || [], visualOptions = {\n langKey: options.langKey,\n type: type\n };\n /**\n * Nested options traversing. Method goes down to the options and copies\n * allowed options (with values) to new object, which is last parameter:\n * \"parent\".\n *\n * @private\n *\n * @param {*} option\n * Atomic type or object/array\n *\n * @param {string} key\n * Option name, for example \"visible\" or \"x\", \"y\"\n *\n * @param {Object} parentEditables\n * Editables from NavigationBindings.annotationsEditable\n *\n * @param {Object} parent\n * Where new options will be assigned\n */\n function traverse(option, key, parentEditables, parent, parentKey) {\n let nextParent;\n if (parentEditables &&\n option &&\n nonEditables.indexOf(key) === -1 &&\n ((parentEditables.indexOf &&\n parentEditables.indexOf(key)) >= 0 ||\n parentEditables[key] || // nested array\n parentEditables === true // simple array\n )) {\n // Roots:\n if (isArray(option)) {\n parent[key] = [];\n option.forEach((arrayOption, i) => {\n if (!isObject(arrayOption)) {\n // Simple arrays, e.g. [String, Number, Boolean]\n traverse(arrayOption, 0, nestedEditables[key], parent[key], key);\n }\n else {\n // Advanced arrays, e.g. [Object, Object]\n parent[key][i] = {};\n objectEach(arrayOption, (nestedOption, nestedKey) => {\n traverse(nestedOption, nestedKey, nestedEditables[key], parent[key][i], key);\n });\n }\n });\n }\n else if (isObject(option)) {\n nextParent = {};\n if (isArray(parent)) {\n parent.push(nextParent);\n nextParent[key] = {};\n nextParent = nextParent[key];\n }\n else {\n parent[key] = nextParent;\n }\n objectEach(option, (nestedOption, nestedKey) => {\n traverse(nestedOption, nestedKey, key === 0 ?\n parentEditables :\n nestedEditables[key], nextParent, key);\n });\n }\n else {\n // Leaf:\n if (key === 'format') {\n parent[key] = [\n format(option, annotation.labels[0].points[0]).toString(),\n 'text'\n ];\n }\n else if (isArray(parent)) {\n parent.push([option, getFieldType(parentKey, option)]);\n }\n else {\n parent[key] = [option, getFieldType(key, option)];\n }\n }\n }\n }\n objectEach(options, (option, key) => {\n if (key === 'typeOptions') {\n visualOptions[key] = {};\n objectEach(options[key], (typeOption, typeKey) => {\n traverse(typeOption, typeKey, nestedEditables, visualOptions[key], typeKey);\n });\n }\n else {\n traverse(option, key, editables[type], visualOptions, key);\n }\n });\n return visualOptions;\n }\n /**\n * Get all class names for all parents in the element. Iterates until finds\n * main container.\n *\n * @private\n * @function Highcharts.NavigationBindings#getClickedClassNames\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Container that event is bound to.\n *\n * @param {global.Event} event\n * Browser's event.\n *\n * @return {Array>}\n * Array of class names with corresponding elements\n */\n getClickedClassNames(container, event) {\n let element = event.target, classNames = [], elemClassName;\n while (element && element.tagName) {\n elemClassName = attr(element, 'class');\n if (elemClassName) {\n classNames = classNames.concat(elemClassName\n .split(' ')\n // eslint-disable-next-line no-loop-func\n .map((name) => ([name, element])));\n }\n element = element.parentNode;\n if (element === container) {\n return classNames;\n }\n }\n return classNames;\n }\n /**\n * Get events bound to a button. It's a custom event delegation to find all\n * events connected to the element.\n *\n * @private\n * @function Highcharts.NavigationBindings#getButtonEvents\n *\n * @param {Highcharts.HTMLDOMElement} container\n * Container that event is bound to.\n *\n * @param {global.Event} event\n * Browser's event.\n *\n * @return {Object}\n * Object with events (init, start, steps, and end)\n */\n getButtonEvents(container, event) {\n const navigation = this, classNames = this.getClickedClassNames(container, event);\n let bindings;\n classNames.forEach((className) => {\n if (navigation.boundClassNames[className[0]] && !bindings) {\n bindings = {\n events: navigation.boundClassNames[className[0]],\n button: className[1]\n };\n }\n });\n return bindings;\n }\n /**\n * Bindings are just events, so the whole update process is simply\n * removing old events and adding new ones.\n *\n * @private\n * @function Highcharts.NavigationBindings#update\n */\n update(options) {\n this.options = merge(true, this.options, options);\n this.removeEvents();\n this.initEvents();\n }\n /**\n * Remove all events created in the navigation.\n *\n * @private\n * @function Highcharts.NavigationBindings#removeEvents\n */\n removeEvents() {\n this.eventsToUnbind.forEach((unbinder) => unbinder());\n }\n /**\n * @private\n * @function Highcharts.NavigationBindings#destroy\n */\n destroy() {\n this.removeEvents();\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n // Define which options from annotations should show up in edit box:\n NavigationBindings.annotationsEditable = {\n // `typeOptions` are always available\n // Nested and shared options:\n nestedOptions: {\n labelOptions: ['style', 'format', 'backgroundColor'],\n labels: ['style'],\n label: ['style'],\n style: ['fontSize', 'color'],\n background: ['fill', 'strokeWidth', 'stroke'],\n innerBackground: ['fill', 'strokeWidth', 'stroke'],\n outerBackground: ['fill', 'strokeWidth', 'stroke'],\n shapeOptions: ['fill', 'strokeWidth', 'stroke'],\n shapes: ['fill', 'strokeWidth', 'stroke'],\n line: ['strokeWidth', 'stroke'],\n backgroundColors: [true],\n connector: ['fill', 'strokeWidth', 'stroke'],\n crosshairX: ['strokeWidth', 'stroke'],\n crosshairY: ['strokeWidth', 'stroke']\n },\n // Simple shapes:\n circle: ['shapes'],\n ellipse: ['shapes'],\n verticalLine: [],\n label: ['labelOptions'],\n // Measure\n measure: ['background', 'crosshairY', 'crosshairX'],\n // Others:\n fibonacci: [],\n tunnel: ['background', 'line', 'height'],\n pitchfork: ['innerBackground', 'outerBackground'],\n rect: ['shapes'],\n // Crooked lines, elliots, arrows etc:\n crookedLine: [],\n basicAnnotation: ['shapes', 'labelOptions']\n };\n // Define non editable fields per annotation, for example Rectangle inherits\n // options from Measure, but crosshairs are not available\n NavigationBindings.annotationsNonEditable = {\n rectangle: ['crosshairX', 'crosshairY', 'labelOptions'],\n ellipse: ['labelOptions'],\n circle: ['labelOptions']\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * A config object for navigation bindings in annotations.\n *\n * @interface Highcharts.NavigationBindingsOptionsObject\n */ /**\n * ClassName of the element for a binding.\n * @name Highcharts.NavigationBindingsOptionsObject#className\n * @type {string|undefined}\n */ /**\n * Last event to be fired after last step event.\n * @name Highcharts.NavigationBindingsOptionsObject#end\n * @type {Function|undefined}\n */ /**\n * Initial event, fired on a button click.\n * @name Highcharts.NavigationBindingsOptionsObject#init\n * @type {Function|undefined}\n */ /**\n * Event fired on first click on a chart.\n * @name Highcharts.NavigationBindingsOptionsObject#start\n * @type {Function|undefined}\n */ /**\n * Last event to be fired after last step event. Array of step events to be\n * called sequentially after each user click.\n * @name Highcharts.NavigationBindingsOptionsObject#steps\n * @type {Array|undefined}\n */\n (''); // keeps doclets above in JS file\n\n return NavigationBindings;\n });\n _registerModule(_modules, 'Stock/StockTools/StockToolsUtilities.js', [_modules['Core/Defaults.js'], _modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (D, NBU, Series, U) {\n /**\n *\n * Events generator for Stock tools\n *\n * (c) 2009-2021 Paweł Fus\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getOptions } = D;\n const { getAssignedAxis, getFieldType } = NBU;\n const { defined, fireEvent, isNumber, uniqueKey } = U;\n /* *\n *\n * Constants\n *\n * */\n /**\n * @private\n */\n const indicatorsWithAxes = [\n 'apo',\n 'ad',\n 'aroon',\n 'aroonoscillator',\n 'atr',\n 'ao',\n 'cci',\n 'chaikin',\n 'cmf',\n 'cmo',\n 'disparityindex',\n 'dmi',\n 'dpo',\n 'linearRegressionAngle',\n 'linearRegressionIntercept',\n 'linearRegressionSlope',\n 'klinger',\n 'macd',\n 'mfi',\n 'momentum',\n 'natr',\n 'obv',\n 'ppo',\n 'roc',\n 'rsi',\n 'slowstochastic',\n 'stochastic',\n 'trix',\n 'williamsr'\n ];\n /**\n * @private\n */\n const indicatorsWithVolume = [\n 'ad',\n 'cmf',\n 'klinger',\n 'mfi',\n 'obv',\n 'vbp',\n 'vwap'\n ];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Generates function which will add a flag series using modal in GUI.\n * Method fires an event \"showPopup\" with config:\n * `{type, options, callback}`.\n *\n * Example: NavigationBindings.utils.addFlagFromForm('url(...)') - will\n * generate function that shows modal in GUI.\n *\n * @private\n * @function bindingsUtils.addFlagFromForm\n *\n * @param {Highcharts.FlagsShapeValue} type\n * Type of flag series, e.g. \"squarepin\"\n *\n * @return {Function}\n * Callback to be used in `start` callback\n */\n function addFlagFromForm(type) {\n return function (e) {\n const navigation = this, chart = navigation.chart, toolbar = chart.stockTools, point = attractToPoint(e, chart);\n if (!point) {\n return;\n }\n const pointConfig = {\n x: point.x,\n y: point.y\n };\n const seriesOptions = {\n type: 'flags',\n onSeries: point.series.id,\n shape: type,\n data: [pointConfig],\n xAxis: point.xAxis,\n yAxis: point.yAxis,\n point: {\n events: {\n click: function () {\n const point = this, options = point.options;\n fireEvent(navigation, 'showPopup', {\n point: point,\n formType: 'annotation-toolbar',\n options: {\n langKey: 'flags',\n type: 'flags',\n title: [\n options.title,\n getFieldType('title', options.title)\n ],\n name: [\n options.name,\n getFieldType('name', options.name)\n ]\n },\n onSubmit: function (updated) {\n if (updated.actionType === 'remove') {\n point.remove();\n }\n else {\n point.update(navigation.fieldsToOptions(updated.fields, {}));\n }\n }\n });\n }\n }\n }\n };\n if (!toolbar || !toolbar.guiEnabled) {\n chart.addSeries(seriesOptions);\n }\n fireEvent(navigation, 'showPopup', {\n formType: 'flag',\n // Enabled options:\n options: {\n langKey: 'flags',\n type: 'flags',\n title: ['A', getFieldType('label', 'A')],\n name: ['Flag A', getFieldType('label', 'Flag A')]\n },\n // Callback on submit:\n onSubmit: function (data) {\n navigation.fieldsToOptions(data.fields, seriesOptions.data[0]);\n chart.addSeries(seriesOptions);\n }\n });\n };\n }\n /**\n * @private\n * @todo\n * Consider using getHoverData(), but always kdTree (columns?)\n */\n function attractToPoint(e, chart) {\n const coords = chart.pointer.getCoordinates(e);\n let coordsX, coordsY, distX = Number.MAX_VALUE, closestPoint;\n if (chart.navigationBindings) {\n coordsX = getAssignedAxis(coords.xAxis);\n coordsY = getAssignedAxis(coords.yAxis);\n }\n // Exit if clicked out of axes area.\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value;\n const y = coordsY.value;\n // Search by 'x' but only in yAxis' series.\n coordsY.axis.series.forEach((series) => {\n if (series.points) {\n series.points.forEach((point) => {\n if (point && distX > Math.abs(point.x - x)) {\n distX = Math.abs(point.x - x);\n closestPoint = point;\n }\n });\n }\n });\n if (closestPoint && closestPoint.x && closestPoint.y) {\n return {\n x: closestPoint.x,\n y: closestPoint.y,\n below: y < closestPoint.y,\n series: closestPoint.series,\n xAxis: closestPoint.series.xAxis.index || 0,\n yAxis: closestPoint.series.yAxis.index || 0\n };\n }\n }\n /**\n * Shorthand to check if given yAxis comes from navigator.\n *\n * @private\n * @function bindingsUtils.isNotNavigatorYAxis\n *\n * @param {Highcharts.Axis} axis\n * Axis to check.\n *\n * @return {boolean}\n * True, if axis comes from navigator.\n */\n function isNotNavigatorYAxis(axis) {\n return axis.userOptions.className !== 'highcharts-navigator-yaxis';\n }\n /**\n * Check if any of the price indicators are enabled.\n * @private\n * @function bindingsUtils.isLastPriceEnabled\n *\n * @param {Array} series\n * Array of series.\n *\n * @return {boolean}\n * Tells which indicator is enabled.\n */\n function isPriceIndicatorEnabled(series) {\n return series.some((s) => s.lastVisiblePrice || s.lastPrice);\n }\n /**\n * @private\n */\n function manageIndicators(data) {\n const chart = this.chart, seriesConfig = {\n linkedTo: data.linkedTo,\n type: data.type\n };\n let yAxis, parentSeries, defaultOptions, series;\n if (data.actionType === 'edit') {\n this.fieldsToOptions(data.fields, seriesConfig);\n series = chart.get(data.seriesId);\n if (series) {\n series.update(seriesConfig, false);\n }\n }\n else if (data.actionType === 'remove') {\n series = chart.get(data.seriesId);\n if (series) {\n yAxis = series.yAxis;\n if (series.linkedSeries) {\n series.linkedSeries.forEach((linkedSeries) => {\n linkedSeries.remove(false);\n });\n }\n series.remove(false);\n if (indicatorsWithAxes.indexOf(series.type) >= 0) {\n const removedYAxisProps = {\n height: yAxis.options.height,\n top: yAxis.options.top\n };\n yAxis.remove(false);\n this.resizeYAxes(removedYAxisProps);\n }\n }\n }\n else {\n seriesConfig.id = uniqueKey();\n this.fieldsToOptions(data.fields, seriesConfig);\n parentSeries = chart.get(seriesConfig.linkedTo);\n defaultOptions = getOptions().plotOptions;\n // Make sure that indicator uses the SUM approx if SUM approx is used\n // by parent series (#13950).\n if (typeof parentSeries !== 'undefined' &&\n parentSeries instanceof Series &&\n parentSeries.getDGApproximation() === 'sum' &&\n // If indicator has defined approx type, use it (e.g. \"ranges\")\n !defined(defaultOptions && defaultOptions[seriesConfig.type] &&\n defaultOptions.dataGrouping &&\n defaultOptions.dataGrouping.approximation)) {\n seriesConfig.dataGrouping = {\n approximation: 'sum'\n };\n }\n if (indicatorsWithAxes.indexOf(data.type) >= 0) {\n yAxis = chart.addAxis({\n id: uniqueKey(),\n offset: 0,\n opposite: true,\n title: {\n text: ''\n },\n tickPixelInterval: 40,\n showLastLabel: false,\n labels: {\n align: 'left',\n y: -2\n }\n }, false, false);\n seriesConfig.yAxis = yAxis.options.id;\n this.resizeYAxes();\n }\n else {\n seriesConfig.yAxis = chart.get(data.linkedTo).options.yAxis;\n }\n if (indicatorsWithVolume.indexOf(data.type) >= 0) {\n seriesConfig.params.volumeSeriesID = chart.series.filter(function (series) {\n return series.options.type === 'column';\n })[0].options.id;\n }\n chart.addSeries(seriesConfig, false);\n }\n fireEvent(this, 'deselectButton', {\n button: this.selectedButtonElement\n });\n chart.redraw();\n }\n /**\n * Update height for an annotation. Height is calculated as a difference\n * between last point in `typeOptions` and current position. It's a value,\n * not pixels height.\n *\n * @private\n * @function bindingsUtils.updateHeight\n *\n * @param {Highcharts.PointerEventObject} e\n * normalized browser event\n *\n * @param {Highcharts.Annotation} annotation\n * Annotation to be updated\n */\n function updateHeight(e, annotation) {\n const options = annotation.options.typeOptions, yAxis = isNumber(options.yAxis) && this.chart.yAxis[options.yAxis];\n if (yAxis && options.points) {\n annotation.update({\n typeOptions: {\n height: yAxis.toValue(e[yAxis.horiz ? 'chartX' : 'chartY']) -\n (options.points[1].y || 0)\n }\n });\n }\n }\n /**\n * Update each point after specified index, most of the annotations use\n * this. For example crooked line: logic behind updating each point is the\n * same, only index changes when adding an annotation.\n *\n * Example: NavigationBindings.utils.updateNthPoint(1) - will generate\n * function that updates all consecutive points except point with index=0.\n *\n * @private\n * @function bindingsUtils.updateNthPoint\n *\n * @param {number} startIndex\n * Index from each point should udpated\n *\n * @return {Function}\n * Callback to be used in steps array\n */\n function updateNthPoint(startIndex) {\n return function (e, annotation) {\n const options = annotation.options.typeOptions, xAxis = isNumber(options.xAxis) && this.chart.xAxis[options.xAxis], yAxis = isNumber(options.yAxis) && this.chart.yAxis[options.yAxis];\n if (xAxis && yAxis) {\n options.points.forEach((point, index) => {\n if (index >= startIndex) {\n point.x = xAxis.toValue(e[xAxis.horiz ? 'chartX' : 'chartY']);\n point.y = yAxis.toValue(e[yAxis.horiz ? 'chartX' : 'chartY']);\n }\n });\n annotation.update({\n typeOptions: {\n points: options.points\n }\n });\n }\n };\n }\n /**\n * Update size of background (rect) in some annotations: Measure, Simple\n * Rect.\n *\n * @private\n * @function Highcharts.NavigationBindingsUtilsObject.updateRectSize\n *\n * @param {Highcharts.PointerEventObject} event\n * Normalized browser event\n *\n * @param {Highcharts.Annotation} annotation\n * Annotation to be updated\n */\n function updateRectSize(event, annotation) {\n const chart = annotation.chart, options = annotation.options.typeOptions, xAxis = isNumber(options.xAxis) && chart.xAxis[options.xAxis], yAxis = isNumber(options.yAxis) && chart.yAxis[options.yAxis];\n if (xAxis && yAxis) {\n const x = xAxis.toValue(event[xAxis.horiz ? 'chartX' : 'chartY']), y = yAxis.toValue(event[yAxis.horiz ? 'chartX' : 'chartY']), width = x - options.point.x, height = options.point.y - y;\n annotation.update({\n typeOptions: {\n background: {\n width: chart.inverted ? height : width,\n height: chart.inverted ? width : height\n }\n }\n });\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const StockToolsUtilities = {\n indicatorsWithAxes,\n indicatorsWithVolume,\n addFlagFromForm,\n attractToPoint,\n getAssignedAxis,\n isNotNavigatorYAxis,\n isPriceIndicatorEnabled,\n manageIndicators,\n updateHeight,\n updateNthPoint,\n updateRectSize\n };\n\n return StockToolsUtilities;\n });\n _registerModule(_modules, 'Stock/StockTools/StockToolsBindings.js', [_modules['Core/Globals.js'], _modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Stock/StockTools/StockToolsUtilities.js'], _modules['Core/Utilities.js']], function (H, NBU, STU, U) {\n /**\n *\n * Events generator for Stock tools\n *\n * (c) 2009-2021 Paweł Fus\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { getAssignedAxis } = NBU;\n const { addFlagFromForm, attractToPoint, isNotNavigatorYAxis, isPriceIndicatorEnabled, manageIndicators, updateHeight, updateNthPoint, updateRectSize } = STU;\n const { fireEvent, merge } = U;\n /* *\n *\n * Constants\n *\n * */\n /**\n * @sample {highstock} stock/stocktools/custom-stock-tools-bindings\n * Custom stock tools bindings\n *\n * @type {Highcharts.Dictionary}\n * @since 7.0.0\n * @optionparent navigation.bindings\n */\n const StockToolsBindings = {\n // Line type annotations:\n /**\n * A segment annotation bindings. Includes `start` and one event in `steps`\n * array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-segment\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n segment: {\n /** @ignore-option */\n className: 'highcharts-segment',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'segment',\n type: 'crookedLine',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.segment.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1)\n ]\n },\n /**\n * A segment with an arrow annotation bindings. Includes `start` and one\n * event in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-arrow-segment\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n arrowSegment: {\n /** @ignore-option */\n className: 'highcharts-arrow-segment',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'arrowSegment',\n type: 'crookedLine',\n typeOptions: {\n line: {\n markerEnd: 'arrow'\n },\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.arrowSegment.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1)\n ]\n },\n /**\n * A ray annotation bindings. Includes `start` and one event in `steps`\n * array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-ray\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n ray: {\n /** @ignore-option */\n className: 'highcharts-ray',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'ray',\n type: 'infinityLine',\n typeOptions: {\n type: 'ray',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.ray.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1)\n ]\n },\n /**\n * A ray with an arrow annotation bindings. Includes `start` and one event\n * in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-arrow-ray\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n arrowRay: {\n /** @ignore-option */\n className: 'highcharts-arrow-ray',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'arrowRay',\n type: 'infinityLine',\n typeOptions: {\n type: 'ray',\n line: {\n markerEnd: 'arrow'\n },\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.arrowRay.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1)\n ]\n },\n /**\n * A line annotation. Includes `start` and one event in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-infinity-line\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n infinityLine: {\n /** @ignore-option */\n className: 'highcharts-infinity-line',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'infinityLine',\n type: 'infinityLine',\n typeOptions: {\n type: 'line',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.infinityLine.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1)\n ]\n },\n /**\n * A line with arrow annotation. Includes `start` and one event in `steps`\n * array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-arrow-infinity-line\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n arrowInfinityLine: {\n /** @ignore-option */\n className: 'highcharts-arrow-infinity-line',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'arrowInfinityLine',\n type: 'infinityLine',\n typeOptions: {\n type: 'line',\n line: {\n markerEnd: 'arrow'\n },\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }, {\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.arrowInfinityLine\n .annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1)\n ]\n },\n /**\n * A horizontal line annotation. Includes `start` event.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-horizontal-line\", \"start\": function() {}, \"annotationsOptions\": {}}\n */\n horizontalLine: {\n /** @ignore-option */\n className: 'highcharts-horizontal-line',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'horizontalLine',\n type: 'infinityLine',\n draggable: 'y',\n typeOptions: {\n type: 'horizontalLine',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings\n .horizontalLine.annotationsOptions);\n this.chart.addAnnotation(options);\n }\n },\n /**\n * A vertical line annotation. Includes `start` event.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-vertical-line\", \"start\": function() {}, \"annotationsOptions\": {}}\n */\n verticalLine: {\n /** @ignore-option */\n className: 'highcharts-vertical-line',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'verticalLine',\n type: 'infinityLine',\n draggable: 'x',\n typeOptions: {\n type: 'verticalLine',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.verticalLine.annotationsOptions);\n this.chart.addAnnotation(options);\n }\n },\n /**\n * Crooked line (three points) annotation bindings. Includes `start` and two\n * events in `steps` (for second and third points in crooked line) array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-crooked3\", \"start\": function() {}, \"steps\": [function() {}, function() {}], \"annotationsOptions\": {}}\n */\n // Crooked Line type annotations:\n crooked3: {\n /** @ignore-option */\n className: 'highcharts-crooked3',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'crooked3',\n type: 'crookedLine',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [\n { x, y },\n { x, y },\n { x, y }\n ]\n }\n }, navigation.annotationsOptions, navigation.bindings.crooked3.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1),\n updateNthPoint(2)\n ]\n },\n /**\n * Crooked line (five points) annotation bindings. Includes `start` and four\n * events in `steps` (for all consequent points in crooked line) array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-crooked5\", \"start\": function() {}, \"steps\": [function() {}, function() {}, function() {}, function() {}], \"annotationsOptions\": {}}\n */\n crooked5: {\n /** @ignore-option */\n className: 'highcharts-crooked5',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'crooked5',\n type: 'crookedLine',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [\n { x, y },\n { x, y },\n { x, y },\n { x, y },\n { x, y }\n ]\n }\n }, navigation.annotationsOptions, navigation.bindings.crooked5.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1),\n updateNthPoint(2),\n updateNthPoint(3),\n updateNthPoint(4)\n ]\n },\n /**\n * Elliott wave (three points) annotation bindings. Includes `start` and two\n * events in `steps` (for second and third points) array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-elliott3\", \"start\": function() {}, \"steps\": [function() {}, function() {}], \"annotationsOptions\": {}}\n */\n elliott3: {\n /** @ignore-option */\n className: 'highcharts-elliott3',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'elliott3',\n type: 'elliottWave',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [\n { x, y },\n { x, y },\n { x, y },\n { x, y }\n ]\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n }\n }, navigation.annotationsOptions, navigation.bindings.elliott3.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1),\n updateNthPoint(2),\n updateNthPoint(3)\n ]\n },\n /**\n * Elliott wave (five points) annotation bindings. Includes `start` and four\n * event in `steps` (for all consequent points in Elliott wave) array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-elliott3\", \"start\": function() {}, \"steps\": [function() {}, function() {}, function() {}, function() {}], \"annotationsOptions\": {}}\n */\n elliott5: {\n /** @ignore-option */\n className: 'highcharts-elliott5',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'elliott5',\n type: 'elliottWave',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [\n { x, y },\n { x, y },\n { x, y },\n { x, y },\n { x, y },\n { x, y }\n ]\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n }\n }, navigation.annotationsOptions, navigation.bindings.elliott5.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1),\n updateNthPoint(2),\n updateNthPoint(3),\n updateNthPoint(4),\n updateNthPoint(5)\n ]\n },\n /**\n * A measure (x-dimension) annotation bindings. Includes `start` and one\n * event in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-measure-x\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n measureX: {\n /** @ignore-option */\n className: 'highcharts-measure-x',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'measure',\n type: 'measure',\n typeOptions: {\n selectType: 'x',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n point: { x, y },\n crosshairX: {\n strokeWidth: 1,\n stroke: \"#000000\" /* Palette.neutralColor100 */\n },\n crosshairY: {\n enabled: false,\n strokeWidth: 0,\n stroke: \"#000000\" /* Palette.neutralColor100 */\n },\n background: {\n width: 0,\n height: 0,\n strokeWidth: 0,\n stroke: \"#ffffff\" /* Palette.backgroundColor */\n }\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n }\n }, navigation.annotationsOptions, navigation.bindings.measureX.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateRectSize\n ]\n },\n /**\n * A measure (y-dimension) annotation bindings. Includes `start` and one\n * event in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-measure-y\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n measureY: {\n /** @ignore-option */\n className: 'highcharts-measure-y',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'measure',\n type: 'measure',\n typeOptions: {\n selectType: 'y',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n point: { x, y },\n crosshairX: {\n enabled: false,\n strokeWidth: 0,\n stroke: \"#000000\" /* Palette.neutralColor100 */\n },\n crosshairY: {\n strokeWidth: 1,\n stroke: \"#000000\" /* Palette.neutralColor100 */\n },\n background: {\n width: 0,\n height: 0,\n strokeWidth: 0,\n stroke: \"#ffffff\" /* Palette.backgroundColor */\n }\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n }\n }, navigation.annotationsOptions, navigation.bindings.measureY.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateRectSize\n ]\n },\n /**\n * A measure (xy-dimension) annotation bindings. Includes `start` and one\n * event in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-measure-xy\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n measureXY: {\n /** @ignore-option */\n className: 'highcharts-measure-xy',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'measure',\n type: 'measure',\n typeOptions: {\n selectType: 'xy',\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n point: { x, y },\n background: {\n width: 0,\n height: 0,\n strokeWidth: 10\n },\n crosshairX: {\n strokeWidth: 1,\n stroke: \"#000000\" /* Palette.neutralColor100 */\n },\n crosshairY: {\n strokeWidth: 1,\n stroke: \"#000000\" /* Palette.neutralColor100 */\n }\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n }\n }, navigation.annotationsOptions, navigation.bindings.measureXY.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateRectSize\n ]\n },\n // Advanced type annotations:\n /**\n * A fibonacci annotation bindings. Includes `start` and two events in\n * `steps` array (updates second point, then height).\n *\n * @sample {highstock} stock/stocktools/custom-stock-tools-bindings\n * Custom stock tools bindings\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-fibonacci\", \"start\": function() {}, \"steps\": [function() {}, function() {}], \"annotationsOptions\": {}}\n */\n fibonacci: {\n /** @ignore-option */\n className: 'highcharts-fibonacci',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'fibonacci',\n type: 'fibonacci',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [\n { x, y },\n { x, y }\n ]\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */\n }\n }\n }, navigation.annotationsOptions, navigation.bindings.fibonacci.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1),\n updateHeight\n ]\n },\n /**\n * A parallel channel (tunnel) annotation bindings. Includes `start` and\n * two events in `steps` array (updates second point, then height).\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-parallel-channel\", \"start\": function() {}, \"steps\": [function() {}, function() {}], \"annotationsOptions\": {}}\n */\n parallelChannel: {\n /** @ignore-option */\n className: 'highcharts-parallel-channel',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'parallelChannel',\n type: 'tunnel',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [\n { x, y },\n { x, y }\n ]\n }\n }, navigation.annotationsOptions, navigation.bindings.parallelChannel\n .annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1),\n updateHeight\n ]\n },\n /**\n * An Andrew's pitchfork annotation bindings. Includes `start` and two\n * events in `steps` array (sets second and third control points).\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-pitchfork\", \"start\": function() {}, \"steps\": [function() {}, function() {}], \"annotationsOptions\": {}}\n */\n pitchfork: {\n /** @ignore-option */\n className: 'highcharts-pitchfork',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const x = coordsX.value, y = coordsY.value, navigation = this.chart.options.navigation, options = merge({\n langKey: 'pitchfork',\n type: 'pitchfork',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value,\n y: coordsY.value,\n controlPoint: {\n style: {\n fill: \"#f21313\" /* Palette.negativeColor */\n }\n }\n },\n { x, y },\n { x, y }],\n innerBackground: {\n fill: 'rgba(100, 170, 255, 0.8)'\n }\n },\n shapeOptions: {\n strokeWidth: 2\n }\n }, navigation.annotationsOptions, navigation.bindings.pitchfork.annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n steps: [\n updateNthPoint(1),\n updateNthPoint(2)\n ]\n },\n // Labels with arrow and auto increments\n /**\n * A vertical counter annotation bindings. Includes `start` event. On click,\n * finds the closest point and marks it with a numeric annotation -\n * incrementing counter on each add.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-vertical-counter\", \"start\": function() {}, \"annotationsOptions\": {}}\n */\n verticalCounter: {\n /** @ignore-option */\n className: 'highcharts-vertical-counter',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const closestPoint = attractToPoint(e, this.chart);\n // Exit if clicked out of axes area\n if (!closestPoint) {\n return;\n }\n this.verticalCounter = this.verticalCounter || 0;\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'verticalCounter',\n type: 'verticalLine',\n typeOptions: {\n point: {\n x: closestPoint.x,\n y: closestPoint.y,\n xAxis: closestPoint.xAxis,\n yAxis: closestPoint.yAxis\n },\n label: {\n offset: closestPoint.below ? 40 : -40,\n text: this.verticalCounter.toString()\n }\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */,\n fontSize: '0.7em'\n }\n },\n shapeOptions: {\n stroke: 'rgba(0, 0, 0, 0.75)',\n strokeWidth: 1\n }\n }, navigation.annotationsOptions, navigation.bindings\n .verticalCounter.annotationsOptions), annotation = this.chart.addAnnotation(options);\n this.verticalCounter++;\n annotation.options.events.click.call(annotation, {});\n }\n },\n /**\n * A time cycles annotation bindings. Includes `start` event and 1 `step`\n * event. first click marks the beginning of the circle, and the second one\n * sets its diameter.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-time-cycles\", \"start\": function() {}, \"steps\": [function (){}] \"annotationsOptions\": {}}\n */\n timeCycles: {\n className: 'highcharts-time-cycles',\n start: function (e) {\n const closestPoint = attractToPoint(e, this.chart);\n // Exit if clicked out of axes area\n if (!closestPoint) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'timeCycles',\n type: 'timeCycles',\n typeOptions: {\n xAxis: closestPoint.xAxis,\n yAxis: closestPoint.yAxis,\n points: [{\n x: closestPoint.x\n }, {\n x: closestPoint.x\n }],\n line: {\n stroke: 'rgba(0, 0, 0, 0.75)',\n fill: 'transparent',\n strokeWidth: 2\n }\n }\n }, navigation.annotationsOptions, navigation.bindings.timeCycles.annotationsOptions), annotation = this.chart.addAnnotation(options);\n annotation.options.events.click.call(annotation, {});\n return annotation;\n },\n steps: [\n updateNthPoint(1)\n ]\n },\n verticalLabel: {\n /** @ignore-option */\n className: 'highcharts-vertical-label',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const closestPoint = attractToPoint(e, this.chart);\n // Exit if clicked out of axes area\n if (!closestPoint) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'verticalLabel',\n type: 'verticalLine',\n typeOptions: {\n point: {\n x: closestPoint.x,\n y: closestPoint.y,\n xAxis: closestPoint.xAxis,\n yAxis: closestPoint.yAxis\n },\n label: {\n offset: closestPoint.below ? 40 : -40\n }\n },\n labelOptions: {\n style: {\n color: \"#666666\" /* Palette.neutralColor60 */,\n fontSize: '0.7em'\n }\n },\n shapeOptions: {\n stroke: 'rgba(0, 0, 0, 0.75)',\n strokeWidth: 1\n }\n }, navigation.annotationsOptions, navigation.bindings\n .verticalLabel.annotationsOptions), annotation = this.chart.addAnnotation(options);\n annotation.options.events.click.call(annotation, {});\n }\n },\n /**\n * A vertical arrow annotation bindings. Includes `start` event. On click,\n * finds the closest point and marks it with an arrow.\n * `#06b535` is the color of the arrow when\n * pointing from above and `#f21313`\n * when pointing from below the point.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-vertical-arrow\", \"start\": function() {}, \"annotationsOptions\": {}}\n */\n verticalArrow: {\n /** @ignore-option */\n className: 'highcharts-vertical-arrow',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const closestPoint = attractToPoint(e, this.chart);\n // Exit if clicked out of axes area\n if (!closestPoint) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n langKey: 'verticalArrow',\n type: 'verticalLine',\n typeOptions: {\n point: {\n x: closestPoint.x,\n y: closestPoint.y,\n xAxis: closestPoint.xAxis,\n yAxis: closestPoint.yAxis\n },\n label: {\n offset: closestPoint.below ? 40 : -40,\n format: ' '\n },\n connector: {\n fill: 'none',\n stroke: closestPoint.below ?\n \"#f21313\" /* Palette.negativeColor */ :\n \"#06b535\" /* Palette.positiveColor */\n }\n },\n shapeOptions: {\n stroke: 'rgba(0, 0, 0, 0.75)',\n strokeWidth: 1\n }\n }, navigation.annotationsOptions, navigation.bindings\n .verticalArrow.annotationsOptions), annotation = this.chart.addAnnotation(options);\n annotation.options.events.click.call(annotation, {});\n }\n },\n /**\n * The Fibonacci Time Zones annotation bindings. Includes `start` and one\n * event in `steps` array.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-fibonacci-time-zones\", \"start\": function() {}, \"steps\": [function() {}], \"annotationsOptions\": {}}\n */\n fibonacciTimeZones: {\n /** @ignore-option */\n className: 'highcharts-fibonacci-time-zones',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n start: function (e) {\n const coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n // Exit if clicked out of axes area\n if (!coordsX || !coordsY) {\n return;\n }\n const navigation = this.chart.options.navigation, options = merge({\n type: 'fibonacciTimeZones',\n langKey: 'fibonacciTimeZones',\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: coordsX.value\n }]\n }\n }, navigation.annotationsOptions, navigation.bindings.fibonacciTimeZones\n .annotationsOptions);\n return this.chart.addAnnotation(options);\n },\n /** @ignore-option */\n // eslint-disable-next-line valid-jsdoc\n steps: [\n function (e, annotation) {\n const mockPointOpts = annotation.options.typeOptions.points, x = mockPointOpts && mockPointOpts[0].x, coords = this.chart.pointer.getCoordinates(e), coordsX = getAssignedAxis(coords.xAxis), coordsY = getAssignedAxis(coords.yAxis);\n annotation.update({\n typeOptions: {\n xAxis: coordsX.axis.index,\n yAxis: coordsY.axis.index,\n points: [{\n x: x\n }, {\n x: coordsX.value\n }]\n }\n });\n }\n ]\n },\n // Flag types:\n /**\n * A flag series bindings. Includes `start` event. On click, finds the\n * closest point and marks it with a flag with `'circlepin'` shape.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-flag-circlepin\", \"start\": function() {}}\n */\n flagCirclepin: {\n /** @ignore-option */\n className: 'highcharts-flag-circlepin',\n /** @ignore-option */\n start: addFlagFromForm('circlepin')\n },\n /**\n * A flag series bindings. Includes `start` event. On click, finds the\n * closest point and marks it with a flag with `'diamondpin'` shape.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-flag-diamondpin\", \"start\": function() {}}\n */\n flagDiamondpin: {\n /** @ignore-option */\n className: 'highcharts-flag-diamondpin',\n /** @ignore-option */\n start: addFlagFromForm('flag')\n },\n /**\n * A flag series bindings. Includes `start` event.\n * On click, finds the closest point and marks it with a flag with\n * `'squarepin'` shape.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-flag-squarepin\", \"start\": function() {}}\n */\n flagSquarepin: {\n /** @ignore-option */\n className: 'highcharts-flag-squarepin',\n /** @ignore-option */\n start: addFlagFromForm('squarepin')\n },\n /**\n * A flag series bindings. Includes `start` event.\n * On click, finds the closest point and marks it with a flag without pin\n * shape.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-flag-simplepin\", \"start\": function() {}}\n */\n flagSimplepin: {\n /** @ignore-option */\n className: 'highcharts-flag-simplepin',\n /** @ignore-option */\n start: addFlagFromForm('nopin')\n },\n // Other tools:\n /**\n * Enables zooming in xAxis on a chart. Includes `start` event which\n * changes [chart.zoomType](#chart.zoomType).\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-zoom-x\", \"init\": function() {}}\n */\n zoomX: {\n /** @ignore-option */\n className: 'highcharts-zoom-x',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.update({\n chart: {\n zooming: {\n type: 'x'\n }\n }\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Enables zooming in yAxis on a chart. Includes `start` event which\n * changes [chart.zoomType](#chart.zoomType).\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-zoom-y\", \"init\": function() {}}\n */\n zoomY: {\n /** @ignore-option */\n className: 'highcharts-zoom-y',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.update({\n chart: {\n zooming: {\n type: 'y'\n }\n }\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Enables zooming in xAxis and yAxis on a chart. Includes `start` event\n * which changes [chart.zoomType](#chart.zoomType).\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-zoom-xy\", \"init\": function() {}}\n */\n zoomXY: {\n /** @ignore-option */\n className: 'highcharts-zoom-xy',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.update({\n chart: {\n zooming: {\n type: 'xy'\n }\n }\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Changes main series to `'line'` type.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-series-type-line\", \"init\": function() {}}\n */\n seriesTypeLine: {\n /** @ignore-option */\n className: 'highcharts-series-type-line',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.series[0].update({\n type: 'line',\n useOhlcData: true\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Changes main series to `'ohlc'` type.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-series-type-ohlc\", \"init\": function() {}}\n */\n seriesTypeOhlc: {\n /** @ignore-option */\n className: 'highcharts-series-type-ohlc',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.series[0].update({\n type: 'ohlc'\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Changes main series to `'candlestick'` type.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-series-type-candlestick\", \"init\": function() {}}\n */\n seriesTypeCandlestick: {\n /** @ignore-option */\n className: 'highcharts-series-type-candlestick',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.series[0].update({\n type: 'candlestick'\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Changes main series to `'heikinashi'` type.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-series-type-heikinashi\", \"init\": function() {}}\n */\n seriesTypeHeikinAshi: {\n /** @ignore-option */\n className: 'highcharts-series-type-heikinashi',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.series[0].update({\n type: 'heikinashi'\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Change main series to `'hlc'` type.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-series-type-hlc\", \"init\": function () {}}\n */\n seriesTypeHLC: {\n className: 'highcharts-series-type-hlc',\n init: function (button) {\n this.chart.series[0].update({\n type: 'hlc',\n useOhlcData: true\n });\n fireEvent(this, 'deselectButton', { button });\n }\n },\n /**\n * Changes main series to `'hollowcandlestick'` type.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-series-type-hollowcandlestick\", \"init\": function() {}}\n */\n seriesTypeHollowCandlestick: {\n /** @ignore-option */\n className: 'highcharts-series-type-hollowcandlestick',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n this.chart.series[0].update({\n type: 'hollowcandlestick'\n });\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Displays chart in fullscreen.\n *\n * **Note**: Fullscreen is not supported on iPhone due to iOS limitations.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"noDataState\": \"normal\", \"highcharts-full-screen\", \"init\": function() {}}\n */\n fullScreen: {\n /** @ignore-option */\n className: 'highcharts-full-screen',\n noDataState: 'normal',\n /** @ignore-option */\n init: function (button) {\n if (this.chart.fullscreen) {\n this.chart.fullscreen.toggle();\n }\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Hides/shows two price indicators:\n * - last price in the dataset\n * - last price in the selected range\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-current-price-indicator\", \"init\": function() {}}\n */\n currentPriceIndicator: {\n /** @ignore-option */\n className: 'highcharts-current-price-indicator',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n const chart = this.chart, series = chart.series, gui = chart.stockTools, priceIndicatorEnabled = isPriceIndicatorEnabled(chart.series);\n if (gui && gui.guiEnabled) {\n series.forEach(function (series) {\n series.update({\n lastPrice: { enabled: !priceIndicatorEnabled },\n lastVisiblePrice: {\n enabled: !priceIndicatorEnabled,\n label: { enabled: true }\n }\n }, false);\n });\n chart.redraw();\n }\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Indicators bindings. Includes `init` event to show a popup.\n *\n * Note: In order to show base series from the chart in the popup's\n * dropdown each series requires\n * [series.id](https://api.highcharts.com/highstock/series.line.id) to be\n * defined.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-indicators\", \"init\": function() {}}\n */\n indicators: {\n /** @ignore-option */\n className: 'highcharts-indicators',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function () {\n const navigation = this;\n fireEvent(navigation, 'showPopup', {\n formType: 'indicators',\n options: {},\n // Callback on submit:\n onSubmit: function (data) {\n manageIndicators.call(navigation, data);\n }\n });\n }\n },\n /**\n * Hides/shows all annotations on a chart.\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-toggle-annotations\", \"init\": function() {}}\n */\n toggleAnnotations: {\n /** @ignore-option */\n className: 'highcharts-toggle-annotations',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n const chart = this.chart, gui = chart.stockTools, iconsURL = gui.getIconsURL();\n this.toggledAnnotations = !this.toggledAnnotations;\n (chart.annotations || []).forEach(function (annotation) {\n annotation.setVisibility(!this.toggledAnnotations);\n }, this);\n if (gui && gui.guiEnabled) {\n if (this.toggledAnnotations) {\n button.firstChild.style['background-image'] =\n 'url(\"' + iconsURL +\n 'annotations-hidden.svg\")';\n }\n else {\n button.firstChild.style['background-image'] =\n 'url(\"' + iconsURL +\n 'annotations-visible.svg\")';\n }\n }\n fireEvent(this, 'deselectButton', { button: button });\n }\n },\n /**\n * Save a chart in localStorage under `highcharts-chart` key.\n * Stored items:\n * - annotations\n * - indicators (with yAxes)\n * - flags\n *\n * @type {Highcharts.NavigationBindingsOptionsObject}\n * @product highstock\n * @default {\"className\": \"highcharts-save-chart\", \"noDataState\": \"normal\", \"init\": function() {}}\n */\n saveChart: {\n /** @ignore-option */\n className: 'highcharts-save-chart',\n noDataState: 'normal',\n // eslint-disable-next-line valid-jsdoc\n /** @ignore-option */\n init: function (button) {\n const navigation = this, chart = navigation.chart, annotations = [], indicators = [], flags = [], yAxes = [];\n chart.annotations.forEach(function (annotation, index) {\n annotations[index] = annotation.userOptions;\n });\n chart.series.forEach(function (series) {\n if (series.is('sma')) {\n indicators.push(series.userOptions);\n }\n else if (series.type === 'flags') {\n flags.push(series.userOptions);\n }\n });\n chart.yAxis.forEach(function (yAxis) {\n if (isNotNavigatorYAxis(yAxis)) {\n yAxes.push(yAxis.options);\n }\n });\n H.win.localStorage.setItem('highcharts-chart', JSON.stringify({\n annotations: annotations,\n indicators: indicators,\n flags: flags,\n yAxes: yAxes\n }));\n fireEvent(this, 'deselectButton', { button: button });\n }\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return StockToolsBindings;\n });\n _registerModule(_modules, 'Stock/StockTools/StockToolsDefaults.js', [], function () {\n /* *\n *\n * GUI generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * @optionparent lang\n */\n const lang = {\n /**\n * Configure the stockTools GUI titles(hints) in the chart. Requires\n * the `stock-tools.js` module to be loaded.\n *\n * @product highstock\n * @since 7.0.0\n */\n stockTools: {\n gui: {\n // Main buttons:\n simpleShapes: 'Simple shapes',\n lines: 'Lines',\n crookedLines: 'Crooked lines',\n measure: 'Measure',\n advanced: 'Advanced',\n toggleAnnotations: 'Toggle annotations',\n verticalLabels: 'Vertical labels',\n flags: 'Flags',\n zoomChange: 'Zoom change',\n typeChange: 'Type change',\n saveChart: 'Save chart',\n indicators: 'Indicators',\n currentPriceIndicator: 'Current Price Indicators',\n // Other features:\n zoomX: 'Zoom X',\n zoomY: 'Zoom Y',\n zoomXY: 'Zooom XY',\n fullScreen: 'Fullscreen',\n typeOHLC: 'OHLC',\n typeLine: 'Line',\n typeCandlestick: 'Candlestick',\n typeHLC: 'HLC',\n typeHollowCandlestick: 'Hollow Candlestick',\n typeHeikinAshi: 'Heikin Ashi',\n // Basic shapes:\n circle: 'Circle',\n ellipse: 'Ellipse',\n label: 'Label',\n rectangle: 'Rectangle',\n // Flags:\n flagCirclepin: 'Flag circle',\n flagDiamondpin: 'Flag diamond',\n flagSquarepin: 'Flag square',\n flagSimplepin: 'Flag simple',\n // Measures:\n measureXY: 'Measure XY',\n measureX: 'Measure X',\n measureY: 'Measure Y',\n // Segment, ray and line:\n segment: 'Segment',\n arrowSegment: 'Arrow segment',\n ray: 'Ray',\n arrowRay: 'Arrow ray',\n line: 'Line',\n arrowInfinityLine: 'Arrow line',\n horizontalLine: 'Horizontal line',\n verticalLine: 'Vertical line',\n infinityLine: 'Infinity line',\n // Crooked lines:\n crooked3: 'Crooked 3 line',\n crooked5: 'Crooked 5 line',\n elliott3: 'Elliott 3 line',\n elliott5: 'Elliott 5 line',\n // Counters:\n verticalCounter: 'Vertical counter',\n verticalLabel: 'Vertical label',\n verticalArrow: 'Vertical arrow',\n // Advanced:\n fibonacci: 'Fibonacci',\n fibonacciTimeZones: 'Fibonacci Time Zones',\n pitchfork: 'Pitchfork',\n parallelChannel: 'Parallel channel',\n timeCycles: 'Time Cycles'\n }\n },\n navigation: {\n popup: {\n // Annotations:\n circle: 'Circle',\n ellipse: 'Ellipse',\n rectangle: 'Rectangle',\n label: 'Label',\n segment: 'Segment',\n arrowSegment: 'Arrow segment',\n ray: 'Ray',\n arrowRay: 'Arrow ray',\n line: 'Line',\n arrowInfinityLine: 'Arrow line',\n horizontalLine: 'Horizontal line',\n verticalLine: 'Vertical line',\n crooked3: 'Crooked 3 line',\n crooked5: 'Crooked 5 line',\n elliott3: 'Elliott 3 line',\n elliott5: 'Elliott 5 line',\n verticalCounter: 'Vertical counter',\n verticalLabel: 'Vertical label',\n verticalArrow: 'Vertical arrow',\n fibonacci: 'Fibonacci',\n fibonacciTimeZones: 'Fibonacci Time Zones',\n pitchfork: 'Pitchfork',\n parallelChannel: 'Parallel channel',\n infinityLine: 'Infinity line',\n measure: 'Measure',\n measureXY: 'Measure XY',\n measureX: 'Measure X',\n measureY: 'Measure Y',\n timeCycles: 'Time Cycles',\n // Flags:\n flags: 'Flags',\n // GUI elements:\n addButton: 'Add',\n saveButton: 'Save',\n editButton: 'Edit',\n removeButton: 'Remove',\n series: 'Series',\n volume: 'Volume',\n connector: 'Connector',\n // Field names:\n innerBackground: 'Inner background',\n outerBackground: 'Outer background',\n crosshairX: 'Crosshair X',\n crosshairY: 'Crosshair Y',\n tunnel: 'Tunnel',\n background: 'Background',\n // Indicators' searchbox (#16019):\n noFilterMatch: 'No match',\n // Indicators' params (#15170):\n searchIndicators: 'Search Indicators',\n clearFilter: '\\u2715 clear filter',\n index: 'Index',\n period: 'Period',\n periods: 'Periods',\n standardDeviation: 'Standard deviation',\n periodTenkan: 'Tenkan period',\n periodSenkouSpanB: 'Senkou Span B period',\n periodATR: 'ATR period',\n multiplierATR: 'ATR multiplier',\n shortPeriod: 'Short period',\n longPeriod: 'Long period',\n signalPeriod: 'Signal period',\n decimals: 'Decimals',\n algorithm: 'Algorithm',\n topBand: 'Top band',\n bottomBand: 'Bottom band',\n initialAccelerationFactor: 'Initial acceleration factor',\n maxAccelerationFactor: 'Max acceleration factor',\n increment: 'Increment',\n multiplier: 'Multiplier',\n ranges: 'Ranges',\n highIndex: 'High index',\n lowIndex: 'Low index',\n deviation: 'Deviation',\n xAxisUnit: 'x-axis unit',\n factor: 'Factor',\n fastAvgPeriod: 'Fast average period',\n slowAvgPeriod: 'Slow average period',\n average: 'Average',\n /**\n * Configure the aliases for indicator names.\n *\n * @product highstock\n * @since 9.3.0\n */\n indicatorAliases: {\n // Overlays\n /**\n * Acceleration Bands alias.\n *\n * @default ['Acceleration Bands']\n * @type {Array}\n */\n abands: ['Acceleration Bands'],\n /**\n * Bollinger Bands alias.\n *\n * @default ['Bollinger Bands']\n * @type {Array}\n */\n bb: ['Bollinger Bands'],\n /**\n * Double Exponential Moving Average alias.\n *\n * @default ['Double Exponential Moving Average']\n * @type {Array}\n */\n dema: ['Double Exponential Moving Average'],\n /**\n * Exponential Moving Average alias.\n *\n * @default ['Exponential Moving Average']\n * @type {Array}\n */\n ema: ['Exponential Moving Average'],\n /**\n * Ichimoku Kinko Hyo alias.\n *\n * @default ['Ichimoku Kinko Hyo']\n * @type {Array}\n */\n ikh: ['Ichimoku Kinko Hyo'],\n /**\n * Keltner Channels alias.\n *\n * @default ['Keltner Channels']\n * @type {Array}\n */\n keltnerchannels: ['Keltner Channels'],\n /**\n * Linear Regression alias.\n *\n * @default ['Linear Regression']\n * @type {Array}\n */\n linearRegression: ['Linear Regression'],\n /**\n * Pivot Points alias.\n *\n * @default ['Pivot Points']\n * @type {Array}\n */\n pivotpoints: ['Pivot Points'],\n /**\n * Price Channel alias.\n *\n * @default ['Price Channel']\n * @type {Array}\n */\n pc: ['Price Channel'],\n /**\n * Price Envelopes alias.\n *\n * @default ['Price Envelopes']\n * @type {Array}\n */\n priceenvelopes: ['Price Envelopes'],\n /**\n * Parabolic SAR alias.\n *\n * @default ['Parabolic SAR']\n * @type {Array}\n */\n psar: ['Parabolic SAR'],\n /**\n * Simple Moving Average alias.\n *\n * @default ['Simple Moving Average']\n * @type {Array}\n */\n sma: ['Simple Moving Average'],\n /**\n * Super Trend alias.\n *\n * @default ['Super Trend']\n * @type {Array}\n */\n supertrend: ['Super Trend'],\n /**\n * Triple Exponential Moving Average alias.\n *\n * @default ['Triple Exponential Moving Average']\n * @type {Array}\n */\n tema: ['Triple Exponential Moving Average'],\n /**\n * Volume by Price alias.\n *\n * @default ['Volume by Price']\n * @type {Array}\n */\n vbp: ['Volume by Price'],\n /**\n * Volume Weighted Moving Average alias.\n *\n * @default ['Volume Weighted Moving Average']\n * @type {Array}\n */\n vwap: ['Volume Weighted Moving Average'],\n /**\n * Weighted Moving Average alias.\n *\n * @default ['Weighted Moving Average']\n * @type {Array}\n */\n wma: ['Weighted Moving Average'],\n /**\n * Zig Zagalias.\n *\n * @default ['Zig Zag']\n * @type {Array}\n */\n zigzag: ['Zig Zag'],\n // Oscilators\n /**\n * Absolute price indicator alias.\n *\n * @default ['Absolute price indicator']\n * @type {Array}\n */\n apo: ['Absolute price indicator'],\n /**\n * Accumulation/Distribution alias.\n *\n * @default ['Accumulation/Distribution’]\n * @type {Array}\n */\n ad: ['Accumulation/Distribution'],\n /**\n * Aroon alias.\n *\n * @default ['Aroon']\n * @type {Array}\n */\n aroon: ['Aroon'],\n /**\n * Aroon oscillator alias.\n *\n * @default ['Aroon oscillator']\n * @type {Array}\n */\n aroonoscillator: ['Aroon oscillator'],\n /**\n * Average True Range alias.\n *\n * @default ['Average True Range’]\n * @type {Array}\n */\n atr: ['Average True Range'],\n /**\n * Awesome oscillator alias.\n *\n * @default ['Awesome oscillator’]\n * @type {Array}\n */\n ao: ['Awesome oscillator'],\n /**\n * Commodity Channel Index alias.\n *\n * @default ['Commodity Channel Index’]\n * @type {Array}\n */\n cci: ['Commodity Channel Index'],\n /**\n * Chaikin alias.\n *\n * @default ['Chaikin’]\n * @type {Array}\n */\n chaikin: ['Chaikin'],\n /**\n * Chaikin Money Flow alias.\n *\n * @default ['Chaikin Money Flow’]\n * @type {Array}\n */\n cmf: ['Chaikin Money Flow'],\n /**\n * Chande Momentum Oscillator alias.\n *\n * @default ['Chande Momentum Oscillator’]\n * @type {Array}\n */\n cmo: ['Chande Momentum Oscillator'],\n /**\n * Disparity Index alias.\n *\n * @default ['Disparity Index’]\n * @type {Array}\n */\n disparityindex: ['Disparity Index'],\n /**\n * Directional Movement Index alias.\n *\n * @default ['Directional Movement Index’]\n * @type {Array}\n */\n dmi: ['Directional Movement Index'],\n /**\n * Detrended price oscillator alias.\n *\n * @default ['Detrended price oscillator’]\n * @type {Array}\n */\n dpo: ['Detrended price oscillator'],\n /**\n * Klinger Oscillator alias.\n *\n * @default [‘Klinger Oscillator’]\n * @type {Array}\n */\n klinger: ['Klinger Oscillator'],\n /**\n * Linear Regression Angle alias.\n *\n * @default [‘Linear Regression Angle’]\n * @type {Array}\n */\n linearRegressionAngle: ['Linear Regression Angle'],\n /**\n * Linear Regression Intercept alias.\n *\n * @default [‘Linear Regression Intercept’]\n * @type {Array}\n */\n linearRegressionIntercept: ['Linear Regression Intercept'],\n /**\n * Linear Regression Slope alias.\n *\n * @default [‘Linear Regression Slope’]\n * @type {Array}\n */\n linearRegressionSlope: ['Linear Regression Slope'],\n /**\n * Moving Average Convergence Divergence alias.\n *\n * @default ['Moving Average Convergence Divergence’]\n * @type {Array}\n */\n macd: ['Moving Average Convergence Divergence'],\n /**\n * Money Flow Index alias.\n *\n * @default ['Money Flow Index’]\n * @type {Array}\n */\n mfi: ['Money Flow Index'],\n /**\n * Momentum alias.\n *\n * @default [‘Momentum’]\n * @type {Array}\n */\n momentum: ['Momentum'],\n /**\n * Normalized Average True Range alias.\n *\n * @default ['Normalized Average True Range’]\n * @type {Array}\n */\n natr: ['Normalized Average True Range'],\n /**\n * On-Balance Volume alias.\n *\n * @default ['On-Balance Volume’]\n * @type {Array}\n */\n obv: ['On-Balance Volume'],\n /**\n * Percentage Price oscillator alias.\n *\n * @default ['Percentage Price oscillator’]\n * @type {Array}\n */\n ppo: ['Percentage Price oscillator'],\n /**\n * Rate of Change alias.\n *\n * @default ['Rate of Change’]\n * @type {Array}\n */\n roc: ['Rate of Change'],\n /**\n * Relative Strength Index alias.\n *\n * @default ['Relative Strength Index’]\n * @type {Array}\n */\n rsi: ['Relative Strength Index'],\n /**\n * Slow Stochastic alias.\n *\n * @default [‘Slow Stochastic’]\n * @type {Array}\n */\n slowstochastic: ['Slow Stochastic'],\n /**\n * Stochastic alias.\n *\n * @default [‘Stochastic’]\n * @type {Array}\n */\n stochastic: ['Stochastic'],\n /**\n * TRIX alias.\n *\n * @default [‘TRIX’]\n * @type {Array}\n */\n trix: ['TRIX'],\n /**\n * Williams %R alias.\n *\n * @default [‘Williams %R’]\n * @type {Array}\n */\n williamsr: ['Williams %R']\n }\n }\n }\n };\n /**\n * Configure the stockTools gui strings in the chart. Requires the\n * [stockTools module]() to be loaded. For a description of the module\n * and information on its features, see [Highcharts StockTools]().\n *\n * @product highstock\n *\n * @sample stock/demo/stock-tools-gui Stock Tools GUI\n *\n * @sample stock/demo/stock-tools-custom-gui Stock Tools customized GUI\n *\n * @since 7.0.0\n * @optionparent stockTools\n */\n const stockTools = {\n /**\n * Definitions of buttons in Stock Tools GUI.\n */\n gui: {\n /**\n * Path where Highcharts will look for icons. Change this to use\n * icons from a different server.\n *\n * Since 7.1.3 use [iconsURL](#navigation.iconsURL) for popup and\n * stock tools.\n *\n * @deprecated\n * @apioption stockTools.gui.iconsURL\n *\n */\n /**\n * Enable or disable the stockTools gui.\n */\n enabled: true,\n /**\n * A CSS class name to apply to the stocktools' div,\n * allowing unique CSS styling for each chart.\n */\n className: 'highcharts-bindings-wrapper',\n /**\n * A CSS class name to apply to the container of buttons,\n * allowing unique CSS styling for each chart.\n */\n toolbarClassName: 'stocktools-toolbar',\n /**\n * A collection of strings pointing to config options for the\n * toolbar items. Each name refers to a unique key from the\n * definitions object.\n *\n * @type {Array}\n * @default [\n * 'indicators',\n * 'separator',\n * 'simpleShapes',\n * 'lines',\n * 'crookedLines',\n * 'measure',\n * 'advanced',\n * 'toggleAnnotations',\n * 'separator',\n * 'verticalLabels',\n * 'flags',\n * 'separator',\n * 'zoomChange',\n * 'fullScreen',\n * 'typeChange',\n * 'separator',\n * 'currentPriceIndicator',\n * 'saveChart'\n * ]\n */\n buttons: [\n 'indicators',\n 'separator',\n 'simpleShapes',\n 'lines',\n 'crookedLines',\n 'measure',\n 'advanced',\n 'toggleAnnotations',\n 'separator',\n 'verticalLabels',\n 'flags',\n 'separator',\n 'zoomChange',\n 'fullScreen',\n 'typeChange',\n 'separator',\n 'currentPriceIndicator',\n 'saveChart'\n ],\n /**\n * An options object of the buttons definitions. Each name refers to\n * unique key from buttons array.\n */\n definitions: {\n separator: {\n /**\n * A predefined background symbol for the button.\n */\n symbol: 'separator.svg'\n },\n simpleShapes: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'label',\n * 'circle',\n * 'ellipse',\n * 'rectangle'\n * ]\n *\n */\n items: [\n 'label',\n 'circle',\n 'ellipse',\n 'rectangle'\n ],\n circle: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n *\n */\n symbol: 'circle.svg'\n },\n ellipse: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n *\n */\n symbol: 'ellipse.svg'\n },\n rectangle: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n *\n */\n symbol: 'rectangle.svg'\n },\n label: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n *\n */\n symbol: 'label.svg'\n }\n },\n flags: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'flagCirclepin',\n * 'flagDiamondpin',\n * 'flagSquarepin',\n * 'flagSimplepin'\n * ]\n *\n */\n items: [\n 'flagCirclepin',\n 'flagDiamondpin',\n 'flagSquarepin',\n 'flagSimplepin'\n ],\n flagSimplepin: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n *\n */\n symbol: 'flag-basic.svg'\n },\n flagDiamondpin: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n *\n */\n symbol: 'flag-diamond.svg'\n },\n flagSquarepin: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'flag-trapeze.svg'\n },\n flagCirclepin: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'flag-elipse.svg'\n }\n },\n lines: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'segment',\n * 'arrowSegment',\n * 'ray',\n * 'arrowRay',\n * 'line',\n * 'arrowInfinityLine',\n * 'horizontalLine',\n * 'verticalLine'\n * ]\n */\n items: [\n 'segment',\n 'arrowSegment',\n 'ray',\n 'arrowRay',\n 'line',\n 'arrowInfinityLine',\n 'horizontalLine',\n 'verticalLine'\n ],\n segment: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'segment.svg'\n },\n arrowSegment: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'arrow-segment.svg'\n },\n ray: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'ray.svg'\n },\n arrowRay: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'arrow-ray.svg'\n },\n line: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'line.svg'\n },\n arrowInfinityLine: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'arrow-line.svg'\n },\n verticalLine: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'vertical-line.svg'\n },\n horizontalLine: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'horizontal-line.svg'\n }\n },\n crookedLines: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'elliott3',\n * 'elliott5',\n * 'crooked3',\n * 'crooked5'\n * ]\n *\n */\n items: [\n 'elliott3',\n 'elliott5',\n 'crooked3',\n 'crooked5'\n ],\n crooked3: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'crooked-3.svg'\n },\n crooked5: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'crooked-5.svg'\n },\n elliott3: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'elliott-3.svg'\n },\n elliott5: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'elliott-5.svg'\n }\n },\n verticalLabels: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'verticalCounter',\n * 'verticalLabel',\n * 'verticalArrow'\n * ]\n */\n items: [\n 'verticalCounter',\n 'verticalLabel',\n 'verticalArrow'\n ],\n verticalCounter: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'vertical-counter.svg'\n },\n verticalLabel: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'vertical-label.svg'\n },\n verticalArrow: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'vertical-arrow.svg'\n }\n },\n advanced: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'fibonacci',\n * 'fibonacciTimeZones',\n * 'pitchfork',\n * 'parallelChannel',\n * 'timeCycles'\n * ]\n */\n items: [\n 'fibonacci',\n 'fibonacciTimeZones',\n 'pitchfork',\n 'parallelChannel',\n 'timeCycles'\n ],\n pitchfork: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'pitchfork.svg'\n },\n fibonacci: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'fibonacci.svg'\n },\n fibonacciTimeZones: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'fibonacci-timezone.svg'\n },\n parallelChannel: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'parallel-channel.svg'\n },\n timeCycles: {\n /**\n * A predefined backgroud symbol for the button.\n *\n * @type {string}\n */\n symbol: 'time-cycles.svg'\n }\n },\n measure: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'measureXY',\n * 'measureX',\n * 'measureY'\n * ]\n */\n items: [\n 'measureXY',\n 'measureX',\n 'measureY'\n ],\n measureX: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'measure-x.svg'\n },\n measureY: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'measure-y.svg'\n },\n measureXY: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'measure-xy.svg'\n }\n },\n toggleAnnotations: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'annotations-visible.svg'\n },\n currentPriceIndicator: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'current-price-show.svg'\n },\n indicators: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'indicators.svg'\n },\n zoomChange: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'zoomX',\n * 'zoomY',\n * 'zoomXY'\n * ]\n */\n items: [\n 'zoomX',\n 'zoomY',\n 'zoomXY'\n ],\n zoomX: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'zoom-x.svg'\n },\n zoomY: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'zoom-y.svg'\n },\n zoomXY: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'zoom-xy.svg'\n }\n },\n typeChange: {\n /**\n * A collection of strings pointing to config options for\n * the items.\n *\n * @type {Array}\n * @default [\n * 'typeOHLC',\n * 'typeLine',\n * 'typeCandlestick'\n * 'typeHollowCandlestick'\n * ]\n */\n items: [\n 'typeOHLC',\n 'typeLine',\n 'typeCandlestick',\n 'typeHollowCandlestick',\n 'typeHLC',\n 'typeHeikinAshi'\n ],\n typeOHLC: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'series-ohlc.svg'\n },\n typeLine: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'series-line.svg'\n },\n typeCandlestick: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'series-candlestick.svg'\n },\n typeHLC: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'series-hlc.svg'\n },\n typeHeikinAshi: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'series-heikin-ashi.svg'\n },\n typeHollowCandlestick: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'series-hollow-candlestick.svg'\n }\n },\n fullScreen: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'fullscreen.svg'\n },\n saveChart: {\n /**\n * A predefined background symbol for the button.\n *\n * @type {string}\n */\n symbol: 'save-chart.svg'\n }\n }\n }\n };\n /* *\n *\n * Default Exports\n *\n * */\n const StockToolsDefaults = {\n lang,\n stockTools\n };\n\n return StockToolsDefaults;\n });\n _registerModule(_modules, 'Stock/StockTools/StockTools.js', [_modules['Core/Defaults.js'], _modules['Extensions/Annotations/NavigationBindingsUtilities.js'], _modules['Stock/StockTools/StockToolsBindings.js'], _modules['Stock/StockTools/StockToolsDefaults.js'], _modules['Stock/StockTools/StockToolsUtilities.js'], _modules['Core/Utilities.js']], function (D, NBU, StockToolsBindings, StockToolsDefaults, STU, U) {\n /**\n *\n * Events generator for Stock tools\n *\n * (c) 2009-2021 Paweł Fus\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { setOptions } = D;\n const { getAssignedAxis } = NBU;\n const { isNotNavigatorYAxis, isPriceIndicatorEnabled } = STU;\n const { correctFloat, defined, isNumber, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(NavigationBindingsClass) {\n if (U.pushUnique(composedMembers, NavigationBindingsClass)) {\n const navigationProto = NavigationBindingsClass.prototype;\n // Extends NavigationBindings to support indicators and resizers:\n navigationProto.getYAxisPositions = navigationGetYAxisPositions;\n navigationProto.getYAxisResizers = navigationGetYAxisResizers;\n navigationProto.recalculateYAxisPositions =\n navigationRecalculateYAxisPositions;\n navigationProto.resizeYAxes = navigationResizeYAxes;\n navigationProto.utils = {\n indicatorsWithAxes: STU.indicatorsWithAxes,\n indicatorsWithVolume: STU.indicatorsWithVolume,\n getAssignedAxis,\n isPriceIndicatorEnabled,\n manageIndicators: STU.manageIndicators\n };\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n setOptions(StockToolsDefaults);\n setOptions({\n navigation: {\n bindings: StockToolsBindings\n }\n });\n }\n }\n /**\n * Get current positions for all yAxes. If new axis does not have position,\n * returned is default height and last available top place.\n *\n * @private\n * @function Highcharts.NavigationBindings#getYAxisPositions\n *\n * @param {Array} yAxes\n * Array of yAxes available in the chart.\n *\n * @param {number} plotHeight\n * Available height in the chart.\n *\n * @param {number} defaultHeight\n * Default height in percents.\n *\n * @param {Highcharts.AxisPositions} removedYAxisProps\n * Height and top value of the removed yAxis in percents.\n *\n * @return {Highcharts.YAxisPositions}\n * An object containing an array of calculated positions\n * in percentages. Format: `{top: Number, height: Number}`\n * and maximum value of top + height of axes.\n */\n function navigationGetYAxisPositions(yAxes, plotHeight, defaultHeight, removedYAxisProps) {\n let allAxesHeight = 0, previousAxisHeight, removedHeight, removedTop;\n /** @private */\n function isPercentage(prop) {\n return defined(prop) && !isNumber(prop) && prop.match('%');\n }\n if (removedYAxisProps) {\n removedTop = correctFloat((parseFloat(removedYAxisProps.top) / 100));\n removedHeight = correctFloat((parseFloat(removedYAxisProps.height) / 100));\n }\n const positions = yAxes.map((yAxis, index) => {\n let height = correctFloat(isPercentage(yAxis.options.height) ?\n parseFloat(yAxis.options.height) / 100 :\n yAxis.height / plotHeight), top = correctFloat(isPercentage(yAxis.options.top) ?\n parseFloat(yAxis.options.top) / 100 :\n (yAxis.top - yAxis.chart.plotTop) / plotHeight);\n if (!removedHeight) {\n // New axis' height is NaN so we can check if\n // the axis is newly created this way\n if (!isNumber(height)) {\n // Check if the previous axis is the\n // indicator axis (every indicator inherits from sma)\n height = yAxes[index - 1].series\n .every((s) => s.is('sma')) ?\n previousAxisHeight : defaultHeight / 100;\n }\n if (!isNumber(top)) {\n top = allAxesHeight;\n }\n previousAxisHeight = height;\n allAxesHeight = correctFloat(Math.max(allAxesHeight, (top || 0) + (height || 0)));\n }\n else {\n // Move all axes which were below the removed axis up.\n if (top > removedTop) {\n top -= removedHeight;\n }\n allAxesHeight = Math.max(allAxesHeight, (top || 0) + (height || 0));\n }\n return {\n height: height * 100,\n top: top * 100\n };\n });\n return { positions, allAxesHeight };\n }\n /**\n * Get current resize options for each yAxis. Note that each resize is\n * linked to the next axis, except the last one which shouldn't affect\n * axes in the navigator. Because indicator can be removed with it's yAxis\n * in the middle of yAxis array, we need to bind closest yAxes back.\n *\n * @private\n * @function Highcharts.NavigationBindings#getYAxisResizers\n *\n * @param {Array} yAxes\n * Array of yAxes available in the chart\n *\n * @return {Array}\n * An array of resizer options.\n * Format: `{enabled: Boolean, controlledAxis: { next: [String]}}`\n */\n function navigationGetYAxisResizers(yAxes) {\n const resizers = [];\n yAxes.forEach(function (_yAxis, index) {\n const nextYAxis = yAxes[index + 1];\n // We have next axis, bind them:\n if (nextYAxis) {\n resizers[index] = {\n enabled: true,\n controlledAxis: {\n next: [\n pick(nextYAxis.options.id, nextYAxis.index)\n ]\n }\n };\n }\n else {\n // Remove binding:\n resizers[index] = {\n enabled: false\n };\n }\n });\n return resizers;\n }\n /**\n * Utility to modify calculated positions according to the remaining/needed\n * space. Later, these positions are used in `yAxis.update({ top, height })`\n *\n * @private\n * @function Highcharts.NavigationBindings#recalculateYAxisPositions\n * @param {Array>} positions\n * Default positions of all yAxes.\n * @param {number} changedSpace\n * How much space should be added or removed.\n * @param {boolean} modifyHeight\n * Update only `top` or both `top` and `height`.\n * @param {number} adder\n * `-1` or `1`, to determine whether we should add or remove space.\n *\n * @return {Array}\n * Modified positions,\n */\n function navigationRecalculateYAxisPositions(positions, changedSpace, modifyHeight, adder) {\n positions.forEach(function (position, index) {\n const prevPosition = positions[index - 1];\n position.top = !prevPosition ? 0 :\n correctFloat(prevPosition.height + prevPosition.top);\n if (modifyHeight) {\n position.height = correctFloat(position.height + adder * changedSpace);\n }\n });\n return positions;\n }\n /**\n * Resize all yAxes (except navigator) to fit the plotting height. Method\n * checks if new axis is added, if the new axis will fit under previous\n * axes it is placed there. If not, current plot area is scaled\n * to make room for new axis.\n *\n * If axis is removed, the current plot area streaches to fit into 100%\n * of the plot area.\n *\n * @private\n */\n function navigationResizeYAxes(removedYAxisProps) {\n // The height of the new axis before rescalling. In %, but as a number.\n const defaultHeight = 20;\n const chart = this.chart, \n // Only non-navigator axes\n yAxes = chart.yAxis.filter(isNotNavigatorYAxis), plotHeight = chart.plotHeight, \n // Gather current heights (in %)\n { positions, allAxesHeight } = this.getYAxisPositions(yAxes, plotHeight, defaultHeight, removedYAxisProps), resizers = this.getYAxisResizers(yAxes);\n // check if the axis is being either added or removed and\n // if the new indicator axis will fit under existing axes.\n // if so, there is no need to scale them.\n if (!removedYAxisProps &&\n allAxesHeight <= correctFloat(0.8 + defaultHeight / 100)) {\n positions[positions.length - 1] = {\n height: defaultHeight,\n top: correctFloat(allAxesHeight * 100 - defaultHeight)\n };\n }\n else {\n positions.forEach(function (position) {\n position.height = (position.height / (allAxesHeight * 100)) * 100;\n position.top = (position.top / (allAxesHeight * 100)) * 100;\n });\n }\n positions.forEach(function (position, index) {\n yAxes[index].update({\n height: position.height + '%',\n top: position.top + '%',\n resize: resizers[index],\n offset: 0\n }, false);\n });\n }\n /* *\n *\n * Default Export\n *\n * */\n const StockTools = {\n compose\n };\n\n return StockTools;\n });\n _registerModule(_modules, 'Stock/StockTools/StockToolbar.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * GUI generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, createElement, css, fireEvent, getStyle, isArray, merge, pick } = U;\n /* *\n *\n * Classes\n *\n * */\n /**\n * Toolbar Class\n *\n * @private\n * @class\n *\n * @param {object} options\n * Options of toolbar\n *\n * @param {Highcharts.Dictionary|undefined} langOptions\n * Language options\n *\n * @param {Highcharts.Chart} chart\n * Reference to chart\n */\n class Toolbar {\n /* *\n *\n * Constructor\n *\n * */\n constructor(options, langOptions, chart) {\n /* *\n *\n * Properties\n *\n * */\n this.arrowDown = void 0;\n this.arrowUp = void 0;\n this.arrowWrapper = void 0;\n this.listWrapper = void 0;\n this.showhideBtn = void 0;\n this.submenu = void 0;\n this.toolbar = void 0;\n this.wrapper = void 0;\n this.chart = chart;\n this.options = options;\n this.lang = langOptions;\n // set url for icons.\n this.iconsURL = this.getIconsURL();\n this.guiEnabled = options.enabled;\n this.visible = pick(options.visible, true);\n this.placed = pick(options.placed, false);\n // General events collection which should be removed upon\n // destroy/update:\n this.eventsToUnbind = [];\n if (this.guiEnabled) {\n this.createHTML();\n this.init();\n this.showHideNavigatorion();\n }\n fireEvent(this, 'afterInit');\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Initialize the toolbar. Create buttons and submenu for each option\n * defined in `stockTools.gui`.\n * @private\n */\n init() {\n const lang = this.lang, guiOptions = this.options, toolbar = this.toolbar, buttons = guiOptions.buttons, defs = guiOptions.definitions, allButtons = toolbar.childNodes;\n // create buttons\n buttons.forEach((btnName) => {\n const button = this.addButton(toolbar, defs, btnName, lang);\n this.eventsToUnbind.push(addEvent(button.buttonWrapper, 'click', () => this.eraseActiveButtons(allButtons, button.buttonWrapper)));\n if (isArray(defs[btnName].items)) {\n // create submenu buttons\n this.addSubmenu(button, defs[btnName]);\n }\n });\n }\n /**\n * Create submenu (list of buttons) for the option. In example main button\n * is Line, in submenu will be buttons with types of lines.\n *\n * @private\n *\n * @param {Highcharts.Dictionary} parentBtn\n * Button which has submenu\n *\n * @param {Highcharts.StockToolsGuiDefinitionsButtonsOptions} button\n * List of all buttons\n */\n addSubmenu(parentBtn, button) {\n const submenuArrow = parentBtn.submenuArrow, buttonWrapper = parentBtn.buttonWrapper, buttonWidth = getStyle(buttonWrapper, 'width'), wrapper = this.wrapper, menuWrapper = this.listWrapper, allButtons = this.toolbar.childNodes, \n // create submenu container\n submenuWrapper = this.submenu = createElement('ul', {\n className: 'highcharts-submenu-wrapper'\n }, void 0, buttonWrapper);\n // create submenu buttons and select the first one\n this.addSubmenuItems(buttonWrapper, button);\n // show / hide submenu\n this.eventsToUnbind.push(addEvent(submenuArrow, 'click', (e) => {\n e.stopPropagation();\n // Erase active class on all other buttons\n this.eraseActiveButtons(allButtons, buttonWrapper);\n // hide menu\n if (buttonWrapper.className\n .indexOf('highcharts-current') >= 0) {\n menuWrapper.style.width =\n menuWrapper.startWidth + 'px';\n buttonWrapper.classList.remove('highcharts-current');\n submenuWrapper.style.display = 'none';\n }\n else {\n // show menu\n // to calculate height of element\n submenuWrapper.style.display = 'block';\n let topMargin = submenuWrapper.offsetHeight -\n buttonWrapper.offsetHeight - 3;\n // calculate position of submenu in the box\n // if submenu is inside, reset top margin\n if (\n // cut on the bottom\n !(submenuWrapper.offsetHeight +\n buttonWrapper.offsetTop >\n wrapper.offsetHeight &&\n // cut on the top\n buttonWrapper.offsetTop > topMargin)) {\n topMargin = 0;\n }\n // apply calculated styles\n css(submenuWrapper, {\n top: -topMargin + 'px',\n left: buttonWidth + 3 + 'px'\n });\n buttonWrapper.className += ' highcharts-current';\n menuWrapper.startWidth = wrapper.offsetWidth;\n menuWrapper.style.width = menuWrapper.startWidth +\n getStyle(menuWrapper, 'padding-left') +\n submenuWrapper.offsetWidth + 3 + 'px';\n }\n }));\n }\n /**\n * Create buttons in submenu\n *\n * @private\n *\n * @param {Highcharts.HTMLDOMElement} buttonWrapper\n * Button where submenu is placed\n *\n * @param {Highcharts.StockToolsGuiDefinitionsButtonsOptions} button\n * List of all buttons options\n */\n addSubmenuItems(buttonWrapper, button) {\n const _self = this, submenuWrapper = this.submenu, lang = this.lang, menuWrapper = this.listWrapper, items = button.items;\n let submenuBtn;\n // add items to submenu\n items.forEach((btnName) => {\n // add buttons to submenu\n submenuBtn = this.addButton(submenuWrapper, button, btnName, lang);\n this.eventsToUnbind.push(addEvent(submenuBtn.mainButton, 'click', function () {\n _self.switchSymbol(this, buttonWrapper, true);\n menuWrapper.style.width =\n menuWrapper.startWidth + 'px';\n submenuWrapper.style.display = 'none';\n }));\n });\n // select first submenu item\n const firstSubmenuItem = submenuWrapper.querySelectorAll('li > .highcharts-menu-item-btn')[0];\n // replace current symbol, in main button, with submenu's button style\n this.switchSymbol(firstSubmenuItem, false);\n }\n /**\n * Erase active class on all other buttons.\n * @private\n */\n eraseActiveButtons(buttons, currentButton, submenuItems) {\n [].forEach.call(buttons, (btn) => {\n if (btn !== currentButton) {\n btn.classList.remove('highcharts-current');\n btn.classList.remove('highcharts-active');\n submenuItems =\n btn.querySelectorAll('.highcharts-submenu-wrapper');\n // hide submenu\n if (submenuItems.length > 0) {\n submenuItems[0].style.display = 'none';\n }\n }\n });\n }\n /**\n * Create single button. Consist of HTML elements `li`, `span`, and (if\n * exists) submenu container.\n *\n * @private\n *\n * @param {Highcharts.HTMLDOMElement} target\n * HTML reference, where button should be added\n *\n * @param {object} options\n * All options, by btnName refer to particular button\n *\n * @param {string} btnName\n * Button name of functionality mapped for specific class\n *\n * @param {Highcharts.Dictionary} lang\n * All titles, by btnName refer to particular button\n *\n * @return {object}\n * References to all created HTML elements\n */\n addButton(target, options, btnName, lang = {}) {\n const btnOptions = options[btnName], items = btnOptions.items, classMapping = Toolbar.prototype.classMapping, userClassName = btnOptions.className || '';\n // main button wrapper\n const buttonWrapper = createElement('li', {\n className: pick(classMapping[btnName], '') + ' ' + userClassName,\n title: lang[btnName] || btnName\n }, void 0, target);\n // single button\n const mainButton = createElement('span', {\n className: 'highcharts-menu-item-btn'\n }, void 0, buttonWrapper);\n // submenu\n if (items && items.length) {\n // arrow is a hook to show / hide submenu\n const submenuArrow = createElement('span', {\n className: 'highcharts-submenu-item-arrow ' +\n 'highcharts-arrow-right'\n }, void 0, buttonWrapper);\n submenuArrow.style.backgroundImage = 'url(' +\n this.iconsURL + 'arrow-bottom.svg)';\n return {\n buttonWrapper,\n mainButton,\n submenuArrow\n };\n }\n mainButton.style.backgroundImage = 'url(' +\n this.iconsURL + btnOptions.symbol + ')';\n return {\n buttonWrapper,\n mainButton\n };\n }\n /**\n * Create navigation's HTML elements: container and arrows.\n * @private\n */\n addNavigation() {\n const wrapper = this.wrapper;\n // arrow wrapper\n this.arrowWrapper = createElement('div', {\n className: 'highcharts-arrow-wrapper'\n });\n this.arrowUp = createElement('div', {\n className: 'highcharts-arrow-up'\n }, void 0, this.arrowWrapper);\n this.arrowUp.style.backgroundImage =\n 'url(' + this.iconsURL + 'arrow-right.svg)';\n this.arrowDown = createElement('div', {\n className: 'highcharts-arrow-down'\n }, void 0, this.arrowWrapper);\n this.arrowDown.style.backgroundImage =\n 'url(' + this.iconsURL + 'arrow-right.svg)';\n wrapper.insertBefore(this.arrowWrapper, wrapper.childNodes[0]);\n // attach scroll events\n this.scrollButtons();\n }\n /**\n * Add events to navigation (two arrows) which allows user to scroll\n * top/down GUI buttons, if container's height is not enough.\n * @private\n */\n scrollButtons() {\n const wrapper = this.wrapper, toolbar = this.toolbar, step = 0.1 * wrapper.offsetHeight; // 0.1 = 10%\n let targetY = 0;\n this.eventsToUnbind.push(addEvent(this.arrowUp, 'click', () => {\n if (targetY > 0) {\n targetY -= step;\n toolbar.style.marginTop = -targetY + 'px';\n }\n }));\n this.eventsToUnbind.push(addEvent(this.arrowDown, 'click', () => {\n if (wrapper.offsetHeight + targetY <=\n toolbar.offsetHeight + step) {\n targetY += step;\n toolbar.style.marginTop = -targetY + 'px';\n }\n }));\n }\n /*\n * Create stockTools HTML main elements.\n *\n */\n createHTML() {\n const chart = this.chart, guiOptions = this.options, container = chart.container, navigation = chart.options.navigation, bindingsClassName = navigation && navigation.bindingsClassName;\n let listWrapper, toolbar;\n // create main container\n const wrapper = this.wrapper = createElement('div', {\n className: 'highcharts-stocktools-wrapper ' +\n guiOptions.className + ' ' + bindingsClassName\n });\n container.appendChild(wrapper);\n // Mimic event behaviour of being outside chart.container\n [\n 'mousedown',\n 'mousemove',\n 'click',\n 'touchstart'\n ].forEach((eventType) => {\n addEvent(wrapper, eventType, (e) => e.stopPropagation());\n });\n addEvent(wrapper, 'mouseover', (e) => chart.pointer.onContainerMouseLeave(e));\n // toolbar\n this.toolbar = toolbar = createElement('ul', {\n className: 'highcharts-stocktools-toolbar ' +\n guiOptions.toolbarClassName\n });\n // add container for list of buttons\n this.listWrapper = listWrapper = createElement('div', {\n className: 'highcharts-menu-wrapper'\n });\n wrapper.insertBefore(listWrapper, wrapper.childNodes[0]);\n listWrapper.insertBefore(toolbar, listWrapper.childNodes[0]);\n this.showHideToolbar();\n // add navigation which allows user to scroll down / top GUI buttons\n this.addNavigation();\n }\n /**\n * Function called in redraw verifies if the navigation should be visible.\n * @private\n */\n showHideNavigatorion() {\n // arrows\n // 50px space for arrows\n if (this.visible &&\n this.toolbar.offsetHeight > (this.wrapper.offsetHeight - 50)) {\n this.arrowWrapper.style.display = 'block';\n }\n else {\n // reset margin if whole toolbar is visible\n this.toolbar.style.marginTop = '0px';\n // hide arrows\n this.arrowWrapper.style.display = 'none';\n }\n }\n /**\n * Create button which shows or hides GUI toolbar.\n * @private\n */\n showHideToolbar() {\n const chart = this.chart, wrapper = this.wrapper, toolbar = this.listWrapper, submenu = this.submenu, \n // Show hide toolbar\n showhideBtn = this.showhideBtn = createElement('div', {\n className: 'highcharts-toggle-toolbar highcharts-arrow-left'\n }, void 0, wrapper);\n let visible = this.visible;\n showhideBtn.style.backgroundImage =\n 'url(' + this.iconsURL + 'arrow-right.svg)';\n if (!visible) {\n // hide\n if (submenu) {\n submenu.style.display = 'none';\n }\n showhideBtn.style.left = '0px';\n visible = this.visible = false;\n toolbar.classList.add('highcharts-hide');\n showhideBtn.classList.toggle('highcharts-arrow-right');\n wrapper.style.height = showhideBtn.offsetHeight + 'px';\n }\n else {\n wrapper.style.height = '100%';\n showhideBtn.style.top = getStyle(toolbar, 'padding-top') + 'px';\n showhideBtn.style.left = (wrapper.offsetWidth +\n getStyle(toolbar, 'padding-left')) + 'px';\n }\n // Toggle menu\n this.eventsToUnbind.push(addEvent(showhideBtn, 'click', () => {\n chart.update({\n stockTools: {\n gui: {\n visible: !visible,\n placed: true\n }\n }\n });\n }));\n }\n /*\n * In main GUI button, replace icon and class with submenu button's\n * class / symbol.\n *\n * @param {HTMLDOMElement} - submenu button\n * @param {Boolean} - true or false\n *\n */\n switchSymbol(button, redraw) {\n const buttonWrapper = button.parentNode, buttonWrapperClass = buttonWrapper.className, \n // main button in first level og GUI\n mainNavButton = buttonWrapper.parentNode.parentNode;\n // if the button is disabled, don't do anything\n if (buttonWrapperClass.indexOf('highcharts-disabled-btn') > -1) {\n return;\n }\n // set class\n mainNavButton.className = '';\n if (buttonWrapperClass) {\n mainNavButton.classList.add(buttonWrapperClass.trim());\n }\n // set icon\n mainNavButton\n .querySelectorAll('.highcharts-menu-item-btn')[0]\n .style.backgroundImage =\n button.style.backgroundImage;\n // set active class\n if (redraw) {\n this.toggleButtonActiveClass(mainNavButton);\n }\n }\n /**\n * Set select state (active class) on button.\n * @private\n */\n toggleButtonActiveClass(button) {\n const classList = button.classList;\n if (classList.contains('highcharts-active')) {\n classList.remove('highcharts-active');\n }\n else {\n classList.add('highcharts-active');\n }\n }\n /**\n * Remove active class from all buttons except defined.\n * @private\n */\n unselectAllButtons(button) {\n const activeBtns = button.parentNode\n .querySelectorAll('.highcharts-active');\n [].forEach.call(activeBtns, (activeBtn) => {\n if (activeBtn !== button) {\n activeBtn.classList.remove('highcharts-active');\n }\n });\n }\n /**\n * Update GUI with given options.\n * @private\n */\n update(options, redraw) {\n merge(true, this.chart.options.stockTools, options);\n this.destroy();\n this.chart.setStockTools(options);\n // If Stock Tools are updated, then bindings should be updated too:\n if (this.chart.navigationBindings) {\n this.chart.navigationBindings.update();\n }\n this.chart.isDirtyBox = true;\n if (pick(redraw, true)) {\n this.chart.redraw();\n }\n }\n /**\n * Destroy all HTML GUI elements.\n * @private\n */\n destroy() {\n const stockToolsDiv = this.wrapper, parent = stockToolsDiv && stockToolsDiv.parentNode;\n this.eventsToUnbind.forEach((unbinder) => unbinder());\n // Remove the empty element\n if (parent) {\n parent.removeChild(stockToolsDiv);\n }\n }\n /**\n * Redraw, GUI requires to verify if the navigation should be visible.\n * @private\n */\n redraw() {\n this.showHideNavigatorion();\n }\n /**\n * @private\n */\n getIconsURL() {\n return this.chart.options.navigation.iconsURL ||\n this.options.iconsURL ||\n 'https://code.highcharts.com/11.1.0/gfx/stock-icons/';\n }\n }\n Toolbar.prototype.classMapping = {\n circle: 'highcharts-circle-annotation',\n ellipse: 'highcharts-ellipse-annotation',\n rectangle: 'highcharts-rectangle-annotation',\n label: 'highcharts-label-annotation',\n segment: 'highcharts-segment',\n arrowSegment: 'highcharts-arrow-segment',\n ray: 'highcharts-ray',\n arrowRay: 'highcharts-arrow-ray',\n line: 'highcharts-infinity-line',\n arrowInfinityLine: 'highcharts-arrow-infinity-line',\n verticalLine: 'highcharts-vertical-line',\n horizontalLine: 'highcharts-horizontal-line',\n crooked3: 'highcharts-crooked3',\n crooked5: 'highcharts-crooked5',\n elliott3: 'highcharts-elliott3',\n elliott5: 'highcharts-elliott5',\n pitchfork: 'highcharts-pitchfork',\n fibonacci: 'highcharts-fibonacci',\n fibonacciTimeZones: 'highcharts-fibonacci-time-zones',\n parallelChannel: 'highcharts-parallel-channel',\n measureX: 'highcharts-measure-x',\n measureY: 'highcharts-measure-y',\n measureXY: 'highcharts-measure-xy',\n timeCycles: 'highcharts-time-cycles',\n verticalCounter: 'highcharts-vertical-counter',\n verticalLabel: 'highcharts-vertical-label',\n verticalArrow: 'highcharts-vertical-arrow',\n currentPriceIndicator: 'highcharts-current-price-indicator',\n indicators: 'highcharts-indicators',\n flagCirclepin: 'highcharts-flag-circlepin',\n flagDiamondpin: 'highcharts-flag-diamondpin',\n flagSquarepin: 'highcharts-flag-squarepin',\n flagSimplepin: 'highcharts-flag-simplepin',\n zoomX: 'highcharts-zoom-x',\n zoomY: 'highcharts-zoom-y',\n zoomXY: 'highcharts-zoom-xy',\n typeLine: 'highcharts-series-type-line',\n typeOHLC: 'highcharts-series-type-ohlc',\n typeHLC: 'highcharts-series-type-hlc',\n typeCandlestick: 'highcharts-series-type-candlestick',\n typeHollowCandlestick: 'highcharts-series-type-hollowcandlestick',\n typeHeikinAshi: 'highcharts-series-type-heikinashi',\n fullScreen: 'highcharts-full-screen',\n toggleAnnotations: 'highcharts-toggle-annotations',\n saveChart: 'highcharts-save-chart',\n separator: 'highcharts-separator'\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return Toolbar;\n });\n _registerModule(_modules, 'Stock/StockTools/StockToolsGui.js', [_modules['Core/Defaults.js'], _modules['Stock/StockTools/StockToolsDefaults.js'], _modules['Stock/StockTools/StockToolbar.js'], _modules['Core/Utilities.js']], function (D, StockToolsDefaults, Toolbar, U) {\n /* *\n *\n * GUI generator for Stock tools\n *\n * (c) 2009-2021 Sebastian Bochan\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { setOptions } = D;\n const { addEvent, getStyle, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * Verify if Toolbar should be added.\n * @private\n */\n function chartSetStockTools(options) {\n const chartOptions = this.options, lang = chartOptions.lang, guiOptions = merge(chartOptions.stockTools && chartOptions.stockTools.gui, options && options.gui), langOptions = lang && lang.stockTools && lang.stockTools.gui;\n this.stockTools = new Toolbar(guiOptions, langOptions, this);\n if (this.stockTools.guiEnabled) {\n this.isDirtyBox = true;\n }\n }\n /**\n * @private\n */\n function compose(ChartClass, NavigationBindingsClass) {\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'afterGetContainer', onChartAfterGetContainer);\n addEvent(ChartClass, 'beforeRedraw', onChartBeforeRedraw);\n addEvent(ChartClass, 'beforeRender', onChartBeforeRedraw);\n addEvent(ChartClass, 'destroy', onChartDestroy);\n addEvent(ChartClass, 'getMargins', onChartGetMargins, { order: 0 });\n addEvent(ChartClass, 'redraw', onChartRedraw);\n addEvent(ChartClass, 'render', onChartRender);\n ChartClass.prototype.setStockTools = chartSetStockTools;\n }\n if (U.pushUnique(composedMembers, NavigationBindingsClass)) {\n addEvent(NavigationBindingsClass, 'deselectButton', onNavigationBindingsDeselectButton);\n addEvent(NavigationBindingsClass, 'selectButton', onNavigationBindingsSelectButton);\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n setOptions(StockToolsDefaults);\n }\n }\n /**\n * Run HTML generator\n * @private\n */\n function onChartAfterGetContainer() {\n this.setStockTools();\n }\n /**\n * Handle beforeRedraw and beforeRender\n * @private\n */\n function onChartBeforeRedraw() {\n if (this.stockTools) {\n const optionsChart = this.options.chart;\n const listWrapper = this.stockTools.listWrapper, offsetWidth = listWrapper && ((listWrapper.startWidth +\n getStyle(listWrapper, 'padding-left') +\n getStyle(listWrapper, 'padding-right')) || listWrapper.offsetWidth);\n let dirty = false;\n if (offsetWidth && offsetWidth < this.plotWidth) {\n const nextX = pick(optionsChart.spacingLeft, optionsChart.spacing && optionsChart.spacing[3], 0) + offsetWidth;\n const diff = nextX - this.spacingBox.x;\n this.spacingBox.x = nextX;\n this.spacingBox.width -= diff;\n dirty = true;\n }\n else if (offsetWidth === 0) {\n dirty = true;\n }\n if (offsetWidth !== this.stockTools.prevOffsetWidth) {\n this.stockTools.prevOffsetWidth = offsetWidth;\n if (dirty) {\n this.isDirtyLegend = true;\n }\n }\n }\n }\n /**\n * @private\n */\n function onChartDestroy() {\n if (this.stockTools) {\n this.stockTools.destroy();\n }\n }\n /**\n * @private\n */\n function onChartGetMargins() {\n const listWrapper = this.stockTools && this.stockTools.listWrapper, offsetWidth = listWrapper && ((listWrapper.startWidth +\n getStyle(listWrapper, 'padding-left') +\n getStyle(listWrapper, 'padding-right')) || listWrapper.offsetWidth);\n if (offsetWidth && offsetWidth < this.plotWidth) {\n this.plotLeft += offsetWidth;\n this.spacing[3] += offsetWidth;\n }\n }\n /**\n * @private\n */\n function onChartRedraw() {\n if (this.stockTools && this.stockTools.guiEnabled) {\n this.stockTools.redraw();\n }\n }\n /**\n * Check if the correct price indicator button is displayed, #15029.\n * @private\n */\n function onChartRender() {\n const stockTools = this.stockTools, button = stockTools &&\n stockTools.toolbar &&\n stockTools.toolbar.querySelector('.highcharts-current-price-indicator');\n // Change the initial button background.\n if (stockTools &&\n this.navigationBindings &&\n this.options.series &&\n button) {\n if (this.navigationBindings.constructor.prototype.utils\n .isPriceIndicatorEnabled(this.series)) {\n button.firstChild.style['background-image'] =\n 'url(\"' + stockTools.getIconsURL() + 'current-price-hide.svg\")';\n }\n else {\n button.firstChild.style['background-image'] =\n 'url(\"' + stockTools.getIconsURL() + 'current-price-show.svg\")';\n }\n }\n }\n /**\n * @private\n */\n function onNavigationBindingsDeselectButton(event) {\n const className = 'highcharts-submenu-wrapper', gui = this.chart.stockTools;\n if (gui && gui.guiEnabled) {\n let button = event.button;\n // If deselecting a button from a submenu, select state for it's parent\n if (button.parentNode.className.indexOf(className) >= 0) {\n button = button.parentNode.parentNode;\n }\n // Set active class on the current button\n gui.toggleButtonActiveClass(button);\n }\n }\n /**\n * Communication with bindings\n * @private\n */\n function onNavigationBindingsSelectButton(event) {\n const className = 'highcharts-submenu-wrapper', gui = this.chart.stockTools;\n if (gui && gui.guiEnabled) {\n let button = event.button;\n // Unslect other active buttons\n gui.unselectAllButtons(event.button);\n // If clicked on a submenu, select state for it's parent\n if (button.parentNode.className.indexOf(className) >= 0) {\n button = button.parentNode.parentNode;\n }\n // Set active class on the current button\n gui.toggleButtonActiveClass(button);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const StockToolsGui = {\n compose\n };\n\n return StockToolsGui;\n });\n _registerModule(_modules, 'masters/modules/stock-tools.src.js', [_modules['Core/Globals.js'], _modules['Extensions/Annotations/NavigationBindings.js'], _modules['Stock/StockTools/StockTools.js'], _modules['Stock/StockTools/StockToolsGui.js'], _modules['Stock/StockTools/StockToolbar.js']], function (Highcharts, NavigationBindings, StockTools, StockToolsGui, Toolbar) {\n\n const G = Highcharts;\n G.Toolbar = Toolbar;\n StockTools.compose(NavigationBindings);\n StockToolsGui.compose(G.Chart, NavigationBindings);\n\n });\n}));","/**\n * @license Highstock JS v11.1.0 (2023-06-05)\n *\n * Highcharts Stock as a plugin for Highcharts\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n */\n(function (factory) {\n if (typeof module === 'object' && module.exports) {\n factory['default'] = factory;\n module.exports = factory;\n } else if (typeof define === 'function' && define.amd) {\n define('highcharts/modules/stock', ['highcharts'], function (Highcharts) {\n factory(Highcharts);\n factory.Highcharts = Highcharts;\n return factory;\n });\n } else {\n factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);\n }\n}(function (Highcharts) {\n 'use strict';\n var _modules = Highcharts ? Highcharts._modules : {};\n function _registerModule(obj, path, args, fn) {\n if (!obj.hasOwnProperty(path)) {\n obj[path] = fn.apply(null, args);\n\n if (typeof CustomEvent === 'function') {\n window.dispatchEvent(\n new CustomEvent(\n 'HighchartsModuleLoaded',\n { detail: { path: path, module: obj[path] }\n })\n );\n }\n }\n }\n _registerModule(_modules, 'Core/Axis/BrokenAxis.js', [_modules['Core/Axis/Stacking/StackItem.js'], _modules['Core/Utilities.js']], function (StackItem, U) {\n /* *\n *\n * (c) 2009-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, find, fireEvent, isArray, isNumber, pick } = U;\n /* *\n *\n * Composition\n *\n * */\n /**\n * Axis with support of broken data rows.\n * @private\n */\n var BrokenAxis;\n (function (BrokenAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Adds support for broken axes.\n * @private\n */\n function compose(AxisClass, SeriesClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('brokenAxis');\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'afterInit', onAxisAfterInit);\n addEvent(AxisClass, 'afterSetTickPositions', onAxisAfterSetTickPositions);\n addEvent(AxisClass, 'afterSetOptions', onAxisAfterSetOptions);\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.drawBreaks = seriesDrawBreaks;\n seriesProto.gappedPath = seriesGappedPath;\n addEvent(SeriesClass, 'afterGeneratePoints', onSeriesAfterGeneratePoints);\n addEvent(SeriesClass, 'afterRender', onSeriesAfterRender);\n }\n return AxisClass;\n }\n BrokenAxis.compose = compose;\n /**\n * @private\n */\n function onAxisAfterInit() {\n if (typeof this.brokenAxis !== 'undefined') {\n this.brokenAxis.setBreaks(this.options.breaks, false);\n }\n }\n /**\n * Force Axis to be not-ordinal when breaks are defined.\n * @private\n */\n function onAxisAfterSetOptions() {\n const axis = this;\n if (axis.brokenAxis && axis.brokenAxis.hasBreaks) {\n axis.options.ordinal = false;\n }\n }\n /**\n * @private\n */\n function onAxisAfterSetTickPositions() {\n const axis = this, brokenAxis = axis.brokenAxis;\n if (brokenAxis &&\n brokenAxis.hasBreaks) {\n const tickPositions = axis.tickPositions, info = axis.tickPositions.info, newPositions = [];\n for (let i = 0; i < tickPositions.length; i++) {\n if (!brokenAxis.isInAnyBreak(tickPositions[i])) {\n newPositions.push(tickPositions[i]);\n }\n }\n axis.tickPositions = newPositions;\n axis.tickPositions.info = info;\n }\n }\n /**\n * @private\n */\n function onAxisInit() {\n const axis = this;\n if (!axis.brokenAxis) {\n axis.brokenAxis = new Additions(axis);\n }\n }\n /**\n * @private\n */\n function onSeriesAfterGeneratePoints() {\n const { isDirty, options: { connectNulls }, points, xAxis, yAxis } = this;\n // Set, or reset visibility of the points. Axis.setBreaks marks\n // the series as isDirty\n if (isDirty) {\n let i = points.length;\n while (i--) {\n const point = points[i];\n // Respect nulls inside the break (#4275)\n const nullGap = point.y === null && connectNulls === false;\n const isPointInBreak = (!nullGap && ((xAxis &&\n xAxis.brokenAxis &&\n xAxis.brokenAxis.isInAnyBreak(point.x, true)) || (yAxis &&\n yAxis.brokenAxis &&\n yAxis.brokenAxis.isInAnyBreak(point.y, true))));\n // Set point.visible if in any break.\n // If not in break, reset visible to original value.\n point.visible = isPointInBreak ?\n false :\n point.options.visible !== false;\n }\n }\n }\n /**\n * @private\n */\n function onSeriesAfterRender() {\n this.drawBreaks(this.xAxis, ['x']);\n this.drawBreaks(this.yAxis, pick(this.pointArrayMap, ['y']));\n }\n /**\n * @private\n */\n function seriesDrawBreaks(axis, keys) {\n const series = this, points = series.points;\n let breaks, threshold, eventName, y;\n if (axis && // #5950\n axis.brokenAxis &&\n axis.brokenAxis.hasBreaks) {\n const brokenAxis = axis.brokenAxis;\n keys.forEach(function (key) {\n breaks = brokenAxis && brokenAxis.breakArray || [];\n threshold = axis.isXAxis ?\n axis.min :\n pick(series.options.threshold, axis.min);\n points.forEach(function (point) {\n y = pick(point['stack' + key.toUpperCase()], point[key]);\n breaks.forEach(function (brk) {\n if (isNumber(threshold) && isNumber(y)) {\n eventName = false;\n if ((threshold < brk.from && y > brk.to) ||\n (threshold > brk.from && y < brk.from)) {\n eventName = 'pointBreak';\n }\n else if ((threshold < brk.from &&\n y > brk.from &&\n y < brk.to) || (threshold > brk.from &&\n y > brk.to &&\n y < brk.from)) {\n eventName = 'pointInBreak';\n }\n if (eventName) {\n fireEvent(axis, eventName, { point, brk });\n }\n }\n });\n });\n });\n }\n }\n /**\n * Extend getGraphPath by identifying gaps in the data so that we\n * can draw a gap in the line or area. This was moved from ordinal\n * axis module to broken axis module as of #5045.\n *\n * @private\n * @function Highcharts.Series#gappedPath\n *\n * @return {Highcharts.SVGPathArray}\n * Gapped path\n */\n function seriesGappedPath() {\n const currentDataGrouping = this.currentDataGrouping, groupingSize = currentDataGrouping && currentDataGrouping.gapSize, points = this.points.slice(), yAxis = this.yAxis;\n let gapSize = this.options.gapSize, i = points.length - 1, stack;\n /**\n * Defines when to display a gap in the graph, together with the\n * [gapUnit](plotOptions.series.gapUnit) option.\n *\n * In case when `dataGrouping` is enabled, points can be grouped\n * into a larger time span. This can make the grouped points to\n * have a greater distance than the absolute value of `gapSize`\n * property, which will result in disappearing graph completely.\n * To prevent this situation the mentioned distance between\n * grouped points is used instead of previously defined\n * `gapSize`.\n *\n * In practice, this option is most often used to visualize gaps\n * in time series. In a stock chart, intraday data is available\n * for daytime hours, while gaps will appear in nights and\n * weekends.\n *\n * @see [gapUnit](plotOptions.series.gapUnit)\n * @see [xAxis.breaks](#xAxis.breaks)\n *\n * @sample {highstock} stock/plotoptions/series-gapsize/\n * Setting the gap size to 2 introduces gaps for weekends in\n * daily datasets.\n *\n * @type {number}\n * @default 0\n * @product highstock\n * @requires modules/broken-axis\n * @apioption plotOptions.series.gapSize\n */\n /**\n * Together with [gapSize](plotOptions.series.gapSize), this\n * option defines where to draw gaps in the graph.\n *\n * When the `gapUnit` is `\"relative\"` (default), a gap size of 5\n * means that if the distance between two points is greater than\n * 5 times that of the two closest points, the graph will be\n * broken.\n *\n * When the `gapUnit` is `\"value\"`, the gap is based on absolute\n * axis values, which on a datetime axis is milliseconds. This\n * also applies to the navigator series that inherits gap\n * options from the base series.\n *\n * @see [gapSize](plotOptions.series.gapSize)\n *\n * @type {string}\n * @default relative\n * @since 5.0.13\n * @product highstock\n * @validvalue [\"relative\", \"value\"]\n * @requires modules/broken-axis\n * @apioption plotOptions.series.gapUnit\n */\n if (gapSize && i > 0) { // #5008\n // Gap unit is relative\n if (this.options.gapUnit !== 'value') {\n gapSize *= this.basePointRange;\n }\n // Setting a new gapSize in case dataGrouping is enabled\n // (#7686)\n if (groupingSize &&\n groupingSize > gapSize &&\n // Except when DG is forced (e.g. from other series)\n // and has lower granularity than actual points (#11351)\n groupingSize >= this.basePointRange) {\n gapSize = groupingSize;\n }\n // extension for ordinal breaks\n let current, next;\n while (i--) {\n // Reassign next if it is not visible\n if (!(next && next.visible !== false)) {\n next = points[i + 1];\n }\n current = points[i];\n // Skip iteration if one of the points is not visible\n if (next.visible === false || current.visible === false) {\n continue;\n }\n if (next.x - current.x > gapSize) {\n const xRange = (current.x + next.x) / 2;\n points.splice(// insert after this one\n i + 1, 0, {\n isNull: true,\n x: xRange\n });\n // For stacked chart generate empty stack items, #6546\n if (yAxis.stacking && this.options.stacking) {\n stack = yAxis.stacking.stacks[this.stackKey][xRange] = new StackItem(yAxis, yAxis.options.stackLabels, false, xRange, this.stack);\n stack.total = 0;\n }\n }\n // Assign current to next for the upcoming iteration\n next = current;\n }\n }\n // Call base method\n return this.getGraphPath(points);\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * Provides support for broken axes.\n * @private\n * @class\n */\n class Additions {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n static isInBreak(brk, val) {\n const repeat = brk.repeat || Infinity, from = brk.from, length = brk.to - brk.from, test = (val >= from ?\n (val - from) % repeat :\n repeat - ((from - val) % repeat));\n let ret;\n if (!brk.inclusive) {\n ret = test < length && test !== 0;\n }\n else {\n ret = test <= length;\n }\n return ret;\n }\n /**\n * @private\n */\n static lin2Val(val) {\n const axis = this;\n const brokenAxis = axis.brokenAxis;\n const breakArray = brokenAxis && brokenAxis.breakArray;\n if (!breakArray || !isNumber(val)) {\n return val;\n }\n let nval = val, brk, i;\n for (i = 0; i < breakArray.length; i++) {\n brk = breakArray[i];\n if (brk.from >= nval) {\n break;\n }\n else if (brk.to < nval) {\n nval += brk.len;\n }\n else if (Additions.isInBreak(brk, nval)) {\n nval += brk.len;\n }\n }\n return nval;\n }\n /**\n * @private\n */\n static val2Lin(val) {\n const axis = this;\n const brokenAxis = axis.brokenAxis;\n const breakArray = brokenAxis && brokenAxis.breakArray;\n if (!breakArray || !isNumber(val)) {\n return val;\n }\n let nval = val, brk, i;\n for (i = 0; i < breakArray.length; i++) {\n brk = breakArray[i];\n if (brk.to <= val) {\n nval -= brk.len;\n }\n else if (brk.from >= val) {\n break;\n }\n else if (Additions.isInBreak(brk, val)) {\n nval -= (val - brk.from);\n break;\n }\n }\n return nval;\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.hasBreaks = false;\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Returns the first break found where the x is larger then break.from\n * and smaller then break.to.\n *\n * @param {number} x\n * The number which should be within a break.\n *\n * @param {Array} breaks\n * The array of breaks to search within.\n *\n * @return {Highcharts.XAxisBreaksOptions|undefined}\n * Returns the first break found that matches, returns false if no break\n * is found.\n */\n findBreakAt(x, breaks) {\n return find(breaks, function (b) {\n return b.from < x && x < b.to;\n });\n }\n /**\n * @private\n */\n isInAnyBreak(val, testKeep) {\n const brokenAxis = this, axis = brokenAxis.axis, breaks = axis.options.breaks || [];\n let i = breaks.length, inbrk, keep, ret;\n if (i && isNumber(val)) {\n while (i--) {\n if (Additions.isInBreak(breaks[i], val)) {\n inbrk = true;\n if (!keep) {\n keep = pick(breaks[i].showPoints, !axis.isXAxis);\n }\n }\n }\n if (inbrk && testKeep) {\n ret = inbrk && !keep;\n }\n else {\n ret = inbrk;\n }\n }\n return ret;\n }\n /**\n * Dynamically set or unset breaks in an axis. This function in lighter\n * than usin Axis.update, and it also preserves animation.\n *\n * @private\n * @function Highcharts.Axis#setBreaks\n *\n * @param {Array} [breaks]\n * The breaks to add. When `undefined` it removes existing breaks.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart immediately.\n */\n setBreaks(breaks, redraw) {\n const brokenAxis = this;\n const axis = brokenAxis.axis;\n const hasBreaks = (isArray(breaks) && !!breaks.length);\n axis.isDirty = brokenAxis.hasBreaks !== hasBreaks;\n brokenAxis.hasBreaks = hasBreaks;\n if (breaks !== axis.options.breaks) {\n axis.options.breaks = axis.userOptions.breaks = breaks;\n }\n axis.forceRedraw = true; // Force recalculation in setScale\n // Recalculate series related to the axis.\n axis.series.forEach(function (series) {\n series.isDirty = true;\n });\n if (!hasBreaks && axis.val2lin === Additions.val2Lin) {\n // Revert to prototype functions\n delete axis.val2lin;\n delete axis.lin2val;\n }\n if (hasBreaks) {\n axis.userOptions.ordinal = false;\n axis.lin2val = Additions.lin2Val;\n axis.val2lin = Additions.val2Lin;\n axis.setExtremes = function (newMin, newMax, redraw, animation, eventArguments) {\n // If trying to set extremes inside a break, extend min to\n // after, and max to before the break ( #3857 )\n if (brokenAxis.hasBreaks) {\n const breaks = (this.options.breaks || []);\n let axisBreak;\n while ((axisBreak = brokenAxis.findBreakAt(newMin, breaks))) {\n newMin = axisBreak.to;\n }\n while ((axisBreak = brokenAxis.findBreakAt(newMax, breaks))) {\n newMax = axisBreak.from;\n }\n // If both min and max is within the same break.\n if (newMax < newMin) {\n newMax = newMin;\n }\n }\n axis.constructor.prototype.setExtremes.call(this, newMin, newMax, redraw, animation, eventArguments);\n };\n axis.setAxisTranslation = function () {\n axis.constructor.prototype.setAxisTranslation.call(this);\n brokenAxis.unitLength = void 0;\n if (brokenAxis.hasBreaks) {\n const breaks = axis.options.breaks || [], \n // Temporary one:\n breakArrayT = [], breakArray = [], pointRangePadding = pick(axis.pointRangePadding, 0);\n let length = 0, inBrk, repeat, min = axis.userMin || axis.min, max = axis.userMax || axis.max, start, i;\n // Min & max check (#4247)\n breaks.forEach(function (brk) {\n repeat = brk.repeat || Infinity;\n if (isNumber(min) && isNumber(max)) {\n if (Additions.isInBreak(brk, min)) {\n min += ((brk.to % repeat) -\n (min % repeat));\n }\n if (Additions.isInBreak(brk, max)) {\n max -= ((max % repeat) -\n (brk.from % repeat));\n }\n }\n });\n // Construct an array holding all breaks in the axis\n breaks.forEach(function (brk) {\n start = brk.from;\n repeat = brk.repeat || Infinity;\n if (isNumber(min) && isNumber(max)) {\n while (start - repeat > min) {\n start -= repeat;\n }\n while (start < min) {\n start += repeat;\n }\n for (i = start; i < max; i += repeat) {\n breakArrayT.push({\n value: i,\n move: 'in'\n });\n breakArrayT.push({\n value: i + brk.to - brk.from,\n move: 'out',\n size: brk.breakSize\n });\n }\n }\n });\n breakArrayT.sort(function (a, b) {\n return ((a.value === b.value) ?\n ((a.move === 'in' ? 0 : 1) -\n (b.move === 'in' ? 0 : 1)) :\n a.value - b.value);\n });\n // Simplify the breaks\n inBrk = 0;\n start = min;\n breakArrayT.forEach(function (brk) {\n inBrk += (brk.move === 'in' ? 1 : -1);\n if (inBrk === 1 && brk.move === 'in') {\n start = brk.value;\n }\n if (inBrk === 0 && isNumber(start)) {\n breakArray.push({\n from: start,\n to: brk.value,\n len: brk.value - start - (brk.size || 0)\n });\n length += (brk.value -\n start -\n (brk.size || 0));\n }\n });\n brokenAxis.breakArray = breakArray;\n // Used with staticScale, and below the actual axis\n // length, when breaks are substracted.\n if (isNumber(min) &&\n isNumber(max) &&\n isNumber(axis.min)) {\n brokenAxis.unitLength = max - min - length +\n pointRangePadding;\n fireEvent(axis, 'afterBreaks');\n if (axis.staticScale) {\n axis.transA = axis.staticScale;\n }\n else if (brokenAxis.unitLength) {\n axis.transA *=\n (max - axis.min + pointRangePadding) /\n brokenAxis.unitLength;\n }\n if (pointRangePadding) {\n axis.minPixelPadding =\n axis.transA * (axis.minPointOffset || 0);\n }\n axis.min = min;\n axis.max = max;\n }\n }\n };\n }\n if (pick(redraw, true)) {\n axis.chart.redraw();\n }\n }\n }\n BrokenAxis.Additions = Additions;\n })(BrokenAxis || (BrokenAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return BrokenAxis;\n });\n _registerModule(_modules, 'masters/modules/broken-axis.src.js', [_modules['Core/Globals.js'], _modules['Core/Axis/BrokenAxis.js']], function (Highcharts, BrokenAxis) {\n\n const G = Highcharts;\n // Compositions\n BrokenAxis.compose(G.Axis, G.Series);\n\n });\n _registerModule(_modules, 'Extensions/DataGrouping/ApproximationRegistry.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Define the available approximation types. The data grouping\n * approximations takes an array or numbers as the first parameter. In case\n * of ohlc, four arrays are sent in as four parameters. Each array consists\n * only of numbers. In case null values belong to the group, the property\n * .hasNulls will be set to true on the array.\n *\n * @product highstock\n *\n * @private\n */\n const ApproximationRegistry = {\n // approximations added programmatically\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ApproximationRegistry;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/ApproximationDefaults.js', [_modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Core/Utilities.js']], function (ApproximationRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { arrayMax, arrayMin, correctFloat, extend, isNumber } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function average(arr) {\n const len = arr.length;\n let ret = sum(arr);\n // If we have a number, return it divided by the length. If not,\n // return null or undefined based on what the sum method finds.\n if (isNumber(ret) && len) {\n ret = correctFloat(ret / len);\n }\n return ret;\n }\n /**\n * The same as average, but for series with multiple values, like area ranges.\n * @private\n */\n function averages() {\n const ret = [];\n [].forEach.call(arguments, function (arr) {\n ret.push(average(arr));\n });\n // Return undefined when first elem. is undefined and let\n // sum method handle null (#7377)\n return typeof ret[0] === 'undefined' ? void 0 : ret;\n }\n /**\n * @private\n */\n function close(arr) {\n return arr.length ?\n arr[arr.length - 1] :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function high(arr) {\n return arr.length ?\n arrayMax(arr) :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * HLC, OHLC and range are special cases where a multidimensional array is input\n * and an array is output.\n * @private\n */\n function hlc(high, low, close) {\n high = ApproximationRegistry.high(high);\n low = ApproximationRegistry.low(low);\n close = ApproximationRegistry.close(close);\n if (isNumber(high) ||\n isNumber(low) ||\n isNumber(close)) {\n return [high, low, close];\n }\n }\n /**\n * @private\n */\n function low(arr) {\n return arr.length ?\n arrayMin(arr) :\n (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function ohlc(open, high, low, close) {\n open = ApproximationRegistry.open(open);\n high = ApproximationRegistry.high(high);\n low = ApproximationRegistry.low(low);\n close = ApproximationRegistry.close(close);\n if (isNumber(open) ||\n isNumber(high) ||\n isNumber(low) ||\n isNumber(close)) {\n return [open, high, low, close];\n }\n }\n /**\n * @private\n */\n function open(arr) {\n return arr.length ? arr[0] : (arr.hasNulls ? null : void 0);\n }\n /**\n * @private\n */\n function range(low, high) {\n low = ApproximationRegistry.low(low);\n high = ApproximationRegistry.high(high);\n if (isNumber(low) || isNumber(high)) {\n return [low, high];\n }\n if (low === null && high === null) {\n return null;\n }\n // else, return is undefined\n }\n /**\n * @private\n */\n function sum(arr) {\n let len = arr.length, ret;\n // 1. it consists of nulls exclusive\n if (!len && arr.hasNulls) {\n ret = null;\n // 2. it has a length and real values\n }\n else if (len) {\n ret = 0;\n while (len--) {\n ret += arr[len];\n }\n }\n // 3. it has zero length, so just return undefined\n // => doNothing()\n return ret;\n }\n /* *\n *\n * Default Export\n *\n * */\n const ApproximationDefaults = {\n average,\n averages,\n close,\n high,\n hlc,\n low,\n ohlc,\n open,\n range,\n sum\n };\n extend(ApproximationRegistry, ApproximationDefaults);\n\n return ApproximationDefaults;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Common options\n * @private\n */\n const common = {\n // enabled: null, // (true for stock charts, false for basic),\n // forced: undefined,\n groupPixelWidth: 2,\n // the first one is the point or start value, the second is the start\n // value if we're dealing with range, the third one is the end value if\n // dealing with a range\n dateTimeLabelFormats: {\n millisecond: [\n '%A, %e %b, %H:%M:%S.%L',\n '%A, %e %b, %H:%M:%S.%L',\n '-%H:%M:%S.%L'\n ],\n second: [\n '%A, %e %b, %H:%M:%S',\n '%A, %e %b, %H:%M:%S',\n '-%H:%M:%S'\n ],\n minute: [\n '%A, %e %b, %H:%M',\n '%A, %e %b, %H:%M',\n '-%H:%M'\n ],\n hour: [\n '%A, %e %b, %H:%M',\n '%A, %e %b, %H:%M',\n '-%H:%M'\n ],\n day: [\n '%A, %e %b %Y',\n '%A, %e %b',\n '-%A, %e %b %Y'\n ],\n week: [\n 'Week from %A, %e %b %Y',\n '%A, %e %b',\n '-%A, %e %b %Y'\n ],\n month: [\n '%B %Y',\n '%B',\n '-%B %Y'\n ],\n year: [\n '%Y',\n '%Y',\n '-%Y'\n ]\n }\n // smoothed = false, // enable this for navigator series only\n };\n /**\n * Extends common options\n * @private\n */\n const seriesSpecific = {\n line: {},\n spline: {},\n area: {},\n areaspline: {},\n arearange: {},\n column: {\n groupPixelWidth: 10\n },\n columnrange: {\n groupPixelWidth: 10\n },\n candlestick: {\n groupPixelWidth: 10\n },\n ohlc: {\n groupPixelWidth: 5\n },\n hlc: {\n groupPixelWidth: 5\n // Move to HeikinAshiSeries.ts aftre refactoring data grouping.\n },\n heikinashi: {\n groupPixelWidth: 10\n }\n };\n /**\n * Units are defined in a separate array to allow complete overriding in\n * case of a user option.\n * @private\n */\n const units = [\n [\n 'millisecond',\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n ], [\n 'second',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'minute',\n [1, 2, 5, 10, 15, 30]\n ], [\n 'hour',\n [1, 2, 3, 4, 6, 8, 12]\n ], [\n 'day',\n [1]\n ], [\n 'week',\n [1]\n ], [\n 'month',\n [1, 3, 6]\n ], [\n 'year',\n null\n ]\n ];\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingDefaults = {\n common,\n seriesSpecific,\n units\n };\n\n return DataGroupingDefaults;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingAxisComposition.js', [_modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Core/Utilities.js']], function (DataGroupingDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, extend, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let AxisConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Check the groupPixelWidth and apply the grouping if needed.\n * Fired only after processing the data.\n *\n * @product highstock\n *\n * @function Highcharts.Axis#applyGrouping\n */\n function applyGrouping(e) {\n const axis = this, series = axis.series;\n // Reset the groupPixelWidth for all series, #17141.\n series.forEach(function (series) {\n series.groupPixelWidth = void 0; // #2110\n });\n series.forEach(function (series) {\n series.groupPixelWidth = (axis.getGroupPixelWidth &&\n axis.getGroupPixelWidth());\n if (series.groupPixelWidth) {\n series.hasProcessed = true; // #2692\n }\n // Fire independing on series.groupPixelWidth to always set a proper\n // dataGrouping state, (#16238)\n series.applyGrouping(!!e.hasExtremesChanged);\n });\n }\n /**\n * @private\n */\n function compose(AxisClass) {\n AxisConstructor = AxisClass;\n if (U.pushUnique(composedMembers, AxisClass)) {\n addEvent(AxisClass, 'afterSetScale', onAfterSetScale);\n // When all series are processed, calculate the group pixel width and\n // then if this value is different than zero apply groupings.\n addEvent(AxisClass, 'postProcessData', applyGrouping);\n extend(AxisClass.prototype, {\n applyGrouping,\n getGroupPixelWidth,\n setDataGrouping\n });\n }\n }\n /**\n * Get the data grouping pixel width based on the greatest defined individual\n * width of the axis' series, and if whether one of the axes need grouping.\n * @private\n */\n function getGroupPixelWidth() {\n const series = this.series;\n let i = series.length, groupPixelWidth = 0, doGrouping = false, dataLength, dgOptions;\n // If one of the series needs grouping, apply it to all (#1634)\n while (i--) {\n dgOptions = series[i].options.dataGrouping;\n if (dgOptions) { // #2692\n // If multiple series are compared on the same x axis, give them the\n // same group pixel width (#334)\n groupPixelWidth = Math.max(groupPixelWidth, \n // Fallback to commonOptions (#9693)\n pick(dgOptions.groupPixelWidth, DataGroupingDefaults.common.groupPixelWidth));\n dataLength = (series[i].processedXData || series[i].data).length;\n // Execute grouping if the amount of points is greater than the\n // limit defined in groupPixelWidth\n if (series[i].groupPixelWidth ||\n (dataLength >\n (this.chart.plotSizeX / groupPixelWidth)) ||\n (dataLength && dgOptions.forced)) {\n doGrouping = true;\n }\n }\n }\n return doGrouping ? groupPixelWidth : 0;\n }\n /**\n * When resetting the scale reset the hasProccessed flag to avoid taking\n * previous data grouping of neighbour series into accound when determining\n * group pixel width (#2692).\n * @private\n */\n function onAfterSetScale() {\n this.series.forEach(function (series) {\n series.hasProcessed = false;\n });\n }\n /**\n * Highcharts Stock only. Force data grouping on all the axis' series.\n *\n * @product highstock\n *\n * @function Highcharts.Axis#setDataGrouping\n *\n * @param {boolean|Highcharts.DataGroupingOptionsObject} [dataGrouping]\n * A `dataGrouping` configuration. Use `false` to disable data grouping\n * dynamically.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or wait for a later call to\n * {@link Chart#redraw}.\n */\n function setDataGrouping(dataGrouping, redraw) {\n const axis = this;\n let i;\n redraw = pick(redraw, true);\n if (!dataGrouping) {\n dataGrouping = {\n forced: false,\n units: null\n };\n }\n // Axis is instantiated, update all series\n if (this instanceof AxisConstructor) {\n i = this.series.length;\n while (i--) {\n this.series[i].update({\n dataGrouping: dataGrouping\n }, false);\n }\n // Axis not yet instanciated, alter series options\n }\n else {\n this.chart.options.series.forEach(function (seriesOptions) {\n // Merging dataGrouping options with already defined options #16759\n seriesOptions.dataGrouping = typeof dataGrouping === 'boolean' ?\n dataGrouping :\n merge(dataGrouping, seriesOptions.dataGrouping);\n });\n }\n // Clear ordinal slope, so we won't accidentaly use the old one (#7827)\n if (axis.ordinal) {\n axis.ordinal.slope = void 0;\n }\n if (redraw) {\n this.chart.redraw();\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingAxisComposition = {\n compose\n };\n\n return DataGroupingAxisComposition;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGroupingSeriesComposition.js', [_modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Core/Axis/DateTimeAxis.js'], _modules['Core/Defaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (ApproximationRegistry, DataGroupingDefaults, DateTimeAxis, D, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { series: { prototype: seriesProto } } = SeriesRegistry;\n const { addEvent, defined, error, extend, isNumber, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const baseGeneratePoints = seriesProto.generatePoints;\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function adjustExtremes(xAxis, groupedXData) {\n // Make sure the X axis extends to show the first group (#2533)\n // But only for visible series (#5493, #6393)\n if (defined(groupedXData[0]) &&\n isNumber(xAxis.min) &&\n isNumber(xAxis.dataMin) &&\n groupedXData[0] < xAxis.min) {\n if ((!defined(xAxis.options.min) &&\n xAxis.min <= xAxis.dataMin) ||\n xAxis.min === xAxis.dataMin) {\n xAxis.min = Math.min(groupedXData[0], xAxis.min);\n }\n xAxis.dataMin = Math.min(groupedXData[0], xAxis.dataMin);\n }\n // When the last anchor set, change the extremes that\n // the last point is visible (#12455).\n if (defined(groupedXData[groupedXData.length - 1]) &&\n isNumber(xAxis.max) &&\n isNumber(xAxis.dataMax) &&\n groupedXData[groupedXData.length - 1] > xAxis.max) {\n if ((!defined(xAxis.options.max) &&\n isNumber(xAxis.dataMax) &&\n xAxis.max >= xAxis.dataMax) || xAxis.max === xAxis.dataMax) {\n xAxis.max = Math.max(groupedXData[groupedXData.length - 1], xAxis.max);\n }\n xAxis.dataMax = Math.max(groupedXData[groupedXData.length - 1], xAxis.dataMax);\n }\n }\n /**\n * @private\n */\n function anchorPoints(series, groupedXData, xMax) {\n const options = series.options, dataGroupingOptions = options.dataGrouping, totalRange = (series.currentDataGrouping && series.currentDataGrouping.gapSize);\n let i;\n // DataGrouping x-coordinates.\n if (dataGroupingOptions && series.xData && totalRange && series.groupMap) {\n const groupedDataLength = groupedXData.length - 1, anchor = dataGroupingOptions.anchor, firstAnchor = pick(dataGroupingOptions.firstAnchor, anchor), lastAnchor = pick(dataGroupingOptions.lastAnchor, anchor);\n // Anchor points that are not extremes.\n if (anchor && anchor !== 'start') {\n const shiftInterval = (totalRange *\n { middle: 0.5, end: 1 }[anchor]);\n i = groupedXData.length - 1;\n while (i-- && i > 0) {\n groupedXData[i] += shiftInterval;\n }\n }\n // Change the first point position, but only when it is\n // the first point in the data set not in the current zoom.\n if (firstAnchor &&\n firstAnchor !== 'start' &&\n series.xData[0] >= groupedXData[0]) {\n const groupStart = series.groupMap[0].start, groupLength = series.groupMap[0].length;\n let firstGroupstEnd;\n if (isNumber(groupStart) && isNumber(groupLength)) {\n firstGroupstEnd = groupStart + (groupLength - 1);\n }\n groupedXData[0] = {\n middle: groupedXData[0] + 0.5 * totalRange,\n end: groupedXData[0] + totalRange,\n firstPoint: series.xData[0],\n lastPoint: firstGroupstEnd && series.xData[firstGroupstEnd]\n }[firstAnchor];\n }\n // Change the last point position but only when it is\n // the last point in the data set not in the current zoom.\n if (lastAnchor &&\n lastAnchor !== 'start' &&\n totalRange &&\n groupedXData[groupedDataLength] >= xMax - totalRange) {\n const lastGroupStart = series.groupMap[series.groupMap.length - 1].start;\n groupedXData[groupedDataLength] = {\n middle: groupedXData[groupedDataLength] + 0.5 * totalRange,\n end: groupedXData[groupedDataLength] + totalRange,\n firstPoint: lastGroupStart && series.xData[lastGroupStart],\n lastPoint: series.xData[series.xData.length - 1]\n }[lastAnchor];\n }\n }\n }\n /**\n * For the processed data, calculate the grouped data if needed.\n *\n * @private\n * @function Highcharts.Series#applyGrouping\n */\n function applyGrouping(hasExtremesChanged) {\n const series = this, chart = series.chart, options = series.options, dataGroupingOptions = options.dataGrouping, groupingEnabled = series.allowDG !== false && dataGroupingOptions &&\n pick(dataGroupingOptions.enabled, chart.options.isStock), visible = (series.visible || !chart.options.chart.ignoreHiddenSeries), lastDataGrouping = this.currentDataGrouping;\n let currentDataGrouping, croppedData, revertRequireSorting = false;\n // Data needs to be sorted for dataGrouping\n if (groupingEnabled && !series.requireSorting) {\n series.requireSorting = revertRequireSorting = true;\n }\n // Skip if skipDataGrouping method returns false or if grouping is disabled\n // (in that order).\n const skip = skipDataGrouping(series, hasExtremesChanged) === false || !groupingEnabled;\n // Revert original requireSorting value if changed\n if (revertRequireSorting) {\n series.requireSorting = false;\n }\n if (!skip) {\n series.destroyGroupedData();\n const processedXData = dataGroupingOptions.groupAll ?\n series.xData :\n series.processedXData, processedYData = dataGroupingOptions.groupAll ?\n series.yData :\n series.processedYData, plotSizeX = chart.plotSizeX, xAxis = series.xAxis, ordinal = xAxis.options.ordinal, groupPixelWidth = series.groupPixelWidth;\n let i, hasGroupedData;\n // Execute grouping if the amount of points is greater than the limit\n // defined in groupPixelWidth\n if (groupPixelWidth &&\n processedXData &&\n processedXData.length &&\n plotSizeX) {\n hasGroupedData = true;\n // Force recreation of point instances in series.translate, #5699\n series.isDirty = true;\n series.points = null; // #6709\n const extremes = xAxis.getExtremes(), xMin = extremes.min, xMax = extremes.max, groupIntervalFactor = (ordinal &&\n xAxis.ordinal &&\n xAxis.ordinal.getGroupIntervalFactor(xMin, xMax, series)) || 1, interval = (groupPixelWidth * (xMax - xMin) / plotSizeX) *\n groupIntervalFactor, groupPositions = xAxis.getTimeTicks(DateTimeAxis.Additions.prototype.normalizeTimeTickInterval(interval, dataGroupingOptions.units ||\n DataGroupingDefaults.units), \n // Processed data may extend beyond axis (#4907)\n Math.min(xMin, processedXData[0]), Math.max(xMax, processedXData[processedXData.length - 1]), xAxis.options.startOfWeek, processedXData, series.closestPointRange), groupedData = seriesProto.groupData.apply(series, [\n processedXData,\n processedYData,\n groupPositions,\n dataGroupingOptions.approximation\n ]);\n let groupedXData = groupedData.groupedXData, groupedYData = groupedData.groupedYData, gapSize = 0;\n // The smoothed option is deprecated, instead, there is a fallback\n // to the new anchoring mechanism. #12455.\n if (dataGroupingOptions &&\n dataGroupingOptions.smoothed &&\n groupedXData.length) {\n dataGroupingOptions.firstAnchor = 'firstPoint';\n dataGroupingOptions.anchor = 'middle';\n dataGroupingOptions.lastAnchor = 'lastPoint';\n error(32, false, chart, {\n 'dataGrouping.smoothed': 'use dataGrouping.anchor'\n });\n }\n anchorPoints(series, groupedXData, xMax);\n // Record what data grouping values were used\n for (i = 1; i < groupPositions.length; i++) {\n // The grouped gapSize needs to be the largest distance between\n // the group to capture varying group sizes like months or DST\n // crossing (#10000). Also check that the gap is not at the\n // start of a segment.\n if (!groupPositions.info.segmentStarts ||\n groupPositions.info.segmentStarts.indexOf(i) === -1) {\n gapSize = Math.max(groupPositions[i] - groupPositions[i - 1], gapSize);\n }\n }\n currentDataGrouping = groupPositions.info;\n currentDataGrouping.gapSize = gapSize;\n series.closestPointRange = groupPositions.info.totalRange;\n series.groupMap = groupedData.groupMap;\n if (visible) {\n adjustExtremes(xAxis, groupedXData);\n }\n // We calculated all group positions but we should render\n // only the ones within the visible range\n if (dataGroupingOptions.groupAll) {\n // Keep the reference to all grouped points\n // for further calculation (eg. heikinashi).\n series.allGroupedData = groupedYData;\n croppedData = series.cropData(groupedXData, groupedYData, xAxis.min, xAxis.max, 1 // Ordinal xAxis will remove left-most points otherwise\n );\n groupedXData = croppedData.xData;\n groupedYData = croppedData.yData;\n series.cropStart = croppedData.start; // #15005\n }\n // Set series props\n series.processedXData = groupedXData;\n series.processedYData = groupedYData;\n }\n else {\n series.groupMap = null;\n }\n series.hasGroupedData = hasGroupedData;\n series.currentDataGrouping = currentDataGrouping;\n series.preventGraphAnimation =\n (lastDataGrouping && lastDataGrouping.totalRange) !==\n (currentDataGrouping && currentDataGrouping.totalRange);\n }\n }\n /**\n * @private\n */\n function compose(SeriesClass) {\n const PointClass = SeriesClass.prototype.pointClass;\n if (U.pushUnique(composedMembers, PointClass)) {\n // Override point prototype to throw a warning when trying to update\n // grouped points.\n addEvent(PointClass, 'update', function () {\n if (this.dataGroup) {\n error(24, false, this.series.chart);\n return false;\n }\n });\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'afterSetOptions', onAfterSetOptions);\n addEvent(SeriesClass, 'destroy', destroyGroupedData);\n extend(SeriesClass.prototype, {\n applyGrouping,\n destroyGroupedData,\n generatePoints,\n getDGApproximation,\n groupData\n });\n }\n }\n /**\n * Destroy the grouped data points. #622, #740\n * @private\n */\n function destroyGroupedData() {\n // Clear previous groups\n if (this.groupedData) {\n this.groupedData.forEach(function (point, i) {\n if (point) {\n this.groupedData[i] = point.destroy ?\n point.destroy() : null;\n }\n }, this);\n // Clears all:\n // - `this.groupedData`\n // - `this.points`\n // - `preserve` object in series.update()\n this.groupedData.length = 0;\n }\n }\n /**\n * Override the generatePoints method by adding a reference to grouped data\n * @private\n */\n function generatePoints() {\n baseGeneratePoints.apply(this);\n // Record grouped data in order to let it be destroyed the next time\n // processData runs\n this.destroyGroupedData(); // #622\n this.groupedData = this.hasGroupedData ? this.points : null;\n }\n /**\n * Set default approximations to the prototypes if present. Properties are\n * inherited down. Can be overridden for individual series types.\n * @private\n */\n function getDGApproximation() {\n if (this.is('arearange')) {\n return 'range';\n }\n if (this.is('ohlc')) {\n return 'ohlc';\n }\n if (this.is('hlc')) {\n return 'hlc';\n }\n if (\n // #18974, default approximation for cumulative\n // should be `sum` when `dataGrouping` is enabled\n this.is('column') ||\n this.options.cumulative) {\n return 'sum';\n }\n return 'average';\n }\n /**\n * Highcharts Stock only. Takes parallel arrays of x and y data and groups the\n * data into intervals defined by groupPositions, a collection of starting x\n * values for each group.\n *\n * @product highstock\n *\n * @function Highcharts.Series#groupData\n * @param {Array} xData\n * Parallel array of x data.\n * @param {Array<(number|null|undefined)>|Array>} yData\n * Parallel array of y data.\n * @param {Array} groupPositions\n * Group positions.\n * @param {string|Function} [approximation]\n * Approximation to use.\n * @return {Highcharts.DataGroupingResultObject}\n * Mapped groups.\n */\n function groupData(xData, yData, groupPositions, approximation) {\n const series = this, data = series.data, dataOptions = series.options && series.options.data, groupedXData = [], groupedYData = [], groupMap = [], dataLength = xData.length, \n // when grouping the fake extended axis for panning,\n // we don't need to consider y\n handleYData = !!yData, values = [], pointArrayMap = series.pointArrayMap, pointArrayMapLength = pointArrayMap && pointArrayMap.length, extendedPointArrayMap = ['x'].concat(pointArrayMap || ['y']), groupAll = (this.options.dataGrouping &&\n this.options.dataGrouping.groupAll);\n let pointX, pointY, groupedY, pos = 0, start = 0;\n const approximationFn = (typeof approximation === 'function' ?\n approximation :\n approximation && ApproximationRegistry[approximation] ?\n ApproximationRegistry[approximation] :\n ApproximationRegistry[(series.getDGApproximation && series.getDGApproximation() ||\n 'average')]);\n // Calculate values array size from pointArrayMap length\n if (pointArrayMapLength) {\n let len = pointArrayMap.length;\n while (len--) {\n values.push([]);\n }\n }\n else {\n values.push([]);\n }\n const valuesLen = pointArrayMapLength || 1;\n for (let i = 0; i <= dataLength; i++) {\n // Start with the first point within the X axis range (#2696)\n if (xData[i] < groupPositions[0]) {\n continue; // with next point\n }\n // when a new group is entered, summarize and initialize\n // the previous group\n while ((typeof groupPositions[pos + 1] !== 'undefined' &&\n xData[i] >= groupPositions[pos + 1]) ||\n i === dataLength) { // get the last group\n // get group x and y\n pointX = groupPositions[pos];\n series.dataGroupInfo = {\n start: groupAll ? start : (series.cropStart + start),\n length: values[0].length\n };\n groupedY = approximationFn.apply(series, values);\n // By default, let options of the first grouped point be passed over\n // to the grouped point. This allows preserving properties like\n // `name` and `color` or custom properties. Implementers can\n // override this from the approximation function, where they can\n // write custom options to `this.dataGroupInfo.options`.\n if (series.pointClass && !defined(series.dataGroupInfo.options)) {\n // Convert numbers and arrays into objects\n series.dataGroupInfo.options = merge(series.pointClass.prototype\n .optionsToObject.call({ series: series }, series.options.data[series.cropStart + start]));\n // Make sure the raw data (x, y, open, high etc) is not copied\n // over and overwriting approximated data.\n extendedPointArrayMap.forEach(function (key) {\n delete series.dataGroupInfo.options[key];\n });\n }\n // push the grouped data\n if (typeof groupedY !== 'undefined') {\n groupedXData.push(pointX);\n groupedYData.push(groupedY);\n groupMap.push(series.dataGroupInfo);\n }\n // reset the aggregate arrays\n start = i;\n for (let j = 0; j < valuesLen; j++) {\n values[j].length = 0; // faster than values[j] = []\n values[j].hasNulls = false;\n }\n // Advance on the group positions\n pos += 1;\n // don't loop beyond the last group\n if (i === dataLength) {\n break;\n }\n }\n // break out\n if (i === dataLength) {\n break;\n }\n // for each raw data point, push it to an array that contains all values\n // for this specific group\n if (pointArrayMap) {\n const index = (series.options.dataGrouping &&\n series.options.dataGrouping.groupAll ?\n i : series.cropStart + i), point = (data && data[index]) ||\n series.pointClass.prototype.applyOptions.apply({\n series: series\n }, [dataOptions[index]]);\n let val;\n for (let j = 0; j < pointArrayMapLength; j++) {\n val = point[pointArrayMap[j]];\n if (isNumber(val)) {\n values[j].push(val);\n }\n else if (val === null) {\n values[j].hasNulls = true;\n }\n }\n }\n else {\n pointY = handleYData ? yData[i] : null;\n if (isNumber(pointY)) {\n values[0].push(pointY);\n }\n else if (pointY === null) {\n values[0].hasNulls = true;\n }\n }\n }\n return {\n groupedXData,\n groupedYData,\n groupMap\n };\n }\n /**\n * Handle default options for data grouping. This must be set at runtime because\n * some series types are defined after this.\n * @private\n */\n function onAfterSetOptions(e) {\n const options = e.options, type = this.type, plotOptions = this.chart.options.plotOptions, \n // External series, for example technical indicators should also inherit\n // commonOptions which are not available outside this module\n baseOptions = (this.useCommonDataGrouping &&\n DataGroupingDefaults.common), seriesSpecific = DataGroupingDefaults.seriesSpecific;\n let defaultOptions = D.defaultOptions.plotOptions[type].dataGrouping;\n if (plotOptions && (seriesSpecific[type] || baseOptions)) { // #1284\n const rangeSelector = this.chart.rangeSelector;\n if (!defaultOptions) {\n defaultOptions = merge(DataGroupingDefaults.common, seriesSpecific[type]);\n }\n options.dataGrouping = merge(baseOptions, defaultOptions, plotOptions.series && plotOptions.series.dataGrouping, // #1228\n // Set by the StockChart constructor:\n plotOptions[type].dataGrouping, this.userOptions.dataGrouping, !options.isInternal &&\n rangeSelector &&\n isNumber(rangeSelector.selected) &&\n rangeSelector.buttonOptions[rangeSelector.selected].dataGrouping);\n }\n }\n /**\n * @private\n */\n function skipDataGrouping(series, force) {\n return !(series.isCartesian &&\n !series.isDirty &&\n !series.xAxis.isDirty &&\n !series.yAxis.isDirty &&\n !force);\n }\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingSeriesComposition = {\n compose,\n groupData\n };\n\n return DataGroupingSeriesComposition;\n });\n _registerModule(_modules, 'Extensions/DataGrouping/DataGrouping.js', [_modules['Extensions/DataGrouping/DataGroupingAxisComposition.js'], _modules['Extensions/DataGrouping/DataGroupingDefaults.js'], _modules['Extensions/DataGrouping/DataGroupingSeriesComposition.js'], _modules['Core/Templating.js'], _modules['Core/Utilities.js']], function (DataGroupingAxisComposition, DataGroupingDefaults, DataGroupingSeriesComposition, F, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = F;\n const { addEvent, extend, isNumber } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AxisClass, SeriesClass, TooltipClass) {\n DataGroupingAxisComposition.compose(AxisClass);\n DataGroupingSeriesComposition.compose(SeriesClass);\n if (TooltipClass &&\n U.pushUnique(composedMembers, TooltipClass)) {\n addEvent(TooltipClass, 'headerFormatter', onTooltipHeaderFormatter);\n }\n }\n /**\n * Extend the original method, make the tooltip's header reflect the grouped\n * range.\n * @private\n */\n function onTooltipHeaderFormatter(e) {\n const chart = this.chart, time = chart.time, labelConfig = e.labelConfig, series = labelConfig.series, options = series.options, tooltipOptions = series.tooltipOptions, dataGroupingOptions = options.dataGrouping, xAxis = series.xAxis;\n let xDateFormat = tooltipOptions.xDateFormat, xDateFormatEnd, currentDataGrouping, dateTimeLabelFormats, labelFormats, formattedKey, formatString = tooltipOptions[e.isFooter ? 'footerFormat' : 'headerFormat'];\n // apply only to grouped series\n if (xAxis &&\n xAxis.options.type === 'datetime' &&\n dataGroupingOptions &&\n isNumber(labelConfig.key)) {\n // set variables\n currentDataGrouping = series.currentDataGrouping;\n dateTimeLabelFormats = dataGroupingOptions.dateTimeLabelFormats ||\n // Fallback to commonOptions (#9693)\n DataGroupingDefaults.common.dateTimeLabelFormats;\n // if we have grouped data, use the grouping information to get the\n // right format\n if (currentDataGrouping) {\n labelFormats =\n dateTimeLabelFormats[currentDataGrouping.unitName];\n if (currentDataGrouping.count === 1) {\n xDateFormat = labelFormats[0];\n }\n else {\n xDateFormat = labelFormats[1];\n xDateFormatEnd = labelFormats[2];\n }\n // if not grouped, and we don't have set the xDateFormat option, get the\n // best fit, so if the least distance between points is one minute, show\n // it, but if the least distance is one day, skip hours and minutes etc.\n }\n else if (!xDateFormat && dateTimeLabelFormats && xAxis.dateTime) {\n xDateFormat = xAxis.dateTime.getXDateFormat(labelConfig.x, tooltipOptions.dateTimeLabelFormats);\n }\n // now format the key\n formattedKey = time.dateFormat(xDateFormat, labelConfig.key);\n if (xDateFormatEnd) {\n formattedKey += time.dateFormat(xDateFormatEnd, labelConfig.key + currentDataGrouping.totalRange - 1);\n }\n // Replace default header style with class name\n if (series.chart.styledMode) {\n formatString = this.styledModeFormat(formatString);\n }\n // return the replaced format\n e.text = format(formatString, {\n point: extend(labelConfig.point, { key: formattedKey }),\n series: series\n }, chart);\n e.preventDefault();\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const DataGroupingComposition = {\n compose,\n groupData: DataGroupingSeriesComposition.groupData\n };\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"average\"|\"averages\"|\"open\"|\"high\"|\"low\"|\"close\"|\"sum\"} Highcharts.DataGroupingApproximationValue\n */\n /**\n * The position of the point inside the group.\n *\n * @typedef {\"start\"|\"middle\"|\"end\"} Highcharts.DataGroupingAnchor\n */\n /**\n * The position of the first or last point in the series inside the group.\n *\n * @typedef {\"start\"|\"middle\"|\"end\"|\"firstPoint\"|\"lastPoint\"} Highcharts.DataGroupingAnchorExtremes\n */\n /**\n * Highcharts Stock only.\n *\n * @product highstock\n * @interface Highcharts.DataGroupingInfoObject\n */ /**\n * @name Highcharts.DataGroupingInfoObject#length\n * @type {number}\n */ /**\n * @name Highcharts.DataGroupingInfoObject#options\n * @type {Highcharts.SeriesOptionsType|undefined}\n */ /**\n * @name Highcharts.DataGroupingInfoObject#start\n * @type {number}\n */\n /**\n * Highcharts Stock only.\n *\n * @product highstock\n * @interface Highcharts.DataGroupingResultObject\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupedXData\n * @type {Array}\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupedYData\n * @type {Array<(number|null|undefined)>|Array>}\n */ /**\n * @name Highcharts.DataGroupingResultObject#groupMap\n * @type {Array}\n */\n /**\n * Highcharts Stock only. If a point object is created by data\n * grouping, it doesn't reflect actual points in the raw\n * data. In this case, the `dataGroup` property holds\n * information that points back to the raw data.\n *\n * - `dataGroup.start` is the index of the first raw data\n * point in the group.\n *\n * - `dataGroup.length` is the amount of points in the\n * group.\n *\n * @sample stock/members/point-datagroup\n * Click to inspect raw data points\n *\n * @product highstock\n *\n * @name Highcharts.Point#dataGroup\n * @type {Highcharts.DataGroupingInfoObject|undefined}\n */\n (''); // detach doclets above\n /* *\n *\n * API Options\n *\n * */\n /**\n * Data grouping is the concept of sampling the data values into larger\n * blocks in order to ease readability and increase performance of the\n * JavaScript charts. Highcharts Stock by default applies data grouping when\n * the points become closer than a certain pixel value, determined by\n * the `groupPixelWidth` option.\n *\n * If data grouping is applied, the grouping information of grouped\n * points can be read from the [Point.dataGroup](\n * /class-reference/Highcharts.Point#dataGroup). If point options other than\n * the data itself are set, for example `name` or `color` or custom properties,\n * the grouping logic doesn't know how to group it. In this case the options of\n * the first point instance are copied over to the group point. This can be\n * altered through a custom `approximation` callback function.\n *\n * @declare Highcharts.DataGroupingOptionsObject\n * @product highstock\n * @requires product:highstock\n * @requires module:modules/datagrouping\n * @apioption plotOptions.series.dataGrouping\n */\n /**\n * Specifies how the points should be located on the X axis inside the group.\n * Points that are extremes can be set separately. Available options:\n *\n * - `start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * - `middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * - `end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-anchor\n * Changing the point x-coordinate inside the group.\n *\n * @see [dataGrouping.firstAnchor](#plotOptions.series.dataGrouping.firstAnchor)\n * @see [dataGrouping.lastAnchor](#plotOptions.series.dataGrouping.lastAnchor)\n *\n * @type {Highcharts.DataGroupingAnchor}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.anchor\n */\n /**\n * The method of approximation inside a group. When for example 30 days\n * are grouped into one month, this determines what value should represent\n * the group. Possible values are \"average\", \"averages\", \"open\", \"high\",\n * \"low\", \"close\" and \"sum\". For OHLC and candlestick series the approximation\n * is \"ohlc\" by default, which finds the open, high, low and close values\n * within all the grouped data. For ranges, the approximation is \"range\",\n * which finds the low and high values. For multi-dimensional data,\n * like ranges and OHLC, \"averages\" will compute the average for each\n * dimension.\n *\n * Custom aggregate methods can be added by assigning a callback function\n * as the approximation. This function takes a numeric array as the\n * argument and should return a single numeric value or `null`. Note\n * that the numeric array will never contain null values, only true\n * numbers. Instead, if null values are present in the raw data, the\n * numeric array will have an `.hasNulls` property set to `true`. For\n * single-value data sets the data is available in the first argument\n * of the callback function. For OHLC data sets, all the open values\n * are in the first argument, all high values in the second etc.\n *\n * Since v4.2.7, grouping meta data is available in the approximation\n * callback from `this.dataGroupInfo`. It can be used to extract information\n * from the raw data.\n *\n * Defaults to `average` for line-type series, `sum` for columns, `range`\n * for range series, `hlc` for HLC, and `ohlc` for OHLC and candlestick.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-approximation\n * Approximation callback with custom data\n * @sample {highstock} stock/plotoptions/series-datagrouping-simple-approximation\n * Simple approximation demo\n *\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @apioption plotOptions.series.dataGrouping.approximation\n */\n /**\n * Datetime formats for the header of the tooltip in a stock chart.\n * The format can vary within a chart depending on the currently selected\n * time range and the current data grouping.\n *\n * The default formats are:\n * ```js\n * {\n * millisecond: [\n * '%A, %e %b, %H:%M:%S.%L', '%A, %e %b, %H:%M:%S.%L', '-%H:%M:%S.%L'\n * ],\n * second: ['%A, %e %b, %H:%M:%S', '%A, %e %b, %H:%M:%S', '-%H:%M:%S'],\n * minute: ['%A, %e %b, %H:%M', '%A, %e %b, %H:%M', '-%H:%M'],\n * hour: ['%A, %e %b, %H:%M', '%A, %e %b, %H:%M', '-%H:%M'],\n * day: ['%A, %e %b %Y', '%A, %e %b', '-%A, %e %b %Y'],\n * week: ['Week from %A, %e %b %Y', '%A, %e %b', '-%A, %e %b %Y'],\n * month: ['%B %Y', '%B', '-%B %Y'],\n * year: ['%Y', '%Y', '-%Y']\n * }\n * ```\n *\n * For each of these array definitions, the first item is the format\n * used when the active time span is one unit. For instance, if the\n * current data applies to one week, the first item of the week array\n * is used. The second and third items are used when the active time\n * span is more than two units. For instance, if the current data applies\n * to two weeks, the second and third item of the week array are used,\n * and applied to the start and end date of the time span.\n *\n * @type {Object}\n * @apioption plotOptions.series.dataGrouping.dateTimeLabelFormats\n */\n /**\n * Enable or disable data grouping.\n *\n * @type {boolean}\n * @default true\n * @apioption plotOptions.series.dataGrouping.enabled\n */\n /**\n * Specifies how the first grouped point is positioned on the xAxis.\n * If firstAnchor and/or lastAnchor are defined, then those options take\n * precedence over anchor for the first and/or last grouped points.\n * Available options:\n *\n * -`start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * -`middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * -`end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * -`firstPoint` the first point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:13)\n *\n * -`lastPoint` the last point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-first-anchor\n * Applying first and last anchor.\n *\n * @see [dataGrouping.anchor](#plotOptions.series.dataGrouping.anchor)\n *\n * @type {Highcharts.DataGroupingAnchorExtremes}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.firstAnchor\n */\n /**\n * When data grouping is forced, it runs no matter how small the intervals\n * are. This can be handy for example when the sum should be calculated\n * for values appearing at random times within each hour.\n *\n * @type {boolean}\n * @default false\n * @apioption plotOptions.series.dataGrouping.forced\n */\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no grouping\n * is performed. If however the series contains so many points that\n * the spacing is less than the groupPixelWidth, Highcharts will try\n * to group it into appropriate groups so that each is more or less\n * two pixels wide. If multiple series with different group pixel widths\n * are drawn on the same x axis, all series will take the greatest width.\n * For example, line series have 2px default group width, while column\n * series have 10px. If combined, both the line and the column will\n * have 10px by default.\n *\n * @type {number}\n * @default 2\n * @apioption plotOptions.series.dataGrouping.groupPixelWidth\n */\n /**\n * By default only points within the visible range are grouped. Enabling this\n * option will force data grouping to calculate all grouped points for a given\n * dataset. That option prevents for example a column series from calculating\n * a grouped point partially. The effect is similar to\n * [Series.getExtremesFromAll](#plotOptions.series.getExtremesFromAll) but does\n * not affect yAxis extremes.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-groupall/\n * Two series with the same data but different groupAll setting\n *\n * @type {boolean}\n * @default false\n * @since 6.1.0\n * @apioption plotOptions.series.dataGrouping.groupAll\n */\n /**\n * Specifies how the last grouped point is positioned on the xAxis.\n * If firstAnchor and/or lastAnchor are defined, then those options take\n * precedence over anchor for the first and/or last grouped points.\n * Available options:\n *\n * -`start` places the point at the beginning of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 00:00:00)\n *\n * -`middle` places the point in the middle of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 12:00:00)\n *\n * -`end` places the point at the end of the group\n * (e.g. range 00:00:00 - 23:59:59 -> 23:59:59)\n *\n * -`firstPoint` the first point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:13)\n *\n * -`lastPoint` the last point in the group\n * (e.g. points at 00:13, 00:35, 00:59 -> 00:59)\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-first-anchor\n * Applying first and last anchor.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-last-anchor\n * Applying the last anchor in the chart with live data.\n *\n * @see [dataGrouping.anchor](#plotOptions.series.dataGrouping.anchor)\n *\n * @type {Highcharts.DataGroupingAnchorExtremes}\n * @since 9.1.0\n * @default start\n * @apioption plotOptions.series.dataGrouping.lastAnchor\n */\n /**\n * Normally, a group is indexed by the start of that group, so for example\n * when 30 daily values are grouped into one month, that month's x value\n * will be the 1st of the month. This apparently shifts the data to\n * the left. When the smoothed option is true, this is compensated for.\n * The data is shifted to the middle of the group, and min and max\n * values are preserved. Internally, this is used in the Navigator series.\n *\n * @type {boolean}\n * @default false\n * @deprecated\n * @apioption plotOptions.series.dataGrouping.smoothed\n */\n /**\n * An array determining what time intervals the data is allowed to be\n * grouped to. Each array item is an array where the first value is\n * the time unit and the second value another array of allowed multiples.\n *\n * Defaults to:\n * ```js\n * units: [[\n * 'millisecond', // unit name\n * [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\n * ], [\n * 'second',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'minute',\n * [1, 2, 5, 10, 15, 30]\n * ], [\n * 'hour',\n * [1, 2, 3, 4, 6, 8, 12]\n * ], [\n * 'day',\n * [1]\n * ], [\n * 'week',\n * [1]\n * ], [\n * 'month',\n * [1, 3, 6]\n * ], [\n * 'year',\n * null\n * ]]\n * ```\n *\n * @type {Array|null)>>}\n * @apioption plotOptions.series.dataGrouping.units\n */\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no grouping\n * is performed. If however the series contains so many points that\n * the spacing is less than the groupPixelWidth, Highcharts will try\n * to group it into appropriate groups so that each is more or less\n * two pixels wide. Defaults to `10`.\n *\n * @sample {highstock} stock/plotoptions/series-datagrouping-grouppixelwidth/\n * Two series with the same data density but different groupPixelWidth\n *\n * @type {number}\n * @default 10\n * @apioption plotOptions.column.dataGrouping.groupPixelWidth\n */\n ''; // required by JSDoc parsing\n\n return DataGroupingComposition;\n });\n _registerModule(_modules, 'masters/modules/datagrouping.src.js', [_modules['Core/Globals.js'], _modules['Extensions/DataGrouping/ApproximationDefaults.js'], _modules['Extensions/DataGrouping/ApproximationRegistry.js'], _modules['Extensions/DataGrouping/DataGrouping.js']], function (Highcharts, ApproximationDefaults, ApproximationRegistry, DataGrouping) {\n\n const G = Highcharts;\n G.dataGrouping = {\n approximationDefaults: ApproximationDefaults,\n approximations: ApproximationRegistry\n };\n DataGrouping.compose(G.Axis, G.Series, G.Tooltip);\n\n });\n _registerModule(_modules, 'Extensions/MouseWheelZoom/MouseWheelZoom.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2023 Torstein Honsi, Askel Eirik Johansson\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, isObject, pick, defined, merge } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedClasses = [], defaultOptions = {\n enabled: true,\n sensitivity: 1.1\n };\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n const optionsToObject = (options) => {\n if (!isObject(options)) {\n return merge(defaultOptions, { enabled: defined(options) ? options : true });\n }\n return merge(defaultOptions, options);\n };\n /**\n * @private\n */\n const fitToBox = function (inner, outer) {\n if (inner.x + inner.width > outer.x + outer.width) {\n if (inner.width > outer.width) {\n inner.width = outer.width;\n inner.x = outer.x;\n }\n else {\n inner.x = outer.x + outer.width - inner.width;\n }\n }\n if (inner.width > outer.width) {\n inner.width = outer.width;\n }\n if (inner.x < outer.x) {\n inner.x = outer.x;\n }\n // y and height\n if (inner.y + inner.height > outer.y + outer.height) {\n if (inner.height > outer.height) {\n inner.height = outer.height;\n inner.y = outer.y;\n }\n else {\n inner.y = outer.y + outer.height - inner.height;\n }\n }\n if (inner.height > outer.height) {\n inner.height = outer.height;\n }\n if (inner.y < outer.y) {\n inner.y = outer.y;\n }\n return inner;\n };\n let wheelTimer, originalOptions;\n /**\n * @private\n */\n const zoomBy = function (chart, howMuch, centerXArg, centerYArg, mouseX, mouseY, options) {\n const xAxis = chart.xAxis[0], yAxis = chart.yAxis[0], type = pick(options.type, chart.options.chart.zooming.type, 'x'), zoomX = /x/.test(type), zoomY = /y/.test(type);\n if (defined(xAxis.max) && defined(xAxis.min) &&\n defined(yAxis.max) && defined(yAxis.min) &&\n defined(xAxis.dataMax) && defined(xAxis.dataMin) &&\n defined(yAxis.dataMax) && defined(yAxis.dataMin)) {\n if (zoomY) {\n // Options interfering with yAxis zoom by setExtremes() returning\n // integers by default.\n if (defined(wheelTimer)) {\n clearTimeout(wheelTimer);\n }\n const { startOnTick, endOnTick } = yAxis.options;\n if (!originalOptions) {\n originalOptions = { startOnTick, endOnTick };\n }\n if (startOnTick || endOnTick) {\n yAxis.setOptions({ startOnTick: false, endOnTick: false });\n }\n wheelTimer = setTimeout(() => {\n if (originalOptions) {\n yAxis.setOptions(originalOptions);\n // Set the extremes to the same as they already are, but now\n // with the original startOnTick and endOnTick. We need\n // `forceRedraw` otherwise it will detect that the values\n // haven't changed. We do not use a simple yAxis.update()\n // because it will destroy the ticks and prevent animation.\n const { min, max } = yAxis.getExtremes();\n yAxis.forceRedraw = true;\n yAxis.setExtremes(min, max);\n originalOptions = void 0;\n }\n }, 400);\n }\n if (chart.inverted) {\n const emulateRoof = yAxis.pos + yAxis.len;\n // Get the correct values\n centerXArg = xAxis.toValue(mouseY);\n centerYArg = yAxis.toValue(mouseX);\n // Swapping x and y for simplicity when chart is inverted.\n const tmp = mouseX;\n mouseX = mouseY;\n mouseY = emulateRoof - tmp + yAxis.pos;\n }\n let fixToX = mouseX ? ((mouseX - xAxis.pos) / xAxis.len) : 0.5;\n if (xAxis.reversed && !chart.inverted ||\n chart.inverted && !xAxis.reversed) {\n // We are taking into account that xAxis automatically gets\n // reversed when chart.inverted\n fixToX = 1 - fixToX;\n }\n let fixToY = 1 - (mouseY ? ((mouseY - yAxis.pos) / yAxis.len) : 0.5);\n if (yAxis.reversed) {\n fixToY = 1 - fixToY;\n }\n const xRange = xAxis.max - xAxis.min, centerX = pick(centerXArg, xAxis.min + xRange / 2), newXRange = xRange * howMuch, yRange = yAxis.max - yAxis.min, centerY = pick(centerYArg, yAxis.min + yRange / 2), newYRange = yRange * howMuch, newXMin = centerX - newXRange * fixToX, newYMin = centerY - newYRange * fixToY, dataRangeX = xAxis.dataMax - xAxis.dataMin, dataRangeY = yAxis.dataMax - yAxis.dataMin, outerX = xAxis.dataMin - dataRangeX * xAxis.options.minPadding, outerWidth = dataRangeX + dataRangeX * xAxis.options.minPadding +\n dataRangeX * xAxis.options.maxPadding, outerY = yAxis.dataMin - dataRangeY * yAxis.options.minPadding, outerHeight = dataRangeY + dataRangeY * yAxis.options.minPadding +\n dataRangeY * yAxis.options.maxPadding, newExt = fitToBox({\n x: newXMin,\n y: newYMin,\n width: newXRange,\n height: newYRange\n }, {\n x: outerX,\n y: outerY,\n width: outerWidth,\n height: outerHeight\n }), zoomOut = (newExt.x <= outerX &&\n newExt.width >=\n outerWidth &&\n newExt.y <= outerY &&\n newExt.height >= outerHeight);\n // Zoom\n if (defined(howMuch) && !zoomOut) {\n if (zoomX) {\n xAxis.setExtremes(newExt.x, newExt.x + newExt.width, false);\n }\n if (zoomY) {\n yAxis.setExtremes(newExt.y, newExt.y + newExt.height, false);\n }\n // Reset zoom\n }\n else {\n if (zoomX) {\n xAxis.setExtremes(void 0, void 0, false);\n }\n if (zoomY) {\n yAxis.setExtremes(void 0, void 0, false);\n }\n }\n chart.redraw(false);\n }\n };\n /**\n * @private\n */\n function onAfterGetContainer() {\n const chart = this, wheelZoomOptions = optionsToObject(chart.options.chart.zooming.mouseWheel);\n if (wheelZoomOptions.enabled) {\n addEvent(this.container, 'wheel', (e) => {\n e = this.pointer.normalize(e);\n // Firefox uses e.detail, WebKit and IE uses deltaX, deltaY, deltaZ.\n if (chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop)) {\n const wheelSensitivity = pick(wheelZoomOptions.sensitivity, 1.1), delta = e.detail || ((e.deltaY || 0) / 120);\n zoomBy(chart, Math.pow(wheelSensitivity, delta), chart.xAxis[0].toValue(e.chartX), chart.yAxis[0].toValue(e.chartY), e.chartX, e.chartY, wheelZoomOptions);\n }\n // prevent page scroll\n if (e.preventDefault) {\n e.preventDefault();\n }\n });\n }\n }\n /**\n * @private\n */\n function compose(ChartClass) {\n if (composedClasses.indexOf(ChartClass) === -1) {\n composedClasses.push(ChartClass);\n addEvent(ChartClass, 'afterGetContainer', onAfterGetContainer);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const MouseWheelZoomComposition = {\n compose\n };\n /* *\n *\n * API Options\n *\n * */\n /**\n * The mouse wheel zoom is a feature included in Highcharts Stock, but is\n * also available for Highcharts Core as a module. Zooming with the mouse wheel\n * is enabled by default. It can be disabled by setting this option to\n * `false`.\n *\n * @type {boolean|object}\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @sample {highcharts} highcharts/mouse-wheel-zoom/enabled\n * Enable or disable\n * @sample {highstock} stock/mouse-wheel-zoom/enabled\n * Enable or disable\n * @apioption chart.zooming.mouseWheel\n */\n /**\n * Zooming with the mouse wheel can be disabled by setting this option to\n * `false`.\n *\n * @type {boolean}\n * @default true\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @apioption chart.zooming.mouseWheel.enabled\n */\n /**\n * Adjust the sensitivity of the zoom. Sensitivity of mouse wheel or trackpad\n * scrolling. `1` is no sensitivity, while with `2`, one mouse wheel delta will\n * zoom in `50%`.\n *\n * @type {number}\n * @default 1.1\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @sample {highcharts} highcharts/mouse-wheel-zoom/sensitivity\n * Change mouse wheel zoom sensitivity\n * @sample {highstock} stock/mouse-wheel-zoom/sensitivity\n * Change mouse wheel zoom sensitivity\n * @apioption chart.zooming.mouseWheel.sensitivity\n */\n /**\n * Decides in what dimensions the user can zoom scrolling the wheel.\n * Can be one of `x`, `y` or `xy`. If not specified here, it will inherit the\n * type from [chart.zooming.type](chart.zooming.type).\n *\n * Note that particularly with mouse wheel in the y direction, the zoom is\n * affected by the default [yAxis.startOnTick](#yAxis.startOnTick) and\n * [endOnTick]((#yAxis.endOnTick)) settings. In order to respect these settings,\n * the zoom level will adjust after the user has stopped zooming. To prevent\n * this, consider setting `startOnTick` and `endOnTick` to `false`.\n *\n * @type {string}\n * @default x\n * @validvalue [\"x\", \"y\", \"xy\"]\n * @since 11.1.0\n * @requires modules/mouse-wheel-zoom\n * @apioption chart.zooming.mouseWheel.type\n */\n (''); // Keeps doclets above in JS file\n\n return MouseWheelZoomComposition;\n });\n _registerModule(_modules, 'masters/modules/mouse-wheel-zoom.src.js', [_modules['Core/Globals.js'], _modules['Extensions/MouseWheelZoom/MouseWheelZoom.js']], function (Highcharts, MouseWheelZoom) {\n\n const G = Highcharts;\n MouseWheelZoom.compose(G.Chart);\n\n });\n _registerModule(_modules, 'Series/DataModifyComposition.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Series/Point.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (Axis, Point, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { prototype: { tooltipFormatter: pointTooltipFormatter } } = Point;\n const { addEvent, arrayMax, arrayMin, correctFloat, defined, isArray, isNumber, isString, pick } = U;\n /* *\n *\n * Composition\n *\n * */\n var DataModifyComposition;\n (function (DataModifyComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * Extends the series, axis and point classes with\n * compare and cumulative support.\n *\n * @private\n *\n * @param SeriesClass\n * Series class to use.\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param PointClass\n * Point class to use.\n */\n function compose(SeriesClass, AxisClass, PointClass) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.setCompare = seriesSetCompare;\n seriesProto.setCumulative = seriesSetCumulative;\n addEvent(SeriesClass, 'afterInit', afterInit);\n addEvent(SeriesClass, 'afterGetExtremes', afterGetExtremes);\n addEvent(SeriesClass, 'afterProcessData', afterProcessData);\n }\n if (U.pushUnique(composedMembers, AxisClass)) {\n const axisProto = AxisClass.prototype;\n axisProto.setCompare = axisSetCompare;\n axisProto.setModifier = setModifier;\n axisProto.setCumulative = axisSetCumulative;\n }\n if (U.pushUnique(composedMembers, PointClass)) {\n const pointProto = PointClass.prototype;\n pointProto.tooltipFormatter = tooltipFormatter;\n }\n return SeriesClass;\n }\n DataModifyComposition.compose = compose;\n /* ********************************************************************** *\n * Start shared compare and cumulative logic *\n * ********************************************************************** */\n /**\n * Shared code for the axis.setCompare() and the axis.setCumulative()\n * methods. Inits the 'compare' or the 'cumulative' mode.\n * @private\n */\n function setModifier(mode, modeState, redraw) {\n if (!this.isXAxis) {\n this.series.forEach(function (series) {\n if (mode === 'compare' &&\n typeof modeState !== 'boolean') {\n series.setCompare(modeState, false);\n }\n else if (mode === 'cumulative' &&\n !isString(modeState)) {\n series.setCumulative(modeState, false);\n }\n });\n if (pick(redraw, true)) {\n this.chart.redraw();\n }\n }\n }\n /**\n * Extend the tooltip formatter by adding support for the point.change\n * variable as well as the changeDecimals option.\n *\n * @ignore\n * @function Highcharts.Point#tooltipFormatter\n *\n * @param {string} pointFormat\n */\n function tooltipFormatter(pointFormat) {\n const point = this, { numberFormatter } = point.series.chart, replace = function (value) {\n pointFormat = pointFormat.replace('{point.' + value + '}', (point[value] > 0 && value === 'change' ? '+' : '') +\n numberFormatter(point[value], pick(point.series.tooltipOptions.changeDecimals, 2)));\n };\n if (defined(point.change)) {\n replace('change');\n }\n if (defined(point.cumulativeSum)) {\n replace('cumulativeSum');\n }\n return pointTooltipFormatter.apply(this, [pointFormat]);\n }\n /**\n * Extend series.init by adding a methods to modify the y values used\n * for plotting on the y axis. For compare mode, this method is called both\n * from the axis when finding dataMin and dataMax,\n * and from the series.translate method.\n *\n * @ignore\n * @function Highcharts.Series#init\n */\n function afterInit() {\n const compare = this.options.compare;\n let dataModify;\n if (compare === 'percent' ||\n compare === 'value' ||\n this.options.cumulative) {\n dataModify = new Additions(this);\n if (compare === 'percent' || compare === 'value') {\n // Set comparison mode\n dataModify.initCompare(compare);\n }\n else {\n // Set Cumulative Sum mode\n dataModify.initCumulative();\n }\n }\n this.dataModify = dataModify;\n }\n /**\n * Adjust the extremes (compare and cumulative modify the data).\n * @private\n */\n function afterGetExtremes(e) {\n const dataExtremes = e.dataExtremes, activeYData = dataExtremes.activeYData;\n if (this.dataModify && dataExtremes) {\n let extremes;\n if (this.options.compare) {\n extremes = [\n this.dataModify.modifyValue(dataExtremes.dataMin),\n this.dataModify.modifyValue(dataExtremes.dataMax)\n ];\n }\n else if (this.options.cumulative &&\n isArray(activeYData) &&\n // If only one y visible, sum doesn't change\n // so no need to change extremes\n activeYData.length >= 2) {\n extremes = Additions.getCumulativeExtremes(activeYData);\n }\n if (extremes) {\n dataExtremes.dataMin = arrayMin(extremes);\n dataExtremes.dataMax = arrayMax(extremes);\n }\n }\n }\n /* ********************************************************************** *\n * End shared compare and cumulative logic *\n * ********************************************************************** */\n /* ********************************************************************** *\n * Start value compare logic *\n * ********************************************************************** */\n /**\n * Highcharts Stock only. Set the\n * [compare](https://api.highcharts.com/highstock/plotOptions.series.compare)\n * mode of the series after render time.\n * In most cases it is more useful running\n * {@link Axis#setCompare} on the X axis to update all its series.\n *\n * @function Highcharts.Series#setCompare\n *\n * @param {string|null} [compare]\n * Can be one of `undefined` (default), `null`, `\"percent\"`\n * or `\"value\"`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function seriesSetCompare(compare, redraw) {\n // Survive to export, #5485 (and for options generally)\n this.options.compare = this.userOptions.compare = compare;\n // Fire series.init() that will set or delete series.dataModify\n this.update({}, pick(redraw, true));\n if (this.dataModify && (compare === 'value' || compare === 'percent')) {\n this.dataModify.initCompare(compare);\n }\n else {\n // When disabling, clear the points\n this.points.forEach((point) => {\n delete point.change;\n });\n }\n }\n /**\n * Extend series.processData by finding the first y value in the plot area,\n * used for comparing the following values\n *\n * @ignore\n * @function Highcharts.Series#processData\n */\n function afterProcessData() {\n const series = this;\n if (series.xAxis && // not pies\n series.processedYData &&\n series.dataModify) {\n const processedXData = series.processedXData, processedYData = series.processedYData, length = processedYData.length, compareStart = series.options.compareStart === true ? 0 : 1;\n let keyIndex = -1, i;\n // For series with more than one value (range, OHLC etc), compare\n // against close or the pointValKey (#4922, #3112, #9854)\n if (series.pointArrayMap) {\n keyIndex = series.pointArrayMap.indexOf(series.options.pointValKey || series.pointValKey || 'y');\n }\n // find the first value for comparison\n for (i = 0; i < length - compareStart; i++) {\n const compareValue = processedYData[i] && keyIndex > -1 ?\n processedYData[i][keyIndex] : processedYData[i];\n if (isNumber(compareValue) &&\n compareValue !== 0 &&\n processedXData[i + compareStart] >= (series.xAxis.min || 0)) {\n series.dataModify.compareValue = compareValue;\n break;\n }\n }\n }\n }\n /**\n * Highcharts Stock only. Set the compare mode on all series\n * belonging to a Y axis.\n *\n * @see [plotOptions.series.compare](https://api.highcharts.com/highstock/plotOptions.series.compare)\n *\n * @sample stock/members/axis-setcompare/\n * Set compare\n *\n * @function Highcharts.Axis#setCompare\n *\n * @param {string|null} [compare]\n * The compare mode. Can be one of `undefined` (default), `null`,\n * `\"value\"` or `\"percent\"`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function axisSetCompare(compare, redraw) {\n this.setModifier('compare', compare, redraw);\n }\n /* ********************************************************************** *\n * End value compare logic *\n * ********************************************************************** */\n /* ********************************************************************** *\n * Start Cumulative Sum logic, author: Rafal Sebestjanski *\n * ********************************************************************** */\n /**\n * Highcharts Stock only. Set the\n * [cumulative](https://api.highcharts.com/highstock/plotOptions.series.cumulative)\n * mode of the series after render time.\n * In most cases it is more useful running\n * {@link Axis#setCumulative} on the Y axis to update all its series.\n *\n * @function Highcharts.Series#setCumulative\n *\n * @param {boolean} [cumulative=false]\n * Either enable or disable Cumulative Sum mode.\n * Can be one of `false` (default) or `true`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function seriesSetCumulative(cumulative, redraw) {\n // Set default value to false\n cumulative = pick(cumulative, false);\n // Survive to export, #5485 (and for options generally)\n this.options.cumulative = this.userOptions.cumulative = cumulative;\n // Fire series.init() that will set or delete series.dataModify\n this.update({}, pick(redraw, true));\n // If should, turn on the Cumulative Sum mode\n if (this.dataModify) {\n this.dataModify.initCumulative();\n }\n else {\n // When disabling, clear the points\n this.points.forEach((point) => {\n delete point.cumulativeSum;\n });\n }\n }\n /**\n * Highcharts Stock only. Set the cumulative mode on all series\n * belonging to a Y axis.\n *\n * @see [plotOptions.series.cumulative](https://api.highcharts.com/highstock/plotOptions.series.cumulative)\n *\n * @sample stock/members/axis-setcumulative/\n * Set cumulative\n *\n * @function Highcharts.Axis#setCumulative\n *\n * @param {boolean} [cumulative]\n * Whether to disable or enable the cumulative mode.\n * Can be one of `undefined` (default, treated as `false`),\n * `false` or `true`.\n *\n * @param {boolean} [redraw=true]\n * Whether to redraw the chart or to wait for a later call to\n * {@link Chart#redraw}.\n */\n function axisSetCumulative(cumulative, redraw) {\n this.setModifier('cumulative', cumulative, redraw);\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * @private\n */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n /**\n * @private\n */\n constructor(series) {\n this.series = series;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n modifyValue() {\n return 0;\n }\n /**\n * @ignore\n * @function Highcharts.Series#getCumulativeExtremes\n *\n * @param {Array} [activeYData]\n * An array cointaining all the points' y values\n * in a visible range.\n */\n static getCumulativeExtremes(activeYData) {\n let cumulativeDataMin = Infinity, cumulativeDataMax = -Infinity;\n activeYData.reduce((prev, cur) => {\n const sum = prev + cur;\n cumulativeDataMin = Math.min(cumulativeDataMin, sum, prev);\n cumulativeDataMax = Math.max(cumulativeDataMax, sum, prev);\n return sum;\n });\n return [cumulativeDataMin, cumulativeDataMax];\n }\n /**\n * @ignore\n * @function Highcharts.Series#initCompare\n *\n * @param {string} [compare]\n * Can be one of `\"percent\"` or `\"value\"`.\n */\n initCompare(compare) {\n // Set the modifyValue method\n this.modifyValue = function (value, index) {\n if (value === null) {\n value = 0;\n }\n const compareValue = this.compareValue;\n if (typeof value !== 'undefined' &&\n typeof compareValue !== 'undefined') { // #2601, #5814\n // Get the modified value\n if (compare === 'value') {\n value -= compareValue;\n // Compare percent\n }\n else {\n const compareBase = this.series.options.compareBase;\n value = 100 * (value / compareValue) -\n (compareBase === 100 ? 0 : 100);\n }\n // record for tooltip etc.\n if (typeof index !== 'undefined') {\n const point = this.series.points[index];\n if (point) {\n point.change = value;\n }\n }\n return value;\n }\n return 0;\n };\n }\n /**\n * @ignore\n * @function Highcharts.Series#initCumulative\n */\n initCumulative() {\n // Set the modifyValue method\n this.modifyValue = function (value, index) {\n if (value === null) {\n value = 0;\n }\n if (value !== void 0 && index !== void 0) {\n const prevPoint = index > 0 ?\n this.series.points[index - 1] : null;\n // Get the modified value\n if (prevPoint && prevPoint.cumulativeSum) {\n value = correctFloat(prevPoint.cumulativeSum + value);\n }\n // Record for tooltip etc.\n const point = this.series.points[index];\n if (point) {\n point.cumulativeSum = value;\n }\n return value;\n }\n return 0;\n };\n }\n }\n DataModifyComposition.Additions = Additions;\n })(DataModifyComposition || (DataModifyComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Compare the values of the series against the first non-null, non-\n * zero value in the visible range. The y axis will show percentage\n * or absolute change depending on whether `compare` is set to `\"percent\"`\n * or `\"value\"`. When this is applied to multiple series, it allows\n * comparing the development of the series against each other. Adds\n * a `change` field to every point object.\n *\n * @see [compareBase](#plotOptions.series.compareBase)\n * @see [Axis.setCompare()](/class-reference/Highcharts.Axis#setCompare)\n * @see [Series.setCompare()](/class-reference/Highcharts.Series#setCompare)\n *\n * @sample {highstock} stock/plotoptions/series-compare-percent/\n * Percent\n * @sample {highstock} stock/plotoptions/series-compare-value/\n * Value\n *\n * @type {string}\n * @since 1.0.1\n * @product highstock\n * @validvalue [\"percent\", \"value\"]\n * @apioption plotOptions.series.compare\n */\n /**\n * Defines if comparison should start from the first point within the visible\n * range or should start from the first point **before** the range.\n *\n * In other words, this flag determines if first point within the visible range\n * will have 0% (`compareStart=true`) or should have been already calculated\n * according to the previous point (`compareStart=false`).\n *\n * @sample {highstock} stock/plotoptions/series-comparestart/\n * Calculate compare within visible range\n *\n * @type {boolean}\n * @default false\n * @since 6.0.0\n * @product highstock\n * @apioption plotOptions.series.compareStart\n */\n /**\n * When [compare](#plotOptions.series.compare) is `percent`, this option\n * dictates whether to use 0 or 100 as the base of comparison.\n *\n * @sample {highstock} stock/plotoptions/series-comparebase/\n * Compare base is 100\n *\n * @type {number}\n * @default 0\n * @since 5.0.6\n * @product highstock\n * @validvalue [0, 100]\n * @apioption plotOptions.series.compareBase\n */\n /**\n * Cumulative Sum feature replaces points' values with the following formula:\n * `sum of all previous points' values + current point's value`.\n * Works only for points in a visible range.\n * Adds the `cumulativeSum` field to each point object that can be accessed\n * e.g. in the [tooltip.pointFormat](https://api.highcharts.com/highstock/tooltip.pointFormat).\n *\n * With `dataGrouping` enabled, default grouping approximation is set to `sum`.\n *\n * @see [Axis.setCumulative()](/class-reference/Highcharts.Axis#setCumulative)\n * @see [Series.setCumulative()](/class-reference/Highcharts.Series#setCumulative)\n *\n * @sample {highstock} stock/plotoptions/series-cumulative-sum/\n * Cumulative Sum\n *\n * @type {boolean}\n * @default false\n * @since 9.3.0\n * @product highstock\n * @apioption plotOptions.series.cumulative\n */\n ''; // keeps doclets above in transpiled file\n\n return DataModifyComposition;\n });\n _registerModule(_modules, 'Core/Axis/NavigatorAxisComposition.js', [_modules['Core/Globals.js'], _modules['Core/Utilities.js']], function (H, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isTouchDevice } = H;\n const { addEvent, correctFloat, defined, isNumber, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function onAxisInit() {\n const axis = this;\n if (!axis.navigatorAxis) {\n axis.navigatorAxis = new NavigatorAxisAdditions(axis);\n }\n }\n /**\n * For Stock charts, override selection zooming with some special features\n * because X axis zooming is already allowed by the Navigator and Range\n * selector.\n * @private\n */\n function onAxisZoom(e) {\n const axis = this, chart = axis.chart, chartOptions = chart.options, navigator = chartOptions.navigator, navigatorAxis = axis.navigatorAxis, pinchType = chart.zooming.pinchType, rangeSelector = chartOptions.rangeSelector, zoomType = chart.zooming.type;\n if (axis.isXAxis && ((navigator && navigator.enabled) ||\n (rangeSelector && rangeSelector.enabled))) {\n // For y only zooming, ignore the X axis completely\n if (zoomType === 'y') {\n e.zoomed = false;\n // For xy zooming, record the state of the zoom before zoom\n // selection, then when the reset button is pressed, revert to\n // this state. This should apply only if the chart is\n // initialized with a range (#6612), otherwise zoom all the way\n // out.\n }\n else if (((!isTouchDevice && zoomType === 'xy') ||\n (isTouchDevice && pinchType === 'xy')) &&\n axis.options.range) {\n const previousZoom = navigatorAxis.previousZoom;\n if (defined(e.newMin)) {\n navigatorAxis.previousZoom = [axis.min, axis.max];\n }\n else if (previousZoom) {\n e.newMin = previousZoom[0];\n e.newMax = previousZoom[1];\n navigatorAxis.previousZoom = void 0;\n }\n }\n }\n if (typeof e.zoomed !== 'undefined') {\n e.preventDefault();\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * @private\n * @class\n */\n class NavigatorAxisAdditions {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n static compose(AxisClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.keepProps.push('navigatorAxis');\n addEvent(AxisClass, 'init', onAxisInit);\n addEvent(AxisClass, 'zoom', onAxisZoom);\n }\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(axis) {\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n destroy() {\n this.axis = void 0;\n }\n /**\n * Add logic to normalize the zoomed range in order to preserve the pressed\n * state of range selector buttons\n *\n * @private\n * @function Highcharts.Axis#toFixedRange\n */\n toFixedRange(pxMin, pxMax, fixedMin, fixedMax) {\n const axis = this.axis, chart = axis.chart;\n let newMin = pick(fixedMin, axis.translate(pxMin, true, !axis.horiz)), newMax = pick(fixedMax, axis.translate(pxMax, true, !axis.horiz));\n const fixedRange = chart && chart.fixedRange, halfPointRange = (axis.pointRange || 0) / 2;\n // Add/remove half point range to/from the extremes (#1172)\n if (!defined(fixedMin)) {\n newMin = correctFloat(newMin + halfPointRange);\n }\n if (!defined(fixedMax)) {\n newMax = correctFloat(newMax - halfPointRange);\n }\n // Make sure panning to the edges does not decrease the zoomed range\n if (fixedRange && axis.dataMin && axis.dataMax) {\n if (newMax >= axis.dataMax) {\n newMin = correctFloat(axis.dataMax - fixedRange);\n }\n if (newMin <= axis.dataMin) {\n newMax = correctFloat(axis.dataMin + fixedRange);\n }\n }\n if (!isNumber(newMin) || !isNumber(newMax)) { // #1195, #7411\n newMin = newMax = void 0;\n }\n return {\n min: newMin,\n max: newMax\n };\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return NavigatorAxisAdditions;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorDefaults.js', [_modules['Core/Color/Color.js'], _modules['Core/Series/SeriesRegistry.js']], function (Color, SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { parse: color } = Color;\n const { seriesTypes } = SeriesRegistry;\n /* *\n *\n * Constants\n *\n * */\n /**\n * The navigator is a small series below the main series, displaying\n * a view of the entire data set. It provides tools to zoom in and\n * out on parts of the data as well as panning across the dataset.\n *\n * @product highstock gantt\n * @optionparent navigator\n */\n const NavigatorDefaults = {\n /**\n * Whether the navigator and scrollbar should adapt to updated data\n * in the base X axis. When loading data async, as in the demo below,\n * this should be `false`. Otherwise new data will trigger navigator\n * redraw, which will cause unwanted looping. In the demo below, the\n * data in the navigator is set only once. On navigating, only the main\n * chart content is updated.\n *\n * @sample {highstock} stock/demo/lazy-loading/\n * Set to false with async data loading\n *\n * @type {boolean}\n * @default true\n * @apioption navigator.adaptToUpdatedData\n */\n /**\n * An integer identifying the index to use for the base series, or a\n * string representing the id of the series.\n *\n * **Note**: As of Highcharts 5.0, this is now a deprecated option.\n * Prefer [series.showInNavigator](#plotOptions.series.showInNavigator).\n *\n * @see [series.showInNavigator](#plotOptions.series.showInNavigator)\n *\n * @deprecated\n * @type {number|string}\n * @default 0\n * @apioption navigator.baseSeries\n */\n /**\n * Enable or disable the navigator.\n *\n * @sample {highstock} stock/navigator/enabled/\n * Disable the navigator\n *\n * @type {boolean}\n * @default true\n * @apioption navigator.enabled\n */\n /**\n * When the chart is inverted, whether to draw the navigator on the\n * opposite side.\n *\n * @type {boolean}\n * @default false\n * @since 5.0.8\n * @apioption navigator.opposite\n */\n /**\n * The height of the navigator.\n *\n * @sample {highstock} stock/navigator/height/\n * A higher navigator\n */\n height: 40,\n /**\n * The distance from the nearest element, the X axis or X axis labels.\n *\n * @sample {highstock} stock/navigator/margin/\n * A margin of 2 draws the navigator closer to the X axis labels\n */\n margin: 25,\n /**\n * Whether the mask should be inside the range marking the zoomed\n * range, or outside. In Highcharts Stock 1.x it was always `false`.\n *\n * @sample {highstock} stock/navigator/maskinside-false/\n * False, mask outside\n *\n * @since 2.0\n */\n maskInside: true,\n /**\n * Options for the handles for dragging the zoomed area.\n *\n * @sample {highstock} stock/navigator/handles/\n * Colored handles\n */\n handles: {\n /**\n * Width for handles.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n */\n width: 7,\n /**\n * Height for handles.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n */\n height: 15,\n /**\n * Array to define shapes of handles. 0-index for left, 1-index for\n * right.\n *\n * Additionally, the URL to a graphic can be given on this form:\n * `url(graphic.png)`. Note that for the image to be applied to\n * exported charts, its URL needs to be accessible by the export\n * server.\n *\n * Custom callbacks for symbol path generation can also be added to\n * `Highcharts.SVGRenderer.prototype.symbols`. The callback is then\n * used by its method name, as shown in the demo.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @type {Array}\n * @default [\"navigator-handle\", \"navigator-handle\"]\n * @since 6.0.0\n */\n symbols: ['navigator-handle', 'navigator-handle'],\n /**\n * Allows to enable/disable handles.\n *\n * @since 6.0.0\n */\n enabled: true,\n /**\n * The width for the handle border and the stripes inside.\n *\n * @sample {highstock} stock/navigator/styled-handles/\n * Styled handles\n *\n * @since 6.0.0\n * @apioption navigator.handles.lineWidth\n */\n lineWidth: 1,\n /**\n * The fill for the handle.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n backgroundColor: \"#f2f2f2\" /* Palette.neutralColor5 */,\n /**\n * The stroke for the handle border and the stripes inside.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n borderColor: \"#999999\" /* Palette.neutralColor40 */\n },\n /**\n * The color of the mask covering the areas of the navigator series\n * that are currently not visible in the main series. The default\n * color is bluish with an opacity of 0.3 to see the series below.\n *\n * @see In styled mode, the mask is styled with the\n * `.highcharts-navigator-mask` and\n * `.highcharts-navigator-mask-inside` classes.\n *\n * @sample {highstock} stock/navigator/maskfill/\n * Blue, semi transparent mask\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default rgba(102,133,194,0.3)\n */\n maskFill: color(\"#667aff\" /* Palette.highlightColor60 */).setOpacity(0.3).get(),\n /**\n * The color of the line marking the currently zoomed area in the\n * navigator.\n *\n * @sample {highstock} stock/navigator/outline/\n * 2px blue outline\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #cccccc\n */\n outlineColor: \"#999999\" /* Palette.neutralColor40 */,\n /**\n * The width of the line marking the currently zoomed area in the\n * navigator.\n *\n * @see In styled mode, the outline stroke width is set with the\n * `.highcharts-navigator-outline` class.\n *\n * @sample {highstock} stock/navigator/outline/\n * 2px blue outline\n *\n * @type {number}\n */\n outlineWidth: 1,\n /**\n * Options for the navigator series. Available options are the same\n * as any series, documented at [plotOptions](#plotOptions.series)\n * and [series](#series).\n *\n * Unless data is explicitly defined on navigator.series, the data\n * is borrowed from the first series in the chart.\n *\n * Default series options for the navigator series are:\n * ```js\n * series: {\n * type: 'areaspline',\n * fillOpacity: 0.05,\n * dataGrouping: {\n * smoothed: true\n * },\n * lineWidth: 1,\n * marker: {\n * enabled: false\n * }\n * }\n * ```\n *\n * @see In styled mode, the navigator series is styled with the\n * `.highcharts-navigator-series` class.\n *\n * @sample {highstock} stock/navigator/series-data/\n * Using a separate data set for the navigator\n * @sample {highstock} stock/navigator/series/\n * A green navigator series\n *\n * @type {*|Array<*>|Highcharts.SeriesOptionsType|Array}\n */\n series: {\n /**\n * The type of the navigator series.\n *\n * Heads up:\n * In column-type navigator, zooming is limited to at least one\n * point with its `pointRange`.\n *\n * @sample {highstock} stock/navigator/column/\n * Column type navigator\n *\n * @type {string}\n * @default {highstock} `areaspline` if defined, otherwise `line`\n * @default {gantt} gantt\n */\n type: (typeof seriesTypes.areaspline === 'undefined' ?\n 'line' :\n 'areaspline'),\n /**\n * The fill opacity of the navigator series.\n */\n fillOpacity: 0.05,\n /**\n * The pixel line width of the navigator series.\n */\n lineWidth: 1,\n /**\n * @ignore-option\n */\n compare: null,\n /**\n * @ignore-option\n */\n sonification: {\n enabled: false\n },\n /**\n * Unless data is explicitly defined, the data is borrowed from the\n * first series in the chart.\n *\n * @type {Array|object|null>}\n * @product highstock\n * @apioption navigator.series.data\n */\n /**\n * Data grouping options for the navigator series.\n *\n * @extends plotOptions.series.dataGrouping\n */\n dataGrouping: {\n approximation: 'average',\n enabled: true,\n groupPixelWidth: 2,\n // Replace smoothed property by anchors, #12455.\n firstAnchor: 'firstPoint',\n anchor: 'middle',\n lastAnchor: 'lastPoint',\n // Day and week differs from plotOptions.series.dataGrouping\n units: [\n ['millisecond', [1, 2, 5, 10, 20, 25, 50, 100, 200, 500]],\n ['second', [1, 2, 5, 10, 15, 30]],\n ['minute', [1, 2, 5, 10, 15, 30]],\n ['hour', [1, 2, 3, 4, 6, 8, 12]],\n ['day', [1, 2, 3, 4]],\n ['week', [1, 2, 3]],\n ['month', [1, 3, 6]],\n ['year', null]\n ]\n },\n /**\n * Data label options for the navigator series. Data labels are\n * disabled by default on the navigator series.\n *\n * @extends plotOptions.series.dataLabels\n */\n dataLabels: {\n enabled: false,\n zIndex: 2 // #1839\n },\n id: 'highcharts-navigator-series',\n className: 'highcharts-navigator-series',\n /**\n * Sets the fill color of the navigator series.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @apioption navigator.series.color\n */\n /**\n * Line color for the navigator series. Allows setting the color\n * while disallowing the default candlestick setting.\n *\n * @type {Highcharts.ColorString|null}\n */\n lineColor: null,\n marker: {\n enabled: false\n },\n /**\n * Since Highcharts Stock v8, default value is the same as default\n * `pointRange` defined for a specific type (e.g. `null` for\n * column type).\n *\n * In Highcharts Stock version < 8, defaults to 0.\n *\n * @extends plotOptions.series.pointRange\n * @type {number|null}\n * @apioption navigator.series.pointRange\n */\n /**\n * The threshold option. Setting it to 0 will make the default\n * navigator area series draw its area from the 0 value and up.\n *\n * @type {number|null}\n */\n threshold: null\n },\n /**\n * Enable or disable navigator sticking to right, while adding new\n * points. If `undefined`, the navigator sticks to the axis maximum only\n * if it was already at the maximum prior to adding points.\n *\n * @type {boolean}\n * @default undefined\n * @since 10.2.1\n * @sample {highstock} stock/navigator/sticktomax-false/\n * stickToMax set to false\n * @apioption navigator.stickToMax\n */\n /**\n * Options for the navigator X axis. Default series options for the\n * navigator xAxis are:\n * ```js\n * xAxis: {\n * tickWidth: 0,\n * lineWidth: 0,\n * gridLineWidth: 1,\n * tickPixelInterval: 200,\n * labels: {\n * align: 'left',\n * style: {\n * color: '#888'\n * },\n * x: 3,\n * y: -4\n * }\n * }\n * ```\n *\n * @extends xAxis\n * @excluding linkedTo, maxZoom, minRange, opposite, range, scrollbar,\n * showEmpty, maxRange\n */\n xAxis: {\n /**\n * Additional range on the right side of the xAxis. Works similar to\n * xAxis.maxPadding, but value is set in milliseconds.\n * Can be set for both, main xAxis and navigator's xAxis.\n *\n * @since 6.0.0\n */\n overscroll: 0,\n className: 'highcharts-navigator-xaxis',\n tickLength: 0,\n lineWidth: 0,\n gridLineColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n gridLineWidth: 1,\n tickPixelInterval: 200,\n labels: {\n align: 'left',\n /**\n * @type {Highcharts.CSSObject}\n */\n style: {\n /** @ignore */\n color: \"#000000\" /* Palette.neutralColor100 */,\n /** @ignore */\n fontSize: '0.7em',\n /** @ignore */\n opacity: 0.6,\n /** @ignore */\n textOutline: '2px contrast'\n },\n x: 3,\n y: -4\n },\n crosshair: false\n },\n /**\n * Options for the navigator Y axis. Default series options for the\n * navigator yAxis are:\n * ```js\n * yAxis: {\n * gridLineWidth: 0,\n * startOnTick: false,\n * endOnTick: false,\n * minPadding: 0.1,\n * maxPadding: 0.1,\n * labels: {\n * enabled: false\n * },\n * title: {\n * text: null\n * },\n * tickWidth: 0\n * }\n * ```\n *\n * @extends yAxis\n * @excluding height, linkedTo, maxZoom, minRange, ordinal, range,\n * showEmpty, scrollbar, top, units, maxRange, minLength,\n * maxLength, resize\n */\n yAxis: {\n className: 'highcharts-navigator-yaxis',\n gridLineWidth: 0,\n startOnTick: false,\n endOnTick: false,\n minPadding: 0.1,\n maxPadding: 0.1,\n labels: {\n enabled: false\n },\n crosshair: false,\n title: {\n text: null\n },\n tickLength: 0,\n tickWidth: 0\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Maximum range which can be set using the navigator's handles.\n * Opposite of [xAxis.minRange](#xAxis.minRange).\n *\n * @sample {highstock} stock/navigator/maxrange/\n * Defined max and min range\n *\n * @type {number}\n * @since 6.0.0\n * @product highstock gantt\n * @apioption xAxis.maxRange\n */\n (''); // keeps doclets above in JS file\n\n return NavigatorDefaults;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorSymbols.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Constants\n *\n * */\n /**\n * Draw one of the handles on the side of the zoomed range in the navigator.\n * @private\n */\n function navigatorHandle(_x, _y, width, height, options = {}) {\n const halfWidth = options.width ? options.width / 2 : width, markerPosition = Math.round(halfWidth / 3) + 0.5;\n height = options.height || height;\n return [\n ['M', -halfWidth - 1, 0.5],\n ['L', halfWidth, 0.5],\n ['L', halfWidth, height + 0.5],\n ['L', -halfWidth - 1, height + 0.5],\n ['L', -halfWidth - 1, 0.5],\n ['M', -markerPosition, 4],\n ['L', -markerPosition, height - 3],\n ['M', markerPosition - 1, 4],\n ['L', markerPosition - 1, height - 3]\n ];\n }\n /* *\n *\n * Default Export\n *\n * */\n const NavigatorSymbols = {\n 'navigator-handle': navigatorHandle\n };\n\n return NavigatorSymbols;\n });\n _registerModule(_modules, 'Stock/Navigator/NavigatorComposition.js', [_modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/NavigatorAxisComposition.js'], _modules['Stock/Navigator/NavigatorDefaults.js'], _modules['Stock/Navigator/NavigatorSymbols.js'], _modules['Core/Renderer/RendererRegistry.js'], _modules['Core/Utilities.js']], function (D, H, NavigatorAxisAdditions, NavigatorDefaults, NavigatorSymbols, RendererRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions, setOptions } = D;\n const { isTouchDevice } = H;\n const { getRendererType } = RendererRegistry;\n const { addEvent, extend, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let NavigatorConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function compose(AxisClass, ChartClass, NavigatorClass, SeriesClass) {\n NavigatorAxisAdditions.compose(AxisClass);\n NavigatorConstructor = NavigatorClass;\n if (U.pushUnique(composedMembers, ChartClass)) {\n const chartProto = ChartClass.prototype;\n chartProto.callbacks.push(onChartCallback);\n addEvent(ChartClass, 'afterAddSeries', onChartAfterAddSeries);\n addEvent(ChartClass, 'afterSetChartSize', onChartAfterSetChartSize);\n addEvent(ChartClass, 'afterUpdate', onChartAfterUpdate);\n addEvent(ChartClass, 'beforeRender', onChartBeforeRender);\n addEvent(ChartClass, 'beforeShowResetZoom', onChartBeforeShowResetZoom);\n addEvent(ChartClass, 'update', onChartUpdate);\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'afterUpdate', onSeriesAfterUpdate);\n }\n if (U.pushUnique(composedMembers, getRendererType)) {\n extend(getRendererType().prototype.symbols, NavigatorSymbols);\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n extend(defaultOptions, { navigator: NavigatorDefaults });\n }\n }\n /**\n * Handle adding new series.\n * @private\n */\n function onChartAfterAddSeries() {\n if (this.navigator) {\n // Recompute which series should be shown in navigator, and add them\n this.navigator.setBaseSeries(null, false);\n }\n }\n /**\n * For stock charts, extend the Chart.setChartSize method so that we can set the\n * final top position of the navigator once the height of the chart, including\n * the legend, is determined. #367. We can't use Chart.getMargins, because\n * labels offsets are not calculated yet.\n * @private\n */\n function onChartAfterSetChartSize() {\n var _a;\n const legend = this.legend, navigator = this.navigator;\n let legendOptions, xAxis, yAxis;\n if (navigator) {\n legendOptions = legend && legend.options;\n xAxis = navigator.xAxis;\n yAxis = navigator.yAxis;\n const { scrollbarHeight, scrollButtonSize } = navigator;\n // Compute the top position\n if (this.inverted) {\n navigator.left = navigator.opposite ?\n this.chartWidth - scrollbarHeight -\n navigator.height :\n this.spacing[3] + scrollbarHeight;\n navigator.top = this.plotTop + scrollButtonSize;\n }\n else {\n navigator.left = pick(xAxis.left, this.plotLeft + scrollButtonSize);\n navigator.top = navigator.navigatorOptions.top ||\n this.chartHeight -\n navigator.height -\n scrollbarHeight -\n (((_a = this.scrollbar) === null || _a === void 0 ? void 0 : _a.options.margin) || 0) -\n this.spacing[2] -\n (this.rangeSelector && this.extraBottomMargin ?\n this.rangeSelector.getHeight() :\n 0) -\n ((legendOptions &&\n legendOptions.verticalAlign === 'bottom' &&\n legendOptions.layout !== 'proximate' && // #13392\n legendOptions.enabled &&\n !legendOptions.floating) ?\n legend.legendHeight +\n pick(legendOptions.margin, 10) :\n 0) -\n (this.titleOffset ? this.titleOffset[2] : 0);\n }\n if (xAxis && yAxis) { // false if navigator is disabled (#904)\n if (this.inverted) {\n xAxis.options.left = yAxis.options.left = navigator.left;\n }\n else {\n xAxis.options.top = yAxis.options.top = navigator.top;\n }\n xAxis.setAxisSize();\n yAxis.setAxisSize();\n }\n }\n }\n /**\n * Initialize navigator, if no scrolling exists yet.\n * @private\n */\n function onChartAfterUpdate(event) {\n if (!this.navigator && !this.scroller &&\n (this.options.navigator.enabled ||\n this.options.scrollbar.enabled)) {\n this.scroller = this.navigator = new NavigatorConstructor(this);\n if (pick(event.redraw, true)) {\n this.redraw(event.animation); // #7067\n }\n }\n }\n /**\n * Initialize navigator for stock charts\n * @private\n */\n function onChartBeforeRender() {\n const options = this.options;\n if (options.navigator.enabled ||\n options.scrollbar.enabled) {\n this.scroller = this.navigator = new NavigatorConstructor(this);\n }\n }\n /**\n * For Stock charts. For x only zooming, do not to create the zoom button\n * because X axis zooming is already allowed by the Navigator and Range\n * selector. (#9285)\n * @private\n */\n function onChartBeforeShowResetZoom() {\n const chartOptions = this.options, navigator = chartOptions.navigator, rangeSelector = chartOptions.rangeSelector;\n if (((navigator && navigator.enabled) ||\n (rangeSelector && rangeSelector.enabled)) &&\n ((!isTouchDevice &&\n this.zooming.type === 'x') ||\n (isTouchDevice && this.zooming.pinchType === 'x'))) {\n return false;\n }\n }\n /**\n * @private\n */\n function onChartCallback(chart) {\n const navigator = chart.navigator;\n // Initialize the navigator\n if (navigator && chart.xAxis[0]) {\n const extremes = chart.xAxis[0].getExtremes();\n navigator.render(extremes.min, extremes.max);\n }\n }\n /**\n * Merge options, if no scrolling exists yet\n * @private\n */\n function onChartUpdate(e) {\n const navigatorOptions = (e.options.navigator || {}), scrollbarOptions = (e.options.scrollbar || {});\n if (!this.navigator && !this.scroller &&\n (navigatorOptions.enabled || scrollbarOptions.enabled)) {\n merge(true, this.options.navigator, navigatorOptions);\n merge(true, this.options.scrollbar, scrollbarOptions);\n delete e.options.navigator;\n delete e.options.scrollbar;\n }\n }\n /**\n * Handle updating series\n * @private\n */\n function onSeriesAfterUpdate() {\n if (this.chart.navigator && !this.options.isInternal) {\n this.chart.navigator.setBaseSeries(null, false);\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const NavigatorComposition = {\n compose\n };\n\n return NavigatorComposition;\n });\n _registerModule(_modules, 'Core/Axis/ScrollbarAxis.js', [_modules['Core/Utilities.js']], function (U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, defined, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Composition\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * Creates scrollbars if enabled.\n * @private\n */\n class ScrollbarAxis {\n /* *\n *\n * Static Properties\n *\n * */\n /**\n * Attaches to axis events to create scrollbars if enabled.\n *\n * @private\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param ScrollbarClass\n * Scrollbar class to use.\n */\n static compose(AxisClass, ScrollbarClass) {\n if (!U.pushUnique(composedMembers, AxisClass)) {\n return AxisClass;\n }\n const getExtremes = (axis) => {\n const axisMin = pick(axis.options && axis.options.min, axis.min);\n const axisMax = pick(axis.options && axis.options.max, axis.max);\n return {\n axisMin,\n axisMax,\n scrollMin: defined(axis.dataMin) ?\n Math.min(axisMin, axis.min, axis.dataMin, pick(axis.threshold, Infinity)) : axisMin,\n scrollMax: defined(axis.dataMax) ?\n Math.max(axisMax, axis.max, axis.dataMax, pick(axis.threshold, -Infinity)) : axisMax\n };\n };\n // Wrap axis initialization and create scrollbar if enabled:\n addEvent(AxisClass, 'afterInit', function () {\n const axis = this;\n if (axis.options &&\n axis.options.scrollbar &&\n axis.options.scrollbar.enabled) {\n // Predefined options:\n axis.options.scrollbar.vertical = !axis.horiz;\n axis.options.startOnTick = axis.options.endOnTick = false;\n axis.scrollbar = new ScrollbarClass(axis.chart.renderer, axis.options.scrollbar, axis.chart);\n addEvent(axis.scrollbar, 'changed', function (e) {\n let { axisMin, axisMax, scrollMin: unitedMin, scrollMax: unitedMax } = getExtremes(axis), range = unitedMax - unitedMin, to, from;\n // #12834, scroll when show/hide series, wrong extremes\n if (!defined(axisMin) || !defined(axisMax)) {\n return;\n }\n if ((axis.horiz && !axis.reversed) ||\n (!axis.horiz && axis.reversed)) {\n to = unitedMin + range * this.to;\n from = unitedMin + range * this.from;\n }\n else {\n // y-values in browser are reversed, but this also\n // applies for reversed horizontal axis:\n to = unitedMin + range * (1 - this.from);\n from = unitedMin + range * (1 - this.to);\n }\n if (this.shouldUpdateExtremes(e.DOMType)) {\n // #17977, set animation to undefined instead of true\n const animate = e.DOMType === 'mousemove' ||\n e.DOMType === 'touchmove' ? false : void 0;\n axis.setExtremes(from, to, true, animate, e);\n }\n else {\n // When live redraw is disabled, don't change extremes\n // Only change the position of the scollbar thumb\n this.setRange(this.from, this.to);\n }\n });\n }\n });\n // Wrap rendering axis, and update scrollbar if one is created:\n addEvent(AxisClass, 'afterRender', function () {\n let axis = this, { scrollMin, scrollMax } = getExtremes(axis), scrollbar = axis.scrollbar, offset = (axis.axisTitleMargin + (axis.titleOffset || 0)), scrollbarsOffsets = axis.chart.scrollbarsOffsets, axisMargin = axis.options.margin || 0, offsetsIndex, from, to;\n if (scrollbar) {\n if (axis.horiz) {\n // Reserve space for labels/title\n if (!axis.opposite) {\n scrollbarsOffsets[1] += offset;\n }\n scrollbar.position(axis.left, (axis.top +\n axis.height +\n 2 +\n scrollbarsOffsets[1] -\n (axis.opposite ? axisMargin : 0)), axis.width, axis.height);\n // Next scrollbar should reserve space for margin (if set)\n if (!axis.opposite) {\n scrollbarsOffsets[1] += axisMargin;\n }\n offsetsIndex = 1;\n }\n else {\n // Reserve space for labels/title\n if (axis.opposite) {\n scrollbarsOffsets[0] += offset;\n }\n let xPosition;\n if (!scrollbar.options.opposite) {\n xPosition = axis.opposite ? 0 : axisMargin;\n }\n else {\n xPosition = axis.left +\n axis.width +\n 2 +\n scrollbarsOffsets[0] -\n (axis.opposite ? 0 : axisMargin);\n }\n scrollbar.position(xPosition, axis.top, axis.width, axis.height);\n // Next scrollbar should reserve space for margin (if set)\n if (axis.opposite) {\n scrollbarsOffsets[0] += axisMargin;\n }\n offsetsIndex = 0;\n }\n scrollbarsOffsets[offsetsIndex] += scrollbar.size +\n (scrollbar.options.margin || 0);\n if (isNaN(scrollMin) ||\n isNaN(scrollMax) ||\n !defined(axis.min) ||\n !defined(axis.max) ||\n axis.min === axis.max // #10733\n ) {\n // default action: when extremes are the same or there is\n // not extremes on the axis, but scrollbar exists, make it\n // full size\n scrollbar.setRange(0, 1);\n }\n else {\n from = ((axis.min - scrollMin) /\n (scrollMax - scrollMin));\n to = ((axis.max - scrollMin) /\n (scrollMax - scrollMin));\n if ((axis.horiz && !axis.reversed) ||\n (!axis.horiz && axis.reversed)) {\n scrollbar.setRange(from, to);\n }\n else {\n // inverse vertical axis\n scrollbar.setRange(1 - to, 1 - from);\n }\n }\n }\n });\n // Make space for a scrollbar:\n addEvent(AxisClass, 'afterGetOffset', function () {\n const axis = this, scrollbar = axis.scrollbar, opposite = scrollbar && !scrollbar.options.opposite, index = axis.horiz ? 2 : opposite ? 3 : 1;\n if (scrollbar) {\n // reset scrollbars offsets\n axis.chart.scrollbarsOffsets = [0, 0];\n axis.chart.axisOffset[index] +=\n scrollbar.size + (scrollbar.options.margin || 0);\n }\n });\n return AxisClass;\n }\n }\n\n return ScrollbarAxis;\n });\n _registerModule(_modules, 'Stock/Scrollbar/ScrollbarDefaults.js', [_modules['Core/Globals.js']], function (H) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { isTouchDevice } = H;\n /* *\n *\n * Constant\n *\n * */\n /**\n *\n * The scrollbar is a means of panning over the X axis of a stock chart.\n * Scrollbars can also be applied to other types of axes.\n *\n * Another approach to scrollable charts is the [chart.scrollablePlotArea](\n * https://api.highcharts.com/highcharts/chart.scrollablePlotArea) option that\n * is especially suitable for simpler cartesian charts on mobile.\n *\n * In styled mode, all the presentational options for the\n * scrollbar are replaced by the classes `.highcharts-scrollbar-thumb`,\n * `.highcharts-scrollbar-arrow`, `.highcharts-scrollbar-button`,\n * `.highcharts-scrollbar-rifles` and `.highcharts-scrollbar-track`.\n *\n * @sample stock/yaxis/inverted-bar-scrollbar/\n * A scrollbar on a simple bar chart\n *\n * @product highstock gantt\n * @optionparent scrollbar\n *\n * @private\n */\n const ScrollbarDefaults = {\n /**\n * The height of the scrollbar. If `buttonsEnabled` is true , the height\n * also applies to the width of the scroll arrows so that they are always\n * squares.\n *\n * @sample stock/scrollbar/style/\n * Non-default height\n *\n * @type {number}\n */\n height: 10,\n /**\n * The border rounding radius of the bar.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n barBorderRadius: 5,\n /**\n * The corner radius of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n buttonBorderRadius: 0,\n /**\n * Enable or disable the buttons at the end of the scrollbar.\n *\n * @since 11.0.0\n */\n buttonsEnabled: false,\n /**\n * Enable or disable the scrollbar.\n *\n * @sample stock/scrollbar/enabled/\n * Disable the scrollbar, only use navigator\n *\n * @type {boolean}\n * @default true\n * @apioption scrollbar.enabled\n */\n /**\n * Whether to redraw the main chart as the scrollbar or the navigator\n * zoomed window is moved. Defaults to `true` for modern browsers and\n * `false` for legacy IE browsers as well as mobile devices.\n *\n * @sample stock/scrollbar/liveredraw\n * Setting live redraw to false\n *\n * @type {boolean}\n * @since 1.3\n */\n liveRedraw: void 0,\n /**\n * The margin between the scrollbar and its axis when the scrollbar is\n * applied directly to an axis, or the navigator in case that is enabled.\n * Defaults to 10 for axis, 0 for navigator.\n *\n * @type {number|undefined}\n */\n margin: void 0,\n /**\n * The minimum width of the scrollbar.\n *\n * @since 1.2.5\n */\n minWidth: 6,\n /** @ignore-option */\n opposite: true,\n /**\n * Whether to show or hide the scrollbar when the scrolled content is\n * zoomed out to it full extent.\n *\n * @type {boolean}\n * @default true\n * @apioption scrollbar.showFull\n */\n step: 0.2,\n /**\n * The z index of the scrollbar group.\n */\n zIndex: 3,\n /**\n * The background color of the scrollbar itself.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n barBackgroundColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The width of the bar's border.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n barBorderWidth: 0,\n /**\n * The color of the scrollbar's border.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n barBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The color of the small arrow inside the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonArrowColor: \"#333333\" /* Palette.neutralColor80 */,\n /**\n * The color of scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonBackgroundColor: \"#e6e6e6\" /* Palette.neutralColor10 */,\n /**\n * The color of the border of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n buttonBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The border width of the scrollbar buttons.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n buttonBorderWidth: 1,\n /**\n * The color of the small rifles in the middle of the scrollbar.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n rifleColor: 'none',\n /**\n * The color of the track background.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n trackBackgroundColor: 'rgba(255, 255, 255, 0.001)',\n /**\n * The color of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n */\n trackBorderColor: \"#cccccc\" /* Palette.neutralColor20 */,\n /**\n * The corner radius of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n trackBorderRadius: 5,\n /**\n * The width of the border of the scrollbar track.\n *\n * @sample stock/scrollbar/style/\n * Scrollbar styling\n */\n trackBorderWidth: 1\n };\n /* *\n *\n * Default Export\n *\n * */\n\n return ScrollbarDefaults;\n });\n _registerModule(_modules, 'Stock/Scrollbar/Scrollbar.js', [_modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/ScrollbarAxis.js'], _modules['Stock/Scrollbar/ScrollbarDefaults.js'], _modules['Core/Utilities.js']], function (D, H, ScrollbarAxis, ScrollbarDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { addEvent, correctFloat, defined, destroyObjectProperties, fireEvent, merge, pick, removeEvent } = U;\n /* *\n *\n * Constants\n *\n * */\n /* eslint-disable no-invalid-this, valid-jsdoc */\n /**\n * A reusable scrollbar, internally used in Highcharts Stock's\n * navigator and optionally on individual axes.\n *\n * @private\n * @class\n * @name Highcharts.Scrollbar\n * @param {Highcharts.SVGRenderer} renderer\n * @param {Highcharts.ScrollbarOptions} options\n * @param {Highcharts.Chart} chart\n */\n class Scrollbar {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AxisClass) {\n ScrollbarAxis.compose(AxisClass, Scrollbar);\n }\n /**\n * When we have vertical scrollbar, rifles and arrow in buttons should be\n * rotated. The same method is used in Navigator's handles, to rotate them.\n *\n * @function Highcharts.swapXY\n *\n * @param {Highcharts.SVGPathArray} path\n * Path to be rotated.\n *\n * @param {boolean} [vertical]\n * If vertical scrollbar, swap x-y values.\n *\n * @return {Highcharts.SVGPathArray}\n * Rotated path.\n *\n * @requires modules/stock\n */\n static swapXY(path, vertical) {\n if (vertical) {\n path.forEach((seg) => {\n const len = seg.length;\n let temp;\n for (let i = 0; i < len; i += 2) {\n temp = seg[i + 1];\n if (typeof temp === 'number') {\n seg[i + 1] = seg[i + 2];\n seg[i + 2] = temp;\n }\n }\n });\n }\n return path;\n }\n /* *\n *\n * Constructors\n *\n * */\n constructor(renderer, options, chart) {\n /* *\n *\n * Properties\n *\n * */\n this._events = [];\n this.chart = void 0;\n this.chartX = 0;\n this.chartY = 0;\n this.from = 0;\n this.group = void 0;\n this.options = void 0;\n this.renderer = void 0;\n this.scrollbar = void 0;\n this.scrollbarButtons = [];\n this.scrollbarGroup = void 0;\n this.scrollbarLeft = 0;\n this.scrollbarRifles = void 0;\n this.scrollbarStrokeWidth = 1;\n this.scrollbarTop = 0;\n this.size = 0;\n this.to = 0;\n this.track = void 0;\n this.trackBorderWidth = 1;\n this.userOptions = void 0;\n this.x = 0;\n this.y = 0;\n this.init(renderer, options, chart);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Set up the mouse and touch events for the Scrollbar\n *\n * @private\n * @function Highcharts.Scrollbar#addEvents\n */\n addEvents() {\n const buttonsOrder = this.options.inverted ? [1, 0] : [0, 1], buttons = this.scrollbarButtons, bar = this.scrollbarGroup.element, track = this.track.element, mouseDownHandler = this.mouseDownHandler.bind(this), mouseMoveHandler = this.mouseMoveHandler.bind(this), mouseUpHandler = this.mouseUpHandler.bind(this);\n // Mouse events\n const _events = [\n [\n buttons[buttonsOrder[0]].element,\n 'click',\n this.buttonToMinClick.bind(this)\n ],\n [\n buttons[buttonsOrder[1]].element,\n 'click',\n this.buttonToMaxClick.bind(this)\n ],\n [track, 'click', this.trackClick.bind(this)],\n [bar, 'mousedown', mouseDownHandler],\n [bar.ownerDocument, 'mousemove', mouseMoveHandler],\n [bar.ownerDocument, 'mouseup', mouseUpHandler]\n ];\n // Touch events\n if (H.hasTouch) {\n _events.push([bar, 'touchstart', mouseDownHandler], [bar.ownerDocument, 'touchmove', mouseMoveHandler], [bar.ownerDocument, 'touchend', mouseUpHandler]);\n }\n // Add them all\n _events.forEach(function (args) {\n addEvent.apply(null, args);\n });\n this._events = _events;\n }\n buttonToMaxClick(e) {\n const scroller = this;\n const range = ((scroller.to - scroller.from) *\n pick(scroller.options.step, 0.2));\n scroller.updatePosition(scroller.from + range, scroller.to + range);\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n }\n buttonToMinClick(e) {\n const scroller = this;\n const range = correctFloat(scroller.to - scroller.from) *\n pick(scroller.options.step, 0.2);\n scroller.updatePosition(correctFloat(scroller.from - range), correctFloat(scroller.to - range));\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n }\n /**\n * Get normalized (0-1) cursor position over the scrollbar\n *\n * @private\n * @function Highcharts.Scrollbar#cursorToScrollbarPosition\n *\n * @param {*} normalizedEvent\n * normalized event, with chartX and chartY values\n *\n * @return {Highcharts.Dictionary}\n * Local position {chartX, chartY}\n */\n cursorToScrollbarPosition(normalizedEvent) {\n const scroller = this, options = scroller.options, minWidthDifference = options.minWidth > scroller.calculatedWidth ?\n options.minWidth :\n 0; // minWidth distorts translation\n return {\n chartX: (normalizedEvent.chartX - scroller.x -\n scroller.xOffset) /\n (scroller.barWidth - minWidthDifference),\n chartY: (normalizedEvent.chartY - scroller.y -\n scroller.yOffset) /\n (scroller.barWidth - minWidthDifference)\n };\n }\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.Scrollbar#destroy\n */\n destroy() {\n const scroller = this, navigator = scroller.chart.scroller;\n // Disconnect events added in addEvents\n scroller.removeEvents();\n // Destroy properties\n [\n 'track',\n 'scrollbarRifles',\n 'scrollbar',\n 'scrollbarGroup',\n 'group'\n ].forEach(function (prop) {\n if (scroller[prop] && scroller[prop].destroy) {\n scroller[prop] = scroller[prop].destroy();\n }\n });\n // #6421, chart may have more scrollbars\n if (navigator && scroller === navigator.scrollbar) {\n navigator.scrollbar = null;\n // Destroy elements in collection\n destroyObjectProperties(navigator.scrollbarButtons);\n }\n }\n /**\n * Draw the scrollbar buttons with arrows\n *\n * @private\n * @function Highcharts.Scrollbar#drawScrollbarButton\n * @param {number} index\n * 0 is left, 1 is right\n */\n drawScrollbarButton(index) {\n const scroller = this, renderer = scroller.renderer, scrollbarButtons = scroller.scrollbarButtons, options = scroller.options, size = scroller.size, group = renderer.g().add(scroller.group);\n scrollbarButtons.push(group);\n if (options.buttonsEnabled) {\n // Create a rectangle for the scrollbar button\n const rect = renderer.rect()\n .addClass('highcharts-scrollbar-button')\n .add(group);\n // Presentational attributes\n if (!scroller.chart.styledMode) {\n rect.attr({\n stroke: options.buttonBorderColor,\n 'stroke-width': options.buttonBorderWidth,\n fill: options.buttonBackgroundColor\n });\n }\n // Place the rectangle based on the rendered stroke width\n rect.attr(rect.crisp({\n x: -0.5,\n y: -0.5,\n // +1 to compensate for crispifying in rect method\n width: size + 1,\n height: size + 1,\n r: options.buttonBorderRadius\n }, rect.strokeWidth()));\n // Button arrow\n const arrow = renderer\n .path(Scrollbar.swapXY([[\n 'M',\n size / 2 + (index ? -1 : 1),\n size / 2 - 3\n ], [\n 'L',\n size / 2 + (index ? -1 : 1),\n size / 2 + 3\n ], [\n 'L',\n size / 2 + (index ? 2 : -2),\n size / 2\n ]], options.vertical))\n .addClass('highcharts-scrollbar-arrow')\n .add(scrollbarButtons[index]);\n if (!scroller.chart.styledMode) {\n arrow.attr({\n fill: options.buttonArrowColor\n });\n }\n }\n }\n /**\n * @private\n * @function Highcharts.Scrollbar#init\n * @param {Highcharts.SVGRenderer} renderer\n * @param {Highcharts.ScrollbarOptions} options\n * @param {Highcharts.Chart} chart\n */\n init(renderer, options, chart) {\n const scroller = this;\n scroller.scrollbarButtons = [];\n scroller.renderer = renderer;\n scroller.userOptions = options;\n scroller.options = merge(ScrollbarDefaults, defaultOptions.scrollbar, options);\n scroller.options.margin = pick(scroller.options.margin, 10);\n scroller.chart = chart;\n // backward compatibility\n scroller.size = pick(scroller.options.size, scroller.options.height);\n // Init\n if (options.enabled) {\n scroller.render();\n scroller.addEvents();\n }\n }\n mouseDownHandler(e) {\n const scroller = this, normalizedEvent = scroller.chart.pointer.normalize(e), mousePosition = scroller.cursorToScrollbarPosition(normalizedEvent);\n scroller.chartX = mousePosition.chartX;\n scroller.chartY = mousePosition.chartY;\n scroller.initPositions = [scroller.from, scroller.to];\n scroller.grabbedCenter = true;\n }\n /**\n * Event handler for the mouse move event.\n * @private\n */\n mouseMoveHandler(e) {\n const scroller = this, normalizedEvent = scroller.chart.pointer.normalize(e), options = scroller.options, direction = options.vertical ?\n 'chartY' : 'chartX', initPositions = scroller.initPositions || [];\n let scrollPosition, chartPosition, change;\n // In iOS, a mousemove event with e.pageX === 0 is fired when\n // holding the finger down in the center of the scrollbar. This\n // should be ignored.\n if (scroller.grabbedCenter &&\n // #4696, scrollbar failed on Android\n (!e.touches || e.touches[0][direction] !== 0)) {\n chartPosition = scroller.cursorToScrollbarPosition(normalizedEvent)[direction];\n scrollPosition = scroller[direction];\n change = chartPosition - scrollPosition;\n scroller.hasDragged = true;\n scroller.updatePosition(initPositions[0] + change, initPositions[1] + change);\n if (scroller.hasDragged) {\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMType: e.type,\n DOMEvent: e\n });\n }\n }\n }\n /**\n * Event handler for the mouse up event.\n * @private\n */\n mouseUpHandler(e) {\n const scroller = this;\n if (scroller.hasDragged) {\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMType: e.type,\n DOMEvent: e\n });\n }\n scroller.grabbedCenter =\n scroller.hasDragged =\n scroller.chartX =\n scroller.chartY = null;\n }\n /**\n * Position the scrollbar, method called from a parent with defined\n * dimensions.\n *\n * @private\n * @function Highcharts.Scrollbar#position\n * @param {number} x\n * x-position on the chart\n * @param {number} y\n * y-position on the chart\n * @param {number} width\n * width of the scrollbar\n * @param {number} height\n * height of the scorllbar\n */\n position(x, y, width, height) {\n const scroller = this, options = scroller.options, { buttonsEnabled, margin = 0, vertical } = options, method = scroller.rendered ? 'animate' : 'attr';\n let xOffset = height, yOffset = 0;\n // Make the scrollbar visible when it is repositioned, #15763.\n scroller.group.show();\n scroller.x = x;\n scroller.y = y + this.trackBorderWidth;\n scroller.width = width; // width with buttons\n scroller.height = height;\n scroller.xOffset = xOffset;\n scroller.yOffset = yOffset;\n // If Scrollbar is a vertical type, swap options:\n if (vertical) {\n scroller.width = scroller.yOffset = width = yOffset = scroller.size;\n scroller.xOffset = xOffset = 0;\n scroller.yOffset = yOffset = buttonsEnabled ? scroller.size : 0;\n // width without buttons\n scroller.barWidth = height - (buttonsEnabled ? width * 2 : 0);\n scroller.x = x = x + margin;\n }\n else {\n scroller.height = height = scroller.size;\n scroller.xOffset = xOffset = buttonsEnabled ? scroller.size : 0;\n // width without buttons\n scroller.barWidth = width - (buttonsEnabled ? height * 2 : 0);\n scroller.y = scroller.y + margin;\n }\n // Set general position for a group:\n scroller.group[method]({\n translateX: x,\n translateY: scroller.y\n });\n // Resize background/track:\n scroller.track[method]({\n width: width,\n height: height\n });\n // Move right/bottom button to its place:\n scroller.scrollbarButtons[1][method]({\n translateX: vertical ? 0 : width - xOffset,\n translateY: vertical ? height - yOffset : 0\n });\n }\n /**\n * Removes the event handlers attached previously with addEvents.\n *\n * @private\n * @function Highcharts.Scrollbar#removeEvents\n */\n removeEvents() {\n this._events.forEach(function (args) {\n removeEvent.apply(null, args);\n });\n this._events.length = 0;\n }\n /**\n * Render scrollbar with all required items.\n *\n * @private\n * @function Highcharts.Scrollbar#render\n */\n render() {\n const scroller = this, renderer = scroller.renderer, options = scroller.options, size = scroller.size, styledMode = scroller.chart.styledMode, group = renderer.g('scrollbar')\n .attr({\n zIndex: options.zIndex\n })\n .hide() // initially hide the scrollbar #15863\n .add();\n // Draw the scrollbar group\n scroller.group = group;\n // Draw the scrollbar track:\n scroller.track = renderer.rect()\n .addClass('highcharts-scrollbar-track')\n .attr({\n r: options.trackBorderRadius || 0,\n height: size,\n width: size\n }).add(group);\n if (!styledMode) {\n scroller.track.attr({\n fill: options.trackBackgroundColor,\n stroke: options.trackBorderColor,\n 'stroke-width': options.trackBorderWidth\n });\n }\n const trackBorderWidth = scroller.trackBorderWidth =\n scroller.track.strokeWidth();\n scroller.track.attr({\n x: -trackBorderWidth % 2 / 2,\n y: -trackBorderWidth % 2 / 2\n });\n // Draw the scrollbar itself\n scroller.scrollbarGroup = renderer.g().add(group);\n scroller.scrollbar = renderer.rect()\n .addClass('highcharts-scrollbar-thumb')\n .attr({\n height: size - trackBorderWidth,\n width: size - trackBorderWidth,\n r: options.barBorderRadius || 0\n }).add(scroller.scrollbarGroup);\n scroller.scrollbarRifles = renderer\n .path(Scrollbar.swapXY([\n ['M', -3, size / 4],\n ['L', -3, 2 * size / 3],\n ['M', 0, size / 4],\n ['L', 0, 2 * size / 3],\n ['M', 3, size / 4],\n ['L', 3, 2 * size / 3]\n ], options.vertical))\n .addClass('highcharts-scrollbar-rifles')\n .add(scroller.scrollbarGroup);\n if (!styledMode) {\n scroller.scrollbar.attr({\n fill: options.barBackgroundColor,\n stroke: options.barBorderColor,\n 'stroke-width': options.barBorderWidth\n });\n scroller.scrollbarRifles.attr({\n stroke: options.rifleColor,\n 'stroke-width': 1\n });\n }\n scroller.scrollbarStrokeWidth = scroller.scrollbar.strokeWidth();\n scroller.scrollbarGroup.translate(-scroller.scrollbarStrokeWidth % 2 / 2, -scroller.scrollbarStrokeWidth % 2 / 2);\n // Draw the buttons:\n scroller.drawScrollbarButton(0);\n scroller.drawScrollbarButton(1);\n }\n /**\n * Set scrollbar size, with a given scale.\n *\n * @private\n * @function Highcharts.Scrollbar#setRange\n * @param {number} from\n * scale (0-1) where bar should start\n * @param {number} to\n * scale (0-1) where bar should end\n */\n setRange(from, to) {\n const scroller = this, options = scroller.options, vertical = options.vertical, minWidth = options.minWidth, fullWidth = scroller.barWidth, method = (this.rendered &&\n !this.hasDragged &&\n !(this.chart.navigator && this.chart.navigator.hasDragged)) ? 'animate' : 'attr';\n if (!defined(fullWidth)) {\n return;\n }\n const toPX = fullWidth * Math.min(to, 1);\n let fromPX, newSize;\n from = Math.max(from, 0);\n fromPX = Math.ceil(fullWidth * from);\n scroller.calculatedWidth = newSize = correctFloat(toPX - fromPX);\n // We need to recalculate position, if minWidth is used\n if (newSize < minWidth) {\n fromPX = (fullWidth - minWidth + newSize) * from;\n newSize = minWidth;\n }\n const newPos = Math.floor(fromPX + scroller.xOffset + scroller.yOffset);\n const newRiflesPos = newSize / 2 - 0.5; // -0.5 -> rifle line width / 2\n // Store current position:\n scroller.from = from;\n scroller.to = to;\n if (!vertical) {\n scroller.scrollbarGroup[method]({\n translateX: newPos\n });\n scroller.scrollbar[method]({\n width: newSize\n });\n scroller.scrollbarRifles[method]({\n translateX: newRiflesPos\n });\n scroller.scrollbarLeft = newPos;\n scroller.scrollbarTop = 0;\n }\n else {\n scroller.scrollbarGroup[method]({\n translateY: newPos\n });\n scroller.scrollbar[method]({\n height: newSize\n });\n scroller.scrollbarRifles[method]({\n translateY: newRiflesPos\n });\n scroller.scrollbarTop = newPos;\n scroller.scrollbarLeft = 0;\n }\n if (newSize <= 12) {\n scroller.scrollbarRifles.hide();\n }\n else {\n scroller.scrollbarRifles.show();\n }\n // Show or hide the scrollbar based on the showFull setting\n if (options.showFull === false) {\n if (from <= 0 && to >= 1) {\n scroller.group.hide();\n }\n else {\n scroller.group.show();\n }\n }\n scroller.rendered = true;\n }\n /**\n * Checks if the extremes should be updated in response to a scrollbar\n * change event.\n *\n * @private\n * @function Highcharts.Scrollbar#shouldUpdateExtremes\n */\n shouldUpdateExtremes(eventType) {\n return (pick(this.options.liveRedraw, H.svg &&\n !H.isTouchDevice &&\n !this.chart.boosted) ||\n // Mouseup always should change extremes\n eventType === 'mouseup' ||\n eventType === 'touchend' ||\n // Internal events\n !defined(eventType));\n }\n trackClick(e) {\n const scroller = this;\n const normalizedEvent = scroller.chart.pointer.normalize(e), range = scroller.to - scroller.from, top = scroller.y + scroller.scrollbarTop, left = scroller.x + scroller.scrollbarLeft;\n if ((scroller.options.vertical && normalizedEvent.chartY > top) ||\n (!scroller.options.vertical && normalizedEvent.chartX > left)) {\n // On the top or on the left side of the track:\n scroller.updatePosition(scroller.from + range, scroller.to + range);\n }\n else {\n // On the bottom or the right side of the track:\n scroller.updatePosition(scroller.from - range, scroller.to - range);\n }\n fireEvent(scroller, 'changed', {\n from: scroller.from,\n to: scroller.to,\n trigger: 'scrollbar',\n DOMEvent: e\n });\n }\n /**\n * Update the scrollbar with new options\n *\n * @private\n * @function Highcharts.Scrollbar#update\n * @param {Highcharts.ScrollbarOptions} options\n */\n update(options) {\n this.destroy();\n this.init(this.chart.renderer, merge(true, this.options, options), this.chart);\n }\n /**\n * Update position option in the Scrollbar, with normalized 0-1 scale\n *\n * @private\n * @function Highcharts.Scrollbar#updatePosition\n * @param {number} from\n * @param {number} to\n */\n updatePosition(from, to) {\n if (to > 1) {\n from = correctFloat(1 - correctFloat(to - from));\n to = 1;\n }\n if (from < 0) {\n to = correctFloat(to - from);\n from = 0;\n }\n this.from = from;\n this.to = to;\n }\n }\n /* *\n *\n * Static Properties\n *\n * */\n Scrollbar.defaultOptions = ScrollbarDefaults;\n /* *\n *\n * Registry\n *\n * */\n defaultOptions.scrollbar = merge(true, Scrollbar.defaultOptions, defaultOptions.scrollbar);\n /* *\n *\n * Default Export\n *\n * */\n\n return Scrollbar;\n });\n _registerModule(_modules, 'Stock/Navigator/Navigator.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Core/Axis/NavigatorAxisComposition.js'], _modules['Stock/Navigator/NavigatorComposition.js'], _modules['Stock/Scrollbar/Scrollbar.js'], _modules['Core/Utilities.js']], function (Axis, D, H, NavigatorAxisAdditions, NavigatorComposition, Scrollbar, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { hasTouch, isTouchDevice } = H;\n const { addEvent, clamp, correctFloat, defined, destroyObjectProperties, erase, extend, find, isArray, isNumber, merge, pick, removeEvent, splat } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Finding the min or max of a set of variables where we don't know if they are\n * defined, is a pattern that is repeated several places in Highcharts. Consider\n * making this a global utility method.\n * @private\n */\n function numExt(extreme, ...args) {\n const numbers = [].filter.call(args, isNumber);\n if (numbers.length) {\n return Math[extreme].apply(0, numbers);\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The Navigator class\n *\n * @private\n * @class\n * @name Highcharts.Navigator\n *\n * @param {Highcharts.Chart} chart\n * Chart object\n */\n class Navigator {\n /* *\n *\n * Static Functions\n *\n * */\n static compose(AxisClass, ChartClass, SeriesClass) {\n NavigatorComposition.compose(AxisClass, ChartClass, Navigator, SeriesClass);\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart) {\n /* *\n *\n * Properties\n *\n * */\n this.baseSeries = void 0;\n this.chart = void 0;\n this.handles = void 0;\n this.height = void 0;\n this.left = void 0;\n this.navigatorEnabled = void 0;\n this.navigatorGroup = void 0;\n this.navigatorOptions = void 0;\n this.navigatorSeries = void 0;\n this.navigatorSize = void 0;\n this.opposite = void 0;\n this.outline = void 0;\n this.range = void 0;\n this.rendered = void 0;\n this.scrollbarHeight = 0;\n this.scrollButtonSize = void 0;\n this.shades = void 0;\n this.size = void 0;\n this.top = void 0;\n this.xAxis = void 0;\n this.yAxis = void 0;\n this.zoomedMax = void 0;\n this.zoomedMin = void 0;\n this.init(chart);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Draw one of the handles on the side of the zoomed range in the navigator.\n *\n * @private\n * @function Highcharts.Navigator#drawHandle\n *\n * @param {number} x\n * The x center for the handle\n *\n * @param {number} index\n * 0 for left and 1 for right\n *\n * @param {boolean|undefined} inverted\n * Flag for chart.inverted\n *\n * @param {string} verb\n * Use 'animate' or 'attr'\n */\n drawHandle(x, index, inverted, verb) {\n const navigator = this, height = navigator.navigatorOptions.handles.height;\n // Place it\n navigator.handles[index][verb](inverted ? {\n translateX: Math.round(navigator.left + navigator.height / 2),\n translateY: Math.round(navigator.top + parseInt(x, 10) + 0.5 - height)\n } : {\n translateX: Math.round(navigator.left + parseInt(x, 10)),\n translateY: Math.round(navigator.top + navigator.height / 2 - height / 2 - 1)\n });\n }\n /**\n * Render outline around the zoomed range\n *\n * @private\n * @function Highcharts.Navigator#drawOutline\n *\n * @param {number} zoomedMin\n * in pixels position where zoomed range starts\n *\n * @param {number} zoomedMax\n * in pixels position where zoomed range ends\n *\n * @param {boolean|undefined} inverted\n * flag if chart is inverted\n *\n * @param {string} verb\n * use 'animate' or 'attr'\n */\n drawOutline(zoomedMin, zoomedMax, inverted, verb) {\n const navigator = this, maskInside = navigator.navigatorOptions.maskInside, outlineWidth = navigator.outline.strokeWidth(), halfOutline = outlineWidth / 2, outlineCorrection = (outlineWidth % 2) / 2, // #5800\n scrollButtonSize = navigator.scrollButtonSize, navigatorSize = navigator.size, navigatorTop = navigator.top, height = navigator.height, lineTop = navigatorTop - halfOutline, lineBtm = navigatorTop + height;\n let left = navigator.left, verticalMin, path;\n if (inverted) {\n verticalMin = navigatorTop + zoomedMax + outlineCorrection;\n zoomedMax = navigatorTop + zoomedMin + outlineCorrection;\n path = [\n [\n 'M',\n left + height,\n navigatorTop - scrollButtonSize - outlineCorrection\n ],\n // top right of zoomed range\n ['L', left + height, verticalMin],\n ['L', left, verticalMin],\n ['M', left, zoomedMax],\n ['L', left + height, zoomedMax],\n [\n 'L',\n left + height,\n navigatorTop + navigatorSize + scrollButtonSize\n ]\n ];\n if (maskInside) {\n path.push(\n // upper left of zoomed range\n ['M', left + height, verticalMin - halfOutline], \n // upper right of z.r.\n [\n 'L',\n left + height,\n zoomedMax + halfOutline\n ]);\n }\n }\n else {\n left -= scrollButtonSize;\n zoomedMin += left + scrollButtonSize - outlineCorrection;\n zoomedMax += left + scrollButtonSize - outlineCorrection;\n path = [\n // left\n ['M', left, lineTop],\n // upper left of zoomed range\n ['L', zoomedMin, lineTop],\n // lower left of z.r.\n ['L', zoomedMin, lineBtm],\n // lower right of z.r.\n ['M', zoomedMax, lineBtm],\n // upper right of z.r.\n ['L', zoomedMax, lineTop],\n // right\n [\n 'L',\n left + navigatorSize + scrollButtonSize * 2,\n navigatorTop + halfOutline\n ]\n ];\n if (maskInside) {\n path.push(\n // upper left of zoomed range\n ['M', zoomedMin - halfOutline, lineTop], \n // upper right of z.r.\n ['L', zoomedMax + halfOutline, lineTop]);\n }\n }\n navigator.outline[verb]({\n d: path\n });\n }\n /**\n * Render outline around the zoomed range\n *\n * @private\n * @function Highcharts.Navigator#drawMasks\n *\n * @param {number} zoomedMin\n * in pixels position where zoomed range starts\n *\n * @param {number} zoomedMax\n * in pixels position where zoomed range ends\n *\n * @param {boolean|undefined} inverted\n * flag if chart is inverted\n *\n * @param {string} verb\n * use 'animate' or 'attr'\n */\n drawMasks(zoomedMin, zoomedMax, inverted, verb) {\n const navigator = this, left = navigator.left, top = navigator.top, navigatorHeight = navigator.height;\n let height, width, x, y;\n // Determine rectangle position & size\n // According to (non)inverted position:\n if (inverted) {\n x = [left, left, left];\n y = [top, top + zoomedMin, top + zoomedMax];\n width = [navigatorHeight, navigatorHeight, navigatorHeight];\n height = [\n zoomedMin,\n zoomedMax - zoomedMin,\n navigator.size - zoomedMax\n ];\n }\n else {\n x = [left, left + zoomedMin, left + zoomedMax];\n y = [top, top, top];\n width = [\n zoomedMin,\n zoomedMax - zoomedMin,\n navigator.size - zoomedMax\n ];\n height = [navigatorHeight, navigatorHeight, navigatorHeight];\n }\n navigator.shades.forEach((shade, i) => {\n shade[verb]({\n x: x[i],\n y: y[i],\n width: width[i],\n height: height[i]\n });\n });\n }\n /**\n * Generate DOM elements for a navigator:\n *\n * - main navigator group\n *\n * - all shades\n *\n * - outline\n *\n * - handles\n *\n * @private\n * @function Highcharts.Navigator#renderElements\n */\n renderElements() {\n const navigator = this, navigatorOptions = navigator.navigatorOptions, maskInside = navigatorOptions.maskInside, chart = navigator.chart, inverted = chart.inverted, renderer = chart.renderer, mouseCursor = {\n cursor: inverted ? 'ns-resize' : 'ew-resize'\n }, \n // Create the main navigator group\n navigatorGroup = navigator.navigatorGroup = renderer\n .g('navigator')\n .attr({\n zIndex: 8,\n visibility: 'hidden'\n })\n .add();\n // Create masks, each mask will get events and fill:\n [\n !maskInside,\n maskInside,\n !maskInside\n ].forEach((hasMask, index) => {\n const shade = renderer.rect()\n .addClass('highcharts-navigator-mask' +\n (index === 1 ? '-inside' : '-outside'))\n .add(navigatorGroup);\n if (!chart.styledMode) {\n shade.attr({\n fill: hasMask ?\n navigatorOptions.maskFill :\n 'rgba(0,0,0,0)'\n });\n if (index === 1) {\n shade.css(mouseCursor);\n }\n }\n navigator.shades[index] = shade;\n });\n // Create the outline:\n navigator.outline = renderer.path()\n .addClass('highcharts-navigator-outline')\n .add(navigatorGroup);\n if (!chart.styledMode) {\n navigator.outline.attr({\n 'stroke-width': navigatorOptions.outlineWidth,\n stroke: navigatorOptions.outlineColor\n });\n }\n // Create the handlers:\n if (navigatorOptions.handles && navigatorOptions.handles.enabled) {\n const handlesOptions = navigatorOptions.handles, { height, width } = handlesOptions;\n [0, 1].forEach((index) => {\n navigator.handles[index] = renderer.symbol(handlesOptions.symbols[index], -width / 2 - 1, 0, width, height, handlesOptions);\n if (chart.inverted) {\n navigator.handles[index].attr({\n rotation: 90,\n rotationOriginX: Math.floor(-width / 2),\n rotationOriginY: (height + width) / 2\n });\n }\n // zIndex = 6 for right handle, 7 for left.\n // Can't be 10, because of the tooltip in inverted chart #2908\n navigator.handles[index].attr({ zIndex: 7 - index })\n .addClass('highcharts-navigator-handle ' +\n 'highcharts-navigator-handle-' +\n ['left', 'right'][index]).add(navigatorGroup);\n if (!chart.styledMode) {\n navigator.handles[index]\n .attr({\n fill: handlesOptions.backgroundColor,\n stroke: handlesOptions.borderColor,\n 'stroke-width': handlesOptions.lineWidth\n })\n .css(mouseCursor);\n }\n });\n }\n }\n /**\n * Update navigator\n *\n * @private\n * @function Highcharts.Navigator#update\n *\n * @param {Highcharts.NavigatorOptions} options\n * Options to merge in when updating navigator\n */\n update(options) {\n // Remove references to old navigator series in base series\n (this.series || []).forEach((series) => {\n if (series.baseSeries) {\n delete series.baseSeries.navigatorSeries;\n }\n });\n // Destroy and rebuild navigator\n this.destroy();\n const chartOptions = this.chart.options;\n merge(true, chartOptions.navigator, options);\n this.init(this.chart);\n }\n /**\n * Render the navigator\n *\n * @private\n * @function Highcharts.Navigator#render\n * @param {number} min\n * X axis value minimum\n * @param {number} max\n * X axis value maximum\n * @param {number} [pxMin]\n * Pixel value minimum\n * @param {number} [pxMax]\n * Pixel value maximum\n */\n render(min, max, pxMin, pxMax) {\n const navigator = this, chart = navigator.chart, xAxis = navigator.xAxis, pointRange = xAxis.pointRange || 0, scrollbarXAxis = xAxis.navigatorAxis.fake ? chart.xAxis[0] : xAxis, navigatorEnabled = navigator.navigatorEnabled, rendered = navigator.rendered, inverted = chart.inverted, minRange = chart.xAxis[0].minRange, maxRange = chart.xAxis[0].options.maxRange, scrollButtonSize = navigator.scrollButtonSize;\n let navigatorWidth, scrollbarLeft, scrollbarTop, scrollbarHeight = navigator.scrollbarHeight, navigatorSize, verb;\n // Don't redraw while moving the handles (#4703).\n if (this.hasDragged && !defined(pxMin)) {\n return;\n }\n min = correctFloat(min - pointRange / 2);\n max = correctFloat(max + pointRange / 2);\n // Don't render the navigator until we have data (#486, #4202, #5172).\n if (!isNumber(min) || !isNumber(max)) {\n // However, if navigator was already rendered, we may need to resize\n // it. For example hidden series, but visible navigator (#6022).\n if (rendered) {\n pxMin = 0;\n pxMax = pick(xAxis.width, scrollbarXAxis.width);\n }\n else {\n return;\n }\n }\n navigator.left = pick(xAxis.left, \n // in case of scrollbar only, without navigator\n chart.plotLeft + scrollButtonSize +\n (inverted ? chart.plotWidth : 0));\n let zoomedMax = navigator.size = navigatorSize = pick(xAxis.len, (inverted ? chart.plotHeight : chart.plotWidth) -\n 2 * scrollButtonSize);\n if (inverted) {\n navigatorWidth = scrollbarHeight;\n }\n else {\n navigatorWidth = navigatorSize + 2 * scrollButtonSize;\n }\n // Get the pixel position of the handles\n pxMin = pick(pxMin, xAxis.toPixels(min, true));\n pxMax = pick(pxMax, xAxis.toPixels(max, true));\n // Verify (#1851, #2238)\n if (!isNumber(pxMin) || Math.abs(pxMin) === Infinity) {\n pxMin = 0;\n pxMax = navigatorWidth;\n }\n // Are we below the minRange? (#2618, #6191)\n const newMin = xAxis.toValue(pxMin, true), newMax = xAxis.toValue(pxMax, true), currentRange = Math.abs(correctFloat(newMax - newMin));\n if (currentRange < minRange) {\n if (this.grabbedLeft) {\n pxMin = xAxis.toPixels(newMax - minRange - pointRange, true);\n }\n else if (this.grabbedRight) {\n pxMax = xAxis.toPixels(newMin + minRange + pointRange, true);\n }\n }\n else if (defined(maxRange) &&\n correctFloat(currentRange - pointRange) > maxRange) {\n if (this.grabbedLeft) {\n pxMin = xAxis.toPixels(newMax - maxRange - pointRange, true);\n }\n else if (this.grabbedRight) {\n pxMax = xAxis.toPixels(newMin + maxRange + pointRange, true);\n }\n }\n // Handles are allowed to cross, but never exceed the plot area\n navigator.zoomedMax = clamp(Math.max(pxMin, pxMax), 0, zoomedMax);\n navigator.zoomedMin = clamp(navigator.fixedWidth ?\n navigator.zoomedMax - navigator.fixedWidth :\n Math.min(pxMin, pxMax), 0, zoomedMax);\n navigator.range = navigator.zoomedMax - navigator.zoomedMin;\n zoomedMax = Math.round(navigator.zoomedMax);\n const zoomedMin = Math.round(navigator.zoomedMin);\n if (navigatorEnabled) {\n navigator.navigatorGroup.attr({\n visibility: 'inherit'\n });\n // Place elements\n verb = rendered && !navigator.hasDragged ? 'animate' : 'attr';\n navigator.drawMasks(zoomedMin, zoomedMax, inverted, verb);\n navigator.drawOutline(zoomedMin, zoomedMax, inverted, verb);\n if (navigator.navigatorOptions.handles.enabled) {\n navigator.drawHandle(zoomedMin, 0, inverted, verb);\n navigator.drawHandle(zoomedMax, 1, inverted, verb);\n }\n }\n if (navigator.scrollbar) {\n if (inverted) {\n scrollbarTop = navigator.top - scrollButtonSize;\n scrollbarLeft = navigator.left - scrollbarHeight +\n (navigatorEnabled || !scrollbarXAxis.opposite ? 0 :\n // Multiple axes has offsets:\n (scrollbarXAxis.titleOffset || 0) +\n // Self margin from the axis.title\n scrollbarXAxis.axisTitleMargin);\n scrollbarHeight = navigatorSize + 2 * scrollButtonSize;\n }\n else {\n scrollbarTop = navigator.top + (navigatorEnabled ?\n navigator.height :\n -scrollbarHeight);\n scrollbarLeft = navigator.left - scrollButtonSize;\n }\n // Reposition scrollbar\n navigator.scrollbar.position(scrollbarLeft, scrollbarTop, navigatorWidth, scrollbarHeight);\n // Keep scale 0-1\n navigator.scrollbar.setRange(\n // Use real value, not rounded because range can be very small\n // (#1716)\n navigator.zoomedMin / (navigatorSize || 1), navigator.zoomedMax / (navigatorSize || 1));\n }\n navigator.rendered = true;\n }\n /**\n * Set up the mouse and touch events for the navigator\n *\n * @private\n * @function Highcharts.Navigator#addMouseEvents\n */\n addMouseEvents() {\n const navigator = this, chart = navigator.chart, container = chart.container;\n let eventsToUnbind = [], mouseMoveHandler, mouseUpHandler;\n /**\n * Create mouse events' handlers.\n * Make them as separate functions to enable wrapping them:\n */\n navigator.mouseMoveHandler = mouseMoveHandler = function (e) {\n navigator.onMouseMove(e);\n };\n navigator.mouseUpHandler = mouseUpHandler = function (e) {\n navigator.onMouseUp(e);\n };\n // Add shades and handles mousedown events\n eventsToUnbind = navigator.getPartsEvents('mousedown');\n // Add mouse move and mouseup events. These are bind to doc/container,\n // because Navigator.grabbedSomething flags are stored in mousedown\n // events\n eventsToUnbind.push(addEvent(chart.renderTo, 'mousemove', mouseMoveHandler), addEvent(container.ownerDocument, 'mouseup', mouseUpHandler));\n // Touch events\n if (hasTouch) {\n eventsToUnbind.push(addEvent(chart.renderTo, 'touchmove', mouseMoveHandler), addEvent(container.ownerDocument, 'touchend', mouseUpHandler));\n eventsToUnbind.concat(navigator.getPartsEvents('touchstart'));\n }\n navigator.eventsToUnbind = eventsToUnbind;\n // Data events\n if (navigator.series && navigator.series[0]) {\n eventsToUnbind.push(addEvent(navigator.series[0].xAxis, 'foundExtremes', function () {\n chart.navigator.modifyNavigatorAxisExtremes();\n }));\n }\n }\n /**\n * Generate events for handles and masks\n *\n * @private\n * @function Highcharts.Navigator#getPartsEvents\n *\n * @param {string} eventName\n * Event name handler, 'mousedown' or 'touchstart'\n *\n * @return {Array}\n * An array of functions to remove navigator functions from the\n * events again.\n */\n getPartsEvents(eventName) {\n const navigator = this, events = [];\n ['shades', 'handles'].forEach(function (name) {\n navigator[name].forEach(function (navigatorItem, index) {\n events.push(addEvent(navigatorItem.element, eventName, function (e) {\n navigator[name + 'Mousedown'](e, index);\n }));\n });\n });\n return events;\n }\n /**\n * Mousedown on a shaded mask, either:\n *\n * - will be stored for future drag&drop\n *\n * - will directly shift to a new range\n *\n * @private\n * @function Highcharts.Navigator#shadesMousedown\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n *\n * @param {number} index\n * Index of a mask in Navigator.shades array\n */\n shadesMousedown(e, index) {\n e = this.chart.pointer.normalize(e);\n const navigator = this, chart = navigator.chart, xAxis = navigator.xAxis, zoomedMin = navigator.zoomedMin, navigatorSize = navigator.size, range = navigator.range;\n let navigatorPosition = navigator.left, chartX = e.chartX, fixedMax, fixedMin, ext, left;\n // For inverted chart, swap some options:\n if (chart.inverted) {\n chartX = e.chartY;\n navigatorPosition = navigator.top;\n }\n if (index === 1) {\n // Store information for drag&drop\n navigator.grabbedCenter = chartX;\n navigator.fixedWidth = range;\n navigator.dragOffset = chartX - zoomedMin;\n }\n else {\n // Shift the range by clicking on shaded areas\n left = chartX - navigatorPosition - range / 2;\n if (index === 0) {\n left = Math.max(0, left);\n }\n else if (index === 2 && left + range >= navigatorSize) {\n left = navigatorSize - range;\n if (navigator.reversedExtremes) {\n // #7713\n left -= range;\n fixedMin = navigator.getUnionExtremes().dataMin;\n }\n else {\n // #2293, #3543\n fixedMax = navigator.getUnionExtremes().dataMax;\n }\n }\n if (left !== zoomedMin) { // it has actually moved\n navigator.fixedWidth = range; // #1370\n ext = xAxis.navigatorAxis.toFixedRange(left, left + range, fixedMin, fixedMax);\n if (defined(ext.min)) { // #7411\n chart.xAxis[0].setExtremes(Math.min(ext.min, ext.max), Math.max(ext.min, ext.max), true, null, // auto animation\n { trigger: 'navigator' });\n }\n }\n }\n }\n /**\n * Mousedown on a handle mask.\n * Will store necessary information for drag&drop.\n *\n * @private\n * @function Highcharts.Navigator#handlesMousedown\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n * @param {number} index\n * Index of a handle in Navigator.handles array\n */\n handlesMousedown(e, index) {\n e = this.chart.pointer.normalize(e);\n const navigator = this, chart = navigator.chart, baseXAxis = chart.xAxis[0], \n // For reversed axes, min and max are changed,\n // so the other extreme should be stored\n reverse = navigator.reversedExtremes;\n if (index === 0) {\n // Grab the left handle\n navigator.grabbedLeft = true;\n navigator.otherHandlePos = navigator.zoomedMax;\n navigator.fixedExtreme = reverse ? baseXAxis.min : baseXAxis.max;\n }\n else {\n // Grab the right handle\n navigator.grabbedRight = true;\n navigator.otherHandlePos = navigator.zoomedMin;\n navigator.fixedExtreme = reverse ? baseXAxis.max : baseXAxis.min;\n }\n chart.fixedRange = null;\n }\n /**\n * Mouse move event based on x/y mouse position.\n *\n * @private\n * @function Highcharts.Navigator#onMouseMove\n *\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n */\n onMouseMove(e) {\n const navigator = this, chart = navigator.chart, navigatorSize = navigator.navigatorSize, range = navigator.range, dragOffset = navigator.dragOffset, inverted = chart.inverted;\n let left = navigator.left, chartX;\n // In iOS, a mousemove event with e.pageX === 0 is fired when holding\n // the finger down in the center of the scrollbar. This should be\n // ignored.\n if (!e.touches || e.touches[0].pageX !== 0) { // #4696\n e = chart.pointer.normalize(e);\n chartX = e.chartX;\n // Swap some options for inverted chart\n if (inverted) {\n left = navigator.top;\n chartX = e.chartY;\n }\n // Drag left handle or top handle\n if (navigator.grabbedLeft) {\n navigator.hasDragged = true;\n navigator.render(0, 0, chartX - left, navigator.otherHandlePos);\n // Drag right handle or bottom handle\n }\n else if (navigator.grabbedRight) {\n navigator.hasDragged = true;\n navigator.render(0, 0, navigator.otherHandlePos, chartX - left);\n // Drag scrollbar or open area in navigator\n }\n else if (navigator.grabbedCenter) {\n navigator.hasDragged = true;\n if (chartX < dragOffset) { // outside left\n chartX = dragOffset;\n // outside right\n }\n else if (chartX >\n navigatorSize + dragOffset - range) {\n chartX = navigatorSize + dragOffset - range;\n }\n navigator.render(0, 0, chartX - dragOffset, chartX - dragOffset + range);\n }\n if (navigator.hasDragged &&\n navigator.scrollbar &&\n pick(navigator.scrollbar.options.liveRedraw, \n // By default, don't run live redraw on touch\n // devices or if the chart is in boost.\n !isTouchDevice &&\n !this.chart.boosted)) {\n e.DOMType = e.type;\n setTimeout(function () {\n navigator.onMouseUp(e);\n }, 0);\n }\n }\n }\n /**\n * Mouse up event based on x/y mouse position.\n *\n * @private\n * @function Highcharts.Navigator#onMouseUp\n * @param {Highcharts.PointerEventObject} e\n * Mouse event\n */\n onMouseUp(e) {\n const navigator = this, chart = navigator.chart, xAxis = navigator.xAxis, scrollbar = navigator.scrollbar, DOMEvent = e.DOMEvent || e, inverted = chart.inverted, verb = navigator.rendered && !navigator.hasDragged ?\n 'animate' : 'attr';\n let zoomedMax, zoomedMin, unionExtremes, fixedMin, fixedMax, ext;\n if (\n // MouseUp is called for both, navigator and scrollbar (that order),\n // which causes calling afterSetExtremes twice. Prevent first call\n // by checking if scrollbar is going to set new extremes (#6334)\n (navigator.hasDragged && (!scrollbar || !scrollbar.hasDragged)) ||\n e.trigger === 'scrollbar') {\n unionExtremes = navigator.getUnionExtremes();\n // When dragging one handle, make sure the other one doesn't change\n if (navigator.zoomedMin === navigator.otherHandlePos) {\n fixedMin = navigator.fixedExtreme;\n }\n else if (navigator.zoomedMax === navigator.otherHandlePos) {\n fixedMax = navigator.fixedExtreme;\n }\n // Snap to right edge (#4076)\n if (navigator.zoomedMax === navigator.size) {\n fixedMax = navigator.reversedExtremes ?\n unionExtremes.dataMin :\n unionExtremes.dataMax;\n }\n // Snap to left edge (#7576)\n if (navigator.zoomedMin === 0) {\n fixedMin = navigator.reversedExtremes ?\n unionExtremes.dataMax :\n unionExtremes.dataMin;\n }\n ext = xAxis.navigatorAxis.toFixedRange(navigator.zoomedMin, navigator.zoomedMax, fixedMin, fixedMax);\n if (defined(ext.min)) {\n chart.xAxis[0].setExtremes(Math.min(ext.min, ext.max), Math.max(ext.min, ext.max), true, \n // Run animation when clicking buttons, scrollbar track etc,\n // but not when dragging handles or scrollbar\n navigator.hasDragged ? false : null, {\n trigger: 'navigator',\n triggerOp: 'navigator-drag',\n DOMEvent: DOMEvent // #1838\n });\n }\n }\n if (e.DOMType !== 'mousemove' &&\n e.DOMType !== 'touchmove') {\n navigator.grabbedLeft = navigator.grabbedRight =\n navigator.grabbedCenter = navigator.fixedWidth =\n navigator.fixedExtreme = navigator.otherHandlePos =\n navigator.hasDragged = navigator.dragOffset = null;\n }\n // Update position of navigator shades, outline and handles (#12573)\n if (navigator.navigatorEnabled &&\n isNumber(navigator.zoomedMin) &&\n isNumber(navigator.zoomedMax)) {\n zoomedMin = Math.round(navigator.zoomedMin);\n zoomedMax = Math.round(navigator.zoomedMax);\n if (navigator.shades) {\n navigator.drawMasks(zoomedMin, zoomedMax, inverted, verb);\n }\n if (navigator.outline) {\n navigator.drawOutline(zoomedMin, zoomedMax, inverted, verb);\n }\n if (navigator.navigatorOptions.handles.enabled &&\n Object.keys(navigator.handles).length ===\n navigator.handles.length) {\n navigator.drawHandle(zoomedMin, 0, inverted, verb);\n navigator.drawHandle(zoomedMax, 1, inverted, verb);\n }\n }\n }\n /**\n * Removes the event handlers attached previously with addEvents.\n *\n * @private\n * @function Highcharts.Navigator#removeEvents\n */\n removeEvents() {\n if (this.eventsToUnbind) {\n this.eventsToUnbind.forEach(function (unbind) {\n unbind();\n });\n this.eventsToUnbind = void 0;\n }\n this.removeBaseSeriesEvents();\n }\n /**\n * Remove data events.\n *\n * @private\n * @function Highcharts.Navigator#removeBaseSeriesEvents\n */\n removeBaseSeriesEvents() {\n const baseSeries = this.baseSeries || [];\n if (this.navigatorEnabled && baseSeries[0]) {\n if (this.navigatorOptions.adaptToUpdatedData !== false) {\n baseSeries.forEach(function (series) {\n removeEvent(series, 'updatedData', this.updatedDataHandler);\n }, this);\n }\n // We only listen for extremes-events on the first baseSeries\n if (baseSeries[0].xAxis) {\n removeEvent(baseSeries[0].xAxis, 'foundExtremes', this.modifyBaseAxisExtremes);\n }\n }\n }\n /**\n * Initialize the Navigator object\n *\n * @private\n * @function Highcharts.Navigator#init\n */\n init(chart) {\n const chartOptions = chart.options, navigatorOptions = chartOptions.navigator || {}, navigatorEnabled = navigatorOptions.enabled, scrollbarOptions = chartOptions.scrollbar || {}, scrollbarEnabled = scrollbarOptions.enabled, height = navigatorEnabled && navigatorOptions.height || 0, scrollbarHeight = scrollbarEnabled && scrollbarOptions.height || 0, scrollButtonSize = scrollbarOptions.buttonsEnabled && scrollbarHeight || 0;\n this.handles = [];\n this.shades = [];\n this.chart = chart;\n this.setBaseSeries();\n this.height = height;\n this.scrollbarHeight = scrollbarHeight;\n this.scrollButtonSize = scrollButtonSize;\n this.scrollbarEnabled = scrollbarEnabled;\n this.navigatorEnabled = navigatorEnabled;\n this.navigatorOptions = navigatorOptions;\n this.scrollbarOptions = scrollbarOptions;\n this.opposite = pick(navigatorOptions.opposite, Boolean(!navigatorEnabled && chart.inverted)); // #6262\n const navigator = this, baseSeries = navigator.baseSeries, xAxisIndex = chart.xAxis.length, yAxisIndex = chart.yAxis.length, baseXaxis = baseSeries && baseSeries[0] && baseSeries[0].xAxis ||\n chart.xAxis[0] || { options: {} };\n chart.isDirtyBox = true;\n if (navigator.navigatorEnabled) {\n // an x axis is required for scrollbar also\n navigator.xAxis = new Axis(chart, merge({\n // inherit base xAxis' break and ordinal options\n breaks: baseXaxis.options.breaks,\n ordinal: baseXaxis.options.ordinal\n }, navigatorOptions.xAxis, {\n id: 'navigator-x-axis',\n yAxis: 'navigator-y-axis',\n type: 'datetime',\n index: xAxisIndex,\n isInternal: true,\n offset: 0,\n keepOrdinalPadding: true,\n startOnTick: false,\n endOnTick: false,\n minPadding: 0,\n maxPadding: 0,\n zoomEnabled: false\n }, chart.inverted ? {\n offsets: [scrollButtonSize, 0, -scrollButtonSize, 0],\n width: height\n } : {\n offsets: [0, -scrollButtonSize, 0, scrollButtonSize],\n height: height\n }), 'xAxis');\n navigator.yAxis = new Axis(chart, merge(navigatorOptions.yAxis, {\n id: 'navigator-y-axis',\n alignTicks: false,\n offset: 0,\n index: yAxisIndex,\n isInternal: true,\n reversed: pick((navigatorOptions.yAxis &&\n navigatorOptions.yAxis.reversed), (chart.yAxis[0] && chart.yAxis[0].reversed), false),\n zoomEnabled: false\n }, chart.inverted ? {\n width: height\n } : {\n height: height\n }), 'yAxis');\n // If we have a base series, initialize the navigator series\n if (baseSeries || navigatorOptions.series.data) {\n navigator.updateNavigatorSeries(false);\n // If not, set up an event to listen for added series\n }\n else if (chart.series.length === 0) {\n navigator.unbindRedraw = addEvent(chart, 'beforeRedraw', function () {\n // We've got one, now add it as base\n if (chart.series.length > 0 && !navigator.series) {\n navigator.setBaseSeries();\n navigator.unbindRedraw(); // reset\n }\n });\n }\n navigator.reversedExtremes = (chart.inverted && !navigator.xAxis.reversed) || (!chart.inverted && navigator.xAxis.reversed);\n // Render items, so we can bind events to them:\n navigator.renderElements();\n // Add mouse events\n navigator.addMouseEvents();\n // in case of scrollbar only, fake an x axis to get translation\n }\n else {\n navigator.xAxis = {\n chart,\n navigatorAxis: {\n fake: true\n },\n translate: function (value, reverse) {\n const axis = chart.xAxis[0], ext = axis.getExtremes(), scrollTrackWidth = axis.len - 2 * scrollButtonSize, min = numExt('min', axis.options.min, ext.dataMin), valueRange = numExt('max', axis.options.max, ext.dataMax) - min;\n return reverse ?\n // from pixel to value\n (value * valueRange / scrollTrackWidth) + min :\n // from value to pixel\n scrollTrackWidth * (value - min) / valueRange;\n },\n toPixels: function (value) {\n return this.translate(value);\n },\n toValue: function (value) {\n return this.translate(value, true);\n }\n };\n navigator.xAxis.navigatorAxis.axis = navigator.xAxis;\n navigator.xAxis.navigatorAxis.toFixedRange = (NavigatorAxisAdditions.prototype.toFixedRange.bind(navigator.xAxis.navigatorAxis));\n }\n // Initialize the scrollbar\n if (chart.options.scrollbar.enabled) {\n const options = merge(chart.options.scrollbar, { vertical: chart.inverted });\n if (!isNumber(options.margin) && navigator.navigatorEnabled) {\n options.margin = chart.inverted ? -3 : 3;\n }\n chart.scrollbar = navigator.scrollbar = new Scrollbar(chart.renderer, options, chart);\n addEvent(navigator.scrollbar, 'changed', function (e) {\n const range = navigator.size, to = range * this.to, from = range * this.from;\n navigator.hasDragged = navigator.scrollbar.hasDragged;\n navigator.render(0, 0, from, to);\n if (this.shouldUpdateExtremes(e.DOMType)) {\n setTimeout(function () {\n navigator.onMouseUp(e);\n });\n }\n });\n }\n // Add data events\n navigator.addBaseSeriesEvents();\n // Add redraw events\n navigator.addChartEvents();\n }\n /**\n * Get the union data extremes of the chart - the outer data extremes of the\n * base X axis and the navigator axis.\n *\n * @private\n * @function Highcharts.Navigator#getUnionExtremes\n */\n getUnionExtremes(returnFalseOnNoBaseSeries) {\n const baseAxis = this.chart.xAxis[0], navAxis = this.xAxis, navAxisOptions = navAxis.options, baseAxisOptions = baseAxis.options;\n let ret;\n if (!returnFalseOnNoBaseSeries || baseAxis.dataMin !== null) {\n ret = {\n dataMin: pick(// #4053\n navAxisOptions && navAxisOptions.min, numExt('min', baseAxisOptions.min, baseAxis.dataMin, navAxis.dataMin, navAxis.min)),\n dataMax: pick(navAxisOptions && navAxisOptions.max, numExt('max', baseAxisOptions.max, baseAxis.dataMax, navAxis.dataMax, navAxis.max))\n };\n }\n return ret;\n }\n /**\n * Set the base series and update the navigator series from this. With a bit\n * of modification we should be able to make this an API method to be called\n * from the outside\n *\n * @private\n * @function Highcharts.Navigator#setBaseSeries\n * @param {Highcharts.SeriesOptionsType} [baseSeriesOptions]\n * Additional series options for a navigator\n * @param {boolean} [redraw]\n * Whether to redraw after update.\n */\n setBaseSeries(baseSeriesOptions, redraw) {\n const chart = this.chart, baseSeries = this.baseSeries = [];\n baseSeriesOptions = (baseSeriesOptions ||\n chart.options && chart.options.navigator.baseSeries ||\n (chart.series.length ?\n // Find the first non-navigator series (#8430)\n find(chart.series, (s) => (!s.options.isInternal)).index :\n 0));\n // Iterate through series and add the ones that should be shown in\n // navigator.\n (chart.series || []).forEach((series, i) => {\n if (\n // Don't include existing nav series\n !series.options.isInternal &&\n (series.options.showInNavigator ||\n (i === baseSeriesOptions ||\n series.options.id === baseSeriesOptions) &&\n series.options.showInNavigator !== false)) {\n baseSeries.push(series);\n }\n });\n // When run after render, this.xAxis already exists\n if (this.xAxis && !this.xAxis.navigatorAxis.fake) {\n this.updateNavigatorSeries(true, redraw);\n }\n }\n /**\n * Update series in the navigator from baseSeries, adding new if does not\n * exist.\n *\n * @private\n * @function Highcharts.Navigator.updateNavigatorSeries\n */\n updateNavigatorSeries(addEvents, redraw) {\n const navigator = this, chart = navigator.chart, baseSeries = navigator.baseSeries, navSeriesMixin = {\n enableMouseTracking: false,\n index: null,\n linkedTo: null,\n group: 'nav',\n padXAxis: false,\n xAxis: 'navigator-x-axis',\n yAxis: 'navigator-y-axis',\n showInLegend: false,\n stacking: void 0,\n isInternal: true,\n states: {\n inactive: {\n opacity: 1\n }\n }\n }, \n // Remove navigator series that are no longer in the baseSeries\n navigatorSeries = navigator.series =\n (navigator.series || []).filter((navSeries) => {\n const base = navSeries.baseSeries;\n if (baseSeries.indexOf(base) < 0) { // Not in array\n // If there is still a base series connected to this\n // series, remove event handler and reference.\n if (base) {\n removeEvent(base, 'updatedData', navigator.updatedDataHandler);\n delete base.navigatorSeries;\n }\n // Kill the nav series. It may already have been\n // destroyed (#8715).\n if (navSeries.chart) {\n navSeries.destroy();\n }\n return false;\n }\n return true;\n });\n let baseOptions, mergedNavSeriesOptions, chartNavigatorSeriesOptions = navigator.navigatorOptions.series, baseNavigatorOptions;\n // Go through each base series and merge the options to create new\n // series\n if (baseSeries && baseSeries.length) {\n baseSeries.forEach((base) => {\n const linkedNavSeries = base.navigatorSeries, userNavOptions = extend(\n // Grab color and visibility from base as default\n {\n color: base.color,\n visible: base.visible\n }, !isArray(chartNavigatorSeriesOptions) ?\n chartNavigatorSeriesOptions :\n defaultOptions.navigator.series);\n // Don't update if the series exists in nav and we have disabled\n // adaptToUpdatedData.\n if (linkedNavSeries &&\n navigator.navigatorOptions.adaptToUpdatedData === false) {\n return;\n }\n navSeriesMixin.name = 'Navigator ' + baseSeries.length;\n baseOptions = base.options || {};\n baseNavigatorOptions = baseOptions.navigatorOptions || {};\n // The dataLabels options are not merged correctly\n // if the settings are an array, #13847.\n userNavOptions.dataLabels = splat(userNavOptions.dataLabels);\n mergedNavSeriesOptions = merge(baseOptions, navSeriesMixin, userNavOptions, baseNavigatorOptions);\n // Once nav series type is resolved, pick correct pointRange\n mergedNavSeriesOptions.pointRange = pick(\n // Stricte set pointRange in options\n userNavOptions.pointRange, baseNavigatorOptions.pointRange, \n // Fallback to default values, e.g. `null` for column\n defaultOptions.plotOptions[mergedNavSeriesOptions.type || 'line'].pointRange);\n // Merge data separately. Do a slice to avoid mutating the\n // navigator options from base series (#4923).\n const navigatorSeriesData = baseNavigatorOptions.data || userNavOptions.data;\n navigator.hasNavigatorData =\n navigator.hasNavigatorData || !!navigatorSeriesData;\n mergedNavSeriesOptions.data =\n navigatorSeriesData ||\n baseOptions.data && baseOptions.data.slice(0);\n // Update or add the series\n if (linkedNavSeries && linkedNavSeries.options) {\n linkedNavSeries.update(mergedNavSeriesOptions, redraw);\n }\n else {\n base.navigatorSeries = chart.initSeries(mergedNavSeriesOptions);\n base.navigatorSeries.baseSeries = base; // Store ref\n navigatorSeries.push(base.navigatorSeries);\n }\n });\n }\n // If user has defined data (and no base series) or explicitly defined\n // navigator.series as an array, we create these series on top of any\n // base series.\n if (chartNavigatorSeriesOptions.data &&\n !(baseSeries && baseSeries.length) ||\n isArray(chartNavigatorSeriesOptions)) {\n navigator.hasNavigatorData = false;\n // Allow navigator.series to be an array\n chartNavigatorSeriesOptions =\n splat(chartNavigatorSeriesOptions);\n chartNavigatorSeriesOptions.forEach((userSeriesOptions, i) => {\n navSeriesMixin.name =\n 'Navigator ' + (navigatorSeries.length + 1);\n mergedNavSeriesOptions = merge(defaultOptions.navigator.series, {\n // Since we don't have a base series to pull color from,\n // try to fake it by using color from series with same\n // index. Otherwise pull from the colors array. We need\n // an explicit color as otherwise updates will increment\n // color counter and we'll get a new color for each\n // update of the nav series.\n color: chart.series[i] &&\n !chart.series[i].options.isInternal &&\n chart.series[i].color ||\n chart.options.colors[i] ||\n chart.options.colors[0]\n }, navSeriesMixin, userSeriesOptions);\n mergedNavSeriesOptions.data = userSeriesOptions.data;\n if (mergedNavSeriesOptions.data) {\n navigator.hasNavigatorData = true;\n navigatorSeries.push(chart.initSeries(mergedNavSeriesOptions));\n }\n });\n }\n if (addEvents) {\n this.addBaseSeriesEvents();\n }\n }\n /**\n * Add data events.\n * For example when main series is updated we need to recalculate extremes\n *\n * @private\n * @function Highcharts.Navigator#addBaseSeriesEvent\n */\n addBaseSeriesEvents() {\n const navigator = this, baseSeries = navigator.baseSeries || [];\n // Bind modified extremes event to first base's xAxis only.\n // In event of > 1 base-xAxes, the navigator will ignore those.\n // Adding this multiple times to the same axis is no problem, as\n // duplicates should be discarded by the browser.\n if (baseSeries[0] && baseSeries[0].xAxis) {\n baseSeries[0].eventsToUnbind.push(addEvent(baseSeries[0].xAxis, 'foundExtremes', this.modifyBaseAxisExtremes));\n }\n baseSeries.forEach((base) => {\n // Link base series show/hide to navigator series visibility\n base.eventsToUnbind.push(addEvent(base, 'show', function () {\n if (this.navigatorSeries) {\n this.navigatorSeries.setVisible(true, false);\n }\n }));\n base.eventsToUnbind.push(addEvent(base, 'hide', function () {\n if (this.navigatorSeries) {\n this.navigatorSeries.setVisible(false, false);\n }\n }));\n // Respond to updated data in the base series, unless explicitily\n // not adapting to data changes.\n if (this.navigatorOptions.adaptToUpdatedData !== false) {\n if (base.xAxis) {\n base.eventsToUnbind.push(addEvent(base, 'updatedData', this.updatedDataHandler));\n }\n }\n // Handle series removal\n base.eventsToUnbind.push(addEvent(base, 'remove', function () {\n if (this.navigatorSeries) {\n erase(navigator.series, this.navigatorSeries);\n if (defined(this.navigatorSeries.options)) {\n this.navigatorSeries.remove(false);\n }\n delete this.navigatorSeries;\n }\n }));\n });\n }\n /**\n * Get minimum from all base series connected to the navigator\n * @private\n * @param {number} currentSeriesMin\n * Minium from the current series\n * @return {number}\n * Minimum from all series\n */\n getBaseSeriesMin(currentSeriesMin) {\n return this.baseSeries.reduce(function (min, series) {\n // (#10193)\n return Math.min(min, series.xData && series.xData.length ?\n series.xData[0] : min);\n }, currentSeriesMin);\n }\n /**\n * Set the navigator x axis extremes to reflect the total. The navigator\n * extremes should always be the extremes of the union of all series in the\n * chart as well as the navigator series.\n *\n * @private\n * @function Highcharts.Navigator#modifyNavigatorAxisExtremes\n */\n modifyNavigatorAxisExtremes() {\n const xAxis = this.xAxis;\n if (typeof xAxis.getExtremes !== 'undefined') {\n const unionExtremes = this.getUnionExtremes(true);\n if (unionExtremes &&\n (unionExtremes.dataMin !== xAxis.min ||\n unionExtremes.dataMax !== xAxis.max)) {\n xAxis.min = unionExtremes.dataMin;\n xAxis.max = unionExtremes.dataMax;\n }\n }\n }\n /**\n * Hook to modify the base axis extremes with information from the Navigator\n *\n * @private\n * @function Highcharts.Navigator#modifyBaseAxisExtremes\n */\n modifyBaseAxisExtremes() {\n const baseXAxis = this, navigator = baseXAxis.chart.navigator, baseExtremes = baseXAxis.getExtremes(), baseMin = baseExtremes.min, baseMax = baseExtremes.max, baseDataMin = baseExtremes.dataMin, baseDataMax = baseExtremes.dataMax, range = baseMax - baseMin, stickToMin = navigator.stickToMin, stickToMax = navigator.stickToMax, overscroll = pick(baseXAxis.options.overscroll, 0), navigatorSeries = navigator.series && navigator.series[0], hasSetExtremes = !!baseXAxis.setExtremes, \n // When the extremes have been set by range selector button, don't\n // stick to min or max. The range selector buttons will handle the\n // extremes. (#5489)\n unmutable = baseXAxis.eventArgs &&\n baseXAxis.eventArgs.trigger === 'rangeSelectorButton';\n let newMax, newMin;\n if (!unmutable) {\n // If the zoomed range is already at the min, move it to the right\n // as new data comes in\n if (stickToMin) {\n newMin = baseDataMin;\n newMax = newMin + range;\n }\n // If the zoomed range is already at the max, move it to the right\n // as new data comes in\n if (stickToMax) {\n newMax = baseDataMax + overscroll;\n // If stickToMin is true, the new min value is set above\n if (!stickToMin) {\n newMin = Math.max(baseDataMin, // don't go below data extremes (#13184)\n newMax - range, navigator.getBaseSeriesMin(navigatorSeries && navigatorSeries.xData ?\n navigatorSeries.xData[0] :\n -Number.MAX_VALUE));\n }\n }\n // Update the extremes\n if (hasSetExtremes && (stickToMin || stickToMax)) {\n if (isNumber(newMin)) {\n baseXAxis.min = baseXAxis.userMin = newMin;\n baseXAxis.max = baseXAxis.userMax = newMax;\n }\n }\n }\n // Reset\n navigator.stickToMin =\n navigator.stickToMax = null;\n }\n /**\n * Handler for updated data on the base series. When data is modified, the\n * navigator series must reflect it. This is called from the Chart.redraw\n * function before axis and series extremes are computed.\n *\n * @private\n * @function Highcharts.Navigator#updateDataHandler\n */\n updatedDataHandler() {\n const navigator = this.chart.navigator, baseSeries = this, navigatorSeries = this.navigatorSeries, shouldStickToMax = navigator.reversedExtremes ?\n Math.round(navigator.zoomedMin) === 0 :\n Math.round(navigator.zoomedMax) >= Math.round(navigator.size);\n // If the scrollbar is scrolled all the way to the right, keep right as\n // new data comes in, unless user set navigator.stickToMax to false.\n navigator.stickToMax = pick(this.chart.options.navigator &&\n this.chart.options.navigator.stickToMax, shouldStickToMax);\n navigator.stickToMin = navigator.shouldStickToMin(baseSeries, navigator);\n // Set the navigator series data to the new data of the base series\n if (navigatorSeries && !navigator.hasNavigatorData) {\n navigatorSeries.options.pointStart = baseSeries.xData[0];\n navigatorSeries.setData(baseSeries.options.data, false, null, false); // #5414\n }\n }\n /**\n * Detect if the zoomed area should stick to the minimum, #14742.\n *\n * @private\n * @function Highcharts.Navigator#shouldStickToMin\n */\n shouldStickToMin(baseSeries, navigator) {\n const xDataMin = navigator.getBaseSeriesMin(baseSeries.xData[0]), xAxis = baseSeries.xAxis, max = xAxis.max, min = xAxis.min, range = xAxis.options.range;\n let stickToMin = true;\n if (isNumber(max) && isNumber(min)) {\n // If range declared, stick to the minimum only if the range\n // is smaller than the data set range.\n if (range && max - xDataMin > 0) {\n stickToMin = max - xDataMin < range;\n }\n else {\n // If the current axis minimum falls outside the new\n // updated dataset, we must adjust.\n stickToMin = min <= xDataMin;\n }\n }\n else {\n stickToMin = false; // #15864\n }\n return stickToMin;\n }\n /**\n * Add chart events, like redrawing navigator, when chart requires that.\n *\n * @private\n * @function Highcharts.Navigator#addChartEvents\n */\n addChartEvents() {\n if (!this.eventsToUnbind) {\n this.eventsToUnbind = [];\n }\n this.eventsToUnbind.push(\n // Move the scrollbar after redraw, like after data updata even if\n // axes don't redraw\n addEvent(this.chart, 'redraw', function () {\n const navigator = this.navigator, xAxis = navigator && (navigator.baseSeries &&\n navigator.baseSeries[0] &&\n navigator.baseSeries[0].xAxis ||\n this.xAxis[0]); // #5709, #13114\n if (xAxis) {\n navigator.render(xAxis.min, xAxis.max);\n }\n }), \n // Make room for the navigator, can be placed around the chart:\n addEvent(this.chart, 'getMargins', function () {\n let chart = this, navigator = chart.navigator, marginName = navigator.opposite ?\n 'plotTop' : 'marginBottom';\n if (chart.inverted) {\n marginName = navigator.opposite ?\n 'marginRight' : 'plotLeft';\n }\n chart[marginName] =\n (chart[marginName] || 0) + (navigator.navigatorEnabled || !chart.inverted ?\n navigator.height + navigator.scrollbarHeight :\n 0) + navigator.navigatorOptions.margin;\n }));\n }\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.Navigator#destroy\n */\n destroy() {\n // Disconnect events added in addEvents\n this.removeEvents();\n if (this.xAxis) {\n erase(this.chart.xAxis, this.xAxis);\n erase(this.chart.axes, this.xAxis);\n }\n if (this.yAxis) {\n erase(this.chart.yAxis, this.yAxis);\n erase(this.chart.axes, this.yAxis);\n }\n // Destroy series\n (this.series || []).forEach((s) => {\n if (s.destroy) {\n s.destroy();\n }\n });\n // Destroy properties\n [\n 'series', 'xAxis', 'yAxis', 'shades', 'outline', 'scrollbarTrack',\n 'scrollbarRifles', 'scrollbarGroup', 'scrollbar', 'navigatorGroup',\n 'rendered'\n ].forEach((prop) => {\n if (this[prop] && this[prop].destroy) {\n this[prop].destroy();\n }\n this[prop] = null;\n });\n // Destroy elements in collection\n [this.handles].forEach((coll) => {\n destroyObjectProperties(coll);\n });\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return Navigator;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelectorDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * Declarations\n *\n * */\n /**\n * Language object. The language object is global and it can't be set\n * on each chart initialization. Instead, use `Highcharts.setOptions` to\n * set it before any chart is initialized.\n *\n * ```js\n * Highcharts.setOptions({\n * lang: {\n * months: [\n * 'Janvier', 'Février', 'Mars', 'Avril',\n * 'Mai', 'Juin', 'Juillet', 'Août',\n * 'Septembre', 'Octobre', 'Novembre', 'Décembre'\n * ],\n * weekdays: [\n * 'Dimanche', 'Lundi', 'Mardi', 'Mercredi',\n * 'Jeudi', 'Vendredi', 'Samedi'\n * ]\n * }\n * });\n * ```\n *\n * @optionparent lang\n */\n const lang = {\n /**\n * The text for the label for the range selector buttons.\n *\n * @product highstock gantt\n */\n rangeSelectorZoom: 'Zoom',\n /**\n * The text for the label for the \"from\" input box in the range\n * selector. Since v9.0, this string is empty as the label is not\n * rendered by default.\n *\n * @product highstock gantt\n */\n rangeSelectorFrom: '',\n /**\n * The text for the label for the \"to\" input box in the range selector.\n *\n * @product highstock gantt\n */\n rangeSelectorTo: '→'\n };\n /**\n * The range selector is a tool for selecting ranges to display within\n * the chart. It provides buttons to select preconfigured ranges in\n * the chart, like 1 day, 1 week, 1 month etc. It also provides input\n * boxes where min and max dates can be manually input.\n *\n * @product highstock gantt\n * @optionparent rangeSelector\n */\n const rangeSelector = {\n /**\n * Whether to enable all buttons from the start. By default buttons are\n * only enabled if the corresponding time range exists on the X axis,\n * but enabling all buttons allows for dynamically loading different\n * time ranges.\n *\n * @sample {highstock} stock/rangeselector/allbuttonsenabled-true/\n * All buttons enabled\n *\n * @since 2.0.3\n */\n allButtonsEnabled: false,\n /**\n * An array of configuration objects for the buttons.\n *\n * Defaults to:\n * ```js\n * buttons: [{\n * type: 'month',\n * count: 1,\n * text: '1m',\n * title: 'View 1 month'\n * }, {\n * type: 'month',\n * count: 3,\n * text: '3m',\n * title: 'View 3 months'\n * }, {\n * type: 'month',\n * count: 6,\n * text: '6m',\n * title: 'View 6 months'\n * }, {\n * type: 'ytd',\n * text: 'YTD',\n * title: 'View year to date'\n * }, {\n * type: 'year',\n * count: 1,\n * text: '1y',\n * title: 'View 1 year'\n * }, {\n * type: 'all',\n * text: 'All',\n * title: 'View all'\n * }]\n * ```\n *\n * @sample {highstock} stock/rangeselector/datagrouping/\n * Data grouping by buttons\n *\n * @type {Array<*>}\n */\n buttons: void 0,\n /**\n * How many units of the defined type the button should span. If `type`\n * is \"month\" and `count` is 3, the button spans three months.\n *\n * @type {number}\n * @default 1\n * @apioption rangeSelector.buttons.count\n */\n /**\n * Fires when clicking on the rangeSelector button. One parameter,\n * event, is passed to the function, containing common event\n * information.\n *\n * ```js\n * click: function(e) {\n * console.log(this);\n * }\n * ```\n *\n * Return false to stop default button's click action.\n *\n * @sample {highstock} stock/rangeselector/button-click/\n * Click event on the button\n *\n * @type {Highcharts.RangeSelectorClickCallbackFunction}\n * @apioption rangeSelector.buttons.events.click\n */\n /**\n * Additional range (in milliseconds) added to the end of the calculated\n * time span.\n *\n * @sample {highstock} stock/rangeselector/min-max-offsets/\n * Button offsets\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @apioption rangeSelector.buttons.offsetMax\n */\n /**\n * Additional range (in milliseconds) added to the start of the\n * calculated time span.\n *\n * @sample {highstock} stock/rangeselector/min-max-offsets/\n * Button offsets\n *\n * @type {number}\n * @default 0\n * @since 6.0.0\n * @apioption rangeSelector.buttons.offsetMin\n */\n /**\n * When buttons apply dataGrouping on a series, by default zooming\n * in/out will deselect buttons and unset dataGrouping. Enable this\n * option to keep buttons selected when extremes change.\n *\n * @sample {highstock} stock/rangeselector/preserve-datagrouping/\n * Different preserveDataGrouping settings\n *\n * @type {boolean}\n * @default false\n * @since 6.1.2\n * @apioption rangeSelector.buttons.preserveDataGrouping\n */\n /**\n * A custom data grouping object for each button.\n *\n * @see [series.dataGrouping](#plotOptions.series.dataGrouping)\n *\n * @sample {highstock} stock/rangeselector/datagrouping/\n * Data grouping by range selector buttons\n *\n * @type {*}\n * @extends plotOptions.series.dataGrouping\n * @apioption rangeSelector.buttons.dataGrouping\n */\n /**\n * The text for the button itself.\n *\n * @type {string}\n * @apioption rangeSelector.buttons.text\n */\n /**\n * Explanation for the button, shown as a tooltip on hover, and used by\n * assistive technology.\n *\n * @type {string}\n * @apioption rangeSelector.buttons.title\n */\n /**\n * Defined the time span for the button. Can be one of `millisecond`,\n * `second`, `minute`, `hour`, `day`, `week`, `month`, `year`, `ytd`,\n * and `all`.\n *\n * @type {Highcharts.RangeSelectorButtonTypeValue}\n * @apioption rangeSelector.buttons.type\n */\n /**\n * The space in pixels between the buttons in the range selector.\n */\n buttonSpacing: 5,\n /**\n * Whether to collapse the range selector buttons into a dropdown when\n * there is not enough room to show everything in a single row, instead\n * of dividing the range selector into multiple rows.\n * Can be one of the following:\n * - `always`: Always collapse\n * - `responsive`: Only collapse when there is not enough room\n * - `never`: Never collapse\n *\n * @sample {highstock} stock/rangeselector/dropdown/\n * Dropdown option\n *\n * @validvalue [\"always\", \"responsive\", \"never\"]\n * @since 9.0.0\n */\n dropdown: 'responsive',\n /**\n * Enable or disable the range selector. Default to `true` for stock\n * charts, using the `stockChart` factory.\n *\n * @sample {highstock} stock/rangeselector/enabled/\n * Disable the range selector\n *\n * @type {boolean|undefined}\n * @default {highstock} true\n */\n enabled: void 0,\n /**\n * The vertical alignment of the rangeselector box. Allowed properties\n * are `top`, `middle`, `bottom`.\n *\n * @sample {highstock} stock/rangeselector/vertical-align-middle/\n * Middle\n * @sample {highstock} stock/rangeselector/vertical-align-bottom/\n * Bottom\n *\n * @type {Highcharts.VerticalAlignValue}\n * @since 6.0.0\n */\n verticalAlign: 'top',\n /**\n * A collection of attributes for the buttons. The object takes SVG\n * attributes like `fill`, `stroke`, `stroke-width`, as well as `style`,\n * a collection of CSS properties for the text.\n *\n * The object can also be extended with states, so you can set\n * presentational options for `hover`, `select` or `disabled` button\n * states.\n *\n * CSS styles for the text label.\n *\n * In styled mode, the buttons are styled by the\n * `.highcharts-range-selector-buttons .highcharts-button` rule with its\n * different states.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.SVGAttributes}\n */\n buttonTheme: {\n /** @ignore */\n width: 28,\n /** @ignore */\n height: 18,\n /** @ignore */\n padding: 2,\n /** @ignore */\n zIndex: 7 // #484, #852\n },\n /**\n * When the rangeselector is floating, the plot area does not reserve\n * space for it. This opens for positioning anywhere on the chart.\n *\n * @sample {highstock} stock/rangeselector/floating/\n * Placing the range selector between the plot area and the\n * navigator\n *\n * @since 6.0.0\n */\n floating: false,\n /**\n * The x offset of the range selector relative to its horizontal\n * alignment within `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @since 6.0.0\n */\n x: 0,\n /**\n * The y offset of the range selector relative to its horizontal\n * alignment within `chart.spacingLeft` and `chart.spacingRight`.\n *\n * @since 6.0.0\n */\n y: 0,\n /**\n * Deprecated. The height of the range selector. Currently it is\n * calculated dynamically.\n *\n * @deprecated\n * @type {number|undefined}\n * @since 2.1.9\n */\n height: void 0,\n /**\n * The border color of the date input boxes.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.ColorString}\n * @since 1.3.7\n */\n inputBoxBorderColor: 'none',\n /**\n * The pixel height of the date input boxes.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @since 1.3.7\n */\n inputBoxHeight: 17,\n /**\n * The pixel width of the date input boxes. When `undefined`, the width\n * is fitted to the rendered content.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {number|undefined}\n * @since 1.3.7\n */\n inputBoxWidth: void 0,\n /**\n * The date format in the input boxes when not selected for editing.\n * Defaults to `%e %b %Y`.\n *\n * This is used to determine which type of input to show,\n * `datetime-local`, `date` or `time` and falling back to `text` when\n * the browser does not support the input type or the format contains\n * milliseconds.\n *\n * @sample {highstock} stock/rangeselector/input-type/\n * Input types\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n */\n inputDateFormat: '%e %b %Y',\n /**\n * A custom callback function to parse values entered in the input boxes\n * and return a valid JavaScript time as milliseconds since 1970.\n * The first argument passed is a value to parse,\n * second is a boolean indicating use of the UTC time.\n *\n * This will only get called for inputs of type `text`. Since v8.2.3,\n * the input type is dynamically determined based on the granularity\n * of the `inputDateFormat` and the browser support.\n *\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n * @type {Highcharts.RangeSelectorParseCallbackFunction}\n * @since 1.3.3\n */\n inputDateParser: void 0,\n /**\n * The date format in the input boxes when they are selected for\n * editing. This must be a format that is recognized by JavaScript\n * Date.parse.\n *\n * This will only be used for inputs of type `text`. Since v8.2.3,\n * the input type is dynamically determined based on the granularity\n * of the `inputDateFormat` and the browser support.\n *\n * @sample {highstock} stock/rangeselector/input-format/\n * Milliseconds in the range selector\n *\n */\n inputEditDateFormat: '%Y-%m-%d',\n /**\n * Enable or disable the date input boxes.\n */\n inputEnabled: true,\n /**\n * Positioning for the input boxes. Allowed properties are `align`,\n * `x` and `y`.\n *\n * @since 1.2.4\n */\n inputPosition: {\n /**\n * The alignment of the input box. Allowed properties are `left`,\n * `center`, `right`.\n *\n * @sample {highstock} stock/rangeselector/input-button-position/\n * Alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 6.0.0\n */\n align: 'right',\n /**\n * X offset of the input row.\n */\n x: 0,\n /**\n * Y offset of the input row.\n */\n y: 0\n },\n /**\n * The space in pixels between the labels and the date input boxes in\n * the range selector.\n *\n * @since 9.0.0\n */\n inputSpacing: 5,\n /**\n * The index of the button to appear pre-selected.\n *\n * @type {number}\n */\n selected: void 0,\n /**\n * Positioning for the button row.\n *\n * @since 1.2.4\n */\n buttonPosition: {\n /**\n * The alignment of the input box. Allowed properties are `left`,\n * `center`, `right`.\n *\n * @sample {highstock} stock/rangeselector/input-button-position/\n * Alignment\n *\n * @type {Highcharts.AlignValue}\n * @since 6.0.0\n */\n align: 'left',\n /**\n * X offset of the button row.\n */\n x: 0,\n /**\n * Y offset of the button row.\n */\n y: 0\n },\n /**\n * CSS for the HTML inputs in the range selector.\n *\n * In styled mode, the inputs are styled by the\n * `.highcharts-range-input text` rule in SVG mode, and\n * `input.highcharts-range-selector` when active.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.CSSObject}\n * @apioption rangeSelector.inputStyle\n */\n inputStyle: {\n /** @ignore */\n color: \"#334eff\" /* Palette.highlightColor80 */,\n /** @ignore */\n cursor: 'pointer',\n /** @ignore */\n fontSize: '0.8em'\n },\n /**\n * CSS styles for the labels - the Zoom, From and To texts.\n *\n * In styled mode, the labels are styled by the\n * `.highcharts-range-label` class.\n *\n * @sample {highstock} stock/rangeselector/styling/\n * Styling the buttons and inputs\n *\n * @type {Highcharts.CSSObject}\n */\n labelStyle: {\n /** @ignore */\n color: \"#666666\" /* Palette.neutralColor60 */,\n /** @ignore */\n fontSize: '0.8em'\n }\n };\n /* *\n *\n * Default Export\n *\n * */\n const RangeSelectorDefaults = {\n lang,\n rangeSelector\n };\n\n return RangeSelectorDefaults;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelectorComposition.js', [_modules['Core/Defaults.js'], _modules['Stock/RangeSelector/RangeSelectorDefaults.js'], _modules['Core/Utilities.js']], function (D, RangeSelectorDefaults, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions, setOptions } = D;\n const { addEvent, defined, extend, find, isNumber, merge, pick } = U;\n /* *\n *\n * Constants\n *\n * */\n const chartDestroyEvents = [];\n const composedMembers = [];\n /* *\n *\n * Variables\n *\n * */\n let RangeSelectorConstructor;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the axis min value based on the range option and the current max. For\n * stock charts this is extended via the {@link RangeSelector} so that if the\n * selected range is a multiple of months or years, it is compensated for\n * various month lengths.\n *\n * @private\n * @function Highcharts.Axis#minFromRange\n * @return {number|undefined}\n * The new minimum value.\n */\n function axisMinFromRange() {\n const rangeOptions = this.range, type = rangeOptions.type, max = this.max, time = this.chart.time, \n // Get the true range from a start date\n getTrueRange = function (base, count) {\n const timeName = type === 'year' ?\n 'FullYear' : 'Month';\n const date = new time.Date(base);\n const basePeriod = time.get(timeName, date);\n time.set(timeName, date, basePeriod + count);\n if (basePeriod === time.get(timeName, date)) {\n time.set('Date', date, 0); // #6537\n }\n return date.getTime() - base;\n };\n let min, range;\n if (isNumber(rangeOptions)) {\n min = max - rangeOptions;\n range = rangeOptions;\n }\n else if (rangeOptions) {\n min = max + getTrueRange(max, -(rangeOptions.count || 1));\n // Let the fixedRange reflect initial settings (#5930)\n if (this.chart) {\n this.chart.fixedRange = max - min;\n }\n }\n const dataMin = pick(this.dataMin, Number.MIN_VALUE);\n if (!isNumber(min)) {\n min = dataMin;\n }\n if (min <= dataMin) {\n min = dataMin;\n if (typeof range === 'undefined') { // #4501\n range = getTrueRange(min, rangeOptions.count);\n }\n this.newMax = Math.min(min + range, pick(this.dataMax, Number.MAX_VALUE));\n }\n if (!isNumber(max)) {\n min = void 0;\n }\n else if (!isNumber(rangeOptions) &&\n rangeOptions &&\n rangeOptions._offsetMin) {\n min += rangeOptions._offsetMin;\n }\n return min;\n }\n /**\n * @private\n */\n function compose(AxisClass, ChartClass, RangeSelectorClass) {\n RangeSelectorConstructor = RangeSelectorClass;\n if (U.pushUnique(composedMembers, AxisClass)) {\n AxisClass.prototype.minFromRange = axisMinFromRange;\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'afterGetContainer', onChartAfterGetContainer);\n addEvent(ChartClass, 'beforeRender', onChartBeforeRender);\n addEvent(ChartClass, 'destroy', onChartDestroy);\n addEvent(ChartClass, 'getMargins', onChartGetMargins);\n addEvent(ChartClass, 'render', onChartRender);\n addEvent(ChartClass, 'update', onChartUpdate);\n const chartProto = ChartClass.prototype;\n chartProto.callbacks.push(onChartCallback);\n }\n if (U.pushUnique(composedMembers, setOptions)) {\n extend(defaultOptions, { rangeSelector: RangeSelectorDefaults.rangeSelector });\n extend(defaultOptions.lang, RangeSelectorDefaults.lang);\n }\n }\n /**\n * Initialize rangeselector for stock charts\n * @private\n */\n function onChartAfterGetContainer() {\n if (this.options.rangeSelector &&\n this.options.rangeSelector.enabled) {\n this.rangeSelector = new RangeSelectorConstructor(this);\n }\n }\n /**\n * @private\n */\n function onChartBeforeRender() {\n const chart = this, axes = chart.axes, rangeSelector = chart.rangeSelector;\n if (rangeSelector) {\n if (isNumber(rangeSelector.deferredYTDClick)) {\n rangeSelector.clickButton(rangeSelector.deferredYTDClick);\n delete rangeSelector.deferredYTDClick;\n }\n axes.forEach((axis) => {\n axis.updateNames();\n axis.setScale();\n });\n chart.getAxisMargins();\n rangeSelector.render();\n const verticalAlign = rangeSelector.options.verticalAlign;\n if (!rangeSelector.options.floating) {\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n }\n }\n /**\n * @private\n */\n function onChartCallback(chart) {\n let extremes, legend, alignTo, verticalAlign;\n const rangeSelector = chart.rangeSelector, redraw = () => {\n if (rangeSelector) {\n extremes = chart.xAxis[0].getExtremes();\n legend = chart.legend;\n verticalAlign = (rangeSelector &&\n rangeSelector.options.verticalAlign);\n if (isNumber(extremes.min)) {\n rangeSelector.render(extremes.min, extremes.max);\n }\n // Re-align the legend so that it's below the rangeselector\n if (legend.display &&\n verticalAlign === 'top' &&\n verticalAlign === legend.options.verticalAlign) {\n // Create a new alignment box for the legend.\n alignTo = merge(chart.spacingBox);\n if (legend.options.layout === 'vertical') {\n alignTo.y = chart.plotTop;\n }\n else {\n alignTo.y += rangeSelector.getHeight();\n }\n legend.group.placed = false; // Don't animate the alignment.\n legend.align(alignTo);\n }\n }\n };\n if (rangeSelector) {\n const events = find(chartDestroyEvents, (e) => e[0] === chart);\n if (!events) {\n chartDestroyEvents.push([chart, [\n // redraw the scroller on setExtremes\n addEvent(chart.xAxis[0], 'afterSetExtremes', function (e) {\n if (rangeSelector) {\n rangeSelector.render(e.min, e.max);\n }\n }),\n // redraw the scroller chart resize\n addEvent(chart, 'redraw', redraw)\n ]]);\n }\n // do it now\n redraw();\n }\n }\n /**\n * Remove resize/afterSetExtremes at chart destroy.\n * @private\n */\n function onChartDestroy() {\n for (let i = 0, iEnd = chartDestroyEvents.length; i < iEnd; ++i) {\n const events = chartDestroyEvents[i];\n if (events[0] === this) {\n events[1].forEach((unbind) => unbind());\n chartDestroyEvents.splice(i, 1);\n return;\n }\n }\n }\n function onChartGetMargins() {\n const rangeSelector = this.rangeSelector;\n if (rangeSelector) {\n const rangeSelectorHeight = rangeSelector.getHeight();\n if (this.extraTopMargin) {\n this.plotTop += rangeSelectorHeight;\n }\n if (this.extraBottomMargin) {\n this.marginBottom += rangeSelectorHeight;\n }\n }\n }\n /**\n * @private\n */\n function onChartRender() {\n const chart = this, rangeSelector = chart.rangeSelector;\n if (rangeSelector && !rangeSelector.options.floating) {\n rangeSelector.render();\n const verticalAlign = rangeSelector.options.verticalAlign;\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n }\n /**\n * @private\n */\n function onChartUpdate(e) {\n const chart = this, options = e.options, optionsRangeSelector = options.rangeSelector, extraBottomMarginWas = this.extraBottomMargin, extraTopMarginWas = this.extraTopMargin;\n let rangeSelector = chart.rangeSelector;\n if (optionsRangeSelector &&\n optionsRangeSelector.enabled &&\n !defined(rangeSelector) &&\n this.options.rangeSelector) {\n this.options.rangeSelector.enabled = true;\n this.rangeSelector = rangeSelector = new RangeSelectorConstructor(this);\n }\n this.extraBottomMargin = false;\n this.extraTopMargin = false;\n if (rangeSelector) {\n onChartCallback(this);\n const verticalAlign = (optionsRangeSelector &&\n optionsRangeSelector.verticalAlign) || (rangeSelector.options && rangeSelector.options.verticalAlign);\n if (!rangeSelector.options.floating) {\n if (verticalAlign === 'bottom') {\n this.extraBottomMargin = true;\n }\n else if (verticalAlign !== 'middle') {\n this.extraTopMargin = true;\n }\n }\n if (this.extraBottomMargin !== extraBottomMarginWas ||\n this.extraTopMargin !== extraTopMarginWas) {\n this.isDirtyBox = true;\n }\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n const RangeSelectorComposition = {\n compose\n };\n\n return RangeSelectorComposition;\n });\n _registerModule(_modules, 'Stock/RangeSelector/RangeSelector.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Defaults.js'], _modules['Core/Globals.js'], _modules['Stock/RangeSelector/RangeSelectorComposition.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (Axis, D, H, RangeSelectorComposition, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { addEvent, createElement, css, defined, destroyObjectProperties, discardElement, extend, fireEvent, isNumber, merge, objectEach, pad, pick, pInt, splat } = U;\n /* *\n *\n * Functions\n *\n * */\n /**\n * Get the preferred input type based on a date format string.\n *\n * @private\n * @function preferredInputType\n */\n function preferredInputType(format) {\n const ms = format.indexOf('%L') !== -1;\n if (ms) {\n return 'text';\n }\n const date = ['a', 'A', 'd', 'e', 'w', 'b', 'B', 'm', 'o', 'y', 'Y']\n .some((char) => format.indexOf('%' + char) !== -1);\n const time = ['H', 'k', 'I', 'l', 'M', 'S']\n .some((char) => format.indexOf('%' + char) !== -1);\n if (date && time) {\n return 'datetime-local';\n }\n if (date) {\n return 'date';\n }\n if (time) {\n return 'time';\n }\n return 'text';\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The range selector.\n *\n * @private\n * @class\n * @name Highcharts.RangeSelector\n * @param {Highcharts.Chart} chart\n */\n class RangeSelector {\n /* *\n *\n * Static Functions\n *\n * */\n /**\n * @private\n */\n static compose(AxisClass, ChartClass) {\n RangeSelectorComposition.compose(AxisClass, ChartClass, RangeSelector);\n }\n /* *\n *\n * Constructor\n *\n * */\n constructor(chart) {\n /* *\n *\n * Properties\n *\n * */\n this.buttons = void 0;\n this.buttonOptions = RangeSelector.prototype.defaultButtons;\n this.initialButtonGroupWidth = 0;\n this.options = void 0;\n this.chart = chart;\n this.init(chart);\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * The method to run when one of the buttons in the range selectors is\n * clicked\n *\n * @private\n * @function Highcharts.RangeSelector#clickButton\n * @param {number} i\n * The index of the button\n * @param {boolean} [redraw]\n */\n clickButton(i, redraw) {\n const rangeSelector = this, chart = rangeSelector.chart, rangeOptions = rangeSelector.buttonOptions[i], baseAxis = chart.xAxis[0], unionExtremes = (chart.scroller && chart.scroller.getUnionExtremes()) || baseAxis || {}, type = rangeOptions.type, dataGrouping = rangeOptions.dataGrouping;\n let dataMin = unionExtremes.dataMin, dataMax = unionExtremes.dataMax, newMin, newMax = baseAxis && Math.round(Math.min(baseAxis.max, pick(dataMax, baseAxis.max))), // #1568\n baseXAxisOptions, range = rangeOptions._range, rangeMin, minSetting, rangeSetting, ctx, ytdExtremes, addOffsetMin = true;\n // chart has no data, base series is removed\n if (dataMin === null || dataMax === null) {\n return;\n }\n // Set the fixed range before range is altered\n chart.fixedRange = range;\n rangeSelector.setSelected(i);\n // Apply dataGrouping associated to button\n if (dataGrouping) {\n this.forcedDataGrouping = true;\n Axis.prototype.setDataGrouping.call(baseAxis || { chart: this.chart }, dataGrouping, false);\n this.frozenStates = rangeOptions.preserveDataGrouping;\n }\n // Apply range\n if (type === 'month' || type === 'year') {\n if (!baseAxis) {\n // This is set to the user options and picked up later when the\n // axis is instantiated so that we know the min and max.\n range = rangeOptions;\n }\n else {\n ctx = {\n range: rangeOptions,\n max: newMax,\n chart: chart,\n dataMin: dataMin,\n dataMax: dataMax\n };\n newMin = baseAxis.minFromRange.call(ctx);\n if (isNumber(ctx.newMax)) {\n newMax = ctx.newMax;\n }\n // #15799: offsetMin is added in minFromRange so that it works\n // with pre-selected buttons as well\n addOffsetMin = false;\n }\n // Fixed times like minutes, hours, days\n }\n else if (range) {\n newMin = Math.max(newMax - range, dataMin);\n newMax = Math.min(newMin + range, dataMax);\n addOffsetMin = false;\n }\n else if (type === 'ytd') {\n // On user clicks on the buttons, or a delayed action running from\n // the beforeRender event (below), the baseAxis is defined.\n if (baseAxis) {\n // When \"ytd\" is the pre-selected button for the initial view,\n // its calculation is delayed and rerun in the beforeRender\n // event (below). When the series are initialized, but before\n // the chart is rendered, we have access to the xData array\n // (#942).\n if (typeof dataMax === 'undefined' ||\n typeof dataMin === 'undefined') {\n dataMin = Number.MAX_VALUE;\n dataMax = Number.MIN_VALUE;\n chart.series.forEach((series) => {\n // reassign it to the last item\n const xData = series.xData;\n if (xData) {\n dataMin = Math.min(xData[0], dataMin);\n dataMax = Math.max(xData[xData.length - 1], dataMax);\n }\n });\n redraw = false;\n }\n ytdExtremes = rangeSelector.getYTDExtremes(dataMax, dataMin, chart.time.useUTC);\n newMin = rangeMin = ytdExtremes.min;\n newMax = ytdExtremes.max;\n // \"ytd\" is pre-selected. We don't yet have access to processed\n // point and extremes data (things like pointStart and pointInterval\n // are missing), so we delay the process (#942)\n }\n else {\n rangeSelector.deferredYTDClick = i;\n return;\n }\n }\n else if (type === 'all' && baseAxis) {\n // If the navigator exist and the axis range is declared reset that\n // range and from now on only use the range set by a user, #14742.\n if (chart.navigator && chart.navigator.baseSeries[0]) {\n chart.navigator.baseSeries[0].xAxis.options.range = void 0;\n }\n newMin = dataMin;\n newMax = dataMax;\n }\n if (addOffsetMin && rangeOptions._offsetMin && defined(newMin)) {\n newMin += rangeOptions._offsetMin;\n }\n if (rangeOptions._offsetMax && defined(newMax)) {\n newMax += rangeOptions._offsetMax;\n }\n if (this.dropdown) {\n this.dropdown.selectedIndex = i + 1;\n }\n // Update the chart\n if (!baseAxis) {\n // Axis not yet instanciated. Temporarily set min and range\n // options and remove them on chart load (#4317).\n baseXAxisOptions = splat(chart.options.xAxis)[0];\n rangeSetting = baseXAxisOptions.range;\n baseXAxisOptions.range = range;\n minSetting = baseXAxisOptions.min;\n baseXAxisOptions.min = rangeMin;\n addEvent(chart, 'load', function resetMinAndRange() {\n baseXAxisOptions.range = rangeSetting;\n baseXAxisOptions.min = minSetting;\n });\n }\n else {\n // Existing axis object. Set extremes after render time.\n baseAxis.setExtremes(newMin, newMax, pick(redraw, true), void 0, // auto animation\n {\n trigger: 'rangeSelectorButton',\n rangeSelectorButton: rangeOptions\n });\n }\n fireEvent(this, 'afterBtnClick');\n }\n /**\n * Set the selected option. This method only sets the internal flag, it\n * doesn't update the buttons or the actual zoomed range.\n *\n * @private\n * @function Highcharts.RangeSelector#setSelected\n * @param {number} [selected]\n */\n setSelected(selected) {\n this.selected = this.options.selected = selected;\n }\n /**\n * Initialize the range selector\n *\n * @private\n * @function Highcharts.RangeSelector#init\n * @param {Highcharts.Chart} chart\n */\n init(chart) {\n const rangeSelector = this, options = chart.options.rangeSelector, buttonOptions = (options.buttons || rangeSelector.defaultButtons.slice()), selectedOption = options.selected, blurInputs = function () {\n const minInput = rangeSelector.minInput, maxInput = rangeSelector.maxInput;\n // #3274 in some case blur is not defined\n if (minInput && (minInput.blur)) {\n fireEvent(minInput, 'blur');\n }\n if (maxInput && (maxInput.blur)) {\n fireEvent(maxInput, 'blur');\n }\n };\n rangeSelector.chart = chart;\n rangeSelector.options = options;\n rangeSelector.buttons = [];\n rangeSelector.buttonOptions = buttonOptions;\n this.eventsToUnbind = [];\n this.eventsToUnbind.push(addEvent(chart.container, 'mousedown', blurInputs));\n this.eventsToUnbind.push(addEvent(chart, 'resize', blurInputs));\n // Extend the buttonOptions with actual range\n buttonOptions.forEach(rangeSelector.computeButtonRange);\n // zoomed range based on a pre-selected button index\n if (typeof selectedOption !== 'undefined' &&\n buttonOptions[selectedOption]) {\n this.clickButton(selectedOption, false);\n }\n this.eventsToUnbind.push(addEvent(chart, 'load', function () {\n // If a data grouping is applied to the current button, release it\n // when extremes change\n if (chart.xAxis && chart.xAxis[0]) {\n addEvent(chart.xAxis[0], 'setExtremes', function (e) {\n if (this.max - this.min !==\n chart.fixedRange &&\n e.trigger !== 'rangeSelectorButton' &&\n e.trigger !== 'updatedData' &&\n rangeSelector.forcedDataGrouping &&\n !rangeSelector.frozenStates) {\n this.setDataGrouping(false, false);\n }\n });\n }\n }));\n }\n /**\n * Dynamically update the range selector buttons after a new range has been\n * set\n *\n * @private\n * @function Highcharts.RangeSelector#updateButtonStates\n */\n updateButtonStates() {\n const rangeSelector = this, chart = this.chart, dropdown = this.dropdown, baseAxis = chart.xAxis[0], actualRange = Math.round(baseAxis.max - baseAxis.min), hasNoData = !baseAxis.hasVisibleSeries, day = 24 * 36e5, // A single day in milliseconds\n unionExtremes = (chart.scroller &&\n chart.scroller.getUnionExtremes()) || baseAxis, dataMin = unionExtremes.dataMin, dataMax = unionExtremes.dataMax, ytdExtremes = rangeSelector.getYTDExtremes(dataMax, dataMin, chart.time.useUTC), ytdMin = ytdExtremes.min, ytdMax = ytdExtremes.max, selected = rangeSelector.selected, allButtonsEnabled = rangeSelector.options.allButtonsEnabled, buttons = rangeSelector.buttons;\n let selectedExists = isNumber(selected);\n rangeSelector.buttonOptions.forEach((rangeOptions, i) => {\n const range = rangeOptions._range, type = rangeOptions.type, count = rangeOptions.count || 1, button = buttons[i], offsetRange = rangeOptions._offsetMax -\n rangeOptions._offsetMin, isSelected = i === selected, \n // Disable buttons where the range exceeds what is allowed in\n // the current view\n isTooGreatRange = range >\n dataMax - dataMin, \n // Disable buttons where the range is smaller than the minimum\n // range\n isTooSmallRange = range < baseAxis.minRange;\n let state = 0, \n // Do not select the YTD button if not explicitly told so\n isYTDButNotSelected = false, \n // Disable the All button if we're already showing all\n isAllButAlreadyShowingAll = false, isSameRange = range === actualRange;\n // Months and years have a variable range so we check the extremes\n if ((type === 'month' || type === 'year') &&\n (actualRange + 36e5 >=\n { month: 28, year: 365 }[type] * day * count - offsetRange) &&\n (actualRange - 36e5 <=\n { month: 31, year: 366 }[type] * day * count + offsetRange)) {\n isSameRange = true;\n }\n else if (type === 'ytd') {\n isSameRange = (ytdMax - ytdMin + offsetRange) === actualRange;\n isYTDButNotSelected = !isSelected;\n }\n else if (type === 'all') {\n isSameRange = (baseAxis.max - baseAxis.min >=\n dataMax - dataMin);\n isAllButAlreadyShowingAll = (!isSelected &&\n selectedExists &&\n isSameRange);\n }\n // The new zoom area happens to match the range for a button - mark\n // it selected. This happens when scrolling across an ordinal gap.\n // It can be seen in the intraday demos when selecting 1h and scroll\n // across the night gap.\n const disable = (!allButtonsEnabled &&\n (isTooGreatRange ||\n isTooSmallRange ||\n isAllButAlreadyShowingAll ||\n hasNoData));\n const select = ((isSelected && isSameRange) ||\n (isSameRange && !selectedExists && !isYTDButNotSelected) ||\n (isSelected && rangeSelector.frozenStates));\n if (disable) {\n state = 3;\n }\n else if (select) {\n selectedExists = true; // Only one button can be selected\n state = 2;\n }\n // If state has changed, update the button\n if (button.state !== state) {\n button.setState(state);\n if (dropdown) {\n dropdown.options[i + 1].disabled = disable;\n if (state === 2) {\n dropdown.selectedIndex = i + 1;\n }\n }\n // Reset (#9209)\n if (state === 0 && selected === i) {\n rangeSelector.setSelected();\n }\n }\n });\n }\n /**\n * Compute and cache the range for an individual button\n *\n * @private\n * @function Highcharts.RangeSelector#computeButtonRange\n * @param {Highcharts.RangeSelectorButtonsOptions} rangeOptions\n */\n computeButtonRange(rangeOptions) {\n const type = rangeOptions.type, count = rangeOptions.count || 1, \n // these time intervals have a fixed number of milliseconds, as\n // opposed to month, ytd and year\n fixedTimes = {\n millisecond: 1,\n second: 1000,\n minute: 60 * 1000,\n hour: 3600 * 1000,\n day: 24 * 3600 * 1000,\n week: 7 * 24 * 3600 * 1000\n };\n // Store the range on the button object\n if (fixedTimes[type]) {\n rangeOptions._range = fixedTimes[type] * count;\n }\n else if (type === 'month' || type === 'year') {\n rangeOptions._range = {\n month: 30,\n year: 365\n }[type] * 24 * 36e5 * count;\n }\n rangeOptions._offsetMin = pick(rangeOptions.offsetMin, 0);\n rangeOptions._offsetMax = pick(rangeOptions.offsetMax, 0);\n rangeOptions._range +=\n rangeOptions._offsetMax - rangeOptions._offsetMin;\n }\n /**\n * Get the unix timestamp of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#getInputValue\n */\n getInputValue(name) {\n const input = name === 'min' ? this.minInput : this.maxInput;\n const options = this.chart.options\n .rangeSelector;\n const time = this.chart.time;\n if (input) {\n return ((input.type === 'text' && options.inputDateParser) ||\n this.defaultInputDateParser)(input.value, time.useUTC, time);\n }\n return 0;\n }\n /**\n * Set the internal and displayed value of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#setInputValue\n */\n setInputValue(name, inputTime) {\n const options = this.options, time = this.chart.time, input = name === 'min' ? this.minInput : this.maxInput, dateBox = name === 'min' ? this.minDateBox : this.maxDateBox;\n if (input) {\n const hcTimeAttr = input.getAttribute('data-hc-time');\n let updatedTime = defined(hcTimeAttr) ? Number(hcTimeAttr) : void 0;\n if (defined(inputTime)) {\n const previousTime = updatedTime;\n if (defined(previousTime)) {\n input.setAttribute('data-hc-time-previous', previousTime);\n }\n input.setAttribute('data-hc-time', inputTime);\n updatedTime = inputTime;\n }\n input.value = time.dateFormat((this.inputTypeFormats[input.type] ||\n options.inputEditDateFormat), updatedTime);\n if (dateBox) {\n dateBox.attr({\n text: time.dateFormat(options.inputDateFormat, updatedTime)\n });\n }\n }\n }\n /**\n * Set the min and max value of a HTML input for the dates\n *\n * @private\n * @function Highcharts.RangeSelector#setInputExtremes\n */\n setInputExtremes(name, min, max) {\n const input = name === 'min' ? this.minInput : this.maxInput;\n if (input) {\n const format = this.inputTypeFormats[input.type];\n const time = this.chart.time;\n if (format) {\n const newMin = time.dateFormat(format, min);\n if (input.min !== newMin) {\n input.min = newMin;\n }\n const newMax = time.dateFormat(format, max);\n if (input.max !== newMax) {\n input.max = newMax;\n }\n }\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#showInput\n * @param {string} name\n */\n showInput(name) {\n const dateBox = name === 'min' ? this.minDateBox : this.maxDateBox;\n const input = name === 'min' ? this.minInput : this.maxInput;\n if (input && dateBox && this.inputGroup) {\n const isTextInput = input.type === 'text';\n const { translateX, translateY } = this.inputGroup;\n const { inputBoxWidth } = this.options;\n css(input, {\n width: isTextInput ?\n ((dateBox.width + (inputBoxWidth ? -2 : 20)) + 'px') :\n 'auto',\n height: (dateBox.height - 2) + 'px',\n border: '2px solid silver'\n });\n if (isTextInput && inputBoxWidth) {\n css(input, {\n left: (translateX + dateBox.x) + 'px',\n top: translateY + 'px'\n });\n // Inputs of types date, time or datetime-local should be centered\n // on top of the dateBox\n }\n else {\n css(input, {\n left: Math.min(Math.round(dateBox.x +\n translateX -\n (input.offsetWidth - dateBox.width) / 2), this.chart.chartWidth - input.offsetWidth) + 'px',\n top: (translateY - (input.offsetHeight - dateBox.height) / 2) + 'px'\n });\n }\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#hideInput\n * @param {string} name\n */\n hideInput(name) {\n const input = name === 'min' ? this.minInput : this.maxInput;\n if (input) {\n css(input, {\n top: '-9999em',\n border: 0,\n width: '1px',\n height: '1px'\n });\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#defaultInputDateParser\n */\n defaultInputDateParser(inputDate, useUTC, time) {\n const hasTimezone = (str) => str.length > 6 &&\n (str.lastIndexOf('-') === str.length - 6 ||\n str.lastIndexOf('+') === str.length - 6);\n let input = inputDate.split('/').join('-').split(' ').join('T');\n if (input.indexOf('T') === -1) {\n input += 'T00:00';\n }\n if (useUTC) {\n input += 'Z';\n }\n else if (H.isSafari && !hasTimezone(input)) {\n const offset = new Date(input).getTimezoneOffset() / 60;\n input += offset <= 0 ? `+${pad(-offset)}:00` : `-${pad(offset)}:00`;\n }\n let date = Date.parse(input);\n // If the value isn't parsed directly to a value by the\n // browser's Date.parse method, try\n // parsing it a different way\n if (!isNumber(date)) {\n const parts = inputDate.split('-');\n date = Date.UTC(pInt(parts[0]), pInt(parts[1]) - 1, pInt(parts[2]));\n }\n if (time && useUTC && isNumber(date)) {\n date += time.getTimezoneOffset(date);\n }\n return date;\n }\n /**\n * Draw either the 'from' or the 'to' HTML input box of the range selector\n *\n * @private\n * @function Highcharts.RangeSelector#drawInput\n */\n drawInput(name) {\n const { chart, div, inputGroup } = this;\n const rangeSelector = this, chartStyle = chart.renderer.style || {}, renderer = chart.renderer, options = chart.options.rangeSelector, lang = defaultOptions.lang, isMin = name === 'min';\n /**\n * @private\n */\n function updateExtremes() {\n const { maxInput, minInput } = rangeSelector, chartAxis = chart.xAxis[0], dataAxis = chart.scroller && chart.scroller.xAxis ?\n chart.scroller.xAxis :\n chartAxis, dataMin = dataAxis.dataMin, dataMax = dataAxis.dataMax;\n let value = rangeSelector.getInputValue(name);\n if (value !== Number(input.getAttribute('data-hc-time-previous')) &&\n isNumber(value)) {\n input.setAttribute('data-hc-time-previous', value);\n // Validate the extremes. If it goes beyound the data min or\n // max, use the actual data extreme (#2438).\n if (isMin && maxInput && isNumber(dataMin)) {\n if (value > Number(maxInput.getAttribute('data-hc-time'))) {\n value = void 0;\n }\n else if (value < dataMin) {\n value = dataMin;\n }\n }\n else if (minInput && isNumber(dataMax)) {\n if (value < Number(minInput.getAttribute('data-hc-time'))) {\n value = void 0;\n }\n else if (value > dataMax) {\n value = dataMax;\n }\n }\n // Set the extremes\n if (typeof value !== 'undefined') { // @todo typof undefined\n chartAxis.setExtremes(isMin ? value : chartAxis.min, isMin ? chartAxis.max : value, void 0, void 0, { trigger: 'rangeSelectorInput' });\n }\n }\n }\n // Create the text label\n const text = lang[isMin ? 'rangeSelectorFrom' : 'rangeSelectorTo'] || '';\n const label = renderer\n .label(text, 0)\n .addClass('highcharts-range-label')\n .attr({\n padding: text ? 2 : 0,\n height: text ? options.inputBoxHeight : 0\n })\n .add(inputGroup);\n // Create an SVG label that shows updated date ranges and and records\n // click events that bring in the HTML input.\n const dateBox = renderer\n .label('', 0)\n .addClass('highcharts-range-input')\n .attr({\n padding: 2,\n width: options.inputBoxWidth,\n height: options.inputBoxHeight,\n 'text-align': 'center'\n })\n .on('click', function () {\n // If it is already focused, the onfocus event doesn't fire\n // (#3713)\n rangeSelector.showInput(name);\n rangeSelector[name + 'Input'].focus();\n });\n if (!chart.styledMode) {\n dateBox.attr({\n stroke: options.inputBoxBorderColor,\n 'stroke-width': 1\n });\n }\n dateBox.add(inputGroup);\n // Create the HTML input element. This is rendered as 1x1 pixel then set\n // to the right size when focused.\n const input = createElement('input', {\n name: name,\n className: 'highcharts-range-selector'\n }, void 0, div);\n // #14788: Setting input.type to an unsupported type throws in IE, so\n // we need to use setAttribute instead\n input.setAttribute('type', preferredInputType(options.inputDateFormat || '%e %b %Y'));\n if (!chart.styledMode) {\n // Styles\n label.css(merge(chartStyle, options.labelStyle));\n dateBox.css(merge({\n color: \"#333333\" /* Palette.neutralColor80 */\n }, chartStyle, options.inputStyle));\n css(input, extend({\n position: 'absolute',\n border: 0,\n boxShadow: '0 0 15px rgba(0,0,0,0.3)',\n width: '1px',\n height: '1px',\n padding: 0,\n textAlign: 'center',\n fontSize: chartStyle.fontSize,\n fontFamily: chartStyle.fontFamily,\n top: '-9999em' // #4798\n }, options.inputStyle));\n }\n // Blow up the input box\n input.onfocus = () => {\n rangeSelector.showInput(name);\n };\n // Hide away the input box\n input.onblur = () => {\n // update extermes only when inputs are active\n if (input === H.doc.activeElement) { // Only when focused\n // Update also when no `change` event is triggered, like when\n // clicking inside the SVG (#4710)\n updateExtremes();\n }\n // #10404 - move hide and blur outside focus\n rangeSelector.hideInput(name);\n rangeSelector.setInputValue(name);\n input.blur(); // #4606\n };\n let keyDown = false;\n // handle changes in the input boxes\n input.onchange = () => {\n // Update extremes and blur input when clicking date input calendar\n if (!keyDown) {\n updateExtremes();\n rangeSelector.hideInput(name);\n input.blur();\n }\n };\n input.onkeypress = (event) => {\n // IE does not fire onchange on enter\n if (event.keyCode === 13) {\n updateExtremes();\n }\n };\n input.onkeydown = (event) => {\n keyDown = true;\n // Arrow keys\n if (event.keyCode === 38 || event.keyCode === 40) {\n updateExtremes();\n }\n };\n input.onkeyup = () => {\n keyDown = false;\n };\n return { dateBox, input, label };\n }\n /**\n * Get the position of the range selector buttons and inputs. This can be\n * overridden from outside for custom positioning.\n *\n * @private\n * @function Highcharts.RangeSelector#getPosition\n */\n getPosition() {\n const chart = this.chart, options = chart.options.rangeSelector, top = options.verticalAlign === 'top' ?\n chart.plotTop - chart.axisOffset[0] :\n 0; // set offset only for varticalAlign top\n return {\n buttonTop: top + options.buttonPosition.y,\n inputTop: top + options.inputPosition.y - 10\n };\n }\n /**\n * Get the extremes of YTD. Will choose dataMax if its value is lower than\n * the current timestamp. Will choose dataMin if its value is higher than\n * the timestamp for the start of current year.\n *\n * @private\n * @function Highcharts.RangeSelector#getYTDExtremes\n * @return {*}\n * Returns min and max for the YTD\n */\n getYTDExtremes(dataMax, dataMin, useUTC) {\n const time = this.chart.time, now = new time.Date(dataMax), year = time.get('FullYear', now), startOfYear = useUTC ?\n time.Date.UTC(year, 0, 1) : // eslint-disable-line new-cap\n +new time.Date(year, 0, 1), min = Math.max(dataMin, startOfYear), ts = now.getTime();\n return {\n max: Math.min(dataMax || ts, ts),\n min\n };\n }\n /**\n * Render the range selector including the buttons and the inputs. The first\n * time render is called, the elements are created and positioned. On\n * subsequent calls, they are moved and updated.\n *\n * @private\n * @function Highcharts.RangeSelector#render\n * @param {number} [min]\n * X axis minimum\n * @param {number} [max]\n * X axis maximum\n */\n render(min, max) {\n const chart = this.chart, renderer = chart.renderer, container = chart.container, chartOptions = chart.options, options = chartOptions.rangeSelector, \n // Place inputs above the container\n inputsZIndex = pick(chartOptions.chart.style &&\n chartOptions.chart.style.zIndex, 0) + 1, inputEnabled = options.inputEnabled, rendered = this.rendered;\n if (options.enabled === false) {\n return;\n }\n // create the elements\n if (!rendered) {\n this.group = renderer.g('range-selector-group')\n .attr({\n zIndex: 7\n })\n .add();\n this.div = createElement('div', void 0, {\n position: 'relative',\n height: 0,\n zIndex: inputsZIndex\n });\n if (this.buttonOptions.length) {\n this.renderButtons();\n }\n // First create a wrapper outside the container in order to make\n // the inputs work and make export correct\n if (container.parentNode) {\n container.parentNode.insertBefore(this.div, container);\n }\n if (inputEnabled) {\n // Create the group to keep the inputs\n this.inputGroup = renderer.g('input-group').add(this.group);\n const minElems = this.drawInput('min');\n this.minDateBox = minElems.dateBox;\n this.minLabel = minElems.label;\n this.minInput = minElems.input;\n const maxElems = this.drawInput('max');\n this.maxDateBox = maxElems.dateBox;\n this.maxLabel = maxElems.label;\n this.maxInput = maxElems.input;\n }\n }\n if (inputEnabled) {\n // Set or reset the input values\n this.setInputValue('min', min);\n this.setInputValue('max', max);\n const unionExtremes = (chart.scroller && chart.scroller.getUnionExtremes()) || chart.xAxis[0] || {};\n if (defined(unionExtremes.dataMin) &&\n defined(unionExtremes.dataMax)) {\n const minRange = chart.xAxis[0].minRange || 0;\n this.setInputExtremes('min', unionExtremes.dataMin, Math.min(unionExtremes.dataMax, this.getInputValue('max')) - minRange);\n this.setInputExtremes('max', Math.max(unionExtremes.dataMin, this.getInputValue('min')) + minRange, unionExtremes.dataMax);\n }\n // Reflow\n if (this.inputGroup) {\n let x = 0;\n [\n this.minLabel,\n this.minDateBox,\n this.maxLabel,\n this.maxDateBox\n ].forEach((label) => {\n if (label) {\n const { width } = label.getBBox();\n if (width) {\n label.attr({ x });\n x += width + options.inputSpacing;\n }\n }\n });\n }\n }\n this.alignElements();\n this.rendered = true;\n }\n /**\n * Render the range buttons. This only runs the first time, later the\n * positioning is laid out in alignElements.\n *\n * @private\n * @function Highcharts.RangeSelector#renderButtons\n */\n renderButtons() {\n const { buttons, chart, options } = this;\n const lang = defaultOptions.lang;\n const renderer = chart.renderer;\n const buttonTheme = merge(options.buttonTheme);\n const states = buttonTheme && buttonTheme.states;\n // Prevent the button from resetting the width when the button state\n // changes since we need more control over the width when collapsing\n // the buttons\n const width = buttonTheme.width || 28;\n delete buttonTheme.width;\n delete buttonTheme.states;\n this.buttonGroup = renderer.g('range-selector-buttons').add(this.group);\n const dropdown = this.dropdown = createElement('select', void 0, {\n position: 'absolute',\n width: '1px',\n height: '1px',\n padding: 0,\n border: 0,\n top: '-9999em',\n cursor: 'pointer',\n opacity: 0.0001\n }, this.div);\n // Prevent page zoom on iPhone\n addEvent(dropdown, 'touchstart', () => {\n dropdown.style.fontSize = '16px';\n });\n // Forward events from select to button\n [\n [H.isMS ? 'mouseover' : 'mouseenter'],\n [H.isMS ? 'mouseout' : 'mouseleave'],\n ['change', 'click']\n ].forEach(([from, to]) => {\n addEvent(dropdown, from, () => {\n const button = buttons[this.currentButtonIndex()];\n if (button) {\n fireEvent(button.element, to || from);\n }\n });\n });\n this.zoomText = renderer\n .label((lang && lang.rangeSelectorZoom) || '', 0)\n .attr({\n padding: options.buttonTheme.padding,\n height: options.buttonTheme.height,\n paddingLeft: 0,\n paddingRight: 0\n })\n .add(this.buttonGroup);\n if (!this.chart.styledMode) {\n this.zoomText.css(options.labelStyle);\n buttonTheme['stroke-width'] = pick(buttonTheme['stroke-width'], 0);\n }\n createElement('option', {\n textContent: this.zoomText.textStr,\n disabled: true\n }, void 0, dropdown);\n this.buttonOptions.forEach((rangeOptions, i) => {\n createElement('option', {\n textContent: rangeOptions.title || rangeOptions.text\n }, void 0, dropdown);\n buttons[i] = renderer\n .button(rangeOptions.text, 0, 0, (e) => {\n // extract events from button object and call\n const buttonEvents = (rangeOptions.events && rangeOptions.events.click);\n let callDefaultEvent;\n if (buttonEvents) {\n callDefaultEvent =\n buttonEvents.call(rangeOptions, e);\n }\n if (callDefaultEvent !== false) {\n this.clickButton(i);\n }\n this.isActive = true;\n }, buttonTheme, states && states.hover, states && states.select, states && states.disabled)\n .attr({\n 'text-align': 'center',\n width\n })\n .add(this.buttonGroup);\n if (rangeOptions.title) {\n buttons[i].attr('title', rangeOptions.title);\n }\n });\n }\n /**\n * Align the elements horizontally and vertically.\n *\n * @private\n * @function Highcharts.RangeSelector#alignElements\n */\n alignElements() {\n const { buttonGroup, buttons, chart, group, inputGroup, options, zoomText } = this;\n const chartOptions = chart.options;\n const navButtonOptions = (chartOptions.exporting &&\n chartOptions.exporting.enabled !== false &&\n chartOptions.navigation &&\n chartOptions.navigation.buttonOptions);\n const { buttonPosition, inputPosition, verticalAlign } = options;\n // Get the X offset required to avoid overlapping with the exporting\n // button. This is is used both by the buttonGroup and the inputGroup.\n const getXOffsetForExportButton = (group, position) => {\n if (navButtonOptions &&\n this.titleCollision(chart) &&\n verticalAlign === 'top' &&\n position.align === 'right' && ((position.y -\n group.getBBox().height - 12) <\n ((navButtonOptions.y || 0) +\n (navButtonOptions.height || 0) +\n chart.spacing[0]))) {\n return -40;\n }\n return 0;\n };\n let plotLeft = chart.plotLeft;\n if (group && buttonPosition && inputPosition) {\n let translateX = buttonPosition.x - chart.spacing[3];\n if (buttonGroup) {\n this.positionButtons();\n if (!this.initialButtonGroupWidth) {\n let width = 0;\n if (zoomText) {\n width += zoomText.getBBox().width + 5;\n }\n buttons.forEach((button, i) => {\n width += button.width;\n if (i !== buttons.length - 1) {\n width += options.buttonSpacing;\n }\n });\n this.initialButtonGroupWidth = width;\n }\n plotLeft -= chart.spacing[3];\n this.updateButtonStates();\n // Detect collision between button group and exporting\n const xOffsetForExportButton = getXOffsetForExportButton(buttonGroup, buttonPosition);\n this.alignButtonGroup(xOffsetForExportButton);\n // Skip animation\n group.placed = buttonGroup.placed = chart.hasLoaded;\n }\n let xOffsetForExportButton = 0;\n if (inputGroup) {\n // Detect collision between the input group and exporting button\n xOffsetForExportButton = getXOffsetForExportButton(inputGroup, inputPosition);\n if (inputPosition.align === 'left') {\n translateX = plotLeft;\n }\n else if (inputPosition.align === 'right') {\n translateX = -Math.max(chart.axisOffset[1], -xOffsetForExportButton);\n }\n // Update the alignment to the updated spacing box\n inputGroup.align({\n y: inputPosition.y,\n width: inputGroup.getBBox().width,\n align: inputPosition.align,\n // fix wrong getBBox() value on right align\n x: inputPosition.x + translateX - 2\n }, true, chart.spacingBox);\n // Skip animation\n inputGroup.placed = chart.hasLoaded;\n }\n this.handleCollision(xOffsetForExportButton);\n // Vertical align\n group.align({\n verticalAlign\n }, true, chart.spacingBox);\n const alignTranslateY = group.alignAttr.translateY;\n // Set position\n let groupHeight = group.getBBox().height + 20; // # 20 padding\n let translateY = 0;\n // Calculate bottom position\n if (verticalAlign === 'bottom') {\n const legendOptions = chart.legend && chart.legend.options;\n const legendHeight = (legendOptions &&\n legendOptions.verticalAlign === 'bottom' &&\n legendOptions.enabled &&\n !legendOptions.floating ?\n (chart.legend.legendHeight +\n pick(legendOptions.margin, 10)) :\n 0);\n groupHeight = groupHeight + legendHeight - 20;\n translateY = (alignTranslateY -\n groupHeight -\n (options.floating ? 0 : options.y) -\n (chart.titleOffset ? chart.titleOffset[2] : 0) -\n 10 // 10 spacing\n );\n }\n if (verticalAlign === 'top') {\n if (options.floating) {\n translateY = 0;\n }\n if (chart.titleOffset && chart.titleOffset[0]) {\n translateY = chart.titleOffset[0];\n }\n translateY += ((chart.margin[0] - chart.spacing[0]) || 0);\n }\n else if (verticalAlign === 'middle') {\n if (inputPosition.y === buttonPosition.y) {\n translateY = alignTranslateY;\n }\n else if (inputPosition.y || buttonPosition.y) {\n if (inputPosition.y < 0 ||\n buttonPosition.y < 0) {\n translateY -= Math.min(inputPosition.y, buttonPosition.y);\n }\n else {\n translateY = alignTranslateY - groupHeight;\n }\n }\n }\n group.translate(options.x, options.y + Math.floor(translateY));\n // Translate HTML inputs\n const { minInput, maxInput, dropdown } = this;\n if (options.inputEnabled && minInput && maxInput) {\n minInput.style.marginTop = group.translateY + 'px';\n maxInput.style.marginTop = group.translateY + 'px';\n }\n if (dropdown) {\n dropdown.style.marginTop = group.translateY + 'px';\n }\n }\n }\n /**\n * Align the button group horizontally and vertically.\n *\n * @private\n * @function Highcharts.RangeSelector#alignButtonGroup\n * @param {number} xOffsetForExportButton\n * @param {number} [width]\n */\n alignButtonGroup(xOffsetForExportButton, width) {\n const { chart, options, buttonGroup, buttons } = this;\n const { buttonPosition } = options;\n const plotLeft = chart.plotLeft - chart.spacing[3];\n let translateX = buttonPosition.x - chart.spacing[3];\n if (buttonPosition.align === 'right') {\n translateX += xOffsetForExportButton - plotLeft; // #13014\n }\n else if (buttonPosition.align === 'center') {\n translateX -= plotLeft / 2;\n }\n if (buttonGroup) {\n // Align button group\n buttonGroup.align({\n y: buttonPosition.y,\n width: pick(width, this.initialButtonGroupWidth),\n align: buttonPosition.align,\n x: translateX\n }, true, chart.spacingBox);\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#positionButtons\n */\n positionButtons() {\n const { buttons, chart, options, zoomText } = this;\n const verb = chart.hasLoaded ? 'animate' : 'attr';\n const { buttonPosition } = options;\n const plotLeft = chart.plotLeft;\n let buttonLeft = plotLeft;\n if (zoomText && zoomText.visibility !== 'hidden') {\n // #8769, allow dynamically updating margins\n zoomText[verb]({\n x: pick(plotLeft + buttonPosition.x, plotLeft)\n });\n // Button start position\n buttonLeft += buttonPosition.x +\n zoomText.getBBox().width + 5;\n }\n for (let i = 0, iEnd = this.buttonOptions.length; i < iEnd; ++i) {\n if (buttons[i].visibility !== 'hidden') {\n buttons[i][verb]({ x: buttonLeft });\n // increase button position for the next button\n buttonLeft += buttons[i].width + options.buttonSpacing;\n }\n else {\n buttons[i][verb]({ x: plotLeft });\n }\n }\n }\n /**\n * Handle collision between the button group and the input group\n *\n * @private\n * @function Highcharts.RangeSelector#handleCollision\n *\n * @param {number} xOffsetForExportButton\n * The X offset of the group required to make room for the\n * exporting button\n */\n handleCollision(xOffsetForExportButton) {\n const { chart, buttonGroup, inputGroup } = this;\n const { buttonPosition, dropdown, inputPosition } = this.options;\n const maxButtonWidth = () => {\n let buttonWidth = 0;\n this.buttons.forEach((button) => {\n const bBox = button.getBBox();\n if (bBox.width > buttonWidth) {\n buttonWidth = bBox.width;\n }\n });\n return buttonWidth;\n };\n const groupsOverlap = (buttonGroupWidth) => {\n if (inputGroup && buttonGroup) {\n const inputGroupX = (inputGroup.alignAttr.translateX +\n inputGroup.alignOptions.x -\n xOffsetForExportButton +\n // getBBox for detecing left margin\n inputGroup.getBBox().x +\n // 2px padding to not overlap input and label\n 2);\n const inputGroupWidth = inputGroup.alignOptions.width;\n const buttonGroupX = buttonGroup.alignAttr.translateX +\n buttonGroup.getBBox().x;\n return (buttonGroupX + buttonGroupWidth > inputGroupX) &&\n (inputGroupX + inputGroupWidth > buttonGroupX) &&\n (buttonPosition.y <\n (inputPosition.y +\n inputGroup.getBBox().height));\n }\n return false;\n };\n const moveInputsDown = () => {\n if (inputGroup && buttonGroup) {\n inputGroup.attr({\n translateX: inputGroup.alignAttr.translateX + (chart.axisOffset[1] >= -xOffsetForExportButton ?\n 0 :\n -xOffsetForExportButton),\n translateY: inputGroup.alignAttr.translateY +\n buttonGroup.getBBox().height + 10\n });\n }\n };\n if (buttonGroup) {\n if (dropdown === 'always') {\n this.collapseButtons(xOffsetForExportButton);\n if (groupsOverlap(maxButtonWidth())) {\n // Move the inputs down if there is still a collision\n // after collapsing the buttons\n moveInputsDown();\n }\n return;\n }\n if (dropdown === 'never') {\n this.expandButtons();\n }\n }\n // Detect collision\n if (inputGroup && buttonGroup) {\n if ((inputPosition.align === buttonPosition.align) ||\n // 20 is minimal spacing between elements\n groupsOverlap(this.initialButtonGroupWidth + 20)) {\n if (dropdown === 'responsive') {\n this.collapseButtons(xOffsetForExportButton);\n if (groupsOverlap(maxButtonWidth())) {\n moveInputsDown();\n }\n }\n else {\n moveInputsDown();\n }\n }\n else if (dropdown === 'responsive') {\n this.expandButtons();\n }\n }\n else if (buttonGroup && dropdown === 'responsive') {\n if (this.initialButtonGroupWidth > chart.plotWidth) {\n this.collapseButtons(xOffsetForExportButton);\n }\n else {\n this.expandButtons();\n }\n }\n }\n /**\n * Collapse the buttons and put the select element on top.\n *\n * @private\n * @function Highcharts.RangeSelector#collapseButtons\n * @param {number} xOffsetForExportButton\n */\n collapseButtons(xOffsetForExportButton) {\n const { buttons, buttonOptions, chart, dropdown, options, zoomText } = this;\n const userButtonTheme = (chart.userOptions.rangeSelector &&\n chart.userOptions.rangeSelector.buttonTheme) || {};\n const getAttribs = (text) => ({\n text: text ? `${text} ▾` : '▾',\n width: 'auto',\n paddingLeft: pick(options.buttonTheme.paddingLeft, userButtonTheme.padding, 8),\n paddingRight: pick(options.buttonTheme.paddingRight, userButtonTheme.padding, 8)\n });\n if (zoomText) {\n zoomText.hide();\n }\n let hasActiveButton = false;\n buttonOptions.forEach((rangeOptions, i) => {\n const button = buttons[i];\n if (button.state !== 2) {\n button.hide();\n }\n else {\n button.show();\n button.attr(getAttribs(rangeOptions.text));\n hasActiveButton = true;\n }\n });\n if (!hasActiveButton) {\n if (dropdown) {\n dropdown.selectedIndex = 0;\n }\n buttons[0].show();\n buttons[0].attr(getAttribs(this.zoomText && this.zoomText.textStr));\n }\n const { align } = options.buttonPosition;\n this.positionButtons();\n if (align === 'right' || align === 'center') {\n this.alignButtonGroup(xOffsetForExportButton, buttons[this.currentButtonIndex()].getBBox().width);\n }\n this.showDropdown();\n }\n /**\n * Show all the buttons and hide the select element.\n *\n * @private\n * @function Highcharts.RangeSelector#expandButtons\n */\n expandButtons() {\n const { buttons, buttonOptions, options, zoomText } = this;\n this.hideDropdown();\n if (zoomText) {\n zoomText.show();\n }\n buttonOptions.forEach((rangeOptions, i) => {\n const button = buttons[i];\n button.show();\n button.attr({\n text: rangeOptions.text,\n width: options.buttonTheme.width || 28,\n paddingLeft: pick(options.buttonTheme.paddingLeft, 'unset'),\n paddingRight: pick(options.buttonTheme.paddingRight, 'unset')\n });\n if (button.state < 2) {\n button.setState(0);\n }\n });\n this.positionButtons();\n }\n /**\n * Get the index of the visible button when the buttons are collapsed.\n *\n * @private\n * @function Highcharts.RangeSelector#currentButtonIndex\n */\n currentButtonIndex() {\n const { dropdown } = this;\n if (dropdown && dropdown.selectedIndex > 0) {\n return dropdown.selectedIndex - 1;\n }\n return 0;\n }\n /**\n * Position the select element on top of the button.\n *\n * @private\n * @function Highcharts.RangeSelector#showDropdown\n */\n showDropdown() {\n const { buttonGroup, buttons, chart, dropdown } = this;\n if (buttonGroup && dropdown) {\n const { translateX, translateY } = buttonGroup;\n const bBox = buttons[this.currentButtonIndex()].getBBox();\n css(dropdown, {\n left: (chart.plotLeft + translateX) + 'px',\n top: (translateY + 0.5) + 'px',\n width: bBox.width + 'px',\n height: bBox.height + 'px'\n });\n this.hasVisibleDropdown = true;\n }\n }\n /**\n * @private\n * @function Highcharts.RangeSelector#hideDropdown\n */\n hideDropdown() {\n const { dropdown } = this;\n if (dropdown) {\n css(dropdown, {\n top: '-9999em',\n width: '1px',\n height: '1px'\n });\n this.hasVisibleDropdown = false;\n }\n }\n /**\n * Extracts height of range selector\n *\n * @private\n * @function Highcharts.RangeSelector#getHeight\n * @return {number}\n * Returns rangeSelector height\n */\n getHeight() {\n const rangeSelector = this, options = rangeSelector.options, rangeSelectorGroup = rangeSelector.group, inputPosition = options.inputPosition, buttonPosition = options.buttonPosition, yPosition = options.y, buttonPositionY = buttonPosition.y, inputPositionY = inputPosition.y;\n let rangeSelectorHeight = 0;\n if (options.height) {\n return options.height;\n }\n // Align the elements before we read the height in case we're switching\n // between wrapped and non-wrapped layout\n this.alignElements();\n rangeSelectorHeight = rangeSelectorGroup ?\n // 13px to keep back compatibility\n (rangeSelectorGroup.getBBox(true).height) + 13 +\n yPosition :\n 0;\n const minPosition = Math.min(inputPositionY, buttonPositionY);\n if ((inputPositionY < 0 && buttonPositionY < 0) ||\n (inputPositionY > 0 && buttonPositionY > 0)) {\n rangeSelectorHeight += Math.abs(minPosition);\n }\n return rangeSelectorHeight;\n }\n /**\n * Detect collision with title or subtitle\n *\n * @private\n * @function Highcharts.RangeSelector#titleCollision\n * @return {boolean}\n * Returns collision status\n */\n titleCollision(chart) {\n return !(chart.options.title.text ||\n chart.options.subtitle.text);\n }\n /**\n * Update the range selector with new options\n *\n * @private\n * @function Highcharts.RangeSelector#update\n * @param {Highcharts.RangeSelectorOptions} options\n */\n update(options) {\n const chart = this.chart;\n merge(true, chart.options.rangeSelector, options);\n this.destroy();\n this.init(chart);\n this.render();\n }\n /**\n * Destroys allocated elements.\n *\n * @private\n * @function Highcharts.RangeSelector#destroy\n */\n destroy() {\n const rSelector = this, minInput = rSelector.minInput, maxInput = rSelector.maxInput;\n if (rSelector.eventsToUnbind) {\n rSelector.eventsToUnbind.forEach((unbind) => unbind());\n rSelector.eventsToUnbind = void 0;\n }\n // Destroy elements in collections\n destroyObjectProperties(rSelector.buttons);\n // Clear input element events\n if (minInput) {\n minInput.onfocus = minInput.onblur = minInput.onchange = null;\n }\n if (maxInput) {\n maxInput.onfocus = maxInput.onblur = maxInput.onchange = null;\n }\n // Destroy HTML and SVG elements\n objectEach(rSelector, function (val, key) {\n if (val && key !== 'chart') {\n if (val instanceof SVGElement) {\n // SVGElement\n val.destroy();\n }\n else if (val instanceof window.HTMLElement) {\n // HTML element\n discardElement(val);\n }\n }\n if (val !== RangeSelector.prototype[key]) {\n rSelector[key] = null;\n }\n }, this);\n }\n }\n extend(RangeSelector.prototype, {\n /**\n * The default buttons for pre-selecting time frames.\n * @private\n */\n defaultButtons: [{\n type: 'month',\n count: 1,\n text: '1m',\n title: 'View 1 month'\n }, {\n type: 'month',\n count: 3,\n text: '3m',\n title: 'View 3 months'\n }, {\n type: 'month',\n count: 6,\n text: '6m',\n title: 'View 6 months'\n }, {\n type: 'ytd',\n text: 'YTD',\n title: 'View year to date'\n }, {\n type: 'year',\n count: 1,\n text: '1y',\n title: 'View 1 year'\n }, {\n type: 'all',\n text: 'All',\n title: 'View all'\n }],\n /**\n * The date formats to use when setting min, max and value on date inputs.\n * @private\n */\n inputTypeFormats: {\n 'datetime-local': '%Y-%m-%dT%H:%M:%S',\n 'date': '%Y-%m-%d',\n 'time': '%H:%M:%S'\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Define the time span for the button\n *\n * @typedef {\"all\"|\"day\"|\"hour\"|\"millisecond\"|\"minute\"|\"month\"|\"second\"|\"week\"|\"year\"|\"ytd\"} Highcharts.RangeSelectorButtonTypeValue\n */\n /**\n * Callback function to react on button clicks.\n *\n * @callback Highcharts.RangeSelectorClickCallbackFunction\n *\n * @param {global.Event} e\n * Event arguments.\n *\n * @param {boolean|undefined}\n * Return false to cancel the default button event.\n */\n /**\n * Callback function to parse values entered in the input boxes and return a\n * valid JavaScript time as milliseconds since 1970.\n *\n * @callback Highcharts.RangeSelectorParseCallbackFunction\n *\n * @param {string} value\n * Input value to parse.\n *\n * @return {number}\n * Parsed JavaScript time value.\n */\n (''); // keeps doclets above in JS file\n\n return RangeSelector;\n });\n _registerModule(_modules, 'Core/Axis/OrdinalAxis.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Globals.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (Axis, H, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { addEvent, correctFloat, css, defined, error, pick, timeUnits } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* eslint-disable valid-jsdoc */\n /* *\n *\n * Composition\n *\n * */\n /**\n * Extends the axis with ordinal support.\n * @private\n */\n var OrdinalAxis;\n (function (OrdinalAxis) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extends the axis with ordinal support.\n *\n * @private\n *\n * @param AxisClass\n * Axis class to extend.\n *\n * @param ChartClass\n * Chart class to use.\n *\n * @param SeriesClass\n * Series class to use.\n */\n function compose(AxisClass, SeriesClass, ChartClass) {\n if (U.pushUnique(composedMembers, AxisClass)) {\n const axisProto = AxisClass.prototype;\n axisProto.getTimeTicks = getTimeTicks;\n axisProto.index2val = index2val;\n axisProto.lin2val = lin2val;\n axisProto.val2lin = val2lin;\n // Record this to prevent overwriting by broken-axis module (#5979)\n axisProto.ordinal2lin = axisProto.val2lin;\n addEvent(AxisClass, 'afterInit', onAxisAfterInit);\n addEvent(AxisClass, 'foundExtremes', onAxisFoundExtremes);\n addEvent(AxisClass, 'afterSetScale', onAxisAfterSetScale);\n addEvent(AxisClass, 'initialAxisTranslation', onAxisInitialAxisTranslation);\n }\n if (U.pushUnique(composedMembers, ChartClass)) {\n addEvent(ChartClass, 'pan', onChartPan);\n }\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'updatedData', onSeriesUpdatedData);\n }\n return AxisClass;\n }\n OrdinalAxis.compose = compose;\n /**\n * In an ordinal axis, there might be areas with dense consentrations of\n * points, then large gaps between some. Creating equally distributed\n * ticks over this entire range may lead to a huge number of ticks that\n * will later be removed. So instead, break the positions up in\n * segments, find the tick positions for each segment then concatenize\n * them. This method is used from both data grouping logic and X axis\n * tick position logic.\n * @private\n */\n function getTimeTicks(normalizedInterval, min, max, startOfWeek, positions = [], closestDistance = 0, findHigherRanks) {\n const higherRanks = {}, tickPixelIntervalOption = this.options.tickPixelInterval, time = this.chart.time, \n // Record all the start positions of a segment, to use when\n // deciding what's a gap in the data.\n segmentStarts = [];\n let end, segmentPositions, hasCrossedHigherRank, info, outsideMax, start = 0, groupPositions = [], lastGroupPosition = -Number.MAX_VALUE;\n // The positions are not always defined, for example for ordinal\n // positions when data has regular interval (#1557, #2090)\n if ((!this.options.ordinal && !this.options.breaks) ||\n !positions ||\n positions.length < 3 ||\n typeof min === 'undefined') {\n return time.getTimeTicks.apply(time, arguments);\n }\n // Analyze the positions array to split it into segments on gaps\n // larger than 5 times the closest distance. The closest distance is\n // already found at this point, so we reuse that instead of\n // computing it again.\n const posLength = positions.length;\n for (end = 0; end < posLength; end++) {\n outsideMax = end && positions[end - 1] > max;\n if (positions[end] < min) { // Set the last position before min\n start = end;\n }\n if (end === posLength - 1 ||\n positions[end + 1] - positions[end] > closestDistance * 5 ||\n outsideMax) {\n // For each segment, calculate the tick positions from the\n // getTimeTicks utility function. The interval will be the\n // same regardless of how long the segment is.\n if (positions[end] > lastGroupPosition) { // #1475\n segmentPositions = time.getTimeTicks(normalizedInterval, positions[start], positions[end], startOfWeek);\n // Prevent duplicate groups, for example for multiple\n // segments within one larger time frame (#1475)\n while (segmentPositions.length &&\n segmentPositions[0] <= lastGroupPosition) {\n segmentPositions.shift();\n }\n if (segmentPositions.length) {\n lastGroupPosition =\n segmentPositions[segmentPositions.length - 1];\n }\n segmentStarts.push(groupPositions.length);\n groupPositions = groupPositions.concat(segmentPositions);\n }\n // Set start of next segment\n start = end + 1;\n }\n if (outsideMax) {\n break;\n }\n }\n // Get the grouping info from the last of the segments. The info is\n // the same for all segments.\n if (segmentPositions) {\n info = segmentPositions.info;\n // Optionally identify ticks with higher rank, for example\n // when the ticks have crossed midnight.\n if (findHigherRanks && info.unitRange <= timeUnits.hour) {\n end = groupPositions.length - 1;\n // Compare points two by two\n for (start = 1; start < end; start++) {\n if (time.dateFormat('%d', groupPositions[start]) !==\n time.dateFormat('%d', groupPositions[start - 1])) {\n higherRanks[groupPositions[start]] = 'day';\n hasCrossedHigherRank = true;\n }\n }\n // If the complete array has crossed midnight, we want\n // to mark the first positions also as higher rank\n if (hasCrossedHigherRank) {\n higherRanks[groupPositions[0]] = 'day';\n }\n info.higherRanks = higherRanks;\n }\n // Save the info\n info.segmentStarts = segmentStarts;\n groupPositions.info = info;\n }\n else {\n error(12, false, this.chart);\n }\n // Don't show ticks within a gap in the ordinal axis, where the\n // space between two points is greater than a portion of the tick\n // pixel interval\n if (findHigherRanks && defined(tickPixelIntervalOption)) {\n const length = groupPositions.length, translatedArr = [], distances = [];\n let itemToRemove, translated, lastTranslated, medianDistance, distance, i = length;\n // Find median pixel distance in order to keep a reasonably even\n // distance between ticks (#748)\n while (i--) {\n translated = this.translate(groupPositions[i]);\n if (lastTranslated) {\n distances[i] = lastTranslated - translated;\n }\n translatedArr[i] = lastTranslated = translated;\n }\n distances.sort();\n medianDistance = distances[Math.floor(distances.length / 2)];\n if (medianDistance < tickPixelIntervalOption * 0.6) {\n medianDistance = null;\n }\n // Now loop over again and remove ticks where needed\n i = groupPositions[length - 1] > max ? length - 1 : length; // #817\n lastTranslated = void 0;\n while (i--) {\n translated = translatedArr[i];\n distance = Math.abs(lastTranslated - translated);\n // #4175 - when axis is reversed, the distance, is negative but\n // tickPixelIntervalOption positive, so we need to compare the\n // same values\n // Remove ticks that are closer than 0.6 times the pixel\n // interval from the one to the right, but not if it is close to\n // the median distance (#748).\n if (lastTranslated &&\n distance < tickPixelIntervalOption * 0.8 &&\n (medianDistance === null || distance < medianDistance * 0.8)) {\n // Is this a higher ranked position with a normal\n // position to the right?\n if (higherRanks[groupPositions[i]] &&\n !higherRanks[groupPositions[i + 1]]) {\n // Yes: remove the lower ranked neighbour to the\n // right\n itemToRemove = i + 1;\n lastTranslated = translated; // #709\n }\n else {\n // No: remove this one\n itemToRemove = i;\n }\n groupPositions.splice(itemToRemove, 1);\n }\n else {\n lastTranslated = translated;\n }\n }\n }\n return groupPositions;\n }\n /**\n * Get axis position of given index of the extended ordinal positions.\n * Used only when panning an ordinal axis.\n *\n * @private\n * @function Highcharts.Axis#index2val\n * @param {number} index\n * The index value of searched point\n */\n function index2val(index) {\n const axis = this, ordinal = axis.ordinal, \n // Context could be changed to extendedOrdinalPositions.\n ordinalPositions = ordinal.positions;\n // The visible range contains only equally spaced values.\n if (!ordinalPositions) {\n return index;\n }\n let i = ordinalPositions.length - 1, distance;\n if (index < 0) { // out of range, in effect panning to the left\n index = ordinalPositions[0];\n }\n else if (index > i) { // out of range, panning to the right\n index = ordinalPositions[i];\n }\n else { // split it up\n i = Math.floor(index);\n distance = index - i; // the decimal\n }\n if (typeof distance !== 'undefined' &&\n typeof ordinalPositions[i] !== 'undefined') {\n return ordinalPositions[i] + (distance ?\n distance *\n (ordinalPositions[i + 1] - ordinalPositions[i]) :\n 0);\n }\n return index;\n }\n /**\n * Translate from linear (internal) to axis value.\n *\n * @private\n * @function Highcharts.Axis#lin2val\n * @param {number} val\n * The linear abstracted value.\n */\n function lin2val(val) {\n const axis = this, ordinal = axis.ordinal, localMin = axis.old ? axis.old.min : axis.min, localA = axis.old ? axis.old.transA : axis.transA;\n let positions = ordinal.positions; // for the current visible range\n // The visible range contains only equally spaced values.\n if (!positions) {\n return val;\n }\n // Convert back from modivied value to pixels. // #15970\n const pixelVal = correctFloat((val - localMin) * localA +\n axis.minPixelPadding), isInside = val >= positions[0] &&\n val <= positions[positions.length - 1];\n // If the value is not inside the plot area, use the extended positions.\n // (array contains also points that are outside of the plotArea).\n if (!isInside) {\n // When iterating for the first time,\n // get the extended ordinal positional and assign them.\n if (!ordinal.extendedOrdinalPositions) {\n ordinal.extendedOrdinalPositions = (ordinal.getExtendedPositions());\n }\n positions = ordinal.extendedOrdinalPositions;\n }\n // In some cases (especially in early stages of the chart creation) the\n // getExtendedPositions might return undefined.\n if (positions && positions.length) {\n const indexOf = positions.indexOf(val);\n const index = indexOf !== -1 ? indexOf : correctFloat(ordinal.getIndexOfPoint(pixelVal, positions)), mantissa = correctFloat(index % 1);\n // Check if the index is inside position array. If true,\n // read/approximate value for that exact index.\n if (index >= 0 && index <= positions.length - 1) {\n const leftNeighbour = positions[Math.floor(index)], rightNeighbour = positions[Math.ceil(index)], distance = rightNeighbour - leftNeighbour;\n return positions[Math.floor(index)] + mantissa * distance;\n }\n // For cases when the index is not in the extended ordinal position\n // array, like when the value we are looking for exceed the\n // available data, approximate that value based on the calculated\n // slope.\n const positionsLength = positions.length, firstPositionsValue = positions[0], lastPositionsValue = positions[positionsLength - 1], slope = (lastPositionsValue - firstPositionsValue) / (positionsLength - 1);\n if (index < 0) {\n return firstPositionsValue + slope * index;\n }\n return lastPositionsValue + slope * (index - positionsLength);\n }\n return val;\n }\n /**\n * Internal function to calculate the precise index in ordinalPositions\n * array.\n * @private\n */\n function getIndexInArray(ordinalPositions, val) {\n const index = OrdinalAxis.Additions.findIndexOf(ordinalPositions, val, true);\n if (ordinalPositions[index] === val) {\n return index;\n }\n const percent = (val - ordinalPositions[index]) /\n (ordinalPositions[index + 1] - ordinalPositions[index]);\n return index + percent;\n }\n /**\n * @private\n */\n function onAxisAfterInit() {\n const axis = this;\n if (!axis.ordinal) {\n axis.ordinal = new OrdinalAxis.Additions(axis);\n }\n }\n /**\n * @private\n */\n function onAxisFoundExtremes() {\n const axis = this;\n if (axis.isXAxis &&\n defined(axis.options.overscroll) &&\n axis.max === axis.dataMax &&\n (\n // Panning is an execption. We don't want to apply\n // overscroll when panning over the dataMax\n !axis.chart.mouseIsDown ||\n axis.isInternal) && (\n // Scrollbar buttons are the other execption:\n !axis.eventArgs ||\n axis.eventArgs && axis.eventArgs.trigger !== 'navigator')) {\n axis.max += axis.options.overscroll;\n // Live data and buttons require translation for the min:\n if (!axis.isInternal && defined(axis.userMin)) {\n axis.min += axis.options.overscroll;\n }\n }\n }\n /**\n * For ordinal axis, that loads data async, redraw axis after data is\n * loaded. If we don't do that, axis will have the same extremes as\n * previously, but ordinal positions won't be calculated. See #10290\n * @private\n */\n function onAxisAfterSetScale() {\n const axis = this;\n if (axis.horiz && !axis.isDirty) {\n axis.isDirty = axis.isOrdinal &&\n axis.chart.navigator &&\n !axis.chart.navigator.adaptToUpdatedData;\n }\n }\n /**\n * @private\n */\n function onAxisInitialAxisTranslation() {\n const axis = this;\n if (axis.ordinal) {\n axis.ordinal.beforeSetTickPositions();\n axis.tickInterval = axis.ordinal.postProcessTickInterval(axis.tickInterval);\n }\n }\n /**\n * Extending the Chart.pan method for ordinal axes\n * @private\n */\n function onChartPan(e) {\n const chart = this, xAxis = chart.xAxis[0], overscroll = xAxis.options.overscroll, chartX = e.originalEvent.chartX, panning = chart.options.chart.panning;\n let runBase = false;\n if (panning &&\n panning.type !== 'y' &&\n xAxis.options.ordinal &&\n xAxis.series.length) {\n const mouseDownX = chart.mouseDownX, extremes = xAxis.getExtremes(), dataMax = extremes.dataMax, min = extremes.min, max = extremes.max, hoverPoints = chart.hoverPoints, closestPointRange = (xAxis.closestPointRange ||\n (xAxis.ordinal && xAxis.ordinal.overscrollPointsRange)), pointPixelWidth = (xAxis.translationSlope *\n (xAxis.ordinal.slope || closestPointRange)), \n // how many ordinal units did we move?\n movedUnits = Math.round((mouseDownX - chartX) / pointPixelWidth), \n // get index of all the chart's points\n extendedOrdinalPositions = xAxis.ordinal.getExtendedPositions(), extendedAxis = {\n ordinal: {\n positions: extendedOrdinalPositions,\n extendedOrdinalPositions: extendedOrdinalPositions\n }\n }, index2val = xAxis.index2val, val2lin = xAxis.val2lin;\n let trimmedRange, ordinalPositions, searchAxisLeft, searchAxisRight;\n // we have an ordinal axis, but the data is equally spaced\n if (!extendedAxis.ordinal.positions) {\n runBase = true;\n }\n else if (Math.abs(movedUnits) > 1) {\n // Remove active points for shared tooltip\n if (hoverPoints) {\n hoverPoints.forEach(function (point) {\n point.setState();\n });\n }\n if (movedUnits < 0) {\n searchAxisLeft = extendedAxis;\n searchAxisRight = xAxis.ordinal.positions ?\n xAxis : extendedAxis;\n }\n else {\n searchAxisLeft = xAxis.ordinal.positions ?\n xAxis : extendedAxis;\n searchAxisRight = extendedAxis;\n }\n // In grouped data series, the last ordinal position represents\n // the grouped data, which is to the left of the real data max.\n // If we don't compensate for this, we will be allowed to pan\n // grouped data series passed the right of the plot area.\n ordinalPositions = searchAxisRight.ordinal.positions;\n if (dataMax >\n ordinalPositions[ordinalPositions.length - 1]) {\n ordinalPositions.push(dataMax);\n }\n // Get the new min and max values by getting the ordinal index\n // for the current extreme, then add the moved units and\n // translate back to values. This happens on the extended\n // ordinal positions if the new position is out of range, else\n // it happens on the current x axis which is smaller and faster.\n chart.fixedRange = max - min;\n trimmedRange = xAxis.navigatorAxis\n .toFixedRange(void 0, void 0, index2val.apply(searchAxisLeft, [\n val2lin.apply(searchAxisLeft, [min, true]) +\n movedUnits\n ]), index2val.apply(searchAxisRight, [\n val2lin.apply(searchAxisRight, [max, true]) +\n movedUnits\n ]));\n // Apply it if it is within the available data range\n if (trimmedRange.min >= Math.min(extremes.dataMin, min) &&\n trimmedRange.max <= Math.max(dataMax, max) +\n overscroll) {\n xAxis.setExtremes(trimmedRange.min, trimmedRange.max, true, false, { trigger: 'pan' });\n }\n chart.mouseDownX = chartX; // set new reference for next run\n css(chart.container, { cursor: 'move' });\n }\n }\n else {\n runBase = true;\n }\n // revert to the linear chart.pan version\n if (runBase || (panning && /y/.test(panning.type))) {\n if (overscroll) {\n xAxis.max = xAxis.dataMax + overscroll;\n }\n }\n else {\n e.preventDefault();\n }\n }\n /**\n * @private\n */\n function onSeriesUpdatedData() {\n const xAxis = this.xAxis;\n // Destroy the extended ordinal index on updated data\n // and destroy extendedOrdinalPositions, #16055.\n if (xAxis && xAxis.options.ordinal) {\n delete xAxis.ordinal.index;\n delete xAxis.ordinal.extendedOrdinalPositions;\n }\n }\n /**\n * Translate from a linear axis value to the corresponding ordinal axis\n * position. If there are no gaps in the ordinal axis this will be the\n * same. The translated value is the value that the point would have if\n * the axis was linear, using the same min and max.\n *\n * @private\n * @function Highcharts.Axis#val2lin\n * @param {number} val\n * The axis value.\n * @param {boolean} [toIndex]\n * Whether to return the index in the ordinalPositions or the new value.\n */\n function val2lin(val, toIndex) {\n const axis = this, ordinal = axis.ordinal, ordinalPositions = ordinal.positions;\n let slope = ordinal.slope, extendedOrdinalPositions = ordinal.extendedOrdinalPositions;\n if (!ordinalPositions) {\n return val;\n }\n const ordinalLength = ordinalPositions.length;\n let ordinalIndex;\n // If the searched value is inside visible plotArea, ivastigate the\n // value basing on ordinalPositions.\n if (ordinalPositions[0] <= val &&\n ordinalPositions[ordinalLength - 1] >= val) {\n ordinalIndex = getIndexInArray(ordinalPositions, val);\n // final return value is based on ordinalIndex\n }\n else {\n if (!extendedOrdinalPositions) {\n extendedOrdinalPositions =\n ordinal.getExtendedPositions &&\n ordinal.getExtendedPositions();\n ordinal.extendedOrdinalPositions = extendedOrdinalPositions;\n }\n if (!(extendedOrdinalPositions && extendedOrdinalPositions.length)) {\n return val;\n }\n const length = extendedOrdinalPositions.length;\n if (!slope) {\n slope =\n (extendedOrdinalPositions[length - 1] -\n extendedOrdinalPositions[0]) /\n length;\n }\n // OriginalPointReference is equal to the index of\n // first point of ordinalPositions in extendedOrdinalPositions.\n const originalPositionsReference = getIndexInArray(extendedOrdinalPositions, ordinalPositions[0]);\n // If the searched value is outside the visiblePlotArea,\n // check if it is inside extendedOrdinalPositions.\n if (val >= extendedOrdinalPositions[0] &&\n val <=\n extendedOrdinalPositions[length - 1]) {\n // Return Value\n ordinalIndex = getIndexInArray(extendedOrdinalPositions, val) -\n originalPositionsReference;\n }\n else {\n // Since ordinal.slope is the average distance between 2\n // points on visible plotArea, this can be used to calculete\n // the approximate position of the point, which is outside\n // the extededOrdinalPositions.\n if (val < extendedOrdinalPositions[0]) {\n const diff = extendedOrdinalPositions[0] - val, approximateIndexOffset = diff / slope;\n ordinalIndex =\n -originalPositionsReference -\n approximateIndexOffset;\n }\n else {\n const diff = val -\n extendedOrdinalPositions[length - 1], approximateIndexOffset = diff / slope;\n ordinalIndex =\n approximateIndexOffset +\n length -\n originalPositionsReference;\n }\n }\n }\n return toIndex ? ordinalIndex : slope * (ordinalIndex || 0) +\n ordinal.offset;\n }\n /* *\n *\n * Classes\n *\n * */\n /**\n * @private\n */\n class Additions {\n /* *\n *\n * Constructors\n *\n * */\n /**\n * @private\n */\n constructor(axis) {\n this.index = {};\n this.axis = axis;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Calculate the ordinal positions before tick positions are calculated.\n * @private\n */\n beforeSetTickPositions() {\n const axis = this.axis, ordinal = axis.ordinal, extremes = axis.getExtremes(), min = extremes.min, max = extremes.max, hasBreaks = axis.isXAxis && !!axis.options.breaks, isOrdinal = axis.options.ordinal, ignoreHiddenSeries = axis.chart.options.chart.ignoreHiddenSeries;\n let len, uniqueOrdinalPositions, dist, minIndex, maxIndex, slope, i, ordinalPositions = [], overscrollPointsRange = Number.MAX_VALUE, useOrdinal = false, adjustOrdinalExtremesPoints = false, isBoosted = false;\n // Apply the ordinal logic\n if (isOrdinal || hasBreaks) { // #4167 YAxis is never ordinal ?\n let distanceBetweenPoint = 0;\n axis.series.forEach(function (series, i) {\n uniqueOrdinalPositions = [];\n // For an axis with multiple series, check if the distance\n // between points is identical throughout all series.\n if (i > 0 &&\n series.options.id !== 'highcharts-navigator-series' &&\n series.processedXData.length > 1) {\n adjustOrdinalExtremesPoints =\n distanceBetweenPoint !== series.processedXData[1] -\n series.processedXData[0];\n }\n distanceBetweenPoint =\n series.processedXData[1] - series.processedXData[0];\n if (series.boosted) {\n isBoosted = series.boosted;\n }\n if ((!ignoreHiddenSeries || series.visible !== false) &&\n (series\n .takeOrdinalPosition !== false ||\n hasBreaks)) {\n // concatenate the processed X data into the existing\n // positions, or the empty array\n ordinalPositions = ordinalPositions.concat(series.processedXData);\n len = ordinalPositions.length;\n // remove duplicates (#1588)\n ordinalPositions.sort(function (a, b) {\n // without a custom function it is sorted as strings\n return a - b;\n });\n overscrollPointsRange = Math.min(overscrollPointsRange, pick(\n // Check for a single-point series:\n series.closestPointRange, overscrollPointsRange));\n if (len) {\n i = 0;\n while (i < len - 1) {\n if (ordinalPositions[i] !==\n ordinalPositions[i + 1]) {\n uniqueOrdinalPositions.push(ordinalPositions[i + 1]);\n }\n i++;\n }\n // Check first item:\n if (uniqueOrdinalPositions[0] !==\n ordinalPositions[0]) {\n uniqueOrdinalPositions.unshift(ordinalPositions[0]);\n }\n ordinalPositions = uniqueOrdinalPositions;\n }\n }\n });\n // If the distance between points is not identical throughout\n // all series, remove the first and last ordinal position to\n // avoid enabling ordinal logic when it is not needed, #17405.\n // Only for boosted series because changes are negligible.\n if (adjustOrdinalExtremesPoints && isBoosted) {\n ordinalPositions.pop();\n ordinalPositions.shift();\n }\n // cache the length\n len = ordinalPositions.length;\n // Check if we really need the overhead of mapping axis data\n // against the ordinal positions. If the series consist of\n // evenly spaced data any way, we don't need any ordinal logic.\n if (len > 2) { // two points have equal distance by default\n dist = ordinalPositions[1] - ordinalPositions[0];\n i = len - 1;\n while (i-- && !useOrdinal) {\n if (ordinalPositions[i + 1] - ordinalPositions[i] !==\n dist) {\n useOrdinal = true;\n }\n }\n // When zooming in on a week, prevent axis padding for\n // weekends even though the data within the week is evenly\n // spaced.\n if (!axis.options.keepOrdinalPadding &&\n (ordinalPositions[0] - min > dist ||\n (max -\n ordinalPositions[ordinalPositions.length - 1]) > dist)) {\n useOrdinal = true;\n }\n }\n else if (axis.options.overscroll) {\n if (len === 2) {\n // Exactly two points, distance for overscroll is fixed:\n overscrollPointsRange =\n ordinalPositions[1] - ordinalPositions[0];\n }\n else if (len === 1) {\n // We have just one point, closest distance is unknown.\n // Assume then it is last point and overscrolled range:\n overscrollPointsRange = axis.options.overscroll;\n ordinalPositions = [\n ordinalPositions[0],\n ordinalPositions[0] + overscrollPointsRange\n ];\n }\n else {\n // In case of zooming in on overscrolled range, stick to\n // the old range:\n overscrollPointsRange = ordinal.overscrollPointsRange;\n }\n }\n // Record the slope and offset to compute the linear values from\n // the array index. Since the ordinal positions may exceed the\n // current range, get the start and end positions within it\n // (#719, #665b)\n if (useOrdinal || axis.forceOrdinal) {\n if (axis.options.overscroll) {\n ordinal.overscrollPointsRange = overscrollPointsRange;\n ordinalPositions = ordinalPositions.concat(ordinal.getOverscrollPositions());\n }\n // Register\n ordinal.positions = ordinalPositions;\n // This relies on the ordinalPositions being set. Use\n // Math.max and Math.min to prevent padding on either sides\n // of the data.\n minIndex = axis.ordinal2lin(// #5979\n Math.max(min, ordinalPositions[0]), true);\n maxIndex = Math.max(axis.ordinal2lin(Math.min(max, ordinalPositions[ordinalPositions.length - 1]), true), 1); // #3339\n // Set the slope and offset of the values compared to the\n // indices in the ordinal positions\n ordinal.slope = slope = (max - min) / (maxIndex - minIndex);\n ordinal.offset = min - (minIndex * slope);\n }\n else {\n ordinal.overscrollPointsRange = pick(axis.closestPointRange, ordinal.overscrollPointsRange);\n ordinal.positions = axis.ordinal.slope = ordinal.offset =\n void 0;\n }\n }\n axis.isOrdinal = isOrdinal && useOrdinal; // #3818, #4196, #4926\n ordinal.groupIntervalFactor = null; // reset for next run\n }\n /**\n * Faster way of using the Array.indexOf method.\n * Works for sorted arrays only with unique values.\n *\n * @param {Array} sortedArray\n * The sorted array inside which we are looking for.\n * @param {number} key\n * The key to being found.\n * @param {boolean} indirectSearch\n * In case of lack of the point in the array, should return\n * value be equal to -1 or the closest smaller index.\n * @private\n */\n static findIndexOf(sortedArray, key, indirectSearch) {\n let start = 0, end = sortedArray.length - 1, middle;\n while (start < end) {\n middle = Math.ceil((start + end) / 2);\n // Key found as the middle element.\n if (sortedArray[middle] <= key) {\n // Continue searching to the right.\n start = middle;\n }\n else {\n // Continue searching to the left.\n end = middle - 1;\n }\n }\n if (sortedArray[start] === key) {\n return start;\n }\n // Key could not be found.\n return !indirectSearch ? -1 : start;\n }\n /**\n * Get the ordinal positions for the entire data set. This is necessary\n * in chart panning because we need to find out what points or data\n * groups are available outside the visible range. When a panning\n * operation starts, if an index for the given grouping does not exists,\n * it is created and cached. This index is deleted on updated data, so\n * it will be regenerated the next time a panning operation starts.\n * @private\n */\n getExtendedPositions() {\n const ordinal = this, axis = ordinal.axis, axisProto = axis.constructor.prototype, chart = axis.chart, grouping = axis.series[0].currentDataGrouping, key = grouping ?\n grouping.count + grouping.unitName :\n 'raw', overscroll = axis.options.overscroll, extremes = axis.getExtremes();\n let fakeAxis, fakeSeries = void 0, ordinalIndex = ordinal.index;\n // If this is the first time, or the ordinal index is deleted by\n // updatedData,\n // create it.\n if (!ordinalIndex) {\n ordinalIndex = ordinal.index = {};\n }\n if (!ordinalIndex[key]) {\n // Create a fake axis object where the extended ordinal\n // positions are emulated\n fakeAxis = {\n series: [],\n chart: chart,\n forceOrdinal: false,\n getExtremes: function () {\n return {\n min: extremes.dataMin,\n max: extremes.dataMax + overscroll\n };\n },\n getGroupPixelWidth: axisProto.getGroupPixelWidth,\n getTimeTicks: axisProto.getTimeTicks,\n options: {\n ordinal: true\n },\n ordinal: {\n getGroupIntervalFactor: this.getGroupIntervalFactor\n },\n ordinal2lin: axisProto.ordinal2lin,\n getIndexOfPoint: axisProto.getIndexOfPoint,\n val2lin: axisProto.val2lin // #2590\n };\n fakeAxis.ordinal.axis = fakeAxis;\n // Add the fake series to hold the full data, then apply\n // processData to it\n axis.series.forEach(function (series) {\n fakeSeries = {\n xAxis: fakeAxis,\n xData: series.xData.slice(),\n chart: chart,\n destroyGroupedData: H.noop,\n getProcessedData: Series.prototype.getProcessedData,\n applyGrouping: Series.prototype.applyGrouping\n };\n fakeSeries.xData = fakeSeries.xData.concat(ordinal.getOverscrollPositions());\n fakeSeries.options = {\n dataGrouping: grouping ? {\n firstAnchor: 'firstPoint',\n anchor: 'middle',\n lastAnchor: 'lastPoint',\n enabled: true,\n forced: true,\n // doesn't matter which, use the fastest\n approximation: 'open',\n units: [[\n grouping.unitName,\n [grouping.count]\n ]]\n } : {\n enabled: false\n }\n };\n fakeAxis.series.push(fakeSeries);\n series.processData.apply(fakeSeries);\n });\n // Force to use the ordinal when points are evenly spaced (e.g.\n // weeks), #3825.\n if ((fakeSeries.closestPointRange !==\n fakeSeries.basePointRange) &&\n fakeSeries.currentDataGrouping) {\n fakeAxis.forceOrdinal = true;\n }\n // Run beforeSetTickPositions to compute the ordinalPositions\n axis.ordinal.beforeSetTickPositions.apply({ axis: fakeAxis });\n // Cache it\n ordinalIndex[key] = fakeAxis.ordinal.positions;\n }\n return ordinalIndex[key];\n }\n /**\n * Find the factor to estimate how wide the plot area would have been if\n * ordinal gaps were included. This value is used to compute an imagined\n * plot width in order to establish the data grouping interval.\n *\n * A real world case is the intraday-candlestick example. Without this\n * logic, it would show the correct data grouping when viewing a range\n * within each day, but once moving the range to include the gap between\n * two days, the interval would include the cut-away night hours and the\n * data grouping would be wrong. So the below method tries to compensate\n * by identifying the most common point interval, in this case days.\n *\n * An opposite case is presented in issue #718. We have a long array of\n * daily data, then one point is appended one hour after the last point.\n * We expect the data grouping not to change.\n *\n * In the future, if we find cases where this estimation doesn't work\n * optimally, we might need to add a second pass to the data grouping\n * logic, where we do another run with a greater interval if the number\n * of data groups is more than a certain fraction of the desired group\n * count.\n * @private\n */\n getGroupIntervalFactor(xMin, xMax, series) {\n const ordinal = this, axis = ordinal.axis, processedXData = series.processedXData, len = processedXData.length, distances = [];\n let median, i, groupIntervalFactor = ordinal.groupIntervalFactor;\n // Only do this computation for the first series, let the other\n // inherit it (#2416)\n if (!groupIntervalFactor) {\n // Register all the distances in an array\n for (i = 0; i < len - 1; i++) {\n distances[i] = (processedXData[i + 1] -\n processedXData[i]);\n }\n // Sort them and find the median\n distances.sort(function (a, b) {\n return a - b;\n });\n median = distances[Math.floor(len / 2)];\n // Compensate for series that don't extend through the entire\n // axis extent. #1675.\n xMin = Math.max(xMin, processedXData[0]);\n xMax = Math.min(xMax, processedXData[len - 1]);\n ordinal.groupIntervalFactor = groupIntervalFactor =\n (len * median) / (xMax - xMin);\n }\n // Return the factor needed for data grouping\n return groupIntervalFactor;\n }\n /**\n * Get index of point inside the ordinal positions array.\n *\n * @private\n * @param {number} val\n * The pixel value of a point.\n *\n * @param {Array} [ordinallArray]\n * An array of all points available on the axis for the given data set.\n * Either ordinalPositions if the value is inside the plotArea or\n * extendedOrdinalPositions if not.\n */\n getIndexOfPoint(val, ordinalArray) {\n const ordinal = this, axis = ordinal.axis, firstPointVal = ordinal.positions ? ordinal.positions[0] : 0;\n // Check whether the series has at least one point inside the chart\n const hasPointsInside = function (series) {\n return series.points.some((point) => !!point.isInside);\n };\n let firstPointX;\n // When more series assign to axis, find the smallest one, #15987.\n axis.series.forEach((series) => {\n var _a;\n const firstPoint = (_a = series.points) === null || _a === void 0 ? void 0 : _a[0];\n if (defined(firstPoint === null || firstPoint === void 0 ? void 0 : firstPoint.plotX) &&\n (firstPoint.plotX < firstPointX ||\n !defined(firstPointX)) &&\n hasPointsInside(series)) {\n firstPointX = firstPoint.plotX;\n }\n });\n // If undefined, give a default value\n firstPointX !== null && firstPointX !== void 0 ? firstPointX : (firstPointX = axis.minPixelPadding);\n // Distance in pixels between two points on the ordinal axis in the\n // current zoom.\n const ordinalPointPixelInterval = axis.translationSlope * (ordinal.slope ||\n axis.closestPointRange ||\n ordinal.overscrollPointsRange), \n // toValue for the first point.\n shiftIndex = correctFloat((val - firstPointX) / ordinalPointPixelInterval);\n return Additions.findIndexOf(ordinalArray, firstPointVal, true) + shiftIndex;\n }\n /**\n * Get ticks for an ordinal axis within a range where points don't\n * exist. It is required when overscroll is enabled. We can't base on\n * points, because we may not have any, so we use approximated\n * pointRange and generate these ticks between Axis.dataMax,\n * Axis.dataMax + Axis.overscroll evenly spaced. Used in panning and\n * navigator scrolling.\n * @private\n */\n getOverscrollPositions() {\n const ordinal = this, axis = ordinal.axis, extraRange = axis.options.overscroll, distance = ordinal.overscrollPointsRange, positions = [];\n let max = axis.dataMax;\n if (defined(distance)) {\n // Max + pointRange because we need to scroll to the last\n while (max <= axis.dataMax + extraRange) {\n max += distance;\n positions.push(max);\n }\n }\n return positions;\n }\n /**\n * Make the tick intervals closer because the ordinal gaps make the\n * ticks spread out or cluster.\n * @private\n */\n postProcessTickInterval(tickInterval) {\n // Problem: https://jsfiddle.net/highcharts/FQm4E/1/. This is a case\n // where this algorithm doesn't work optimally. In this case, the\n // tick labels are spread out per week, but all the gaps reside\n // within weeks. So we have a situation where the labels are courser\n // than the ordinal gaps, and thus the tick interval should not be\n // altered.\n const ordinal = this, axis = ordinal.axis, ordinalSlope = ordinal.slope;\n let ret;\n if (ordinalSlope) {\n if (!axis.options.breaks) {\n ret = (tickInterval /\n (ordinalSlope / axis.closestPointRange));\n }\n else {\n ret = axis.closestPointRange || tickInterval; // #7275\n }\n }\n else {\n ret = tickInterval;\n }\n return ret;\n }\n }\n OrdinalAxis.Additions = Additions;\n })(OrdinalAxis || (OrdinalAxis = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return OrdinalAxis;\n });\n _registerModule(_modules, 'Series/HLC/HLCPoint.js', [_modules['Core/Series/SeriesRegistry.js']], function (SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: { prototype: { pointClass: ColumnPoint } } } = SeriesRegistry.seriesTypes;\n /* *\n *\n * Class\n *\n * */\n class HLCPoint extends ColumnPoint {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.close = void 0;\n this.high = void 0;\n this.low = void 0;\n this.options = void 0;\n this.plotClose = void 0;\n this.series = void 0;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCPoint;\n });\n _registerModule(_modules, 'Series/HLC/HLCSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * An HLC chart is a style of financial chart used to describe price\n * movements over time. It displays high, low and close values per\n * data point.\n *\n * @sample stock/demo/hlc/\n * HLC chart\n *\n * @extends plotOptions.column\n * @excluding borderColor, borderRadius, borderWidth, crisp, stacking,\n * stack\n * @product highstock\n * @optionparent plotOptions.hlc\n */\n const HLCSeriesDefaults = {\n /**\n * The approximate pixel width of each group. If for example a series\n * with 30 points is displayed over a 600 pixel wide plot area, no\n * grouping is performed. If however the series contains so many points\n * that the spacing is less than the groupPixelWidth, Highcharts will\n * try to group it into appropriate groups so that each is more or less\n * two pixels wide. Defaults to `5`.\n *\n * @type {number}\n * @default 5\n * @product highstock\n * @apioption plotOptions.hlc.dataGrouping.groupPixelWidth\n */\n /**\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @default hlc\n * @product highstock\n * @apioption plotOptions.hlc.dataGrouping.approximation\n */\n /**\n * @default close\n * @apioption plotOptions.hlc.colorKey\n */\n /**\n * The pixel width of the line/border. Defaults to `1`.\n *\n * @sample {highstock} stock/plotoptions/hlc-linewidth/\n * A greater line width\n *\n * @type {number}\n * @default 1\n * @product highstock\n *\n * @public\n */\n lineWidth: 1,\n tooltip: {\n pointFormat: '\\u25CF ' +\n ' {series.name}
' +\n 'High: {point.high}
' +\n 'Low: {point.low}
' +\n 'Close: {point.close}
'\n },\n /**\n * @type {number|null}\n */\n threshold: null,\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The pixel width of the line representing the HLC point.\n *\n * @type {number}\n * @default 3\n * @product highstock\n */\n lineWidth: 3\n }\n },\n /**\n * Determines which one of `high`, `low`, `close` values should\n * be represented as `point.y`, which is later used to set dataLabel\n * position and [compare](#plotOptions.series.compare).\n *\n * @sample {highstock} stock/plotoptions/hlc-pointvalkey/\n * Possible values\n *\n * @declare Highcharts.OptionsHLCPointValKeyValue\n * @type {string}\n * @default close\n * @validvalue [\"high\", \"low\", \"close\"]\n * @product highstock\n * @apioption plotOptions.hlc.pointValKey\n */\n /**\n * @default close\n * @apioption plotOptions.hlc.colorKey\n */\n stickyTracking: true\n };\n /**\n * A `hlc` series. If the [type](#series.hlc.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.hlc\n * @excluding dataParser, dataURL\n * @product highstock\n * @apioption series.hlc\n */\n /**\n * An array of data points for the series. For the `hlc` series type,\n * points can be given in the following ways:\n *\n * 1. An array of arrays with 4 or 3 values. In this case, the values correspond\n * to `x,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length of 3\\.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 5, 6, 7],\n * [1, 4, 8, 2],\n * [2, 3, 4, 10]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.hlc.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * high: 4,\n * low: 5,\n * close: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * high: 3,\n * low: 6,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number>|*>}\n * @extends series.arearange.data\n * @excluding y, marker\n * @product highstock\n * @apioption series.hlc.data\n */\n /**\n * The closing value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.hlc.data.close\n */\n (''); // keeps doclets above in JS file\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCSeriesDefaults;\n });\n _registerModule(_modules, 'Series/HLC/HLCSeries.js', [_modules['Series/HLC/HLCPoint.js'], _modules['Series/HLC/HLCSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (HLCPoint, HLCSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Pawel Lysy\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: ColumnSeries } = SeriesRegistry.seriesTypes;\n const { extend, merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The hlc series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.hlc\n *\n * @augments Highcharts.Series\n */\n class HLCSeries extends ColumnSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n this.yData = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extend the path if close is not between high and low.\n *\n * @param {SVGPath} path the path array of the point\n * @param {number} halfStrokeWidth\n * @param {number} value value of the point to which the stem should be extended\n */\n extendStem(path, halfStrokeWidth, value) {\n const start = path[0];\n const end = path[1];\n // We don't need to worry about crisp - close value\n // is already crisped and halfStrokeWidth should remove it.\n if (typeof start[2] === 'number') {\n start[2] = Math.max(value + halfStrokeWidth, start[2]);\n }\n if (typeof end[2] === 'number') {\n end[2] = Math.min(value - halfStrokeWidth, end[2]);\n }\n }\n /**\n * Function to create SVGPath of the point based on the\n * plot positions of this point.\n * @private\n */\n getPointPath(point, graphic) {\n // crisp vector coordinates\n const strokeWidth = graphic.strokeWidth(), series = point.series, crispCorr = (strokeWidth % 2) / 2, \n // #2596:\n crispX = Math.round(point.plotX) - crispCorr, halfWidth = Math.round(point.shapeArgs.width / 2);\n let plotClose = point.plotClose;\n // the vertical stem\n const path = [\n ['M', crispX, Math.round(point.yBottom)],\n ['L', crispX, Math.round(point.plotHigh)]\n ];\n // close\n if (point.close !== null) {\n plotClose = Math.round(point.plotClose) + crispCorr;\n path.push(['M', crispX, plotClose], ['L', crispX + halfWidth, plotClose]);\n series.extendStem(path, strokeWidth / 2, plotClose);\n }\n return path;\n }\n /**\n * Draw single point\n * @private\n */\n drawSinglePoint(point) {\n const series = point.series, chart = series.chart;\n let path, graphic = point.graphic;\n if (typeof point.plotY !== 'undefined') {\n // Create and/or update the graphic\n if (!graphic) {\n point.graphic = graphic = chart.renderer.path()\n .add(series.group);\n }\n if (!chart.styledMode) {\n graphic.attr(series.pointAttribs(point, (point.selected && 'select'))); // #3897\n }\n // crisp vector coordinates\n path = series.getPointPath(point, graphic);\n graphic[!graphic ? 'attr' : 'animate']({ d: path })\n .addClass(point.getClassName(), true);\n }\n }\n /**\n * Draw the data points\n * @private\n */\n drawPoints() {\n this.points.forEach(this.drawSinglePoint);\n }\n /**\n * @private\n * @function Highcharts.seriesTypes.hlc#init\n */\n init() {\n super.init.apply(this, arguments);\n this.options.stacking = void 0; // #8817\n }\n /**\n * Postprocess mapping between options and SVG attributes\n * @private\n */\n pointAttribs(point, state) {\n const attribs = super.pointAttribs.call(this, point, state);\n delete attribs.fill;\n return attribs;\n }\n toYData(point) {\n // return a plain array for speedy calculation\n return [point.high, point.low, point.close];\n }\n /**\n * Translate data points from raw values x and y to plotX and plotY\n *\n * @private\n * @function Highcharts.seriesTypes.hlc#translate\n */\n translate() {\n const series = this, yAxis = series.yAxis, names = (this.pointArrayMap && this.pointArrayMap.slice()) || [], translated = names.map((name) => `plot${name.charAt(0).toUpperCase() + name.slice(1)}`);\n translated.push('yBottom');\n names.push('low');\n super.translate.apply(series);\n // Do the translation\n series.points.forEach(function (point) {\n names.forEach(function (name, i) {\n let value = point[name];\n if (value !== null) {\n if (series.dataModify) {\n value = series.dataModify.modifyValue(value);\n }\n point[translated[i]] =\n yAxis.toPixels(value, true);\n }\n });\n // Align the tooltip to the high value to avoid covering the\n // point\n point.tooltipPos[1] =\n point.plotHigh + yAxis.pos - series.chart.plotTop;\n });\n }\n }\n HLCSeries.defaultOptions = merge(ColumnSeries.defaultOptions, HLCSeriesDefaults);\n extend(HLCSeries.prototype, {\n pointClass: HLCPoint,\n animate: null,\n directTouch: false,\n pointArrayMap: ['high', 'low', 'close'],\n pointAttrToOptions: {\n stroke: 'color',\n 'stroke-width': 'lineWidth'\n },\n pointValKey: 'close'\n });\n SeriesRegistry.registerSeriesType('hlc', HLCSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return HLCSeries;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCPoint.js', [_modules['Core/Series/SeriesRegistry.js']], function (SeriesRegistry) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { seriesTypes: { hlc: HLCSeries } } = SeriesRegistry;\n /* *\n *\n * Class\n *\n * */\n class OHLCPoint extends HLCSeries.prototype.pointClass {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.open = void 0;\n this.options = void 0;\n this.plotOpen = void 0;\n this.series = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Extend the parent method by adding up or down to the class name.\n * @private\n * @function Highcharts.seriesTypes.ohlc#getClassName\n */\n getClassName() {\n return super.getClassName.call(this) +\n (this.open < this.close ?\n ' highcharts-point-up' :\n ' highcharts-point-down');\n }\n /**\n * Save upColor as point color (#14826).\n * @private\n * @function Highcharts.seriesTypes.ohlc#resolveUpColor\n */\n resolveUpColor() {\n if (this.open < this.close &&\n !this.options.color &&\n this.series.options.upColor) {\n this.color = this.series.options.upColor;\n }\n }\n /**\n * Extend the parent method by saving upColor.\n * @private\n * @function Highcharts.seriesTypes.ohlc#resolveColor\n */\n resolveColor() {\n super.resolveColor();\n this.resolveUpColor();\n }\n /**\n * Extend the parent method by saving upColor.\n * @private\n * @function Highcharts.seriesTypes.ohlc#getZone\n *\n * @return {Highcharts.SeriesZonesOptionsObject}\n * The zone item.\n */\n getZone() {\n const zone = super.getZone();\n this.resolveUpColor();\n return zone;\n }\n /**\n * Extend the parent method by resolving up/down colors (#15849)\n * @private\n **/\n applyOptions() {\n super.applyOptions.apply(this, arguments);\n if (this.resolveColor) {\n this.resolveColor();\n }\n return this;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCPoint;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * An OHLC chart is a style of financial chart used to describe price\n * movements over time. It displays open, high, low and close values per\n * data point.\n *\n * @sample stock/demo/ohlc\n * OHLC chart\n *\n * @extends plotOptions.hlc\n * @product highstock\n * @optionparent plotOptions.ohlc\n */\n const OHLCSeriesDefaults = {\n /**\n * @type {Highcharts.DataGroupingApproximationValue|Function}\n * @default ohlc\n * @product highstock\n * @apioption plotOptions.ohlc.dataGrouping.approximation\n */\n /**\n * Determines which one of `open`, `high`, `low`, `close` values should\n * be represented as `point.y`, which is later used to set dataLabel\n * position and [compare](#plotOptions.series.compare).\n *\n * @declare Highcharts.OptionsPointValKeyValue\n * @default close\n * @validvalue [\"open\", \"high\", \"low\", \"close\"]\n * @product highstock\n * @apioption plotOptions.ohlc.pointValKey\n */\n /**\n * Line color for up points.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n * @apioption plotOptions.ohlc.upColor\n */\n tooltip: {\n pointFormat: '\\u25CF ' +\n ' {series.name}
' +\n 'Open: {point.open}
' +\n 'High: {point.high}
' +\n 'Low: {point.low}
' +\n 'Close: {point.close}
'\n }\n };\n /**\n * The parameter allows setting line series type and use OHLC indicators.\n * Data in OHLC format is required.\n *\n * @sample {highstock} stock/indicators/use-ohlc-data\n * Use OHLC data format to plot line chart\n *\n * @type {boolean}\n * @product highstock\n * @apioption plotOptions.line.useOhlcData\n */\n /**\n * A `ohlc` series. If the [type](#series.ohlc.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.ohlc\n * @excluding dataParser, dataURL\n * @product highstock\n * @apioption series.ohlc\n */\n /**\n * An array of data points for the series. For the `ohlc` series type,\n * points can be given in the following ways:\n *\n * 1. An array of arrays with 5 or 4 values. In this case, the values correspond\n * to `x,open,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length 4\\.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 6, 5, 6, 7],\n * [1, 9, 4, 8, 2],\n * [2, 6, 3, 4, 10]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.ohlc.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * open: 3,\n * high: 4,\n * low: 5,\n * close: 2,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * open: 4,\n * high: 3,\n * low: 6,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number,number>|*>}\n * @extends series.arearange.data\n * @excluding y, marker\n * @product highstock\n * @apioption series.ohlc.data\n */\n /**\n * The closing value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.ohlc.data.close\n */\n /**\n * The opening value of each data point.\n *\n * @type {number}\n * @product highstock\n * @apioption series.ohlc.data.open\n */\n ''; // adds doclets above to transpilat\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCSeriesDefaults;\n });\n _registerModule(_modules, 'Series/OHLC/OHLCSeries.js', [_modules['Series/OHLC/OHLCPoint.js'], _modules['Series/OHLC/OHLCSeriesDefaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (OHLCPoint, OHLCSeriesDefaults, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { seriesTypes: { hlc: HLCSeries } } = SeriesRegistry;\n const { addEvent, extend, merge } = U;\n /* *\n *\n * Constants\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n function onSeriesAfterSetOptions(e) {\n const options = e.options, dataGrouping = options.dataGrouping;\n if (dataGrouping &&\n options.useOhlcData &&\n options.id !== 'highcharts-navigator-series') {\n dataGrouping.approximation = 'ohlc';\n }\n }\n /**\n * Add useOhlcData option\n * @private\n */\n function onSeriesInit(eventOptions) {\n // eslint-disable-next-line no-invalid-this\n const series = this, options = eventOptions.options;\n if (options.useOhlcData &&\n options.id !== 'highcharts-navigator-series') {\n extend(series, {\n pointValKey: OHLCSeries.prototype.pointValKey,\n // keys: ohlcProto.keys, // @todo potentially nonsense\n pointArrayMap: OHLCSeries.prototype.pointArrayMap,\n toYData: OHLCSeries.prototype.toYData\n });\n }\n }\n /* *\n *\n * Class\n *\n * */\n /**\n * The ohlc series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.ohlc\n *\n * @augments Highcharts.Series\n */\n class OHLCSeries extends HLCSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Static Functions\n *\n * */\n static compose(SeriesClass, ..._args) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n addEvent(SeriesClass, 'afterSetOptions', onSeriesAfterSetOptions);\n addEvent(SeriesClass, 'init', onSeriesInit);\n }\n }\n /* *\n *\n * Functions\n *\n * */\n getPointPath(point, graphic) {\n const path = super.getPointPath(point, graphic), strokeWidth = graphic.strokeWidth(), crispCorr = (strokeWidth % 2) / 2, crispX = Math.round(point.plotX) - crispCorr, halfWidth = Math.round(point.shapeArgs.width / 2);\n let plotOpen = point.plotOpen;\n // crisp vector coordinates\n if (point.open !== null) {\n plotOpen = Math.round(point.plotOpen) + crispCorr;\n path.push(['M', crispX, plotOpen], ['L', crispX - halfWidth, plotOpen]);\n super.extendStem(path, strokeWidth / 2, plotOpen);\n }\n return path;\n }\n /**\n * Postprocess mapping between options and SVG attributes\n * @private\n */\n pointAttribs(point, state) {\n const attribs = super.pointAttribs.call(this, point, state), options = this.options;\n delete attribs.fill;\n if (!point.options.color &&\n options.upColor &&\n point.open < point.close) {\n attribs.stroke = options.upColor;\n }\n return attribs;\n }\n toYData(point) {\n // return a plain array for speedy calculation\n return [point.open, point.high, point.low, point.close];\n }\n }\n OHLCSeries.defaultOptions = merge(HLCSeries.defaultOptions, OHLCSeriesDefaults);\n extend(OHLCSeries.prototype, {\n pointClass: OHLCPoint,\n pointArrayMap: ['open', 'high', 'low', 'close']\n });\n SeriesRegistry.registerSeriesType('ohlc', OHLCSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return OHLCSeries;\n });\n _registerModule(_modules, 'Series/Candlestick/CandlestickSeriesDefaults.js', [_modules['Core/Defaults.js'], _modules['Core/Utilities.js']], function (D, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { merge } = U;\n /* *\n *\n * API Options\n *\n * */\n /**\n * A candlestick chart is a style of financial chart used to describe\n * price movements over time.\n *\n * @sample stock/demo/candlestick/\n * Candlestick chart\n *\n * @extends plotOptions.ohlc\n * @excluding borderColor,borderRadius,borderWidth\n * @product highstock\n * @optionparent plotOptions.candlestick\n */\n const CandlestickSeriesDefaults = {\n /**\n * The specific line color for up candle sticks. The default is to\n * inherit the general `lineColor` setting.\n *\n * @sample {highstock} stock/plotoptions/candlestick-linecolor/\n * Candlestick line colors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @since 1.3.6\n * @product highstock\n * @apioption plotOptions.candlestick.upLineColor\n */\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The pixel width of the line/border around the\n * candlestick.\n *\n * @product highstock\n */\n lineWidth: 2\n }\n },\n /**\n * @type {number|null}\n * @product highstock\n */\n threshold: null,\n /**\n * The color of the line/border of the candlestick.\n *\n * In styled mode, the line stroke can be set with the\n * `.highcharts-candlestick-series .highcahrts-point` rule.\n *\n * @see [upLineColor](#plotOptions.candlestick.upLineColor)\n *\n * @sample {highstock} stock/plotoptions/candlestick-linecolor/\n * Candlestick line colors\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highstock\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The pixel width of the candlestick line/border. Defaults to `1`.\n *\n *\n * In styled mode, the line stroke width can be set with the\n * `.highcharts-candlestick-series .highcahrts-point` rule.\n *\n * @product highstock\n */\n lineWidth: 1,\n /**\n * The fill color of the candlestick when values are rising.\n *\n * In styled mode, the up color can be set with the\n * `.highcharts-candlestick-series .highcharts-point-up` rule.\n *\n * @sample {highstock} stock/plotoptions/candlestick-color/\n * Custom colors\n * @sample {highstock} highcharts/css/candlestick/\n * Colors in styled mode\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #ffffff\n * @product highstock\n */\n upColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * @product highstock\n */\n stickyTracking: true\n };\n /**\n * A `candlestick` series. If the [type](#series.candlestick.type)\n * option is not specified, it is inherited from [chart.type](\n * #chart.type).\n *\n * @type {*}\n * @extends series,plotOptions.candlestick\n * @excluding dataParser, dataURL, marker\n * @product highstock\n * @apioption series.candlestick\n */\n /**\n * An array of data points for the series. For the `candlestick` series\n * type, points can be given in the following ways:\n *\n * 1. An array of arrays with 5 or 4 values. In this case, the values correspond\n * to `x,open,high,low,close`. If the first value is a string, it is applied\n * as the name of the point, and the `x` value is inferred. The `x` value can\n * also be omitted, in which case the inner arrays should be of length 4.\n * Then the `x` value is automatically calculated, either starting at 0 and\n * incremented by 1, or from `pointStart` and `pointInterval` given in the\n * series options.\n * ```js\n * data: [\n * [0, 7, 2, 0, 4],\n * [1, 1, 4, 2, 8],\n * [2, 3, 3, 9, 3]\n * ]\n * ```\n *\n * 2. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.candlestick.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * open: 9,\n * high: 2,\n * low: 4,\n * close: 6,\n * name: \"Point2\",\n * color: \"#00FF00\"\n * }, {\n * x: 1,\n * open: 1,\n * high: 4,\n * low: 7,\n * close: 7,\n * name: \"Point1\",\n * color: \"#FF00FF\"\n * }]\n * ```\n *\n * @type {Array|Array<(number|string),number,number,number,number>|*>}\n * @extends series.ohlc.data\n * @excluding y\n * @product highstock\n * @apioption series.candlestick.data\n */\n ''; // adds doclets above to transpilat\n /* *\n *\n * Default Export\n *\n * */\n\n return CandlestickSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Candlestick/CandlestickSeries.js', [_modules['Series/Candlestick/CandlestickSeriesDefaults.js'], _modules['Core/Defaults.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (CandlestickSeriesDefaults, D, SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { defaultOptions } = D;\n const { column: ColumnSeries, ohlc: OHLCSeries } = SeriesRegistry.seriesTypes;\n const { merge } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * The candlestick series type.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.candlestick\n *\n * @augments Highcharts.seriesTypes.ohlc\n */\n class CandlestickSeries extends OHLCSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Postprocess mapping between options and SVG attributes\n *\n * @private\n * @function Highcharts.seriesTypes.candlestick#pointAttribs\n */\n pointAttribs(point, state) {\n const attribs = ColumnSeries.prototype.pointAttribs.call(this, point, state), options = this.options, isUp = point.open < point.close, stroke = options.lineColor || this.color, color = point.color || this.color; // (#14826)\n attribs['stroke-width'] = options.lineWidth;\n attribs.fill = point.options.color ||\n (isUp ? (options.upColor || color) : color);\n attribs.stroke = point.options.lineColor ||\n (isUp ? (options.upLineColor || stroke) : stroke);\n // Select or hover states\n if (state) {\n const stateOptions = options.states[state];\n attribs.fill = stateOptions.color || attribs.fill;\n attribs.stroke = stateOptions.lineColor || attribs.stroke;\n attribs['stroke-width'] =\n stateOptions.lineWidth || attribs['stroke-width'];\n }\n return attribs;\n }\n /**\n * Draw the data points.\n *\n * @private\n * @function Highcharts.seriesTypes.candlestick#drawPoints\n */\n drawPoints() {\n const series = this, points = series.points, chart = series.chart, reversedYAxis = series.yAxis.reversed;\n for (const point of points) {\n let graphic = point.graphic, plotOpen, plotClose, topBox, bottomBox, hasTopWhisker, hasBottomWhisker, crispCorr, crispX, path, halfWidth;\n const isNew = !graphic;\n if (typeof point.plotY !== 'undefined') {\n if (!graphic) {\n point.graphic = graphic = chart.renderer.path()\n .add(series.group);\n }\n if (!series.chart.styledMode) {\n graphic\n .attr(series.pointAttribs(point, (point.selected && 'select'))) // #3897\n .shadow(series.options.shadow);\n }\n // Crisp vector coordinates\n crispCorr = (graphic.strokeWidth() % 2) / 2;\n // #2596:\n crispX = Math.round(point.plotX) - crispCorr;\n plotOpen = point.plotOpen;\n plotClose = point.plotClose;\n topBox = Math.min(plotOpen, plotClose);\n bottomBox = Math.max(plotOpen, plotClose);\n halfWidth = Math.round(point.shapeArgs.width / 2);\n hasTopWhisker = reversedYAxis ?\n bottomBox !== point.yBottom :\n Math.round(topBox) !==\n Math.round(point.plotHigh);\n hasBottomWhisker = reversedYAxis ?\n Math.round(topBox) !==\n Math.round(point.plotHigh) :\n bottomBox !== point.yBottom;\n topBox = Math.round(topBox) + crispCorr;\n bottomBox = Math.round(bottomBox) + crispCorr;\n // Create the path. Due to a bug in Chrome 49, the path is\n // first instanciated with no values, then the values\n // pushed. For unknown reasons, instanciating the path array\n // with all the values would lead to a crash when updating\n // frequently (#5193).\n path = [];\n path.push(['M', crispX - halfWidth, bottomBox], ['L', crispX - halfWidth, topBox], ['L', crispX + halfWidth, topBox], ['L', crispX + halfWidth, bottomBox], ['Z'], // Ensure a nice rectangle #2602\n ['M', crispX, topBox], [\n 'L',\n // #460, #2094\n crispX,\n hasTopWhisker ?\n Math.round(reversedYAxis ?\n point.yBottom :\n point.plotHigh) :\n topBox\n ], ['M', crispX, bottomBox], [\n 'L',\n // #460, #2094\n crispX,\n hasBottomWhisker ?\n Math.round(reversedYAxis ?\n point.plotHigh :\n point.yBottom) :\n bottomBox\n ]);\n graphic[isNew ? 'attr' : 'animate']({ d: path })\n .addClass(point.getClassName(), true);\n }\n }\n }\n }\n CandlestickSeries.defaultOptions = merge(OHLCSeries.defaultOptions, defaultOptions.plotOptions, { tooltip: OHLCSeries.defaultOptions.tooltip }, CandlestickSeriesDefaults);\n SeriesRegistry.registerSeriesType('candlestick', CandlestickSeries);\n /* *\n *\n * Default Export\n *\n * */\n\n return CandlestickSeries;\n });\n _registerModule(_modules, 'Series/Flags/FlagsPoint.js', [_modules['Core/Series/SeriesRegistry.js'], _modules['Core/Utilities.js']], function (SeriesRegistry, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { column: { prototype: { pointClass: ColumnPoint } } } = SeriesRegistry.seriesTypes;\n const { isNumber } = U;\n /* *\n *\n * Class\n *\n * */\n class FlagsPoint extends ColumnPoint {\n constructor() {\n /* *\n *\n * Properties\n *\n * */\n super(...arguments);\n this.options = void 0;\n this.series = void 0;\n this.ttBelow = false;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * @private\n */\n isValid() {\n // #9233 - Prevent from treating flags as null points (even if\n // they have no y values defined).\n return isNumber(this.y) || typeof this.y === 'undefined';\n }\n /**\n * @private\n */\n hasNewShapeType() {\n const shape = this.options.shape || this.series.options.shape;\n return this.graphic && shape && shape !== this.graphic.symbolKey;\n }\n }\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsPoint;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSeriesDefaults.js', [], function () {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n /* *\n *\n * API Options\n *\n * */\n /**\n * Flags are used to mark events in stock charts. They can be added on the\n * timeline, or attached to a specific series.\n *\n * @sample stock/demo/flags-general/\n * Flags on a line series\n *\n * @extends plotOptions.column\n * @excluding animation, borderColor, borderRadius, borderWidth,\n * colorByPoint, cropThreshold, dataGrouping, pointPadding,\n * pointWidth, turboThreshold\n * @product highstock\n * @optionparent plotOptions.flags\n */\n const FlagsSeriesDefaults = {\n /**\n * In case the flag is placed on a series, on what point key to place\n * it. Line and columns have one key, `y`. In range or OHLC-type series,\n * however, the flag can optionally be placed on the `open`, `high`,\n * `low` or `close` key.\n *\n * @sample {highstock} stock/plotoptions/flags-onkey/\n * Range series, flag on high\n *\n * @type {string}\n * @default y\n * @since 4.2.2\n * @product highstock\n * @validvalue [\"y\", \"open\", \"high\", \"low\", \"close\"]\n * @apioption plotOptions.flags.onKey\n */\n /**\n * The id of the series that the flags should be drawn on. If no id\n * is given, the flags are drawn on the x axis.\n *\n * @sample {highstock} stock/plotoptions/flags/\n * Flags on series and on x axis\n *\n * @type {string}\n * @product highstock\n * @apioption plotOptions.flags.onSeries\n */\n pointRange: 0,\n /**\n * Whether the flags are allowed to overlap sideways. If `false`, the\n * flags are moved sideways using an algorithm that seeks to place every\n * flag as close as possible to its original position.\n *\n * @sample {highstock} stock/plotoptions/flags-allowoverlapx\n * Allow sideways overlap\n *\n * @since 6.0.4\n */\n allowOverlapX: false,\n /**\n * The shape of the marker. Can be one of \"flag\", \"circlepin\",\n * \"squarepin\", or an image of the format `url(/path-to-image.jpg)`.\n * Individual shapes can also be set for each point.\n *\n * @sample {highstock} stock/plotoptions/flags/\n * Different shapes\n *\n * @type {Highcharts.FlagsShapeValue}\n * @product highstock\n */\n shape: 'flag',\n /**\n * When multiple flags in the same series fall on the same value, this\n * number determines the vertical offset between them.\n *\n * @sample {highstock} stock/plotoptions/flags-stackdistance/\n * A greater stack distance\n *\n * @product highstock\n */\n stackDistance: 12,\n /**\n * Text alignment for the text inside the flag.\n *\n * @since 5.0.0\n * @product highstock\n * @validvalue [\"left\", \"center\", \"right\"]\n */\n textAlign: 'center',\n /**\n * Specific tooltip options for flag series. Flag series tooltips are\n * different from most other types in that a flag doesn't have a data\n * value, so the tooltip rather displays the `text` option for each\n * point.\n *\n * @extends plotOptions.series.tooltip\n * @excluding changeDecimals, valueDecimals, valuePrefix, valueSuffix\n * @product highstock\n */\n tooltip: {\n pointFormat: '{point.text}'\n },\n /**\n * @type {number|null}\n */\n threshold: null,\n /**\n * The text to display on each flag. This can be defined on series\n * level, or individually for each point. Defaults to `\"A\"`.\n *\n * @type {string}\n * @default A\n * @product highstock\n * @apioption plotOptions.flags.title\n */\n /**\n * The y position of the top left corner of the flag relative to either\n * the series (if onSeries is defined), or the x axis. Defaults to\n * `-30`.\n *\n * @product highstock\n */\n y: -30,\n /**\n * Whether to use HTML to render the flag texts. Using HTML allows for\n * advanced formatting, images and reliable bi-directional text\n * rendering. Note that exported images won't respect the HTML, and that\n * HTML won't respect Z-index settings.\n *\n * @type {boolean}\n * @default false\n * @since 1.3\n * @product highstock\n * @apioption plotOptions.flags.useHTML\n */\n /**\n * Fixed width of the flag's shape. By default, width is autocalculated\n * according to the flag's title.\n *\n * @sample {highstock} stock/demo/flags-shapes/\n * Flags with fixed width\n *\n * @type {number}\n * @product highstock\n * @apioption plotOptions.flags.width\n */\n /**\n * Fixed height of the flag's shape. By default, height is\n * autocalculated according to the flag's title.\n *\n * @type {number}\n * @product highstock\n * @apioption plotOptions.flags.height\n */\n /**\n * The fill color for the flags.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n fillColor: \"#ffffff\" /* Palette.backgroundColor */,\n /**\n * The color of the line/border of the flag.\n *\n * In styled mode, the stroke is set in the\n * `.highcharts-flag-series.highcharts-point` rule.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @default #000000\n * @product highstock\n * @apioption plotOptions.flags.lineColor\n */\n /**\n * The pixel width of the flag's line/border.\n *\n * @product highstock\n */\n lineWidth: 1,\n states: {\n /**\n * @extends plotOptions.column.states.hover\n * @product highstock\n */\n hover: {\n /**\n * The color of the line/border of the flag.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n lineColor: \"#000000\" /* Palette.neutralColor100 */,\n /**\n * The fill or background color of the flag.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n */\n fillColor: \"#ccd3ff\" /* Palette.highlightColor20 */\n }\n },\n /**\n * The text styles of the flag.\n *\n * In styled mode, the styles are set in the\n * `.highcharts-flag-series .highcharts-point` rule.\n *\n * @type {Highcharts.CSSObject}\n * @default {\"fontSize\": \"11px\", \"fontWeight\": \"bold\"}\n * @product highstock\n */\n style: {\n /** @ignore-option */\n fontSize: '0.7em',\n /** @ignore-option */\n fontWeight: 'bold'\n }\n };\n /**\n * A `flags` series. If the [type](#series.flags.type) option is not\n * specified, it is inherited from [chart.type](#chart.type).\n *\n * @extends series,plotOptions.flags\n * @excluding animation, borderColor, borderRadius, borderWidth, colorByPoint,\n * connectNulls, cropThreshold, dashStyle, dataGrouping, dataParser,\n * dataURL, gapSize, gapUnit, linecap, lineWidth, marker,\n * pointPadding, pointWidth, step, turboThreshold, useOhlcData\n * @product highstock\n * @apioption series.flags\n */\n /**\n * An array of data points for the series. For the `flags` series type,\n * points can be given in the following ways:\n *\n * 1. An array of objects with named values. The following snippet shows only a\n * few settings, see the complete options set below. If the total number of\n * data points exceeds the series'\n * [turboThreshold](#series.flags.turboThreshold), this option is not\n * available.\n * ```js\n * data: [{\n * x: 1,\n * title: \"A\",\n * text: \"First event\"\n * }, {\n * x: 1,\n * title: \"B\",\n * text: \"Second event\"\n * }]\n * ```\n *\n * @type {Array<*>}\n * @extends series.line.data\n * @excluding dataLabels, marker, name, y\n * @product highstock\n * @apioption series.flags.data\n */\n /**\n * The fill color of an individual flag. By default it inherits from\n * the series color.\n *\n * @type {Highcharts.ColorString|Highcharts.GradientColorObject|Highcharts.PatternObject}\n * @product highstock\n * @apioption series.flags.data.fillColor\n */\n /**\n * The longer text to be shown in the flag's tooltip.\n *\n * @type {string}\n * @product highstock\n * @apioption series.flags.data.text\n */\n /**\n * The short text to be shown on the flag.\n *\n * @type {string}\n * @product highstock\n * @apioption series.flags.data.title\n */\n ''; // keeps doclets above in transpiled file\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsSeriesDefaults;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSymbols.js', [_modules['Core/Renderer/RendererRegistry.js']], function (RendererRegistry) {\n /* *\n *\n * Imports\n *\n * */\n /* *\n *\n * Composition\n *\n * */\n var FlagsSymbols;\n (function (FlagsSymbols) {\n /* *\n *\n * Constants\n *\n * */\n const modifiedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(SVGRendererClass) {\n if (modifiedMembers.indexOf(SVGRendererClass) === -1) {\n modifiedMembers.push(SVGRendererClass);\n const symbols = SVGRendererClass.prototype.symbols;\n symbols.flag = flag;\n createPinSymbol(symbols, 'circle');\n createPinSymbol(symbols, 'square');\n }\n const RendererClass = RendererRegistry.getRendererType();\n // The symbol callbacks are generated on the SVGRenderer object in all\n // browsers.\n if (modifiedMembers.indexOf(RendererClass)) {\n modifiedMembers.push(RendererClass);\n }\n }\n FlagsSymbols.compose = compose;\n /**\n * Create the flag icon with anchor.\n * @private\n */\n function flag(x, y, w, h, options) {\n const anchorX = (options && options.anchorX) || x, anchorY = (options && options.anchorY) || y;\n // To do: unwanted any cast because symbols.circle has wrong type, it\n // actually returns an SVGPathArray\n const path = this.circle(anchorX - 1, anchorY - 1, 2, 2);\n path.push(['M', anchorX, anchorY], ['L', x, y + h], ['L', x, y], ['L', x + w, y], ['L', x + w, y + h], ['L', x, y + h], ['Z']);\n return path;\n }\n /**\n * Create the circlepin and squarepin icons with anchor.\n * @private\n */\n function createPinSymbol(symbols, shape) {\n symbols[(shape + 'pin')] = function (x, y, w, h, options) {\n const anchorX = options && options.anchorX, anchorY = options && options.anchorY;\n let path;\n // For single-letter flags, make sure circular flags are not taller\n // than their width\n if (shape === 'circle' && h > w) {\n x -= Math.round((h - w) / 2);\n w = h;\n }\n path = (symbols[shape])(x, y, w, h);\n if (anchorX && anchorY) {\n /**\n * If the label is below the anchor, draw the connecting line\n * from the top edge of the label, otherwise start drawing from\n * the bottom edge\n */\n let labelX = anchorX;\n if (shape === 'circle') {\n labelX = x + w / 2;\n }\n else {\n const startSeg = path[0];\n const endSeg = path[1];\n if (startSeg[0] === 'M' && endSeg[0] === 'L') {\n labelX = (startSeg[1] + endSeg[1]) / 2;\n }\n }\n const labelY = (y > anchorY) ? y : y + h;\n path.push([\n 'M',\n labelX,\n labelY\n ], [\n 'L',\n anchorX,\n anchorY\n ]);\n path = path.concat(symbols.circle(anchorX - 1, anchorY - 1, 2, 2));\n }\n return path;\n };\n }\n })(FlagsSymbols || (FlagsSymbols = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return FlagsSymbols;\n });\n _registerModule(_modules, 'Series/OnSeriesComposition.js', [_modules['Series/Column/ColumnSeries.js'], _modules['Core/Series/Series.js'], _modules['Core/Utilities.js']], function (ColumnSeries, Series, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { prototype: columnProto } = ColumnSeries;\n const { prototype: seriesProto } = Series;\n const { defined, stableSort } = U;\n /* *\n *\n * Composition\n *\n * */\n var OnSeriesComposition;\n (function (OnSeriesComposition) {\n /* *\n *\n * Declarations\n *\n * */\n /* *\n *\n * Properties\n *\n * */\n const composedMembers = [];\n /* *\n *\n * Functions\n *\n * */\n /* eslint-disable valid-jsdoc */\n /**\n * @private\n */\n function compose(SeriesClass) {\n if (U.pushUnique(composedMembers, SeriesClass)) {\n const seriesProto = SeriesClass.prototype;\n seriesProto.getPlotBox = getPlotBox;\n seriesProto.translate = translate;\n }\n return SeriesClass;\n }\n OnSeriesComposition.compose = compose;\n /**\n * Override getPlotBox. If the onSeries option is valid, return the plot box\n * of the onSeries, otherwise proceed as usual.\n *\n * @private\n */\n function getPlotBox(name) {\n return seriesProto.getPlotBox.call((this.options.onSeries &&\n this.chart.get(this.options.onSeries)) || this, name);\n }\n OnSeriesComposition.getPlotBox = getPlotBox;\n /**\n * Extend the translate method by placing the point on the related series\n *\n * @private\n */\n function translate() {\n columnProto.translate.apply(this);\n const series = this, options = series.options, chart = series.chart, points = series.points, optionsOnSeries = options.onSeries, onSeries = (optionsOnSeries &&\n chart.get(optionsOnSeries)), step = onSeries && onSeries.options.step, onData = (onSeries && onSeries.points), inverted = chart.inverted, xAxis = series.xAxis, yAxis = series.yAxis;\n let cursor = points.length - 1, point, lastPoint, onKey = options.onKey || 'y', i = onData && onData.length, xOffset = 0, leftPoint, lastX, rightPoint, currentDataGrouping, distanceRatio;\n // relate to a master series\n if (onSeries && onSeries.visible && i) {\n xOffset = (onSeries.pointXOffset || 0) + (onSeries.barW || 0) / 2;\n currentDataGrouping = onSeries.currentDataGrouping;\n lastX = (onData[i - 1].x +\n (currentDataGrouping ? currentDataGrouping.totalRange : 0)); // #2374\n // sort the data points\n stableSort(points, (a, b) => (a.x - b.x));\n onKey = 'plot' + onKey[0].toUpperCase() + onKey.substr(1);\n while (i-- && points[cursor]) {\n leftPoint = onData[i];\n point = points[cursor];\n point.y = leftPoint.y;\n if (leftPoint.x <= point.x &&\n typeof leftPoint[onKey] !== 'undefined') {\n if (point.x <= lastX) { // #803\n point.plotY = leftPoint[onKey];\n // interpolate between points, #666\n if (leftPoint.x < point.x &&\n !step) {\n rightPoint = onData[i + 1];\n if (rightPoint &&\n typeof rightPoint[onKey] !== 'undefined') {\n // the distance ratio, between 0 and 1\n distanceRatio =\n (point.x - leftPoint.x) /\n (rightPoint.x - leftPoint.x);\n point.plotY +=\n distanceRatio *\n // the plotY distance\n (rightPoint[onKey] - leftPoint[onKey]);\n point.y +=\n distanceRatio *\n (rightPoint.y - leftPoint.y);\n }\n }\n }\n cursor--;\n i++; // check again for points in the same x position\n if (cursor < 0) {\n break;\n }\n }\n }\n }\n // Add plotY position and handle stacking\n points.forEach((point, i) => {\n let stackIndex;\n point.plotX += xOffset; // #2049\n // Undefined plotY means the point is either on axis, outside series\n // range or hidden series. If the series is outside the range of the\n // x axis it should fall through with an undefined plotY, but then\n // we must remove the shapeArgs (#847). For inverted charts, we need\n // to calculate position anyway, because series.invertGroups is not\n // defined\n if (typeof point.plotY === 'undefined' || inverted) {\n if (point.plotX >= 0 &&\n point.plotX <= xAxis.len) {\n // We're inside xAxis range\n if (inverted) {\n point.plotY = xAxis.translate(point.x, 0, 1, 0, 1);\n point.plotX = defined(point.y) ?\n yAxis.translate(point.y, 0, 0, 0, 1) :\n 0;\n }\n else {\n point.plotY = (xAxis.opposite ? 0 : series.yAxis.len) +\n xAxis.offset; // For the windbarb demo\n }\n }\n else {\n point.shapeArgs = {}; // 847\n }\n }\n // if multiple flags appear at the same x, order them into a stack\n lastPoint = points[i - 1];\n if (lastPoint && lastPoint.plotX === point.plotX) {\n if (typeof lastPoint.stackIndex === 'undefined') {\n lastPoint.stackIndex = 0;\n }\n stackIndex = lastPoint.stackIndex + 1;\n }\n point.stackIndex = stackIndex; // #3639\n });\n this.onSeries = onSeries;\n }\n OnSeriesComposition.translate = translate;\n })(OnSeriesComposition || (OnSeriesComposition = {}));\n /* *\n *\n * Default Export\n *\n * */\n\n return OnSeriesComposition;\n });\n _registerModule(_modules, 'Series/Flags/FlagsSeries.js', [_modules['Series/Flags/FlagsPoint.js'], _modules['Series/Flags/FlagsSeriesDefaults.js'], _modules['Series/Flags/FlagsSymbols.js'], _modules['Core/Globals.js'], _modules['Series/OnSeriesComposition.js'], _modules['Core/Renderer/RendererUtilities.js'], _modules['Core/Series/SeriesRegistry.js'], _modules['Core/Renderer/SVG/SVGElement.js'], _modules['Core/Utilities.js']], function (FlagsPoint, FlagsSeriesDefaults, FlagsSymbols, H, OnSeriesComposition, R, SeriesRegistry, SVGElement, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { noop } = H;\n const { distribute } = R;\n const { series: Series, seriesTypes: { column: ColumnSeries } } = SeriesRegistry;\n const { addEvent, defined, extend, merge, objectEach, wrap } = U;\n /* *\n *\n * Classes\n *\n * */\n /**\n * The Flags series.\n *\n * @private\n * @class\n * @name Highcharts.seriesTypes.flags\n *\n * @augments Highcharts.Series\n */\n class FlagsSeries extends ColumnSeries {\n constructor() {\n /* *\n *\n * Static Properties\n *\n * */\n super(...arguments);\n /* *\n *\n * Properties\n *\n * */\n this.data = void 0;\n this.options = void 0;\n this.points = void 0;\n }\n /* *\n *\n * Functions\n *\n * */\n /**\n * Disable animation, but keep clipping (#8546).\n * @private\n */\n animate(init) {\n if (init) {\n this.setClip();\n }\n }\n /**\n * Draw the markers.\n * @private\n */\n drawPoints() {\n const series = this, points = series.points, chart = series.chart, renderer = chart.renderer, inverted = chart.inverted, options = series.options, optionsY = options.y, yAxis = series.yAxis, boxesMap = {}, boxes = [];\n let plotX, plotY, shape, i, point, graphic, stackIndex, anchorY, attribs, outsideRight, centered;\n i = points.length;\n while (i--) {\n point = points[i];\n outsideRight =\n (inverted ? point.plotY : point.plotX) >\n series.xAxis.len;\n plotX = point.plotX;\n stackIndex = point.stackIndex;\n shape = point.options.shape || options.shape;\n plotY = point.plotY;\n if (typeof plotY !== 'undefined') {\n plotY = point.plotY + optionsY -\n (typeof stackIndex !== 'undefined' &&\n (stackIndex * options.stackDistance));\n }\n // skip connectors for higher level stacked points\n point.anchorX = stackIndex ? void 0 : point.plotX;\n anchorY = stackIndex ? void 0 : point.plotY;\n centered = shape !== 'flag';\n graphic = point.graphic;\n // Only draw the point if y is defined and the flag is within\n // the visible area\n if (typeof plotY !== 'undefined' &&\n plotX >= 0 &&\n !outsideRight) {\n // #15384\n if (graphic && point.hasNewShapeType()) {\n graphic = graphic.destroy();\n }\n // Create the flag\n if (!graphic) {\n graphic = point.graphic = renderer.label('', null, null, shape, null, null, options.useHTML)\n .addClass('highcharts-point')\n .add(series.markerGroup);\n // Add reference to the point for tracker (#6303)\n if (point.graphic.div) {\n point.graphic.div.point = point;\n }\n graphic.isNew = true;\n }\n graphic.attr({\n align: centered ? 'center' : 'left',\n width: options.width,\n height: options.height,\n 'text-align': options.textAlign\n });\n if (!chart.styledMode) {\n graphic\n .attr(series.pointAttribs(point))\n .css(merge(options.style, point.style))\n .shadow(options.shadow);\n }\n if (plotX > 0) { // #3119\n plotX -= graphic.strokeWidth() % 2; // #4285\n }\n // Plant the flag\n attribs = {\n y: plotY,\n anchorY: anchorY\n };\n if (options.allowOverlapX) {\n attribs.x = plotX;\n attribs.anchorX = point.anchorX;\n }\n graphic.attr({\n text: point.options.title || options.title || 'A'\n })[graphic.isNew ? 'attr' : 'animate'](attribs);\n // Rig for the distribute function\n if (!options.allowOverlapX) {\n if (!boxesMap[point.plotX]) {\n boxesMap[point.plotX] = {\n align: centered ? 0.5 : 0,\n size: graphic.width,\n target: plotX,\n anchorX: plotX\n };\n }\n else {\n boxesMap[point.plotX].size = Math.max(boxesMap[point.plotX].size, graphic.width);\n }\n }\n // Set the tooltip anchor position\n point.tooltipPos = [\n plotX,\n plotY + yAxis.pos - chart.plotTop\n ]; // #6327\n }\n else if (graphic) {\n point.graphic = graphic.destroy();\n }\n }\n // Handle X-dimension overlapping\n if (!options.allowOverlapX) {\n let maxDistance = 100;\n objectEach(boxesMap, function (box) {\n box.plotX = box.anchorX;\n boxes.push(box);\n maxDistance = Math.max(box.size, maxDistance);\n });\n // If necessary (for overlapping or long labels) distribute it\n // depending on the label width or a hardcoded value, #16041.\n distribute(boxes, inverted ? yAxis.len : this.xAxis.len, maxDistance);\n for (const point of points) {\n const plotX = point.plotX, graphic = point.graphic, box = graphic && boxesMap[plotX];\n if (box && graphic) {\n // Hide flag when its box position is not specified\n // (#8573, #9299)\n if (!defined(box.pos)) {\n graphic.hide().isNew = true;\n }\n else {\n graphic[graphic.isNew ? 'attr' : 'animate']({\n x: box.pos + (box.align || 0) * box.size,\n anchorX: point.anchorX\n }).show().isNew = false;\n }\n }\n }\n }\n // Can be a mix of SVG and HTML and we need events for both (#6303)\n if (options.useHTML && series.markerGroup) {\n wrap(series.markerGroup, 'on', function (proceed) {\n return SVGElement.prototype.on.apply(\n // for HTML\n // eslint-disable-next-line no-invalid-this\n proceed.apply(this, [].slice.call(arguments, 1)), \n // and for SVG\n [].slice.call(arguments, 1));\n });\n }\n }\n /**\n * Extend the column trackers with listeners to expand and contract\n * stacks.\n * @private\n */\n drawTracker() {\n const series = this, points = series.points;\n super.drawTracker();\n /* *\n * Bring each stacked flag up on mouse over, this allows readability\n * of vertically stacked elements as well as tight points on the x\n * axis. #1924.\n */\n for (const point of points) {\n const graphic = point.graphic;\n if (graphic) {\n if (point.unbindMouseOver) {\n point.unbindMouseOver();\n }\n point.unbindMouseOver = addEvent(graphic.element, 'mouseover', function () {\n // Raise this point\n if (point.stackIndex > 0 &&\n !point.raised) {\n point._y = graphic.y;\n graphic.attr({\n y: point._y - 8\n });\n point.raised = true;\n }\n // Revert other raised points\n for (const otherPoint of points) {\n if (otherPoint !== point &&\n otherPoint.raised &&\n otherPoint.graphic) {\n otherPoint.graphic.attr({\n y: otherPoint._y\n });\n otherPoint.raised = false;\n }\n }\n });\n }\n }\n }\n /**\n * Get presentational attributes\n * @private\n */\n pointAttribs(point, state) {\n const options = this.options, color = (point && point.color) || this.color;\n let lineColor = options.lineColor, lineWidth = (point && point.lineWidth), fill = (point && point.fillColor) || options.fillColor;\n if (state) {\n fill = options.states[state].fillColor;\n lineColor = options.states[state].lineColor;\n lineWidth = options.states[state].lineWidth;\n }\n return {\n fill: fill || color,\n stroke: lineColor || color,\n 'stroke-width': lineWidth || options.lineWidth || 0\n };\n }\n /**\n * @private\n */\n setClip() {\n Series.prototype.setClip.apply(this, arguments);\n if (this.options.clip !== false &&\n this.sharedClipKey &&\n this.markerGroup) {\n this.markerGroup.clip(this.chart.sharedClips[this.sharedClipKey]);\n }\n }\n }\n FlagsSeries.compose = FlagsSymbols.compose;\n FlagsSeries.defaultOptions = merge(ColumnSeries.defaultOptions, FlagsSeriesDefaults);\n OnSeriesComposition.compose(FlagsSeries);\n extend(FlagsSeries.prototype, {\n allowDG: false,\n forceCrop: true,\n invertible: false,\n noSharedTooltip: true,\n pointClass: FlagsPoint,\n sorted: false,\n takeOrdinalPosition: false,\n trackerGroups: ['markerGroup'],\n buildKDTree: noop,\n /**\n * Inherit the initialization from base Series.\n * @private\n */\n init: Series.prototype.init\n });\n SeriesRegistry.registerSeriesType('flags', FlagsSeries);\n /* *\n *\n * Default Export\n *\n * */\n /* *\n *\n * API Declarations\n *\n * */\n /**\n * @typedef {\"circlepin\"|\"flag\"|\"squarepin\"} Highcharts.FlagsShapeValue\n */\n ''; // detach doclets above\n\n return FlagsSeries;\n });\n _registerModule(_modules, 'Core/Chart/StockChart.js', [_modules['Core/Axis/Axis.js'], _modules['Core/Chart/Chart.js'], _modules['Core/Templating.js'], _modules['Core/Defaults.js'], _modules['Stock/Navigator/NavigatorDefaults.js'], _modules['Stock/RangeSelector/RangeSelectorDefaults.js'], _modules['Stock/Scrollbar/ScrollbarDefaults.js'], _modules['Core/Series/Series.js'], _modules['Core/Renderer/SVG/SVGRenderer.js'], _modules['Core/Utilities.js']], function (Axis, Chart, F, D, NavigatorDefaults, RangeSelectorDefaults, ScrollbarDefaults, Series, SVGRenderer, U) {\n /* *\n *\n * (c) 2010-2021 Torstein Honsi\n *\n * License: www.highcharts.com/license\n *\n * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!\n *\n * */\n const { format } = F;\n const { getOptions } = D;\n const { addEvent, clamp, defined, extend, find, isNumber, isString, merge, pick, splat } = U;\n /* *\n *\n * Class\n *\n * */\n /**\n * Stock-optimized chart. Use {@link Highcharts.Chart|Chart} for common charts.\n *\n * @requires modules/stock\n *\n * @class\n * @name Highcharts.StockChart\n * @extends Highcharts.Chart\n */\n class StockChart extends Chart {\n /**\n * Initializes the chart. The constructor's arguments are passed on\n * directly.\n *\n * @function Highcharts.StockChart#init\n *\n * @param {Highcharts.Options} userOptions\n * Custom options.\n *\n * @param {Function} [callback]\n * Function to run when the chart has loaded and and all external\n * images are loaded.\n *\n *\n * @emits Highcharts.StockChart#event:init\n * @emits Highcharts.StockChart#event:afterInit\n */\n init(userOptions, callback) {\n const defaultOptions = getOptions(), xAxisOptions = userOptions.xAxis, yAxisOptions = userOptions.yAxis, \n // Always disable startOnTick:true on the main axis when the\n // navigator is enabled (#1090)\n navigatorEnabled = pick(userOptions.navigator && userOptions.navigator.enabled, NavigatorDefaults.enabled, true);\n // Avoid doing these twice\n userOptions.xAxis = userOptions.yAxis = void 0;\n const options = merge({\n chart: {\n panning: {\n enabled: true,\n type: 'x'\n },\n zooming: {\n pinchType: 'x'\n }\n },\n navigator: {\n enabled: navigatorEnabled\n },\n scrollbar: {\n // #4988 - check if setOptions was called\n enabled: pick(ScrollbarDefaults.enabled, true)\n },\n rangeSelector: {\n // #4988 - check if setOptions was called\n enabled: pick(RangeSelectorDefaults.rangeSelector.enabled, true)\n },\n title: {\n text: null\n },\n tooltip: {\n split: pick(defaultOptions.tooltip.split, true),\n crosshairs: true\n },\n legend: {\n enabled: false\n }\n }, userOptions, // user's options\n {\n isStock: true // internal flag\n });\n userOptions.xAxis = xAxisOptions;\n userOptions.yAxis = yAxisOptions;\n // apply X axis options to both single and multi y axes\n options.xAxis = splat(userOptions.xAxis || {}).map(function (xAxisOptions, i) {\n return merge(getDefaultAxisOptions('xAxis', xAxisOptions), defaultOptions.xAxis, // #3802\n // #7690\n defaultOptions.xAxis && defaultOptions.xAxis[i], xAxisOptions, // user options\n getForcedAxisOptions('xAxis', userOptions));\n });\n // apply Y axis options to both single and multi y axes\n options.yAxis = splat(userOptions.yAxis || {}).map(function (yAxisOptions, i) {\n return merge(getDefaultAxisOptions('yAxis', yAxisOptions), defaultOptions.yAxis, // #3802\n // #7690\n defaultOptions.yAxis && defaultOptions.yAxis[i], yAxisOptions // user options\n );\n });\n super.init(options, callback);\n }\n /**\n * Factory for creating different axis types.\n * Extended to add stock defaults.\n *\n * @private\n * @function Highcharts.StockChart#createAxis\n * @param {string} coll\n * An axis type.\n * @param {Chart.CreateAxisOptionsObject} options\n * The axis creation options.\n */\n createAxis(coll, options) {\n options.axis = merge(getDefaultAxisOptions(coll, options.axis), options.axis, getForcedAxisOptions(coll, this.userOptions));\n return super.createAxis(coll, options);\n }\n }\n /* eslint-disable no-invalid-this, valid-jsdoc */\n (function (StockChart) {\n /**\n * Factory function for creating new stock charts. Creates a new\n * {@link Highcharts.StockChart|StockChart} object with different default\n * options than the basic Chart.\n *\n * @example\n * let chart = Highcharts.stockChart('container', {\n * series: [{\n * data: [1, 2, 3, 4, 5, 6, 7, 8, 9],\n * pointInterval: 24 * 60 * 60 * 1000\n * }]\n * });\n *\n * @function Highcharts.stockChart\n *\n * @param {string|Highcharts.HTMLDOMElement} [renderTo]\n * The DOM element to render to, or its id.\n *\n * @param {Highcharts.Options} options\n * The chart options structure as described in the\n * [options reference](https://api.highcharts.com/highstock).\n *\n * @param {Highcharts.ChartCallbackFunction} [callback]\n * A function to execute when the chart object is finished\n * rendering and all external image files (`chart.backgroundImage`,\n * `chart.plotBackgroundImage` etc) are loaded. Defining a\n * [chart.events.load](https://api.highcharts.com/highstock/chart.events.load)\n * handler is equivalent.\n *\n * @return {Highcharts.StockChart}\n * The chart object.\n */\n function stockChart(a, b, c) {\n return new StockChart(a, b, c);\n }\n StockChart.stockChart = stockChart;\n })(StockChart || (StockChart = {}));\n /**\n * Get stock-specific default axis options.\n *\n * @private\n * @function getDefaultAxisOptions\n */\n function getDefaultAxisOptions(type, options) {\n if (type === 'xAxis') {\n return {\n minPadding: 0,\n maxPadding: 0,\n overscroll: 0,\n ordinal: true,\n title: {\n text: null\n },\n labels: {\n overflow: 'justify'\n },\n showLastLabel: true\n };\n }\n if (type === 'yAxis') {\n return {\n labels: {\n y: -2\n },\n opposite: pick(options.opposite, true),\n showLastLabel: !!(\n // #6104, show last label by default for category axes\n options.categories ||\n options.type === 'category'),\n title: {\n text: null\n }\n };\n }\n return {};\n }\n /**\n * Get stock-specific forced axis options.\n *\n * @private\n * @function getForcedAxisOptions\n */\n function getForcedAxisOptions(type, chartOptions) {\n if (type === 'xAxis') {\n // Always disable startOnTick:true on the main axis when the navigator\n // is enabled (#1090)\n const navigatorEnabled = pick(chartOptions.navigator && chartOptions.navigator.enabled, NavigatorDefaults.enabled, true);\n const axisOptions = {\n type: 'datetime',\n categories: void 0\n };\n if (navigatorEnabled) {\n axisOptions.startOnTick = false;\n axisOptions.endOnTick = false;\n }\n return axisOptions;\n }\n return {};\n }\n /* *\n *\n * Compositions\n *\n * */\n // Handle som Stock-specific series defaults, override the plotOptions before\n // series options are handled.\n addEvent(Series, 'setOptions', function (e) {\n let overrides;\n if (this.chart.options.isStock) {\n if (this.is('column') || this.is('columnrange')) {\n overrides = {\n borderWidth: 0,\n shadow: false\n };\n }\n else if (!this.is('scatter') && !this.is('sma')) {\n overrides = {\n marker: {\n enabled: false,\n radius: 2\n }\n };\n }\n if (overrides) {\n e.plotOptions[this.type] = merge(e.plotOptions[this.type], overrides);\n }\n }\n });\n // Override the automatic label alignment so that the first Y axis' labels are\n // drawn on top of the grid line, and subsequent axes are drawn outside\n addEvent(Axis, 'autoLabelAlign', function (e) {\n const { chart, options } = this, panes = chart._labelPanes = chart._labelPanes || {}, labelOptions = options.labels;\n if (chart.options.isStock && this.coll === 'yAxis') {\n const key = options.top + ',' + options.height;\n // Do it only for the first Y axis of each pane\n if (!panes[key] && labelOptions.enabled) {\n if (labelOptions.distance === 15 && // default\n this.side === 1) {\n labelOptions.distance = 0;\n }\n if (typeof labelOptions.align === 'undefined') {\n labelOptions.align = 'right';\n }\n panes[key] = this;\n e.align = 'right';\n e.preventDefault();\n }\n }\n });\n // Clear axis from label panes (#6071)\n addEvent(Axis, 'destroy', function () {\n const chart = this.chart, key = this.options && (this.options.top + ',' + this.options.height);\n if (key && chart._labelPanes && chart._labelPanes[key] === this) {\n delete chart._labelPanes[key];\n }\n });\n // Override getPlotLinePath to allow for multipane charts\n addEvent(Axis, 'getPlotLinePath', function (e) {\n let axis = this, series = (this.isLinked && !this.series ?\n this.linkedParent.series :\n this.series), chart = axis.chart, renderer = chart.renderer, axisLeft = axis.left, axisTop = axis.top, x1, y1, x2, y2, result = [], axes = [], // #3416 need a default array\n axes2, uniqueAxes, translatedValue = e.translatedValue, value = e.value, force = e.force, transVal;\n /**\n * Return the other axis based on either the axis option or on related\n * series.\n * @private\n */\n function getAxis(coll) {\n const otherColl = coll === 'xAxis' ? 'yAxis' : 'xAxis', opt = axis.options[otherColl];\n // Other axis indexed by number\n if (isNumber(opt)) {\n return [chart[otherColl][opt]];\n }\n // Other axis indexed by id (like navigator)\n if (isString(opt)) {\n return [chart.get(opt)];\n }\n // Auto detect based on existing series\n return series.map(function (s) {\n return s[otherColl];\n });\n }\n if ( // For stock chart, by default render paths across the panes\n // except the case when `acrossPanes` is disabled by user (#6644)\n (chart.options.isStock && e.acrossPanes !== false) &&\n // Ignore in case of colorAxis or zAxis. #3360, #3524, #6720\n axis.coll === 'xAxis' || axis.coll === 'yAxis') {\n e.preventDefault();\n // Get the related axes based on series\n axes = getAxis(axis.coll);\n // Get the related axes based options.*Axis setting #2810\n axes2 = (axis.isXAxis ? chart.yAxis : chart.xAxis);\n axes2.forEach(function (A) {\n if (defined(A.options.id) ?\n A.options.id.indexOf('navigator') === -1 :\n true) {\n const a = (A.isXAxis ? 'yAxis' : 'xAxis'), rax = (defined(A.options[a]) ?\n chart[a][A.options[a]] :\n chart[a][0]);\n if (axis === rax) {\n axes.push(A);\n }\n }\n });\n // Remove duplicates in the axes array. If there are no axes in the axes\n // array, we are adding an axis without data, so we need to populate\n // this with grid lines (#2796).\n uniqueAxes = axes.length ?\n [] :\n [axis.isXAxis ? chart.yAxis[0] : chart.xAxis[0]]; // #3742\n axes.forEach(function (axis2) {\n if (uniqueAxes.indexOf(axis2) === -1 &&\n // Do not draw on axis which overlap completely. #5424\n !find(uniqueAxes, function (unique) {\n return unique.pos === axis2.pos && unique.len === axis2.len;\n })) {\n uniqueAxes.push(axis2);\n }\n });\n transVal = pick(translatedValue, axis.translate(value, void 0, void 0, e.old));\n if (isNumber(transVal)) {\n if (axis.horiz) {\n uniqueAxes.forEach(function (axis2) {\n let skip;\n y1 = axis2.pos;\n y2 = y1 + axis2.len;\n x1 = x2 = Math.round(transVal + axis.transB);\n // outside plot area\n if (force !== 'pass' &&\n (x1 < axisLeft || x1 > axisLeft + axis.width)) {\n if (force) {\n x1 = x2 = clamp(x1, axisLeft, axisLeft + axis.width);\n }\n else {\n skip = true;\n }\n }\n if (!skip) {\n result.push(['M', x1, y1], ['L', x2, y2]);\n }\n });\n }\n else {\n uniqueAxes.forEach(function (axis2) {\n let skip;\n x1 = axis2.pos;\n x2 = x1 + axis2.len;\n y1 = y2 = Math.round(axisTop + axis.height - transVal);\n // outside plot area\n if (force !== 'pass' &&\n (y1 < axisTop || y1 > axisTop + axis.height)) {\n if (force) {\n y1 = y2 = clamp(y1, axisTop, axisTop + axis.height);\n }\n else {\n skip = true;\n }\n }\n if (!skip) {\n result.push(['M', x1, y1], ['L', x2, y2]);\n }\n });\n }\n }\n e.path = result.length > 0 ?\n renderer.crispPolyLine(result, e.lineWidth || 1) :\n // #3557 getPlotLinePath in regular Highcharts also returns null\n null;\n }\n });\n /**\n * Function to crisp a line with multiple segments\n *\n * @private\n * @function Highcharts.SVGRenderer#crispPolyLine\n */\n SVGRenderer.prototype.crispPolyLine = function (points, width) {\n // points format: [['M', 0, 0], ['L', 100, 0]]\n // normalize to a crisp line\n for (let i = 0; i < points.length; i = i + 2) {\n const start = points[i], end = points[i + 1];\n if (start[1] === end[1]) {\n // Substract due to #1129. Now bottom and left axis gridlines behave\n // the same.\n start[1] = end[1] =\n Math.round(start[1]) - (width % 2 / 2);\n }\n if (start[2] === end[2]) {\n start[2] = end[2] =\n Math.round(start[2]) + (width % 2 / 2);\n }\n }\n return points;\n };\n // Wrapper to hide the label\n addEvent(Axis, 'afterHideCrosshair', function () {\n if (this.crossLabel) {\n this.crossLabel = this.crossLabel.hide();\n }\n });\n // Extend crosshairs to also draw the label\n addEvent(Axis, 'afterDrawCrosshair', function (event) {\n // Check if the label has to be drawn\n if (!this.crosshair ||\n !this.crosshair.label ||\n !this.crosshair.label.enabled ||\n !this.cross ||\n !isNumber(this.min) ||\n !isNumber(this.max)) {\n return;\n }\n let chart = this.chart, log = this.logarithmic, options = this.crosshair.label, // the label's options\n horiz = this.horiz, // axis orientation\n opposite = this.opposite, // axis position\n left = this.left, // left position\n top = this.top, // top position\n width = this.width, crossLabel = this.crossLabel, // the svgElement\n posx, posy, crossBox, formatOption = options.format, formatFormat = '', limit, align, tickInside = this.options.tickPosition === 'inside', snap = this.crosshair.snap !== false, offset = 0, \n // Use last available event (#5287)\n e = event.e || (this.cross && this.cross.e), point = event.point, min = this.min, max = this.max;\n if (log) {\n min = log.lin2log(min);\n max = log.lin2log(max);\n }\n align = (horiz ? 'center' : opposite ?\n (this.labelAlign === 'right' ? 'right' : 'left') :\n (this.labelAlign === 'left' ? 'left' : 'center'));\n // If the label does not exist yet, create it.\n if (!crossLabel) {\n crossLabel = this.crossLabel = chart.renderer\n .label('', 0, void 0, options.shape || 'callout')\n .addClass('highcharts-crosshair-label highcharts-color-' + (point && point.series ?\n point.series.colorIndex :\n this.series[0] && this.series[0].colorIndex))\n .attr({\n align: options.align || align,\n padding: pick(options.padding, 8),\n r: pick(options.borderRadius, 3),\n zIndex: 2\n })\n .add(this.labelGroup);\n // Presentational\n if (!chart.styledMode) {\n crossLabel\n .attr({\n fill: options.backgroundColor ||\n point && point.series && point.series.color || // #14888\n \"#666666\" /* Palette.neutralColor60 */,\n stroke: options.borderColor || '',\n 'stroke-width': options.borderWidth || 0\n })\n .css(extend({\n color: \"#ffffff\" /* Palette.backgroundColor */,\n fontWeight: 'normal',\n fontSize: '0.7em',\n textAlign: 'center'\n }, options.style || {}));\n }\n }\n if (horiz) {\n posx = snap ? (point.plotX || 0) + left : e.chartX;\n posy = top + (opposite ? 0 : this.height);\n }\n else {\n posx = left + this.offset + (opposite ? width : 0);\n posy = snap ? (point.plotY || 0) + top : e.chartY;\n }\n if (!formatOption && !options.formatter) {\n if (this.dateTime) {\n formatFormat = '%b %d, %Y';\n }\n formatOption =\n '{value' + (formatFormat ? ':' + formatFormat : '') + '}';\n }\n // Show the label\n const value = snap ?\n (this.isXAxis ? point.x : point.y) :\n this.toValue(horiz ? e.chartX : e.chartY);\n // Crosshair should be rendered within Axis range (#7219). Also, the point\n // of currentPriceIndicator should be inside the plot area, #14879.\n const isInside = point && point.series ?\n point.series.isPointInside(point) :\n (isNumber(value) && value > min && value < max);\n let text = '';\n if (formatOption) {\n text = format(formatOption, { value }, chart);\n }\n else if (options.formatter && isNumber(value)) {\n text = options.formatter.call(this, value);\n }\n crossLabel.attr({\n text,\n x: posx,\n y: posy,\n visibility: isInside ? 'inherit' : 'hidden'\n });\n crossBox = crossLabel.getBBox();\n // now it is placed we can correct its position\n if (isNumber(crossLabel.x) && !horiz && !opposite) {\n posx = crossLabel.x - (crossBox.width / 2);\n }\n if (isNumber(crossLabel.y)) {\n if (horiz) {\n if ((tickInside && !opposite) || (!tickInside && opposite)) {\n posy = crossLabel.y - crossBox.height;\n }\n }\n else {\n posy = crossLabel.y - (crossBox.height / 2);\n }\n }\n // check the edges\n if (horiz) {\n limit = {\n left: left - crossBox.x,\n right: left + this.width - crossBox.x\n };\n }\n else {\n limit = {\n left: this.labelAlign === 'left' ? left : 0,\n right: this.labelAlign === 'right' ?\n left + this.width :\n chart.chartWidth\n };\n }\n // left edge\n if (crossLabel.translateX < limit.left) {\n offset = limit.left - crossLabel.translateX;\n }\n // right edge\n if (crossLabel.translateX + crossBox.width >= limit.right) {\n offset = -(crossLabel.translateX + crossBox.width - limit.right);\n }\n // show the crosslabel\n crossLabel.attr({\n x: posx + offset,\n y: posy,\n // First set x and y, then anchorX and anchorY, when box is actually\n // calculated, #5702\n anchorX: horiz ?\n posx :\n (this.opposite ? 0 : chart.chartWidth),\n anchorY: horiz ?\n (this.opposite ? chart.chartHeight : 0) :\n posy + crossBox.height / 2\n });\n });\n /**\n * Based on the data grouping options decides whether\n * the data should be cropped while processing.\n *\n * @ignore\n * @function Highcharts.Series#forceCropping\n */\n Series.prototype.forceCropping = function () {\n const chart = this.chart, options = this.options, dataGroupingOptions = options.dataGrouping, groupingEnabled = this.allowDG !== false && dataGroupingOptions &&\n pick(dataGroupingOptions.enabled, chart.options.isStock);\n return groupingEnabled;\n };\n addEvent(Chart, 'update', function (e) {\n const options = e.options;\n // Use case: enabling scrollbar from a disabled state.\n // Scrollbar needs to be initialized from a controller, Navigator in this\n // case (#6615)\n if ('scrollbar' in options && this.navigator) {\n merge(true, this.options.scrollbar, options.scrollbar);\n this.navigator.update({});\n delete options.scrollbar;\n }\n });\n /* *\n *\n * Default Export\n *\n * */\n\n return StockChart;\n });\n _registerModule(_modules, 'masters/modules/stock.src.js', [_modules['Core/Globals.js'], _modules['Series/DataModifyComposition.js'], _modules['Stock/Navigator/Navigator.js'], _modules['Stock/RangeSelector/RangeSelector.js'], _modules['Stock/Scrollbar/Scrollbar.js'], _modules['Core/Axis/OrdinalAxis.js'], _modules['Series/OHLC/OHLCSeries.js'], _modules['Series/Flags/FlagsSeries.js'], _modules['Core/Chart/StockChart.js']], function (Highcharts, DataModifyComposition, Navigator, RangeSelector, Scrollbar, OrdinalAxis, OHLCSeries, FlagsSeries, StockChart) {\n\n const G = Highcharts;\n // Classes\n G.Navigator = Navigator;\n G.RangeSelector = RangeSelector;\n G.Scrollbar = Scrollbar;\n G.StockChart = G.stockChart = StockChart.stockChart;\n // Compositions\n DataModifyComposition.compose(G.Series, G.Axis, G.Point);\n FlagsSeries.compose(G.Renderer);\n Navigator.compose(G.Axis, G.Chart, G.Series);\n OHLCSeries.compose(G.Series);\n OrdinalAxis.compose(G.Axis, G.Series, G.Chart);\n RangeSelector.compose(G.Axis, G.Chart);\n Scrollbar.compose(G.Axis);\n\n });\n}));","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"\")&&(k=k.replace(\"\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e\"+b.valueOf().toString()+\"\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a>=g;e-=g;rg=1<<32-oc(b)+e|c<w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;ww?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;ac?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eHj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;de&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;kB()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}\nmodule.exports = _arrayWithoutHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nfunction _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {};\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}\nmodule.exports = _createForOfIteratorHelper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nvar isNativeReflectConstruct = require(\"./isNativeReflectConstruct.js\");\nvar possibleConstructorReturn = require(\"./possibleConstructorReturn.js\");\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}\nmodule.exports = _createSuper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var superPropBase = require(\"./superPropBase.js\");\nfunction _get() {\n if (typeof Reflect !== \"undefined\" && Reflect.get) {\n module.exports = _get = Reflect.get.bind(), module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n } else {\n module.exports = _get = function _get(target, property, receiver) {\n var base = superPropBase(target, property);\n if (!base) return;\n var desc = Object.getOwnPropertyDescriptor(base, property);\n if (desc.get) {\n return desc.get.call(arguments.length < 3 ? target : receiver);\n }\n return desc.value;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n }\n return _get.apply(this, arguments);\n}\nmodule.exports = _get, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _getPrototypeOf(o);\n}\nmodule.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\nmodule.exports = _inherits, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\nmodule.exports = _isNativeReflectConstruct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nmodule.exports = _iterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(arr, i) {\n var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (null != _i) {\n var _s,\n _e,\n _x,\n _r,\n _arr = [],\n _n = !0,\n _d = !1;\n try {\n if (_x = (_i = _i.call(arr)).next, 0 === i) {\n if (Object(_i) !== _i) return;\n _n = !1;\n } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0);\n } catch (err) {\n _d = !0, _e = err;\n } finally {\n try {\n if (!_n && null != _i[\"return\"] && (_r = _i[\"return\"](), Object(_r) !== _r)) return;\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n }\n}\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableSpread, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}\nmodule.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _setPrototypeOf(o, p);\n}\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableRest = require(\"./nonIterableRest.js\");\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nfunction _superPropBase(object, property) {\n while (!Object.prototype.hasOwnProperty.call(object, property)) {\n object = getPrototypeOf(object);\n if (object === null) break;\n }\n return object;\n}\nmodule.exports = _superPropBase, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithoutHoles = require(\"./arrayWithoutHoles.js\");\nvar iterableToArray = require(\"./iterableToArray.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableSpread = require(\"./nonIterableSpread.js\");\nfunction _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}\nmodule.exports = _toConsumableArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nmodule.exports = _toPrimitive, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar toPrimitive = require(\"./toPrimitive.js\");\nfunction _toPropertyKey(arg) {\n var key = toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}\nmodule.exports = _toPropertyKey, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(obj);\n}\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","var getProto = Object.getPrototypeOf ? function(obj) { return Object.getPrototypeOf(obj); } : function(obj) { return obj.__proto__; };\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach(function(key) { def[key] = function() { return value[key]; }; });\n\t}\n\tdef['default'] = function() { return value; };\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + \"bc83fce9\" + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","var inProgress = {};\nvar dataWebpackPrefix = \"funviz-react:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkfunviz_react\"] = self[\"webpackChunkfunviz_react\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","var _g;\nvar _excluded = [\"title\", \"titleId\"];\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport * as React from \"react\";\nfunction SvgLogo(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 841.9 595.3\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n fill: \"#61DAFB\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n d: \"M666.3 296.5c0-32.5-40.7-63.3-103.1-82.4 14.4-63.6 8-114.2-20.2-130.4-6.5-3.8-14.1-5.6-22.4-5.6v22.3c4.6 0 8.3.9 11.4 2.6 13.6 7.8 19.5 37.5 14.9 75.7-1.1 9.4-2.9 19.3-5.1 29.4-19.6-4.8-41-8.5-63.5-10.9-13.5-18.5-27.5-35.3-41.6-50 32.6-30.3 63.2-46.9 84-46.9V78c-27.5 0-63.5 19.6-99.9 53.6-36.4-33.8-72.4-53.2-99.9-53.2v22.3c20.7 0 51.4 16.5 84 46.6-14 14.7-28 31.4-41.3 49.9-22.6 2.4-44 6.1-63.6 11-2.3-10-4-19.7-5.2-29-4.7-38.2 1.1-67.9 14.6-75.8 3-1.8 6.9-2.6 11.5-2.6V78.5c-8.4 0-16 1.8-22.6 5.6-28.1 16.2-34.4 66.7-19.9 130.1-62.2 19.2-102.7 49.9-102.7 82.3 0 32.5 40.7 63.3 103.1 82.4-14.4 63.6-8 114.2 20.2 130.4 6.5 3.8 14.1 5.6 22.5 5.6 27.5 0 63.5-19.6 99.9-53.6 36.4 33.8 72.4 53.2 99.9 53.2 8.4 0 16-1.8 22.6-5.6 28.1-16.2 34.4-66.7 19.9-130.1 62-19.1 102.5-49.9 102.5-82.3zm-130.2-66.7c-3.7 12.9-8.3 26.2-13.5 39.5-4.1-8-8.4-16-13.1-24-4.6-8-9.5-15.8-14.4-23.4 14.2 2.1 27.9 4.7 41 7.9zm-45.8 106.5c-7.8 13.5-15.8 26.3-24.1 38.2-14.9 1.3-30 2-45.2 2-15.1 0-30.2-.7-45-1.9-8.3-11.9-16.4-24.6-24.2-38-7.6-13.1-14.5-26.4-20.8-39.8 6.2-13.4 13.2-26.8 20.7-39.9 7.8-13.5 15.8-26.3 24.1-38.2 14.9-1.3 30-2 45.2-2 15.1 0 30.2.7 45 1.9 8.3 11.9 16.4 24.6 24.2 38 7.6 13.1 14.5 26.4 20.8 39.8-6.3 13.4-13.2 26.8-20.7 39.9zm32.3-13c5.4 13.4 10 26.8 13.8 39.8-13.1 3.2-26.9 5.9-41.2 8 4.9-7.7 9.8-15.6 14.4-23.7 4.6-8 8.9-16.1 13-24.1zM421.2 430c-9.3-9.6-18.6-20.3-27.8-32 9 .4 18.2.7 27.5.7 9.4 0 18.7-.2 27.8-.7-9 11.7-18.3 22.4-27.5 32zm-74.4-58.9c-14.2-2.1-27.9-4.7-41-7.9 3.7-12.9 8.3-26.2 13.5-39.5 4.1 8 8.4 16 13.1 24 4.7 8 9.5 15.8 14.4 23.4zM420.7 163c9.3 9.6 18.6 20.3 27.8 32-9-.4-18.2-.7-27.5-.7-9.4 0-18.7.2-27.8.7 9-11.7 18.3-22.4 27.5-32zm-74 58.9c-4.9 7.7-9.8 15.6-14.4 23.7-4.6 8-8.9 16-13 24-5.4-13.4-10-26.8-13.8-39.8 13.1-3.1 26.9-5.8 41.2-7.9zm-90.5 125.2c-35.4-15.1-58.3-34.9-58.3-50.6 0-15.7 22.9-35.6 58.3-50.6 8.6-3.7 18-7 27.7-10.1 5.7 19.6 13.2 40 22.5 60.9-9.2 20.8-16.6 41.1-22.2 60.6-9.9-3.1-19.3-6.5-28-10.2zM310 490c-13.6-7.8-19.5-37.5-14.9-75.7 1.1-9.4 2.9-19.3 5.1-29.4 19.6 4.8 41 8.5 63.5 10.9 13.5 18.5 27.5 35.3 41.6 50-32.6 30.3-63.2 46.9-84 46.9-4.5-.1-8.3-1-11.3-2.7zm237.2-76.2c4.7 38.2-1.1 67.9-14.6 75.8-3 1.8-6.9 2.6-11.5 2.6-20.7 0-51.4-16.5-84-46.6 14-14.7 28-31.4 41.3-49.9 22.6-2.4 44-6.1 63.6-11 2.3 10.1 4.1 19.8 5.2 29.1zm38.5-66.7c-8.6 3.7-18 7-27.7 10.1-5.7-19.6-13.2-40-22.5-60.9 9.2-20.8 16.6-41.1 22.2-60.6 9.9 3.1 19.3 6.5 28.1 10.2 35.4 15.1 58.3 34.9 58.3 50.6-.1 15.7-23 35.6-58.4 50.6zM320.8 78.4z\"\n }), /*#__PURE__*/React.createElement(\"circle\", {\n cx: 420.9,\n cy: 296.5,\n r: 45.7\n }), /*#__PURE__*/React.createElement(\"path\", {\n d: \"M520.5 78.1z\"\n }))));\n}\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgLogo);\nexport default __webpack_public_path__ + \"static/media/logo.6ce24c58023cc2f8fd88fe9d219db6c6.svg\";\nexport { ForwardRef as ReactComponent };","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nimport { AWS_CLOUDWATCH_CATEGORY } from '../Util/Constants';\nvar LOG_LEVELS = {\n VERBOSE: 1,\n DEBUG: 2,\n INFO: 3,\n WARN: 4,\n ERROR: 5,\n};\nexport var LOG_TYPE;\n(function (LOG_TYPE) {\n LOG_TYPE[\"DEBUG\"] = \"DEBUG\";\n LOG_TYPE[\"ERROR\"] = \"ERROR\";\n LOG_TYPE[\"INFO\"] = \"INFO\";\n LOG_TYPE[\"WARN\"] = \"WARN\";\n LOG_TYPE[\"VERBOSE\"] = \"VERBOSE\";\n})(LOG_TYPE || (LOG_TYPE = {}));\n/**\n * Write logs\n * @class Logger\n */\nexport var ConsoleLogger = /** @class */ (function () {\n /**\n * @constructor\n * @param {string} name - Name of the logger\n */\n function ConsoleLogger(name, level) {\n if (level === void 0) { level = LOG_TYPE.WARN; }\n this.name = name;\n this.level = level;\n this._pluggables = [];\n }\n ConsoleLogger.prototype._padding = function (n) {\n return n < 10 ? '0' + n : '' + n;\n };\n ConsoleLogger.prototype._ts = function () {\n var dt = new Date();\n return ([this._padding(dt.getMinutes()), this._padding(dt.getSeconds())].join(':') +\n '.' +\n dt.getMilliseconds());\n };\n ConsoleLogger.prototype.configure = function (config) {\n if (!config)\n return this._config;\n this._config = config;\n return this._config;\n };\n /**\n * Write log\n * @method\n * @memeberof Logger\n * @param {LOG_TYPE|string} type - log type, default INFO\n * @param {string|object} msg - Logging message or object\n */\n ConsoleLogger.prototype._log = function (type) {\n var e_1, _a;\n var msg = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n msg[_i - 1] = arguments[_i];\n }\n var logger_level_name = this.level;\n if (ConsoleLogger.LOG_LEVEL) {\n logger_level_name = ConsoleLogger.LOG_LEVEL;\n }\n if (typeof window !== 'undefined' && window.LOG_LEVEL) {\n logger_level_name = window.LOG_LEVEL;\n }\n var logger_level = LOG_LEVELS[logger_level_name];\n var type_level = LOG_LEVELS[type];\n if (!(type_level >= logger_level)) {\n // Do nothing if type is not greater than or equal to logger level (handle undefined)\n return;\n }\n var log = console.log.bind(console);\n if (type === LOG_TYPE.ERROR && console.error) {\n log = console.error.bind(console);\n }\n if (type === LOG_TYPE.WARN && console.warn) {\n log = console.warn.bind(console);\n }\n var prefix = \"[\".concat(type, \"] \").concat(this._ts(), \" \").concat(this.name);\n var message = '';\n if (msg.length === 1 && typeof msg[0] === 'string') {\n message = \"\".concat(prefix, \" - \").concat(msg[0]);\n log(message);\n }\n else if (msg.length === 1) {\n message = \"\".concat(prefix, \" \").concat(msg[0]);\n log(prefix, msg[0]);\n }\n else if (typeof msg[0] === 'string') {\n var obj = msg.slice(1);\n if (obj.length === 1) {\n obj = obj[0];\n }\n message = \"\".concat(prefix, \" - \").concat(msg[0], \" \").concat(obj);\n log(\"\".concat(prefix, \" - \").concat(msg[0]), obj);\n }\n else {\n message = \"\".concat(prefix, \" \").concat(msg);\n log(prefix, msg);\n }\n try {\n for (var _b = __values(this._pluggables), _c = _b.next(); !_c.done; _c = _b.next()) {\n var plugin = _c.value;\n var logEvent = { message: message, timestamp: Date.now() };\n plugin.pushLogs([logEvent]);\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_1) throw e_1.error; }\n }\n };\n /**\n * Write General log. Default to INFO\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n ConsoleLogger.prototype.log = function () {\n var msg = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n msg[_i] = arguments[_i];\n }\n this._log.apply(this, __spreadArray([LOG_TYPE.INFO], __read(msg), false));\n };\n /**\n * Write INFO log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n ConsoleLogger.prototype.info = function () {\n var msg = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n msg[_i] = arguments[_i];\n }\n this._log.apply(this, __spreadArray([LOG_TYPE.INFO], __read(msg), false));\n };\n /**\n * Write WARN log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n ConsoleLogger.prototype.warn = function () {\n var msg = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n msg[_i] = arguments[_i];\n }\n this._log.apply(this, __spreadArray([LOG_TYPE.WARN], __read(msg), false));\n };\n /**\n * Write ERROR log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n ConsoleLogger.prototype.error = function () {\n var msg = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n msg[_i] = arguments[_i];\n }\n this._log.apply(this, __spreadArray([LOG_TYPE.ERROR], __read(msg), false));\n };\n /**\n * Write DEBUG log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n ConsoleLogger.prototype.debug = function () {\n var msg = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n msg[_i] = arguments[_i];\n }\n this._log.apply(this, __spreadArray([LOG_TYPE.DEBUG], __read(msg), false));\n };\n /**\n * Write VERBOSE log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n ConsoleLogger.prototype.verbose = function () {\n var msg = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n msg[_i] = arguments[_i];\n }\n this._log.apply(this, __spreadArray([LOG_TYPE.VERBOSE], __read(msg), false));\n };\n ConsoleLogger.prototype.addPluggable = function (pluggable) {\n if (pluggable && pluggable.getCategoryName() === AWS_CLOUDWATCH_CATEGORY) {\n this._pluggables.push(pluggable);\n pluggable.configure(this._config);\n }\n };\n ConsoleLogger.prototype.listPluggables = function () {\n return this._pluggables;\n };\n ConsoleLogger.LOG_LEVEL = null;\n return ConsoleLogger;\n}());\n","////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Actions represent the type of change to a location value.\n */\nexport enum Action {\n /**\n * A POP indicates a change to an arbitrary index in the history stack, such\n * as a back or forward navigation. It does not describe the direction of the\n * navigation, only that the current index changed.\n *\n * Note: This is the default action for newly created history objects.\n */\n Pop = \"POP\",\n\n /**\n * A PUSH indicates a new entry being added to the history stack, such as when\n * a link is clicked and a new page loads. When this happens, all subsequent\n * entries in the stack are lost.\n */\n Push = \"PUSH\",\n\n /**\n * A REPLACE indicates the entry at the current index in the history stack\n * being replaced by a new one.\n */\n Replace = \"REPLACE\",\n}\n\n/**\n * The pathname, search, and hash values of a URL.\n */\nexport interface Path {\n /**\n * A URL pathname, beginning with a /.\n */\n pathname: string;\n\n /**\n * A URL search string, beginning with a ?.\n */\n search: string;\n\n /**\n * A URL fragment identifier, beginning with a #.\n */\n hash: string;\n}\n\n/**\n * An entry in a history stack. A location contains information about the\n * URL path, as well as possibly some arbitrary state and a key.\n */\nexport interface Location extends Path {\n /**\n * A value of arbitrary data associated with this location.\n */\n state: any;\n\n /**\n * A unique string associated with this location. May be used to safely store\n * and retrieve data in some other storage API, like `localStorage`.\n *\n * Note: This value is always \"default\" on the initial location.\n */\n key: string;\n}\n\n/**\n * A change to the current location.\n */\nexport interface Update {\n /**\n * The action that triggered the change.\n */\n action: Action;\n\n /**\n * The new location.\n */\n location: Location;\n\n /**\n * The delta between this location and the former location in the history stack\n */\n delta: number | null;\n}\n\n/**\n * A function that receives notifications about location changes.\n */\nexport interface Listener {\n (update: Update): void;\n}\n\n/**\n * Describes a location that is the destination of some navigation, either via\n * `history.push` or `history.replace`. May be either a URL or the pieces of a\n * URL path.\n */\nexport type To = string | Partial;\n\n/**\n * A history is an interface to the navigation stack. The history serves as the\n * source of truth for the current location, as well as provides a set of\n * methods that may be used to change it.\n *\n * It is similar to the DOM's `window.history` object, but with a smaller, more\n * focused API.\n */\nexport interface History {\n /**\n * The last action that modified the current location. This will always be\n * Action.Pop when a history instance is first created. This value is mutable.\n */\n readonly action: Action;\n\n /**\n * The current location. This value is mutable.\n */\n readonly location: Location;\n\n /**\n * Returns a valid href for the given `to` value that may be used as\n * the value of an attribute.\n *\n * @param to - The destination URL\n */\n createHref(to: To): string;\n\n /**\n * Returns a URL for the given `to` value\n *\n * @param to - The destination URL\n */\n createURL(to: To): URL;\n\n /**\n * Encode a location the same way window.history would do (no-op for memory\n * history) so we ensure our PUSH/REPLACE navigations for data routers\n * behave the same as POP\n *\n * @param to Unencoded path\n */\n encodeLocation(to: To): Path;\n\n /**\n * Pushes a new location onto the history stack, increasing its length by one.\n * If there were any entries in the stack after the current one, they are\n * lost.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n push(to: To, state?: any): void;\n\n /**\n * Replaces the current location in the history stack with a new one. The\n * location that was replaced will no longer be available.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n replace(to: To, state?: any): void;\n\n /**\n * Navigates `n` entries backward/forward in the history stack relative to the\n * current index. For example, a \"back\" navigation would use go(-1).\n *\n * @param delta - The delta in the stack index\n */\n go(delta: number): void;\n\n /**\n * Sets up a listener that will be called whenever the current location\n * changes.\n *\n * @param listener - A function that will be called when the location changes\n * @returns unlisten - A function that may be used to stop listening\n */\n listen(listener: Listener): () => void;\n}\n\ntype HistoryState = {\n usr: any;\n key?: string;\n idx: number;\n};\n\nconst PopStateEventType = \"popstate\";\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Memory History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A user-supplied object that describes a location. Used when providing\n * entries to `createMemoryHistory` via its `initialEntries` option.\n */\nexport type InitialEntry = string | Partial;\n\nexport type MemoryHistoryOptions = {\n initialEntries?: InitialEntry[];\n initialIndex?: number;\n v5Compat?: boolean;\n};\n\n/**\n * A memory history stores locations in memory. This is useful in stateful\n * environments where there is no web browser, such as node tests or React\n * Native.\n */\nexport interface MemoryHistory extends History {\n /**\n * The current index in the history stack.\n */\n readonly index: number;\n}\n\n/**\n * Memory history stores the current location in memory. It is designed for use\n * in stateful non-browser environments like tests and React Native.\n */\nexport function createMemoryHistory(\n options: MemoryHistoryOptions = {}\n): MemoryHistory {\n let { initialEntries = [\"/\"], initialIndex, v5Compat = false } = options;\n let entries: Location[]; // Declare so we can access from createMemoryLocation\n entries = initialEntries.map((entry, index) =>\n createMemoryLocation(\n entry,\n typeof entry === \"string\" ? null : entry.state,\n index === 0 ? \"default\" : undefined\n )\n );\n let index = clampIndex(\n initialIndex == null ? entries.length - 1 : initialIndex\n );\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n function clampIndex(n: number): number {\n return Math.min(Math.max(n, 0), entries.length - 1);\n }\n function getCurrentLocation(): Location {\n return entries[index];\n }\n function createMemoryLocation(\n to: To,\n state: any = null,\n key?: string\n ): Location {\n let location = createLocation(\n entries ? getCurrentLocation().pathname : \"/\",\n to,\n state,\n key\n );\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in memory history: ${JSON.stringify(\n to\n )}`\n );\n return location;\n }\n\n function createHref(to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n let history: MemoryHistory = {\n get index() {\n return index;\n },\n get action() {\n return action;\n },\n get location() {\n return getCurrentLocation();\n },\n createHref,\n createURL(to) {\n return new URL(createHref(to), \"http://localhost\");\n },\n encodeLocation(to: To) {\n let path = typeof to === \"string\" ? parsePath(to) : to;\n return {\n pathname: path.pathname || \"\",\n search: path.search || \"\",\n hash: path.hash || \"\",\n };\n },\n push(to, state) {\n action = Action.Push;\n let nextLocation = createMemoryLocation(to, state);\n index += 1;\n entries.splice(index, entries.length, nextLocation);\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 1 });\n }\n },\n replace(to, state) {\n action = Action.Replace;\n let nextLocation = createMemoryLocation(to, state);\n entries[index] = nextLocation;\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 0 });\n }\n },\n go(delta) {\n action = Action.Pop;\n let nextIndex = clampIndex(index + delta);\n let nextLocation = entries[nextIndex];\n index = nextIndex;\n if (listener) {\n listener({ action, location: nextLocation, delta });\n }\n },\n listen(fn: Listener) {\n listener = fn;\n return () => {\n listener = null;\n };\n },\n };\n\n return history;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Browser History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A browser history stores the current location in regular URLs in a web\n * browser environment. This is the standard for most web apps and provides the\n * cleanest URLs the browser's address bar.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#browserhistory\n */\nexport interface BrowserHistory extends UrlHistory {}\n\nexport type BrowserHistoryOptions = UrlHistoryOptions;\n\n/**\n * Browser history stores the location in regular URLs. This is the standard for\n * most web apps, but it requires some configuration on the server to ensure you\n * serve the same app at multiple URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createbrowserhistory\n */\nexport function createBrowserHistory(\n options: BrowserHistoryOptions = {}\n): BrowserHistory {\n function createBrowserLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let { pathname, search, hash } = window.location;\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createBrowserHref(window: Window, to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n return getUrlBasedHistory(\n createBrowserLocation,\n createBrowserHref,\n null,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hash History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A hash history stores the current location in the fragment identifier portion\n * of the URL in a web browser environment.\n *\n * This is ideal for apps that do not control the server for some reason\n * (because the fragment identifier is never sent to the server), including some\n * shared hosting environments that do not provide fine-grained controls over\n * which pages are served at which URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#hashhistory\n */\nexport interface HashHistory extends UrlHistory {}\n\nexport type HashHistoryOptions = UrlHistoryOptions;\n\n/**\n * Hash history stores the location in window.location.hash. This makes it ideal\n * for situations where you don't want to send the location to the server for\n * some reason, either because you do cannot configure it or the URL space is\n * reserved for something else.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createhashhistory\n */\nexport function createHashHistory(\n options: HashHistoryOptions = {}\n): HashHistory {\n function createHashLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n } = parsePath(window.location.hash.substr(1));\n\n // Hash URL should always have a leading / just like window.location.pathname\n // does, so if an app ends up at a route like /#something then we add a\n // leading slash so all of our path-matching behaves the same as if it would\n // in a browser router. This is particularly important when there exists a\n // root splat route () since that matches internally against\n // \"/*\" and we'd expect /#something to 404 in a hash router app.\n if (!pathname.startsWith(\"/\") && !pathname.startsWith(\".\")) {\n pathname = \"/\" + pathname;\n }\n\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createHashHref(window: Window, to: To) {\n let base = window.document.querySelector(\"base\");\n let href = \"\";\n\n if (base && base.getAttribute(\"href\")) {\n let url = window.location.href;\n let hashIndex = url.indexOf(\"#\");\n href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n }\n\n return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n }\n\n function validateHashLocation(location: Location, to: To) {\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in hash history.push(${JSON.stringify(\n to\n )})`\n );\n }\n\n return getUrlBasedHistory(\n createHashLocation,\n createHashHref,\n validateHashLocation,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region UTILS\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * @private\n */\nexport function invariant(value: boolean, message?: string): asserts value;\nexport function invariant(\n value: T | null | undefined,\n message?: string\n): asserts value is T;\nexport function invariant(value: any, message?: string) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\n\nexport function warning(cond: any, message: string) {\n if (!cond) {\n // eslint-disable-next-line no-console\n if (typeof console !== \"undefined\") console.warn(message);\n\n try {\n // Welcome to debugging history!\n //\n // This error is thrown as a convenience so you can more easily\n // find the source for a warning that appears in the console by\n // enabling \"pause on exceptions\" in your JavaScript debugger.\n throw new Error(message);\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n}\n\nfunction createKey() {\n return Math.random().toString(36).substr(2, 8);\n}\n\n/**\n * For browser-based histories, we combine the state and key into an object\n */\nfunction getHistoryState(location: Location, index: number): HistoryState {\n return {\n usr: location.state,\n key: location.key,\n idx: index,\n };\n}\n\n/**\n * Creates a Location object with a unique key from the given Path\n */\nexport function createLocation(\n current: string | Location,\n to: To,\n state: any = null,\n key?: string\n): Readonly {\n let location: Readonly = {\n pathname: typeof current === \"string\" ? current : current.pathname,\n search: \"\",\n hash: \"\",\n ...(typeof to === \"string\" ? parsePath(to) : to),\n state,\n // TODO: This could be cleaned up. push/replace should probably just take\n // full Locations now and avoid the need to run through this flow at all\n // But that's a pretty big refactor to the current test suite so going to\n // keep as is for the time being and just let any incoming keys take precedence\n key: (to && (to as Location).key) || key || createKey(),\n };\n return location;\n}\n\n/**\n * Creates a string URL path from the given pathname, search, and hash components.\n */\nexport function createPath({\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n}: Partial) {\n if (search && search !== \"?\")\n pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n if (hash && hash !== \"#\")\n pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n return pathname;\n}\n\n/**\n * Parses a string URL path into its separate pathname, search, and hash components.\n */\nexport function parsePath(path: string): Partial {\n let parsedPath: Partial = {};\n\n if (path) {\n let hashIndex = path.indexOf(\"#\");\n if (hashIndex >= 0) {\n parsedPath.hash = path.substr(hashIndex);\n path = path.substr(0, hashIndex);\n }\n\n let searchIndex = path.indexOf(\"?\");\n if (searchIndex >= 0) {\n parsedPath.search = path.substr(searchIndex);\n path = path.substr(0, searchIndex);\n }\n\n if (path) {\n parsedPath.pathname = path;\n }\n }\n\n return parsedPath;\n}\n\nexport interface UrlHistory extends History {}\n\nexport type UrlHistoryOptions = {\n window?: Window;\n v5Compat?: boolean;\n};\n\nfunction getUrlBasedHistory(\n getLocation: (window: Window, globalHistory: Window[\"history\"]) => Location,\n createHref: (window: Window, to: To) => string,\n validateLocation: ((location: Location, to: To) => void) | null,\n options: UrlHistoryOptions = {}\n): UrlHistory {\n let { window = document.defaultView!, v5Compat = false } = options;\n let globalHistory = window.history;\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n let index = getIndex()!;\n // Index should only be null when we initialize. If not, it's because the\n // user called history.pushState or history.replaceState directly, in which\n // case we should log a warning as it will result in bugs.\n if (index == null) {\n index = 0;\n globalHistory.replaceState({ ...globalHistory.state, idx: index }, \"\");\n }\n\n function getIndex(): number {\n let state = globalHistory.state || { idx: null };\n return state.idx;\n }\n\n function handlePop() {\n action = Action.Pop;\n let nextIndex = getIndex();\n let delta = nextIndex == null ? null : nextIndex - index;\n index = nextIndex;\n if (listener) {\n listener({ action, location: history.location, delta });\n }\n }\n\n function push(to: To, state?: any) {\n action = Action.Push;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex() + 1;\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n\n // try...catch because iOS limits us to 100 pushState calls :/\n try {\n globalHistory.pushState(historyState, \"\", url);\n } catch (error) {\n // If the exception is because `state` can't be serialized, let that throw\n // outwards just like a replace call would so the dev knows the cause\n // https://html.spec.whatwg.org/multipage/nav-history-apis.html#shared-history-push/replace-state-steps\n // https://html.spec.whatwg.org/multipage/structured-data.html#structuredserializeinternal\n if (error instanceof DOMException && error.name === \"DataCloneError\") {\n throw error;\n }\n // They are going to lose state here, but there is no real\n // way to warn them about it since the page will refresh...\n window.location.assign(url);\n }\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 1 });\n }\n }\n\n function replace(to: To, state?: any) {\n action = Action.Replace;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex();\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n globalHistory.replaceState(historyState, \"\", url);\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 0 });\n }\n }\n\n function createURL(to: To): URL {\n // window.location.origin is \"null\" (the literal string value) in Firefox\n // under certain conditions, notably when serving from a local HTML file\n // See https://bugzilla.mozilla.org/show_bug.cgi?id=878297\n let base =\n window.location.origin !== \"null\"\n ? window.location.origin\n : window.location.href;\n\n let href = typeof to === \"string\" ? to : createPath(to);\n invariant(\n base,\n `No window.location.(origin|href) available to create URL for href: ${href}`\n );\n return new URL(href, base);\n }\n\n let history: History = {\n get action() {\n return action;\n },\n get location() {\n return getLocation(window, globalHistory);\n },\n listen(fn: Listener) {\n if (listener) {\n throw new Error(\"A history only accepts one active listener\");\n }\n window.addEventListener(PopStateEventType, handlePop);\n listener = fn;\n\n return () => {\n window.removeEventListener(PopStateEventType, handlePop);\n listener = null;\n };\n },\n createHref(to) {\n return createHref(window, to);\n },\n createURL,\n encodeLocation(to) {\n // Encode a Location the same way window.location would\n let url = createURL(to);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash,\n };\n },\n push,\n replace,\n go(n) {\n return globalHistory.go(n);\n },\n };\n\n return history;\n}\n\n//#endregion\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Logging constants\nvar AWS_CLOUDWATCH_BASE_BUFFER_SIZE = 26;\nvar AWS_CLOUDWATCH_MAX_BATCH_EVENT_SIZE = 1048576;\nvar AWS_CLOUDWATCH_MAX_EVENT_SIZE = 256000;\nvar AWS_CLOUDWATCH_CATEGORY = 'Logging';\nvar AWS_CLOUDWATCH_PROVIDER_NAME = 'AWSCloudWatch';\nvar NO_CREDS_ERROR_STRING = 'No credentials';\nvar RETRY_ERROR_CODES = [\n 'ResourceNotFoundException',\n 'InvalidSequenceTokenException',\n];\nexport { AWS_CLOUDWATCH_BASE_BUFFER_SIZE, AWS_CLOUDWATCH_CATEGORY, AWS_CLOUDWATCH_MAX_BATCH_EVENT_SIZE, AWS_CLOUDWATCH_MAX_EVENT_SIZE, AWS_CLOUDWATCH_PROVIDER_NAME, NO_CREDS_ERROR_STRING, RETRY_ERROR_CODES, };\n","var __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { ConsoleLogger as LoggerClass } from './Logger';\nvar logger = new LoggerClass('Amplify');\nvar AmplifyClass = /** @class */ (function () {\n function AmplifyClass() {\n // Everything that is `register`ed is tracked here\n this._components = [];\n this._config = {};\n // All modules (with `getModuleName()`) are stored here for dependency injection\n this._modules = {};\n // for backward compatibility to avoid breaking change\n // if someone is using like Amplify.Auth\n this.Auth = null;\n this.Analytics = null;\n this.API = null;\n this.Credentials = null;\n this.Storage = null;\n this.I18n = null;\n this.Cache = null;\n this.PubSub = null;\n this.Interactions = null;\n this.Pushnotification = null;\n this.UI = null;\n this.XR = null;\n this.Predictions = null;\n this.DataStore = null;\n this.Geo = null;\n this.Notifications = null;\n this.Logger = LoggerClass;\n this.ServiceWorker = null;\n }\n AmplifyClass.prototype.register = function (comp) {\n logger.debug('component registered in amplify', comp);\n this._components.push(comp);\n if (typeof comp.getModuleName === 'function') {\n this._modules[comp.getModuleName()] = comp;\n this[comp.getModuleName()] = comp;\n }\n else {\n logger.debug('no getModuleName method for component', comp);\n }\n // Finally configure this new component(category) loaded\n // With the new modularization changes in Amplify V3, all the Amplify\n // component are not loaded/registered right away but when they are\n // imported (and hence instantiated) in the client's app. This ensures\n // that all new components imported get correctly configured with the\n // configuration that Amplify.configure() was called with.\n comp.configure(this._config);\n };\n AmplifyClass.prototype.configure = function (config) {\n var _this = this;\n if (!config)\n return this._config;\n this._config = Object.assign(this._config, config);\n logger.debug('amplify config', this._config);\n // Dependency Injection via property-setting.\n // This avoids introducing a public method/interface/setter that's difficult to remove later.\n // Plus, it reduces `if` statements within the `constructor` and `configure` of each module\n Object.entries(this._modules).forEach(function (_a) {\n var _b = __read(_a, 2), Name = _b[0], comp = _b[1];\n // e.g. Auth.*\n Object.keys(comp).forEach(function (property) {\n // e.g. Auth[\"Credentials\"] = this._modules[\"Credentials\"] when set\n if (_this._modules[property]) {\n comp[property] = _this._modules[property];\n }\n });\n });\n this._components.map(function (comp) {\n comp.configure(_this._config);\n });\n return this._config;\n };\n AmplifyClass.prototype.addPluggable = function (pluggable) {\n if (pluggable &&\n pluggable['getCategory'] &&\n typeof pluggable['getCategory'] === 'function') {\n this._components.map(function (comp) {\n if (comp['addPluggable'] &&\n typeof comp['addPluggable'] === 'function') {\n comp.addPluggable(pluggable);\n }\n });\n }\n };\n return AmplifyClass;\n}());\nexport { AmplifyClass };\nexport var Amplify = new AmplifyClass();\n","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (null != _i) {\n var _s,\n _e,\n _x,\n _r,\n _arr = [],\n _n = !0,\n _d = !1;\n try {\n if (_x = (_i = _i.call(arr)).next, 0 === i) {\n if (Object(_i) !== _i) return;\n _n = !1;\n } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0);\n } catch (err) {\n _d = !0, _e = err;\n } finally {\n try {\n if (!_n && null != _i[\"return\"] && (_r = _i[\"return\"](), Object(_r) !== _r)) return;\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n }\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function _toPropertyKey(arg) {\n var key = toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}","import _typeof from \"./typeof.js\";\nexport default function _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, toPropertyKey(descriptor.key), descriptor);\n }\n}\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nimport possibleConstructorReturn from \"./possibleConstructorReturn.js\";\nexport default function _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nexport default function _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct.bind();\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n return _construct.apply(null, arguments);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeFunction from \"./isNativeFunction.js\";\nimport construct from \"./construct.js\";\nexport default function _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n _cache.set(Class, Wrapper);\n }\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n };\n return _wrapNativeSuper(Class);\n}","export default function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}","import type { Location, Path, To } from \"./history\";\nimport { warning, invariant, parsePath } from \"./history\";\n\n/**\n * Map of routeId -> data returned from a loader/action/error\n */\nexport interface RouteData {\n [routeId: string]: any;\n}\n\nexport enum ResultType {\n data = \"data\",\n deferred = \"deferred\",\n redirect = \"redirect\",\n error = \"error\",\n}\n\n/**\n * Successful result from a loader or action\n */\nexport interface SuccessResult {\n type: ResultType.data;\n data: any;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Successful defer() result from a loader or action\n */\nexport interface DeferredResult {\n type: ResultType.deferred;\n deferredData: DeferredData;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Redirect result from a loader or action\n */\nexport interface RedirectResult {\n type: ResultType.redirect;\n status: number;\n location: string;\n revalidate: boolean;\n reloadDocument?: boolean;\n}\n\n/**\n * Unsuccessful result from a loader or action\n */\nexport interface ErrorResult {\n type: ResultType.error;\n error: any;\n headers?: Headers;\n}\n\n/**\n * Result from a loader or action - potentially successful or unsuccessful\n */\nexport type DataResult =\n | SuccessResult\n | DeferredResult\n | RedirectResult\n | ErrorResult;\n\ntype LowerCaseFormMethod = \"get\" | \"post\" | \"put\" | \"patch\" | \"delete\";\ntype UpperCaseFormMethod = Uppercase;\n\n/**\n * Users can specify either lowercase or uppercase form methods on
,\n * useSubmit(), , etc.\n */\nexport type HTMLFormMethod = LowerCaseFormMethod | UpperCaseFormMethod;\n\n/**\n * Active navigation/fetcher form methods are exposed in lowercase on the\n * RouterState\n */\nexport type FormMethod = LowerCaseFormMethod;\nexport type MutationFormMethod = Exclude;\n\n/**\n * In v7, active navigation/fetcher form methods are exposed in uppercase on the\n * RouterState. This is to align with the normalization done via fetch().\n */\nexport type V7_FormMethod = UpperCaseFormMethod;\nexport type V7_MutationFormMethod = Exclude;\n\nexport type FormEncType =\n | \"application/x-www-form-urlencoded\"\n | \"multipart/form-data\"\n | \"application/json\"\n | \"text/plain\";\n\n// Thanks https://github.com/sindresorhus/type-fest!\ntype JsonObject = { [Key in string]: JsonValue } & {\n [Key in string]?: JsonValue | undefined;\n};\ntype JsonArray = JsonValue[] | readonly JsonValue[];\ntype JsonPrimitive = string | number | boolean | null;\ntype JsonValue = JsonPrimitive | JsonObject | JsonArray;\n\n/**\n * @private\n * Internal interface to pass around for action submissions, not intended for\n * external consumption\n */\nexport type Submission =\n | {\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\n json: undefined;\n text: undefined;\n }\n | {\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: undefined;\n json: JsonValue;\n text: undefined;\n }\n | {\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: undefined;\n json: undefined;\n text: string;\n };\n\n/**\n * @private\n * Arguments passed to route loader/action functions. Same for now but we keep\n * this as a private implementation detail in case they diverge in the future.\n */\ninterface DataFunctionArgs {\n request: Request;\n params: Params;\n context?: any;\n}\n\n/**\n * Arguments passed to loader functions\n */\nexport interface LoaderFunctionArgs extends DataFunctionArgs {}\n\n/**\n * Arguments passed to action functions\n */\nexport interface ActionFunctionArgs extends DataFunctionArgs {}\n\n/**\n * Loaders and actions can return anything except `undefined` (`null` is a\n * valid return value if there is no data to return). Responses are preferred\n * and will ease any future migration to Remix\n */\ntype DataFunctionValue = Response | NonNullable | null;\n\n/**\n * Route loader function signature\n */\nexport interface LoaderFunction {\n (args: LoaderFunctionArgs): Promise | DataFunctionValue;\n}\n\n/**\n * Route action function signature\n */\nexport interface ActionFunction {\n (args: ActionFunctionArgs): Promise | DataFunctionValue;\n}\n\n/**\n * Route shouldRevalidate function signature. This runs after any submission\n * (navigation or fetcher), so we flatten the navigation/fetcher submission\n * onto the arguments. It shouldn't matter whether it came from a navigation\n * or a fetcher, what really matters is the URLs and the formData since loaders\n * have to re-run based on the data models that were potentially mutated.\n */\nexport interface ShouldRevalidateFunction {\n (args: {\n currentUrl: URL;\n currentParams: AgnosticDataRouteMatch[\"params\"];\n nextUrl: URL;\n nextParams: AgnosticDataRouteMatch[\"params\"];\n formMethod?: Submission[\"formMethod\"];\n formAction?: Submission[\"formAction\"];\n formEncType?: Submission[\"formEncType\"];\n text?: Submission[\"text\"];\n formData?: Submission[\"formData\"];\n json?: Submission[\"json\"];\n actionResult?: DataResult;\n defaultShouldRevalidate: boolean;\n }): boolean;\n}\n\n/**\n * Function provided by the framework-aware layers to set `hasErrorBoundary`\n * from the framework-aware `errorElement` prop\n *\n * @deprecated Use `mapRouteProperties` instead\n */\nexport interface DetectErrorBoundaryFunction {\n (route: AgnosticRouteObject): boolean;\n}\n\n/**\n * Function provided by the framework-aware layers to set any framework-specific\n * properties from framework-agnostic properties\n */\nexport interface MapRoutePropertiesFunction {\n (route: AgnosticRouteObject): {\n hasErrorBoundary: boolean;\n } & Record;\n}\n\n/**\n * Keys we cannot change from within a lazy() function. We spread all other keys\n * onto the route. Either they're meaningful to the router, or they'll get\n * ignored.\n */\nexport type ImmutableRouteKey =\n | \"lazy\"\n | \"caseSensitive\"\n | \"path\"\n | \"id\"\n | \"index\"\n | \"children\";\n\nexport const immutableRouteKeys = new Set([\n \"lazy\",\n \"caseSensitive\",\n \"path\",\n \"id\",\n \"index\",\n \"children\",\n]);\n\ntype RequireOne = Exclude<\n {\n [K in keyof T]: K extends Key ? Omit & Required> : never;\n }[keyof T],\n undefined\n>;\n\n/**\n * lazy() function to load a route definition, which can add non-matching\n * related properties to a route\n */\nexport interface LazyRouteFunction {\n (): Promise>>;\n}\n\n/**\n * Base RouteObject with common props shared by all types of routes\n */\ntype AgnosticBaseRouteObject = {\n caseSensitive?: boolean;\n path?: string;\n id?: string;\n loader?: LoaderFunction;\n action?: ActionFunction;\n hasErrorBoundary?: boolean;\n shouldRevalidate?: ShouldRevalidateFunction;\n handle?: any;\n lazy?: LazyRouteFunction;\n};\n\n/**\n * Index routes must not have children\n */\nexport type AgnosticIndexRouteObject = AgnosticBaseRouteObject & {\n children?: undefined;\n index: true;\n};\n\n/**\n * Non-index routes may have children, but cannot have index\n */\nexport type AgnosticNonIndexRouteObject = AgnosticBaseRouteObject & {\n children?: AgnosticRouteObject[];\n index?: false;\n};\n\n/**\n * A route object represents a logical route, with (optionally) its child\n * routes organized in a tree-like structure.\n */\nexport type AgnosticRouteObject =\n | AgnosticIndexRouteObject\n | AgnosticNonIndexRouteObject;\n\nexport type AgnosticDataIndexRouteObject = AgnosticIndexRouteObject & {\n id: string;\n};\n\nexport type AgnosticDataNonIndexRouteObject = AgnosticNonIndexRouteObject & {\n children?: AgnosticDataRouteObject[];\n id: string;\n};\n\n/**\n * A data route object, which is just a RouteObject with a required unique ID\n */\nexport type AgnosticDataRouteObject =\n | AgnosticDataIndexRouteObject\n | AgnosticDataNonIndexRouteObject;\n\nexport type RouteManifest = Record;\n\n// Recursive helper for finding path parameters in the absence of wildcards\ntype _PathParam =\n // split path into individual path segments\n Path extends `${infer L}/${infer R}`\n ? _PathParam | _PathParam\n : // find params after `:`\n Path extends `:${infer Param}`\n ? Param extends `${infer Optional}?`\n ? Optional\n : Param\n : // otherwise, there aren't any params present\n never;\n\n/**\n * Examples:\n * \"/a/b/*\" -> \"*\"\n * \":a\" -> \"a\"\n * \"/a/:b\" -> \"b\"\n * \"/a/blahblahblah:b\" -> \"b\"\n * \"/:a/:b\" -> \"a\" | \"b\"\n * \"/:a/b/:c/*\" -> \"a\" | \"c\" | \"*\"\n */\ntype PathParam =\n // check if path is just a wildcard\n Path extends \"*\" | \"/*\"\n ? \"*\"\n : // look for wildcard at the end of the path\n Path extends `${infer Rest}/*`\n ? \"*\" | _PathParam\n : // look for params in the absence of wildcards\n _PathParam;\n\n// Attempt to parse the given string segment. If it fails, then just return the\n// plain string type as a default fallback. Otherwise return the union of the\n// parsed string literals that were referenced as dynamic segments in the route.\nexport type ParamParseKey =\n // if could not find path params, fallback to `string`\n [PathParam] extends [never] ? string : PathParam;\n\n/**\n * The parameters that were parsed from the URL path.\n */\nexport type Params = {\n readonly [key in Key]: string | undefined;\n};\n\n/**\n * A RouteMatch contains info about how a route matched a URL.\n */\nexport interface AgnosticRouteMatch<\n ParamKey extends string = string,\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n /**\n * The names and values of dynamic parameters in the URL.\n */\n params: Params;\n /**\n * The portion of the URL pathname that was matched.\n */\n pathname: string;\n /**\n * The portion of the URL pathname that was matched before child routes.\n */\n pathnameBase: string;\n /**\n * The route object that was used to match.\n */\n route: RouteObjectType;\n}\n\nexport interface AgnosticDataRouteMatch\n extends AgnosticRouteMatch {}\n\nfunction isIndexRoute(\n route: AgnosticRouteObject\n): route is AgnosticIndexRouteObject {\n return route.index === true;\n}\n\n// Walk the route tree generating unique IDs where necessary so we are working\n// solely with AgnosticDataRouteObject's within the Router\nexport function convertRoutesToDataRoutes(\n routes: AgnosticRouteObject[],\n mapRouteProperties: MapRoutePropertiesFunction,\n parentPath: number[] = [],\n manifest: RouteManifest = {}\n): AgnosticDataRouteObject[] {\n return routes.map((route, index) => {\n let treePath = [...parentPath, index];\n let id = typeof route.id === \"string\" ? route.id : treePath.join(\"-\");\n invariant(\n route.index !== true || !route.children,\n `Cannot specify children on an index route`\n );\n invariant(\n !manifest[id],\n `Found a route id collision on id \"${id}\". Route ` +\n \"id's must be globally unique within Data Router usages\"\n );\n\n if (isIndexRoute(route)) {\n let indexRoute: AgnosticDataIndexRouteObject = {\n ...route,\n ...mapRouteProperties(route),\n id,\n };\n manifest[id] = indexRoute;\n return indexRoute;\n } else {\n let pathOrLayoutRoute: AgnosticDataNonIndexRouteObject = {\n ...route,\n ...mapRouteProperties(route),\n id,\n children: undefined,\n };\n manifest[id] = pathOrLayoutRoute;\n\n if (route.children) {\n pathOrLayoutRoute.children = convertRoutesToDataRoutes(\n route.children,\n mapRouteProperties,\n treePath,\n manifest\n );\n }\n\n return pathOrLayoutRoute;\n }\n });\n}\n\n/**\n * Matches the given routes to a location and returns the match data.\n *\n * @see https://reactrouter.com/utils/match-routes\n */\nexport function matchRoutes<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n routes: RouteObjectType[],\n locationArg: Partial | string,\n basename = \"/\"\n): AgnosticRouteMatch[] | null {\n let location =\n typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n\n let pathname = stripBasename(location.pathname || \"/\", basename);\n\n if (pathname == null) {\n return null;\n }\n\n let branches = flattenRoutes(routes);\n rankRouteBranches(branches);\n\n let matches = null;\n for (let i = 0; matches == null && i < branches.length; ++i) {\n matches = matchRouteBranch(\n branches[i],\n // Incoming pathnames are generally encoded from either window.location\n // or from router.navigate, but we want to match against the unencoded\n // paths in the route definitions. Memory router locations won't be\n // encoded here but there also shouldn't be anything to decode so this\n // should be a safe operation. This avoids needing matchRoutes to be\n // history-aware.\n safelyDecodeURI(pathname)\n );\n }\n\n return matches;\n}\n\ninterface RouteMeta<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n relativePath: string;\n caseSensitive: boolean;\n childrenIndex: number;\n route: RouteObjectType;\n}\n\ninterface RouteBranch<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n path: string;\n score: number;\n routesMeta: RouteMeta[];\n}\n\nfunction flattenRoutes<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n routes: RouteObjectType[],\n branches: RouteBranch[] = [],\n parentsMeta: RouteMeta[] = [],\n parentPath = \"\"\n): RouteBranch[] {\n let flattenRoute = (\n route: RouteObjectType,\n index: number,\n relativePath?: string\n ) => {\n let meta: RouteMeta = {\n relativePath:\n relativePath === undefined ? route.path || \"\" : relativePath,\n caseSensitive: route.caseSensitive === true,\n childrenIndex: index,\n route,\n };\n\n if (meta.relativePath.startsWith(\"/\")) {\n invariant(\n meta.relativePath.startsWith(parentPath),\n `Absolute route path \"${meta.relativePath}\" nested under path ` +\n `\"${parentPath}\" is not valid. An absolute child route path ` +\n `must start with the combined path of all its parent routes.`\n );\n\n meta.relativePath = meta.relativePath.slice(parentPath.length);\n }\n\n let path = joinPaths([parentPath, meta.relativePath]);\n let routesMeta = parentsMeta.concat(meta);\n\n // Add the children before adding this route to the array so we traverse the\n // route tree depth-first and child routes appear before their parents in\n // the \"flattened\" version.\n if (route.children && route.children.length > 0) {\n invariant(\n // Our types know better, but runtime JS may not!\n // @ts-expect-error\n route.index !== true,\n `Index routes must not have child routes. Please remove ` +\n `all child routes from route path \"${path}\".`\n );\n\n flattenRoutes(route.children, branches, routesMeta, path);\n }\n\n // Routes without a path shouldn't ever match by themselves unless they are\n // index routes, so don't add them to the list of possible branches.\n if (route.path == null && !route.index) {\n return;\n }\n\n branches.push({\n path,\n score: computeScore(path, route.index),\n routesMeta,\n });\n };\n routes.forEach((route, index) => {\n // coarse-grain check for optional params\n if (route.path === \"\" || !route.path?.includes(\"?\")) {\n flattenRoute(route, index);\n } else {\n for (let exploded of explodeOptionalSegments(route.path)) {\n flattenRoute(route, index, exploded);\n }\n }\n });\n\n return branches;\n}\n\n/**\n * Computes all combinations of optional path segments for a given path,\n * excluding combinations that are ambiguous and of lower priority.\n *\n * For example, `/one/:two?/three/:four?/:five?` explodes to:\n * - `/one/three`\n * - `/one/:two/three`\n * - `/one/three/:four`\n * - `/one/three/:five`\n * - `/one/:two/three/:four`\n * - `/one/:two/three/:five`\n * - `/one/three/:four/:five`\n * - `/one/:two/three/:four/:five`\n */\nfunction explodeOptionalSegments(path: string): string[] {\n let segments = path.split(\"/\");\n if (segments.length === 0) return [];\n\n let [first, ...rest] = segments;\n\n // Optional path segments are denoted by a trailing `?`\n let isOptional = first.endsWith(\"?\");\n // Compute the corresponding required segment: `foo?` -> `foo`\n let required = first.replace(/\\?$/, \"\");\n\n if (rest.length === 0) {\n // Intepret empty string as omitting an optional segment\n // `[\"one\", \"\", \"three\"]` corresponds to omitting `:two` from `/one/:two?/three` -> `/one/three`\n return isOptional ? [required, \"\"] : [required];\n }\n\n let restExploded = explodeOptionalSegments(rest.join(\"/\"));\n\n let result: string[] = [];\n\n // All child paths with the prefix. Do this for all children before the\n // optional version for all children so we get consistent ordering where the\n // parent optional aspect is preferred as required. Otherwise, we can get\n // child sections interspersed where deeper optional segments are higher than\n // parent optional segments, where for example, /:two would explodes _earlier_\n // then /:one. By always including the parent as required _for all children_\n // first, we avoid this issue\n result.push(\n ...restExploded.map((subpath) =>\n subpath === \"\" ? required : [required, subpath].join(\"/\")\n )\n );\n\n // Then if this is an optional value, add all child versions without\n if (isOptional) {\n result.push(...restExploded);\n }\n\n // for absolute paths, ensure `/` instead of empty segment\n return result.map((exploded) =>\n path.startsWith(\"/\") && exploded === \"\" ? \"/\" : exploded\n );\n}\n\nfunction rankRouteBranches(branches: RouteBranch[]): void {\n branches.sort((a, b) =>\n a.score !== b.score\n ? b.score - a.score // Higher score first\n : compareIndexes(\n a.routesMeta.map((meta) => meta.childrenIndex),\n b.routesMeta.map((meta) => meta.childrenIndex)\n )\n );\n}\n\nconst paramRe = /^:\\w+$/;\nconst dynamicSegmentValue = 3;\nconst indexRouteValue = 2;\nconst emptySegmentValue = 1;\nconst staticSegmentValue = 10;\nconst splatPenalty = -2;\nconst isSplat = (s: string) => s === \"*\";\n\nfunction computeScore(path: string, index: boolean | undefined): number {\n let segments = path.split(\"/\");\n let initialScore = segments.length;\n if (segments.some(isSplat)) {\n initialScore += splatPenalty;\n }\n\n if (index) {\n initialScore += indexRouteValue;\n }\n\n return segments\n .filter((s) => !isSplat(s))\n .reduce(\n (score, segment) =>\n score +\n (paramRe.test(segment)\n ? dynamicSegmentValue\n : segment === \"\"\n ? emptySegmentValue\n : staticSegmentValue),\n initialScore\n );\n}\n\nfunction compareIndexes(a: number[], b: number[]): number {\n let siblings =\n a.length === b.length && a.slice(0, -1).every((n, i) => n === b[i]);\n\n return siblings\n ? // If two routes are siblings, we should try to match the earlier sibling\n // first. This allows people to have fine-grained control over the matching\n // behavior by simply putting routes with identical paths in the order they\n // want them tried.\n a[a.length - 1] - b[b.length - 1]\n : // Otherwise, it doesn't really make sense to rank non-siblings by index,\n // so they sort equally.\n 0;\n}\n\nfunction matchRouteBranch<\n ParamKey extends string = string,\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n branch: RouteBranch,\n pathname: string\n): AgnosticRouteMatch[] | null {\n let { routesMeta } = branch;\n\n let matchedParams = {};\n let matchedPathname = \"/\";\n let matches: AgnosticRouteMatch[] = [];\n for (let i = 0; i < routesMeta.length; ++i) {\n let meta = routesMeta[i];\n let end = i === routesMeta.length - 1;\n let remainingPathname =\n matchedPathname === \"/\"\n ? pathname\n : pathname.slice(matchedPathname.length) || \"/\";\n let match = matchPath(\n { path: meta.relativePath, caseSensitive: meta.caseSensitive, end },\n remainingPathname\n );\n\n if (!match) return null;\n\n Object.assign(matchedParams, match.params);\n\n let route = meta.route;\n\n matches.push({\n // TODO: Can this as be avoided?\n params: matchedParams as Params,\n pathname: joinPaths([matchedPathname, match.pathname]),\n pathnameBase: normalizePathname(\n joinPaths([matchedPathname, match.pathnameBase])\n ),\n route,\n });\n\n if (match.pathnameBase !== \"/\") {\n matchedPathname = joinPaths([matchedPathname, match.pathnameBase]);\n }\n }\n\n return matches;\n}\n\n/**\n * Returns a path with params interpolated.\n *\n * @see https://reactrouter.com/utils/generate-path\n */\nexport function generatePath(\n originalPath: Path,\n params: {\n [key in PathParam]: string | null;\n } = {} as any\n): string {\n let path: string = originalPath;\n if (path.endsWith(\"*\") && path !== \"*\" && !path.endsWith(\"/*\")) {\n warning(\n false,\n `Route path \"${path}\" will be treated as if it were ` +\n `\"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must ` +\n `always follow a \\`/\\` in the pattern. To get rid of this warning, ` +\n `please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n path = path.replace(/\\*$/, \"/*\") as Path;\n }\n\n // ensure `/` is added at the beginning if the path is absolute\n const prefix = path.startsWith(\"/\") ? \"/\" : \"\";\n\n const stringify = (p: any) =>\n p == null ? \"\" : typeof p === \"string\" ? p : String(p);\n\n const segments = path\n .split(/\\/+/)\n .map((segment, index, array) => {\n const isLastSegment = index === array.length - 1;\n\n // only apply the splat if it's the last segment\n if (isLastSegment && segment === \"*\") {\n const star = \"*\" as PathParam;\n // Apply the splat\n return stringify(params[star]);\n }\n\n const keyMatch = segment.match(/^:(\\w+)(\\??)$/);\n if (keyMatch) {\n const [, key, optional] = keyMatch;\n let param = params[key as PathParam];\n invariant(optional === \"?\" || param != null, `Missing \":${key}\" param`);\n return stringify(param);\n }\n\n // Remove any optional markers from optional static segments\n return segment.replace(/\\?$/g, \"\");\n })\n // Remove empty segments\n .filter((segment) => !!segment);\n\n return prefix + segments.join(\"/\");\n}\n\n/**\n * A PathPattern is used to match on some portion of a URL pathname.\n */\nexport interface PathPattern {\n /**\n * A string to match against a URL pathname. May contain `:id`-style segments\n * to indicate placeholders for dynamic parameters. May also end with `/*` to\n * indicate matching the rest of the URL pathname.\n */\n path: Path;\n /**\n * Should be `true` if the static portions of the `path` should be matched in\n * the same case.\n */\n caseSensitive?: boolean;\n /**\n * Should be `true` if this pattern should match the entire URL pathname.\n */\n end?: boolean;\n}\n\n/**\n * A PathMatch contains info about how a PathPattern matched on a URL pathname.\n */\nexport interface PathMatch {\n /**\n * The names and values of dynamic parameters in the URL.\n */\n params: Params;\n /**\n * The portion of the URL pathname that was matched.\n */\n pathname: string;\n /**\n * The portion of the URL pathname that was matched before child routes.\n */\n pathnameBase: string;\n /**\n * The pattern that was used to match.\n */\n pattern: PathPattern;\n}\n\ntype Mutable = {\n -readonly [P in keyof T]: T[P];\n};\n\n/**\n * Performs pattern matching on a URL pathname and returns information about\n * the match.\n *\n * @see https://reactrouter.com/utils/match-path\n */\nexport function matchPath<\n ParamKey extends ParamParseKey,\n Path extends string\n>(\n pattern: PathPattern | Path,\n pathname: string\n): PathMatch | null {\n if (typeof pattern === \"string\") {\n pattern = { path: pattern, caseSensitive: false, end: true };\n }\n\n let [matcher, paramNames] = compilePath(\n pattern.path,\n pattern.caseSensitive,\n pattern.end\n );\n\n let match = pathname.match(matcher);\n if (!match) return null;\n\n let matchedPathname = match[0];\n let pathnameBase = matchedPathname.replace(/(.)\\/+$/, \"$1\");\n let captureGroups = match.slice(1);\n let params: Params = paramNames.reduce>(\n (memo, paramName, index) => {\n // We need to compute the pathnameBase here using the raw splat value\n // instead of using params[\"*\"] later because it will be decoded then\n if (paramName === \"*\") {\n let splatValue = captureGroups[index] || \"\";\n pathnameBase = matchedPathname\n .slice(0, matchedPathname.length - splatValue.length)\n .replace(/(.)\\/+$/, \"$1\");\n }\n\n memo[paramName] = safelyDecodeURIComponent(\n captureGroups[index] || \"\",\n paramName\n );\n return memo;\n },\n {}\n );\n\n return {\n params,\n pathname: matchedPathname,\n pathnameBase,\n pattern,\n };\n}\n\nfunction compilePath(\n path: string,\n caseSensitive = false,\n end = true\n): [RegExp, string[]] {\n warning(\n path === \"*\" || !path.endsWith(\"*\") || path.endsWith(\"/*\"),\n `Route path \"${path}\" will be treated as if it were ` +\n `\"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must ` +\n `always follow a \\`/\\` in the pattern. To get rid of this warning, ` +\n `please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n\n let paramNames: string[] = [];\n let regexpSource =\n \"^\" +\n path\n .replace(/\\/*\\*?$/, \"\") // Ignore trailing / and /*, we'll handle it below\n .replace(/^\\/*/, \"/\") // Make sure it has a leading /\n .replace(/[\\\\.*+^$?{}|()[\\]]/g, \"\\\\$&\") // Escape special regex chars\n .replace(/\\/:(\\w+)/g, (_: string, paramName: string) => {\n paramNames.push(paramName);\n return \"/([^\\\\/]+)\";\n });\n\n if (path.endsWith(\"*\")) {\n paramNames.push(\"*\");\n regexpSource +=\n path === \"*\" || path === \"/*\"\n ? \"(.*)$\" // Already matched the initial /, just match the rest\n : \"(?:\\\\/(.+)|\\\\/*)$\"; // Don't include the / in params[\"*\"]\n } else if (end) {\n // When matching to the end, ignore trailing slashes\n regexpSource += \"\\\\/*$\";\n } else if (path !== \"\" && path !== \"/\") {\n // If our path is non-empty and contains anything beyond an initial slash,\n // then we have _some_ form of path in our regex so we should expect to\n // match only if we find the end of this path segment. Look for an optional\n // non-captured trailing slash (to match a portion of the URL) or the end\n // of the path (if we've matched to the end). We used to do this with a\n // word boundary but that gives false positives on routes like\n // /user-preferences since `-` counts as a word boundary.\n regexpSource += \"(?:(?=\\\\/|$))\";\n } else {\n // Nothing to match for \"\" or \"/\"\n }\n\n let matcher = new RegExp(regexpSource, caseSensitive ? undefined : \"i\");\n\n return [matcher, paramNames];\n}\n\nfunction safelyDecodeURI(value: string) {\n try {\n return decodeURI(value);\n } catch (error) {\n warning(\n false,\n `The URL path \"${value}\" could not be decoded because it is is a ` +\n `malformed URL segment. This is probably due to a bad percent ` +\n `encoding (${error}).`\n );\n\n return value;\n }\n}\n\nfunction safelyDecodeURIComponent(value: string, paramName: string) {\n try {\n return decodeURIComponent(value);\n } catch (error) {\n warning(\n false,\n `The value for the URL param \"${paramName}\" will not be decoded because` +\n ` the string \"${value}\" is a malformed URL segment. This is probably` +\n ` due to a bad percent encoding (${error}).`\n );\n\n return value;\n }\n}\n\n/**\n * @private\n */\nexport function stripBasename(\n pathname: string,\n basename: string\n): string | null {\n if (basename === \"/\") return pathname;\n\n if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {\n return null;\n }\n\n // We want to leave trailing slash behavior in the user's control, so if they\n // specify a basename with a trailing slash, we should support it\n let startIndex = basename.endsWith(\"/\")\n ? basename.length - 1\n : basename.length;\n let nextChar = pathname.charAt(startIndex);\n if (nextChar && nextChar !== \"/\") {\n // pathname does not start with basename/\n return null;\n }\n\n return pathname.slice(startIndex) || \"/\";\n}\n\n/**\n * Returns a resolved path object relative to the given pathname.\n *\n * @see https://reactrouter.com/utils/resolve-path\n */\nexport function resolvePath(to: To, fromPathname = \"/\"): Path {\n let {\n pathname: toPathname,\n search = \"\",\n hash = \"\",\n } = typeof to === \"string\" ? parsePath(to) : to;\n\n let pathname = toPathname\n ? toPathname.startsWith(\"/\")\n ? toPathname\n : resolvePathname(toPathname, fromPathname)\n : fromPathname;\n\n return {\n pathname,\n search: normalizeSearch(search),\n hash: normalizeHash(hash),\n };\n}\n\nfunction resolvePathname(relativePath: string, fromPathname: string): string {\n let segments = fromPathname.replace(/\\/+$/, \"\").split(\"/\");\n let relativeSegments = relativePath.split(\"/\");\n\n relativeSegments.forEach((segment) => {\n if (segment === \"..\") {\n // Keep the root \"\" segment so the pathname starts at /\n if (segments.length > 1) segments.pop();\n } else if (segment !== \".\") {\n segments.push(segment);\n }\n });\n\n return segments.length > 1 ? segments.join(\"/\") : \"/\";\n}\n\nfunction getInvalidPathError(\n char: string,\n field: string,\n dest: string,\n path: Partial\n) {\n return (\n `Cannot include a '${char}' character in a manually specified ` +\n `\\`to.${field}\\` field [${JSON.stringify(\n path\n )}]. Please separate it out to the ` +\n `\\`to.${dest}\\` field. Alternatively you may provide the full path as ` +\n `a string in and the router will parse it for you.`\n );\n}\n\n/**\n * @private\n *\n * When processing relative navigation we want to ignore ancestor routes that\n * do not contribute to the path, such that index/pathless layout routes don't\n * interfere.\n *\n * For example, when moving a route element into an index route and/or a\n * pathless layout route, relative link behavior contained within should stay\n * the same. Both of the following examples should link back to the root:\n *\n * \n * \n * \n *\n * \n * \n * }> // <-- Does not contribute\n * // <-- Does not contribute\n * \n * \n */\nexport function getPathContributingMatches<\n T extends AgnosticRouteMatch = AgnosticRouteMatch\n>(matches: T[]) {\n return matches.filter(\n (match, index) =>\n index === 0 || (match.route.path && match.route.path.length > 0)\n );\n}\n\n/**\n * @private\n */\nexport function resolveTo(\n toArg: To,\n routePathnames: string[],\n locationPathname: string,\n isPathRelative = false\n): Path {\n let to: Partial;\n if (typeof toArg === \"string\") {\n to = parsePath(toArg);\n } else {\n to = { ...toArg };\n\n invariant(\n !to.pathname || !to.pathname.includes(\"?\"),\n getInvalidPathError(\"?\", \"pathname\", \"search\", to)\n );\n invariant(\n !to.pathname || !to.pathname.includes(\"#\"),\n getInvalidPathError(\"#\", \"pathname\", \"hash\", to)\n );\n invariant(\n !to.search || !to.search.includes(\"#\"),\n getInvalidPathError(\"#\", \"search\", \"hash\", to)\n );\n }\n\n let isEmptyPath = toArg === \"\" || to.pathname === \"\";\n let toPathname = isEmptyPath ? \"/\" : to.pathname;\n\n let from: string;\n\n // Routing is relative to the current pathname if explicitly requested.\n //\n // If a pathname is explicitly provided in `to`, it should be relative to the\n // route context. This is explained in `Note on `` values` in our\n // migration guide from v5 as a means of disambiguation between `to` values\n // that begin with `/` and those that do not. However, this is problematic for\n // `to` values that do not provide a pathname. `to` can simply be a search or\n // hash string, in which case we should assume that the navigation is relative\n // to the current location's pathname and *not* the route pathname.\n if (isPathRelative || toPathname == null) {\n from = locationPathname;\n } else {\n let routePathnameIndex = routePathnames.length - 1;\n\n if (toPathname.startsWith(\"..\")) {\n let toSegments = toPathname.split(\"/\");\n\n // Each leading .. segment means \"go up one route\" instead of \"go up one\n // URL segment\". This is a key difference from how works and a\n // major reason we call this a \"to\" value instead of a \"href\".\n while (toSegments[0] === \"..\") {\n toSegments.shift();\n routePathnameIndex -= 1;\n }\n\n to.pathname = toSegments.join(\"/\");\n }\n\n // If there are more \"..\" segments than parent routes, resolve relative to\n // the root / URL.\n from = routePathnameIndex >= 0 ? routePathnames[routePathnameIndex] : \"/\";\n }\n\n let path = resolvePath(to, from);\n\n // Ensure the pathname has a trailing slash if the original \"to\" had one\n let hasExplicitTrailingSlash =\n toPathname && toPathname !== \"/\" && toPathname.endsWith(\"/\");\n // Or if this was a link to the current path which has a trailing slash\n let hasCurrentTrailingSlash =\n (isEmptyPath || toPathname === \".\") && locationPathname.endsWith(\"/\");\n if (\n !path.pathname.endsWith(\"/\") &&\n (hasExplicitTrailingSlash || hasCurrentTrailingSlash)\n ) {\n path.pathname += \"/\";\n }\n\n return path;\n}\n\n/**\n * @private\n */\nexport function getToPathname(to: To): string | undefined {\n // Empty strings should be treated the same as / paths\n return to === \"\" || (to as Path).pathname === \"\"\n ? \"/\"\n : typeof to === \"string\"\n ? parsePath(to).pathname\n : to.pathname;\n}\n\n/**\n * @private\n */\nexport const joinPaths = (paths: string[]): string =>\n paths.join(\"/\").replace(/\\/\\/+/g, \"/\");\n\n/**\n * @private\n */\nexport const normalizePathname = (pathname: string): string =>\n pathname.replace(/\\/+$/, \"\").replace(/^\\/*/, \"/\");\n\n/**\n * @private\n */\nexport const normalizeSearch = (search: string): string =>\n !search || search === \"?\"\n ? \"\"\n : search.startsWith(\"?\")\n ? search\n : \"?\" + search;\n\n/**\n * @private\n */\nexport const normalizeHash = (hash: string): string =>\n !hash || hash === \"#\" ? \"\" : hash.startsWith(\"#\") ? hash : \"#\" + hash;\n\nexport type JsonFunction = (\n data: Data,\n init?: number | ResponseInit\n) => Response;\n\n/**\n * This is a shortcut for creating `application/json` responses. Converts `data`\n * to JSON and sets the `Content-Type` header.\n */\nexport const json: JsonFunction = (data, init = {}) => {\n let responseInit = typeof init === \"number\" ? { status: init } : init;\n\n let headers = new Headers(responseInit.headers);\n if (!headers.has(\"Content-Type\")) {\n headers.set(\"Content-Type\", \"application/json; charset=utf-8\");\n }\n\n return new Response(JSON.stringify(data), {\n ...responseInit,\n headers,\n });\n};\n\nexport interface TrackedPromise extends Promise {\n _tracked?: boolean;\n _data?: any;\n _error?: any;\n}\n\nexport class AbortedDeferredError extends Error {}\n\nexport class DeferredData {\n private pendingKeysSet: Set = new Set();\n private controller: AbortController;\n private abortPromise: Promise;\n private unlistenAbortSignal: () => void;\n private subscribers: Set<(aborted: boolean, settledKey?: string) => void> =\n new Set();\n data: Record;\n init?: ResponseInit;\n deferredKeys: string[] = [];\n\n constructor(data: Record, responseInit?: ResponseInit) {\n invariant(\n data && typeof data === \"object\" && !Array.isArray(data),\n \"defer() only accepts plain objects\"\n );\n\n // Set up an AbortController + Promise we can race against to exit early\n // cancellation\n let reject: (e: AbortedDeferredError) => void;\n this.abortPromise = new Promise((_, r) => (reject = r));\n this.controller = new AbortController();\n let onAbort = () =>\n reject(new AbortedDeferredError(\"Deferred data aborted\"));\n this.unlistenAbortSignal = () =>\n this.controller.signal.removeEventListener(\"abort\", onAbort);\n this.controller.signal.addEventListener(\"abort\", onAbort);\n\n this.data = Object.entries(data).reduce(\n (acc, [key, value]) =>\n Object.assign(acc, {\n [key]: this.trackPromise(key, value),\n }),\n {}\n );\n\n if (this.done) {\n // All incoming values were resolved\n this.unlistenAbortSignal();\n }\n\n this.init = responseInit;\n }\n\n private trackPromise(\n key: string,\n value: Promise | unknown\n ): TrackedPromise | unknown {\n if (!(value instanceof Promise)) {\n return value;\n }\n\n this.deferredKeys.push(key);\n this.pendingKeysSet.add(key);\n\n // We store a little wrapper promise that will be extended with\n // _data/_error props upon resolve/reject\n let promise: TrackedPromise = Promise.race([value, this.abortPromise]).then(\n (data) => this.onSettle(promise, key, undefined, data as unknown),\n (error) => this.onSettle(promise, key, error as unknown)\n );\n\n // Register rejection listeners to avoid uncaught promise rejections on\n // errors or aborted deferred values\n promise.catch(() => {});\n\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n return promise;\n }\n\n private onSettle(\n promise: TrackedPromise,\n key: string,\n error: unknown,\n data?: unknown\n ): unknown {\n if (\n this.controller.signal.aborted &&\n error instanceof AbortedDeferredError\n ) {\n this.unlistenAbortSignal();\n Object.defineProperty(promise, \"_error\", { get: () => error });\n return Promise.reject(error);\n }\n\n this.pendingKeysSet.delete(key);\n\n if (this.done) {\n // Nothing left to abort!\n this.unlistenAbortSignal();\n }\n\n // If the promise was resolved/rejected with undefined, we'll throw an error as you\n // should always resolve with a value or null\n if (error === undefined && data === undefined) {\n let undefinedError = new Error(\n `Deferred data for key \"${key}\" resolved/rejected with \\`undefined\\`, ` +\n `you must resolve/reject with a value or \\`null\\`.`\n );\n Object.defineProperty(promise, \"_error\", { get: () => undefinedError });\n this.emit(false, key);\n return Promise.reject(undefinedError);\n }\n\n if (data === undefined) {\n Object.defineProperty(promise, \"_error\", { get: () => error });\n this.emit(false, key);\n return Promise.reject(error);\n }\n\n Object.defineProperty(promise, \"_data\", { get: () => data });\n this.emit(false, key);\n return data;\n }\n\n private emit(aborted: boolean, settledKey?: string) {\n this.subscribers.forEach((subscriber) => subscriber(aborted, settledKey));\n }\n\n subscribe(fn: (aborted: boolean, settledKey?: string) => void) {\n this.subscribers.add(fn);\n return () => this.subscribers.delete(fn);\n }\n\n cancel() {\n this.controller.abort();\n this.pendingKeysSet.forEach((v, k) => this.pendingKeysSet.delete(k));\n this.emit(true);\n }\n\n async resolveData(signal: AbortSignal) {\n let aborted = false;\n if (!this.done) {\n let onAbort = () => this.cancel();\n signal.addEventListener(\"abort\", onAbort);\n aborted = await new Promise((resolve) => {\n this.subscribe((aborted) => {\n signal.removeEventListener(\"abort\", onAbort);\n if (aborted || this.done) {\n resolve(aborted);\n }\n });\n });\n }\n return aborted;\n }\n\n get done() {\n return this.pendingKeysSet.size === 0;\n }\n\n get unwrappedData() {\n invariant(\n this.data !== null && this.done,\n \"Can only unwrap data on initialized and settled deferreds\"\n );\n\n return Object.entries(this.data).reduce(\n (acc, [key, value]) =>\n Object.assign(acc, {\n [key]: unwrapTrackedPromise(value),\n }),\n {}\n );\n }\n\n get pendingKeys() {\n return Array.from(this.pendingKeysSet);\n }\n}\n\nfunction isTrackedPromise(value: any): value is TrackedPromise {\n return (\n value instanceof Promise && (value as TrackedPromise)._tracked === true\n );\n}\n\nfunction unwrapTrackedPromise(value: any) {\n if (!isTrackedPromise(value)) {\n return value;\n }\n\n if (value._error) {\n throw value._error;\n }\n return value._data;\n}\n\nexport type DeferFunction = (\n data: Record,\n init?: number | ResponseInit\n) => DeferredData;\n\nexport const defer: DeferFunction = (data, init = {}) => {\n let responseInit = typeof init === \"number\" ? { status: init } : init;\n\n return new DeferredData(data, responseInit);\n};\n\nexport type RedirectFunction = (\n url: string,\n init?: number | ResponseInit\n) => Response;\n\n/**\n * A redirect response. Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nexport const redirect: RedirectFunction = (url, init = 302) => {\n let responseInit = init;\n if (typeof responseInit === \"number\") {\n responseInit = { status: responseInit };\n } else if (typeof responseInit.status === \"undefined\") {\n responseInit.status = 302;\n }\n\n let headers = new Headers(responseInit.headers);\n headers.set(\"Location\", url);\n\n return new Response(null, {\n ...responseInit,\n headers,\n });\n};\n\n/**\n * A redirect response that will force a document reload to the new location.\n * Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nexport const redirectDocument: RedirectFunction = (url, init) => {\n let response = redirect(url, init);\n response.headers.set(\"X-Remix-Reload-Document\", \"true\");\n return response;\n};\n\n/**\n * @private\n * Utility class we use to hold auto-unwrapped 4xx/5xx Response bodies\n */\nexport class ErrorResponse {\n status: number;\n statusText: string;\n data: any;\n error?: Error;\n internal: boolean;\n\n constructor(\n status: number,\n statusText: string | undefined,\n data: any,\n internal = false\n ) {\n this.status = status;\n this.statusText = statusText || \"\";\n this.internal = internal;\n if (data instanceof Error) {\n this.data = data.toString();\n this.error = data;\n } else {\n this.data = data;\n }\n }\n}\n\n/**\n * Check if the given error is an ErrorResponse generated from a 4xx/5xx\n * Response thrown from an action/loader\n */\nexport function isRouteErrorResponse(error: any): error is ErrorResponse {\n return (\n error != null &&\n typeof error.status === \"number\" &&\n typeof error.statusText === \"string\" &&\n typeof error.internal === \"boolean\" &&\n \"data\" in error\n );\n}\n","import unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nexport default function _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {};\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableRest();\n}","import type { History, Location, Path, To } from \"./history\";\nimport {\n Action as HistoryAction,\n createLocation,\n createPath,\n invariant,\n parsePath,\n warning,\n} from \"./history\";\nimport type {\n DataResult,\n DeferredData,\n AgnosticDataRouteMatch,\n AgnosticDataRouteObject,\n DeferredResult,\n ErrorResult,\n FormEncType,\n FormMethod,\n DetectErrorBoundaryFunction,\n RedirectResult,\n RouteData,\n AgnosticRouteObject,\n Submission,\n SuccessResult,\n AgnosticRouteMatch,\n ShouldRevalidateFunction,\n RouteManifest,\n ImmutableRouteKey,\n ActionFunction,\n LoaderFunction,\n V7_MutationFormMethod,\n V7_FormMethod,\n HTMLFormMethod,\n MutationFormMethod,\n MapRoutePropertiesFunction,\n} from \"./utils\";\nimport {\n ErrorResponse,\n ResultType,\n convertRoutesToDataRoutes,\n getPathContributingMatches,\n immutableRouteKeys,\n isRouteErrorResponse,\n joinPaths,\n matchRoutes,\n resolveTo,\n stripBasename,\n} from \"./utils\";\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A Router instance manages all navigation and data loading/mutations\n */\nexport interface Router {\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the basename for the router\n */\n get basename(): RouterInit[\"basename\"];\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the current state of the router\n */\n get state(): RouterState;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the routes for this router instance\n */\n get routes(): AgnosticDataRouteObject[];\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Initialize the router, including adding history listeners and kicking off\n * initial data fetches. Returns a function to cleanup listeners and abort\n * any in-progress loads\n */\n initialize(): Router;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Subscribe to router.state updates\n *\n * @param fn function to call with the new state\n */\n subscribe(fn: RouterSubscriber): () => void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Enable scroll restoration behavior in the router\n *\n * @param savedScrollPositions Object that will manage positions, in case\n * it's being restored from sessionStorage\n * @param getScrollPosition Function to get the active Y scroll position\n * @param getKey Function to get the key to use for restoration\n */\n enableScrollRestoration(\n savedScrollPositions: Record,\n getScrollPosition: GetScrollPositionFunction,\n getKey?: GetScrollRestorationKeyFunction\n ): () => void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Navigate forward/backward in the history stack\n * @param to Delta to move in the history stack\n */\n navigate(to: number): Promise;\n\n /**\n * Navigate to the given path\n * @param to Path to navigate to\n * @param opts Navigation options (method, submission, etc.)\n */\n navigate(to: To | null, opts?: RouterNavigateOptions): Promise;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Trigger a fetcher load/submission\n *\n * @param key Fetcher key\n * @param routeId Route that owns the fetcher\n * @param href href to fetch\n * @param opts Fetcher options, (method, submission, etc.)\n */\n fetch(\n key: string,\n routeId: string,\n href: string | null,\n opts?: RouterFetchOptions\n ): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Trigger a revalidation of all current route loaders and fetcher loads\n */\n revalidate(): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Utility function to create an href for the given location\n * @param location\n */\n createHref(location: Location | URL): string;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Utility function to URL encode a destination path according to the internal\n * history implementation\n * @param to\n */\n encodeLocation(to: To): Path;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Get/create a fetcher for the given key\n * @param key\n */\n getFetcher(key?: string): Fetcher;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Delete the fetcher for a given key\n * @param key\n */\n deleteFetcher(key?: string): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Cleanup listeners and abort any in-progress loads\n */\n dispose(): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Get a navigation blocker\n * @param key The identifier for the blocker\n * @param fn The blocker function implementation\n */\n getBlocker(key: string, fn: BlockerFunction): Blocker;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Delete a navigation blocker\n * @param key The identifier for the blocker\n */\n deleteBlocker(key: string): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * HMR needs to pass in-flight route updates to React Router\n * TODO: Replace this with granular route update APIs (addRoute, updateRoute, deleteRoute)\n */\n _internalSetRoutes(routes: AgnosticRouteObject[]): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Internal fetch AbortControllers accessed by unit tests\n */\n _internalFetchControllers: Map;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Internal pending DeferredData instances accessed by unit tests\n */\n _internalActiveDeferreds: Map;\n}\n\n/**\n * State maintained internally by the router. During a navigation, all states\n * reflect the the \"old\" location unless otherwise noted.\n */\nexport interface RouterState {\n /**\n * The action of the most recent navigation\n */\n historyAction: HistoryAction;\n\n /**\n * The current location reflected by the router\n */\n location: Location;\n\n /**\n * The current set of route matches\n */\n matches: AgnosticDataRouteMatch[];\n\n /**\n * Tracks whether we've completed our initial data load\n */\n initialized: boolean;\n\n /**\n * Current scroll position we should start at for a new view\n * - number -> scroll position to restore to\n * - false -> do not restore scroll at all (used during submissions)\n * - null -> don't have a saved position, scroll to hash or top of page\n */\n restoreScrollPosition: number | false | null;\n\n /**\n * Indicate whether this navigation should skip resetting the scroll position\n * if we are unable to restore the scroll position\n */\n preventScrollReset: boolean;\n\n /**\n * Tracks the state of the current navigation\n */\n navigation: Navigation;\n\n /**\n * Tracks any in-progress revalidations\n */\n revalidation: RevalidationState;\n\n /**\n * Data from the loaders for the current matches\n */\n loaderData: RouteData;\n\n /**\n * Data from the action for the current matches\n */\n actionData: RouteData | null;\n\n /**\n * Errors caught from loaders for the current matches\n */\n errors: RouteData | null;\n\n /**\n * Map of current fetchers\n */\n fetchers: Map;\n\n /**\n * Map of current blockers\n */\n blockers: Map;\n}\n\n/**\n * Data that can be passed into hydrate a Router from SSR\n */\nexport type HydrationState = Partial<\n Pick\n>;\n\n/**\n * Future flags to toggle new feature behavior\n */\nexport interface FutureConfig {\n v7_normalizeFormMethod: boolean;\n v7_prependBasename: boolean;\n}\n\n/**\n * Initialization options for createRouter\n */\nexport interface RouterInit {\n routes: AgnosticRouteObject[];\n history: History;\n basename?: string;\n /**\n * @deprecated Use `mapRouteProperties` instead\n */\n detectErrorBoundary?: DetectErrorBoundaryFunction;\n mapRouteProperties?: MapRoutePropertiesFunction;\n future?: Partial;\n hydrationData?: HydrationState;\n window?: Window;\n}\n\n/**\n * State returned from a server-side query() call\n */\nexport interface StaticHandlerContext {\n basename: Router[\"basename\"];\n location: RouterState[\"location\"];\n matches: RouterState[\"matches\"];\n loaderData: RouterState[\"loaderData\"];\n actionData: RouterState[\"actionData\"];\n errors: RouterState[\"errors\"];\n statusCode: number;\n loaderHeaders: Record;\n actionHeaders: Record;\n activeDeferreds: Record | null;\n _deepestRenderedBoundaryId?: string | null;\n}\n\n/**\n * A StaticHandler instance manages a singular SSR navigation/fetch event\n */\nexport interface StaticHandler {\n dataRoutes: AgnosticDataRouteObject[];\n query(\n request: Request,\n opts?: { requestContext?: unknown }\n ): Promise;\n queryRoute(\n request: Request,\n opts?: { routeId?: string; requestContext?: unknown }\n ): Promise;\n}\n\n/**\n * Subscriber function signature for changes to router state\n */\nexport interface RouterSubscriber {\n (state: RouterState): void;\n}\n\ninterface UseMatchesMatch {\n id: string;\n pathname: string;\n params: AgnosticRouteMatch[\"params\"];\n data: unknown;\n handle: unknown;\n}\n\n/**\n * Function signature for determining the key to be used in scroll restoration\n * for a given location\n */\nexport interface GetScrollRestorationKeyFunction {\n (location: Location, matches: UseMatchesMatch[]): string | null;\n}\n\n/**\n * Function signature for determining the current scroll position\n */\nexport interface GetScrollPositionFunction {\n (): number;\n}\n\nexport type RelativeRoutingType = \"route\" | \"path\";\n\n// Allowed for any navigation or fetch\ntype BaseNavigateOrFetchOptions = {\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n};\n\n// Only allowed for navigations\ntype BaseNavigateOptions = BaseNavigateOrFetchOptions & {\n replace?: boolean;\n state?: any;\n fromRouteId?: string;\n};\n\n// Only allowed for submission navigations\ntype BaseSubmissionOptions = {\n formMethod?: HTMLFormMethod;\n formEncType?: FormEncType;\n} & (\n | { formData: FormData; body?: undefined }\n | { formData?: undefined; body: any }\n);\n\n/**\n * Options for a navigate() call for a normal (non-submission) navigation\n */\ntype LinkNavigateOptions = BaseNavigateOptions;\n\n/**\n * Options for a navigate() call for a submission navigation\n */\ntype SubmissionNavigateOptions = BaseNavigateOptions & BaseSubmissionOptions;\n\n/**\n * Options to pass to navigate() for a navigation\n */\nexport type RouterNavigateOptions =\n | LinkNavigateOptions\n | SubmissionNavigateOptions;\n\n/**\n * Options for a fetch() load\n */\ntype LoadFetchOptions = BaseNavigateOrFetchOptions;\n\n/**\n * Options for a fetch() submission\n */\ntype SubmitFetchOptions = BaseNavigateOrFetchOptions & BaseSubmissionOptions;\n\n/**\n * Options to pass to fetch()\n */\nexport type RouterFetchOptions = LoadFetchOptions | SubmitFetchOptions;\n\n/**\n * Potential states for state.navigation\n */\nexport type NavigationStates = {\n Idle: {\n state: \"idle\";\n location: undefined;\n formMethod: undefined;\n formAction: undefined;\n formEncType: undefined;\n formData: undefined;\n json: undefined;\n text: undefined;\n };\n Loading: {\n state: \"loading\";\n location: Location;\n formMethod: Submission[\"formMethod\"] | undefined;\n formAction: Submission[\"formAction\"] | undefined;\n formEncType: Submission[\"formEncType\"] | undefined;\n formData: Submission[\"formData\"] | undefined;\n json: Submission[\"json\"] | undefined;\n text: Submission[\"text\"] | undefined;\n };\n Submitting: {\n state: \"submitting\";\n location: Location;\n formMethod: Submission[\"formMethod\"];\n formAction: Submission[\"formAction\"];\n formEncType: Submission[\"formEncType\"];\n formData: Submission[\"formData\"];\n json: Submission[\"json\"];\n text: Submission[\"text\"];\n };\n};\n\nexport type Navigation = NavigationStates[keyof NavigationStates];\n\nexport type RevalidationState = \"idle\" | \"loading\";\n\n/**\n * Potential states for fetchers\n */\ntype FetcherStates = {\n Idle: {\n state: \"idle\";\n formMethod: undefined;\n formAction: undefined;\n formEncType: undefined;\n text: undefined;\n formData: undefined;\n json: undefined;\n data: TData | undefined;\n \" _hasFetcherDoneAnything \"?: boolean;\n };\n Loading: {\n state: \"loading\";\n formMethod: Submission[\"formMethod\"] | undefined;\n formAction: Submission[\"formAction\"] | undefined;\n formEncType: Submission[\"formEncType\"] | undefined;\n text: Submission[\"text\"] | undefined;\n formData: Submission[\"formData\"] | undefined;\n json: Submission[\"json\"] | undefined;\n data: TData | undefined;\n \" _hasFetcherDoneAnything \"?: boolean;\n };\n Submitting: {\n state: \"submitting\";\n formMethod: Submission[\"formMethod\"];\n formAction: Submission[\"formAction\"];\n formEncType: Submission[\"formEncType\"];\n text: Submission[\"text\"];\n formData: Submission[\"formData\"];\n json: Submission[\"json\"];\n data: TData | undefined;\n \" _hasFetcherDoneAnything \"?: boolean;\n };\n};\n\nexport type Fetcher =\n FetcherStates[keyof FetcherStates];\n\ninterface BlockerBlocked {\n state: \"blocked\";\n reset(): void;\n proceed(): void;\n location: Location;\n}\n\ninterface BlockerUnblocked {\n state: \"unblocked\";\n reset: undefined;\n proceed: undefined;\n location: undefined;\n}\n\ninterface BlockerProceeding {\n state: \"proceeding\";\n reset: undefined;\n proceed: undefined;\n location: Location;\n}\n\nexport type Blocker = BlockerUnblocked | BlockerBlocked | BlockerProceeding;\n\nexport type BlockerFunction = (args: {\n currentLocation: Location;\n nextLocation: Location;\n historyAction: HistoryAction;\n}) => boolean;\n\ninterface ShortCircuitable {\n /**\n * startNavigation does not need to complete the navigation because we\n * redirected or got interrupted\n */\n shortCircuited?: boolean;\n}\n\ninterface HandleActionResult extends ShortCircuitable {\n /**\n * Error thrown from the current action, keyed by the route containing the\n * error boundary to render the error. To be committed to the state after\n * loaders have completed\n */\n pendingActionError?: RouteData;\n /**\n * Data returned from the current action, keyed by the route owning the action.\n * To be committed to the state after loaders have completed\n */\n pendingActionData?: RouteData;\n}\n\ninterface HandleLoadersResult extends ShortCircuitable {\n /**\n * loaderData returned from the current set of loaders\n */\n loaderData?: RouterState[\"loaderData\"];\n /**\n * errors thrown from the current set of loaders\n */\n errors?: RouterState[\"errors\"];\n}\n\n/**\n * Cached info for active fetcher.load() instances so they can participate\n * in revalidation\n */\ninterface FetchLoadMatch {\n routeId: string;\n path: string;\n}\n\n/**\n * Identified fetcher.load() calls that need to be revalidated\n */\ninterface RevalidatingFetcher extends FetchLoadMatch {\n key: string;\n match: AgnosticDataRouteMatch | null;\n matches: AgnosticDataRouteMatch[] | null;\n controller: AbortController | null;\n}\n\n/**\n * Wrapper object to allow us to throw any response out from callLoaderOrAction\n * for queryRouter while preserving whether or not it was thrown or returned\n * from the loader/action\n */\ninterface QueryRouteResponse {\n type: ResultType.data | ResultType.error;\n response: Response;\n}\n\nconst validMutationMethodsArr: MutationFormMethod[] = [\n \"post\",\n \"put\",\n \"patch\",\n \"delete\",\n];\nconst validMutationMethods = new Set(\n validMutationMethodsArr\n);\n\nconst validRequestMethodsArr: FormMethod[] = [\n \"get\",\n ...validMutationMethodsArr,\n];\nconst validRequestMethods = new Set(validRequestMethodsArr);\n\nconst redirectStatusCodes = new Set([301, 302, 303, 307, 308]);\nconst redirectPreserveMethodStatusCodes = new Set([307, 308]);\n\nexport const IDLE_NAVIGATION: NavigationStates[\"Idle\"] = {\n state: \"idle\",\n location: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n};\n\nexport const IDLE_FETCHER: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n};\n\nexport const IDLE_BLOCKER: BlockerUnblocked = {\n state: \"unblocked\",\n proceed: undefined,\n reset: undefined,\n location: undefined,\n};\n\nconst ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\n\nconst defaultMapRouteProperties: MapRoutePropertiesFunction = (route) => ({\n hasErrorBoundary: Boolean(route.hasErrorBoundary),\n});\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region createRouter\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Create a router and listen to history POP navigations\n */\nexport function createRouter(init: RouterInit): Router {\n const routerWindow = init.window\n ? init.window\n : typeof window !== \"undefined\"\n ? window\n : undefined;\n const isBrowser =\n typeof routerWindow !== \"undefined\" &&\n typeof routerWindow.document !== \"undefined\" &&\n typeof routerWindow.document.createElement !== \"undefined\";\n const isServer = !isBrowser;\n\n invariant(\n init.routes.length > 0,\n \"You must provide a non-empty routes array to createRouter\"\n );\n\n let mapRouteProperties: MapRoutePropertiesFunction;\n if (init.mapRouteProperties) {\n mapRouteProperties = init.mapRouteProperties;\n } else if (init.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = init.detectErrorBoundary;\n mapRouteProperties = (route) => ({\n hasErrorBoundary: detectErrorBoundary(route),\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n\n // Routes keyed by ID\n let manifest: RouteManifest = {};\n // Routes in tree format for matching\n let dataRoutes = convertRoutesToDataRoutes(\n init.routes,\n mapRouteProperties,\n undefined,\n manifest\n );\n let inFlightDataRoutes: AgnosticDataRouteObject[] | undefined;\n let basename = init.basename || \"/\";\n // Config driven behavior flags\n let future: FutureConfig = {\n v7_normalizeFormMethod: false,\n v7_prependBasename: false,\n ...init.future,\n };\n // Cleanup function for history\n let unlistenHistory: (() => void) | null = null;\n // Externally-provided functions to call on all state changes\n let subscribers = new Set();\n // Externally-provided object to hold scroll restoration locations during routing\n let savedScrollPositions: Record | null = null;\n // Externally-provided function to get scroll restoration keys\n let getScrollRestorationKey: GetScrollRestorationKeyFunction | null = null;\n // Externally-provided function to get current scroll position\n let getScrollPosition: GetScrollPositionFunction | null = null;\n // One-time flag to control the initial hydration scroll restoration. Because\n // we don't get the saved positions from until _after_\n // the initial render, we need to manually trigger a separate updateState to\n // send along the restoreScrollPosition\n // Set to true if we have `hydrationData` since we assume we were SSR'd and that\n // SSR did the initial scroll restoration.\n let initialScrollRestored = init.hydrationData != null;\n\n let initialMatches = matchRoutes(dataRoutes, init.history.location, basename);\n let initialErrors: RouteData | null = null;\n\n if (initialMatches == null) {\n // If we do not match a user-provided-route, fall back to the root\n // to allow the error boundary to take over\n let error = getInternalRouterError(404, {\n pathname: init.history.location.pathname,\n });\n let { matches, route } = getShortCircuitMatches(dataRoutes);\n initialMatches = matches;\n initialErrors = { [route.id]: error };\n }\n\n let initialized =\n // All initialMatches need to be loaded before we're ready. If we have lazy\n // functions around still then we'll need to run them in initialize()\n !initialMatches.some((m) => m.route.lazy) &&\n // And we have to either have no loaders or have been provided hydrationData\n (!initialMatches.some((m) => m.route.loader) || init.hydrationData != null);\n\n let router: Router;\n let state: RouterState = {\n historyAction: init.history.action,\n location: init.history.location,\n matches: initialMatches,\n initialized,\n navigation: IDLE_NAVIGATION,\n // Don't restore on initial updateState() if we were SSR'd\n restoreScrollPosition: init.hydrationData != null ? false : null,\n preventScrollReset: false,\n revalidation: \"idle\",\n loaderData: (init.hydrationData && init.hydrationData.loaderData) || {},\n actionData: (init.hydrationData && init.hydrationData.actionData) || null,\n errors: (init.hydrationData && init.hydrationData.errors) || initialErrors,\n fetchers: new Map(),\n blockers: new Map(),\n };\n\n // -- Stateful internal variables to manage navigations --\n // Current navigation in progress (to be committed in completeNavigation)\n let pendingAction: HistoryAction = HistoryAction.Pop;\n\n // Should the current navigation prevent the scroll reset if scroll cannot\n // be restored?\n let pendingPreventScrollReset = false;\n\n // AbortController for the active navigation\n let pendingNavigationController: AbortController | null;\n\n // We use this to avoid touching history in completeNavigation if a\n // revalidation is entirely uninterrupted\n let isUninterruptedRevalidation = false;\n\n // Use this internal flag to force revalidation of all loaders:\n // - submissions (completed or interrupted)\n // - useRevalidator()\n // - X-Remix-Revalidate (from redirect)\n let isRevalidationRequired = false;\n\n // Use this internal array to capture routes that require revalidation due\n // to a cancelled deferred on action submission\n let cancelledDeferredRoutes: string[] = [];\n\n // Use this internal array to capture fetcher loads that were cancelled by an\n // action navigation and require revalidation\n let cancelledFetcherLoads: string[] = [];\n\n // AbortControllers for any in-flight fetchers\n let fetchControllers = new Map();\n\n // Track loads based on the order in which they started\n let incrementingLoadId = 0;\n\n // Track the outstanding pending navigation data load to be compared against\n // the globally incrementing load when a fetcher load lands after a completed\n // navigation\n let pendingNavigationLoadId = -1;\n\n // Fetchers that triggered data reloads as a result of their actions\n let fetchReloadIds = new Map();\n\n // Fetchers that triggered redirect navigations\n let fetchRedirectIds = new Set();\n\n // Most recent href/match for fetcher.load calls for fetchers\n let fetchLoadMatches = new Map();\n\n // Store DeferredData instances for active route matches. When a\n // route loader returns defer() we stick one in here. Then, when a nested\n // promise resolves we update loaderData. If a new navigation starts we\n // cancel active deferreds for eliminated routes.\n let activeDeferreds = new Map();\n\n // Store blocker functions in a separate Map outside of router state since\n // we don't need to update UI state if they change\n let blockerFunctions = new Map();\n\n // Flag to ignore the next history update, so we can revert the URL change on\n // a POP navigation that was blocked by the user without touching router state\n let ignoreNextHistoryUpdate = false;\n\n // Initialize the router, all side effects should be kicked off from here.\n // Implemented as a Fluent API for ease of:\n // let router = createRouter(init).initialize();\n function initialize() {\n // If history informs us of a POP navigation, start the navigation but do not update\n // state. We'll update our own state once the navigation completes\n unlistenHistory = init.history.listen(\n ({ action: historyAction, location, delta }) => {\n // Ignore this event if it was just us resetting the URL from a\n // blocked POP navigation\n if (ignoreNextHistoryUpdate) {\n ignoreNextHistoryUpdate = false;\n return;\n }\n\n warning(\n blockerFunctions.size === 0 || delta != null,\n \"You are trying to use a blocker on a POP navigation to a location \" +\n \"that was not created by @remix-run/router. This will fail silently in \" +\n \"production. This can happen if you are navigating outside the router \" +\n \"via `window.history.pushState`/`window.location.hash` instead of using \" +\n \"router navigation APIs. This can also happen if you are using \" +\n \"createHashRouter and the user manually changes the URL.\"\n );\n\n let blockerKey = shouldBlockNavigation({\n currentLocation: state.location,\n nextLocation: location,\n historyAction,\n });\n\n if (blockerKey && delta != null) {\n // Restore the URL to match the current UI, but don't update router state\n ignoreNextHistoryUpdate = true;\n init.history.go(delta * -1);\n\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location,\n proceed() {\n updateBlocker(blockerKey!, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location,\n });\n // Re-do the same POP navigation we just blocked\n init.history.go(delta);\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey!, IDLE_BLOCKER);\n updateState({ blockers });\n },\n });\n return;\n }\n\n return startNavigation(historyAction, location);\n }\n );\n\n // Kick off initial data load if needed. Use Pop to avoid modifying history\n // Note we don't do any handling of lazy here. For SPA's it'll get handled\n // in the normal navigation flow. For SSR it's expected that lazy modules are\n // resolved prior to router creation since we can't go into a fallbackElement\n // UI for SSR'd apps\n if (!state.initialized) {\n startNavigation(HistoryAction.Pop, state.location);\n }\n\n return router;\n }\n\n // Clean up a router and it's side effects\n function dispose() {\n if (unlistenHistory) {\n unlistenHistory();\n }\n subscribers.clear();\n pendingNavigationController && pendingNavigationController.abort();\n state.fetchers.forEach((_, key) => deleteFetcher(key));\n state.blockers.forEach((_, key) => deleteBlocker(key));\n }\n\n // Subscribe to state updates for the router\n function subscribe(fn: RouterSubscriber) {\n subscribers.add(fn);\n return () => subscribers.delete(fn);\n }\n\n // Update our state and notify the calling context of the change\n function updateState(newState: Partial): void {\n state = {\n ...state,\n ...newState,\n };\n subscribers.forEach((subscriber) => subscriber(state));\n }\n\n // Complete a navigation returning the state.navigation back to the IDLE_NAVIGATION\n // and setting state.[historyAction/location/matches] to the new route.\n // - Location is a required param\n // - Navigation will always be set to IDLE_NAVIGATION\n // - Can pass any other state in newState\n function completeNavigation(\n location: Location,\n newState: Partial>\n ): void {\n // Deduce if we're in a loading/actionReload state:\n // - We have committed actionData in the store\n // - The current navigation was a mutation submission\n // - We're past the submitting state and into the loading state\n // - The location being loaded is not the result of a redirect\n let isActionReload =\n state.actionData != null &&\n state.navigation.formMethod != null &&\n isMutationMethod(state.navigation.formMethod) &&\n state.navigation.state === \"loading\" &&\n location.state?._isRedirect !== true;\n\n let actionData: RouteData | null;\n if (newState.actionData) {\n if (Object.keys(newState.actionData).length > 0) {\n actionData = newState.actionData;\n } else {\n // Empty actionData -> clear prior actionData due to an action error\n actionData = null;\n }\n } else if (isActionReload) {\n // Keep the current data if we're wrapping up the action reload\n actionData = state.actionData;\n } else {\n // Clear actionData on any other completed navigations\n actionData = null;\n }\n\n // Always preserve any existing loaderData from re-used routes\n let loaderData = newState.loaderData\n ? mergeLoaderData(\n state.loaderData,\n newState.loaderData,\n newState.matches || [],\n newState.errors\n )\n : state.loaderData;\n\n // On a successful navigation we can assume we got through all blockers\n // so we can start fresh\n let blockers = state.blockers;\n if (blockers.size > 0) {\n blockers = new Map(blockers);\n blockers.forEach((_, k) => blockers.set(k, IDLE_BLOCKER));\n }\n\n // Always respect the user flag. Otherwise don't reset on mutation\n // submission navigations unless they redirect\n let preventScrollReset =\n pendingPreventScrollReset === true ||\n (state.navigation.formMethod != null &&\n isMutationMethod(state.navigation.formMethod) &&\n location.state?._isRedirect !== true);\n\n if (inFlightDataRoutes) {\n dataRoutes = inFlightDataRoutes;\n inFlightDataRoutes = undefined;\n }\n\n if (isUninterruptedRevalidation) {\n // If this was an uninterrupted revalidation then do not touch history\n } else if (pendingAction === HistoryAction.Pop) {\n // Do nothing for POP - URL has already been updated\n } else if (pendingAction === HistoryAction.Push) {\n init.history.push(location, location.state);\n } else if (pendingAction === HistoryAction.Replace) {\n init.history.replace(location, location.state);\n }\n\n updateState({\n ...newState, // matches, errors, fetchers go through as-is\n actionData,\n loaderData,\n historyAction: pendingAction,\n location,\n initialized: true,\n navigation: IDLE_NAVIGATION,\n revalidation: \"idle\",\n restoreScrollPosition: getSavedScrollPosition(\n location,\n newState.matches || state.matches\n ),\n preventScrollReset,\n blockers,\n });\n\n // Reset stateful navigation vars\n pendingAction = HistoryAction.Pop;\n pendingPreventScrollReset = false;\n isUninterruptedRevalidation = false;\n isRevalidationRequired = false;\n cancelledDeferredRoutes = [];\n cancelledFetcherLoads = [];\n }\n\n // Trigger a navigation event, which can either be a numerical POP or a PUSH\n // replace with an optional submission\n async function navigate(\n to: number | To | null,\n opts?: RouterNavigateOptions\n ): Promise {\n if (typeof to === \"number\") {\n init.history.go(to);\n return;\n }\n\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n future.v7_prependBasename,\n to,\n opts?.fromRouteId,\n opts?.relative\n );\n let { path, submission, error } = normalizeNavigateOptions(\n future.v7_normalizeFormMethod,\n false,\n normalizedPath,\n opts\n );\n\n let currentLocation = state.location;\n let nextLocation = createLocation(state.location, path, opts && opts.state);\n\n // When using navigate as a PUSH/REPLACE we aren't reading an already-encoded\n // URL from window.location, so we need to encode it here so the behavior\n // remains the same as POP and non-data-router usages. new URL() does all\n // the same encoding we'd get from a history.pushState/window.location read\n // without having to touch history\n nextLocation = {\n ...nextLocation,\n ...init.history.encodeLocation(nextLocation),\n };\n\n let userReplace = opts && opts.replace != null ? opts.replace : undefined;\n\n let historyAction = HistoryAction.Push;\n\n if (userReplace === true) {\n historyAction = HistoryAction.Replace;\n } else if (userReplace === false) {\n // no-op\n } else if (\n submission != null &&\n isMutationMethod(submission.formMethod) &&\n submission.formAction === state.location.pathname + state.location.search\n ) {\n // By default on submissions to the current location we REPLACE so that\n // users don't have to double-click the back button to get to the prior\n // location. If the user redirects to a different location from the\n // action/loader this will be ignored and the redirect will be a PUSH\n historyAction = HistoryAction.Replace;\n }\n\n let preventScrollReset =\n opts && \"preventScrollReset\" in opts\n ? opts.preventScrollReset === true\n : undefined;\n\n let blockerKey = shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction,\n });\n\n if (blockerKey) {\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location: nextLocation,\n proceed() {\n updateBlocker(blockerKey!, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location: nextLocation,\n });\n // Send the same navigation through\n navigate(to, opts);\n },\n reset() {\n let blockers = new Map(state.blockers);\n blockers.set(blockerKey!, IDLE_BLOCKER);\n updateState({ blockers });\n },\n });\n return;\n }\n\n return await startNavigation(historyAction, nextLocation, {\n submission,\n // Send through the formData serialization error if we have one so we can\n // render at the right error boundary after we match routes\n pendingError: error,\n preventScrollReset,\n replace: opts && opts.replace,\n });\n }\n\n // Revalidate all current loaders. If a navigation is in progress or if this\n // is interrupted by a navigation, allow this to \"succeed\" by calling all\n // loaders during the next loader round\n function revalidate() {\n interruptActiveLoads();\n updateState({ revalidation: \"loading\" });\n\n // If we're currently submitting an action, we don't need to start a new\n // navigation, we'll just let the follow up loader execution call all loaders\n if (state.navigation.state === \"submitting\") {\n return;\n }\n\n // If we're currently in an idle state, start a new navigation for the current\n // action/location and mark it as uninterrupted, which will skip the history\n // update in completeNavigation\n if (state.navigation.state === \"idle\") {\n startNavigation(state.historyAction, state.location, {\n startUninterruptedRevalidation: true,\n });\n return;\n }\n\n // Otherwise, if we're currently in a loading state, just start a new\n // navigation to the navigation.location but do not trigger an uninterrupted\n // revalidation so that history correctly updates once the navigation completes\n startNavigation(\n pendingAction || state.historyAction,\n state.navigation.location,\n { overrideNavigation: state.navigation }\n );\n }\n\n // Start a navigation to the given action/location. Can optionally provide a\n // overrideNavigation which will override the normalLoad in the case of a redirect\n // navigation\n async function startNavigation(\n historyAction: HistoryAction,\n location: Location,\n opts?: {\n submission?: Submission;\n fetcherSubmission?: Submission;\n overrideNavigation?: Navigation;\n pendingError?: ErrorResponse;\n startUninterruptedRevalidation?: boolean;\n preventScrollReset?: boolean;\n replace?: boolean;\n }\n ): Promise {\n // Abort any in-progress navigations and start a new one. Unset any ongoing\n // uninterrupted revalidations unless told otherwise, since we want this\n // new navigation to update history normally\n pendingNavigationController && pendingNavigationController.abort();\n pendingNavigationController = null;\n pendingAction = historyAction;\n isUninterruptedRevalidation =\n (opts && opts.startUninterruptedRevalidation) === true;\n\n // Save the current scroll position every time we start a new navigation,\n // and track whether we should reset scroll on completion\n saveScrollPosition(state.location, state.matches);\n pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let loadingNavigation = opts && opts.overrideNavigation;\n let matches = matchRoutes(routesToUse, location, basename);\n\n // Short circuit with a 404 on the root error boundary if we match nothing\n if (!matches) {\n let error = getInternalRouterError(404, { pathname: location.pathname });\n let { matches: notFoundMatches, route } =\n getShortCircuitMatches(routesToUse);\n // Cancel all pending deferred on 404s since we don't keep any routes\n cancelActiveDeferreds();\n completeNavigation(location, {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error,\n },\n });\n return;\n }\n\n // Short circuit if it's only a hash change and not a revalidation or\n // mutation submission.\n //\n // Ignore on initial page loads because since the initial load will always\n // be \"same hash\". For example, on /page#hash and submit a \n // which will default to a navigation to /page\n if (\n state.initialized &&\n !isRevalidationRequired &&\n isHashChangeOnly(state.location, location) &&\n !(opts && opts.submission && isMutationMethod(opts.submission.formMethod))\n ) {\n completeNavigation(location, { matches });\n return;\n }\n\n // Create a controller/Request for this navigation\n pendingNavigationController = new AbortController();\n let request = createClientSideRequest(\n init.history,\n location,\n pendingNavigationController.signal,\n opts && opts.submission\n );\n let pendingActionData: RouteData | undefined;\n let pendingError: RouteData | undefined;\n\n if (opts && opts.pendingError) {\n // If we have a pendingError, it means the user attempted a GET submission\n // with binary FormData so assign here and skip to handleLoaders. That\n // way we handle calling loaders above the boundary etc. It's not really\n // different from an actionError in that sense.\n pendingError = {\n [findNearestBoundary(matches).route.id]: opts.pendingError,\n };\n } else if (\n opts &&\n opts.submission &&\n isMutationMethod(opts.submission.formMethod)\n ) {\n // Call action if we received an action submission\n let actionOutput = await handleAction(\n request,\n location,\n opts.submission,\n matches,\n { replace: opts.replace }\n );\n\n if (actionOutput.shortCircuited) {\n return;\n }\n\n pendingActionData = actionOutput.pendingActionData;\n pendingError = actionOutput.pendingActionError;\n loadingNavigation = getLoadingNavigation(location, opts.submission);\n\n // Create a GET request for the loaders\n request = new Request(request.url, { signal: request.signal });\n }\n\n // Call loaders\n let { shortCircuited, loaderData, errors } = await handleLoaders(\n request,\n location,\n matches,\n loadingNavigation,\n opts && opts.submission,\n opts && opts.fetcherSubmission,\n opts && opts.replace,\n pendingActionData,\n pendingError\n );\n\n if (shortCircuited) {\n return;\n }\n\n // Clean up now that the action/loaders have completed. Don't clean up if\n // we short circuited because pendingNavigationController will have already\n // been assigned to a new controller for the next navigation\n pendingNavigationController = null;\n\n completeNavigation(location, {\n matches,\n ...(pendingActionData ? { actionData: pendingActionData } : {}),\n loaderData,\n errors,\n });\n }\n\n // Call the action matched by the leaf route for this navigation and handle\n // redirects/errors\n async function handleAction(\n request: Request,\n location: Location,\n submission: Submission,\n matches: AgnosticDataRouteMatch[],\n opts: { replace?: boolean } = {}\n ): Promise {\n interruptActiveLoads();\n\n // Put us in a submitting state\n let navigation = getSubmittingNavigation(location, submission);\n updateState({ navigation });\n\n // Call our action and get the result\n let result: DataResult;\n let actionMatch = getTargetMatch(matches, location);\n\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n result = {\n type: ResultType.error,\n error: getInternalRouterError(405, {\n method: request.method,\n pathname: location.pathname,\n routeId: actionMatch.route.id,\n }),\n };\n } else {\n result = await callLoaderOrAction(\n \"action\",\n request,\n actionMatch,\n matches,\n manifest,\n mapRouteProperties,\n basename\n );\n\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n }\n\n if (isRedirectResult(result)) {\n let replace: boolean;\n if (opts && opts.replace != null) {\n replace = opts.replace;\n } else {\n // If the user didn't explicity indicate replace behavior, replace if\n // we redirected to the exact same location we're currently at to avoid\n // double back-buttons\n replace =\n result.location === state.location.pathname + state.location.search;\n }\n await startRedirectNavigation(state, result, { submission, replace });\n return { shortCircuited: true };\n }\n\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n\n // By default, all submissions are REPLACE navigations, but if the\n // action threw an error that'll be rendered in an errorElement, we fall\n // back to PUSH so that the user can use the back button to get back to\n // the pre-submission form location to try again\n if ((opts && opts.replace) !== true) {\n pendingAction = HistoryAction.Push;\n }\n\n return {\n // Send back an empty object we can use to clear out any prior actionData\n pendingActionData: {},\n pendingActionError: { [boundaryMatch.route.id]: result.error },\n };\n }\n\n if (isDeferredResult(result)) {\n throw getInternalRouterError(400, { type: \"defer-action\" });\n }\n\n return {\n pendingActionData: { [actionMatch.route.id]: result.data },\n };\n }\n\n // Call all applicable loaders for the given matches, handling redirects,\n // errors, etc.\n async function handleLoaders(\n request: Request,\n location: Location,\n matches: AgnosticDataRouteMatch[],\n overrideNavigation?: Navigation,\n submission?: Submission,\n fetcherSubmission?: Submission,\n replace?: boolean,\n pendingActionData?: RouteData,\n pendingError?: RouteData\n ): Promise {\n // Figure out the right navigation we want to use for data loading\n let loadingNavigation =\n overrideNavigation || getLoadingNavigation(location, submission);\n\n // If this was a redirect from an action we don't have a \"submission\" but\n // we have it on the loading navigation so use that if available\n let activeSubmission =\n submission ||\n fetcherSubmission ||\n getSubmissionFromNavigation(loadingNavigation);\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n init.history,\n state,\n matches,\n activeSubmission,\n location,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n fetchLoadMatches,\n fetchRedirectIds,\n routesToUse,\n basename,\n pendingActionData,\n pendingError\n );\n\n // Cancel pending deferreds for no-longer-matched routes or routes we're\n // about to reload. Note that if this is an action reload we would have\n // already cancelled all pending deferreds so this would be a no-op\n cancelActiveDeferreds(\n (routeId) =>\n !(matches && matches.some((m) => m.route.id === routeId)) ||\n (matchesToLoad && matchesToLoad.some((m) => m.route.id === routeId))\n );\n\n pendingNavigationLoadId = ++incrementingLoadId;\n\n // Short circuit if we have no loaders to run\n if (matchesToLoad.length === 0 && revalidatingFetchers.length === 0) {\n let updatedFetchers = markFetchRedirectsDone();\n completeNavigation(location, {\n matches,\n loaderData: {},\n // Commit pending error if we're short circuiting\n errors: pendingError || null,\n ...(pendingActionData ? { actionData: pendingActionData } : {}),\n ...(updatedFetchers ? { fetchers: new Map(state.fetchers) } : {}),\n });\n return { shortCircuited: true };\n }\n\n // If this is an uninterrupted revalidation, we remain in our current idle\n // state. If not, we need to switch to our loading state and load data,\n // preserving any new action data or existing action data (in the case of\n // a revalidation interrupting an actionReload)\n if (!isUninterruptedRevalidation) {\n revalidatingFetchers.forEach((rf) => {\n let fetcher = state.fetchers.get(rf.key);\n let revalidatingFetcher = getLoadingFetcher(\n undefined,\n fetcher ? fetcher.data : undefined\n );\n state.fetchers.set(rf.key, revalidatingFetcher);\n });\n let actionData = pendingActionData || state.actionData;\n updateState({\n navigation: loadingNavigation,\n ...(actionData\n ? Object.keys(actionData).length === 0\n ? { actionData: null }\n : { actionData }\n : {}),\n ...(revalidatingFetchers.length > 0\n ? { fetchers: new Map(state.fetchers) }\n : {}),\n });\n }\n\n revalidatingFetchers.forEach((rf) => {\n if (fetchControllers.has(rf.key)) {\n abortFetcher(rf.key);\n }\n if (rf.controller) {\n // Fetchers use an independent AbortController so that aborting a fetcher\n // (via deleteFetcher) does not abort the triggering navigation that\n // triggered the revalidation\n fetchControllers.set(rf.key, rf.controller);\n }\n });\n\n // Proxy navigation abort through to revalidation fetchers\n let abortPendingFetchRevalidations = () =>\n revalidatingFetchers.forEach((f) => abortFetcher(f.key));\n if (pendingNavigationController) {\n pendingNavigationController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n\n let { results, loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state.matches,\n matches,\n matchesToLoad,\n revalidatingFetchers,\n request\n );\n\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n\n // Clean up _after_ loaders have completed. Don't clean up if we short\n // circuited because fetchControllers would have been aborted and\n // reassigned to new controllers for the next navigation\n if (pendingNavigationController) {\n pendingNavigationController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n revalidatingFetchers.forEach((rf) => fetchControllers.delete(rf.key));\n\n // If any loaders returned a redirect Response, start a new REPLACE navigation\n let redirect = findRedirect(results);\n if (redirect) {\n if (redirect.idx >= matchesToLoad.length) {\n // If this redirect came from a fetcher make sure we mark it in\n // fetchRedirectIds so it doesn't get revalidated on the next set of\n // loader executions\n let fetcherKey =\n revalidatingFetchers[redirect.idx - matchesToLoad.length].key;\n fetchRedirectIds.add(fetcherKey);\n }\n await startRedirectNavigation(state, redirect.result, { replace });\n return { shortCircuited: true };\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n matches,\n matchesToLoad,\n loaderResults,\n pendingError,\n revalidatingFetchers,\n fetcherResults,\n activeDeferreds\n );\n\n // Wire up subscribers to update loaderData as promises settle\n activeDeferreds.forEach((deferredData, routeId) => {\n deferredData.subscribe((aborted) => {\n // Note: No need to updateState here since the TrackedPromise on\n // loaderData is stable across resolve/reject\n // Remove this instance if we were aborted or if promises have settled\n if (aborted || deferredData.done) {\n activeDeferreds.delete(routeId);\n }\n });\n });\n\n let updatedFetchers = markFetchRedirectsDone();\n let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);\n let shouldUpdateFetchers =\n updatedFetchers || didAbortFetchLoads || revalidatingFetchers.length > 0;\n\n return {\n loaderData,\n errors,\n ...(shouldUpdateFetchers ? { fetchers: new Map(state.fetchers) } : {}),\n };\n }\n\n function getFetcher(key: string): Fetcher {\n return state.fetchers.get(key) || IDLE_FETCHER;\n }\n\n // Trigger a fetcher load/submit for the given fetcher key\n function fetch(\n key: string,\n routeId: string,\n href: string | null,\n opts?: RouterFetchOptions\n ) {\n if (isServer) {\n throw new Error(\n \"router.fetch() was called during the server render, but it shouldn't be. \" +\n \"You are likely calling a useFetcher() method in the body of your component. \" +\n \"Try moving it to a useEffect or a callback.\"\n );\n }\n\n if (fetchControllers.has(key)) abortFetcher(key);\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n future.v7_prependBasename,\n href,\n routeId,\n opts?.relative\n );\n let matches = matchRoutes(routesToUse, normalizedPath, basename);\n\n if (!matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: normalizedPath })\n );\n return;\n }\n\n let { path, submission, error } = normalizeNavigateOptions(\n future.v7_normalizeFormMethod,\n true,\n normalizedPath,\n opts\n );\n\n if (error) {\n setFetcherError(key, routeId, error);\n return;\n }\n\n let match = getTargetMatch(matches, path);\n\n pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n\n if (submission && isMutationMethod(submission.formMethod)) {\n handleFetcherAction(key, routeId, path, match, matches, submission);\n return;\n }\n\n // Store off the match so we can call it's shouldRevalidate on subsequent\n // revalidations\n fetchLoadMatches.set(key, { routeId, path });\n handleFetcherLoader(key, routeId, path, match, matches, submission);\n }\n\n // Call the action for the matched fetcher.submit(), and then handle redirects,\n // errors, and revalidation\n async function handleFetcherAction(\n key: string,\n routeId: string,\n path: string,\n match: AgnosticDataRouteMatch,\n requestMatches: AgnosticDataRouteMatch[],\n submission: Submission\n ) {\n interruptActiveLoads();\n fetchLoadMatches.delete(key);\n\n if (!match.route.action && !match.route.lazy) {\n let error = getInternalRouterError(405, {\n method: submission.formMethod,\n pathname: path,\n routeId: routeId,\n });\n setFetcherError(key, routeId, error);\n return;\n }\n\n // Put this fetcher into it's submitting state\n let existingFetcher = state.fetchers.get(key);\n let fetcher = getSubmittingFetcher(submission, existingFetcher);\n state.fetchers.set(key, fetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n // Call the action for the fetcher\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal,\n submission\n );\n fetchControllers.set(key, abortController);\n\n let originatingLoadId = incrementingLoadId;\n let actionResult = await callLoaderOrAction(\n \"action\",\n fetchRequest,\n match,\n requestMatches,\n manifest,\n mapRouteProperties,\n basename\n );\n\n if (fetchRequest.signal.aborted) {\n // We can delete this so long as we weren't aborted by ou our own fetcher\n // re-submit which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n return;\n }\n\n if (isRedirectResult(actionResult)) {\n fetchControllers.delete(key);\n if (pendingNavigationLoadId > originatingLoadId) {\n // A new navigation was kicked off after our action started, so that\n // should take precedence over this redirect navigation. We already\n // set isRevalidationRequired so all loaders for the new route should\n // fire unless opted out via shouldRevalidate\n let doneFetcher = getDoneFetcher(undefined);\n state.fetchers.set(key, doneFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n return;\n } else {\n fetchRedirectIds.add(key);\n let loadingFetcher = getLoadingFetcher(submission);\n state.fetchers.set(key, loadingFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n return startRedirectNavigation(state, actionResult, {\n submission,\n isFetchActionRedirect: true,\n });\n }\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(actionResult)) {\n setFetcherError(key, routeId, actionResult.error);\n return;\n }\n\n if (isDeferredResult(actionResult)) {\n throw getInternalRouterError(400, { type: \"defer-action\" });\n }\n\n // Start the data load for current matches, or the next location if we're\n // in the middle of a navigation\n let nextLocation = state.navigation.location || state.location;\n let revalidationRequest = createClientSideRequest(\n init.history,\n nextLocation,\n abortController.signal\n );\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let matches =\n state.navigation.state !== \"idle\"\n ? matchRoutes(routesToUse, state.navigation.location, basename)\n : state.matches;\n\n invariant(matches, \"Didn't find any matches after fetcher action\");\n\n let loadId = ++incrementingLoadId;\n fetchReloadIds.set(key, loadId);\n\n let loadFetcher = getLoadingFetcher(submission, actionResult.data);\n state.fetchers.set(key, loadFetcher);\n\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n init.history,\n state,\n matches,\n submission,\n nextLocation,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n fetchLoadMatches,\n fetchRedirectIds,\n routesToUse,\n basename,\n { [match.route.id]: actionResult.data },\n undefined // No need to send through errors since we short circuit above\n );\n\n // Put all revalidating fetchers into the loading state, except for the\n // current fetcher which we want to keep in it's current loading state which\n // contains it's action submission info + action data\n revalidatingFetchers\n .filter((rf) => rf.key !== key)\n .forEach((rf) => {\n let staleKey = rf.key;\n let existingFetcher = state.fetchers.get(staleKey);\n let revalidatingFetcher = getLoadingFetcher(\n undefined,\n existingFetcher ? existingFetcher.data : undefined\n );\n state.fetchers.set(staleKey, revalidatingFetcher);\n if (fetchControllers.has(staleKey)) {\n abortFetcher(staleKey);\n }\n if (rf.controller) {\n fetchControllers.set(staleKey, rf.controller);\n }\n });\n\n updateState({ fetchers: new Map(state.fetchers) });\n\n let abortPendingFetchRevalidations = () =>\n revalidatingFetchers.forEach((rf) => abortFetcher(rf.key));\n\n abortController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n\n let { results, loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state.matches,\n matches,\n matchesToLoad,\n revalidatingFetchers,\n revalidationRequest\n );\n\n if (abortController.signal.aborted) {\n return;\n }\n\n abortController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n\n fetchReloadIds.delete(key);\n fetchControllers.delete(key);\n revalidatingFetchers.forEach((r) => fetchControllers.delete(r.key));\n\n let redirect = findRedirect(results);\n if (redirect) {\n if (redirect.idx >= matchesToLoad.length) {\n // If this redirect came from a fetcher make sure we mark it in\n // fetchRedirectIds so it doesn't get revalidated on the next set of\n // loader executions\n let fetcherKey =\n revalidatingFetchers[redirect.idx - matchesToLoad.length].key;\n fetchRedirectIds.add(fetcherKey);\n }\n return startRedirectNavigation(state, redirect.result);\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n state.matches,\n matchesToLoad,\n loaderResults,\n undefined,\n revalidatingFetchers,\n fetcherResults,\n activeDeferreds\n );\n\n // Since we let revalidations complete even if the submitting fetcher was\n // deleted, only put it back to idle if it hasn't been deleted\n if (state.fetchers.has(key)) {\n let doneFetcher = getDoneFetcher(actionResult.data);\n state.fetchers.set(key, doneFetcher);\n }\n\n let didAbortFetchLoads = abortStaleFetchLoads(loadId);\n\n // If we are currently in a navigation loading state and this fetcher is\n // more recent than the navigation, we want the newer data so abort the\n // navigation and complete it with the fetcher data\n if (\n state.navigation.state === \"loading\" &&\n loadId > pendingNavigationLoadId\n ) {\n invariant(pendingAction, \"Expected pending action\");\n pendingNavigationController && pendingNavigationController.abort();\n\n completeNavigation(state.navigation.location, {\n matches,\n loaderData,\n errors,\n fetchers: new Map(state.fetchers),\n });\n } else {\n // otherwise just update with the fetcher data, preserving any existing\n // loaderData for loaders that did not need to reload. We have to\n // manually merge here since we aren't going through completeNavigation\n updateState({\n errors,\n loaderData: mergeLoaderData(\n state.loaderData,\n loaderData,\n matches,\n errors\n ),\n ...(didAbortFetchLoads || revalidatingFetchers.length > 0\n ? { fetchers: new Map(state.fetchers) }\n : {}),\n });\n isRevalidationRequired = false;\n }\n }\n\n // Call the matched loader for fetcher.load(), handling redirects, errors, etc.\n async function handleFetcherLoader(\n key: string,\n routeId: string,\n path: string,\n match: AgnosticDataRouteMatch,\n matches: AgnosticDataRouteMatch[],\n submission?: Submission\n ) {\n let existingFetcher = state.fetchers.get(key);\n // Put this fetcher into it's loading state\n let loadingFetcher = getLoadingFetcher(\n submission,\n existingFetcher ? existingFetcher.data : undefined\n );\n state.fetchers.set(key, loadingFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n // Call the loader for this fetcher route match\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal\n );\n fetchControllers.set(key, abortController);\n\n let originatingLoadId = incrementingLoadId;\n let result: DataResult = await callLoaderOrAction(\n \"loader\",\n fetchRequest,\n match,\n matches,\n manifest,\n mapRouteProperties,\n basename\n );\n\n // Deferred isn't supported for fetcher loads, await everything and treat it\n // as a normal load. resolveDeferredData will return undefined if this\n // fetcher gets aborted, so we just leave result untouched and short circuit\n // below if that happens\n if (isDeferredResult(result)) {\n result =\n (await resolveDeferredData(result, fetchRequest.signal, true)) ||\n result;\n }\n\n // We can delete this so long as we weren't aborted by our our own fetcher\n // re-load which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n\n if (fetchRequest.signal.aborted) {\n return;\n }\n\n // If the loader threw a redirect Response, start a new REPLACE navigation\n if (isRedirectResult(result)) {\n if (pendingNavigationLoadId > originatingLoadId) {\n // A new navigation was kicked off after our loader started, so that\n // should take precedence over this redirect navigation\n let doneFetcher = getDoneFetcher(undefined);\n state.fetchers.set(key, doneFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n return;\n } else {\n fetchRedirectIds.add(key);\n await startRedirectNavigation(state, result);\n return;\n }\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n state.fetchers.delete(key);\n // TODO: In remix, this would reset to IDLE_NAVIGATION if it was a catch -\n // do we need to behave any differently with our non-redirect errors?\n // What if it was a non-redirect Response?\n updateState({\n fetchers: new Map(state.fetchers),\n errors: {\n [boundaryMatch.route.id]: result.error,\n },\n });\n return;\n }\n\n invariant(!isDeferredResult(result), \"Unhandled fetcher deferred data\");\n\n // Put the fetcher back into an idle state\n let doneFetcher = getDoneFetcher(result.data);\n state.fetchers.set(key, doneFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n }\n\n /**\n * Utility function to handle redirects returned from an action or loader.\n * Normally, a redirect \"replaces\" the navigation that triggered it. So, for\n * example:\n *\n * - user is on /a\n * - user clicks a link to /b\n * - loader for /b redirects to /c\n *\n * In a non-JS app the browser would track the in-flight navigation to /b and\n * then replace it with /c when it encountered the redirect response. In\n * the end it would only ever update the URL bar with /c.\n *\n * In client-side routing using pushState/replaceState, we aim to emulate\n * this behavior and we also do not update history until the end of the\n * navigation (including processed redirects). This means that we never\n * actually touch history until we've processed redirects, so we just use\n * the history action from the original navigation (PUSH or REPLACE).\n */\n async function startRedirectNavigation(\n state: RouterState,\n redirect: RedirectResult,\n {\n submission,\n replace,\n isFetchActionRedirect,\n }: {\n submission?: Submission;\n replace?: boolean;\n isFetchActionRedirect?: boolean;\n } = {}\n ) {\n if (redirect.revalidate) {\n isRevalidationRequired = true;\n }\n\n let redirectLocation = createLocation(\n state.location,\n redirect.location,\n // TODO: This can be removed once we get rid of useTransition in Remix v2\n {\n _isRedirect: true,\n ...(isFetchActionRedirect ? { _isFetchActionRedirect: true } : {}),\n }\n );\n invariant(\n redirectLocation,\n \"Expected a location on the redirect navigation\"\n );\n\n if (isBrowser) {\n let isDocumentReload = false;\n\n if (redirect.reloadDocument) {\n // Hard reload if the response contained X-Remix-Reload-Document\n isDocumentReload = true;\n } else if (ABSOLUTE_URL_REGEX.test(redirect.location)) {\n const url = init.history.createURL(redirect.location);\n isDocumentReload =\n // Hard reload if it's an absolute URL to a new origin\n url.origin !== routerWindow.location.origin ||\n // Hard reload if it's an absolute URL that does not match our basename\n stripBasename(url.pathname, basename) == null;\n }\n\n if (isDocumentReload) {\n if (replace) {\n routerWindow.location.replace(redirect.location);\n } else {\n routerWindow.location.assign(redirect.location);\n }\n return;\n }\n }\n\n // There's no need to abort on redirects, since we don't detect the\n // redirect until the action/loaders have settled\n pendingNavigationController = null;\n\n let redirectHistoryAction =\n replace === true ? HistoryAction.Replace : HistoryAction.Push;\n\n // Use the incoming submission if provided, fallback on the active one in\n // state.navigation\n let activeSubmission =\n submission || getSubmissionFromNavigation(state.navigation);\n\n // If this was a 307/308 submission we want to preserve the HTTP method and\n // re-submit the GET/POST/PUT/PATCH/DELETE as a submission navigation to the\n // redirected location\n if (\n redirectPreserveMethodStatusCodes.has(redirect.status) &&\n activeSubmission &&\n isMutationMethod(activeSubmission.formMethod)\n ) {\n await startNavigation(redirectHistoryAction, redirectLocation, {\n submission: {\n ...activeSubmission,\n formAction: redirect.location,\n },\n // Preserve this flag across redirects\n preventScrollReset: pendingPreventScrollReset,\n });\n } else if (isFetchActionRedirect) {\n // For a fetch action redirect, we kick off a new loading navigation\n // without the fetcher submission, but we send it along for shouldRevalidate\n await startNavigation(redirectHistoryAction, redirectLocation, {\n overrideNavigation: getLoadingNavigation(redirectLocation),\n fetcherSubmission: activeSubmission,\n // Preserve this flag across redirects\n preventScrollReset: pendingPreventScrollReset,\n });\n } else {\n // If we have a submission, we will preserve it through the redirect navigation\n let overrideNavigation = getLoadingNavigation(\n redirectLocation,\n activeSubmission\n );\n await startNavigation(redirectHistoryAction, redirectLocation, {\n overrideNavigation,\n // Preserve this flag across redirects\n preventScrollReset: pendingPreventScrollReset,\n });\n }\n }\n\n async function callLoadersAndMaybeResolveData(\n currentMatches: AgnosticDataRouteMatch[],\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n fetchersToLoad: RevalidatingFetcher[],\n request: Request\n ) {\n // Call all navigation loaders and revalidating fetcher loaders in parallel,\n // then slice off the results into separate arrays so we can handle them\n // accordingly\n let results = await Promise.all([\n ...matchesToLoad.map((match) =>\n callLoaderOrAction(\n \"loader\",\n request,\n match,\n matches,\n manifest,\n mapRouteProperties,\n basename\n )\n ),\n ...fetchersToLoad.map((f) => {\n if (f.matches && f.match && f.controller) {\n return callLoaderOrAction(\n \"loader\",\n createClientSideRequest(init.history, f.path, f.controller.signal),\n f.match,\n f.matches,\n manifest,\n mapRouteProperties,\n basename\n );\n } else {\n let error: ErrorResult = {\n type: ResultType.error,\n error: getInternalRouterError(404, { pathname: f.path }),\n };\n return error;\n }\n }),\n ]);\n let loaderResults = results.slice(0, matchesToLoad.length);\n let fetcherResults = results.slice(matchesToLoad.length);\n\n await Promise.all([\n resolveDeferredResults(\n currentMatches,\n matchesToLoad,\n loaderResults,\n loaderResults.map(() => request.signal),\n false,\n state.loaderData\n ),\n resolveDeferredResults(\n currentMatches,\n fetchersToLoad.map((f) => f.match),\n fetcherResults,\n fetchersToLoad.map((f) => (f.controller ? f.controller.signal : null)),\n true\n ),\n ]);\n\n return { results, loaderResults, fetcherResults };\n }\n\n function interruptActiveLoads() {\n // Every interruption triggers a revalidation\n isRevalidationRequired = true;\n\n // Cancel pending route-level deferreds and mark cancelled routes for\n // revalidation\n cancelledDeferredRoutes.push(...cancelActiveDeferreds());\n\n // Abort in-flight fetcher loads\n fetchLoadMatches.forEach((_, key) => {\n if (fetchControllers.has(key)) {\n cancelledFetcherLoads.push(key);\n abortFetcher(key);\n }\n });\n }\n\n function setFetcherError(key: string, routeId: string, error: any) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n deleteFetcher(key);\n updateState({\n errors: {\n [boundaryMatch.route.id]: error,\n },\n fetchers: new Map(state.fetchers),\n });\n }\n\n function deleteFetcher(key: string): void {\n let fetcher = state.fetchers.get(key);\n // Don't abort the controller if this is a deletion of a fetcher.submit()\n // in it's loading phase since - we don't want to abort the corresponding\n // revalidation and want them to complete and land\n if (\n fetchControllers.has(key) &&\n !(fetcher && fetcher.state === \"loading\" && fetchReloadIds.has(key))\n ) {\n abortFetcher(key);\n }\n fetchLoadMatches.delete(key);\n fetchReloadIds.delete(key);\n fetchRedirectIds.delete(key);\n state.fetchers.delete(key);\n }\n\n function abortFetcher(key: string) {\n let controller = fetchControllers.get(key);\n invariant(controller, `Expected fetch controller: ${key}`);\n controller.abort();\n fetchControllers.delete(key);\n }\n\n function markFetchersDone(keys: string[]) {\n for (let key of keys) {\n let fetcher = getFetcher(key);\n let doneFetcher = getDoneFetcher(fetcher.data);\n state.fetchers.set(key, doneFetcher);\n }\n }\n\n function markFetchRedirectsDone(): boolean {\n let doneKeys = [];\n let updatedFetchers = false;\n for (let key of fetchRedirectIds) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n fetchRedirectIds.delete(key);\n doneKeys.push(key);\n updatedFetchers = true;\n }\n }\n markFetchersDone(doneKeys);\n return updatedFetchers;\n }\n\n function abortStaleFetchLoads(landedId: number): boolean {\n let yeetedKeys = [];\n for (let [key, id] of fetchReloadIds) {\n if (id < landedId) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n abortFetcher(key);\n fetchReloadIds.delete(key);\n yeetedKeys.push(key);\n }\n }\n }\n markFetchersDone(yeetedKeys);\n return yeetedKeys.length > 0;\n }\n\n function getBlocker(key: string, fn: BlockerFunction) {\n let blocker: Blocker = state.blockers.get(key) || IDLE_BLOCKER;\n\n if (blockerFunctions.get(key) !== fn) {\n blockerFunctions.set(key, fn);\n }\n\n return blocker;\n }\n\n function deleteBlocker(key: string) {\n state.blockers.delete(key);\n blockerFunctions.delete(key);\n }\n\n // Utility function to update blockers, ensuring valid state transitions\n function updateBlocker(key: string, newBlocker: Blocker) {\n let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n\n // Poor mans state machine :)\n // https://mermaid.live/edit#pako:eNqVkc9OwzAMxl8l8nnjAYrEtDIOHEBIgwvKJTReGy3_lDpIqO27k6awMG0XcrLlnz87nwdonESogKXXBuE79rq75XZO3-yHds0RJVuv70YrPlUrCEe2HfrORS3rubqZfuhtpg5C9wk5tZ4VKcRUq88q9Z8RS0-48cE1iHJkL0ugbHuFLus9L6spZy8nX9MP2CNdomVaposqu3fGayT8T8-jJQwhepo_UtpgBQaDEUom04dZhAN1aJBDlUKJBxE1ceB2Smj0Mln-IBW5AFU2dwUiktt_2Qaq2dBfaKdEup85UV7Yd-dKjlnkabl2Pvr0DTkTreM\n invariant(\n (blocker.state === \"unblocked\" && newBlocker.state === \"blocked\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"blocked\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"proceeding\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"unblocked\") ||\n (blocker.state === \"proceeding\" && newBlocker.state === \"unblocked\"),\n `Invalid blocker state transition: ${blocker.state} -> ${newBlocker.state}`\n );\n\n let blockers = new Map(state.blockers);\n blockers.set(key, newBlocker);\n updateState({ blockers });\n }\n\n function shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction,\n }: {\n currentLocation: Location;\n nextLocation: Location;\n historyAction: HistoryAction;\n }): string | undefined {\n if (blockerFunctions.size === 0) {\n return;\n }\n\n // We ony support a single active blocker at the moment since we don't have\n // any compelling use cases for multi-blocker yet\n if (blockerFunctions.size > 1) {\n warning(false, \"A router only supports one blocker at a time\");\n }\n\n let entries = Array.from(blockerFunctions.entries());\n let [blockerKey, blockerFunction] = entries[entries.length - 1];\n let blocker = state.blockers.get(blockerKey);\n\n if (blocker && blocker.state === \"proceeding\") {\n // If the blocker is currently proceeding, we don't need to re-check\n // it and can let this navigation continue\n return;\n }\n\n // At this point, we know we're unblocked/blocked so we need to check the\n // user-provided blocker function\n if (blockerFunction({ currentLocation, nextLocation, historyAction })) {\n return blockerKey;\n }\n }\n\n function cancelActiveDeferreds(\n predicate?: (routeId: string) => boolean\n ): string[] {\n let cancelledRouteIds: string[] = [];\n activeDeferreds.forEach((dfd, routeId) => {\n if (!predicate || predicate(routeId)) {\n // Cancel the deferred - but do not remove from activeDeferreds here -\n // we rely on the subscribers to do that so our tests can assert proper\n // cleanup via _internalActiveDeferreds\n dfd.cancel();\n cancelledRouteIds.push(routeId);\n activeDeferreds.delete(routeId);\n }\n });\n return cancelledRouteIds;\n }\n\n // Opt in to capturing and reporting scroll positions during navigations,\n // used by the component\n function enableScrollRestoration(\n positions: Record,\n getPosition: GetScrollPositionFunction,\n getKey?: GetScrollRestorationKeyFunction\n ) {\n savedScrollPositions = positions;\n getScrollPosition = getPosition;\n getScrollRestorationKey = getKey || null;\n\n // Perform initial hydration scroll restoration, since we miss the boat on\n // the initial updateState() because we've not yet rendered \n // and therefore have no savedScrollPositions available\n if (!initialScrollRestored && state.navigation === IDLE_NAVIGATION) {\n initialScrollRestored = true;\n let y = getSavedScrollPosition(state.location, state.matches);\n if (y != null) {\n updateState({ restoreScrollPosition: y });\n }\n }\n\n return () => {\n savedScrollPositions = null;\n getScrollPosition = null;\n getScrollRestorationKey = null;\n };\n }\n\n function getScrollKey(location: Location, matches: AgnosticDataRouteMatch[]) {\n if (getScrollRestorationKey) {\n let key = getScrollRestorationKey(\n location,\n matches.map((m) => createUseMatchesMatch(m, state.loaderData))\n );\n return key || location.key;\n }\n return location.key;\n }\n\n function saveScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): void {\n if (savedScrollPositions && getScrollPosition) {\n let key = getScrollKey(location, matches);\n savedScrollPositions[key] = getScrollPosition();\n }\n }\n\n function getSavedScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): number | null {\n if (savedScrollPositions) {\n let key = getScrollKey(location, matches);\n let y = savedScrollPositions[key];\n if (typeof y === \"number\") {\n return y;\n }\n }\n return null;\n }\n\n function _internalSetRoutes(newRoutes: AgnosticDataRouteObject[]) {\n manifest = {};\n inFlightDataRoutes = convertRoutesToDataRoutes(\n newRoutes,\n mapRouteProperties,\n undefined,\n manifest\n );\n }\n\n router = {\n get basename() {\n return basename;\n },\n get state() {\n return state;\n },\n get routes() {\n return dataRoutes;\n },\n initialize,\n subscribe,\n enableScrollRestoration,\n navigate,\n fetch,\n revalidate,\n // Passthrough to history-aware createHref used by useHref so we get proper\n // hash-aware URLs in DOM paths\n createHref: (to: To) => init.history.createHref(to),\n encodeLocation: (to: To) => init.history.encodeLocation(to),\n getFetcher,\n deleteFetcher,\n dispose,\n getBlocker,\n deleteBlocker,\n _internalFetchControllers: fetchControllers,\n _internalActiveDeferreds: activeDeferreds,\n // TODO: Remove setRoutes, it's temporary to avoid dealing with\n // updating the tree while validating the update algorithm.\n _internalSetRoutes,\n };\n\n return router;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region createStaticHandler\n////////////////////////////////////////////////////////////////////////////////\n\nexport const UNSAFE_DEFERRED_SYMBOL = Symbol(\"deferred\");\n\nexport interface CreateStaticHandlerOptions {\n basename?: string;\n /**\n * @deprecated Use `mapRouteProperties` instead\n */\n detectErrorBoundary?: DetectErrorBoundaryFunction;\n mapRouteProperties?: MapRoutePropertiesFunction;\n}\n\nexport function createStaticHandler(\n routes: AgnosticRouteObject[],\n opts?: CreateStaticHandlerOptions\n): StaticHandler {\n invariant(\n routes.length > 0,\n \"You must provide a non-empty routes array to createStaticHandler\"\n );\n\n let manifest: RouteManifest = {};\n let basename = (opts ? opts.basename : null) || \"/\";\n let mapRouteProperties: MapRoutePropertiesFunction;\n if (opts?.mapRouteProperties) {\n mapRouteProperties = opts.mapRouteProperties;\n } else if (opts?.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = opts.detectErrorBoundary;\n mapRouteProperties = (route) => ({\n hasErrorBoundary: detectErrorBoundary(route),\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n\n let dataRoutes = convertRoutesToDataRoutes(\n routes,\n mapRouteProperties,\n undefined,\n manifest\n );\n\n /**\n * The query() method is intended for document requests, in which we want to\n * call an optional action and potentially multiple loaders for all nested\n * routes. It returns a StaticHandlerContext object, which is very similar\n * to the router state (location, loaderData, actionData, errors, etc.) and\n * also adds SSR-specific information such as the statusCode and headers\n * from action/loaders Responses.\n *\n * It _should_ never throw and should report all errors through the\n * returned context.errors object, properly associating errors to their error\n * boundary. Additionally, it tracks _deepestRenderedBoundaryId which can be\n * used to emulate React error boundaries during SSr by performing a second\n * pass only down to the boundaryId.\n *\n * The one exception where we do not return a StaticHandlerContext is when a\n * redirect response is returned or thrown from any action/loader. We\n * propagate that out and return the raw Response so the HTTP server can\n * return it directly.\n */\n async function query(\n request: Request,\n { requestContext }: { requestContext?: unknown } = {}\n ): Promise {\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\") {\n let error = getInternalRouterError(405, { method });\n let { matches: methodNotAllowedMatches, route } =\n getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: methodNotAllowedMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error,\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n } else if (!matches) {\n let error = getInternalRouterError(404, { pathname: location.pathname });\n let { matches: notFoundMatches, route } =\n getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: notFoundMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error,\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n }\n\n let result = await queryImpl(request, location, matches, requestContext);\n if (isResponse(result)) {\n return result;\n }\n\n // When returning StaticHandlerContext, we patch back in the location here\n // since we need it for React Context. But this helps keep our submit and\n // loadRouteData operating on a Request instead of a Location\n return { location, basename, ...result };\n }\n\n /**\n * The queryRoute() method is intended for targeted route requests, either\n * for fetch ?_data requests or resource route requests. In this case, we\n * are only ever calling a single action or loader, and we are returning the\n * returned value directly. In most cases, this will be a Response returned\n * from the action/loader, but it may be a primitive or other value as well -\n * and in such cases the calling context should handle that accordingly.\n *\n * We do respect the throw/return differentiation, so if an action/loader\n * throws, then this method will throw the value. This is important so we\n * can do proper boundary identification in Remix where a thrown Response\n * must go to the Catch Boundary but a returned Response is happy-path.\n *\n * One thing to note is that any Router-initiated Errors that make sense\n * to associate with a status code will be thrown as an ErrorResponse\n * instance which include the raw Error, such that the calling context can\n * serialize the error as they see fit while including the proper response\n * code. Examples here are 404 and 405 errors that occur prior to reaching\n * any user-defined loaders.\n */\n async function queryRoute(\n request: Request,\n {\n routeId,\n requestContext,\n }: { requestContext?: unknown; routeId?: string } = {}\n ): Promise {\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\" && method !== \"OPTIONS\") {\n throw getInternalRouterError(405, { method });\n } else if (!matches) {\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n\n let match = routeId\n ? matches.find((m) => m.route.id === routeId)\n : getTargetMatch(matches, location);\n\n if (routeId && !match) {\n throw getInternalRouterError(403, {\n pathname: location.pathname,\n routeId,\n });\n } else if (!match) {\n // This should never hit I don't think?\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n\n let result = await queryImpl(\n request,\n location,\n matches,\n requestContext,\n match\n );\n if (isResponse(result)) {\n return result;\n }\n\n let error = result.errors ? Object.values(result.errors)[0] : undefined;\n if (error !== undefined) {\n // If we got back result.errors, that means the loader/action threw\n // _something_ that wasn't a Response, but it's not guaranteed/required\n // to be an `instanceof Error` either, so we have to use throw here to\n // preserve the \"error\" state outside of queryImpl.\n throw error;\n }\n\n // Pick off the right state value to return\n if (result.actionData) {\n return Object.values(result.actionData)[0];\n }\n\n if (result.loaderData) {\n let data = Object.values(result.loaderData)[0];\n if (result.activeDeferreds?.[match.route.id]) {\n data[UNSAFE_DEFERRED_SYMBOL] = result.activeDeferreds[match.route.id];\n }\n return data;\n }\n\n return undefined;\n }\n\n async function queryImpl(\n request: Request,\n location: Location,\n matches: AgnosticDataRouteMatch[],\n requestContext: unknown,\n routeMatch?: AgnosticDataRouteMatch\n ): Promise | Response> {\n invariant(\n request.signal,\n \"query()/queryRoute() requests must contain an AbortController signal\"\n );\n\n try {\n if (isMutationMethod(request.method.toLowerCase())) {\n let result = await submit(\n request,\n matches,\n routeMatch || getTargetMatch(matches, location),\n requestContext,\n routeMatch != null\n );\n return result;\n }\n\n let result = await loadRouteData(\n request,\n matches,\n requestContext,\n routeMatch\n );\n return isResponse(result)\n ? result\n : {\n ...result,\n actionData: null,\n actionHeaders: {},\n };\n } catch (e) {\n // If the user threw/returned a Response in callLoaderOrAction, we throw\n // it to bail out and then return or throw here based on whether the user\n // returned or threw\n if (isQueryRouteResponse(e)) {\n if (e.type === ResultType.error) {\n throw e.response;\n }\n return e.response;\n }\n // Redirects are always returned since they don't propagate to catch\n // boundaries\n if (isRedirectResponse(e)) {\n return e;\n }\n throw e;\n }\n }\n\n async function submit(\n request: Request,\n matches: AgnosticDataRouteMatch[],\n actionMatch: AgnosticDataRouteMatch,\n requestContext: unknown,\n isRouteRequest: boolean\n ): Promise | Response> {\n let result: DataResult;\n\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n let error = getInternalRouterError(405, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: actionMatch.route.id,\n });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error,\n };\n } else {\n result = await callLoaderOrAction(\n \"action\",\n request,\n actionMatch,\n matches,\n manifest,\n mapRouteProperties,\n basename,\n { isStaticRequest: true, isRouteRequest, requestContext }\n );\n\n if (request.signal.aborted) {\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(`${method}() call aborted`);\n }\n }\n\n if (isRedirectResult(result)) {\n // Uhhhh - this should never happen, we should always throw these from\n // callLoaderOrAction, but the type narrowing here keeps TS happy and we\n // can get back on the \"throw all redirect responses\" train here should\n // this ever happen :/\n throw new Response(null, {\n status: result.status,\n headers: {\n Location: result.location,\n },\n });\n }\n\n if (isDeferredResult(result)) {\n let error = getInternalRouterError(400, { type: \"defer-action\" });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error,\n };\n }\n\n if (isRouteRequest) {\n // Note: This should only be non-Response values if we get here, since\n // isRouteRequest should throw any Response received in callLoaderOrAction\n if (isErrorResult(result)) {\n throw result.error;\n }\n\n return {\n matches: [actionMatch],\n loaderData: {},\n actionData: { [actionMatch.route.id]: result.data },\n errors: null,\n // Note: statusCode + headers are unused here since queryRoute will\n // return the raw Response or value\n statusCode: 200,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n }\n\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n let context = await loadRouteData(\n request,\n matches,\n requestContext,\n undefined,\n {\n [boundaryMatch.route.id]: result.error,\n }\n );\n\n // action status codes take precedence over loader status codes\n return {\n ...context,\n statusCode: isRouteErrorResponse(result.error)\n ? result.error.status\n : 500,\n actionData: null,\n actionHeaders: {\n ...(result.headers ? { [actionMatch.route.id]: result.headers } : {}),\n },\n };\n }\n\n // Create a GET request for the loaders\n let loaderRequest = new Request(request.url, {\n headers: request.headers,\n redirect: request.redirect,\n signal: request.signal,\n });\n let context = await loadRouteData(loaderRequest, matches, requestContext);\n\n return {\n ...context,\n // action status codes take precedence over loader status codes\n ...(result.statusCode ? { statusCode: result.statusCode } : {}),\n actionData: {\n [actionMatch.route.id]: result.data,\n },\n actionHeaders: {\n ...(result.headers ? { [actionMatch.route.id]: result.headers } : {}),\n },\n };\n }\n\n async function loadRouteData(\n request: Request,\n matches: AgnosticDataRouteMatch[],\n requestContext: unknown,\n routeMatch?: AgnosticDataRouteMatch,\n pendingActionError?: RouteData\n ): Promise<\n | Omit<\n StaticHandlerContext,\n \"location\" | \"basename\" | \"actionData\" | \"actionHeaders\"\n >\n | Response\n > {\n let isRouteRequest = routeMatch != null;\n\n // Short circuit if we have no loaders to run (queryRoute())\n if (\n isRouteRequest &&\n !routeMatch?.route.loader &&\n !routeMatch?.route.lazy\n ) {\n throw getInternalRouterError(400, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: routeMatch?.route.id,\n });\n }\n\n let requestMatches = routeMatch\n ? [routeMatch]\n : getLoaderMatchesUntilBoundary(\n matches,\n Object.keys(pendingActionError || {})[0]\n );\n let matchesToLoad = requestMatches.filter(\n (m) => m.route.loader || m.route.lazy\n );\n\n // Short circuit if we have no loaders to run (query())\n if (matchesToLoad.length === 0) {\n return {\n matches,\n // Add a null for all matched routes for proper revalidation on the client\n loaderData: matches.reduce(\n (acc, m) => Object.assign(acc, { [m.route.id]: null }),\n {}\n ),\n errors: pendingActionError || null,\n statusCode: 200,\n loaderHeaders: {},\n activeDeferreds: null,\n };\n }\n\n let results = await Promise.all([\n ...matchesToLoad.map((match) =>\n callLoaderOrAction(\n \"loader\",\n request,\n match,\n matches,\n manifest,\n mapRouteProperties,\n basename,\n { isStaticRequest: true, isRouteRequest, requestContext }\n )\n ),\n ]);\n\n if (request.signal.aborted) {\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(`${method}() call aborted`);\n }\n\n // Process and commit output from loaders\n let activeDeferreds = new Map();\n let context = processRouteLoaderData(\n matches,\n matchesToLoad,\n results,\n pendingActionError,\n activeDeferreds\n );\n\n // Add a null for any non-loader matches for proper revalidation on the client\n let executedLoaders = new Set(\n matchesToLoad.map((match) => match.route.id)\n );\n matches.forEach((match) => {\n if (!executedLoaders.has(match.route.id)) {\n context.loaderData[match.route.id] = null;\n }\n });\n\n return {\n ...context,\n matches,\n activeDeferreds:\n activeDeferreds.size > 0\n ? Object.fromEntries(activeDeferreds.entries())\n : null,\n };\n }\n\n return {\n dataRoutes,\n query,\n queryRoute,\n };\n}\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Helpers\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Given an existing StaticHandlerContext and an error thrown at render time,\n * provide an updated StaticHandlerContext suitable for a second SSR render\n */\nexport function getStaticContextFromError(\n routes: AgnosticDataRouteObject[],\n context: StaticHandlerContext,\n error: any\n) {\n let newContext: StaticHandlerContext = {\n ...context,\n statusCode: 500,\n errors: {\n [context._deepestRenderedBoundaryId || routes[0].id]: error,\n },\n };\n return newContext;\n}\n\nfunction isSubmissionNavigation(\n opts: RouterNavigateOptions\n): opts is SubmissionNavigateOptions {\n return (\n opts != null &&\n ((\"formData\" in opts && opts.formData != null) ||\n (\"body\" in opts && opts.body !== undefined))\n );\n}\n\nfunction normalizeTo(\n location: Path,\n matches: AgnosticDataRouteMatch[],\n basename: string,\n prependBasename: boolean,\n to: To | null,\n fromRouteId?: string,\n relative?: RelativeRoutingType\n) {\n let contextualMatches: AgnosticDataRouteMatch[];\n let activeRouteMatch: AgnosticDataRouteMatch | undefined;\n if (fromRouteId != null && relative !== \"path\") {\n // Grab matches up to the calling route so our route-relative logic is\n // relative to the correct source route. When using relative:path,\n // fromRouteId is ignored since that is always relative to the current\n // location path\n contextualMatches = [];\n for (let match of matches) {\n contextualMatches.push(match);\n if (match.route.id === fromRouteId) {\n activeRouteMatch = match;\n break;\n }\n }\n } else {\n contextualMatches = matches;\n activeRouteMatch = matches[matches.length - 1];\n }\n\n // Resolve the relative path\n let path = resolveTo(\n to ? to : \".\",\n getPathContributingMatches(contextualMatches).map((m) => m.pathnameBase),\n stripBasename(location.pathname, basename) || location.pathname,\n relative === \"path\"\n );\n\n // When `to` is not specified we inherit search/hash from the current\n // location, unlike when to=\".\" and we just inherit the path.\n // See https://github.com/remix-run/remix/issues/927\n if (to == null) {\n path.search = location.search;\n path.hash = location.hash;\n }\n\n // Add an ?index param for matched index routes if we don't already have one\n if (\n (to == null || to === \"\" || to === \".\") &&\n activeRouteMatch &&\n activeRouteMatch.route.index &&\n !hasNakedIndexQuery(path.search)\n ) {\n path.search = path.search\n ? path.search.replace(/^\\?/, \"?index&\")\n : \"?index\";\n }\n\n // If we're operating within a basename, prepend it to the pathname. If\n // this is a root navigation, then just use the raw basename which allows\n // the basename to have full control over the presence of a trailing slash\n // on root actions\n if (prependBasename && basename !== \"/\") {\n path.pathname =\n path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n }\n\n return createPath(path);\n}\n\n// Normalize navigation options by converting formMethod=GET formData objects to\n// URLSearchParams so they behave identically to links with query params\nfunction normalizeNavigateOptions(\n normalizeFormMethod: boolean,\n isFetcher: boolean,\n path: string,\n opts?: RouterNavigateOptions\n): {\n path: string;\n submission?: Submission;\n error?: ErrorResponse;\n} {\n // Return location verbatim on non-submission navigations\n if (!opts || !isSubmissionNavigation(opts)) {\n return { path };\n }\n\n if (opts.formMethod && !isValidMethod(opts.formMethod)) {\n return {\n path,\n error: getInternalRouterError(405, { method: opts.formMethod }),\n };\n }\n\n let getInvalidBodyError = () => ({\n path,\n error: getInternalRouterError(400, { type: \"invalid-body\" }),\n });\n\n // Create a Submission on non-GET navigations\n let rawFormMethod = opts.formMethod || \"get\";\n let formMethod = normalizeFormMethod\n ? (rawFormMethod.toUpperCase() as V7_FormMethod)\n : (rawFormMethod.toLowerCase() as FormMethod);\n let formAction = stripHashFromPath(path);\n\n if (opts.body !== undefined) {\n if (opts.formEncType === \"text/plain\") {\n // text only support POST/PUT/PATCH/DELETE submissions\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n\n let text =\n typeof opts.body === \"string\"\n ? opts.body\n : opts.body instanceof FormData ||\n opts.body instanceof URLSearchParams\n ? // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#plain-text-form-data\n Array.from(opts.body.entries()).reduce(\n (acc, [name, value]) => `${acc}${name}=${value}\\n`,\n \"\"\n )\n : String(opts.body);\n\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: undefined,\n json: undefined,\n text,\n },\n };\n } else if (opts.formEncType === \"application/json\") {\n // json only supports POST/PUT/PATCH/DELETE submissions\n if (!isMutationMethod(formMethod)) {\n return getInvalidBodyError();\n }\n\n try {\n let json =\n typeof opts.body === \"string\" ? JSON.parse(opts.body) : opts.body;\n\n return {\n path,\n submission: {\n formMethod,\n formAction,\n formEncType: opts.formEncType,\n formData: undefined,\n json,\n text: undefined,\n },\n };\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n }\n\n invariant(\n typeof FormData === \"function\",\n \"FormData is not available in this environment\"\n );\n\n let searchParams: URLSearchParams;\n let formData: FormData;\n\n if (opts.formData) {\n searchParams = convertFormDataToSearchParams(opts.formData);\n formData = opts.formData;\n } else if (opts.body instanceof FormData) {\n searchParams = convertFormDataToSearchParams(opts.body);\n formData = opts.body;\n } else if (opts.body instanceof URLSearchParams) {\n searchParams = opts.body;\n formData = convertSearchParamsToFormData(searchParams);\n } else if (opts.body == null) {\n searchParams = new URLSearchParams();\n formData = new FormData();\n } else {\n try {\n searchParams = new URLSearchParams(opts.body);\n formData = convertSearchParamsToFormData(searchParams);\n } catch (e) {\n return getInvalidBodyError();\n }\n }\n\n let submission: Submission = {\n formMethod,\n formAction,\n formEncType:\n (opts && opts.formEncType) || \"application/x-www-form-urlencoded\",\n formData,\n json: undefined,\n text: undefined,\n };\n\n if (isMutationMethod(submission.formMethod)) {\n return { path, submission };\n }\n\n // Flatten submission onto URLSearchParams for GET submissions\n let parsedPath = parsePath(path);\n // On GET navigation submissions we can drop the ?index param from the\n // resulting location since all loaders will run. But fetcher GET submissions\n // only run a single loader so we need to preserve any incoming ?index params\n if (isFetcher && parsedPath.search && hasNakedIndexQuery(parsedPath.search)) {\n searchParams.append(\"index\", \"\");\n }\n parsedPath.search = `?${searchParams}`;\n\n return { path: createPath(parsedPath), submission };\n}\n\n// Filter out all routes below any caught error as they aren't going to\n// render so we don't need to load them\nfunction getLoaderMatchesUntilBoundary(\n matches: AgnosticDataRouteMatch[],\n boundaryId?: string\n) {\n let boundaryMatches = matches;\n if (boundaryId) {\n let index = matches.findIndex((m) => m.route.id === boundaryId);\n if (index >= 0) {\n boundaryMatches = matches.slice(0, index);\n }\n }\n return boundaryMatches;\n}\n\nfunction getMatchesToLoad(\n history: History,\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n submission: Submission | undefined,\n location: Location,\n isRevalidationRequired: boolean,\n cancelledDeferredRoutes: string[],\n cancelledFetcherLoads: string[],\n fetchLoadMatches: Map,\n fetchRedirectIds: Set,\n routesToUse: AgnosticDataRouteObject[],\n basename: string | undefined,\n pendingActionData?: RouteData,\n pendingError?: RouteData\n): [AgnosticDataRouteMatch[], RevalidatingFetcher[]] {\n let actionResult = pendingError\n ? Object.values(pendingError)[0]\n : pendingActionData\n ? Object.values(pendingActionData)[0]\n : undefined;\n\n let currentUrl = history.createURL(state.location);\n let nextUrl = history.createURL(location);\n\n // Pick navigation matches that are net-new or qualify for revalidation\n let boundaryId = pendingError ? Object.keys(pendingError)[0] : undefined;\n let boundaryMatches = getLoaderMatchesUntilBoundary(matches, boundaryId);\n\n let navigationMatches = boundaryMatches.filter((match, index) => {\n if (match.route.lazy) {\n // We haven't loaded this route yet so we don't know if it's got a loader!\n return true;\n }\n if (match.route.loader == null) {\n return false;\n }\n\n // Always call the loader on new route instances and pending defer cancellations\n if (\n isNewLoader(state.loaderData, state.matches[index], match) ||\n cancelledDeferredRoutes.some((id) => id === match.route.id)\n ) {\n return true;\n }\n\n // This is the default implementation for when we revalidate. If the route\n // provides it's own implementation, then we give them full control but\n // provide this value so they can leverage it if needed after they check\n // their own specific use cases\n let currentRouteMatch = state.matches[index];\n let nextRouteMatch = match;\n\n return shouldRevalidateLoader(match, {\n currentUrl,\n currentParams: currentRouteMatch.params,\n nextUrl,\n nextParams: nextRouteMatch.params,\n ...submission,\n actionResult,\n defaultShouldRevalidate:\n // Forced revalidation due to submission, useRevalidator, or X-Remix-Revalidate\n isRevalidationRequired ||\n // Clicked the same link, resubmitted a GET form\n currentUrl.pathname + currentUrl.search ===\n nextUrl.pathname + nextUrl.search ||\n // Search params affect all loaders\n currentUrl.search !== nextUrl.search ||\n isNewRouteInstance(currentRouteMatch, nextRouteMatch),\n });\n });\n\n // Pick fetcher.loads that need to be revalidated\n let revalidatingFetchers: RevalidatingFetcher[] = [];\n fetchLoadMatches.forEach((f, key) => {\n // Don't revalidate if fetcher won't be present in the subsequent render\n if (!matches.some((m) => m.route.id === f.routeId)) {\n return;\n }\n\n let fetcherMatches = matchRoutes(routesToUse, f.path, basename);\n\n // If the fetcher path no longer matches, push it in with null matches so\n // we can trigger a 404 in callLoadersAndMaybeResolveData. Note this is\n // currently only a use-case for Remix HMR where the route tree can change\n // at runtime and remove a route previously loaded via a fetcher\n if (!fetcherMatches) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: null,\n match: null,\n controller: null,\n });\n return;\n }\n\n // Revalidating fetchers are decoupled from the route matches since they\n // load from a static href. They revalidate based on explicit revalidation\n // (submission, useRevalidator, or X-Remix-Revalidate)\n let fetcher = state.fetchers.get(key);\n let fetcherMatch = getTargetMatch(fetcherMatches, f.path);\n\n let shouldRevalidate = false;\n if (fetchRedirectIds.has(key)) {\n // Never trigger a revalidation of an actively redirecting fetcher\n shouldRevalidate = false;\n } else if (cancelledFetcherLoads.includes(key)) {\n // Always revalidate if the fetcher was cancelled\n shouldRevalidate = true;\n } else if (\n fetcher &&\n fetcher.state !== \"idle\" &&\n fetcher.data === undefined\n ) {\n // If the fetcher hasn't ever completed loading yet, then this isn't a\n // revalidation, it would just be a brand new load if an explicit\n // revalidation is required\n shouldRevalidate = isRevalidationRequired;\n } else {\n // Otherwise fall back on any user-defined shouldRevalidate, defaulting\n // to explicit revalidations only\n shouldRevalidate = shouldRevalidateLoader(fetcherMatch, {\n currentUrl,\n currentParams: state.matches[state.matches.length - 1].params,\n nextUrl,\n nextParams: matches[matches.length - 1].params,\n ...submission,\n actionResult,\n defaultShouldRevalidate: isRevalidationRequired,\n });\n }\n\n if (shouldRevalidate) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: fetcherMatches,\n match: fetcherMatch,\n controller: new AbortController(),\n });\n }\n });\n\n return [navigationMatches, revalidatingFetchers];\n}\n\nfunction isNewLoader(\n currentLoaderData: RouteData,\n currentMatch: AgnosticDataRouteMatch,\n match: AgnosticDataRouteMatch\n) {\n let isNew =\n // [a] -> [a, b]\n !currentMatch ||\n // [a, b] -> [a, c]\n match.route.id !== currentMatch.route.id;\n\n // Handle the case that we don't have data for a re-used route, potentially\n // from a prior error or from a cancelled pending deferred\n let isMissingData = currentLoaderData[match.route.id] === undefined;\n\n // Always load if this is a net-new route or we don't yet have data\n return isNew || isMissingData;\n}\n\nfunction isNewRouteInstance(\n currentMatch: AgnosticDataRouteMatch,\n match: AgnosticDataRouteMatch\n) {\n let currentPath = currentMatch.route.path;\n return (\n // param change for this match, /users/123 -> /users/456\n currentMatch.pathname !== match.pathname ||\n // splat param changed, which is not present in match.path\n // e.g. /files/images/avatar.jpg -> files/finances.xls\n (currentPath != null &&\n currentPath.endsWith(\"*\") &&\n currentMatch.params[\"*\"] !== match.params[\"*\"])\n );\n}\n\nfunction shouldRevalidateLoader(\n loaderMatch: AgnosticDataRouteMatch,\n arg: Parameters[0]\n) {\n if (loaderMatch.route.shouldRevalidate) {\n let routeChoice = loaderMatch.route.shouldRevalidate(arg);\n if (typeof routeChoice === \"boolean\") {\n return routeChoice;\n }\n }\n\n return arg.defaultShouldRevalidate;\n}\n\n/**\n * Execute route.lazy() methods to lazily load route modules (loader, action,\n * shouldRevalidate) and update the routeManifest in place which shares objects\n * with dataRoutes so those get updated as well.\n */\nasync function loadLazyRouteModule(\n route: AgnosticDataRouteObject,\n mapRouteProperties: MapRoutePropertiesFunction,\n manifest: RouteManifest\n) {\n if (!route.lazy) {\n return;\n }\n\n let lazyRoute = await route.lazy();\n\n // If the lazy route function was executed and removed by another parallel\n // call then we can return - first lazy() to finish wins because the return\n // value of lazy is expected to be static\n if (!route.lazy) {\n return;\n }\n\n let routeToUpdate = manifest[route.id];\n invariant(routeToUpdate, \"No route found in manifest\");\n\n // Update the route in place. This should be safe because there's no way\n // we could yet be sitting on this route as we can't get there without\n // resolving lazy() first.\n //\n // This is different than the HMR \"update\" use-case where we may actively be\n // on the route being updated. The main concern boils down to \"does this\n // mutation affect any ongoing navigations or any current state.matches\n // values?\". If not, it should be safe to update in place.\n let routeUpdates: Record = {};\n for (let lazyRouteProperty in lazyRoute) {\n let staticRouteValue =\n routeToUpdate[lazyRouteProperty as keyof typeof routeToUpdate];\n\n let isPropertyStaticallyDefined =\n staticRouteValue !== undefined &&\n // This property isn't static since it should always be updated based\n // on the route updates\n lazyRouteProperty !== \"hasErrorBoundary\";\n\n warning(\n !isPropertyStaticallyDefined,\n `Route \"${routeToUpdate.id}\" has a static property \"${lazyRouteProperty}\" ` +\n `defined but its lazy function is also returning a value for this property. ` +\n `The lazy route property \"${lazyRouteProperty}\" will be ignored.`\n );\n\n if (\n !isPropertyStaticallyDefined &&\n !immutableRouteKeys.has(lazyRouteProperty as ImmutableRouteKey)\n ) {\n routeUpdates[lazyRouteProperty] =\n lazyRoute[lazyRouteProperty as keyof typeof lazyRoute];\n }\n }\n\n // Mutate the route with the provided updates. Do this first so we pass\n // the updated version to mapRouteProperties\n Object.assign(routeToUpdate, routeUpdates);\n\n // Mutate the `hasErrorBoundary` property on the route based on the route\n // updates and remove the `lazy` function so we don't resolve the lazy\n // route again.\n Object.assign(routeToUpdate, {\n // To keep things framework agnostic, we use the provided\n // `mapRouteProperties` (or wrapped `detectErrorBoundary`) function to\n // set the framework-aware properties (`element`/`hasErrorBoundary`) since\n // the logic will differ between frameworks.\n ...mapRouteProperties(routeToUpdate),\n lazy: undefined,\n });\n}\n\nasync function callLoaderOrAction(\n type: \"loader\" | \"action\",\n request: Request,\n match: AgnosticDataRouteMatch,\n matches: AgnosticDataRouteMatch[],\n manifest: RouteManifest,\n mapRouteProperties: MapRoutePropertiesFunction,\n basename: string,\n opts: {\n isStaticRequest?: boolean;\n isRouteRequest?: boolean;\n requestContext?: unknown;\n } = {}\n): Promise {\n let resultType;\n let result;\n let onReject: (() => void) | undefined;\n\n let runHandler = (handler: ActionFunction | LoaderFunction) => {\n // Setup a promise we can race against so that abort signals short circuit\n let reject: () => void;\n let abortPromise = new Promise((_, r) => (reject = r));\n onReject = () => reject();\n request.signal.addEventListener(\"abort\", onReject);\n return Promise.race([\n handler({\n request,\n params: match.params,\n context: opts.requestContext,\n }),\n abortPromise,\n ]);\n };\n\n try {\n let handler = match.route[type];\n\n if (match.route.lazy) {\n if (handler) {\n // Run statically defined handler in parallel with lazy()\n let values = await Promise.all([\n runHandler(handler),\n loadLazyRouteModule(match.route, mapRouteProperties, manifest),\n ]);\n result = values[0];\n } else {\n // Load lazy route module, then run any returned handler\n await loadLazyRouteModule(match.route, mapRouteProperties, manifest);\n\n handler = match.route[type];\n if (handler) {\n // Handler still run even if we got interrupted to maintain consistency\n // with un-abortable behavior of handler execution on non-lazy or\n // previously-lazy-loaded routes\n result = await runHandler(handler);\n } else if (type === \"action\") {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(405, {\n method: request.method,\n pathname,\n routeId: match.route.id,\n });\n } else {\n // lazy() route has no loader to run. Short circuit here so we don't\n // hit the invariant below that errors on returning undefined.\n return { type: ResultType.data, data: undefined };\n }\n }\n } else if (!handler) {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(404, {\n pathname,\n });\n } else {\n result = await runHandler(handler);\n }\n\n invariant(\n result !== undefined,\n `You defined ${type === \"action\" ? \"an action\" : \"a loader\"} for route ` +\n `\"${match.route.id}\" but didn't return anything from your \\`${type}\\` ` +\n `function. Please return a value or \\`null\\`.`\n );\n } catch (e) {\n resultType = ResultType.error;\n result = e;\n } finally {\n if (onReject) {\n request.signal.removeEventListener(\"abort\", onReject);\n }\n }\n\n if (isResponse(result)) {\n let status = result.status;\n\n // Process redirects\n if (redirectStatusCodes.has(status)) {\n let location = result.headers.get(\"Location\");\n invariant(\n location,\n \"Redirects returned/thrown from loaders/actions must have a Location header\"\n );\n\n // Support relative routing in internal redirects\n if (!ABSOLUTE_URL_REGEX.test(location)) {\n location = normalizeTo(\n new URL(request.url),\n matches.slice(0, matches.indexOf(match) + 1),\n basename,\n true,\n location\n );\n } else if (!opts.isStaticRequest) {\n // Strip off the protocol+origin for same-origin + same-basename absolute\n // redirects. If this is a static request, we can let it go back to the\n // browser as-is\n let currentUrl = new URL(request.url);\n let url = location.startsWith(\"//\")\n ? new URL(currentUrl.protocol + location)\n : new URL(location);\n let isSameBasename = stripBasename(url.pathname, basename) != null;\n if (url.origin === currentUrl.origin && isSameBasename) {\n location = url.pathname + url.search + url.hash;\n }\n }\n\n // Don't process redirects in the router during static requests requests.\n // Instead, throw the Response and let the server handle it with an HTTP\n // redirect. We also update the Location header in place in this flow so\n // basename and relative routing is taken into account\n if (opts.isStaticRequest) {\n result.headers.set(\"Location\", location);\n throw result;\n }\n\n return {\n type: ResultType.redirect,\n status,\n location,\n revalidate: result.headers.get(\"X-Remix-Revalidate\") !== null,\n reloadDocument: result.headers.get(\"X-Remix-Reload-Document\") !== null,\n };\n }\n\n // For SSR single-route requests, we want to hand Responses back directly\n // without unwrapping. We do this with the QueryRouteResponse wrapper\n // interface so we can know whether it was returned or thrown\n if (opts.isRouteRequest) {\n let queryRouteResponse: QueryRouteResponse = {\n type:\n resultType === ResultType.error ? ResultType.error : ResultType.data,\n response: result,\n };\n throw queryRouteResponse;\n }\n\n let data: any;\n let contentType = result.headers.get(\"Content-Type\");\n // Check between word boundaries instead of startsWith() due to the last\n // paragraph of https://httpwg.org/specs/rfc9110.html#field.content-type\n if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n data = await result.json();\n } else {\n data = await result.text();\n }\n\n if (resultType === ResultType.error) {\n return {\n type: resultType,\n error: new ErrorResponse(status, result.statusText, data),\n headers: result.headers,\n };\n }\n\n return {\n type: ResultType.data,\n data,\n statusCode: result.status,\n headers: result.headers,\n };\n }\n\n if (resultType === ResultType.error) {\n return { type: resultType, error: result };\n }\n\n if (isDeferredData(result)) {\n return {\n type: ResultType.deferred,\n deferredData: result,\n statusCode: result.init?.status,\n headers: result.init?.headers && new Headers(result.init.headers),\n };\n }\n\n return { type: ResultType.data, data: result };\n}\n\n// Utility method for creating the Request instances for loaders/actions during\n// client-side navigations and fetches. During SSR we will always have a\n// Request instance from the static handler (query/queryRoute)\nfunction createClientSideRequest(\n history: History,\n location: string | Location,\n signal: AbortSignal,\n submission?: Submission\n): Request {\n let url = history.createURL(stripHashFromPath(location)).toString();\n let init: RequestInit = { signal };\n\n if (submission && isMutationMethod(submission.formMethod)) {\n let { formMethod, formEncType } = submission;\n // Didn't think we needed this but it turns out unlike other methods, patch\n // won't be properly normalized to uppercase and results in a 405 error.\n // See: https://fetch.spec.whatwg.org/#concept-method\n init.method = formMethod.toUpperCase();\n\n if (formEncType === \"application/json\") {\n init.headers = new Headers({ \"Content-Type\": formEncType });\n init.body = JSON.stringify(submission.json);\n } else if (formEncType === \"text/plain\") {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = submission.text;\n } else if (\n formEncType === \"application/x-www-form-urlencoded\" &&\n submission.formData\n ) {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = convertFormDataToSearchParams(submission.formData);\n } else {\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n init.body = submission.formData;\n }\n }\n\n return new Request(url, init);\n}\n\nfunction convertFormDataToSearchParams(formData: FormData): URLSearchParams {\n let searchParams = new URLSearchParams();\n\n for (let [key, value] of formData.entries()) {\n // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#converting-an-entry-list-to-a-list-of-name-value-pairs\n searchParams.append(key, typeof value === \"string\" ? value : value.name);\n }\n\n return searchParams;\n}\n\nfunction convertSearchParamsToFormData(\n searchParams: URLSearchParams\n): FormData {\n let formData = new FormData();\n for (let [key, value] of searchParams.entries()) {\n formData.append(key, value);\n }\n return formData;\n}\n\nfunction processRouteLoaderData(\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n results: DataResult[],\n pendingError: RouteData | undefined,\n activeDeferreds: Map\n): {\n loaderData: RouterState[\"loaderData\"];\n errors: RouterState[\"errors\"] | null;\n statusCode: number;\n loaderHeaders: Record;\n} {\n // Fill in loaderData/errors from our loaders\n let loaderData: RouterState[\"loaderData\"] = {};\n let errors: RouterState[\"errors\"] | null = null;\n let statusCode: number | undefined;\n let foundError = false;\n let loaderHeaders: Record = {};\n\n // Process loader results into state.loaderData/state.errors\n results.forEach((result, index) => {\n let id = matchesToLoad[index].route.id;\n invariant(\n !isRedirectResult(result),\n \"Cannot handle redirect results in processLoaderData\"\n );\n if (isErrorResult(result)) {\n // Look upwards from the matched route for the closest ancestor\n // error boundary, defaulting to the root match\n let boundaryMatch = findNearestBoundary(matches, id);\n let error = result.error;\n // If we have a pending action error, we report it at the highest-route\n // that throws a loader error, and then clear it out to indicate that\n // it was consumed\n if (pendingError) {\n error = Object.values(pendingError)[0];\n pendingError = undefined;\n }\n\n errors = errors || {};\n\n // Prefer higher error values if lower errors bubble to the same boundary\n if (errors[boundaryMatch.route.id] == null) {\n errors[boundaryMatch.route.id] = error;\n }\n\n // Clear our any prior loaderData for the throwing route\n loaderData[id] = undefined;\n\n // Once we find our first (highest) error, we set the status code and\n // prevent deeper status codes from overriding\n if (!foundError) {\n foundError = true;\n statusCode = isRouteErrorResponse(result.error)\n ? result.error.status\n : 500;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n } else {\n if (isDeferredResult(result)) {\n activeDeferreds.set(id, result.deferredData);\n loaderData[id] = result.deferredData.data;\n } else {\n loaderData[id] = result.data;\n }\n\n // Error status codes always override success status codes, but if all\n // loaders are successful we take the deepest status code.\n if (\n result.statusCode != null &&\n result.statusCode !== 200 &&\n !foundError\n ) {\n statusCode = result.statusCode;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n }\n });\n\n // If we didn't consume the pending action error (i.e., all loaders\n // resolved), then consume it here. Also clear out any loaderData for the\n // throwing route\n if (pendingError) {\n errors = pendingError;\n loaderData[Object.keys(pendingError)[0]] = undefined;\n }\n\n return {\n loaderData,\n errors,\n statusCode: statusCode || 200,\n loaderHeaders,\n };\n}\n\nfunction processLoaderData(\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n results: DataResult[],\n pendingError: RouteData | undefined,\n revalidatingFetchers: RevalidatingFetcher[],\n fetcherResults: DataResult[],\n activeDeferreds: Map\n): {\n loaderData: RouterState[\"loaderData\"];\n errors?: RouterState[\"errors\"];\n} {\n let { loaderData, errors } = processRouteLoaderData(\n matches,\n matchesToLoad,\n results,\n pendingError,\n activeDeferreds\n );\n\n // Process results from our revalidating fetchers\n for (let index = 0; index < revalidatingFetchers.length; index++) {\n let { key, match, controller } = revalidatingFetchers[index];\n invariant(\n fetcherResults !== undefined && fetcherResults[index] !== undefined,\n \"Did not find corresponding fetcher result\"\n );\n let result = fetcherResults[index];\n\n // Process fetcher non-redirect errors\n if (controller && controller.signal.aborted) {\n // Nothing to do for aborted fetchers\n continue;\n } else if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, match?.route.id);\n if (!(errors && errors[boundaryMatch.route.id])) {\n errors = {\n ...errors,\n [boundaryMatch.route.id]: result.error,\n };\n }\n state.fetchers.delete(key);\n } else if (isRedirectResult(result)) {\n // Should never get here, redirects should get processed above, but we\n // keep this to type narrow to a success result in the else\n invariant(false, \"Unhandled fetcher revalidation redirect\");\n } else if (isDeferredResult(result)) {\n // Should never get here, deferred data should be awaited for fetchers\n // in resolveDeferredResults\n invariant(false, \"Unhandled fetcher deferred data\");\n } else {\n let doneFetcher = getDoneFetcher(result.data);\n state.fetchers.set(key, doneFetcher);\n }\n }\n\n return { loaderData, errors };\n}\n\nfunction mergeLoaderData(\n loaderData: RouteData,\n newLoaderData: RouteData,\n matches: AgnosticDataRouteMatch[],\n errors: RouteData | null | undefined\n): RouteData {\n let mergedLoaderData = { ...newLoaderData };\n for (let match of matches) {\n let id = match.route.id;\n if (newLoaderData.hasOwnProperty(id)) {\n if (newLoaderData[id] !== undefined) {\n mergedLoaderData[id] = newLoaderData[id];\n } else {\n // No-op - this is so we ignore existing data if we have a key in the\n // incoming object with an undefined value, which is how we unset a prior\n // loaderData if we encounter a loader error\n }\n } else if (loaderData[id] !== undefined && match.route.loader) {\n // Preserve existing keys not included in newLoaderData and where a loader\n // wasn't removed by HMR\n mergedLoaderData[id] = loaderData[id];\n }\n\n if (errors && errors.hasOwnProperty(id)) {\n // Don't keep any loader data below the boundary\n break;\n }\n }\n return mergedLoaderData;\n}\n\n// Find the nearest error boundary, looking upwards from the leaf route (or the\n// route specified by routeId) for the closest ancestor error boundary,\n// defaulting to the root match\nfunction findNearestBoundary(\n matches: AgnosticDataRouteMatch[],\n routeId?: string\n): AgnosticDataRouteMatch {\n let eligibleMatches = routeId\n ? matches.slice(0, matches.findIndex((m) => m.route.id === routeId) + 1)\n : [...matches];\n return (\n eligibleMatches.reverse().find((m) => m.route.hasErrorBoundary === true) ||\n matches[0]\n );\n}\n\nfunction getShortCircuitMatches(routes: AgnosticDataRouteObject[]): {\n matches: AgnosticDataRouteMatch[];\n route: AgnosticDataRouteObject;\n} {\n // Prefer a root layout route if present, otherwise shim in a route object\n let route = routes.find((r) => r.index || !r.path || r.path === \"/\") || {\n id: `__shim-error-route__`,\n };\n\n return {\n matches: [\n {\n params: {},\n pathname: \"\",\n pathnameBase: \"\",\n route,\n },\n ],\n route,\n };\n}\n\nfunction getInternalRouterError(\n status: number,\n {\n pathname,\n routeId,\n method,\n type,\n }: {\n pathname?: string;\n routeId?: string;\n method?: string;\n type?: \"defer-action\" | \"invalid-body\";\n } = {}\n) {\n let statusText = \"Unknown Server Error\";\n let errorMessage = \"Unknown @remix-run/router error\";\n\n if (status === 400) {\n statusText = \"Bad Request\";\n if (method && pathname && routeId) {\n errorMessage =\n `You made a ${method} request to \"${pathname}\" but ` +\n `did not provide a \\`loader\\` for route \"${routeId}\", ` +\n `so there is no way to handle the request.`;\n } else if (type === \"defer-action\") {\n errorMessage = \"defer() is not supported in actions\";\n } else if (type === \"invalid-body\") {\n errorMessage = \"Unable to encode submission body\";\n }\n } else if (status === 403) {\n statusText = \"Forbidden\";\n errorMessage = `Route \"${routeId}\" does not match URL \"${pathname}\"`;\n } else if (status === 404) {\n statusText = \"Not Found\";\n errorMessage = `No route matches URL \"${pathname}\"`;\n } else if (status === 405) {\n statusText = \"Method Not Allowed\";\n if (method && pathname && routeId) {\n errorMessage =\n `You made a ${method.toUpperCase()} request to \"${pathname}\" but ` +\n `did not provide an \\`action\\` for route \"${routeId}\", ` +\n `so there is no way to handle the request.`;\n } else if (method) {\n errorMessage = `Invalid request method \"${method.toUpperCase()}\"`;\n }\n }\n\n return new ErrorResponse(\n status || 500,\n statusText,\n new Error(errorMessage),\n true\n );\n}\n\n// Find any returned redirect errors, starting from the lowest match\nfunction findRedirect(\n results: DataResult[]\n): { result: RedirectResult; idx: number } | undefined {\n for (let i = results.length - 1; i >= 0; i--) {\n let result = results[i];\n if (isRedirectResult(result)) {\n return { result, idx: i };\n }\n }\n}\n\nfunction stripHashFromPath(path: To) {\n let parsedPath = typeof path === \"string\" ? parsePath(path) : path;\n return createPath({ ...parsedPath, hash: \"\" });\n}\n\nfunction isHashChangeOnly(a: Location, b: Location): boolean {\n if (a.pathname !== b.pathname || a.search !== b.search) {\n return false;\n }\n\n if (a.hash === \"\") {\n // /page -> /page#hash\n return b.hash !== \"\";\n } else if (a.hash === b.hash) {\n // /page#hash -> /page#hash\n return true;\n } else if (b.hash !== \"\") {\n // /page#hash -> /page#other\n return true;\n }\n\n // If the hash is removed the browser will re-perform a request to the server\n // /page#hash -> /page\n return false;\n}\n\nfunction isDeferredResult(result: DataResult): result is DeferredResult {\n return result.type === ResultType.deferred;\n}\n\nfunction isErrorResult(result: DataResult): result is ErrorResult {\n return result.type === ResultType.error;\n}\n\nfunction isRedirectResult(result?: DataResult): result is RedirectResult {\n return (result && result.type) === ResultType.redirect;\n}\n\nexport function isDeferredData(value: any): value is DeferredData {\n let deferred: DeferredData = value;\n return (\n deferred &&\n typeof deferred === \"object\" &&\n typeof deferred.data === \"object\" &&\n typeof deferred.subscribe === \"function\" &&\n typeof deferred.cancel === \"function\" &&\n typeof deferred.resolveData === \"function\"\n );\n}\n\nfunction isResponse(value: any): value is Response {\n return (\n value != null &&\n typeof value.status === \"number\" &&\n typeof value.statusText === \"string\" &&\n typeof value.headers === \"object\" &&\n typeof value.body !== \"undefined\"\n );\n}\n\nfunction isRedirectResponse(result: any): result is Response {\n if (!isResponse(result)) {\n return false;\n }\n\n let status = result.status;\n let location = result.headers.get(\"Location\");\n return status >= 300 && status <= 399 && location != null;\n}\n\nfunction isQueryRouteResponse(obj: any): obj is QueryRouteResponse {\n return (\n obj &&\n isResponse(obj.response) &&\n (obj.type === ResultType.data || obj.type === ResultType.error)\n );\n}\n\nfunction isValidMethod(method: string): method is FormMethod | V7_FormMethod {\n return validRequestMethods.has(method.toLowerCase() as FormMethod);\n}\n\nfunction isMutationMethod(\n method: string\n): method is MutationFormMethod | V7_MutationFormMethod {\n return validMutationMethods.has(method.toLowerCase() as MutationFormMethod);\n}\n\nasync function resolveDeferredResults(\n currentMatches: AgnosticDataRouteMatch[],\n matchesToLoad: (AgnosticDataRouteMatch | null)[],\n results: DataResult[],\n signals: (AbortSignal | null)[],\n isFetcher: boolean,\n currentLoaderData?: RouteData\n) {\n for (let index = 0; index < results.length; index++) {\n let result = results[index];\n let match = matchesToLoad[index];\n // If we don't have a match, then we can have a deferred result to do\n // anything with. This is for revalidating fetchers where the route was\n // removed during HMR\n if (!match) {\n continue;\n }\n\n let currentMatch = currentMatches.find(\n (m) => m.route.id === match!.route.id\n );\n let isRevalidatingLoader =\n currentMatch != null &&\n !isNewRouteInstance(currentMatch, match) &&\n (currentLoaderData && currentLoaderData[match.route.id]) !== undefined;\n\n if (isDeferredResult(result) && (isFetcher || isRevalidatingLoader)) {\n // Note: we do not have to touch activeDeferreds here since we race them\n // against the signal in resolveDeferredData and they'll get aborted\n // there if needed\n let signal = signals[index];\n invariant(\n signal,\n \"Expected an AbortSignal for revalidating fetcher deferred result\"\n );\n await resolveDeferredData(result, signal, isFetcher).then((result) => {\n if (result) {\n results[index] = result || results[index];\n }\n });\n }\n }\n}\n\nasync function resolveDeferredData(\n result: DeferredResult,\n signal: AbortSignal,\n unwrap = false\n): Promise {\n let aborted = await result.deferredData.resolveData(signal);\n if (aborted) {\n return;\n }\n\n if (unwrap) {\n try {\n return {\n type: ResultType.data,\n data: result.deferredData.unwrappedData,\n };\n } catch (e) {\n // Handle any TrackedPromise._error values encountered while unwrapping\n return {\n type: ResultType.error,\n error: e,\n };\n }\n }\n\n return {\n type: ResultType.data,\n data: result.deferredData.data,\n };\n}\n\nfunction hasNakedIndexQuery(search: string): boolean {\n return new URLSearchParams(search).getAll(\"index\").some((v) => v === \"\");\n}\n\n// Note: This should match the format exported by useMatches, so if you change\n// this please also change that :) Eventually we'll DRY this up\nfunction createUseMatchesMatch(\n match: AgnosticDataRouteMatch,\n loaderData: RouteData\n): UseMatchesMatch {\n let { route, pathname, params } = match;\n return {\n id: route.id,\n pathname,\n params,\n data: loaderData[route.id] as unknown,\n handle: route.handle as unknown,\n };\n}\n\nfunction getTargetMatch(\n matches: AgnosticDataRouteMatch[],\n location: Location | string\n) {\n let search =\n typeof location === \"string\" ? parsePath(location).search : location.search;\n if (\n matches[matches.length - 1].route.index &&\n hasNakedIndexQuery(search || \"\")\n ) {\n // Return the leaf index route when index is present\n return matches[matches.length - 1];\n }\n // Otherwise grab the deepest \"path contributing\" match (ignoring index and\n // pathless layout routes)\n let pathMatches = getPathContributingMatches(matches);\n return pathMatches[pathMatches.length - 1];\n}\n\nfunction getSubmissionFromNavigation(\n navigation: Navigation\n): Submission | undefined {\n let { formMethod, formAction, formEncType, text, formData, json } =\n navigation;\n if (!formMethod || !formAction || !formEncType) {\n return;\n }\n\n if (text != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: undefined,\n json: undefined,\n text,\n };\n } else if (formData != null) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData,\n json: undefined,\n text: undefined,\n };\n } else if (json !== undefined) {\n return {\n formMethod,\n formAction,\n formEncType,\n formData: undefined,\n json,\n text: undefined,\n };\n }\n}\n\nfunction getLoadingNavigation(\n location: Location,\n submission?: Submission\n): NavigationStates[\"Loading\"] {\n if (submission) {\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n };\n return navigation;\n } else {\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n };\n return navigation;\n }\n}\n\nfunction getSubmittingNavigation(\n location: Location,\n submission: Submission\n): NavigationStates[\"Submitting\"] {\n let navigation: NavigationStates[\"Submitting\"] = {\n state: \"submitting\",\n location,\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n };\n return navigation;\n}\n\nfunction getLoadingFetcher(\n submission?: Submission,\n data?: Fetcher[\"data\"]\n): FetcherStates[\"Loading\"] {\n if (submission) {\n let fetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data,\n \" _hasFetcherDoneAnything \": true,\n };\n return fetcher;\n } else {\n let fetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n data,\n \" _hasFetcherDoneAnything \": true,\n };\n return fetcher;\n }\n}\n\nfunction getSubmittingFetcher(\n submission: Submission,\n existingFetcher?: Fetcher\n): FetcherStates[\"Submitting\"] {\n let fetcher: FetcherStates[\"Submitting\"] = {\n state: \"submitting\",\n formMethod: submission.formMethod,\n formAction: submission.formAction,\n formEncType: submission.formEncType,\n formData: submission.formData,\n json: submission.json,\n text: submission.text,\n data: existingFetcher ? existingFetcher.data : undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n return fetcher;\n}\n\nfunction getDoneFetcher(data: Fetcher[\"data\"]): FetcherStates[\"Idle\"] {\n let fetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n json: undefined,\n text: undefined,\n data,\n \" _hasFetcherDoneAnything \": true,\n };\n return fetcher;\n}\n//#endregion\n","import * as React from \"react\";\nimport type {\n AgnosticRouteMatch,\n AgnosticIndexRouteObject,\n AgnosticNonIndexRouteObject,\n History,\n Location,\n RelativeRoutingType,\n Router,\n StaticHandlerContext,\n To,\n TrackedPromise,\n LazyRouteFunction,\n} from \"@remix-run/router\";\nimport type { Action as NavigationType } from \"@remix-run/router\";\n\n// Create react-specific types from the agnostic types in @remix-run/router to\n// export from react-router\nexport interface IndexRouteObject {\n caseSensitive?: AgnosticIndexRouteObject[\"caseSensitive\"];\n path?: AgnosticIndexRouteObject[\"path\"];\n id?: AgnosticIndexRouteObject[\"id\"];\n loader?: AgnosticIndexRouteObject[\"loader\"];\n action?: AgnosticIndexRouteObject[\"action\"];\n hasErrorBoundary?: AgnosticIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: AgnosticIndexRouteObject[\"shouldRevalidate\"];\n handle?: AgnosticIndexRouteObject[\"handle\"];\n index: true;\n children?: undefined;\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n lazy?: LazyRouteFunction;\n}\n\nexport interface NonIndexRouteObject {\n caseSensitive?: AgnosticNonIndexRouteObject[\"caseSensitive\"];\n path?: AgnosticNonIndexRouteObject[\"path\"];\n id?: AgnosticNonIndexRouteObject[\"id\"];\n loader?: AgnosticNonIndexRouteObject[\"loader\"];\n action?: AgnosticNonIndexRouteObject[\"action\"];\n hasErrorBoundary?: AgnosticNonIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: AgnosticNonIndexRouteObject[\"shouldRevalidate\"];\n handle?: AgnosticNonIndexRouteObject[\"handle\"];\n index?: false;\n children?: RouteObject[];\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n lazy?: LazyRouteFunction;\n}\n\nexport type RouteObject = IndexRouteObject | NonIndexRouteObject;\n\nexport type DataRouteObject = RouteObject & {\n children?: DataRouteObject[];\n id: string;\n};\n\nexport interface RouteMatch<\n ParamKey extends string = string,\n RouteObjectType extends RouteObject = RouteObject\n> extends AgnosticRouteMatch {}\n\nexport interface DataRouteMatch extends RouteMatch {}\n\nexport interface DataRouterContextObject extends NavigationContextObject {\n router: Router;\n staticContext?: StaticHandlerContext;\n}\n\nexport const DataRouterContext =\n React.createContext(null);\nif (__DEV__) {\n DataRouterContext.displayName = \"DataRouter\";\n}\n\nexport const DataRouterStateContext = React.createContext<\n Router[\"state\"] | null\n>(null);\nif (__DEV__) {\n DataRouterStateContext.displayName = \"DataRouterState\";\n}\n\nexport const AwaitContext = React.createContext(null);\nif (__DEV__) {\n AwaitContext.displayName = \"Await\";\n}\n\nexport interface NavigateOptions {\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n}\n\n/**\n * A Navigator is a \"location changer\"; it's how you get to different locations.\n *\n * Every history instance conforms to the Navigator interface, but the\n * distinction is useful primarily when it comes to the low-level API\n * where both the location and a navigator must be provided separately in order\n * to avoid \"tearing\" that may occur in a suspense-enabled app if the action\n * and/or location were to be read directly from the history instance.\n */\nexport interface Navigator {\n createHref: History[\"createHref\"];\n // Optional for backwards-compat with Router/HistoryRouter usage (edge case)\n encodeLocation?: History[\"encodeLocation\"];\n go: History[\"go\"];\n push(to: To, state?: any, opts?: NavigateOptions): void;\n replace(to: To, state?: any, opts?: NavigateOptions): void;\n}\n\ninterface NavigationContextObject {\n basename: string;\n navigator: Navigator;\n static: boolean;\n}\n\nexport const NavigationContext = React.createContext(\n null!\n);\n\nif (__DEV__) {\n NavigationContext.displayName = \"Navigation\";\n}\n\ninterface LocationContextObject {\n location: Location;\n navigationType: NavigationType;\n}\n\nexport const LocationContext = React.createContext(\n null!\n);\n\nif (__DEV__) {\n LocationContext.displayName = \"Location\";\n}\n\nexport interface RouteContextObject {\n outlet: React.ReactElement | null;\n matches: RouteMatch[];\n isDataRoute: boolean;\n}\n\nexport const RouteContext = React.createContext({\n outlet: null,\n matches: [],\n isDataRoute: false,\n});\n\nif (__DEV__) {\n RouteContext.displayName = \"Route\";\n}\n\nexport const RouteErrorContext = React.createContext(null);\n\nif (__DEV__) {\n RouteErrorContext.displayName = \"RouteError\";\n}\n","import * as React from \"react\";\nimport type {\n Blocker,\n BlockerFunction,\n Location,\n ParamParseKey,\n Params,\n Path,\n PathMatch,\n PathPattern,\n RelativeRoutingType,\n Router as RemixRouter,\n RevalidationState,\n To,\n} from \"@remix-run/router\";\nimport {\n Action as NavigationType,\n UNSAFE_invariant as invariant,\n isRouteErrorResponse,\n joinPaths,\n matchPath,\n matchRoutes,\n parsePath,\n resolveTo,\n stripBasename,\n IDLE_BLOCKER,\n UNSAFE_getPathContributingMatches as getPathContributingMatches,\n UNSAFE_warning as warning,\n} from \"@remix-run/router\";\n\nimport type {\n NavigateOptions,\n RouteContextObject,\n RouteMatch,\n RouteObject,\n DataRouteMatch,\n} from \"./context\";\nimport {\n DataRouterContext,\n DataRouterStateContext,\n LocationContext,\n NavigationContext,\n RouteContext,\n RouteErrorContext,\n AwaitContext,\n} from \"./context\";\n\n/**\n * Returns the full href for the given \"to\" value. This is useful for building\n * custom links that are also accessible and preserve right-click behavior.\n *\n * @see https://reactrouter.com/hooks/use-href\n */\nexport function useHref(\n to: To,\n { relative }: { relative?: RelativeRoutingType } = {}\n): string {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useHref() may be used only in the context of a component.`\n );\n\n let { basename, navigator } = React.useContext(NavigationContext);\n let { hash, pathname, search } = useResolvedPath(to, { relative });\n\n let joinedPathname = pathname;\n\n // If we're operating within a basename, prepend it to the pathname prior\n // to creating the href. If this is a root navigation, then just use the raw\n // basename which allows the basename to have full control over the presence\n // of a trailing slash on root links\n if (basename !== \"/\") {\n joinedPathname =\n pathname === \"/\" ? basename : joinPaths([basename, pathname]);\n }\n\n return navigator.createHref({ pathname: joinedPathname, search, hash });\n}\n\n/**\n * Returns true if this component is a descendant of a .\n *\n * @see https://reactrouter.com/hooks/use-in-router-context\n */\nexport function useInRouterContext(): boolean {\n return React.useContext(LocationContext) != null;\n}\n\n/**\n * Returns the current location object, which represents the current URL in web\n * browsers.\n *\n * Note: If you're using this it may mean you're doing some of your own\n * \"routing\" in your app, and we'd like to know what your use case is. We may\n * be able to provide something higher-level to better suit your needs.\n *\n * @see https://reactrouter.com/hooks/use-location\n */\nexport function useLocation(): Location {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useLocation() may be used only in the context of a component.`\n );\n\n return React.useContext(LocationContext).location;\n}\n\n/**\n * Returns the current navigation action which describes how the router came to\n * the current location, either by a pop, push, or replace on the history stack.\n *\n * @see https://reactrouter.com/hooks/use-navigation-type\n */\nexport function useNavigationType(): NavigationType {\n return React.useContext(LocationContext).navigationType;\n}\n\n/**\n * Returns a PathMatch object if the given pattern matches the current URL.\n * This is useful for components that need to know \"active\" state, e.g.\n * .\n *\n * @see https://reactrouter.com/hooks/use-match\n */\nexport function useMatch<\n ParamKey extends ParamParseKey,\n Path extends string\n>(pattern: PathPattern | Path): PathMatch | null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useMatch() may be used only in the context of a component.`\n );\n\n let { pathname } = useLocation();\n return React.useMemo(\n () => matchPath(pattern, pathname),\n [pathname, pattern]\n );\n}\n\n/**\n * The interface for the navigate() function returned from useNavigate().\n */\nexport interface NavigateFunction {\n (to: To, options?: NavigateOptions): void;\n (delta: number): void;\n}\n\nconst navigateEffectWarning =\n `You should call navigate() in a React.useEffect(), not when ` +\n `your component is first rendered.`;\n\n// Mute warnings for calls to useNavigate in SSR environments\nfunction useIsomorphicLayoutEffect(\n cb: Parameters[0]\n) {\n let isStatic = React.useContext(NavigationContext).static;\n if (!isStatic) {\n // We should be able to get rid of this once react 18.3 is released\n // See: https://github.com/facebook/react/pull/26395\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useLayoutEffect(cb);\n }\n}\n\n/**\n * Returns an imperative method for changing the location. Used by s, but\n * may also be used by other elements to change the location.\n *\n * @see https://reactrouter.com/hooks/use-navigate\n */\nexport function useNavigate(): NavigateFunction {\n let { isDataRoute } = React.useContext(RouteContext);\n // Conditional usage is OK here because the usage of a data router is static\n // eslint-disable-next-line react-hooks/rules-of-hooks\n return isDataRoute ? useNavigateStable() : useNavigateUnstable();\n}\n\nfunction useNavigateUnstable(): NavigateFunction {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useNavigate() may be used only in the context of a component.`\n );\n\n let dataRouterContext = React.useContext(DataRouterContext);\n let { basename, navigator } = React.useContext(NavigationContext);\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n\n let routePathnamesJson = JSON.stringify(\n getPathContributingMatches(matches).map((match) => match.pathnameBase)\n );\n\n let activeRef = React.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n\n let navigate: NavigateFunction = React.useCallback(\n (to: To | number, options: NavigateOptions = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our history listener yet\n if (!activeRef.current) return;\n\n if (typeof to === \"number\") {\n navigator.go(to);\n return;\n }\n\n let path = resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n options.relative === \"path\"\n );\n\n // If we're operating within a basename, prepend it to the pathname prior\n // to handing off to history (but only if we're not in a data router,\n // otherwise it'll prepend the basename inside of the router).\n // If this is a root navigation, then we navigate to the raw basename\n // which allows the basename to have full control over the presence of a\n // trailing slash on root links\n if (dataRouterContext == null && basename !== \"/\") {\n path.pathname =\n path.pathname === \"/\"\n ? basename\n : joinPaths([basename, path.pathname]);\n }\n\n (!!options.replace ? navigator.replace : navigator.push)(\n path,\n options.state,\n options\n );\n },\n [\n basename,\n navigator,\n routePathnamesJson,\n locationPathname,\n dataRouterContext,\n ]\n );\n\n return navigate;\n}\n\nconst OutletContext = React.createContext(null);\n\n/**\n * Returns the context (if provided) for the child route at this level of the route\n * hierarchy.\n * @see https://reactrouter.com/hooks/use-outlet-context\n */\nexport function useOutletContext(): Context {\n return React.useContext(OutletContext) as Context;\n}\n\n/**\n * Returns the element for the child route at this level of the route\n * hierarchy. Used internally by to render child routes.\n *\n * @see https://reactrouter.com/hooks/use-outlet\n */\nexport function useOutlet(context?: unknown): React.ReactElement | null {\n let outlet = React.useContext(RouteContext).outlet;\n if (outlet) {\n return (\n {outlet}\n );\n }\n return outlet;\n}\n\n/**\n * Returns an object of key/value pairs of the dynamic params from the current\n * URL that were matched by the route path.\n *\n * @see https://reactrouter.com/hooks/use-params\n */\nexport function useParams<\n ParamsOrKey extends string | Record = string\n>(): Readonly<\n [ParamsOrKey] extends [string] ? Params : Partial\n> {\n let { matches } = React.useContext(RouteContext);\n let routeMatch = matches[matches.length - 1];\n return routeMatch ? (routeMatch.params as any) : {};\n}\n\n/**\n * Resolves the pathname of the given `to` value against the current location.\n *\n * @see https://reactrouter.com/hooks/use-resolved-path\n */\nexport function useResolvedPath(\n to: To,\n { relative }: { relative?: RelativeRoutingType } = {}\n): Path {\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n\n let routePathnamesJson = JSON.stringify(\n getPathContributingMatches(matches).map((match) => match.pathnameBase)\n );\n\n return React.useMemo(\n () =>\n resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n relative === \"path\"\n ),\n [to, routePathnamesJson, locationPathname, relative]\n );\n}\n\n/**\n * Returns the element of the route that matched the current location, prepared\n * with the correct context to render the remainder of the route tree. Route\n * elements in the tree must render an to render their child route's\n * element.\n *\n * @see https://reactrouter.com/hooks/use-routes\n */\nexport function useRoutes(\n routes: RouteObject[],\n locationArg?: Partial | string\n): React.ReactElement | null {\n return useRoutesImpl(routes, locationArg);\n}\n\n// Internal implementation with accept optional param for RouterProvider usage\nexport function useRoutesImpl(\n routes: RouteObject[],\n locationArg?: Partial | string,\n dataRouterState?: RemixRouter[\"state\"]\n): React.ReactElement | null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useRoutes() may be used only in the context of a component.`\n );\n\n let { navigator } = React.useContext(NavigationContext);\n let { matches: parentMatches } = React.useContext(RouteContext);\n let routeMatch = parentMatches[parentMatches.length - 1];\n let parentParams = routeMatch ? routeMatch.params : {};\n let parentPathname = routeMatch ? routeMatch.pathname : \"/\";\n let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : \"/\";\n let parentRoute = routeMatch && routeMatch.route;\n\n if (__DEV__) {\n // You won't get a warning about 2 different under a \n // without a trailing *, but this is a best-effort warning anyway since we\n // cannot even give the warning unless they land at the parent route.\n //\n // Example:\n //\n // \n // {/* This route path MUST end with /* because otherwise\n // it will never match /blog/post/123 */}\n // } />\n // } />\n // \n //\n // function Blog() {\n // return (\n // \n // } />\n // \n // );\n // }\n let parentPath = (parentRoute && parentRoute.path) || \"\";\n warningOnce(\n parentPathname,\n !parentRoute || parentPath.endsWith(\"*\"),\n `You rendered descendant (or called \\`useRoutes()\\`) at ` +\n `\"${parentPathname}\" (under ) but the ` +\n `parent route path has no trailing \"*\". This means if you navigate ` +\n `deeper, the parent won't match anymore and therefore the child ` +\n `routes will never render.\\n\\n` +\n `Please change the parent to .`\n );\n }\n\n let locationFromContext = useLocation();\n\n let location;\n if (locationArg) {\n let parsedLocationArg =\n typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n\n invariant(\n parentPathnameBase === \"/\" ||\n parsedLocationArg.pathname?.startsWith(parentPathnameBase),\n `When overriding the location using \\`\\` or \\`useRoutes(routes, location)\\`, ` +\n `the location pathname must begin with the portion of the URL pathname that was ` +\n `matched by all parent routes. The current pathname base is \"${parentPathnameBase}\" ` +\n `but pathname \"${parsedLocationArg.pathname}\" was given in the \\`location\\` prop.`\n );\n\n location = parsedLocationArg;\n } else {\n location = locationFromContext;\n }\n\n let pathname = location.pathname || \"/\";\n let remainingPathname =\n parentPathnameBase === \"/\"\n ? pathname\n : pathname.slice(parentPathnameBase.length) || \"/\";\n\n let matches = matchRoutes(routes, { pathname: remainingPathname });\n\n if (__DEV__) {\n warning(\n parentRoute || matches != null,\n `No routes matched location \"${location.pathname}${location.search}${location.hash}\" `\n );\n\n warning(\n matches == null ||\n matches[matches.length - 1].route.element !== undefined ||\n matches[matches.length - 1].route.Component !== undefined,\n `Matched leaf route at location \"${location.pathname}${location.search}${location.hash}\" ` +\n `does not have an element or Component. This means it will render an with a ` +\n `null value by default resulting in an \"empty\" page.`\n );\n }\n\n let renderedMatches = _renderMatches(\n matches &&\n matches.map((match) =>\n Object.assign({}, match, {\n params: Object.assign({}, parentParams, match.params),\n pathname: joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation\n ? navigator.encodeLocation(match.pathname).pathname\n : match.pathname,\n ]),\n pathnameBase:\n match.pathnameBase === \"/\"\n ? parentPathnameBase\n : joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation\n ? navigator.encodeLocation(match.pathnameBase).pathname\n : match.pathnameBase,\n ]),\n })\n ),\n parentMatches,\n dataRouterState\n );\n\n // When a user passes in a `locationArg`, the associated routes need to\n // be wrapped in a new `LocationContext.Provider` in order for `useLocation`\n // to use the scoped location instead of the global location.\n if (locationArg && renderedMatches) {\n return (\n \n {renderedMatches}\n \n );\n }\n\n return renderedMatches;\n}\n\nfunction DefaultErrorComponent() {\n let error = useRouteError();\n let message = isRouteErrorResponse(error)\n ? `${error.status} ${error.statusText}`\n : error instanceof Error\n ? error.message\n : JSON.stringify(error);\n let stack = error instanceof Error ? error.stack : null;\n let lightgrey = \"rgba(200,200,200, 0.5)\";\n let preStyles = { padding: \"0.5rem\", backgroundColor: lightgrey };\n let codeStyles = { padding: \"2px 4px\", backgroundColor: lightgrey };\n\n let devInfo = null;\n if (__DEV__) {\n console.error(\n \"Error handled by React Router default ErrorBoundary:\",\n error\n );\n\n devInfo = (\n <>\n

💿 Hey developer 👋

\n

\n You can provide a way better UX than this when your app throws errors\n by providing your own ErrorBoundary or{\" \"}\n errorElement prop on your route.\n

\n \n );\n }\n\n return (\n <>\n

Unexpected Application Error!

\n

{message}

\n {stack ?
{stack}
: null}\n {devInfo}\n \n );\n}\n\nconst defaultErrorElement = ;\n\ntype RenderErrorBoundaryProps = React.PropsWithChildren<{\n location: Location;\n revalidation: RevalidationState;\n error: any;\n component: React.ReactNode;\n routeContext: RouteContextObject;\n}>;\n\ntype RenderErrorBoundaryState = {\n location: Location;\n revalidation: RevalidationState;\n error: any;\n};\n\nexport class RenderErrorBoundary extends React.Component<\n RenderErrorBoundaryProps,\n RenderErrorBoundaryState\n> {\n constructor(props: RenderErrorBoundaryProps) {\n super(props);\n this.state = {\n location: props.location,\n revalidation: props.revalidation,\n error: props.error,\n };\n }\n\n static getDerivedStateFromError(error: any) {\n return { error: error };\n }\n\n static getDerivedStateFromProps(\n props: RenderErrorBoundaryProps,\n state: RenderErrorBoundaryState\n ) {\n // When we get into an error state, the user will likely click \"back\" to the\n // previous page that didn't have an error. Because this wraps the entire\n // application, that will have no effect--the error page continues to display.\n // This gives us a mechanism to recover from the error when the location changes.\n //\n // Whether we're in an error state or not, we update the location in state\n // so that when we are in an error state, it gets reset when a new location\n // comes in and the user recovers from the error.\n if (\n state.location !== props.location ||\n (state.revalidation !== \"idle\" && props.revalidation === \"idle\")\n ) {\n return {\n error: props.error,\n location: props.location,\n revalidation: props.revalidation,\n };\n }\n\n // If we're not changing locations, preserve the location but still surface\n // any new errors that may come through. We retain the existing error, we do\n // this because the error provided from the app state may be cleared without\n // the location changing.\n return {\n error: props.error || state.error,\n location: state.location,\n revalidation: props.revalidation || state.revalidation,\n };\n }\n\n componentDidCatch(error: any, errorInfo: any) {\n console.error(\n \"React Router caught the following error during render\",\n error,\n errorInfo\n );\n }\n\n render() {\n return this.state.error ? (\n \n \n \n ) : (\n this.props.children\n );\n }\n}\n\ninterface RenderedRouteProps {\n routeContext: RouteContextObject;\n match: RouteMatch;\n children: React.ReactNode | null;\n}\n\nfunction RenderedRoute({ routeContext, match, children }: RenderedRouteProps) {\n let dataRouterContext = React.useContext(DataRouterContext);\n\n // Track how deep we got in our render pass to emulate SSR componentDidCatch\n // in a DataStaticRouter\n if (\n dataRouterContext &&\n dataRouterContext.static &&\n dataRouterContext.staticContext &&\n (match.route.errorElement || match.route.ErrorBoundary)\n ) {\n dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;\n }\n\n return (\n \n {children}\n \n );\n}\n\nexport function _renderMatches(\n matches: RouteMatch[] | null,\n parentMatches: RouteMatch[] = [],\n dataRouterState: RemixRouter[\"state\"] | null = null\n): React.ReactElement | null {\n if (matches == null) {\n if (dataRouterState?.errors) {\n // Don't bail if we have data router errors so we can render them in the\n // boundary. Use the pre-matched (or shimmed) matches\n matches = dataRouterState.matches as DataRouteMatch[];\n } else {\n return null;\n }\n }\n\n let renderedMatches = matches;\n\n // If we have data errors, trim matches to the highest error boundary\n let errors = dataRouterState?.errors;\n if (errors != null) {\n let errorIndex = renderedMatches.findIndex(\n (m) => m.route.id && errors?.[m.route.id]\n );\n invariant(\n errorIndex >= 0,\n `Could not find a matching route for errors on route IDs: ${Object.keys(\n errors\n ).join(\",\")}`\n );\n renderedMatches = renderedMatches.slice(\n 0,\n Math.min(renderedMatches.length, errorIndex + 1)\n );\n }\n\n return renderedMatches.reduceRight((outlet, match, index) => {\n let error = match.route.id ? errors?.[match.route.id] : null;\n // Only data routers handle errors\n let errorElement: React.ReactNode | null = null;\n if (dataRouterState) {\n errorElement = match.route.errorElement || defaultErrorElement;\n }\n let matches = parentMatches.concat(renderedMatches.slice(0, index + 1));\n let getChildren = () => {\n let children: React.ReactNode;\n if (error) {\n children = errorElement;\n } else if (match.route.Component) {\n // Note: This is a de-optimized path since React won't re-use the\n // ReactElement since it's identity changes with each new\n // React.createElement call. We keep this so folks can use\n // `` in `` but generally `Component`\n // usage is only advised in `RouterProvider` when we can convert it to\n // `element` ahead of time.\n children = ;\n } else if (match.route.element) {\n children = match.route.element;\n } else {\n children = outlet;\n }\n return (\n \n );\n };\n // Only wrap in an error boundary within data router usages when we have an\n // ErrorBoundary/errorElement on this route. Otherwise let it bubble up to\n // an ancestor ErrorBoundary/errorElement\n return dataRouterState &&\n (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? (\n \n ) : (\n getChildren()\n );\n }, null as React.ReactElement | null);\n}\n\nenum DataRouterHook {\n UseBlocker = \"useBlocker\",\n UseRevalidator = \"useRevalidator\",\n UseNavigateStable = \"useNavigate\",\n}\n\nenum DataRouterStateHook {\n UseBlocker = \"useBlocker\",\n UseLoaderData = \"useLoaderData\",\n UseActionData = \"useActionData\",\n UseRouteError = \"useRouteError\",\n UseNavigation = \"useNavigation\",\n UseRouteLoaderData = \"useRouteLoaderData\",\n UseMatches = \"useMatches\",\n UseRevalidator = \"useRevalidator\",\n UseNavigateStable = \"useNavigate\",\n UseRouteId = \"useRouteId\",\n}\n\nfunction getDataRouterConsoleError(\n hookName: DataRouterHook | DataRouterStateHook\n) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/routers/picking-a-router.`;\n}\n\nfunction useDataRouterContext(hookName: DataRouterHook) {\n let ctx = React.useContext(DataRouterContext);\n invariant(ctx, getDataRouterConsoleError(hookName));\n return ctx;\n}\n\nfunction useDataRouterState(hookName: DataRouterStateHook) {\n let state = React.useContext(DataRouterStateContext);\n invariant(state, getDataRouterConsoleError(hookName));\n return state;\n}\n\nfunction useRouteContext(hookName: DataRouterStateHook) {\n let route = React.useContext(RouteContext);\n invariant(route, getDataRouterConsoleError(hookName));\n return route;\n}\n\n// Internal version with hookName-aware debugging\nfunction useCurrentRouteId(hookName: DataRouterStateHook) {\n let route = useRouteContext(hookName);\n let thisRoute = route.matches[route.matches.length - 1];\n invariant(\n thisRoute.route.id,\n `${hookName} can only be used on routes that contain a unique \"id\"`\n );\n return thisRoute.route.id;\n}\n\n/**\n * Returns the ID for the nearest contextual route\n */\nexport function useRouteId() {\n return useCurrentRouteId(DataRouterStateHook.UseRouteId);\n}\n\n/**\n * Returns the current navigation, defaulting to an \"idle\" navigation when\n * no navigation is in progress\n */\nexport function useNavigation() {\n let state = useDataRouterState(DataRouterStateHook.UseNavigation);\n return state.navigation;\n}\n\n/**\n * Returns a revalidate function for manually triggering revalidation, as well\n * as the current state of any manual revalidations\n */\nexport function useRevalidator() {\n let dataRouterContext = useDataRouterContext(DataRouterHook.UseRevalidator);\n let state = useDataRouterState(DataRouterStateHook.UseRevalidator);\n return React.useMemo(\n () => ({\n revalidate: dataRouterContext.router.revalidate,\n state: state.revalidation,\n }),\n [dataRouterContext.router.revalidate, state.revalidation]\n );\n}\n\n/**\n * Returns the active route matches, useful for accessing loaderData for\n * parent/child routes or the route \"handle\" property\n */\nexport function useMatches() {\n let { matches, loaderData } = useDataRouterState(\n DataRouterStateHook.UseMatches\n );\n return React.useMemo(\n () =>\n matches.map((match) => {\n let { pathname, params } = match;\n // Note: This structure matches that created by createUseMatchesMatch\n // in the @remix-run/router , so if you change this please also change\n // that :) Eventually we'll DRY this up\n return {\n id: match.route.id,\n pathname,\n params,\n data: loaderData[match.route.id] as unknown,\n handle: match.route.handle as unknown,\n };\n }),\n [matches, loaderData]\n );\n}\n\n/**\n * Returns the loader data for the nearest ancestor Route loader\n */\nexport function useLoaderData(): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseLoaderData);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);\n\n if (state.errors && state.errors[routeId] != null) {\n console.error(\n `You cannot \\`useLoaderData\\` in an errorElement (routeId: ${routeId})`\n );\n return undefined;\n }\n return state.loaderData[routeId];\n}\n\n/**\n * Returns the loaderData for the given routeId\n */\nexport function useRouteLoaderData(routeId: string): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseRouteLoaderData);\n return state.loaderData[routeId];\n}\n\n/**\n * Returns the action data for the nearest ancestor Route action\n */\nexport function useActionData(): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseActionData);\n\n let route = React.useContext(RouteContext);\n invariant(route, `useActionData must be used inside a RouteContext`);\n\n return Object.values(state?.actionData || {})[0];\n}\n\n/**\n * Returns the nearest ancestor Route error, which could be a loader/action\n * error or a render error. This is intended to be called from your\n * ErrorBoundary/errorElement to display a proper error message.\n */\nexport function useRouteError(): unknown {\n let error = React.useContext(RouteErrorContext);\n let state = useDataRouterState(DataRouterStateHook.UseRouteError);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseRouteError);\n\n // If this was a render error, we put it in a RouteError context inside\n // of RenderErrorBoundary\n if (error) {\n return error;\n }\n\n // Otherwise look for errors from our data router state\n return state.errors?.[routeId];\n}\n\n/**\n * Returns the happy-path data from the nearest ancestor value\n */\nexport function useAsyncValue(): unknown {\n let value = React.useContext(AwaitContext);\n return value?._data;\n}\n\n/**\n * Returns the error from the nearest ancestor value\n */\nexport function useAsyncError(): unknown {\n let value = React.useContext(AwaitContext);\n return value?._error;\n}\n\nlet blockerId = 0;\n\n/**\n * Allow the application to block navigations within the SPA and present the\n * user a confirmation dialog to confirm the navigation. Mostly used to avoid\n * using half-filled form data. This does not handle hard-reloads or\n * cross-origin navigations.\n */\nexport function useBlocker(shouldBlock: boolean | BlockerFunction): Blocker {\n let { router, basename } = useDataRouterContext(DataRouterHook.UseBlocker);\n let state = useDataRouterState(DataRouterStateHook.UseBlocker);\n\n let [blockerKey, setBlockerKey] = React.useState(\"\");\n let blockerFunction = React.useCallback(\n (arg) => {\n if (typeof shouldBlock !== \"function\") {\n return !!shouldBlock;\n }\n if (basename === \"/\") {\n return shouldBlock(arg);\n }\n\n // If they provided us a function and we've got an active basename, strip\n // it from the locations we expose to the user to match the behavior of\n // useLocation\n let { currentLocation, nextLocation, historyAction } = arg;\n return shouldBlock({\n currentLocation: {\n ...currentLocation,\n pathname:\n stripBasename(currentLocation.pathname, basename) ||\n currentLocation.pathname,\n },\n nextLocation: {\n ...nextLocation,\n pathname:\n stripBasename(nextLocation.pathname, basename) ||\n nextLocation.pathname,\n },\n historyAction,\n });\n },\n [basename, shouldBlock]\n );\n\n // This effect is in charge of blocker key assignment and deletion (which is\n // tightly coupled to the key)\n React.useEffect(() => {\n let key = String(++blockerId);\n setBlockerKey(key);\n return () => router.deleteBlocker(key);\n }, [router]);\n\n // This effect handles assigning the blockerFunction. This is to handle\n // unstable blocker function identities, and happens only after the prior\n // effect so we don't get an orphaned blockerFunction in the router with a\n // key of \"\". Until then we just have the IDLE_BLOCKER.\n React.useEffect(() => {\n if (blockerKey !== \"\") {\n router.getBlocker(blockerKey, blockerFunction);\n }\n }, [router, blockerKey, blockerFunction]);\n\n // Prefer the blocker from `state` not `router.state` since DataRouterContext\n // is memoized so this ensures we update on blocker state updates\n return blockerKey && state.blockers.has(blockerKey)\n ? state.blockers.get(blockerKey)!\n : IDLE_BLOCKER;\n}\n\n/**\n * Stable version of useNavigate that is used when we are in the context of\n * a RouterProvider.\n */\nfunction useNavigateStable(): NavigateFunction {\n let { router } = useDataRouterContext(DataRouterHook.UseNavigateStable);\n let id = useCurrentRouteId(DataRouterStateHook.UseNavigateStable);\n\n let activeRef = React.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n\n let navigate: NavigateFunction = React.useCallback(\n (to: To | number, options: NavigateOptions = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our router subscriber yet\n if (!activeRef.current) return;\n\n if (typeof to === \"number\") {\n router.navigate(to);\n } else {\n router.navigate(to, { fromRouteId: id, ...options });\n }\n },\n [router, id]\n );\n\n return navigate;\n}\n\nconst alreadyWarned: Record = {};\n\nfunction warningOnce(key: string, cond: boolean, message: string) {\n if (!cond && !alreadyWarned[key]) {\n alreadyWarned[key] = true;\n warning(false, message);\n }\n}\n","import * as React from \"react\";\nimport type {\n TrackedPromise,\n InitialEntry,\n Location,\n MemoryHistory,\n Router as RemixRouter,\n To,\n LazyRouteFunction,\n RelativeRoutingType,\n RouterState,\n} from \"@remix-run/router\";\nimport {\n Action as NavigationType,\n AbortedDeferredError,\n createMemoryHistory,\n UNSAFE_invariant as invariant,\n parsePath,\n resolveTo,\n stripBasename,\n UNSAFE_warning as warning,\n UNSAFE_getPathContributingMatches as getPathContributingMatches,\n} from \"@remix-run/router\";\n\nimport type {\n DataRouteObject,\n IndexRouteObject,\n RouteMatch,\n RouteObject,\n Navigator,\n NonIndexRouteObject,\n} from \"./context\";\nimport {\n LocationContext,\n NavigationContext,\n DataRouterContext,\n DataRouterStateContext,\n AwaitContext,\n RouteContext,\n} from \"./context\";\nimport {\n useAsyncValue,\n useInRouterContext,\n useNavigate,\n useOutlet,\n useRoutes,\n _renderMatches,\n useRoutesImpl,\n useLocation,\n} from \"./hooks\";\n\nexport interface FutureConfig {\n v7_startTransition: boolean;\n}\n\nexport interface RouterProviderProps {\n fallbackElement?: React.ReactNode;\n router: RemixRouter;\n future?: FutureConfig;\n}\n\n/**\n Webpack + React 17 fails to compile on any of the following because webpack\n complains that `startTransition` doesn't exist in `React`:\n * import { startTransition } from \"react\"\n * import * as React from from \"react\";\n \"startTransition\" in React ? React.startTransition(() => setState()) : setState()\n * import * as React from from \"react\";\n \"startTransition\" in React ? React[\"startTransition\"](() => setState()) : setState()\n\n Moving it to a constant such as the following solves the Webpack/React 17 issue:\n * import * as React from from \"react\";\n const START_TRANSITION = \"startTransition\";\n START_TRANSITION in React ? React[START_TRANSITION](() => setState()) : setState()\n\n However, that introduces webpack/terser minification issues in production builds\n in React 18 where minification/obfuscation ends up removing the call of\n React.startTransition entirely from the first half of the ternary. Grabbing\n this exported reference once up front resolves that issue.\n\n See https://github.com/remix-run/react-router/issues/10579\n*/\nconst START_TRANSITION = \"startTransition\";\nconst startTransitionImpl = React[START_TRANSITION];\n\n/**\n * Given a Remix Router instance, render the appropriate UI\n */\nexport function RouterProvider({\n fallbackElement,\n router,\n future,\n}: RouterProviderProps): React.ReactElement {\n // Need to use a layout effect here so we are subscribed early enough to\n // pick up on any render-driven redirects/navigations (useEffect/)\n let [state, setStateImpl] = React.useState(router.state);\n let { v7_startTransition } = future || {};\n let setState = React.useCallback(\n (newState: RouterState) => {\n v7_startTransition && startTransitionImpl\n ? startTransitionImpl(() => setStateImpl(newState))\n : setStateImpl(newState);\n },\n [setStateImpl, v7_startTransition]\n );\n React.useLayoutEffect(() => router.subscribe(setState), [router, setState]);\n\n let navigator = React.useMemo((): Navigator => {\n return {\n createHref: router.createHref,\n encodeLocation: router.encodeLocation,\n go: (n) => router.navigate(n),\n push: (to, state, opts) =>\n router.navigate(to, {\n state,\n preventScrollReset: opts?.preventScrollReset,\n }),\n replace: (to, state, opts) =>\n router.navigate(to, {\n replace: true,\n state,\n preventScrollReset: opts?.preventScrollReset,\n }),\n };\n }, [router]);\n\n let basename = router.basename || \"/\";\n\n let dataRouterContext = React.useMemo(\n () => ({\n router,\n navigator,\n static: false,\n basename,\n }),\n [router, navigator, basename]\n );\n\n // The fragment and {null} here are important! We need them to keep React 18's\n // useId happy when we are server-rendering since we may have a