{"version":3,"file":"file_viewer.js","sources":["../../../svelte/node_modules/svelte/src/runtime/internal/utils.js","../../../svelte/node_modules/svelte/src/runtime/internal/environment.js","../../../svelte/node_modules/svelte/src/runtime/internal/loop.js","../../../svelte/node_modules/svelte/src/runtime/internal/globals.js","../../../svelte/node_modules/svelte/src/runtime/internal/dom.js","../../../svelte/node_modules/svelte/src/runtime/internal/style_manager.js","../../../svelte/node_modules/svelte/src/runtime/internal/lifecycle.js","../../../svelte/node_modules/svelte/src/runtime/internal/animations.js","../../../svelte/node_modules/svelte/src/runtime/internal/scheduler.js","../../../svelte/node_modules/svelte/src/runtime/internal/transitions.js","../../../svelte/node_modules/svelte/src/runtime/internal/each.js","../../../svelte/node_modules/svelte/src/runtime/internal/Component.js","../../../svelte/node_modules/svelte/src/runtime/internal/disclose-version/index.js","../../../svelte/node_modules/svelte/src/shared/version.js","../../../svelte/src/file_viewer/FileUtilities.svelte","../../../svelte/node_modules/svelte/src/runtime/easing/index.js","../../../svelte/node_modules/svelte/src/runtime/transition/index.js","../../../svelte/src/layout/Button.svelte","../../../svelte/src/util/Modal.svelte","../../../svelte/src/util/Formatting.ts","../../../svelte/src/util/Util.svelte","../../../svelte/node_modules/@kurkle/color/dist/color.esm.js","../../../svelte/node_modules/chart.js/dist/chunks/helpers.segment.js","../../../svelte/node_modules/chart.js/dist/chart.js","../../../svelte/src/util/Chart.svelte","../../../svelte/src/file_viewer/DetailsWindow.svelte","../../../svelte/src/util/Spinner.svelte","../../../svelte/src/lib/VideoPosition.ts","../../../svelte/src/layout/TextBlock.svelte","../../../svelte/src/util/ProgressBar.svelte","../../../svelte/node_modules/svelte/src/runtime/store/index.js","../../../svelte/src/lib/StatsSocket.ts","../../../svelte/src/file_viewer/viewers/BandwidthUsage.svelte","../../../svelte/src/layout/IconBlock.svelte","../../../svelte/src/file_viewer/viewers/Video.svelte","../../../svelte/src/layout/FileTitle.svelte","../../../svelte/src/file_viewer/viewers/Audio.svelte","../../../svelte/src/lib/SwipeNavigate.ts","../../../svelte/src/file_viewer/viewers/Image.svelte","../../../svelte/src/file_viewer/viewers/PDF.svelte","../../../svelte/src/file_viewer/viewers/Text.svelte","../../../svelte/src/file_viewer/viewers/File.svelte","../../../svelte/src/file_viewer/viewers/Abuse.svelte","../../../svelte/src/file_viewer/viewers/RateLimit.svelte","../../../svelte/src/icons/Magnet.svelte","../../../svelte/src/file_viewer/viewers/TorrentItem.svelte","../../../svelte/src/layout/CopyButton.svelte","../../../svelte/src/file_viewer/viewers/Torrent.svelte","../../../svelte/src/file_viewer/viewers/ZipItem.svelte","../../../svelte/src/file_viewer/viewers/Zip.svelte","../../../svelte/src/layout/SlowDown.svelte","../../../svelte/src/file_viewer/viewers/FilePreview.svelte","../../../svelte/src/file_viewer/ListNavigator.svelte","../../../svelte/src/file_viewer/FileStats.svelte","../../../svelte/src/file_viewer/EditWindow.svelte","../../../svelte/src/util/ThemePicker.svelte","../../../svelte/src/file_viewer/EmbedWindow.svelte","../../../svelte/src/file_viewer/ReportWindow.svelte","../../../svelte/src/file_viewer/BottomBanner.svelte","../../../svelte/src/file_viewer/Sharebar.svelte","../../../svelte/node_modules/svelte/src/runtime/animate/index.js","../../../svelte/src/user_home/filemanager/DirectoryElement.svelte","../../../svelte/src/file_viewer/FilePicker.svelte","../../../svelte/src/file_viewer/GalleryView.svelte","../../../svelte/src/file_viewer/Downloader.svelte","../../../svelte/src/file_viewer/CustomBanner.svelte","../../../svelte/src/util/LoadingIndicator.svelte","../../../svelte/src/file_viewer/TransferLimit.svelte","../../../svelte/src/file_viewer/ListStats.svelte","../../../svelte/src/util/upload_widget/DropUpload.svelte","../../../svelte/src/util/upload_widget/UploadProgress.svelte","../../../svelte/src/util/upload_widget/UploadFunc.js","../../../svelte/src/util/upload_widget/UploadWidget.svelte","../../../svelte/src/file_viewer/ListUpdater.svelte","../../../svelte/src/util/PixeldrainLogo.svelte","../../../svelte/src/util/Euro.svelte","../../../svelte/src/lib/PixeldrainAPI.ts","../../../svelte/src/lib/UserStore.ts","../../../svelte/src/filesystem/Menu.svelte","../../../svelte/src/user_home/AffiliatePrompt.svelte","../../../svelte/src/file_viewer/FileViewer.svelte","../../../svelte/src/file_viewer.js"],"sourcesContent":["/** @returns {void} */\nexport function noop() {}\n\nexport const identity = (x) => x;\n\n/**\n * @template T\n * @template S\n * @param {T} tar\n * @param {S} src\n * @returns {T & S}\n */\nexport function assign(tar, src) {\n\t// @ts-ignore\n\tfor (const k in src) tar[k] = src[k];\n\treturn /** @type {T & S} */ (tar);\n}\n\n// Adapted from https://github.com/then/is-promise/blob/master/index.js\n// Distributed under MIT License https://github.com/then/is-promise/blob/master/LICENSE\n/**\n * @param {any} value\n * @returns {value is PromiseLike}\n */\nexport function is_promise(value) {\n\treturn (\n\t\t!!value &&\n\t\t(typeof value === 'object' || typeof value === 'function') &&\n\t\ttypeof (/** @type {any} */ (value).then) === 'function'\n\t);\n}\n\n/** @returns {void} */\nexport function add_location(element, file, line, column, char) {\n\telement.__svelte_meta = {\n\t\tloc: { file, line, column, char }\n\t};\n}\n\nexport function run(fn) {\n\treturn fn();\n}\n\nexport function blank_object() {\n\treturn Object.create(null);\n}\n\n/**\n * @param {Function[]} fns\n * @returns {void}\n */\nexport function run_all(fns) {\n\tfns.forEach(run);\n}\n\n/**\n * @param {any} thing\n * @returns {thing is Function}\n */\nexport function is_function(thing) {\n\treturn typeof thing === 'function';\n}\n\n/** @returns {boolean} */\nexport function safe_not_equal(a, b) {\n\treturn a != a ? b == b : a !== b || (a && typeof a === 'object') || typeof a === 'function';\n}\n\nlet src_url_equal_anchor;\n\n/**\n * @param {string} element_src\n * @param {string} url\n * @returns {boolean}\n */\nexport function src_url_equal(element_src, url) {\n\tif (element_src === url) return true;\n\tif (!src_url_equal_anchor) {\n\t\tsrc_url_equal_anchor = document.createElement('a');\n\t}\n\t// This is actually faster than doing URL(..).href\n\tsrc_url_equal_anchor.href = url;\n\treturn element_src === src_url_equal_anchor.href;\n}\n\n/** @param {string} srcset */\nfunction split_srcset(srcset) {\n\treturn srcset.split(',').map((src) => src.trim().split(' ').filter(Boolean));\n}\n\n/**\n * @param {HTMLSourceElement | HTMLImageElement} element_srcset\n * @param {string | undefined | null} srcset\n * @returns {boolean}\n */\nexport function srcset_url_equal(element_srcset, srcset) {\n\tconst element_urls = split_srcset(element_srcset.srcset);\n\tconst urls = split_srcset(srcset || '');\n\n\treturn (\n\t\turls.length === element_urls.length &&\n\t\turls.every(\n\t\t\t([url, width], i) =>\n\t\t\t\twidth === element_urls[i][1] &&\n\t\t\t\t// We need to test both ways because Vite will create an a full URL with\n\t\t\t\t// `new URL(asset, import.meta.url).href` for the client when `base: './'`, and the\n\t\t\t\t// relative URLs inside srcset are not automatically resolved to absolute URLs by\n\t\t\t\t// browsers (in contrast to img.src). This means both SSR and DOM code could\n\t\t\t\t// contain relative or absolute URLs.\n\t\t\t\t(src_url_equal(element_urls[i][0], url) || src_url_equal(url, element_urls[i][0]))\n\t\t)\n\t);\n}\n\n/** @returns {boolean} */\nexport function not_equal(a, b) {\n\treturn a != a ? b == b : a !== b;\n}\n\n/** @returns {boolean} */\nexport function is_empty(obj) {\n\treturn Object.keys(obj).length === 0;\n}\n\n/** @returns {void} */\nexport function validate_store(store, name) {\n\tif (store != null && typeof store.subscribe !== 'function') {\n\t\tthrow new Error(`'${name}' is not a store with a 'subscribe' method`);\n\t}\n}\n\nexport function subscribe(store, ...callbacks) {\n\tif (store == null) {\n\t\tfor (const callback of callbacks) {\n\t\t\tcallback(undefined);\n\t\t}\n\t\treturn noop;\n\t}\n\tconst unsub = store.subscribe(...callbacks);\n\treturn unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;\n}\n\n/**\n * Get the current value from a store by subscribing and immediately unsubscribing.\n *\n * https://svelte.dev/docs/svelte-store#get\n * @template T\n * @param {import('../store/public.js').Readable} store\n * @returns {T}\n */\nexport function get_store_value(store) {\n\tlet value;\n\tsubscribe(store, (_) => (value = _))();\n\treturn value;\n}\n\n/** @returns {void} */\nexport function component_subscribe(component, store, callback) {\n\tcomponent.$$.on_destroy.push(subscribe(store, callback));\n}\n\nexport function create_slot(definition, ctx, $$scope, fn) {\n\tif (definition) {\n\t\tconst slot_ctx = get_slot_context(definition, ctx, $$scope, fn);\n\t\treturn definition[0](slot_ctx);\n\t}\n}\n\nfunction get_slot_context(definition, ctx, $$scope, fn) {\n\treturn definition[1] && fn ? assign($$scope.ctx.slice(), definition[1](fn(ctx))) : $$scope.ctx;\n}\n\nexport function get_slot_changes(definition, $$scope, dirty, fn) {\n\tif (definition[2] && fn) {\n\t\tconst lets = definition[2](fn(dirty));\n\t\tif ($$scope.dirty === undefined) {\n\t\t\treturn lets;\n\t\t}\n\t\tif (typeof lets === 'object') {\n\t\t\tconst merged = [];\n\t\t\tconst len = Math.max($$scope.dirty.length, lets.length);\n\t\t\tfor (let i = 0; i < len; i += 1) {\n\t\t\t\tmerged[i] = $$scope.dirty[i] | lets[i];\n\t\t\t}\n\t\t\treturn merged;\n\t\t}\n\t\treturn $$scope.dirty | lets;\n\t}\n\treturn $$scope.dirty;\n}\n\n/** @returns {void} */\nexport function update_slot_base(\n\tslot,\n\tslot_definition,\n\tctx,\n\t$$scope,\n\tslot_changes,\n\tget_slot_context_fn\n) {\n\tif (slot_changes) {\n\t\tconst slot_context = get_slot_context(slot_definition, ctx, $$scope, get_slot_context_fn);\n\t\tslot.p(slot_context, slot_changes);\n\t}\n}\n\n/** @returns {void} */\nexport function update_slot(\n\tslot,\n\tslot_definition,\n\tctx,\n\t$$scope,\n\tdirty,\n\tget_slot_changes_fn,\n\tget_slot_context_fn\n) {\n\tconst slot_changes = get_slot_changes(slot_definition, $$scope, dirty, get_slot_changes_fn);\n\tupdate_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn);\n}\n\n/** @returns {any[] | -1} */\nexport function get_all_dirty_from_scope($$scope) {\n\tif ($$scope.ctx.length > 32) {\n\t\tconst dirty = [];\n\t\tconst length = $$scope.ctx.length / 32;\n\t\tfor (let i = 0; i < length; i++) {\n\t\t\tdirty[i] = -1;\n\t\t}\n\t\treturn dirty;\n\t}\n\treturn -1;\n}\n\n/** @returns {{}} */\nexport function exclude_internal_props(props) {\n\tconst result = {};\n\tfor (const k in props) if (k[0] !== '$') result[k] = props[k];\n\treturn result;\n}\n\n/** @returns {{}} */\nexport function compute_rest_props(props, keys) {\n\tconst rest = {};\n\tkeys = new Set(keys);\n\tfor (const k in props) if (!keys.has(k) && k[0] !== '$') rest[k] = props[k];\n\treturn rest;\n}\n\n/** @returns {{}} */\nexport function compute_slots(slots) {\n\tconst result = {};\n\tfor (const key in slots) {\n\t\tresult[key] = true;\n\t}\n\treturn result;\n}\n\n/** @returns {(this: any, ...args: any[]) => void} */\nexport function once(fn) {\n\tlet ran = false;\n\treturn function (...args) {\n\t\tif (ran) return;\n\t\tran = true;\n\t\tfn.call(this, ...args);\n\t};\n}\n\nexport function null_to_empty(value) {\n\treturn value == null ? '' : value;\n}\n\nexport function set_store_value(store, ret, value) {\n\tstore.set(value);\n\treturn ret;\n}\n\nexport const has_prop = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\n\nexport function action_destroyer(action_result) {\n\treturn action_result && is_function(action_result.destroy) ? action_result.destroy : noop;\n}\n\n/** @param {number | string} value\n * @returns {[number, string]}\n */\nexport function split_css_unit(value) {\n\tconst split = typeof value === 'string' && value.match(/^\\s*(-?[\\d.]+)([^\\s]*)\\s*$/);\n\treturn split ? [parseFloat(split[1]), split[2] || 'px'] : [/** @type {number} */ (value), 'px'];\n}\n\nexport const contenteditable_truthy_values = ['', true, 1, 'true', 'contenteditable'];\n","import { noop } from './utils.js';\n\nexport const is_client = typeof window !== 'undefined';\n\n/** @type {() => number} */\nexport let now = is_client ? () => window.performance.now() : () => Date.now();\n\nexport let raf = is_client ? (cb) => requestAnimationFrame(cb) : noop;\n\n// used internally for testing\n/** @returns {void} */\nexport function set_now(fn) {\n\tnow = fn;\n}\n\n/** @returns {void} */\nexport function set_raf(fn) {\n\traf = fn;\n}\n","import { raf } from './environment.js';\n\nconst tasks = new Set();\n\n/**\n * @param {number} now\n * @returns {void}\n */\nfunction run_tasks(now) {\n\ttasks.forEach((task) => {\n\t\tif (!task.c(now)) {\n\t\t\ttasks.delete(task);\n\t\t\ttask.f();\n\t\t}\n\t});\n\tif (tasks.size !== 0) raf(run_tasks);\n}\n\n/**\n * For testing purposes only!\n * @returns {void}\n */\nexport function clear_loops() {\n\ttasks.clear();\n}\n\n/**\n * Creates a new task that runs on each raf frame\n * until it returns a falsy value or is aborted\n * @param {import('./private.js').TaskCallback} callback\n * @returns {import('./private.js').Task}\n */\nexport function loop(callback) {\n\t/** @type {import('./private.js').TaskEntry} */\n\tlet task;\n\tif (tasks.size === 0) raf(run_tasks);\n\treturn {\n\t\tpromise: new Promise((fulfill) => {\n\t\t\ttasks.add((task = { c: callback, f: fulfill }));\n\t\t}),\n\t\tabort() {\n\t\t\ttasks.delete(task);\n\t\t}\n\t};\n}\n","/** @type {typeof globalThis} */\nexport const globals =\n\ttypeof window !== 'undefined'\n\t\t? window\n\t\t: typeof globalThis !== 'undefined'\n\t\t? globalThis\n\t\t: // @ts-ignore Node typings have this\n\t\t global;\n","import { contenteditable_truthy_values, has_prop } from './utils.js';\n\nimport { ResizeObserverSingleton } from './ResizeObserverSingleton.js';\n\n// Track which nodes are claimed during hydration. Unclaimed nodes can then be removed from the DOM\n// at the end of hydration without touching the remaining nodes.\nlet is_hydrating = false;\n\n/**\n * @returns {void}\n */\nexport function start_hydrating() {\n\tis_hydrating = true;\n}\n\n/**\n * @returns {void}\n */\nexport function end_hydrating() {\n\tis_hydrating = false;\n}\n\n/**\n * @param {number} low\n * @param {number} high\n * @param {(index: number) => number} key\n * @param {number} value\n * @returns {number}\n */\nfunction upper_bound(low, high, key, value) {\n\t// Return first index of value larger than input value in the range [low, high)\n\twhile (low < high) {\n\t\tconst mid = low + ((high - low) >> 1);\n\t\tif (key(mid) <= value) {\n\t\t\tlow = mid + 1;\n\t\t} else {\n\t\t\thigh = mid;\n\t\t}\n\t}\n\treturn low;\n}\n\n/**\n * @param {NodeEx} target\n * @returns {void}\n */\nfunction init_hydrate(target) {\n\tif (target.hydrate_init) return;\n\ttarget.hydrate_init = true;\n\t// We know that all children have claim_order values since the unclaimed have been detached if target is not \n\n\tlet children = /** @type {ArrayLike} */ (target.childNodes);\n\t// If target is , there may be children without claim_order\n\tif (target.nodeName === 'HEAD') {\n\t\tconst my_children = [];\n\t\tfor (let i = 0; i < children.length; i++) {\n\t\t\tconst node = children[i];\n\t\t\tif (node.claim_order !== undefined) {\n\t\t\t\tmy_children.push(node);\n\t\t\t}\n\t\t}\n\t\tchildren = my_children;\n\t}\n\t/*\n\t * Reorder claimed children optimally.\n\t * We can reorder claimed children optimally by finding the longest subsequence of\n\t * nodes that are already claimed in order and only moving the rest. The longest\n\t * subsequence of nodes that are claimed in order can be found by\n\t * computing the longest increasing subsequence of .claim_order values.\n\t *\n\t * This algorithm is optimal in generating the least amount of reorder operations\n\t * possible.\n\t *\n\t * Proof:\n\t * We know that, given a set of reordering operations, the nodes that do not move\n\t * always form an increasing subsequence, since they do not move among each other\n\t * meaning that they must be already ordered among each other. Thus, the maximal\n\t * set of nodes that do not move form a longest increasing subsequence.\n\t */\n\t// Compute longest increasing subsequence\n\t// m: subsequence length j => index k of smallest value that ends an increasing subsequence of length j\n\tconst m = new Int32Array(children.length + 1);\n\t// Predecessor indices + 1\n\tconst p = new Int32Array(children.length);\n\tm[0] = -1;\n\tlet longest = 0;\n\tfor (let i = 0; i < children.length; i++) {\n\t\tconst current = children[i].claim_order;\n\t\t// Find the largest subsequence length such that it ends in a value less than our current value\n\t\t// upper_bound returns first greater value, so we subtract one\n\t\t// with fast path for when we are on the current longest subsequence\n\t\tconst seq_len =\n\t\t\t(longest > 0 && children[m[longest]].claim_order <= current\n\t\t\t\t? longest + 1\n\t\t\t\t: upper_bound(1, longest, (idx) => children[m[idx]].claim_order, current)) - 1;\n\t\tp[i] = m[seq_len] + 1;\n\t\tconst new_len = seq_len + 1;\n\t\t// We can guarantee that current is the smallest value. Otherwise, we would have generated a longer sequence.\n\t\tm[new_len] = i;\n\t\tlongest = Math.max(new_len, longest);\n\t}\n\t// The longest increasing subsequence of nodes (initially reversed)\n\n\t/**\n\t * @type {NodeEx2[]}\n\t */\n\tconst lis = [];\n\t// The rest of the nodes, nodes that will be moved\n\n\t/**\n\t * @type {NodeEx2[]}\n\t */\n\tconst to_move = [];\n\tlet last = children.length - 1;\n\tfor (let cur = m[longest] + 1; cur != 0; cur = p[cur - 1]) {\n\t\tlis.push(children[cur - 1]);\n\t\tfor (; last >= cur; last--) {\n\t\t\tto_move.push(children[last]);\n\t\t}\n\t\tlast--;\n\t}\n\tfor (; last >= 0; last--) {\n\t\tto_move.push(children[last]);\n\t}\n\tlis.reverse();\n\t// We sort the nodes being moved to guarantee that their insertion order matches the claim order\n\tto_move.sort((a, b) => a.claim_order - b.claim_order);\n\t// Finally, we move the nodes\n\tfor (let i = 0, j = 0; i < to_move.length; i++) {\n\t\twhile (j < lis.length && to_move[i].claim_order >= lis[j].claim_order) {\n\t\t\tj++;\n\t\t}\n\t\tconst anchor = j < lis.length ? lis[j] : null;\n\t\ttarget.insertBefore(to_move[i], anchor);\n\t}\n}\n\n/**\n * @param {Node} target\n * @param {Node} node\n * @returns {void}\n */\nexport function append(target, node) {\n\ttarget.appendChild(node);\n}\n\n/**\n * @param {Node} target\n * @param {string} style_sheet_id\n * @param {string} styles\n * @returns {void}\n */\nexport function append_styles(target, style_sheet_id, styles) {\n\tconst append_styles_to = get_root_for_style(target);\n\tif (!append_styles_to.getElementById(style_sheet_id)) {\n\t\tconst style = element('style');\n\t\tstyle.id = style_sheet_id;\n\t\tstyle.textContent = styles;\n\t\tappend_stylesheet(append_styles_to, style);\n\t}\n}\n\n/**\n * @param {Node} node\n * @returns {ShadowRoot | Document}\n */\nexport function get_root_for_style(node) {\n\tif (!node) return document;\n\tconst root = node.getRootNode ? node.getRootNode() : node.ownerDocument;\n\tif (root && /** @type {ShadowRoot} */ (root).host) {\n\t\treturn /** @type {ShadowRoot} */ (root);\n\t}\n\treturn node.ownerDocument;\n}\n\n/**\n * @param {Node} node\n * @returns {CSSStyleSheet}\n */\nexport function append_empty_stylesheet(node) {\n\tconst style_element = element('style');\n\t// For transitions to work without 'style-src: unsafe-inline' Content Security Policy,\n\t// these empty tags need to be allowed with a hash as a workaround until we move to the Web Animations API.\n\t// Using the hash for the empty string (for an empty tag) works in all browsers except Safari.\n\t// So as a workaround for the workaround, when we append empty style tags we set their content to /* empty */.\n\t// The hash 'sha256-9OlNO0DNEeaVzHL4RZwCLsBHA8WBQ8toBp/4F5XV2nc=' will then work even in Safari.\n\tstyle_element.textContent = '/* empty */';\n\tappend_stylesheet(get_root_for_style(node), style_element);\n\treturn style_element.sheet;\n}\n\n/**\n * @param {ShadowRoot | Document} node\n * @param {HTMLStyleElement} style\n * @returns {CSSStyleSheet}\n */\nfunction append_stylesheet(node, style) {\n\tappend(/** @type {Document} */ (node).head || node, style);\n\treturn style.sheet;\n}\n\n/**\n * @param {NodeEx} target\n * @param {NodeEx} node\n * @returns {void}\n */\nexport function append_hydration(target, node) {\n\tif (is_hydrating) {\n\t\tinit_hydrate(target);\n\t\tif (\n\t\t\ttarget.actual_end_child === undefined ||\n\t\t\t(target.actual_end_child !== null && target.actual_end_child.parentNode !== target)\n\t\t) {\n\t\t\ttarget.actual_end_child = target.firstChild;\n\t\t}\n\t\t// Skip nodes of undefined ordering\n\t\twhile (target.actual_end_child !== null && target.actual_end_child.claim_order === undefined) {\n\t\t\ttarget.actual_end_child = target.actual_end_child.nextSibling;\n\t\t}\n\t\tif (node !== target.actual_end_child) {\n\t\t\t// We only insert if the ordering of this node should be modified or the parent node is not target\n\t\t\tif (node.claim_order !== undefined || node.parentNode !== target) {\n\t\t\t\ttarget.insertBefore(node, target.actual_end_child);\n\t\t\t}\n\t\t} else {\n\t\t\ttarget.actual_end_child = node.nextSibling;\n\t\t}\n\t} else if (node.parentNode !== target || node.nextSibling !== null) {\n\t\ttarget.appendChild(node);\n\t}\n}\n\n/**\n * @param {Node} target\n * @param {Node} node\n * @param {Node} [anchor]\n * @returns {void}\n */\nexport function insert(target, node, anchor) {\n\ttarget.insertBefore(node, anchor || null);\n}\n\n/**\n * @param {NodeEx} target\n * @param {NodeEx} node\n * @param {NodeEx} [anchor]\n * @returns {void}\n */\nexport function insert_hydration(target, node, anchor) {\n\tif (is_hydrating && !anchor) {\n\t\tappend_hydration(target, node);\n\t} else if (node.parentNode !== target || node.nextSibling != anchor) {\n\t\ttarget.insertBefore(node, anchor || null);\n\t}\n}\n\n/**\n * @param {Node} node\n * @returns {void}\n */\nexport function detach(node) {\n\tif (node.parentNode) {\n\t\tnode.parentNode.removeChild(node);\n\t}\n}\n\n/**\n * @returns {void} */\nexport function destroy_each(iterations, detaching) {\n\tfor (let i = 0; i < iterations.length; i += 1) {\n\t\tif (iterations[i]) iterations[i].d(detaching);\n\t}\n}\n\n/**\n * @template {keyof HTMLElementTagNameMap} K\n * @param {K} name\n * @returns {HTMLElementTagNameMap[K]}\n */\nexport function element(name) {\n\treturn document.createElement(name);\n}\n\n/**\n * @template {keyof HTMLElementTagNameMap} K\n * @param {K} name\n * @param {string} is\n * @returns {HTMLElementTagNameMap[K]}\n */\nexport function element_is(name, is) {\n\treturn document.createElement(name, { is });\n}\n\n/**\n * @template T\n * @template {keyof T} K\n * @param {T} obj\n * @param {K[]} exclude\n * @returns {Pick>}\n */\nexport function object_without_properties(obj, exclude) {\n\tconst target = /** @type {Pick>} */ ({});\n\tfor (const k in obj) {\n\t\tif (\n\t\t\thas_prop(obj, k) &&\n\t\t\t// @ts-ignore\n\t\t\texclude.indexOf(k) === -1\n\t\t) {\n\t\t\t// @ts-ignore\n\t\t\ttarget[k] = obj[k];\n\t\t}\n\t}\n\treturn target;\n}\n\n/**\n * @template {keyof SVGElementTagNameMap} K\n * @param {K} name\n * @returns {SVGElement}\n */\nexport function svg_element(name) {\n\treturn document.createElementNS('http://www.w3.org/2000/svg', name);\n}\n\n/**\n * @param {string} data\n * @returns {Text}\n */\nexport function text(data) {\n\treturn document.createTextNode(data);\n}\n\n/**\n * @returns {Text} */\nexport function space() {\n\treturn text(' ');\n}\n\n/**\n * @returns {Text} */\nexport function empty() {\n\treturn text('');\n}\n\n/**\n * @param {string} content\n * @returns {Comment}\n */\nexport function comment(content) {\n\treturn document.createComment(content);\n}\n\n/**\n * @param {EventTarget} node\n * @param {string} event\n * @param {EventListenerOrEventListenerObject} handler\n * @param {boolean | AddEventListenerOptions | EventListenerOptions} [options]\n * @returns {() => void}\n */\nexport function listen(node, event, handler, options) {\n\tnode.addEventListener(event, handler, options);\n\treturn () => node.removeEventListener(event, handler, options);\n}\n\n/**\n * @returns {(event: any) => any} */\nexport function prevent_default(fn) {\n\treturn function (event) {\n\t\tevent.preventDefault();\n\t\t// @ts-ignore\n\t\treturn fn.call(this, event);\n\t};\n}\n\n/**\n * @returns {(event: any) => any} */\nexport function stop_propagation(fn) {\n\treturn function (event) {\n\t\tevent.stopPropagation();\n\t\t// @ts-ignore\n\t\treturn fn.call(this, event);\n\t};\n}\n\n/**\n * @returns {(event: any) => any} */\nexport function stop_immediate_propagation(fn) {\n\treturn function (event) {\n\t\tevent.stopImmediatePropagation();\n\t\t// @ts-ignore\n\t\treturn fn.call(this, event);\n\t};\n}\n\n/**\n * @returns {(event: any) => void} */\nexport function self(fn) {\n\treturn function (event) {\n\t\t// @ts-ignore\n\t\tif (event.target === this) fn.call(this, event);\n\t};\n}\n\n/**\n * @returns {(event: any) => void} */\nexport function trusted(fn) {\n\treturn function (event) {\n\t\t// @ts-ignore\n\t\tif (event.isTrusted) fn.call(this, event);\n\t};\n}\n\n/**\n * @param {Element} node\n * @param {string} attribute\n * @param {string} [value]\n * @returns {void}\n */\nexport function attr(node, attribute, value) {\n\tif (value == null) node.removeAttribute(attribute);\n\telse if (node.getAttribute(attribute) !== value) node.setAttribute(attribute, value);\n}\n/**\n * List of attributes that should always be set through the attr method,\n * because updating them through the property setter doesn't work reliably.\n * In the example of `width`/`height`, the problem is that the setter only\n * accepts numeric values, but the attribute can also be set to a string like `50%`.\n * If this list becomes too big, rethink this approach.\n */\nconst always_set_through_set_attribute = ['width', 'height'];\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {{ [x: string]: string }} attributes\n * @returns {void}\n */\nexport function set_attributes(node, attributes) {\n\t// @ts-ignore\n\tconst descriptors = Object.getOwnPropertyDescriptors(node.__proto__);\n\tfor (const key in attributes) {\n\t\tif (attributes[key] == null) {\n\t\t\tnode.removeAttribute(key);\n\t\t} else if (key === 'style') {\n\t\t\tnode.style.cssText = attributes[key];\n\t\t} else if (key === '__value') {\n\t\t\t/** @type {any} */ (node).value = node[key] = attributes[key];\n\t\t} else if (\n\t\t\tdescriptors[key] &&\n\t\t\tdescriptors[key].set &&\n\t\t\talways_set_through_set_attribute.indexOf(key) === -1\n\t\t) {\n\t\t\tnode[key] = attributes[key];\n\t\t} else {\n\t\t\tattr(node, key, attributes[key]);\n\t\t}\n\t}\n}\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {{ [x: string]: string }} attributes\n * @returns {void}\n */\nexport function set_svg_attributes(node, attributes) {\n\tfor (const key in attributes) {\n\t\tattr(node, key, attributes[key]);\n\t}\n}\n\n/**\n * @param {Record} data_map\n * @returns {void}\n */\nexport function set_custom_element_data_map(node, data_map) {\n\tObject.keys(data_map).forEach((key) => {\n\t\tset_custom_element_data(node, key, data_map[key]);\n\t});\n}\n\n/**\n * @returns {void} */\nexport function set_custom_element_data(node, prop, value) {\n\tconst lower = prop.toLowerCase(); // for backwards compatibility with existing behavior we do lowercase first\n\tif (lower in node) {\n\t\tnode[lower] = typeof node[lower] === 'boolean' && value === '' ? true : value;\n\t} else if (prop in node) {\n\t\tnode[prop] = typeof node[prop] === 'boolean' && value === '' ? true : value;\n\t} else {\n\t\tattr(node, prop, value);\n\t}\n}\n\n/**\n * @param {string} tag\n */\nexport function set_dynamic_element_data(tag) {\n\treturn /-/.test(tag) ? set_custom_element_data_map : set_attributes;\n}\n\n/**\n * @returns {void}\n */\nexport function xlink_attr(node, attribute, value) {\n\tnode.setAttributeNS('http://www.w3.org/1999/xlink', attribute, value);\n}\n\n/**\n * @param {HTMLElement} node\n * @returns {string}\n */\nexport function get_svelte_dataset(node) {\n\treturn node.dataset.svelteH;\n}\n\n/**\n * @returns {unknown[]} */\nexport function get_binding_group_value(group, __value, checked) {\n\tconst value = new Set();\n\tfor (let i = 0; i < group.length; i += 1) {\n\t\tif (group[i].checked) value.add(group[i].__value);\n\t}\n\tif (!checked) {\n\t\tvalue.delete(__value);\n\t}\n\treturn Array.from(value);\n}\n\n/**\n * @param {HTMLInputElement[]} group\n * @returns {{ p(...inputs: HTMLInputElement[]): void; r(): void; }}\n */\nexport function init_binding_group(group) {\n\t/**\n\t * @type {HTMLInputElement[]} */\n\tlet _inputs;\n\treturn {\n\t\t/* push */ p(...inputs) {\n\t\t\t_inputs = inputs;\n\t\t\t_inputs.forEach((input) => group.push(input));\n\t\t},\n\t\t/* remove */ r() {\n\t\t\t_inputs.forEach((input) => group.splice(group.indexOf(input), 1));\n\t\t}\n\t};\n}\n\n/**\n * @param {number[]} indexes\n * @returns {{ u(new_indexes: number[]): void; p(...inputs: HTMLInputElement[]): void; r: () => void; }}\n */\nexport function init_binding_group_dynamic(group, indexes) {\n\t/**\n\t * @type {HTMLInputElement[]} */\n\tlet _group = get_binding_group(group);\n\n\t/**\n\t * @type {HTMLInputElement[]} */\n\tlet _inputs;\n\n\tfunction get_binding_group(group) {\n\t\tfor (let i = 0; i < indexes.length; i++) {\n\t\t\tgroup = group[indexes[i]] = group[indexes[i]] || [];\n\t\t}\n\t\treturn group;\n\t}\n\n\t/**\n\t * @returns {void} */\n\tfunction push() {\n\t\t_inputs.forEach((input) => _group.push(input));\n\t}\n\n\t/**\n\t * @returns {void} */\n\tfunction remove() {\n\t\t_inputs.forEach((input) => _group.splice(_group.indexOf(input), 1));\n\t}\n\treturn {\n\t\t/* update */ u(new_indexes) {\n\t\t\tindexes = new_indexes;\n\t\t\tconst new_group = get_binding_group(group);\n\t\t\tif (new_group !== _group) {\n\t\t\t\tremove();\n\t\t\t\t_group = new_group;\n\t\t\t\tpush();\n\t\t\t}\n\t\t},\n\t\t/* push */ p(...inputs) {\n\t\t\t_inputs = inputs;\n\t\t\tpush();\n\t\t},\n\t\t/* remove */ r: remove\n\t};\n}\n\n/** @returns {number} */\nexport function to_number(value) {\n\treturn value === '' ? null : +value;\n}\n\n/** @returns {any[]} */\nexport function time_ranges_to_array(ranges) {\n\tconst array = [];\n\tfor (let i = 0; i < ranges.length; i += 1) {\n\t\tarray.push({ start: ranges.start(i), end: ranges.end(i) });\n\t}\n\treturn array;\n}\n\n/**\n * @param {Element} element\n * @returns {ChildNode[]}\n */\nexport function children(element) {\n\treturn Array.from(element.childNodes);\n}\n\n/**\n * @param {ChildNodeArray} nodes\n * @returns {void}\n */\nfunction init_claim_info(nodes) {\n\tif (nodes.claim_info === undefined) {\n\t\tnodes.claim_info = { last_index: 0, total_claimed: 0 };\n\t}\n}\n\n/**\n * @template {ChildNodeEx} R\n * @param {ChildNodeArray} nodes\n * @param {(node: ChildNodeEx) => node is R} predicate\n * @param {(node: ChildNodeEx) => ChildNodeEx | undefined} process_node\n * @param {() => R} create_node\n * @param {boolean} dont_update_last_index\n * @returns {R}\n */\nfunction claim_node(nodes, predicate, process_node, create_node, dont_update_last_index = false) {\n\t// Try to find nodes in an order such that we lengthen the longest increasing subsequence\n\tinit_claim_info(nodes);\n\tconst result_node = (() => {\n\t\t// We first try to find an element after the previous one\n\t\tfor (let i = nodes.claim_info.last_index; i < nodes.length; i++) {\n\t\t\tconst node = nodes[i];\n\t\t\tif (predicate(node)) {\n\t\t\t\tconst replacement = process_node(node);\n\t\t\t\tif (replacement === undefined) {\n\t\t\t\t\tnodes.splice(i, 1);\n\t\t\t\t} else {\n\t\t\t\t\tnodes[i] = replacement;\n\t\t\t\t}\n\t\t\t\tif (!dont_update_last_index) {\n\t\t\t\t\tnodes.claim_info.last_index = i;\n\t\t\t\t}\n\t\t\t\treturn node;\n\t\t\t}\n\t\t}\n\t\t// Otherwise, we try to find one before\n\t\t// We iterate in reverse so that we don't go too far back\n\t\tfor (let i = nodes.claim_info.last_index - 1; i >= 0; i--) {\n\t\t\tconst node = nodes[i];\n\t\t\tif (predicate(node)) {\n\t\t\t\tconst replacement = process_node(node);\n\t\t\t\tif (replacement === undefined) {\n\t\t\t\t\tnodes.splice(i, 1);\n\t\t\t\t} else {\n\t\t\t\t\tnodes[i] = replacement;\n\t\t\t\t}\n\t\t\t\tif (!dont_update_last_index) {\n\t\t\t\t\tnodes.claim_info.last_index = i;\n\t\t\t\t} else if (replacement === undefined) {\n\t\t\t\t\t// Since we spliced before the last_index, we decrease it\n\t\t\t\t\tnodes.claim_info.last_index--;\n\t\t\t\t}\n\t\t\t\treturn node;\n\t\t\t}\n\t\t}\n\t\t// If we can't find any matching node, we create a new one\n\t\treturn create_node();\n\t})();\n\tresult_node.claim_order = nodes.claim_info.total_claimed;\n\tnodes.claim_info.total_claimed += 1;\n\treturn result_node;\n}\n\n/**\n * @param {ChildNodeArray} nodes\n * @param {string} name\n * @param {{ [key: string]: boolean }} attributes\n * @param {(name: string) => Element | SVGElement} create_element\n * @returns {Element | SVGElement}\n */\nfunction claim_element_base(nodes, name, attributes, create_element) {\n\treturn claim_node(\n\t\tnodes,\n\t\t/** @returns {node is Element | SVGElement} */\n\t\t(node) => node.nodeName === name,\n\t\t/** @param {Element} node */\n\t\t(node) => {\n\t\t\tconst remove = [];\n\t\t\tfor (let j = 0; j < node.attributes.length; j++) {\n\t\t\t\tconst attribute = node.attributes[j];\n\t\t\t\tif (!attributes[attribute.name]) {\n\t\t\t\t\tremove.push(attribute.name);\n\t\t\t\t}\n\t\t\t}\n\t\t\tremove.forEach((v) => node.removeAttribute(v));\n\t\t\treturn undefined;\n\t\t},\n\t\t() => create_element(name)\n\t);\n}\n\n/**\n * @param {ChildNodeArray} nodes\n * @param {string} name\n * @param {{ [key: string]: boolean }} attributes\n * @returns {Element | SVGElement}\n */\nexport function claim_element(nodes, name, attributes) {\n\treturn claim_element_base(nodes, name, attributes, element);\n}\n\n/**\n * @param {ChildNodeArray} nodes\n * @param {string} name\n * @param {{ [key: string]: boolean }} attributes\n * @returns {Element | SVGElement}\n */\nexport function claim_svg_element(nodes, name, attributes) {\n\treturn claim_element_base(nodes, name, attributes, svg_element);\n}\n\n/**\n * @param {ChildNodeArray} nodes\n * @returns {Text}\n */\nexport function claim_text(nodes, data) {\n\treturn claim_node(\n\t\tnodes,\n\t\t/** @returns {node is Text} */\n\t\t(node) => node.nodeType === 3,\n\t\t/** @param {Text} node */\n\t\t(node) => {\n\t\t\tconst data_str = '' + data;\n\t\t\tif (node.data.startsWith(data_str)) {\n\t\t\t\tif (node.data.length !== data_str.length) {\n\t\t\t\t\treturn node.splitText(data_str.length);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tnode.data = data_str;\n\t\t\t}\n\t\t},\n\t\t() => text(data),\n\t\ttrue // Text nodes should not update last index since it is likely not worth it to eliminate an increasing subsequence of actual elements\n\t);\n}\n\n/**\n * @returns {Text} */\nexport function claim_space(nodes) {\n\treturn claim_text(nodes, ' ');\n}\n\n/**\n * @param {ChildNodeArray} nodes\n * @returns {Comment}\n */\nexport function claim_comment(nodes, data) {\n\treturn claim_node(\n\t\tnodes,\n\t\t/** @returns {node is Comment} */\n\t\t(node) => node.nodeType === 8,\n\t\t/** @param {Comment} node */\n\t\t(node) => {\n\t\t\tnode.data = '' + data;\n\t\t\treturn undefined;\n\t\t},\n\t\t() => comment(data),\n\t\ttrue\n\t);\n}\n\nfunction get_comment_idx(nodes, text, start) {\n\tfor (let i = start; i < nodes.length; i += 1) {\n\t\tconst node = nodes[i];\n\t\tif (node.nodeType === 8 /* comment node */ && node.textContent.trim() === text) {\n\t\t\treturn i;\n\t\t}\n\t}\n\treturn -1;\n}\n\n/**\n * @param {boolean} is_svg\n * @returns {HtmlTagHydration}\n */\nexport function claim_html_tag(nodes, is_svg) {\n\t// find html opening tag\n\tconst start_index = get_comment_idx(nodes, 'HTML_TAG_START', 0);\n\tconst end_index = get_comment_idx(nodes, 'HTML_TAG_END', start_index + 1);\n\tif (start_index === -1 || end_index === -1) {\n\t\treturn new HtmlTagHydration(is_svg);\n\t}\n\n\tinit_claim_info(nodes);\n\tconst html_tag_nodes = nodes.splice(start_index, end_index - start_index + 1);\n\tdetach(html_tag_nodes[0]);\n\tdetach(html_tag_nodes[html_tag_nodes.length - 1]);\n\tconst claimed_nodes = html_tag_nodes.slice(1, html_tag_nodes.length - 1);\n\tif (claimed_nodes.length === 0) {\n\t\treturn new HtmlTagHydration(is_svg);\n\t}\n\tfor (const n of claimed_nodes) {\n\t\tn.claim_order = nodes.claim_info.total_claimed;\n\t\tnodes.claim_info.total_claimed += 1;\n\t}\n\treturn new HtmlTagHydration(is_svg, claimed_nodes);\n}\n\n/**\n * @param {Text} text\n * @param {unknown} data\n * @returns {void}\n */\nexport function set_data(text, data) {\n\tdata = '' + data;\n\tif (text.data === data) return;\n\ttext.data = /** @type {string} */ (data);\n}\n\n/**\n * @param {Text} text\n * @param {unknown} data\n * @returns {void}\n */\nexport function set_data_contenteditable(text, data) {\n\tdata = '' + data;\n\tif (text.wholeText === data) return;\n\ttext.data = /** @type {string} */ (data);\n}\n\n/**\n * @param {Text} text\n * @param {unknown} data\n * @param {string} attr_value\n * @returns {void}\n */\nexport function set_data_maybe_contenteditable(text, data, attr_value) {\n\tif (~contenteditable_truthy_values.indexOf(attr_value)) {\n\t\tset_data_contenteditable(text, data);\n\t} else {\n\t\tset_data(text, data);\n\t}\n}\n\n/**\n * @returns {void} */\nexport function set_input_value(input, value) {\n\tinput.value = value == null ? '' : value;\n}\n\n/**\n * @returns {void} */\nexport function set_input_type(input, type) {\n\ttry {\n\t\tinput.type = type;\n\t} catch (e) {\n\t\t// do nothing\n\t}\n}\n\n/**\n * @returns {void} */\nexport function set_style(node, key, value, important) {\n\tif (value == null) {\n\t\tnode.style.removeProperty(key);\n\t} else {\n\t\tnode.style.setProperty(key, value, important ? 'important' : '');\n\t}\n}\n\n/**\n * @returns {void} */\nexport function select_option(select, value, mounting) {\n\tfor (let i = 0; i < select.options.length; i += 1) {\n\t\tconst option = select.options[i];\n\t\tif (option.__value === value) {\n\t\t\toption.selected = true;\n\t\t\treturn;\n\t\t}\n\t}\n\tif (!mounting || value !== undefined) {\n\t\tselect.selectedIndex = -1; // no option should be selected\n\t}\n}\n\n/**\n * @returns {void} */\nexport function select_options(select, value) {\n\tfor (let i = 0; i < select.options.length; i += 1) {\n\t\tconst option = select.options[i];\n\t\toption.selected = ~value.indexOf(option.__value);\n\t}\n}\n\nexport function select_value(select) {\n\tconst selected_option = select.querySelector(':checked');\n\treturn selected_option && selected_option.__value;\n}\n\nexport function select_multiple_value(select) {\n\treturn [].map.call(select.querySelectorAll(':checked'), (option) => option.__value);\n}\n// unfortunately this can't be a constant as that wouldn't be tree-shakeable\n// so we cache the result instead\n\n/**\n * @type {boolean} */\nlet crossorigin;\n\n/**\n * @returns {boolean} */\nexport function is_crossorigin() {\n\tif (crossorigin === undefined) {\n\t\tcrossorigin = false;\n\t\ttry {\n\t\t\tif (typeof window !== 'undefined' && window.parent) {\n\t\t\t\tvoid window.parent.document;\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tcrossorigin = true;\n\t\t}\n\t}\n\treturn crossorigin;\n}\n\n/**\n * @param {HTMLElement} node\n * @param {() => void} fn\n * @returns {() => void}\n */\nexport function add_iframe_resize_listener(node, fn) {\n\tconst computed_style = getComputedStyle(node);\n\tif (computed_style.position === 'static') {\n\t\tnode.style.position = 'relative';\n\t}\n\tconst iframe = element('iframe');\n\tiframe.setAttribute(\n\t\t'style',\n\t\t'display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; ' +\n\t\t\t'overflow: hidden; border: 0; opacity: 0; pointer-events: none; z-index: -1;'\n\t);\n\tiframe.setAttribute('aria-hidden', 'true');\n\tiframe.tabIndex = -1;\n\tconst crossorigin = is_crossorigin();\n\n\t/**\n\t * @type {() => void}\n\t */\n\tlet unsubscribe;\n\tif (crossorigin) {\n\t\tiframe.src = \"data:text/html,\";\n\t\tunsubscribe = listen(\n\t\t\twindow,\n\t\t\t'message',\n\t\t\t/** @param {MessageEvent} event */ (event) => {\n\t\t\t\tif (event.source === iframe.contentWindow) fn();\n\t\t\t}\n\t\t);\n\t} else {\n\t\tiframe.src = 'about:blank';\n\t\tiframe.onload = () => {\n\t\t\tunsubscribe = listen(iframe.contentWindow, 'resize', fn);\n\t\t\t// make sure an initial resize event is fired _after_ the iframe is loaded (which is asynchronous)\n\t\t\t// see https://github.com/sveltejs/svelte/issues/4233\n\t\t\tfn();\n\t\t};\n\t}\n\tappend(node, iframe);\n\treturn () => {\n\t\tif (crossorigin) {\n\t\t\tunsubscribe();\n\t\t} else if (unsubscribe && iframe.contentWindow) {\n\t\t\tunsubscribe();\n\t\t}\n\t\tdetach(iframe);\n\t};\n}\nexport const resize_observer_content_box = /* @__PURE__ */ new ResizeObserverSingleton({\n\tbox: 'content-box'\n});\nexport const resize_observer_border_box = /* @__PURE__ */ new ResizeObserverSingleton({\n\tbox: 'border-box'\n});\nexport const resize_observer_device_pixel_content_box = /* @__PURE__ */ new ResizeObserverSingleton(\n\t{ box: 'device-pixel-content-box' }\n);\nexport { ResizeObserverSingleton };\n\n/**\n * @returns {void} */\nexport function toggle_class(element, name, toggle) {\n\t// The `!!` is required because an `undefined` flag means flipping the current state.\n\telement.classList.toggle(name, !!toggle);\n}\n\n/**\n * @template T\n * @param {string} type\n * @param {T} [detail]\n * @param {{ bubbles?: boolean, cancelable?: boolean }} [options]\n * @returns {CustomEvent}\n */\nexport function custom_event(type, detail, { bubbles = false, cancelable = false } = {}) {\n\treturn new CustomEvent(type, { detail, bubbles, cancelable });\n}\n\n/**\n * @param {string} selector\n * @param {HTMLElement} parent\n * @returns {ChildNodeArray}\n */\nexport function query_selector_all(selector, parent = document.body) {\n\treturn Array.from(parent.querySelectorAll(selector));\n}\n\n/**\n * @param {string} nodeId\n * @param {HTMLElement} head\n * @returns {any[]}\n */\nexport function head_selector(nodeId, head) {\n\tconst result = [];\n\tlet started = 0;\n\tfor (const node of head.childNodes) {\n\t\tif (node.nodeType === 8 /* comment node */) {\n\t\t\tconst comment = node.textContent.trim();\n\t\t\tif (comment === `HEAD_${nodeId}_END`) {\n\t\t\t\tstarted -= 1;\n\t\t\t\tresult.push(node);\n\t\t\t} else if (comment === `HEAD_${nodeId}_START`) {\n\t\t\t\tstarted += 1;\n\t\t\t\tresult.push(node);\n\t\t\t}\n\t\t} else if (started > 0) {\n\t\t\tresult.push(node);\n\t\t}\n\t}\n\treturn result;\n}\n/** */\nexport class HtmlTag {\n\t/**\n\t * @private\n\t * @default false\n\t */\n\tis_svg = false;\n\t/** parent for creating node */\n\te = undefined;\n\t/** html tag nodes */\n\tn = undefined;\n\t/** target */\n\tt = undefined;\n\t/** anchor */\n\ta = undefined;\n\tconstructor(is_svg = false) {\n\t\tthis.is_svg = is_svg;\n\t\tthis.e = this.n = null;\n\t}\n\n\t/**\n\t * @param {string} html\n\t * @returns {void}\n\t */\n\tc(html) {\n\t\tthis.h(html);\n\t}\n\n\t/**\n\t * @param {string} html\n\t * @param {HTMLElement | SVGElement} target\n\t * @param {HTMLElement | SVGElement} anchor\n\t * @returns {void}\n\t */\n\tm(html, target, anchor = null) {\n\t\tif (!this.e) {\n\t\t\tif (this.is_svg)\n\t\t\t\tthis.e = svg_element(/** @type {keyof SVGElementTagNameMap} */ (target.nodeName));\n\t\t\t/** #7364 target for may be provided as #document-fragment(11) */ else\n\t\t\t\tthis.e = element(\n\t\t\t\t\t/** @type {keyof HTMLElementTagNameMap} */ (\n\t\t\t\t\t\ttarget.nodeType === 11 ? 'TEMPLATE' : target.nodeName\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tthis.t =\n\t\t\t\ttarget.tagName !== 'TEMPLATE'\n\t\t\t\t\t? target\n\t\t\t\t\t: /** @type {HTMLTemplateElement} */ (target).content;\n\t\t\tthis.c(html);\n\t\t}\n\t\tthis.i(anchor);\n\t}\n\n\t/**\n\t * @param {string} html\n\t * @returns {void}\n\t */\n\th(html) {\n\t\tthis.e.innerHTML = html;\n\t\tthis.n = Array.from(\n\t\t\tthis.e.nodeName === 'TEMPLATE' ? this.e.content.childNodes : this.e.childNodes\n\t\t);\n\t}\n\n\t/**\n\t * @returns {void} */\n\ti(anchor) {\n\t\tfor (let i = 0; i < this.n.length; i += 1) {\n\t\t\tinsert(this.t, this.n[i], anchor);\n\t\t}\n\t}\n\n\t/**\n\t * @param {string} html\n\t * @returns {void}\n\t */\n\tp(html) {\n\t\tthis.d();\n\t\tthis.h(html);\n\t\tthis.i(this.a);\n\t}\n\n\t/**\n\t * @returns {void} */\n\td() {\n\t\tthis.n.forEach(detach);\n\t}\n}\n\nexport class HtmlTagHydration extends HtmlTag {\n\t/** @type {Element[]} hydration claimed nodes */\n\tl = undefined;\n\n\tconstructor(is_svg = false, claimed_nodes) {\n\t\tsuper(is_svg);\n\t\tthis.e = this.n = null;\n\t\tthis.l = claimed_nodes;\n\t}\n\n\t/**\n\t * @param {string} html\n\t * @returns {void}\n\t */\n\tc(html) {\n\t\tif (this.l) {\n\t\t\tthis.n = this.l;\n\t\t} else {\n\t\t\tsuper.c(html);\n\t\t}\n\t}\n\n\t/**\n\t * @returns {void} */\n\ti(anchor) {\n\t\tfor (let i = 0; i < this.n.length; i += 1) {\n\t\t\tinsert_hydration(this.t, this.n[i], anchor);\n\t\t}\n\t}\n}\n\n/**\n * @param {NamedNodeMap} attributes\n * @returns {{}}\n */\nexport function attribute_to_object(attributes) {\n\tconst result = {};\n\tfor (const attribute of attributes) {\n\t\tresult[attribute.name] = attribute.value;\n\t}\n\treturn result;\n}\n\nconst escaped = {\n\t'\"': '"',\n\t'&': '&',\n\t'<': '<'\n};\n\nconst regex_attribute_characters_to_escape = /[\"&<]/g;\n\n/**\n * Note that the attribute itself should be surrounded in double quotes\n * @param {any} attribute\n */\nfunction escape_attribute(attribute) {\n\treturn String(attribute).replace(regex_attribute_characters_to_escape, (match) => escaped[match]);\n}\n\n/**\n * @param {Record} attributes\n */\nexport function stringify_spread(attributes) {\n\tlet str = ' ';\n\tfor (const key in attributes) {\n\t\tif (attributes[key] != null) {\n\t\t\tstr += `${key}=\"${escape_attribute(attributes[key])}\" `;\n\t\t}\n\t}\n\n\treturn str;\n}\n\n/**\n * @param {HTMLElement} element\n * @returns {{}}\n */\nexport function get_custom_elements_slots(element) {\n\tconst result = {};\n\telement.childNodes.forEach(\n\t\t/** @param {Element} node */ (node) => {\n\t\t\tresult[node.slot || 'default'] = true;\n\t\t}\n\t);\n\treturn result;\n}\n\nexport function construct_svelte_component(component, props) {\n\treturn new component(props);\n}\n\n/**\n * @typedef {Node & {\n * \tclaim_order?: number;\n * \thydrate_init?: true;\n * \tactual_end_child?: NodeEx;\n * \tchildNodes: NodeListOf;\n * }} NodeEx\n */\n\n/** @typedef {ChildNode & NodeEx} ChildNodeEx */\n\n/** @typedef {NodeEx & { claim_order: number }} NodeEx2 */\n\n/**\n * @typedef {ChildNodeEx[] & {\n * \tclaim_info?: {\n * \t\tlast_index: number;\n * \t\ttotal_claimed: number;\n * \t};\n * }} ChildNodeArray\n */\n","import { append_empty_stylesheet, detach, get_root_for_style } from './dom.js';\nimport { raf } from './environment.js';\n\n// we need to store the information for multiple documents because a Svelte application could also contain iframes\n// https://github.com/sveltejs/svelte/issues/3624\n/** @type {Map} */\nconst managed_styles = new Map();\n\nlet active = 0;\n\n// https://github.com/darkskyapp/string-hash/blob/master/index.js\n/**\n * @param {string} str\n * @returns {number}\n */\nfunction hash(str) {\n\tlet hash = 5381;\n\tlet i = str.length;\n\twhile (i--) hash = ((hash << 5) - hash) ^ str.charCodeAt(i);\n\treturn hash >>> 0;\n}\n\n/**\n * @param {Document | ShadowRoot} doc\n * @param {Element & ElementCSSInlineStyle} node\n * @returns {{ stylesheet: any; rules: {}; }}\n */\nfunction create_style_information(doc, node) {\n\tconst info = { stylesheet: append_empty_stylesheet(node), rules: {} };\n\tmanaged_styles.set(doc, info);\n\treturn info;\n}\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {number} a\n * @param {number} b\n * @param {number} duration\n * @param {number} delay\n * @param {(t: number) => number} ease\n * @param {(t: number, u: number) => string} fn\n * @param {number} uid\n * @returns {string}\n */\nexport function create_rule(node, a, b, duration, delay, ease, fn, uid = 0) {\n\tconst step = 16.666 / duration;\n\tlet keyframes = '{\\n';\n\tfor (let p = 0; p <= 1; p += step) {\n\t\tconst t = a + (b - a) * ease(p);\n\t\tkeyframes += p * 100 + `%{${fn(t, 1 - t)}}\\n`;\n\t}\n\tconst rule = keyframes + `100% {${fn(b, 1 - b)}}\\n}`;\n\tconst name = `__svelte_${hash(rule)}_${uid}`;\n\tconst doc = get_root_for_style(node);\n\tconst { stylesheet, rules } = managed_styles.get(doc) || create_style_information(doc, node);\n\tif (!rules[name]) {\n\t\trules[name] = true;\n\t\tstylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);\n\t}\n\tconst animation = node.style.animation || '';\n\tnode.style.animation = `${\n\t\tanimation ? `${animation}, ` : ''\n\t}${name} ${duration}ms linear ${delay}ms 1 both`;\n\tactive += 1;\n\treturn name;\n}\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {string} [name]\n * @returns {void}\n */\nexport function delete_rule(node, name) {\n\tconst previous = (node.style.animation || '').split(', ');\n\tconst next = previous.filter(\n\t\tname\n\t\t\t? (anim) => anim.indexOf(name) < 0 // remove specific animation\n\t\t\t: (anim) => anim.indexOf('__svelte') === -1 // remove all Svelte animations\n\t);\n\tconst deleted = previous.length - next.length;\n\tif (deleted) {\n\t\tnode.style.animation = next.join(', ');\n\t\tactive -= deleted;\n\t\tif (!active) clear_rules();\n\t}\n}\n\n/** @returns {void} */\nexport function clear_rules() {\n\traf(() => {\n\t\tif (active) return;\n\t\tmanaged_styles.forEach((info) => {\n\t\t\tconst { ownerNode } = info.stylesheet;\n\t\t\t// there is no ownerNode if it runs on jsdom.\n\t\t\tif (ownerNode) detach(ownerNode);\n\t\t});\n\t\tmanaged_styles.clear();\n\t});\n}\n","import { custom_event } from './dom.js';\n\nexport let current_component;\n\n/** @returns {void} */\nexport function set_current_component(component) {\n\tcurrent_component = component;\n}\n\nexport function get_current_component() {\n\tif (!current_component) throw new Error('Function called outside component initialization');\n\treturn current_component;\n}\n\n/**\n * Schedules a callback to run immediately before the component is updated after any state change.\n *\n * The first time the callback runs will be before the initial `onMount`\n *\n * https://svelte.dev/docs/svelte#beforeupdate\n * @param {() => any} fn\n * @returns {void}\n */\nexport function beforeUpdate(fn) {\n\tget_current_component().$$.before_update.push(fn);\n}\n\n/**\n * The `onMount` function schedules a callback to run as soon as the component has been mounted to the DOM.\n * It must be called during the component's initialisation (but doesn't need to live *inside* the component;\n * it can be called from an external module).\n *\n * If a function is returned _synchronously_ from `onMount`, it will be called when the component is unmounted.\n *\n * `onMount` does not run inside a [server-side component](https://svelte.dev/docs#run-time-server-side-component-api).\n *\n * https://svelte.dev/docs/svelte#onmount\n * @template T\n * @param {() => import('./private.js').NotFunction | Promise> | (() => any)} fn\n * @returns {void}\n */\nexport function onMount(fn) {\n\tget_current_component().$$.on_mount.push(fn);\n}\n\n/**\n * Schedules a callback to run immediately after the component has been updated.\n *\n * The first time the callback runs will be after the initial `onMount`\n *\n * https://svelte.dev/docs/svelte#afterupdate\n * @param {() => any} fn\n * @returns {void}\n */\nexport function afterUpdate(fn) {\n\tget_current_component().$$.after_update.push(fn);\n}\n\n/**\n * Schedules a callback to run immediately before the component is unmounted.\n *\n * Out of `onMount`, `beforeUpdate`, `afterUpdate` and `onDestroy`, this is the\n * only one that runs inside a server-side component.\n *\n * https://svelte.dev/docs/svelte#ondestroy\n * @param {() => any} fn\n * @returns {void}\n */\nexport function onDestroy(fn) {\n\tget_current_component().$$.on_destroy.push(fn);\n}\n\n/**\n * Creates an event dispatcher that can be used to dispatch [component events](https://svelte.dev/docs#template-syntax-component-directives-on-eventname).\n * Event dispatchers are functions that can take two arguments: `name` and `detail`.\n *\n * Component events created with `createEventDispatcher` create a\n * [CustomEvent](https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent).\n * These events do not [bubble](https://developer.mozilla.org/en-US/docs/Learn/JavaScript/Building_blocks/Events#Event_bubbling_and_capture).\n * The `detail` argument corresponds to the [CustomEvent.detail](https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent/detail)\n * property and can contain any type of data.\n *\n * The event dispatcher can be typed to narrow the allowed event names and the type of the `detail` argument:\n * ```ts\n * const dispatch = createEventDispatcher<{\n * loaded: never; // does not take a detail argument\n * change: string; // takes a detail argument of type string, which is required\n * optional: number | null; // takes an optional detail argument of type number\n * }>();\n * ```\n *\n * https://svelte.dev/docs/svelte#createeventdispatcher\n * @template {Record} [EventMap=any]\n * @returns {import('./public.js').EventDispatcher}\n */\nexport function createEventDispatcher() {\n\tconst component = get_current_component();\n\treturn (type, detail, { cancelable = false } = {}) => {\n\t\tconst callbacks = component.$$.callbacks[type];\n\t\tif (callbacks) {\n\t\t\t// TODO are there situations where events could be dispatched\n\t\t\t// in a server (non-DOM) environment?\n\t\t\tconst event = custom_event(/** @type {string} */ (type), detail, { cancelable });\n\t\t\tcallbacks.slice().forEach((fn) => {\n\t\t\t\tfn.call(component, event);\n\t\t\t});\n\t\t\treturn !event.defaultPrevented;\n\t\t}\n\t\treturn true;\n\t};\n}\n\n/**\n * Associates an arbitrary `context` object with the current component and the specified `key`\n * and returns that object. The context is then available to children of the component\n * (including slotted content) with `getContext`.\n *\n * Like lifecycle functions, this must be called during component initialisation.\n *\n * https://svelte.dev/docs/svelte#setcontext\n * @template T\n * @param {any} key\n * @param {T} context\n * @returns {T}\n */\nexport function setContext(key, context) {\n\tget_current_component().$$.context.set(key, context);\n\treturn context;\n}\n\n/**\n * Retrieves the context that belongs to the closest parent component with the specified `key`.\n * Must be called during component initialisation.\n *\n * https://svelte.dev/docs/svelte#getcontext\n * @template T\n * @param {any} key\n * @returns {T}\n */\nexport function getContext(key) {\n\treturn get_current_component().$$.context.get(key);\n}\n\n/**\n * Retrieves the whole context map that belongs to the closest parent component.\n * Must be called during component initialisation. Useful, for example, if you\n * programmatically create a component and want to pass the existing context to it.\n *\n * https://svelte.dev/docs/svelte#getallcontexts\n * @template {Map} [T=Map]\n * @returns {T}\n */\nexport function getAllContexts() {\n\treturn get_current_component().$$.context;\n}\n\n/**\n * Checks whether a given `key` has been set in the context of a parent component.\n * Must be called during component initialisation.\n *\n * https://svelte.dev/docs/svelte#hascontext\n * @param {any} key\n * @returns {boolean}\n */\nexport function hasContext(key) {\n\treturn get_current_component().$$.context.has(key);\n}\n\n// TODO figure out if we still want to support\n// shorthand events, or if we want to implement\n// a real bubbling mechanism\n/**\n * @param component\n * @param event\n * @returns {void}\n */\nexport function bubble(component, event) {\n\tconst callbacks = component.$$.callbacks[event.type];\n\tif (callbacks) {\n\t\t// @ts-ignore\n\t\tcallbacks.slice().forEach((fn) => fn.call(this, event));\n\t}\n}\n","import { identity as linear, noop } from './utils.js';\nimport { now } from './environment.js';\nimport { loop } from './loop.js';\nimport { create_rule, delete_rule } from './style_manager.js';\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {import('./private.js').PositionRect} from\n * @param {import('./private.js').AnimationFn} fn\n */\nexport function create_animation(node, from, fn, params) {\n\tif (!from) return noop;\n\tconst to = node.getBoundingClientRect();\n\tif (\n\t\tfrom.left === to.left &&\n\t\tfrom.right === to.right &&\n\t\tfrom.top === to.top &&\n\t\tfrom.bottom === to.bottom\n\t)\n\t\treturn noop;\n\tconst {\n\t\tdelay = 0,\n\t\tduration = 300,\n\t\teasing = linear,\n\t\t// @ts-ignore todo: should this be separated from destructuring? Or start/end added to public api and documentation?\n\t\tstart: start_time = now() + delay,\n\t\t// @ts-ignore todo:\n\t\tend = start_time + duration,\n\t\ttick = noop,\n\t\tcss\n\t} = fn(node, { from, to }, params);\n\tlet running = true;\n\tlet started = false;\n\tlet name;\n\t/** @returns {void} */\n\tfunction start() {\n\t\tif (css) {\n\t\t\tname = create_rule(node, 0, 1, duration, delay, easing, css);\n\t\t}\n\t\tif (!delay) {\n\t\t\tstarted = true;\n\t\t}\n\t}\n\t/** @returns {void} */\n\tfunction stop() {\n\t\tif (css) delete_rule(node, name);\n\t\trunning = false;\n\t}\n\tloop((now) => {\n\t\tif (!started && now >= start_time) {\n\t\t\tstarted = true;\n\t\t}\n\t\tif (started && now >= end) {\n\t\t\ttick(1, 0);\n\t\t\tstop();\n\t\t}\n\t\tif (!running) {\n\t\t\treturn false;\n\t\t}\n\t\tif (started) {\n\t\t\tconst p = now - start_time;\n\t\t\tconst t = 0 + 1 * easing(p / duration);\n\t\t\ttick(t, 1 - t);\n\t\t}\n\t\treturn true;\n\t});\n\tstart();\n\ttick(0, 1);\n\treturn stop;\n}\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @returns {void}\n */\nexport function fix_position(node) {\n\tconst style = getComputedStyle(node);\n\tif (style.position !== 'absolute' && style.position !== 'fixed') {\n\t\tconst { width, height } = style;\n\t\tconst a = node.getBoundingClientRect();\n\t\tnode.style.position = 'absolute';\n\t\tnode.style.width = width;\n\t\tnode.style.height = height;\n\t\tadd_transform(node, a);\n\t}\n}\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {import('./private.js').PositionRect} a\n * @returns {void}\n */\nexport function add_transform(node, a) {\n\tconst b = node.getBoundingClientRect();\n\tif (a.left !== b.left || a.top !== b.top) {\n\t\tconst style = getComputedStyle(node);\n\t\tconst transform = style.transform === 'none' ? '' : style.transform;\n\t\tnode.style.transform = `${transform} translate(${a.left - b.left}px, ${a.top - b.top}px)`;\n\t}\n}\n","import { run_all } from './utils.js';\nimport { current_component, set_current_component } from './lifecycle.js';\n\nexport const dirty_components = [];\nexport const intros = { enabled: false };\nexport const binding_callbacks = [];\n\nlet render_callbacks = [];\n\nconst flush_callbacks = [];\n\nconst resolved_promise = /* @__PURE__ */ Promise.resolve();\n\nlet update_scheduled = false;\n\n/** @returns {void} */\nexport function schedule_update() {\n\tif (!update_scheduled) {\n\t\tupdate_scheduled = true;\n\t\tresolved_promise.then(flush);\n\t}\n}\n\n/** @returns {Promise} */\nexport function tick() {\n\tschedule_update();\n\treturn resolved_promise;\n}\n\n/** @returns {void} */\nexport function add_render_callback(fn) {\n\trender_callbacks.push(fn);\n}\n\n/** @returns {void} */\nexport function add_flush_callback(fn) {\n\tflush_callbacks.push(fn);\n}\n\n// flush() calls callbacks in this order:\n// 1. All beforeUpdate callbacks, in order: parents before children\n// 2. All bind:this callbacks, in reverse order: children before parents.\n// 3. All afterUpdate callbacks, in order: parents before children. EXCEPT\n// for afterUpdates called during the initial onMount, which are called in\n// reverse order: children before parents.\n// Since callbacks might update component values, which could trigger another\n// call to flush(), the following steps guard against this:\n// 1. During beforeUpdate, any updated components will be added to the\n// dirty_components array and will cause a reentrant call to flush(). Because\n// the flush index is kept outside the function, the reentrant call will pick\n// up where the earlier call left off and go through all dirty components. The\n// current_component value is saved and restored so that the reentrant call will\n// not interfere with the \"parent\" flush() call.\n// 2. bind:this callbacks cannot trigger new flush() calls.\n// 3. During afterUpdate, any updated components will NOT have their afterUpdate\n// callback called a second time; the seen_callbacks set, outside the flush()\n// function, guarantees this behavior.\nconst seen_callbacks = new Set();\n\nlet flushidx = 0; // Do *not* move this inside the flush() function\n\n/** @returns {void} */\nexport function flush() {\n\t// Do not reenter flush while dirty components are updated, as this can\n\t// result in an infinite loop. Instead, let the inner flush handle it.\n\t// Reentrancy is ok afterwards for bindings etc.\n\tif (flushidx !== 0) {\n\t\treturn;\n\t}\n\tconst saved_component = current_component;\n\tdo {\n\t\t// first, call beforeUpdate functions\n\t\t// and update components\n\t\ttry {\n\t\t\twhile (flushidx < dirty_components.length) {\n\t\t\t\tconst component = dirty_components[flushidx];\n\t\t\t\tflushidx++;\n\t\t\t\tset_current_component(component);\n\t\t\t\tupdate(component.$$);\n\t\t\t}\n\t\t} catch (e) {\n\t\t\t// reset dirty state to not end up in a deadlocked state and then rethrow\n\t\t\tdirty_components.length = 0;\n\t\t\tflushidx = 0;\n\t\t\tthrow e;\n\t\t}\n\t\tset_current_component(null);\n\t\tdirty_components.length = 0;\n\t\tflushidx = 0;\n\t\twhile (binding_callbacks.length) binding_callbacks.pop()();\n\t\t// then, once components are updated, call\n\t\t// afterUpdate functions. This may cause\n\t\t// subsequent updates...\n\t\tfor (let i = 0; i < render_callbacks.length; i += 1) {\n\t\t\tconst callback = render_callbacks[i];\n\t\t\tif (!seen_callbacks.has(callback)) {\n\t\t\t\t// ...so guard against infinite loops\n\t\t\t\tseen_callbacks.add(callback);\n\t\t\t\tcallback();\n\t\t\t}\n\t\t}\n\t\trender_callbacks.length = 0;\n\t} while (dirty_components.length);\n\twhile (flush_callbacks.length) {\n\t\tflush_callbacks.pop()();\n\t}\n\tupdate_scheduled = false;\n\tseen_callbacks.clear();\n\tset_current_component(saved_component);\n}\n\n/** @returns {void} */\nfunction update($$) {\n\tif ($$.fragment !== null) {\n\t\t$$.update();\n\t\trun_all($$.before_update);\n\t\tconst dirty = $$.dirty;\n\t\t$$.dirty = [-1];\n\t\t$$.fragment && $$.fragment.p($$.ctx, dirty);\n\t\t$$.after_update.forEach(add_render_callback);\n\t}\n}\n\n/**\n * Useful for example to execute remaining `afterUpdate` callbacks before executing `destroy`.\n * @param {Function[]} fns\n * @returns {void}\n */\nexport function flush_render_callbacks(fns) {\n\tconst filtered = [];\n\tconst targets = [];\n\trender_callbacks.forEach((c) => (fns.indexOf(c) === -1 ? filtered.push(c) : targets.push(c)));\n\ttargets.forEach((c) => c());\n\trender_callbacks = filtered;\n}\n","import { identity as linear, is_function, noop, run_all } from './utils.js';\nimport { now } from './environment.js';\nimport { loop } from './loop.js';\nimport { create_rule, delete_rule } from './style_manager.js';\nimport { custom_event } from './dom.js';\nimport { add_render_callback } from './scheduler.js';\n\n/**\n * @type {Promise | null}\n */\nlet promise;\n\n/**\n * @returns {Promise}\n */\nfunction wait() {\n\tif (!promise) {\n\t\tpromise = Promise.resolve();\n\t\tpromise.then(() => {\n\t\t\tpromise = null;\n\t\t});\n\t}\n\treturn promise;\n}\n\n/**\n * @param {Element} node\n * @param {INTRO | OUTRO | boolean} direction\n * @param {'start' | 'end'} kind\n * @returns {void}\n */\nfunction dispatch(node, direction, kind) {\n\tnode.dispatchEvent(custom_event(`${direction ? 'intro' : 'outro'}${kind}`));\n}\n\nconst outroing = new Set();\n\n/**\n * @type {Outro}\n */\nlet outros;\n\n/**\n * @returns {void} */\nexport function group_outros() {\n\toutros = {\n\t\tr: 0,\n\t\tc: [],\n\t\tp: outros // parent group\n\t};\n}\n\n/**\n * @returns {void} */\nexport function check_outros() {\n\tif (!outros.r) {\n\t\trun_all(outros.c);\n\t}\n\toutros = outros.p;\n}\n\n/**\n * @param {import('./private.js').Fragment} block\n * @param {0 | 1} [local]\n * @returns {void}\n */\nexport function transition_in(block, local) {\n\tif (block && block.i) {\n\t\toutroing.delete(block);\n\t\tblock.i(local);\n\t}\n}\n\n/**\n * @param {import('./private.js').Fragment} block\n * @param {0 | 1} local\n * @param {0 | 1} [detach]\n * @param {() => void} [callback]\n * @returns {void}\n */\nexport function transition_out(block, local, detach, callback) {\n\tif (block && block.o) {\n\t\tif (outroing.has(block)) return;\n\t\toutroing.add(block);\n\t\toutros.c.push(() => {\n\t\t\toutroing.delete(block);\n\t\t\tif (callback) {\n\t\t\t\tif (detach) block.d(1);\n\t\t\t\tcallback();\n\t\t\t}\n\t\t});\n\t\tblock.o(local);\n\t} else if (callback) {\n\t\tcallback();\n\t}\n}\n\n/**\n * @type {import('../transition/public.js').TransitionConfig}\n */\nconst null_transition = { duration: 0 };\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {TransitionFn} fn\n * @param {any} params\n * @returns {{ start(): void; invalidate(): void; end(): void; }}\n */\nexport function create_in_transition(node, fn, params) {\n\t/**\n\t * @type {TransitionOptions} */\n\tconst options = { direction: 'in' };\n\tlet config = fn(node, params, options);\n\tlet running = false;\n\tlet animation_name;\n\tlet task;\n\tlet uid = 0;\n\n\t/**\n\t * @returns {void} */\n\tfunction cleanup() {\n\t\tif (animation_name) delete_rule(node, animation_name);\n\t}\n\n\t/**\n\t * @returns {void} */\n\tfunction go() {\n\t\tconst {\n\t\t\tdelay = 0,\n\t\t\tduration = 300,\n\t\t\teasing = linear,\n\t\t\ttick = noop,\n\t\t\tcss\n\t\t} = config || null_transition;\n\t\tif (css) animation_name = create_rule(node, 0, 1, duration, delay, easing, css, uid++);\n\t\ttick(0, 1);\n\t\tconst start_time = now() + delay;\n\t\tconst end_time = start_time + duration;\n\t\tif (task) task.abort();\n\t\trunning = true;\n\t\tadd_render_callback(() => dispatch(node, true, 'start'));\n\t\ttask = loop((now) => {\n\t\t\tif (running) {\n\t\t\t\tif (now >= end_time) {\n\t\t\t\t\ttick(1, 0);\n\t\t\t\t\tdispatch(node, true, 'end');\n\t\t\t\t\tcleanup();\n\t\t\t\t\treturn (running = false);\n\t\t\t\t}\n\t\t\t\tif (now >= start_time) {\n\t\t\t\t\tconst t = easing((now - start_time) / duration);\n\t\t\t\t\ttick(t, 1 - t);\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn running;\n\t\t});\n\t}\n\tlet started = false;\n\treturn {\n\t\tstart() {\n\t\t\tif (started) return;\n\t\t\tstarted = true;\n\t\t\tdelete_rule(node);\n\t\t\tif (is_function(config)) {\n\t\t\t\tconfig = config(options);\n\t\t\t\twait().then(go);\n\t\t\t} else {\n\t\t\t\tgo();\n\t\t\t}\n\t\t},\n\t\tinvalidate() {\n\t\t\tstarted = false;\n\t\t},\n\t\tend() {\n\t\t\tif (running) {\n\t\t\t\tcleanup();\n\t\t\t\trunning = false;\n\t\t\t}\n\t\t}\n\t};\n}\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {TransitionFn} fn\n * @param {any} params\n * @returns {{ end(reset: any): void; }}\n */\nexport function create_out_transition(node, fn, params) {\n\t/** @type {TransitionOptions} */\n\tconst options = { direction: 'out' };\n\tlet config = fn(node, params, options);\n\tlet running = true;\n\tlet animation_name;\n\tconst group = outros;\n\tgroup.r += 1;\n\t/** @type {boolean} */\n\tlet original_inert_value;\n\n\t/**\n\t * @returns {void} */\n\tfunction go() {\n\t\tconst {\n\t\t\tdelay = 0,\n\t\t\tduration = 300,\n\t\t\teasing = linear,\n\t\t\ttick = noop,\n\t\t\tcss\n\t\t} = config || null_transition;\n\n\t\tif (css) animation_name = create_rule(node, 1, 0, duration, delay, easing, css);\n\n\t\tconst start_time = now() + delay;\n\t\tconst end_time = start_time + duration;\n\t\tadd_render_callback(() => dispatch(node, false, 'start'));\n\n\t\tif ('inert' in node) {\n\t\t\toriginal_inert_value = /** @type {HTMLElement} */ (node).inert;\n\t\t\tnode.inert = true;\n\t\t}\n\n\t\tloop((now) => {\n\t\t\tif (running) {\n\t\t\t\tif (now >= end_time) {\n\t\t\t\t\ttick(0, 1);\n\t\t\t\t\tdispatch(node, false, 'end');\n\t\t\t\t\tif (!--group.r) {\n\t\t\t\t\t\t// this will result in `end()` being called,\n\t\t\t\t\t\t// so we don't need to clean up here\n\t\t\t\t\t\trun_all(group.c);\n\t\t\t\t\t}\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\tif (now >= start_time) {\n\t\t\t\t\tconst t = easing((now - start_time) / duration);\n\t\t\t\t\ttick(1 - t, t);\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn running;\n\t\t});\n\t}\n\n\tif (is_function(config)) {\n\t\twait().then(() => {\n\t\t\t// @ts-ignore\n\t\t\tconfig = config(options);\n\t\t\tgo();\n\t\t});\n\t} else {\n\t\tgo();\n\t}\n\n\treturn {\n\t\tend(reset) {\n\t\t\tif (reset && 'inert' in node) {\n\t\t\t\tnode.inert = original_inert_value;\n\t\t\t}\n\t\t\tif (reset && config.tick) {\n\t\t\t\tconfig.tick(1, 0);\n\t\t\t}\n\t\t\tif (running) {\n\t\t\t\tif (animation_name) delete_rule(node, animation_name);\n\t\t\t\trunning = false;\n\t\t\t}\n\t\t}\n\t};\n}\n\n/**\n * @param {Element & ElementCSSInlineStyle} node\n * @param {TransitionFn} fn\n * @param {any} params\n * @param {boolean} intro\n * @returns {{ run(b: 0 | 1): void; end(): void; }}\n */\nexport function create_bidirectional_transition(node, fn, params, intro) {\n\t/**\n\t * @type {TransitionOptions} */\n\tconst options = { direction: 'both' };\n\tlet config = fn(node, params, options);\n\tlet t = intro ? 0 : 1;\n\n\t/**\n\t * @type {Program | null} */\n\tlet running_program = null;\n\n\t/**\n\t * @type {PendingProgram | null} */\n\tlet pending_program = null;\n\tlet animation_name = null;\n\n\t/** @type {boolean} */\n\tlet original_inert_value;\n\n\t/**\n\t * @returns {void} */\n\tfunction clear_animation() {\n\t\tif (animation_name) delete_rule(node, animation_name);\n\t}\n\n\t/**\n\t * @param {PendingProgram} program\n\t * @param {number} duration\n\t * @returns {Program}\n\t */\n\tfunction init(program, duration) {\n\t\tconst d = /** @type {Program['d']} */ (program.b - t);\n\t\tduration *= Math.abs(d);\n\t\treturn {\n\t\t\ta: t,\n\t\t\tb: program.b,\n\t\t\td,\n\t\t\tduration,\n\t\t\tstart: program.start,\n\t\t\tend: program.start + duration,\n\t\t\tgroup: program.group\n\t\t};\n\t}\n\n\t/**\n\t * @param {INTRO | OUTRO} b\n\t * @returns {void}\n\t */\n\tfunction go(b) {\n\t\tconst {\n\t\t\tdelay = 0,\n\t\t\tduration = 300,\n\t\t\teasing = linear,\n\t\t\ttick = noop,\n\t\t\tcss\n\t\t} = config || null_transition;\n\n\t\t/**\n\t\t * @type {PendingProgram} */\n\t\tconst program = {\n\t\t\tstart: now() + delay,\n\t\t\tb\n\t\t};\n\n\t\tif (!b) {\n\t\t\t// @ts-ignore todo: improve typings\n\t\t\tprogram.group = outros;\n\t\t\toutros.r += 1;\n\t\t}\n\n\t\tif ('inert' in node) {\n\t\t\tif (b) {\n\t\t\t\tif (original_inert_value !== undefined) {\n\t\t\t\t\t// aborted/reversed outro — restore previous inert value\n\t\t\t\t\tnode.inert = original_inert_value;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\toriginal_inert_value = /** @type {HTMLElement} */ (node).inert;\n\t\t\t\tnode.inert = true;\n\t\t\t}\n\t\t}\n\n\t\tif (running_program || pending_program) {\n\t\t\tpending_program = program;\n\t\t} else {\n\t\t\t// if this is an intro, and there's a delay, we need to do\n\t\t\t// an initial tick and/or apply CSS animation immediately\n\t\t\tif (css) {\n\t\t\t\tclear_animation();\n\t\t\t\tanimation_name = create_rule(node, t, b, duration, delay, easing, css);\n\t\t\t}\n\t\t\tif (b) tick(0, 1);\n\t\t\trunning_program = init(program, duration);\n\t\t\tadd_render_callback(() => dispatch(node, b, 'start'));\n\t\t\tloop((now) => {\n\t\t\t\tif (pending_program && now > pending_program.start) {\n\t\t\t\t\trunning_program = init(pending_program, duration);\n\t\t\t\t\tpending_program = null;\n\t\t\t\t\tdispatch(node, running_program.b, 'start');\n\t\t\t\t\tif (css) {\n\t\t\t\t\t\tclear_animation();\n\t\t\t\t\t\tanimation_name = create_rule(\n\t\t\t\t\t\t\tnode,\n\t\t\t\t\t\t\tt,\n\t\t\t\t\t\t\trunning_program.b,\n\t\t\t\t\t\t\trunning_program.duration,\n\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\teasing,\n\t\t\t\t\t\t\tconfig.css\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (running_program) {\n\t\t\t\t\tif (now >= running_program.end) {\n\t\t\t\t\t\ttick((t = running_program.b), 1 - t);\n\t\t\t\t\t\tdispatch(node, running_program.b, 'end');\n\t\t\t\t\t\tif (!pending_program) {\n\t\t\t\t\t\t\t// we're done\n\t\t\t\t\t\t\tif (running_program.b) {\n\t\t\t\t\t\t\t\t// intro — we can tidy up immediately\n\t\t\t\t\t\t\t\tclear_animation();\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t// outro — needs to be coordinated\n\t\t\t\t\t\t\t\tif (!--running_program.group.r) run_all(running_program.group.c);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\trunning_program = null;\n\t\t\t\t\t} else if (now >= running_program.start) {\n\t\t\t\t\t\tconst p = now - running_program.start;\n\t\t\t\t\t\tt = running_program.a + running_program.d * easing(p / running_program.duration);\n\t\t\t\t\t\ttick(t, 1 - t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn !!(running_program || pending_program);\n\t\t\t});\n\t\t}\n\t}\n\treturn {\n\t\trun(b) {\n\t\t\tif (is_function(config)) {\n\t\t\t\twait().then(() => {\n\t\t\t\t\tconst opts = { direction: b ? 'in' : 'out' };\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\tconfig = config(opts);\n\t\t\t\t\tgo(b);\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tgo(b);\n\t\t\t}\n\t\t},\n\t\tend() {\n\t\t\tclear_animation();\n\t\t\trunning_program = pending_program = null;\n\t\t}\n\t};\n}\n\n/** @typedef {1} INTRO */\n/** @typedef {0} OUTRO */\n/** @typedef {{ direction: 'in' | 'out' | 'both' }} TransitionOptions */\n/** @typedef {(node: Element, params: any, options: TransitionOptions) => import('../transition/public.js').TransitionConfig} TransitionFn */\n\n/**\n * @typedef {Object} Outro\n * @property {number} r\n * @property {Function[]} c\n * @property {Object} p\n */\n\n/**\n * @typedef {Object} PendingProgram\n * @property {number} start\n * @property {INTRO|OUTRO} b\n * @property {Outro} [group]\n */\n\n/**\n * @typedef {Object} Program\n * @property {number} a\n * @property {INTRO|OUTRO} b\n * @property {1|-1} d\n * @property {number} duration\n * @property {number} start\n * @property {number} end\n * @property {Outro} [group]\n */\n","import { transition_in, transition_out } from './transitions.js';\nimport { run_all } from './utils.js';\n\n// general each functions:\n\nexport function ensure_array_like(array_like_or_iterator) {\n\treturn array_like_or_iterator?.length !== undefined\n\t\t? array_like_or_iterator\n\t\t: Array.from(array_like_or_iterator);\n}\n\n// keyed each functions:\n\n/** @returns {void} */\nexport function destroy_block(block, lookup) {\n\tblock.d(1);\n\tlookup.delete(block.key);\n}\n\n/** @returns {void} */\nexport function outro_and_destroy_block(block, lookup) {\n\ttransition_out(block, 1, 1, () => {\n\t\tlookup.delete(block.key);\n\t});\n}\n\n/** @returns {void} */\nexport function fix_and_destroy_block(block, lookup) {\n\tblock.f();\n\tdestroy_block(block, lookup);\n}\n\n/** @returns {void} */\nexport function fix_and_outro_and_destroy_block(block, lookup) {\n\tblock.f();\n\toutro_and_destroy_block(block, lookup);\n}\n\n/** @returns {any[]} */\nexport function update_keyed_each(\n\told_blocks,\n\tdirty,\n\tget_key,\n\tdynamic,\n\tctx,\n\tlist,\n\tlookup,\n\tnode,\n\tdestroy,\n\tcreate_each_block,\n\tnext,\n\tget_context\n) {\n\tlet o = old_blocks.length;\n\tlet n = list.length;\n\tlet i = o;\n\tconst old_indexes = {};\n\twhile (i--) old_indexes[old_blocks[i].key] = i;\n\tconst new_blocks = [];\n\tconst new_lookup = new Map();\n\tconst deltas = new Map();\n\tconst updates = [];\n\ti = n;\n\twhile (i--) {\n\t\tconst child_ctx = get_context(ctx, list, i);\n\t\tconst key = get_key(child_ctx);\n\t\tlet block = lookup.get(key);\n\t\tif (!block) {\n\t\t\tblock = create_each_block(key, child_ctx);\n\t\t\tblock.c();\n\t\t} else if (dynamic) {\n\t\t\t// defer updates until all the DOM shuffling is done\n\t\t\tupdates.push(() => block.p(child_ctx, dirty));\n\t\t}\n\t\tnew_lookup.set(key, (new_blocks[i] = block));\n\t\tif (key in old_indexes) deltas.set(key, Math.abs(i - old_indexes[key]));\n\t}\n\tconst will_move = new Set();\n\tconst did_move = new Set();\n\t/** @returns {void} */\n\tfunction insert(block) {\n\t\ttransition_in(block, 1);\n\t\tblock.m(node, next);\n\t\tlookup.set(block.key, block);\n\t\tnext = block.first;\n\t\tn--;\n\t}\n\twhile (o && n) {\n\t\tconst new_block = new_blocks[n - 1];\n\t\tconst old_block = old_blocks[o - 1];\n\t\tconst new_key = new_block.key;\n\t\tconst old_key = old_block.key;\n\t\tif (new_block === old_block) {\n\t\t\t// do nothing\n\t\t\tnext = new_block.first;\n\t\t\to--;\n\t\t\tn--;\n\t\t} else if (!new_lookup.has(old_key)) {\n\t\t\t// remove old block\n\t\t\tdestroy(old_block, lookup);\n\t\t\to--;\n\t\t} else if (!lookup.has(new_key) || will_move.has(new_key)) {\n\t\t\tinsert(new_block);\n\t\t} else if (did_move.has(old_key)) {\n\t\t\to--;\n\t\t} else if (deltas.get(new_key) > deltas.get(old_key)) {\n\t\t\tdid_move.add(new_key);\n\t\t\tinsert(new_block);\n\t\t} else {\n\t\t\twill_move.add(old_key);\n\t\t\to--;\n\t\t}\n\t}\n\twhile (o--) {\n\t\tconst old_block = old_blocks[o];\n\t\tif (!new_lookup.has(old_block.key)) destroy(old_block, lookup);\n\t}\n\twhile (n) insert(new_blocks[n - 1]);\n\trun_all(updates);\n\treturn new_blocks;\n}\n\n/** @returns {void} */\nexport function validate_each_keys(ctx, list, get_context, get_key) {\n\tconst keys = new Map();\n\tfor (let i = 0; i < list.length; i++) {\n\t\tconst key = get_key(get_context(ctx, list, i));\n\t\tif (keys.has(key)) {\n\t\t\tlet value = '';\n\t\t\ttry {\n\t\t\t\tvalue = `with value '${String(key)}' `;\n\t\t\t} catch (e) {\n\t\t\t\t// can't stringify\n\t\t\t}\n\t\t\tthrow new Error(\n\t\t\t\t`Cannot have duplicate keys in a keyed each: Keys at index ${keys.get(\n\t\t\t\t\tkey\n\t\t\t\t)} and ${i} ${value}are duplicates`\n\t\t\t);\n\t\t}\n\t\tkeys.set(key, i);\n\t}\n}\n","import {\n\tadd_render_callback,\n\tflush,\n\tflush_render_callbacks,\n\tschedule_update,\n\tdirty_components\n} from './scheduler.js';\nimport { current_component, set_current_component } from './lifecycle.js';\nimport { blank_object, is_empty, is_function, run, run_all, noop } from './utils.js';\nimport {\n\tchildren,\n\tdetach,\n\tstart_hydrating,\n\tend_hydrating,\n\tget_custom_elements_slots,\n\tinsert,\n\telement,\n\tattr\n} from './dom.js';\nimport { transition_in } from './transitions.js';\n\n/** @returns {void} */\nexport function bind(component, name, callback) {\n\tconst index = component.$$.props[name];\n\tif (index !== undefined) {\n\t\tcomponent.$$.bound[index] = callback;\n\t\tcallback(component.$$.ctx[index]);\n\t}\n}\n\n/** @returns {void} */\nexport function create_component(block) {\n\tblock && block.c();\n}\n\n/** @returns {void} */\nexport function claim_component(block, parent_nodes) {\n\tblock && block.l(parent_nodes);\n}\n\n/** @returns {void} */\nexport function mount_component(component, target, anchor) {\n\tconst { fragment, after_update } = component.$$;\n\tfragment && fragment.m(target, anchor);\n\t// onMount happens before the initial afterUpdate\n\tadd_render_callback(() => {\n\t\tconst new_on_destroy = component.$$.on_mount.map(run).filter(is_function);\n\t\t// if the component was destroyed immediately\n\t\t// it will update the `$$.on_destroy` reference to `null`.\n\t\t// the destructured on_destroy may still reference to the old array\n\t\tif (component.$$.on_destroy) {\n\t\t\tcomponent.$$.on_destroy.push(...new_on_destroy);\n\t\t} else {\n\t\t\t// Edge case - component was destroyed immediately,\n\t\t\t// most likely as a result of a binding initialising\n\t\t\trun_all(new_on_destroy);\n\t\t}\n\t\tcomponent.$$.on_mount = [];\n\t});\n\tafter_update.forEach(add_render_callback);\n}\n\n/** @returns {void} */\nexport function destroy_component(component, detaching) {\n\tconst $$ = component.$$;\n\tif ($$.fragment !== null) {\n\t\tflush_render_callbacks($$.after_update);\n\t\trun_all($$.on_destroy);\n\t\t$$.fragment && $$.fragment.d(detaching);\n\t\t// TODO null out other refs, including component.$$ (but need to\n\t\t// preserve final state?)\n\t\t$$.on_destroy = $$.fragment = null;\n\t\t$$.ctx = [];\n\t}\n}\n\n/** @returns {void} */\nfunction make_dirty(component, i) {\n\tif (component.$$.dirty[0] === -1) {\n\t\tdirty_components.push(component);\n\t\tschedule_update();\n\t\tcomponent.$$.dirty.fill(0);\n\t}\n\tcomponent.$$.dirty[(i / 31) | 0] |= 1 << i % 31;\n}\n\n// TODO: Document the other params\n/**\n * @param {SvelteComponent} component\n * @param {import('./public.js').ComponentConstructorOptions} options\n *\n * @param {import('./utils.js')['not_equal']} not_equal Used to compare props and state values.\n * @param {(target: Element | ShadowRoot) => void} [append_styles] Function that appends styles to the DOM when the component is first initialised.\n * This will be the `add_css` function from the compiled component.\n *\n * @returns {void}\n */\nexport function init(\n\tcomponent,\n\toptions,\n\tinstance,\n\tcreate_fragment,\n\tnot_equal,\n\tprops,\n\tappend_styles = null,\n\tdirty = [-1]\n) {\n\tconst parent_component = current_component;\n\tset_current_component(component);\n\t/** @type {import('./private.js').T$$} */\n\tconst $$ = (component.$$ = {\n\t\tfragment: null,\n\t\tctx: [],\n\t\t// state\n\t\tprops,\n\t\tupdate: noop,\n\t\tnot_equal,\n\t\tbound: blank_object(),\n\t\t// lifecycle\n\t\ton_mount: [],\n\t\ton_destroy: [],\n\t\ton_disconnect: [],\n\t\tbefore_update: [],\n\t\tafter_update: [],\n\t\tcontext: new Map(options.context || (parent_component ? parent_component.$$.context : [])),\n\t\t// everything else\n\t\tcallbacks: blank_object(),\n\t\tdirty,\n\t\tskip_bound: false,\n\t\troot: options.target || parent_component.$$.root\n\t});\n\tappend_styles && append_styles($$.root);\n\tlet ready = false;\n\t$$.ctx = instance\n\t\t? instance(component, options.props || {}, (i, ret, ...rest) => {\n\t\t\t\tconst value = rest.length ? rest[0] : ret;\n\t\t\t\tif ($$.ctx && not_equal($$.ctx[i], ($$.ctx[i] = value))) {\n\t\t\t\t\tif (!$$.skip_bound && $$.bound[i]) $$.bound[i](value);\n\t\t\t\t\tif (ready) make_dirty(component, i);\n\t\t\t\t}\n\t\t\t\treturn ret;\n\t\t })\n\t\t: [];\n\t$$.update();\n\tready = true;\n\trun_all($$.before_update);\n\t// `false` as a special case of no DOM component\n\t$$.fragment = create_fragment ? create_fragment($$.ctx) : false;\n\tif (options.target) {\n\t\tif (options.hydrate) {\n\t\t\tstart_hydrating();\n\t\t\t// TODO: what is the correct type here?\n\t\t\t// @ts-expect-error\n\t\t\tconst nodes = children(options.target);\n\t\t\t$$.fragment && $$.fragment.l(nodes);\n\t\t\tnodes.forEach(detach);\n\t\t} else {\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\t\t\t$$.fragment && $$.fragment.c();\n\t\t}\n\t\tif (options.intro) transition_in(component.$$.fragment);\n\t\tmount_component(component, options.target, options.anchor);\n\t\tend_hydrating();\n\t\tflush();\n\t}\n\tset_current_component(parent_component);\n}\n\nexport let SvelteElement;\n\nif (typeof HTMLElement === 'function') {\n\tSvelteElement = class extends HTMLElement {\n\t\t/** The Svelte component constructor */\n\t\t$$ctor;\n\t\t/** Slots */\n\t\t$$s;\n\t\t/** The Svelte component instance */\n\t\t$$c;\n\t\t/** Whether or not the custom element is connected */\n\t\t$$cn = false;\n\t\t/** Component props data */\n\t\t$$d = {};\n\t\t/** `true` if currently in the process of reflecting component props back to attributes */\n\t\t$$r = false;\n\t\t/** @type {Record} Props definition (name, reflected, type etc) */\n\t\t$$p_d = {};\n\t\t/** @type {Record} Event listeners */\n\t\t$$l = {};\n\t\t/** @type {Map} Event listener unsubscribe functions */\n\t\t$$l_u = new Map();\n\n\t\tconstructor($$componentCtor, $$slots, use_shadow_dom) {\n\t\t\tsuper();\n\t\t\tthis.$$ctor = $$componentCtor;\n\t\t\tthis.$$s = $$slots;\n\t\t\tif (use_shadow_dom) {\n\t\t\t\tthis.attachShadow({ mode: 'open' });\n\t\t\t}\n\t\t}\n\n\t\taddEventListener(type, listener, options) {\n\t\t\t// We can't determine upfront if the event is a custom event or not, so we have to\n\t\t\t// listen to both. If someone uses a custom event with the same name as a regular\n\t\t\t// browser event, this fires twice - we can't avoid that.\n\t\t\tthis.$$l[type] = this.$$l[type] || [];\n\t\t\tthis.$$l[type].push(listener);\n\t\t\tif (this.$$c) {\n\t\t\t\tconst unsub = this.$$c.$on(type, listener);\n\t\t\t\tthis.$$l_u.set(listener, unsub);\n\t\t\t}\n\t\t\tsuper.addEventListener(type, listener, options);\n\t\t}\n\n\t\tremoveEventListener(type, listener, options) {\n\t\t\tsuper.removeEventListener(type, listener, options);\n\t\t\tif (this.$$c) {\n\t\t\t\tconst unsub = this.$$l_u.get(listener);\n\t\t\t\tif (unsub) {\n\t\t\t\t\tunsub();\n\t\t\t\t\tthis.$$l_u.delete(listener);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tasync connectedCallback() {\n\t\t\tthis.$$cn = true;\n\t\t\tif (!this.$$c) {\n\t\t\t\t// We wait one tick to let possible child slot elements be created/mounted\n\t\t\t\tawait Promise.resolve();\n\t\t\t\tif (!this.$$cn || this.$$c) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tfunction create_slot(name) {\n\t\t\t\t\treturn () => {\n\t\t\t\t\t\tlet node;\n\t\t\t\t\t\tconst obj = {\n\t\t\t\t\t\t\tc: function create() {\n\t\t\t\t\t\t\t\tnode = element('slot');\n\t\t\t\t\t\t\t\tif (name !== 'default') {\n\t\t\t\t\t\t\t\t\tattr(node, 'name', name);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t/**\n\t\t\t\t\t\t\t * @param {HTMLElement} target\n\t\t\t\t\t\t\t * @param {HTMLElement} [anchor]\n\t\t\t\t\t\t\t */\n\t\t\t\t\t\t\tm: function mount(target, anchor) {\n\t\t\t\t\t\t\t\tinsert(target, node, anchor);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\td: function destroy(detaching) {\n\t\t\t\t\t\t\t\tif (detaching) {\n\t\t\t\t\t\t\t\t\tdetach(node);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\t\t\t\t\t\treturn obj;\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tconst $$slots = {};\n\t\t\t\tconst existing_slots = get_custom_elements_slots(this);\n\t\t\t\tfor (const name of this.$$s) {\n\t\t\t\t\tif (name in existing_slots) {\n\t\t\t\t\t\t$$slots[name] = [create_slot(name)];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tfor (const attribute of this.attributes) {\n\t\t\t\t\t// this.$$data takes precedence over this.attributes\n\t\t\t\t\tconst name = this.$$g_p(attribute.name);\n\t\t\t\t\tif (!(name in this.$$d)) {\n\t\t\t\t\t\tthis.$$d[name] = get_custom_element_value(name, attribute.value, this.$$p_d, 'toProp');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// Port over props that were set programmatically before ce was initialized\n\t\t\t\tfor (const key in this.$$p_d) {\n\t\t\t\t\tif (!(key in this.$$d) && this[key] !== undefined) {\n\t\t\t\t\t\tthis.$$d[key] = this[key]; // don't transform, these were set through JavaScript\n\t\t\t\t\t\tdelete this[key]; // remove the property that shadows the getter/setter\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tthis.$$c = new this.$$ctor({\n\t\t\t\t\ttarget: this.shadowRoot || this,\n\t\t\t\t\tprops: {\n\t\t\t\t\t\t...this.$$d,\n\t\t\t\t\t\t$$slots,\n\t\t\t\t\t\t$$scope: {\n\t\t\t\t\t\t\tctx: []\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\t// Reflect component props as attributes\n\t\t\t\tconst reflect_attributes = () => {\n\t\t\t\t\tthis.$$r = true;\n\t\t\t\t\tfor (const key in this.$$p_d) {\n\t\t\t\t\t\tthis.$$d[key] = this.$$c.$$.ctx[this.$$c.$$.props[key]];\n\t\t\t\t\t\tif (this.$$p_d[key].reflect) {\n\t\t\t\t\t\t\tconst attribute_value = get_custom_element_value(\n\t\t\t\t\t\t\t\tkey,\n\t\t\t\t\t\t\t\tthis.$$d[key],\n\t\t\t\t\t\t\t\tthis.$$p_d,\n\t\t\t\t\t\t\t\t'toAttribute'\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tif (attribute_value == null) {\n\t\t\t\t\t\t\t\tthis.removeAttribute(this.$$p_d[key].attribute || key);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.setAttribute(this.$$p_d[key].attribute || key, attribute_value);\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\tthis.$$r = false;\n\t\t\t\t};\n\t\t\t\tthis.$$c.$$.after_update.push(reflect_attributes);\n\t\t\t\treflect_attributes(); // once initially because after_update is added too late for first render\n\n\t\t\t\tfor (const type in this.$$l) {\n\t\t\t\t\tfor (const listener of this.$$l[type]) {\n\t\t\t\t\t\tconst unsub = this.$$c.$on(type, listener);\n\t\t\t\t\t\tthis.$$l_u.set(listener, unsub);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tthis.$$l = {};\n\t\t\t}\n\t\t}\n\n\t\t// We don't need this when working within Svelte code, but for compatibility of people using this outside of Svelte\n\t\t// and setting attributes through setAttribute etc, this is helpful\n\t\tattributeChangedCallback(attr, _oldValue, newValue) {\n\t\t\tif (this.$$r) return;\n\t\t\tattr = this.$$g_p(attr);\n\t\t\tthis.$$d[attr] = get_custom_element_value(attr, newValue, this.$$p_d, 'toProp');\n\t\t\tthis.$$c?.$set({ [attr]: this.$$d[attr] });\n\t\t}\n\n\t\tdisconnectedCallback() {\n\t\t\tthis.$$cn = false;\n\t\t\t// In a microtask, because this could be a move within the DOM\n\t\t\tPromise.resolve().then(() => {\n\t\t\t\tif (!this.$$cn && this.$$c) {\n\t\t\t\t\tthis.$$c.$destroy();\n\t\t\t\t\tthis.$$c = undefined;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\t$$g_p(attribute_name) {\n\t\t\treturn (\n\t\t\t\tObject.keys(this.$$p_d).find(\n\t\t\t\t\t(key) =>\n\t\t\t\t\t\tthis.$$p_d[key].attribute === attribute_name ||\n\t\t\t\t\t\t(!this.$$p_d[key].attribute && key.toLowerCase() === attribute_name)\n\t\t\t\t) || attribute_name\n\t\t\t);\n\t\t}\n\t};\n}\n\n/**\n * @param {string} prop\n * @param {any} value\n * @param {Record} props_definition\n * @param {'toAttribute' | 'toProp'} [transform]\n */\nfunction get_custom_element_value(prop, value, props_definition, transform) {\n\tconst type = props_definition[prop]?.type;\n\tvalue = type === 'Boolean' && typeof value !== 'boolean' ? value != null : value;\n\tif (!transform || !props_definition[prop]) {\n\t\treturn value;\n\t} else if (transform === 'toAttribute') {\n\t\tswitch (type) {\n\t\t\tcase 'Object':\n\t\t\tcase 'Array':\n\t\t\t\treturn value == null ? null : JSON.stringify(value);\n\t\t\tcase 'Boolean':\n\t\t\t\treturn value ? '' : null;\n\t\t\tcase 'Number':\n\t\t\t\treturn value == null ? null : value;\n\t\t\tdefault:\n\t\t\t\treturn value;\n\t\t}\n\t} else {\n\t\tswitch (type) {\n\t\t\tcase 'Object':\n\t\t\tcase 'Array':\n\t\t\t\treturn value && JSON.parse(value);\n\t\t\tcase 'Boolean':\n\t\t\t\treturn value; // conversion already handled above\n\t\t\tcase 'Number':\n\t\t\t\treturn value != null ? +value : value;\n\t\t\tdefault:\n\t\t\t\treturn value;\n\t\t}\n\t}\n}\n\n/**\n * @internal\n *\n * Turn a Svelte component into a custom element.\n * @param {import('./public.js').ComponentType} Component A Svelte component constructor\n * @param {Record} props_definition The props to observe\n * @param {string[]} slots The slots to create\n * @param {string[]} accessors Other accessors besides the ones for props the component has\n * @param {boolean} use_shadow_dom Whether to use shadow DOM\n * @param {(ce: new () => HTMLElement) => new () => HTMLElement} [extend]\n */\nexport function create_custom_element(\n\tComponent,\n\tprops_definition,\n\tslots,\n\taccessors,\n\tuse_shadow_dom,\n\textend\n) {\n\tlet Class = class extends SvelteElement {\n\t\tconstructor() {\n\t\t\tsuper(Component, slots, use_shadow_dom);\n\t\t\tthis.$$p_d = props_definition;\n\t\t}\n\t\tstatic get observedAttributes() {\n\t\t\treturn Object.keys(props_definition).map((key) =>\n\t\t\t\t(props_definition[key].attribute || key).toLowerCase()\n\t\t\t);\n\t\t}\n\t};\n\tObject.keys(props_definition).forEach((prop) => {\n\t\tObject.defineProperty(Class.prototype, prop, {\n\t\t\tget() {\n\t\t\t\treturn this.$$c && prop in this.$$c ? this.$$c[prop] : this.$$d[prop];\n\t\t\t},\n\t\t\tset(value) {\n\t\t\t\tvalue = get_custom_element_value(prop, value, props_definition);\n\t\t\t\tthis.$$d[prop] = value;\n\t\t\t\tthis.$$c?.$set({ [prop]: value });\n\t\t\t}\n\t\t});\n\t});\n\taccessors.forEach((accessor) => {\n\t\tObject.defineProperty(Class.prototype, accessor, {\n\t\t\tget() {\n\t\t\t\treturn this.$$c?.[accessor];\n\t\t\t}\n\t\t});\n\t});\n\tif (extend) {\n\t\t// @ts-expect-error - assigning here is fine\n\t\tClass = extend(Class);\n\t}\n\tComponent.element = /** @type {any} */ (Class);\n\treturn Class;\n}\n\n/**\n * Base class for Svelte components. Used when dev=false.\n *\n * @template {Record} [Props=any]\n * @template {Record} [Events=any]\n */\nexport class SvelteComponent {\n\t/**\n\t * ### PRIVATE API\n\t *\n\t * Do not use, may change at any time\n\t *\n\t * @type {any}\n\t */\n\t$$ = undefined;\n\t/**\n\t * ### PRIVATE API\n\t *\n\t * Do not use, may change at any time\n\t *\n\t * @type {any}\n\t */\n\t$$set = undefined;\n\n\t/** @returns {void} */\n\t$destroy() {\n\t\tdestroy_component(this, 1);\n\t\tthis.$destroy = noop;\n\t}\n\n\t/**\n\t * @template {Extract} K\n\t * @param {K} type\n\t * @param {((e: Events[K]) => void) | null | undefined} callback\n\t * @returns {() => void}\n\t */\n\t$on(type, callback) {\n\t\tif (!is_function(callback)) {\n\t\t\treturn noop;\n\t\t}\n\t\tconst callbacks = this.$$.callbacks[type] || (this.$$.callbacks[type] = []);\n\t\tcallbacks.push(callback);\n\t\treturn () => {\n\t\t\tconst index = callbacks.indexOf(callback);\n\t\t\tif (index !== -1) callbacks.splice(index, 1);\n\t\t};\n\t}\n\n\t/**\n\t * @param {Partial} props\n\t * @returns {void}\n\t */\n\t$set(props) {\n\t\tif (this.$$set && !is_empty(props)) {\n\t\t\tthis.$$.skip_bound = true;\n\t\t\tthis.$$set(props);\n\t\t\tthis.$$.skip_bound = false;\n\t\t}\n\t}\n}\n\n/**\n * @typedef {Object} CustomElementPropDefinition\n * @property {string} [attribute]\n * @property {boolean} [reflect]\n * @property {'String'|'Boolean'|'Number'|'Array'|'Object'} [type]\n */\n","import { PUBLIC_VERSION } from '../../../shared/version.js';\n\nif (typeof window !== 'undefined')\n\t// @ts-ignore\n\t(window.__svelte || (window.__svelte = { v: new Set() })).v.add(PUBLIC_VERSION);\n","// generated during release, do not modify\n\n/**\n * The current version, as set in package.json.\n *\n * https://svelte.dev/docs/svelte-compiler#svelte-version\n * @type {string}\n */\nexport const VERSION = '4.2.19';\nexport const PUBLIC_VERSION = '4';\n","\n","/*\nAdapted from https://github.com/mattdesl\nDistributed under MIT License https://github.com/mattdesl/eases/blob/master/LICENSE.md\n*/\nexport { identity as linear } from '../internal/index.js';\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function backInOut(t) {\n\tconst s = 1.70158 * 1.525;\n\tif ((t *= 2) < 1) return 0.5 * (t * t * ((s + 1) * t - s));\n\treturn 0.5 * ((t -= 2) * t * ((s + 1) * t + s) + 2);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function backIn(t) {\n\tconst s = 1.70158;\n\treturn t * t * ((s + 1) * t - s);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function backOut(t) {\n\tconst s = 1.70158;\n\treturn --t * t * ((s + 1) * t + s) + 1;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function bounceOut(t) {\n\tconst a = 4.0 / 11.0;\n\tconst b = 8.0 / 11.0;\n\tconst c = 9.0 / 10.0;\n\tconst ca = 4356.0 / 361.0;\n\tconst cb = 35442.0 / 1805.0;\n\tconst cc = 16061.0 / 1805.0;\n\tconst t2 = t * t;\n\treturn t < a\n\t\t? 7.5625 * t2\n\t\t: t < b\n\t\t? 9.075 * t2 - 9.9 * t + 3.4\n\t\t: t < c\n\t\t? ca * t2 - cb * t + cc\n\t\t: 10.8 * t * t - 20.52 * t + 10.72;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function bounceInOut(t) {\n\treturn t < 0.5 ? 0.5 * (1.0 - bounceOut(1.0 - t * 2.0)) : 0.5 * bounceOut(t * 2.0 - 1.0) + 0.5;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function bounceIn(t) {\n\treturn 1.0 - bounceOut(1.0 - t);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function circInOut(t) {\n\tif ((t *= 2) < 1) return -0.5 * (Math.sqrt(1 - t * t) - 1);\n\treturn 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function circIn(t) {\n\treturn 1.0 - Math.sqrt(1.0 - t * t);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function circOut(t) {\n\treturn Math.sqrt(1 - --t * t);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function cubicInOut(t) {\n\treturn t < 0.5 ? 4.0 * t * t * t : 0.5 * Math.pow(2.0 * t - 2.0, 3.0) + 1.0;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function cubicIn(t) {\n\treturn t * t * t;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function cubicOut(t) {\n\tconst f = t - 1.0;\n\treturn f * f * f + 1.0;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function elasticInOut(t) {\n\treturn t < 0.5\n\t\t? 0.5 * Math.sin(((+13.0 * Math.PI) / 2) * 2.0 * t) * Math.pow(2.0, 10.0 * (2.0 * t - 1.0))\n\t\t: 0.5 *\n\t\t\t\tMath.sin(((-13.0 * Math.PI) / 2) * (2.0 * t - 1.0 + 1.0)) *\n\t\t\t\tMath.pow(2.0, -10.0 * (2.0 * t - 1.0)) +\n\t\t\t\t1.0;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function elasticIn(t) {\n\treturn Math.sin((13.0 * t * Math.PI) / 2) * Math.pow(2.0, 10.0 * (t - 1.0));\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function elasticOut(t) {\n\treturn Math.sin((-13.0 * (t + 1.0) * Math.PI) / 2) * Math.pow(2.0, -10.0 * t) + 1.0;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function expoInOut(t) {\n\treturn t === 0.0 || t === 1.0\n\t\t? t\n\t\t: t < 0.5\n\t\t? +0.5 * Math.pow(2.0, 20.0 * t - 10.0)\n\t\t: -0.5 * Math.pow(2.0, 10.0 - t * 20.0) + 1.0;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function expoIn(t) {\n\treturn t === 0.0 ? t : Math.pow(2.0, 10.0 * (t - 1.0));\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function expoOut(t) {\n\treturn t === 1.0 ? t : 1.0 - Math.pow(2.0, -10.0 * t);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quadInOut(t) {\n\tt /= 0.5;\n\tif (t < 1) return 0.5 * t * t;\n\tt--;\n\treturn -0.5 * (t * (t - 2) - 1);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quadIn(t) {\n\treturn t * t;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quadOut(t) {\n\treturn -t * (t - 2.0);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quartInOut(t) {\n\treturn t < 0.5 ? +8.0 * Math.pow(t, 4.0) : -8.0 * Math.pow(t - 1.0, 4.0) + 1.0;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quartIn(t) {\n\treturn Math.pow(t, 4.0);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quartOut(t) {\n\treturn Math.pow(t - 1.0, 3.0) * (1.0 - t) + 1.0;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quintInOut(t) {\n\tif ((t *= 2) < 1) return 0.5 * t * t * t * t * t;\n\treturn 0.5 * ((t -= 2) * t * t * t * t + 2);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quintIn(t) {\n\treturn t * t * t * t * t;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function quintOut(t) {\n\treturn --t * t * t * t * t + 1;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function sineInOut(t) {\n\treturn -0.5 * (Math.cos(Math.PI * t) - 1);\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function sineIn(t) {\n\tconst v = Math.cos(t * Math.PI * 0.5);\n\tif (Math.abs(v) < 1e-14) return 1;\n\telse return 1 - v;\n}\n\n/**\n * https://svelte.dev/docs/svelte-easing\n * @param {number} t\n * @returns {number}\n */\nexport function sineOut(t) {\n\treturn Math.sin((t * Math.PI) / 2);\n}\n","import { cubicOut, cubicInOut, linear } from '../easing/index.js';\nimport { assign, split_css_unit, is_function } from '../internal/index.js';\n\n/**\n * Animates a `blur` filter alongside an element's opacity.\n *\n * https://svelte.dev/docs/svelte-transition#blur\n * @param {Element} node\n * @param {import('./public').BlurParams} [params]\n * @returns {import('./public').TransitionConfig}\n */\nexport function blur(\n\tnode,\n\t{ delay = 0, duration = 400, easing = cubicInOut, amount = 5, opacity = 0 } = {}\n) {\n\tconst style = getComputedStyle(node);\n\tconst target_opacity = +style.opacity;\n\tconst f = style.filter === 'none' ? '' : style.filter;\n\tconst od = target_opacity * (1 - opacity);\n\tconst [value, unit] = split_css_unit(amount);\n\treturn {\n\t\tdelay,\n\t\tduration,\n\t\teasing,\n\t\tcss: (_t, u) => `opacity: ${target_opacity - od * u}; filter: ${f} blur(${u * value}${unit});`\n\t};\n}\n\n/**\n * Animates the opacity of an element from 0 to the current opacity for `in` transitions and from the current opacity to 0 for `out` transitions.\n *\n * https://svelte.dev/docs/svelte-transition#fade\n * @param {Element} node\n * @param {import('./public').FadeParams} [params]\n * @returns {import('./public').TransitionConfig}\n */\nexport function fade(node, { delay = 0, duration = 400, easing = linear } = {}) {\n\tconst o = +getComputedStyle(node).opacity;\n\treturn {\n\t\tdelay,\n\t\tduration,\n\t\teasing,\n\t\tcss: (t) => `opacity: ${t * o}`\n\t};\n}\n\n/**\n * Animates the x and y positions and the opacity of an element. `in` transitions animate from the provided values, passed as parameters to the element's default values. `out` transitions animate from the element's default values to the provided values.\n *\n * https://svelte.dev/docs/svelte-transition#fly\n * @param {Element} node\n * @param {import('./public').FlyParams} [params]\n * @returns {import('./public').TransitionConfig}\n */\nexport function fly(\n\tnode,\n\t{ delay = 0, duration = 400, easing = cubicOut, x = 0, y = 0, opacity = 0 } = {}\n) {\n\tconst style = getComputedStyle(node);\n\tconst target_opacity = +style.opacity;\n\tconst transform = style.transform === 'none' ? '' : style.transform;\n\tconst od = target_opacity * (1 - opacity);\n\tconst [xValue, xUnit] = split_css_unit(x);\n\tconst [yValue, yUnit] = split_css_unit(y);\n\treturn {\n\t\tdelay,\n\t\tduration,\n\t\teasing,\n\t\tcss: (t, u) => `\n\t\t\ttransform: ${transform} translate(${(1 - t) * xValue}${xUnit}, ${(1 - t) * yValue}${yUnit});\n\t\t\topacity: ${target_opacity - od * u}`\n\t};\n}\n\n/**\n * Slides an element in and out.\n *\n * https://svelte.dev/docs/svelte-transition#slide\n * @param {Element} node\n * @param {import('./public').SlideParams} [params]\n * @returns {import('./public').TransitionConfig}\n */\nexport function slide(node, { delay = 0, duration = 400, easing = cubicOut, axis = 'y' } = {}) {\n\tconst style = getComputedStyle(node);\n\tconst opacity = +style.opacity;\n\tconst primary_property = axis === 'y' ? 'height' : 'width';\n\tconst primary_property_value = parseFloat(style[primary_property]);\n\tconst secondary_properties = axis === 'y' ? ['top', 'bottom'] : ['left', 'right'];\n\tconst capitalized_secondary_properties = secondary_properties.map(\n\t\t(e) => `${e[0].toUpperCase()}${e.slice(1)}`\n\t);\n\tconst padding_start_value = parseFloat(style[`padding${capitalized_secondary_properties[0]}`]);\n\tconst padding_end_value = parseFloat(style[`padding${capitalized_secondary_properties[1]}`]);\n\tconst margin_start_value = parseFloat(style[`margin${capitalized_secondary_properties[0]}`]);\n\tconst margin_end_value = parseFloat(style[`margin${capitalized_secondary_properties[1]}`]);\n\tconst border_width_start_value = parseFloat(\n\t\tstyle[`border${capitalized_secondary_properties[0]}Width`]\n\t);\n\tconst border_width_end_value = parseFloat(\n\t\tstyle[`border${capitalized_secondary_properties[1]}Width`]\n\t);\n\treturn {\n\t\tdelay,\n\t\tduration,\n\t\teasing,\n\t\tcss: (t) =>\n\t\t\t'overflow: hidden;' +\n\t\t\t`opacity: ${Math.min(t * 20, 1) * opacity};` +\n\t\t\t`${primary_property}: ${t * primary_property_value}px;` +\n\t\t\t`padding-${secondary_properties[0]}: ${t * padding_start_value}px;` +\n\t\t\t`padding-${secondary_properties[1]}: ${t * padding_end_value}px;` +\n\t\t\t`margin-${secondary_properties[0]}: ${t * margin_start_value}px;` +\n\t\t\t`margin-${secondary_properties[1]}: ${t * margin_end_value}px;` +\n\t\t\t`border-${secondary_properties[0]}-width: ${t * border_width_start_value}px;` +\n\t\t\t`border-${secondary_properties[1]}-width: ${t * border_width_end_value}px;`\n\t};\n}\n\n/**\n * Animates the opacity and scale of an element. `in` transitions animate from an element's current (default) values to the provided values, passed as parameters. `out` transitions animate from the provided values to an element's default values.\n *\n * https://svelte.dev/docs/svelte-transition#scale\n * @param {Element} node\n * @param {import('./public').ScaleParams} [params]\n * @returns {import('./public').TransitionConfig}\n */\nexport function scale(\n\tnode,\n\t{ delay = 0, duration = 400, easing = cubicOut, start = 0, opacity = 0 } = {}\n) {\n\tconst style = getComputedStyle(node);\n\tconst target_opacity = +style.opacity;\n\tconst transform = style.transform === 'none' ? '' : style.transform;\n\tconst sd = 1 - start;\n\tconst od = target_opacity * (1 - opacity);\n\treturn {\n\t\tdelay,\n\t\tduration,\n\t\teasing,\n\t\tcss: (_t, u) => `\n\t\t\ttransform: ${transform} scale(${1 - sd * u});\n\t\t\topacity: ${target_opacity - od * u}\n\t\t`\n\t};\n}\n\n/**\n * Animates the stroke of an SVG element, like a snake in a tube. `in` transitions begin with the path invisible and draw the path to the screen over time. `out` transitions start in a visible state and gradually erase the path. `draw` only works with elements that have a `getTotalLength` method, like `` and ``.\n *\n * https://svelte.dev/docs/svelte-transition#draw\n * @param {SVGElement & { getTotalLength(): number }} node\n * @param {import('./public').DrawParams} [params]\n * @returns {import('./public').TransitionConfig}\n */\nexport function draw(node, { delay = 0, speed, duration, easing = cubicInOut } = {}) {\n\tlet len = node.getTotalLength();\n\tconst style = getComputedStyle(node);\n\tif (style.strokeLinecap !== 'butt') {\n\t\tlen += parseInt(style.strokeWidth);\n\t}\n\tif (duration === undefined) {\n\t\tif (speed === undefined) {\n\t\t\tduration = 800;\n\t\t} else {\n\t\t\tduration = len / speed;\n\t\t}\n\t} else if (typeof duration === 'function') {\n\t\tduration = duration(len);\n\t}\n\treturn {\n\t\tdelay,\n\t\tduration,\n\t\teasing,\n\t\tcss: (_, u) => `\n\t\t\tstroke-dasharray: ${len};\n\t\t\tstroke-dashoffset: ${u * len};\n\t\t`\n\t};\n}\n\n/**\n * The `crossfade` function creates a pair of [transitions](https://svelte.dev/docs#template-syntax-element-directives-transition-fn) called `send` and `receive`. When an element is 'sent', it looks for a corresponding element being 'received', and generates a transition that transforms the element to its counterpart's position and fades it out. When an element is 'received', the reverse happens. If there is no counterpart, the `fallback` transition is used.\n *\n * https://svelte.dev/docs/svelte-transition#crossfade\n * @param {import('./public').CrossfadeParams & {\n * \tfallback?: (node: Element, params: import('./public').CrossfadeParams, intro: boolean) => import('./public').TransitionConfig;\n * }} params\n * @returns {[(node: any, params: import('./public').CrossfadeParams & { key: any; }) => () => import('./public').TransitionConfig, (node: any, params: import('./public').CrossfadeParams & { key: any; }) => () => import('./public').TransitionConfig]}\n */\nexport function crossfade({ fallback, ...defaults }) {\n\t/** @type {Map} */\n\tconst to_receive = new Map();\n\t/** @type {Map} */\n\tconst to_send = new Map();\n\t/**\n\t * @param {Element} from_node\n\t * @param {Element} node\n\t * @param {import('./public').CrossfadeParams} params\n\t * @returns {import('./public').TransitionConfig}\n\t */\n\tfunction crossfade(from_node, node, params) {\n\t\tconst {\n\t\t\tdelay = 0,\n\t\t\tduration = (d) => Math.sqrt(d) * 30,\n\t\t\teasing = cubicOut\n\t\t} = assign(assign({}, defaults), params);\n\t\tconst from = from_node.getBoundingClientRect();\n\t\tconst to = node.getBoundingClientRect();\n\t\tconst dx = from.left - to.left;\n\t\tconst dy = from.top - to.top;\n\t\tconst dw = from.width / to.width;\n\t\tconst dh = from.height / to.height;\n\t\tconst d = Math.sqrt(dx * dx + dy * dy);\n\t\tconst style = getComputedStyle(node);\n\t\tconst transform = style.transform === 'none' ? '' : style.transform;\n\t\tconst opacity = +style.opacity;\n\t\treturn {\n\t\t\tdelay,\n\t\t\tduration: is_function(duration) ? duration(d) : duration,\n\t\t\teasing,\n\t\t\tcss: (t, u) => `\n\t\t\t\topacity: ${t * opacity};\n\t\t\t\ttransform-origin: top left;\n\t\t\t\ttransform: ${transform} translate(${u * dx}px,${u * dy}px) scale(${t + (1 - t) * dw}, ${\n\t\t\t\tt + (1 - t) * dh\n\t\t\t});\n\t\t\t`\n\t\t};\n\t}\n\n\t/**\n\t * @param {Map} items\n\t * @param {Map} counterparts\n\t * @param {boolean} intro\n\t * @returns {(node: any, params: import('./public').CrossfadeParams & { key: any; }) => () => import('./public').TransitionConfig}\n\t */\n\tfunction transition(items, counterparts, intro) {\n\t\treturn (node, params) => {\n\t\t\titems.set(params.key, node);\n\t\t\treturn () => {\n\t\t\t\tif (counterparts.has(params.key)) {\n\t\t\t\t\tconst other_node = counterparts.get(params.key);\n\t\t\t\t\tcounterparts.delete(params.key);\n\t\t\t\t\treturn crossfade(other_node, node, params);\n\t\t\t\t}\n\t\t\t\t// if the node is disappearing altogether\n\t\t\t\t// (i.e. wasn't claimed by the other list)\n\t\t\t\t// then we need to supply an outro\n\t\t\t\titems.delete(params.key);\n\t\t\t\treturn fallback && fallback(node, params, intro);\n\t\t\t};\n\t\t};\n\t}\n\treturn [transition(to_send, to_receive, false), transition(to_receive, to_send, true)];\n}\n","\n\n{#if link_href === \"\"}\n\t\n\t\t{#if icon !== \"\"}\n\t\t\t{icon} \n\t\t{/if}\n\t\t{#if label !== \"\"}\n\t\t\t{label} \n\t\t{/if}\n\t \n{:else}\n\t\n\t\t{#if icon !== \"\"}\n\t\t\t{icon} \n\t\t{/if}\n\t\t{#if label !== \"\"}\n\t\t\t{label} \n\t\t{/if}\n\t \n{/if}\n\n\n","\n\n\n\n\n\n{#if visible}\n\t\n\t\n\t\t
\n\t\t\n\t\t
\n\t\t\t\n\t\t\t
\n\t\t\t\t \n\t\t\t
\n\t\t
\n\t\t
\n\t
\n{/if}\n\n\n","export const formatNumber = (amt: number, precision: number) => {\n\tif (precision < 3) { precision = 3; }\n\tif (amt >= 1e6) {\n\t\treturn (amt/1e6).toPrecision(precision) + \"M\";\n\t} else if (amt >= 1e3) {\n\t\treturn (amt/1e3).toPrecision(precision) + \"k\";\n\t}\n\treturn amt.toPrecision(precision)\n}\n\nexport const formatThousands = (amt: number) => {\n\treturn amt.toString().replace(/\\B(?=(\\d{3})+(?!\\d))/g, \" \");\n}\n\nexport const formatDataVolume = (amt: number, precision: number) => {\n\tif (precision < 3) { precision = 3; }\n\tif (amt >= 1e18-1e15) {\n\t\treturn (amt/1e18).toPrecision(precision) + \" EB\";\n\t}else if (amt >= 1e15-1e12) {\n\t\treturn (amt/1e15).toPrecision(precision) + \" PB\";\n\t}else if (amt >= 1e12-1e9) {\n\t\treturn (amt/1e12).toPrecision(precision) + \" TB\";\n\t} else if (amt >= 1e9-1e6) {\n\t\treturn (amt/1e9).toPrecision(precision) + \" GB\";\n\t} else if (amt >= 1e6-1e3) {\n\t\treturn (amt/1e6).toPrecision(precision) + \" MB\";\n\t} else if (amt >= 1e3-1) {\n\t\treturn (amt/1e3).toPrecision(precision) + \" kB\";\n\t}\n\treturn amt.toPrecision(precision) + \" B\"\n}\nexport const formatDataVolumeBits = (amt: number, precision: number) => {\n\tamt = amt*8\n\tif (precision < 3) { precision = 3; }\n\tif (amt >= 1e18-1e15) {\n\t\treturn (amt/1e18).toPrecision(precision) + \" Eb\";\n\t}else if (amt >= 1e15-1e12) {\n\t\treturn (amt/1e15).toPrecision(precision) + \" Pb\";\n\t}else if (amt >= 1e12-1e9) {\n\t\treturn (amt/1e12).toPrecision(precision) + \" Tb\";\n\t} else if (amt >= 1e9-1e6) {\n\t\treturn (amt/1e9).toPrecision(precision) + \" Gb\";\n\t} else if (amt >= 1e6-1e3) {\n\t\treturn (amt/1e6).toPrecision(precision) + \" Mb\";\n\t} else if (amt >= 1e3-1) {\n\t\treturn (amt/1e3).toPrecision(precision) + \" kb\";\n\t}\n\treturn amt + \" b\"\n}\n\nconst second = 1000\nconst minute = second*60\nconst hour = minute*60\nconst day = hour*24\n\nexport const formatDuration = (ms: number, decimals: number) => {\n\tlet res = \"\"\n\tif (ms >= day) { res += Math.floor(ms/day) + \"d \" }\n\tif (ms >= hour) { res += Math.floor((ms%day)/hour) + \"h \" }\n\tif (ms >= minute) { res += Math.floor((ms%hour)/minute) + \"m \" }\n\treturn res + ((ms%minute)/second).toFixed(decimals) + \"s\"\n}\n\nexport const formatDate = (\n\tdate: Date|string,\n\thours: boolean = true,\n\tminutes: boolean = true,\n\tseconds: boolean = true,\n) => {\n\tif (!(date instanceof Date)) {\n\t\tdate = new Date(date)\n\t}\n\n\tlet dateStr = date.getFullYear()\n\t\t+\"-\"+(\"00\"+(date.getMonth()+1)).slice(-2)\n\t\t+\"-\"+(\"00\"+date.getDate()).slice(-2)\n\n\tif (hours) { dateStr += \" \"+(\"00\"+date.getHours()).slice(-2) }\n\tif (minutes) { dateStr += \":\"+(\"00\"+date.getMinutes()).slice(-2) }\n\tif (seconds) { dateStr += \":\"+(\"00\"+date.getMinutes()).slice(-2) }\n\treturn dateStr\n}\n\nexport const formatEuros = (amt: number, precision: number) => {\n\treturn \"€ \"+ (amt / 1000000).toFixed(precision)\n}\n","\n","/*!\n * @kurkle/color v0.3.2\n * https://github.com/kurkle/color#readme\n * (c) 2023 Jukka Kurkela\n * Released under the MIT License\n */\nfunction round(v) {\n return v + 0.5 | 0;\n}\nconst lim = (v, l, h) => Math.max(Math.min(v, h), l);\nfunction p2b(v) {\n return lim(round(v * 2.55), 0, 255);\n}\nfunction b2p(v) {\n return lim(round(v / 2.55), 0, 100);\n}\nfunction n2b(v) {\n return lim(round(v * 255), 0, 255);\n}\nfunction b2n(v) {\n return lim(round(v / 2.55) / 100, 0, 1);\n}\nfunction n2p(v) {\n return lim(round(v * 100), 0, 100);\n}\n\nconst map$1 = {0: 0, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, A: 10, B: 11, C: 12, D: 13, E: 14, F: 15, a: 10, b: 11, c: 12, d: 13, e: 14, f: 15};\nconst hex = [...'0123456789ABCDEF'];\nconst h1 = b => hex[b & 0xF];\nconst h2 = b => hex[(b & 0xF0) >> 4] + hex[b & 0xF];\nconst eq = b => ((b & 0xF0) >> 4) === (b & 0xF);\nconst isShort = v => eq(v.r) && eq(v.g) && eq(v.b) && eq(v.a);\nfunction hexParse(str) {\n var len = str.length;\n var ret;\n if (str[0] === '#') {\n if (len === 4 || len === 5) {\n ret = {\n r: 255 & map$1[str[1]] * 17,\n g: 255 & map$1[str[2]] * 17,\n b: 255 & map$1[str[3]] * 17,\n a: len === 5 ? map$1[str[4]] * 17 : 255\n };\n } else if (len === 7 || len === 9) {\n ret = {\n r: map$1[str[1]] << 4 | map$1[str[2]],\n g: map$1[str[3]] << 4 | map$1[str[4]],\n b: map$1[str[5]] << 4 | map$1[str[6]],\n a: len === 9 ? (map$1[str[7]] << 4 | map$1[str[8]]) : 255\n };\n }\n }\n return ret;\n}\nconst alpha = (a, f) => a < 255 ? f(a) : '';\nfunction hexString(v) {\n var f = isShort(v) ? h1 : h2;\n return v\n ? '#' + f(v.r) + f(v.g) + f(v.b) + alpha(v.a, f)\n : undefined;\n}\n\nconst HUE_RE = /^(hsla?|hwb|hsv)\\(\\s*([-+.e\\d]+)(?:deg)?[\\s,]+([-+.e\\d]+)%[\\s,]+([-+.e\\d]+)%(?:[\\s,]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction hsl2rgbn(h, s, l) {\n const a = s * Math.min(l, 1 - l);\n const f = (n, k = (n + h / 30) % 12) => l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n return [f(0), f(8), f(4)];\n}\nfunction hsv2rgbn(h, s, v) {\n const f = (n, k = (n + h / 60) % 6) => v - v * s * Math.max(Math.min(k, 4 - k, 1), 0);\n return [f(5), f(3), f(1)];\n}\nfunction hwb2rgbn(h, w, b) {\n const rgb = hsl2rgbn(h, 1, 0.5);\n let i;\n if (w + b > 1) {\n i = 1 / (w + b);\n w *= i;\n b *= i;\n }\n for (i = 0; i < 3; i++) {\n rgb[i] *= 1 - w - b;\n rgb[i] += w;\n }\n return rgb;\n}\nfunction hueValue(r, g, b, d, max) {\n if (r === max) {\n return ((g - b) / d) + (g < b ? 6 : 0);\n }\n if (g === max) {\n return (b - r) / d + 2;\n }\n return (r - g) / d + 4;\n}\nfunction rgb2hsl(v) {\n const range = 255;\n const r = v.r / range;\n const g = v.g / range;\n const b = v.b / range;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const l = (max + min) / 2;\n let h, s, d;\n if (max !== min) {\n d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n h = hueValue(r, g, b, d, max);\n h = h * 60 + 0.5;\n }\n return [h | 0, s || 0, l];\n}\nfunction calln(f, a, b, c) {\n return (\n Array.isArray(a)\n ? f(a[0], a[1], a[2])\n : f(a, b, c)\n ).map(n2b);\n}\nfunction hsl2rgb(h, s, l) {\n return calln(hsl2rgbn, h, s, l);\n}\nfunction hwb2rgb(h, w, b) {\n return calln(hwb2rgbn, h, w, b);\n}\nfunction hsv2rgb(h, s, v) {\n return calln(hsv2rgbn, h, s, v);\n}\nfunction hue(h) {\n return (h % 360 + 360) % 360;\n}\nfunction hueParse(str) {\n const m = HUE_RE.exec(str);\n let a = 255;\n let v;\n if (!m) {\n return;\n }\n if (m[5] !== v) {\n a = m[6] ? p2b(+m[5]) : n2b(+m[5]);\n }\n const h = hue(+m[2]);\n const p1 = +m[3] / 100;\n const p2 = +m[4] / 100;\n if (m[1] === 'hwb') {\n v = hwb2rgb(h, p1, p2);\n } else if (m[1] === 'hsv') {\n v = hsv2rgb(h, p1, p2);\n } else {\n v = hsl2rgb(h, p1, p2);\n }\n return {\n r: v[0],\n g: v[1],\n b: v[2],\n a: a\n };\n}\nfunction rotate(v, deg) {\n var h = rgb2hsl(v);\n h[0] = hue(h[0] + deg);\n h = hsl2rgb(h);\n v.r = h[0];\n v.g = h[1];\n v.b = h[2];\n}\nfunction hslString(v) {\n if (!v) {\n return;\n }\n const a = rgb2hsl(v);\n const h = a[0];\n const s = n2p(a[1]);\n const l = n2p(a[2]);\n return v.a < 255\n ? `hsla(${h}, ${s}%, ${l}%, ${b2n(v.a)})`\n : `hsl(${h}, ${s}%, ${l}%)`;\n}\n\nconst map = {\n x: 'dark',\n Z: 'light',\n Y: 're',\n X: 'blu',\n W: 'gr',\n V: 'medium',\n U: 'slate',\n A: 'ee',\n T: 'ol',\n S: 'or',\n B: 'ra',\n C: 'lateg',\n D: 'ights',\n R: 'in',\n Q: 'turquois',\n E: 'hi',\n P: 'ro',\n O: 'al',\n N: 'le',\n M: 'de',\n L: 'yello',\n F: 'en',\n K: 'ch',\n G: 'arks',\n H: 'ea',\n I: 'ightg',\n J: 'wh'\n};\nconst names$1 = {\n OiceXe: 'f0f8ff',\n antiquewEte: 'faebd7',\n aqua: 'ffff',\n aquamarRe: '7fffd4',\n azuY: 'f0ffff',\n beige: 'f5f5dc',\n bisque: 'ffe4c4',\n black: '0',\n blanKedOmond: 'ffebcd',\n Xe: 'ff',\n XeviTet: '8a2be2',\n bPwn: 'a52a2a',\n burlywood: 'deb887',\n caMtXe: '5f9ea0',\n KartYuse: '7fff00',\n KocTate: 'd2691e',\n cSO: 'ff7f50',\n cSnflowerXe: '6495ed',\n cSnsilk: 'fff8dc',\n crimson: 'dc143c',\n cyan: 'ffff',\n xXe: '8b',\n xcyan: '8b8b',\n xgTMnPd: 'b8860b',\n xWay: 'a9a9a9',\n xgYF: '6400',\n xgYy: 'a9a9a9',\n xkhaki: 'bdb76b',\n xmagFta: '8b008b',\n xTivegYF: '556b2f',\n xSange: 'ff8c00',\n xScEd: '9932cc',\n xYd: '8b0000',\n xsOmon: 'e9967a',\n xsHgYF: '8fbc8f',\n xUXe: '483d8b',\n xUWay: '2f4f4f',\n xUgYy: '2f4f4f',\n xQe: 'ced1',\n xviTet: '9400d3',\n dAppRk: 'ff1493',\n dApskyXe: 'bfff',\n dimWay: '696969',\n dimgYy: '696969',\n dodgerXe: '1e90ff',\n fiYbrick: 'b22222',\n flSOwEte: 'fffaf0',\n foYstWAn: '228b22',\n fuKsia: 'ff00ff',\n gaRsbSo: 'dcdcdc',\n ghostwEte: 'f8f8ff',\n gTd: 'ffd700',\n gTMnPd: 'daa520',\n Way: '808080',\n gYF: '8000',\n gYFLw: 'adff2f',\n gYy: '808080',\n honeyMw: 'f0fff0',\n hotpRk: 'ff69b4',\n RdianYd: 'cd5c5c',\n Rdigo: '4b0082',\n ivSy: 'fffff0',\n khaki: 'f0e68c',\n lavFMr: 'e6e6fa',\n lavFMrXsh: 'fff0f5',\n lawngYF: '7cfc00',\n NmoncEffon: 'fffacd',\n ZXe: 'add8e6',\n ZcSO: 'f08080',\n Zcyan: 'e0ffff',\n ZgTMnPdLw: 'fafad2',\n ZWay: 'd3d3d3',\n ZgYF: '90ee90',\n ZgYy: 'd3d3d3',\n ZpRk: 'ffb6c1',\n ZsOmon: 'ffa07a',\n ZsHgYF: '20b2aa',\n ZskyXe: '87cefa',\n ZUWay: '778899',\n ZUgYy: '778899',\n ZstAlXe: 'b0c4de',\n ZLw: 'ffffe0',\n lime: 'ff00',\n limegYF: '32cd32',\n lRF: 'faf0e6',\n magFta: 'ff00ff',\n maPon: '800000',\n VaquamarRe: '66cdaa',\n VXe: 'cd',\n VScEd: 'ba55d3',\n VpurpN: '9370db',\n VsHgYF: '3cb371',\n VUXe: '7b68ee',\n VsprRggYF: 'fa9a',\n VQe: '48d1cc',\n VviTetYd: 'c71585',\n midnightXe: '191970',\n mRtcYam: 'f5fffa',\n mistyPse: 'ffe4e1',\n moccasR: 'ffe4b5',\n navajowEte: 'ffdead',\n navy: '80',\n Tdlace: 'fdf5e6',\n Tive: '808000',\n TivedBb: '6b8e23',\n Sange: 'ffa500',\n SangeYd: 'ff4500',\n ScEd: 'da70d6',\n pOegTMnPd: 'eee8aa',\n pOegYF: '98fb98',\n pOeQe: 'afeeee',\n pOeviTetYd: 'db7093',\n papayawEp: 'ffefd5',\n pHKpuff: 'ffdab9',\n peru: 'cd853f',\n pRk: 'ffc0cb',\n plum: 'dda0dd',\n powMrXe: 'b0e0e6',\n purpN: '800080',\n YbeccapurpN: '663399',\n Yd: 'ff0000',\n Psybrown: 'bc8f8f',\n PyOXe: '4169e1',\n saddNbPwn: '8b4513',\n sOmon: 'fa8072',\n sandybPwn: 'f4a460',\n sHgYF: '2e8b57',\n sHshell: 'fff5ee',\n siFna: 'a0522d',\n silver: 'c0c0c0',\n skyXe: '87ceeb',\n UXe: '6a5acd',\n UWay: '708090',\n UgYy: '708090',\n snow: 'fffafa',\n sprRggYF: 'ff7f',\n stAlXe: '4682b4',\n tan: 'd2b48c',\n teO: '8080',\n tEstN: 'd8bfd8',\n tomato: 'ff6347',\n Qe: '40e0d0',\n viTet: 'ee82ee',\n JHt: 'f5deb3',\n wEte: 'ffffff',\n wEtesmoke: 'f5f5f5',\n Lw: 'ffff00',\n LwgYF: '9acd32'\n};\nfunction unpack() {\n const unpacked = {};\n const keys = Object.keys(names$1);\n const tkeys = Object.keys(map);\n let i, j, k, ok, nk;\n for (i = 0; i < keys.length; i++) {\n ok = nk = keys[i];\n for (j = 0; j < tkeys.length; j++) {\n k = tkeys[j];\n nk = nk.replace(k, map[k]);\n }\n k = parseInt(names$1[ok], 16);\n unpacked[nk] = [k >> 16 & 0xFF, k >> 8 & 0xFF, k & 0xFF];\n }\n return unpacked;\n}\n\nlet names;\nfunction nameParse(str) {\n if (!names) {\n names = unpack();\n names.transparent = [0, 0, 0, 0];\n }\n const a = names[str.toLowerCase()];\n return a && {\n r: a[0],\n g: a[1],\n b: a[2],\n a: a.length === 4 ? a[3] : 255\n };\n}\n\nconst RGB_RE = /^rgba?\\(\\s*([-+.\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?(?:[\\s,/]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction rgbParse(str) {\n const m = RGB_RE.exec(str);\n let a = 255;\n let r, g, b;\n if (!m) {\n return;\n }\n if (m[7] !== r) {\n const v = +m[7];\n a = m[8] ? p2b(v) : lim(v * 255, 0, 255);\n }\n r = +m[1];\n g = +m[3];\n b = +m[5];\n r = 255 & (m[2] ? p2b(r) : lim(r, 0, 255));\n g = 255 & (m[4] ? p2b(g) : lim(g, 0, 255));\n b = 255 & (m[6] ? p2b(b) : lim(b, 0, 255));\n return {\n r: r,\n g: g,\n b: b,\n a: a\n };\n}\nfunction rgbString(v) {\n return v && (\n v.a < 255\n ? `rgba(${v.r}, ${v.g}, ${v.b}, ${b2n(v.a)})`\n : `rgb(${v.r}, ${v.g}, ${v.b})`\n );\n}\n\nconst to = v => v <= 0.0031308 ? v * 12.92 : Math.pow(v, 1.0 / 2.4) * 1.055 - 0.055;\nconst from = v => v <= 0.04045 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4);\nfunction interpolate(rgb1, rgb2, t) {\n const r = from(b2n(rgb1.r));\n const g = from(b2n(rgb1.g));\n const b = from(b2n(rgb1.b));\n return {\n r: n2b(to(r + t * (from(b2n(rgb2.r)) - r))),\n g: n2b(to(g + t * (from(b2n(rgb2.g)) - g))),\n b: n2b(to(b + t * (from(b2n(rgb2.b)) - b))),\n a: rgb1.a + t * (rgb2.a - rgb1.a)\n };\n}\n\nfunction modHSL(v, i, ratio) {\n if (v) {\n let tmp = rgb2hsl(v);\n tmp[i] = Math.max(0, Math.min(tmp[i] + tmp[i] * ratio, i === 0 ? 360 : 1));\n tmp = hsl2rgb(tmp);\n v.r = tmp[0];\n v.g = tmp[1];\n v.b = tmp[2];\n }\n}\nfunction clone(v, proto) {\n return v ? Object.assign(proto || {}, v) : v;\n}\nfunction fromObject(input) {\n var v = {r: 0, g: 0, b: 0, a: 255};\n if (Array.isArray(input)) {\n if (input.length >= 3) {\n v = {r: input[0], g: input[1], b: input[2], a: 255};\n if (input.length > 3) {\n v.a = n2b(input[3]);\n }\n }\n } else {\n v = clone(input, {r: 0, g: 0, b: 0, a: 1});\n v.a = n2b(v.a);\n }\n return v;\n}\nfunction functionParse(str) {\n if (str.charAt(0) === 'r') {\n return rgbParse(str);\n }\n return hueParse(str);\n}\nclass Color {\n constructor(input) {\n if (input instanceof Color) {\n return input;\n }\n const type = typeof input;\n let v;\n if (type === 'object') {\n v = fromObject(input);\n } else if (type === 'string') {\n v = hexParse(input) || nameParse(input) || functionParse(input);\n }\n this._rgb = v;\n this._valid = !!v;\n }\n get valid() {\n return this._valid;\n }\n get rgb() {\n var v = clone(this._rgb);\n if (v) {\n v.a = b2n(v.a);\n }\n return v;\n }\n set rgb(obj) {\n this._rgb = fromObject(obj);\n }\n rgbString() {\n return this._valid ? rgbString(this._rgb) : undefined;\n }\n hexString() {\n return this._valid ? hexString(this._rgb) : undefined;\n }\n hslString() {\n return this._valid ? hslString(this._rgb) : undefined;\n }\n mix(color, weight) {\n if (color) {\n const c1 = this.rgb;\n const c2 = color.rgb;\n let w2;\n const p = weight === w2 ? 0.5 : weight;\n const w = 2 * p - 1;\n const a = c1.a - c2.a;\n const w1 = ((w * a === -1 ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n w2 = 1 - w1;\n c1.r = 0xFF & w1 * c1.r + w2 * c2.r + 0.5;\n c1.g = 0xFF & w1 * c1.g + w2 * c2.g + 0.5;\n c1.b = 0xFF & w1 * c1.b + w2 * c2.b + 0.5;\n c1.a = p * c1.a + (1 - p) * c2.a;\n this.rgb = c1;\n }\n return this;\n }\n interpolate(color, t) {\n if (color) {\n this._rgb = interpolate(this._rgb, color._rgb, t);\n }\n return this;\n }\n clone() {\n return new Color(this.rgb);\n }\n alpha(a) {\n this._rgb.a = n2b(a);\n return this;\n }\n clearer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 - ratio;\n return this;\n }\n greyscale() {\n const rgb = this._rgb;\n const val = round(rgb.r * 0.3 + rgb.g * 0.59 + rgb.b * 0.11);\n rgb.r = rgb.g = rgb.b = val;\n return this;\n }\n opaquer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 + ratio;\n return this;\n }\n negate() {\n const v = this._rgb;\n v.r = 255 - v.r;\n v.g = 255 - v.g;\n v.b = 255 - v.b;\n return this;\n }\n lighten(ratio) {\n modHSL(this._rgb, 2, ratio);\n return this;\n }\n darken(ratio) {\n modHSL(this._rgb, 2, -ratio);\n return this;\n }\n saturate(ratio) {\n modHSL(this._rgb, 1, ratio);\n return this;\n }\n desaturate(ratio) {\n modHSL(this._rgb, 1, -ratio);\n return this;\n }\n rotate(deg) {\n rotate(this._rgb, deg);\n return this;\n }\n}\n\nfunction index_esm(input) {\n return new Color(input);\n}\n\nexport { Color, b2n, b2p, index_esm as default, hexParse, hexString, hsl2rgb, hslString, hsv2rgb, hueParse, hwb2rgb, lim, n2b, n2p, nameParse, p2b, rgb2hsl, rgbParse, rgbString, rotate, round };\n","/*!\n * Chart.js v4.4.6\n * https://www.chartjs.org\n * (c) 2024 Chart.js Contributors\n * Released under the MIT License\n */\nimport { Color } from '@kurkle/color';\n\n/**\n * @namespace Chart.helpers\n */ /**\n * An empty function that can be used, for example, for optional callback.\n */ function noop() {\n/* noop */ }\n/**\n * Returns a unique id, sequentially generated from a global variable.\n */ const uid = (()=>{\n let id = 0;\n return ()=>id++;\n})();\n/**\n * Returns true if `value` is neither null nor undefined, else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */ function isNullOrUndef(value) {\n return value === null || typeof value === 'undefined';\n}\n/**\n * Returns true if `value` is an array (including typed arrays), else returns false.\n * @param value - The value to test.\n * @function\n */ function isArray(value) {\n if (Array.isArray && Array.isArray(value)) {\n return true;\n }\n const type = Object.prototype.toString.call(value);\n if (type.slice(0, 7) === '[object' && type.slice(-6) === 'Array]') {\n return true;\n }\n return false;\n}\n/**\n * Returns true if `value` is an object (excluding null), else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */ function isObject(value) {\n return value !== null && Object.prototype.toString.call(value) === '[object Object]';\n}\n/**\n * Returns true if `value` is a finite number, else returns false\n * @param value - The value to test.\n */ function isNumberFinite(value) {\n return (typeof value === 'number' || value instanceof Number) && isFinite(+value);\n}\n/**\n * Returns `value` if finite, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is not finite.\n */ function finiteOrDefault(value, defaultValue) {\n return isNumberFinite(value) ? value : defaultValue;\n}\n/**\n * Returns `value` if defined, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is undefined.\n */ function valueOrDefault(value, defaultValue) {\n return typeof value === 'undefined' ? defaultValue : value;\n}\nconst toPercentage = (value, dimension)=>typeof value === 'string' && value.endsWith('%') ? parseFloat(value) / 100 : +value / dimension;\nconst toDimension = (value, dimension)=>typeof value === 'string' && value.endsWith('%') ? parseFloat(value) / 100 * dimension : +value;\n/**\n * Calls `fn` with the given `args` in the scope defined by `thisArg` and returns the\n * value returned by `fn`. If `fn` is not a function, this method returns undefined.\n * @param fn - The function to call.\n * @param args - The arguments with which `fn` should be called.\n * @param [thisArg] - The value of `this` provided for the call to `fn`.\n */ function callback(fn, args, thisArg) {\n if (fn && typeof fn.call === 'function') {\n return fn.apply(thisArg, args);\n }\n}\nfunction each(loopable, fn, thisArg, reverse) {\n let i, len, keys;\n if (isArray(loopable)) {\n len = loopable.length;\n if (reverse) {\n for(i = len - 1; i >= 0; i--){\n fn.call(thisArg, loopable[i], i);\n }\n } else {\n for(i = 0; i < len; i++){\n fn.call(thisArg, loopable[i], i);\n }\n }\n } else if (isObject(loopable)) {\n keys = Object.keys(loopable);\n len = keys.length;\n for(i = 0; i < len; i++){\n fn.call(thisArg, loopable[keys[i]], keys[i]);\n }\n }\n}\n/**\n * Returns true if the `a0` and `a1` arrays have the same content, else returns false.\n * @param a0 - The array to compare\n * @param a1 - The array to compare\n * @private\n */ function _elementsEqual(a0, a1) {\n let i, ilen, v0, v1;\n if (!a0 || !a1 || a0.length !== a1.length) {\n return false;\n }\n for(i = 0, ilen = a0.length; i < ilen; ++i){\n v0 = a0[i];\n v1 = a1[i];\n if (v0.datasetIndex !== v1.datasetIndex || v0.index !== v1.index) {\n return false;\n }\n }\n return true;\n}\n/**\n * Returns a deep copy of `source` without keeping references on objects and arrays.\n * @param source - The value to clone.\n */ function clone(source) {\n if (isArray(source)) {\n return source.map(clone);\n }\n if (isObject(source)) {\n const target = Object.create(null);\n const keys = Object.keys(source);\n const klen = keys.length;\n let k = 0;\n for(; k < klen; ++k){\n target[keys[k]] = clone(source[keys[k]]);\n }\n return target;\n }\n return source;\n}\nfunction isValidKey(key) {\n return [\n '__proto__',\n 'prototype',\n 'constructor'\n ].indexOf(key) === -1;\n}\n/**\n * The default merger when Chart.helpers.merge is called without merger option.\n * Note(SB): also used by mergeConfig and mergeScaleConfig as fallback.\n * @private\n */ function _merger(key, target, source, options) {\n if (!isValidKey(key)) {\n return;\n }\n const tval = target[key];\n const sval = source[key];\n if (isObject(tval) && isObject(sval)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n merge(tval, sval, options);\n } else {\n target[key] = clone(sval);\n }\n}\nfunction merge(target, source, options) {\n const sources = isArray(source) ? source : [\n source\n ];\n const ilen = sources.length;\n if (!isObject(target)) {\n return target;\n }\n options = options || {};\n const merger = options.merger || _merger;\n let current;\n for(let i = 0; i < ilen; ++i){\n current = sources[i];\n if (!isObject(current)) {\n continue;\n }\n const keys = Object.keys(current);\n for(let k = 0, klen = keys.length; k < klen; ++k){\n merger(keys[k], target, current, options);\n }\n }\n return target;\n}\nfunction mergeIf(target, source) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return merge(target, source, {\n merger: _mergerIf\n });\n}\n/**\n * Merges source[key] in target[key] only if target[key] is undefined.\n * @private\n */ function _mergerIf(key, target, source) {\n if (!isValidKey(key)) {\n return;\n }\n const tval = target[key];\n const sval = source[key];\n if (isObject(tval) && isObject(sval)) {\n mergeIf(tval, sval);\n } else if (!Object.prototype.hasOwnProperty.call(target, key)) {\n target[key] = clone(sval);\n }\n}\n/**\n * @private\n */ function _deprecated(scope, value, previous, current) {\n if (value !== undefined) {\n console.warn(scope + ': \"' + previous + '\" is deprecated. Please use \"' + current + '\" instead');\n }\n}\n// resolveObjectKey resolver cache\nconst keyResolvers = {\n // Chart.helpers.core resolveObjectKey should resolve empty key to root object\n '': (v)=>v,\n // default resolvers\n x: (o)=>o.x,\n y: (o)=>o.y\n};\n/**\n * @private\n */ function _splitKey(key) {\n const parts = key.split('.');\n const keys = [];\n let tmp = '';\n for (const part of parts){\n tmp += part;\n if (tmp.endsWith('\\\\')) {\n tmp = tmp.slice(0, -1) + '.';\n } else {\n keys.push(tmp);\n tmp = '';\n }\n }\n return keys;\n}\nfunction _getKeyResolver(key) {\n const keys = _splitKey(key);\n return (obj)=>{\n for (const k of keys){\n if (k === '') {\n break;\n }\n obj = obj && obj[k];\n }\n return obj;\n };\n}\nfunction resolveObjectKey(obj, key) {\n const resolver = keyResolvers[key] || (keyResolvers[key] = _getKeyResolver(key));\n return resolver(obj);\n}\n/**\n * @private\n */ function _capitalize(str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\nconst defined = (value)=>typeof value !== 'undefined';\nconst isFunction = (value)=>typeof value === 'function';\n// Adapted from https://stackoverflow.com/questions/31128855/comparing-ecma6-sets-for-equality#31129384\nconst setsEqual = (a, b)=>{\n if (a.size !== b.size) {\n return false;\n }\n for (const item of a){\n if (!b.has(item)) {\n return false;\n }\n }\n return true;\n};\n/**\n * @param e - The event\n * @private\n */ function _isClickEvent(e) {\n return e.type === 'mouseup' || e.type === 'click' || e.type === 'contextmenu';\n}\n\n/**\n * @alias Chart.helpers.math\n * @namespace\n */ const PI = Math.PI;\nconst TAU = 2 * PI;\nconst PITAU = TAU + PI;\nconst INFINITY = Number.POSITIVE_INFINITY;\nconst RAD_PER_DEG = PI / 180;\nconst HALF_PI = PI / 2;\nconst QUARTER_PI = PI / 4;\nconst TWO_THIRDS_PI = PI * 2 / 3;\nconst log10 = Math.log10;\nconst sign = Math.sign;\nfunction almostEquals(x, y, epsilon) {\n return Math.abs(x - y) < epsilon;\n}\n/**\n * Implementation of the nice number algorithm used in determining where axis labels will go\n */ function niceNum(range) {\n const roundedRange = Math.round(range);\n range = almostEquals(range, roundedRange, range / 1000) ? roundedRange : range;\n const niceRange = Math.pow(10, Math.floor(log10(range)));\n const fraction = range / niceRange;\n const niceFraction = fraction <= 1 ? 1 : fraction <= 2 ? 2 : fraction <= 5 ? 5 : 10;\n return niceFraction * niceRange;\n}\n/**\n * Returns an array of factors sorted from 1 to sqrt(value)\n * @private\n */ function _factorize(value) {\n const result = [];\n const sqrt = Math.sqrt(value);\n let i;\n for(i = 1; i < sqrt; i++){\n if (value % i === 0) {\n result.push(i);\n result.push(value / i);\n }\n }\n if (sqrt === (sqrt | 0)) {\n result.push(sqrt);\n }\n result.sort((a, b)=>a - b).pop();\n return result;\n}\nfunction isNumber(n) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n}\nfunction almostWhole(x, epsilon) {\n const rounded = Math.round(x);\n return rounded - epsilon <= x && rounded + epsilon >= x;\n}\n/**\n * @private\n */ function _setMinAndMaxByKey(array, target, property) {\n let i, ilen, value;\n for(i = 0, ilen = array.length; i < ilen; i++){\n value = array[i][property];\n if (!isNaN(value)) {\n target.min = Math.min(target.min, value);\n target.max = Math.max(target.max, value);\n }\n }\n}\nfunction toRadians(degrees) {\n return degrees * (PI / 180);\n}\nfunction toDegrees(radians) {\n return radians * (180 / PI);\n}\n/**\n * Returns the number of decimal places\n * i.e. the number of digits after the decimal point, of the value of this Number.\n * @param x - A number.\n * @returns The number of decimal places.\n * @private\n */ function _decimalPlaces(x) {\n if (!isNumberFinite(x)) {\n return;\n }\n let e = 1;\n let p = 0;\n while(Math.round(x * e) / e !== x){\n e *= 10;\n p++;\n }\n return p;\n}\n// Gets the angle from vertical upright to the point about a centre.\nfunction getAngleFromPoint(centrePoint, anglePoint) {\n const distanceFromXCenter = anglePoint.x - centrePoint.x;\n const distanceFromYCenter = anglePoint.y - centrePoint.y;\n const radialDistanceFromCenter = Math.sqrt(distanceFromXCenter * distanceFromXCenter + distanceFromYCenter * distanceFromYCenter);\n let angle = Math.atan2(distanceFromYCenter, distanceFromXCenter);\n if (angle < -0.5 * PI) {\n angle += TAU; // make sure the returned angle is in the range of (-PI/2, 3PI/2]\n }\n return {\n angle,\n distance: radialDistanceFromCenter\n };\n}\nfunction distanceBetweenPoints(pt1, pt2) {\n return Math.sqrt(Math.pow(pt2.x - pt1.x, 2) + Math.pow(pt2.y - pt1.y, 2));\n}\n/**\n * Shortest distance between angles, in either direction.\n * @private\n */ function _angleDiff(a, b) {\n return (a - b + PITAU) % TAU - PI;\n}\n/**\n * Normalize angle to be between 0 and 2*PI\n * @private\n */ function _normalizeAngle(a) {\n return (a % TAU + TAU) % TAU;\n}\n/**\n * @private\n */ function _angleBetween(angle, start, end, sameAngleIsFullCircle) {\n const a = _normalizeAngle(angle);\n const s = _normalizeAngle(start);\n const e = _normalizeAngle(end);\n const angleToStart = _normalizeAngle(s - a);\n const angleToEnd = _normalizeAngle(e - a);\n const startToAngle = _normalizeAngle(a - s);\n const endToAngle = _normalizeAngle(a - e);\n return a === s || a === e || sameAngleIsFullCircle && s === e || angleToStart > angleToEnd && startToAngle < endToAngle;\n}\n/**\n * Limit `value` between `min` and `max`\n * @param value\n * @param min\n * @param max\n * @private\n */ function _limitValue(value, min, max) {\n return Math.max(min, Math.min(max, value));\n}\n/**\n * @param {number} value\n * @private\n */ function _int16Range(value) {\n return _limitValue(value, -32768, 32767);\n}\n/**\n * @param value\n * @param start\n * @param end\n * @param [epsilon]\n * @private\n */ function _isBetween(value, start, end, epsilon = 1e-6) {\n return value >= Math.min(start, end) - epsilon && value <= Math.max(start, end) + epsilon;\n}\n\nfunction _lookup(table, value, cmp) {\n cmp = cmp || ((index)=>table[index] < value);\n let hi = table.length - 1;\n let lo = 0;\n let mid;\n while(hi - lo > 1){\n mid = lo + hi >> 1;\n if (cmp(mid)) {\n lo = mid;\n } else {\n hi = mid;\n }\n }\n return {\n lo,\n hi\n };\n}\n/**\n * Binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @param last - lookup last index\n * @private\n */ const _lookupByKey = (table, key, value, last)=>_lookup(table, value, last ? (index)=>{\n const ti = table[index][key];\n return ti < value || ti === value && table[index + 1][key] === value;\n } : (index)=>table[index][key] < value);\n/**\n * Reverse binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @private\n */ const _rlookupByKey = (table, key, value)=>_lookup(table, value, (index)=>table[index][key] >= value);\n/**\n * Return subset of `values` between `min` and `max` inclusive.\n * Values are assumed to be in sorted order.\n * @param values - sorted array of values\n * @param min - min value\n * @param max - max value\n */ function _filterBetween(values, min, max) {\n let start = 0;\n let end = values.length;\n while(start < end && values[start] < min){\n start++;\n }\n while(end > start && values[end - 1] > max){\n end--;\n }\n return start > 0 || end < values.length ? values.slice(start, end) : values;\n}\nconst arrayEvents = [\n 'push',\n 'pop',\n 'shift',\n 'splice',\n 'unshift'\n];\nfunction listenArrayEvents(array, listener) {\n if (array._chartjs) {\n array._chartjs.listeners.push(listener);\n return;\n }\n Object.defineProperty(array, '_chartjs', {\n configurable: true,\n enumerable: false,\n value: {\n listeners: [\n listener\n ]\n }\n });\n arrayEvents.forEach((key)=>{\n const method = '_onData' + _capitalize(key);\n const base = array[key];\n Object.defineProperty(array, key, {\n configurable: true,\n enumerable: false,\n value (...args) {\n const res = base.apply(this, args);\n array._chartjs.listeners.forEach((object)=>{\n if (typeof object[method] === 'function') {\n object[method](...args);\n }\n });\n return res;\n }\n });\n });\n}\nfunction unlistenArrayEvents(array, listener) {\n const stub = array._chartjs;\n if (!stub) {\n return;\n }\n const listeners = stub.listeners;\n const index = listeners.indexOf(listener);\n if (index !== -1) {\n listeners.splice(index, 1);\n }\n if (listeners.length > 0) {\n return;\n }\n arrayEvents.forEach((key)=>{\n delete array[key];\n });\n delete array._chartjs;\n}\n/**\n * @param items\n */ function _arrayUnique(items) {\n const set = new Set(items);\n if (set.size === items.length) {\n return items;\n }\n return Array.from(set);\n}\n\nfunction fontString(pixelSize, fontStyle, fontFamily) {\n return fontStyle + ' ' + pixelSize + 'px ' + fontFamily;\n}\n/**\n* Request animation polyfill\n*/ const requestAnimFrame = function() {\n if (typeof window === 'undefined') {\n return function(callback) {\n return callback();\n };\n }\n return window.requestAnimationFrame;\n}();\n/**\n * Throttles calling `fn` once per animation frame\n * Latest arguments are used on the actual call\n */ function throttled(fn, thisArg) {\n let argsToUse = [];\n let ticking = false;\n return function(...args) {\n // Save the args for use later\n argsToUse = args;\n if (!ticking) {\n ticking = true;\n requestAnimFrame.call(window, ()=>{\n ticking = false;\n fn.apply(thisArg, argsToUse);\n });\n }\n };\n}\n/**\n * Debounces calling `fn` for `delay` ms\n */ function debounce(fn, delay) {\n let timeout;\n return function(...args) {\n if (delay) {\n clearTimeout(timeout);\n timeout = setTimeout(fn, delay, args);\n } else {\n fn.apply(this, args);\n }\n return delay;\n };\n}\n/**\n * Converts 'start' to 'left', 'end' to 'right' and others to 'center'\n * @private\n */ const _toLeftRightCenter = (align)=>align === 'start' ? 'left' : align === 'end' ? 'right' : 'center';\n/**\n * Returns `start`, `end` or `(start + end) / 2` depending on `align`. Defaults to `center`\n * @private\n */ const _alignStartEnd = (align, start, end)=>align === 'start' ? start : align === 'end' ? end : (start + end) / 2;\n/**\n * Returns `left`, `right` or `(left + right) / 2` depending on `align`. Defaults to `left`\n * @private\n */ const _textX = (align, left, right, rtl)=>{\n const check = rtl ? 'left' : 'right';\n return align === check ? right : align === 'center' ? (left + right) / 2 : left;\n};\n/**\n * Return start and count of visible points.\n * @private\n */ function _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled) {\n const pointCount = points.length;\n let start = 0;\n let count = pointCount;\n if (meta._sorted) {\n const { iScale , _parsed } = meta;\n const axis = iScale.axis;\n const { min , max , minDefined , maxDefined } = iScale.getUserBounds();\n if (minDefined) {\n start = _limitValue(Math.min(// @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, axis, min).lo, // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? pointCount : _lookupByKey(points, axis, iScale.getPixelForValue(min)).lo), 0, pointCount - 1);\n }\n if (maxDefined) {\n count = _limitValue(Math.max(// @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, iScale.axis, max, true).hi + 1, // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? 0 : _lookupByKey(points, axis, iScale.getPixelForValue(max), true).hi + 1), start, pointCount) - start;\n } else {\n count = pointCount - start;\n }\n }\n return {\n start,\n count\n };\n}\n/**\n * Checks if the scale ranges have changed.\n * @param {object} meta - dataset meta.\n * @returns {boolean}\n * @private\n */ function _scaleRangesChanged(meta) {\n const { xScale , yScale , _scaleRanges } = meta;\n const newRanges = {\n xmin: xScale.min,\n xmax: xScale.max,\n ymin: yScale.min,\n ymax: yScale.max\n };\n if (!_scaleRanges) {\n meta._scaleRanges = newRanges;\n return true;\n }\n const changed = _scaleRanges.xmin !== xScale.min || _scaleRanges.xmax !== xScale.max || _scaleRanges.ymin !== yScale.min || _scaleRanges.ymax !== yScale.max;\n Object.assign(_scaleRanges, newRanges);\n return changed;\n}\n\nconst atEdge = (t)=>t === 0 || t === 1;\nconst elasticIn = (t, s, p)=>-(Math.pow(2, 10 * (t -= 1)) * Math.sin((t - s) * TAU / p));\nconst elasticOut = (t, s, p)=>Math.pow(2, -10 * t) * Math.sin((t - s) * TAU / p) + 1;\n/**\n * Easing functions adapted from Robert Penner's easing equations.\n * @namespace Chart.helpers.easing.effects\n * @see http://www.robertpenner.com/easing/\n */ const effects = {\n linear: (t)=>t,\n easeInQuad: (t)=>t * t,\n easeOutQuad: (t)=>-t * (t - 2),\n easeInOutQuad: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t : -0.5 * (--t * (t - 2) - 1),\n easeInCubic: (t)=>t * t * t,\n easeOutCubic: (t)=>(t -= 1) * t * t + 1,\n easeInOutCubic: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t : 0.5 * ((t -= 2) * t * t + 2),\n easeInQuart: (t)=>t * t * t * t,\n easeOutQuart: (t)=>-((t -= 1) * t * t * t - 1),\n easeInOutQuart: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t * t : -0.5 * ((t -= 2) * t * t * t - 2),\n easeInQuint: (t)=>t * t * t * t * t,\n easeOutQuint: (t)=>(t -= 1) * t * t * t * t + 1,\n easeInOutQuint: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t * t * t : 0.5 * ((t -= 2) * t * t * t * t + 2),\n easeInSine: (t)=>-Math.cos(t * HALF_PI) + 1,\n easeOutSine: (t)=>Math.sin(t * HALF_PI),\n easeInOutSine: (t)=>-0.5 * (Math.cos(PI * t) - 1),\n easeInExpo: (t)=>t === 0 ? 0 : Math.pow(2, 10 * (t - 1)),\n easeOutExpo: (t)=>t === 1 ? 1 : -Math.pow(2, -10 * t) + 1,\n easeInOutExpo: (t)=>atEdge(t) ? t : t < 0.5 ? 0.5 * Math.pow(2, 10 * (t * 2 - 1)) : 0.5 * (-Math.pow(2, -10 * (t * 2 - 1)) + 2),\n easeInCirc: (t)=>t >= 1 ? t : -(Math.sqrt(1 - t * t) - 1),\n easeOutCirc: (t)=>Math.sqrt(1 - (t -= 1) * t),\n easeInOutCirc: (t)=>(t /= 0.5) < 1 ? -0.5 * (Math.sqrt(1 - t * t) - 1) : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1),\n easeInElastic: (t)=>atEdge(t) ? t : elasticIn(t, 0.075, 0.3),\n easeOutElastic: (t)=>atEdge(t) ? t : elasticOut(t, 0.075, 0.3),\n easeInOutElastic (t) {\n const s = 0.1125;\n const p = 0.45;\n return atEdge(t) ? t : t < 0.5 ? 0.5 * elasticIn(t * 2, s, p) : 0.5 + 0.5 * elasticOut(t * 2 - 1, s, p);\n },\n easeInBack (t) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n },\n easeOutBack (t) {\n const s = 1.70158;\n return (t -= 1) * t * ((s + 1) * t + s) + 1;\n },\n easeInOutBack (t) {\n let s = 1.70158;\n if ((t /= 0.5) < 1) {\n return 0.5 * (t * t * (((s *= 1.525) + 1) * t - s));\n }\n return 0.5 * ((t -= 2) * t * (((s *= 1.525) + 1) * t + s) + 2);\n },\n easeInBounce: (t)=>1 - effects.easeOutBounce(1 - t),\n easeOutBounce (t) {\n const m = 7.5625;\n const d = 2.75;\n if (t < 1 / d) {\n return m * t * t;\n }\n if (t < 2 / d) {\n return m * (t -= 1.5 / d) * t + 0.75;\n }\n if (t < 2.5 / d) {\n return m * (t -= 2.25 / d) * t + 0.9375;\n }\n return m * (t -= 2.625 / d) * t + 0.984375;\n },\n easeInOutBounce: (t)=>t < 0.5 ? effects.easeInBounce(t * 2) * 0.5 : effects.easeOutBounce(t * 2 - 1) * 0.5 + 0.5\n};\n\nfunction isPatternOrGradient(value) {\n if (value && typeof value === 'object') {\n const type = value.toString();\n return type === '[object CanvasPattern]' || type === '[object CanvasGradient]';\n }\n return false;\n}\nfunction color(value) {\n return isPatternOrGradient(value) ? value : new Color(value);\n}\nfunction getHoverColor(value) {\n return isPatternOrGradient(value) ? value : new Color(value).saturate(0.5).darken(0.1).hexString();\n}\n\nconst numbers = [\n 'x',\n 'y',\n 'borderWidth',\n 'radius',\n 'tension'\n];\nconst colors = [\n 'color',\n 'borderColor',\n 'backgroundColor'\n];\nfunction applyAnimationsDefaults(defaults) {\n defaults.set('animation', {\n delay: undefined,\n duration: 1000,\n easing: 'easeOutQuart',\n fn: undefined,\n from: undefined,\n loop: undefined,\n to: undefined,\n type: undefined\n });\n defaults.describe('animation', {\n _fallback: false,\n _indexable: false,\n _scriptable: (name)=>name !== 'onProgress' && name !== 'onComplete' && name !== 'fn'\n });\n defaults.set('animations', {\n colors: {\n type: 'color',\n properties: colors\n },\n numbers: {\n type: 'number',\n properties: numbers\n }\n });\n defaults.describe('animations', {\n _fallback: 'animation'\n });\n defaults.set('transitions', {\n active: {\n animation: {\n duration: 400\n }\n },\n resize: {\n animation: {\n duration: 0\n }\n },\n show: {\n animations: {\n colors: {\n from: 'transparent'\n },\n visible: {\n type: 'boolean',\n duration: 0\n }\n }\n },\n hide: {\n animations: {\n colors: {\n to: 'transparent'\n },\n visible: {\n type: 'boolean',\n easing: 'linear',\n fn: (v)=>v | 0\n }\n }\n }\n });\n}\n\nfunction applyLayoutsDefaults(defaults) {\n defaults.set('layout', {\n autoPadding: true,\n padding: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n }\n });\n}\n\nconst intlCache = new Map();\nfunction getNumberFormat(locale, options) {\n options = options || {};\n const cacheKey = locale + JSON.stringify(options);\n let formatter = intlCache.get(cacheKey);\n if (!formatter) {\n formatter = new Intl.NumberFormat(locale, options);\n intlCache.set(cacheKey, formatter);\n }\n return formatter;\n}\nfunction formatNumber(num, locale, options) {\n return getNumberFormat(locale, options).format(num);\n}\n\nconst formatters = {\n values (value) {\n return isArray(value) ? value : '' + value;\n },\n numeric (tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const locale = this.chart.options.locale;\n let notation;\n let delta = tickValue;\n if (ticks.length > 1) {\n const maxTick = Math.max(Math.abs(ticks[0].value), Math.abs(ticks[ticks.length - 1].value));\n if (maxTick < 1e-4 || maxTick > 1e+15) {\n notation = 'scientific';\n }\n delta = calculateDelta(tickValue, ticks);\n }\n const logDelta = log10(Math.abs(delta));\n const numDecimal = isNaN(logDelta) ? 1 : Math.max(Math.min(-1 * Math.floor(logDelta), 20), 0);\n const options = {\n notation,\n minimumFractionDigits: numDecimal,\n maximumFractionDigits: numDecimal\n };\n Object.assign(options, this.options.ticks.format);\n return formatNumber(tickValue, locale, options);\n },\n logarithmic (tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const remain = ticks[index].significand || tickValue / Math.pow(10, Math.floor(log10(tickValue)));\n if ([\n 1,\n 2,\n 3,\n 5,\n 10,\n 15\n ].includes(remain) || index > 0.8 * ticks.length) {\n return formatters.numeric.call(this, tickValue, index, ticks);\n }\n return '';\n }\n};\nfunction calculateDelta(tickValue, ticks) {\n let delta = ticks.length > 3 ? ticks[2].value - ticks[1].value : ticks[1].value - ticks[0].value;\n if (Math.abs(delta) >= 1 && tickValue !== Math.floor(tickValue)) {\n delta = tickValue - Math.floor(tickValue);\n }\n return delta;\n}\n var Ticks = {\n formatters\n};\n\nfunction applyScaleDefaults(defaults) {\n defaults.set('scale', {\n display: true,\n offset: false,\n reverse: false,\n beginAtZero: false,\n bounds: 'ticks',\n clip: true,\n grace: 0,\n grid: {\n display: true,\n lineWidth: 1,\n drawOnChartArea: true,\n drawTicks: true,\n tickLength: 8,\n tickWidth: (_ctx, options)=>options.lineWidth,\n tickColor: (_ctx, options)=>options.color,\n offset: false\n },\n border: {\n display: true,\n dash: [],\n dashOffset: 0.0,\n width: 1\n },\n title: {\n display: false,\n text: '',\n padding: {\n top: 4,\n bottom: 4\n }\n },\n ticks: {\n minRotation: 0,\n maxRotation: 50,\n mirror: false,\n textStrokeWidth: 0,\n textStrokeColor: '',\n padding: 3,\n display: true,\n autoSkip: true,\n autoSkipPadding: 3,\n labelOffset: 0,\n callback: Ticks.formatters.values,\n minor: {},\n major: {},\n align: 'center',\n crossAlign: 'near',\n showLabelBackdrop: false,\n backdropColor: 'rgba(255, 255, 255, 0.75)',\n backdropPadding: 2\n }\n });\n defaults.route('scale.ticks', 'color', '', 'color');\n defaults.route('scale.grid', 'color', '', 'borderColor');\n defaults.route('scale.border', 'color', '', 'borderColor');\n defaults.route('scale.title', 'color', '', 'color');\n defaults.describe('scale', {\n _fallback: false,\n _scriptable: (name)=>!name.startsWith('before') && !name.startsWith('after') && name !== 'callback' && name !== 'parser',\n _indexable: (name)=>name !== 'borderDash' && name !== 'tickBorderDash' && name !== 'dash'\n });\n defaults.describe('scales', {\n _fallback: 'scale'\n });\n defaults.describe('scale.ticks', {\n _scriptable: (name)=>name !== 'backdropPadding' && name !== 'callback',\n _indexable: (name)=>name !== 'backdropPadding'\n });\n}\n\nconst overrides = Object.create(null);\nconst descriptors = Object.create(null);\n function getScope$1(node, key) {\n if (!key) {\n return node;\n }\n const keys = key.split('.');\n for(let i = 0, n = keys.length; i < n; ++i){\n const k = keys[i];\n node = node[k] || (node[k] = Object.create(null));\n }\n return node;\n}\nfunction set(root, scope, values) {\n if (typeof scope === 'string') {\n return merge(getScope$1(root, scope), values);\n }\n return merge(getScope$1(root, ''), scope);\n}\n class Defaults {\n constructor(_descriptors, _appliers){\n this.animation = undefined;\n this.backgroundColor = 'rgba(0,0,0,0.1)';\n this.borderColor = 'rgba(0,0,0,0.1)';\n this.color = '#666';\n this.datasets = {};\n this.devicePixelRatio = (context)=>context.chart.platform.getDevicePixelRatio();\n this.elements = {};\n this.events = [\n 'mousemove',\n 'mouseout',\n 'click',\n 'touchstart',\n 'touchmove'\n ];\n this.font = {\n family: \"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif\",\n size: 12,\n style: 'normal',\n lineHeight: 1.2,\n weight: null\n };\n this.hover = {};\n this.hoverBackgroundColor = (ctx, options)=>getHoverColor(options.backgroundColor);\n this.hoverBorderColor = (ctx, options)=>getHoverColor(options.borderColor);\n this.hoverColor = (ctx, options)=>getHoverColor(options.color);\n this.indexAxis = 'x';\n this.interaction = {\n mode: 'nearest',\n intersect: true,\n includeInvisible: false\n };\n this.maintainAspectRatio = true;\n this.onHover = null;\n this.onClick = null;\n this.parsing = true;\n this.plugins = {};\n this.responsive = true;\n this.scale = undefined;\n this.scales = {};\n this.showLine = true;\n this.drawActiveElementsOnTop = true;\n this.describe(_descriptors);\n this.apply(_appliers);\n }\n set(scope, values) {\n return set(this, scope, values);\n }\n get(scope) {\n return getScope$1(this, scope);\n }\n describe(scope, values) {\n return set(descriptors, scope, values);\n }\n override(scope, values) {\n return set(overrides, scope, values);\n }\n route(scope, name, targetScope, targetName) {\n const scopeObject = getScope$1(this, scope);\n const targetScopeObject = getScope$1(this, targetScope);\n const privateName = '_' + name;\n Object.defineProperties(scopeObject, {\n [privateName]: {\n value: scopeObject[name],\n writable: true\n },\n [name]: {\n enumerable: true,\n get () {\n const local = this[privateName];\n const target = targetScopeObject[targetName];\n if (isObject(local)) {\n return Object.assign({}, target, local);\n }\n return valueOrDefault(local, target);\n },\n set (value) {\n this[privateName] = value;\n }\n }\n });\n }\n apply(appliers) {\n appliers.forEach((apply)=>apply(this));\n }\n}\nvar defaults = /* #__PURE__ */ new Defaults({\n _scriptable: (name)=>!name.startsWith('on'),\n _indexable: (name)=>name !== 'events',\n hover: {\n _fallback: 'interaction'\n },\n interaction: {\n _scriptable: false,\n _indexable: false\n }\n}, [\n applyAnimationsDefaults,\n applyLayoutsDefaults,\n applyScaleDefaults\n]);\n\n/**\n * Converts the given font object into a CSS font string.\n * @param font - A font object.\n * @return The CSS font string. See https://developer.mozilla.org/en-US/docs/Web/CSS/font\n * @private\n */ function toFontString(font) {\n if (!font || isNullOrUndef(font.size) || isNullOrUndef(font.family)) {\n return null;\n }\n return (font.style ? font.style + ' ' : '') + (font.weight ? font.weight + ' ' : '') + font.size + 'px ' + font.family;\n}\n/**\n * @private\n */ function _measureText(ctx, data, gc, longest, string) {\n let textWidth = data[string];\n if (!textWidth) {\n textWidth = data[string] = ctx.measureText(string).width;\n gc.push(string);\n }\n if (textWidth > longest) {\n longest = textWidth;\n }\n return longest;\n}\n/**\n * @private\n */ // eslint-disable-next-line complexity\nfunction _longestText(ctx, font, arrayOfThings, cache) {\n cache = cache || {};\n let data = cache.data = cache.data || {};\n let gc = cache.garbageCollect = cache.garbageCollect || [];\n if (cache.font !== font) {\n data = cache.data = {};\n gc = cache.garbageCollect = [];\n cache.font = font;\n }\n ctx.save();\n ctx.font = font;\n let longest = 0;\n const ilen = arrayOfThings.length;\n let i, j, jlen, thing, nestedThing;\n for(i = 0; i < ilen; i++){\n thing = arrayOfThings[i];\n // Undefined strings and arrays should not be measured\n if (thing !== undefined && thing !== null && !isArray(thing)) {\n longest = _measureText(ctx, data, gc, longest, thing);\n } else if (isArray(thing)) {\n // if it is an array lets measure each element\n // to do maybe simplify this function a bit so we can do this more recursively?\n for(j = 0, jlen = thing.length; j < jlen; j++){\n nestedThing = thing[j];\n // Undefined strings and arrays should not be measured\n if (nestedThing !== undefined && nestedThing !== null && !isArray(nestedThing)) {\n longest = _measureText(ctx, data, gc, longest, nestedThing);\n }\n }\n }\n }\n ctx.restore();\n const gcLen = gc.length / 2;\n if (gcLen > arrayOfThings.length) {\n for(i = 0; i < gcLen; i++){\n delete data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n return longest;\n}\n/**\n * Returns the aligned pixel value to avoid anti-aliasing blur\n * @param chart - The chart instance.\n * @param pixel - A pixel value.\n * @param width - The width of the element.\n * @returns The aligned pixel value.\n * @private\n */ function _alignPixel(chart, pixel, width) {\n const devicePixelRatio = chart.currentDevicePixelRatio;\n const halfWidth = width !== 0 ? Math.max(width / 2, 0.5) : 0;\n return Math.round((pixel - halfWidth) * devicePixelRatio) / devicePixelRatio + halfWidth;\n}\n/**\n * Clears the entire canvas.\n */ function clearCanvas(canvas, ctx) {\n if (!ctx && !canvas) {\n return;\n }\n ctx = ctx || canvas.getContext('2d');\n ctx.save();\n // canvas.width and canvas.height do not consider the canvas transform,\n // while clearRect does\n ctx.resetTransform();\n ctx.clearRect(0, 0, canvas.width, canvas.height);\n ctx.restore();\n}\nfunction drawPoint(ctx, options, x, y) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n drawPointLegend(ctx, options, x, y, null);\n}\n// eslint-disable-next-line complexity\nfunction drawPointLegend(ctx, options, x, y, w) {\n let type, xOffset, yOffset, size, cornerRadius, width, xOffsetW, yOffsetW;\n const style = options.pointStyle;\n const rotation = options.rotation;\n const radius = options.radius;\n let rad = (rotation || 0) * RAD_PER_DEG;\n if (style && typeof style === 'object') {\n type = style.toString();\n if (type === '[object HTMLImageElement]' || type === '[object HTMLCanvasElement]') {\n ctx.save();\n ctx.translate(x, y);\n ctx.rotate(rad);\n ctx.drawImage(style, -style.width / 2, -style.height / 2, style.width, style.height);\n ctx.restore();\n return;\n }\n }\n if (isNaN(radius) || radius <= 0) {\n return;\n }\n ctx.beginPath();\n switch(style){\n // Default includes circle\n default:\n if (w) {\n ctx.ellipse(x, y, w / 2, radius, 0, 0, TAU);\n } else {\n ctx.arc(x, y, radius, 0, TAU);\n }\n ctx.closePath();\n break;\n case 'triangle':\n width = w ? w / 2 : radius;\n ctx.moveTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n ctx.closePath();\n break;\n case 'rectRounded':\n // NOTE: the rounded rect implementation changed to use `arc` instead of\n // `quadraticCurveTo` since it generates better results when rect is\n // almost a circle. 0.516 (instead of 0.5) produces results with visually\n // closer proportion to the previous impl and it is inscribed in the\n // circle with `radius`. For more details, see the following PRs:\n // https://github.com/chartjs/Chart.js/issues/5597\n // https://github.com/chartjs/Chart.js/issues/5858\n cornerRadius = radius * 0.516;\n size = radius - cornerRadius;\n xOffset = Math.cos(rad + QUARTER_PI) * size;\n xOffsetW = Math.cos(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n yOffset = Math.sin(rad + QUARTER_PI) * size;\n yOffsetW = Math.sin(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n ctx.arc(x - xOffsetW, y - yOffset, cornerRadius, rad - PI, rad - HALF_PI);\n ctx.arc(x + yOffsetW, y - xOffset, cornerRadius, rad - HALF_PI, rad);\n ctx.arc(x + xOffsetW, y + yOffset, cornerRadius, rad, rad + HALF_PI);\n ctx.arc(x - yOffsetW, y + xOffset, cornerRadius, rad + HALF_PI, rad + PI);\n ctx.closePath();\n break;\n case 'rect':\n if (!rotation) {\n size = Math.SQRT1_2 * radius;\n width = w ? w / 2 : size;\n ctx.rect(x - width, y - size, 2 * width, 2 * size);\n break;\n }\n rad += QUARTER_PI;\n /* falls through */ case 'rectRot':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n ctx.closePath();\n break;\n case 'crossRot':\n rad += QUARTER_PI;\n /* falls through */ case 'cross':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'star':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n rad += QUARTER_PI;\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'line':\n xOffset = w ? w / 2 : Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n ctx.moveTo(x - xOffset, y - yOffset);\n ctx.lineTo(x + xOffset, y + yOffset);\n break;\n case 'dash':\n ctx.moveTo(x, y);\n ctx.lineTo(x + Math.cos(rad) * (w ? w / 2 : radius), y + Math.sin(rad) * radius);\n break;\n case false:\n ctx.closePath();\n break;\n }\n ctx.fill();\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n}\n/**\n * Returns true if the point is inside the rectangle\n * @param point - The point to test\n * @param area - The rectangle\n * @param margin - allowed margin\n * @private\n */ function _isPointInArea(point, area, margin) {\n margin = margin || 0.5; // margin - default is to match rounded decimals\n return !area || point && point.x > area.left - margin && point.x < area.right + margin && point.y > area.top - margin && point.y < area.bottom + margin;\n}\nfunction clipArea(ctx, area) {\n ctx.save();\n ctx.beginPath();\n ctx.rect(area.left, area.top, area.right - area.left, area.bottom - area.top);\n ctx.clip();\n}\nfunction unclipArea(ctx) {\n ctx.restore();\n}\n/**\n * @private\n */ function _steppedLineTo(ctx, previous, target, flip, mode) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n if (mode === 'middle') {\n const midpoint = (previous.x + target.x) / 2.0;\n ctx.lineTo(midpoint, previous.y);\n ctx.lineTo(midpoint, target.y);\n } else if (mode === 'after' !== !!flip) {\n ctx.lineTo(previous.x, target.y);\n } else {\n ctx.lineTo(target.x, previous.y);\n }\n ctx.lineTo(target.x, target.y);\n}\n/**\n * @private\n */ function _bezierCurveTo(ctx, previous, target, flip) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n ctx.bezierCurveTo(flip ? previous.cp1x : previous.cp2x, flip ? previous.cp1y : previous.cp2y, flip ? target.cp2x : target.cp1x, flip ? target.cp2y : target.cp1y, target.x, target.y);\n}\nfunction setRenderOpts(ctx, opts) {\n if (opts.translation) {\n ctx.translate(opts.translation[0], opts.translation[1]);\n }\n if (!isNullOrUndef(opts.rotation)) {\n ctx.rotate(opts.rotation);\n }\n if (opts.color) {\n ctx.fillStyle = opts.color;\n }\n if (opts.textAlign) {\n ctx.textAlign = opts.textAlign;\n }\n if (opts.textBaseline) {\n ctx.textBaseline = opts.textBaseline;\n }\n}\nfunction decorateText(ctx, x, y, line, opts) {\n if (opts.strikethrough || opts.underline) {\n /**\n * Now that IE11 support has been dropped, we can use more\n * of the TextMetrics object. The actual bounding boxes\n * are unflagged in Chrome, Firefox, Edge, and Safari so they\n * can be safely used.\n * See https://developer.mozilla.org/en-US/docs/Web/API/TextMetrics#Browser_compatibility\n */ const metrics = ctx.measureText(line);\n const left = x - metrics.actualBoundingBoxLeft;\n const right = x + metrics.actualBoundingBoxRight;\n const top = y - metrics.actualBoundingBoxAscent;\n const bottom = y + metrics.actualBoundingBoxDescent;\n const yDecoration = opts.strikethrough ? (top + bottom) / 2 : bottom;\n ctx.strokeStyle = ctx.fillStyle;\n ctx.beginPath();\n ctx.lineWidth = opts.decorationWidth || 2;\n ctx.moveTo(left, yDecoration);\n ctx.lineTo(right, yDecoration);\n ctx.stroke();\n }\n}\nfunction drawBackdrop(ctx, opts) {\n const oldColor = ctx.fillStyle;\n ctx.fillStyle = opts.color;\n ctx.fillRect(opts.left, opts.top, opts.width, opts.height);\n ctx.fillStyle = oldColor;\n}\n/**\n * Render text onto the canvas\n */ function renderText(ctx, text, x, y, font, opts = {}) {\n const lines = isArray(text) ? text : [\n text\n ];\n const stroke = opts.strokeWidth > 0 && opts.strokeColor !== '';\n let i, line;\n ctx.save();\n ctx.font = font.string;\n setRenderOpts(ctx, opts);\n for(i = 0; i < lines.length; ++i){\n line = lines[i];\n if (opts.backdrop) {\n drawBackdrop(ctx, opts.backdrop);\n }\n if (stroke) {\n if (opts.strokeColor) {\n ctx.strokeStyle = opts.strokeColor;\n }\n if (!isNullOrUndef(opts.strokeWidth)) {\n ctx.lineWidth = opts.strokeWidth;\n }\n ctx.strokeText(line, x, y, opts.maxWidth);\n }\n ctx.fillText(line, x, y, opts.maxWidth);\n decorateText(ctx, x, y, line, opts);\n y += Number(font.lineHeight);\n }\n ctx.restore();\n}\n/**\n * Add a path of a rectangle with rounded corners to the current sub-path\n * @param ctx - Context\n * @param rect - Bounding rect\n */ function addRoundedRectPath(ctx, rect) {\n const { x , y , w , h , radius } = rect;\n // top left arc\n ctx.arc(x + radius.topLeft, y + radius.topLeft, radius.topLeft, 1.5 * PI, PI, true);\n // line from top left to bottom left\n ctx.lineTo(x, y + h - radius.bottomLeft);\n // bottom left arc\n ctx.arc(x + radius.bottomLeft, y + h - radius.bottomLeft, radius.bottomLeft, PI, HALF_PI, true);\n // line from bottom left to bottom right\n ctx.lineTo(x + w - radius.bottomRight, y + h);\n // bottom right arc\n ctx.arc(x + w - radius.bottomRight, y + h - radius.bottomRight, radius.bottomRight, HALF_PI, 0, true);\n // line from bottom right to top right\n ctx.lineTo(x + w, y + radius.topRight);\n // top right arc\n ctx.arc(x + w - radius.topRight, y + radius.topRight, radius.topRight, 0, -HALF_PI, true);\n // line from top right to top left\n ctx.lineTo(x + radius.topLeft, y);\n}\n\nconst LINE_HEIGHT = /^(normal|(\\d+(?:\\.\\d+)?)(px|em|%)?)$/;\nconst FONT_STYLE = /^(normal|italic|initial|inherit|unset|(oblique( -?[0-9]?[0-9]deg)?))$/;\n/**\n * @alias Chart.helpers.options\n * @namespace\n */ /**\n * Converts the given line height `value` in pixels for a specific font `size`.\n * @param value - The lineHeight to parse (eg. 1.6, '14px', '75%', '1.6em').\n * @param size - The font size (in pixels) used to resolve relative `value`.\n * @returns The effective line height in pixels (size * 1.2 if value is invalid).\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/line-height\n * @since 2.7.0\n */ function toLineHeight(value, size) {\n const matches = ('' + value).match(LINE_HEIGHT);\n if (!matches || matches[1] === 'normal') {\n return size * 1.2;\n }\n value = +matches[2];\n switch(matches[3]){\n case 'px':\n return value;\n case '%':\n value /= 100;\n break;\n }\n return size * value;\n}\nconst numberOrZero = (v)=>+v || 0;\nfunction _readValueToProps(value, props) {\n const ret = {};\n const objProps = isObject(props);\n const keys = objProps ? Object.keys(props) : props;\n const read = isObject(value) ? objProps ? (prop)=>valueOrDefault(value[prop], value[props[prop]]) : (prop)=>value[prop] : ()=>value;\n for (const prop of keys){\n ret[prop] = numberOrZero(read(prop));\n }\n return ret;\n}\n/**\n * Converts the given value into a TRBL object.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left)\n * @since 3.0.0\n */ function toTRBL(value) {\n return _readValueToProps(value, {\n top: 'y',\n right: 'x',\n bottom: 'y',\n left: 'x'\n });\n}\n/**\n * Converts the given value into a TRBL corners object (similar with css border-radius).\n * @param value - If a number, set the value to all TRBL corner components,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * @returns The TRBL corner values (topLeft, topRight, bottomLeft, bottomRight)\n * @since 3.0.0\n */ function toTRBLCorners(value) {\n return _readValueToProps(value, [\n 'topLeft',\n 'topRight',\n 'bottomLeft',\n 'bottomRight'\n ]);\n}\n/**\n * Converts the given value into a padding object with pre-computed width/height.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left, width, height)\n * @since 2.7.0\n */ function toPadding(value) {\n const obj = toTRBL(value);\n obj.width = obj.left + obj.right;\n obj.height = obj.top + obj.bottom;\n return obj;\n}\n/**\n * Parses font options and returns the font object.\n * @param options - A object that contains font options to be parsed.\n * @param fallback - A object that contains fallback font options.\n * @return The font object.\n * @private\n */ function toFont(options, fallback) {\n options = options || {};\n fallback = fallback || defaults.font;\n let size = valueOrDefault(options.size, fallback.size);\n if (typeof size === 'string') {\n size = parseInt(size, 10);\n }\n let style = valueOrDefault(options.style, fallback.style);\n if (style && !('' + style).match(FONT_STYLE)) {\n console.warn('Invalid font style specified: \"' + style + '\"');\n style = undefined;\n }\n const font = {\n family: valueOrDefault(options.family, fallback.family),\n lineHeight: toLineHeight(valueOrDefault(options.lineHeight, fallback.lineHeight), size),\n size,\n style,\n weight: valueOrDefault(options.weight, fallback.weight),\n string: ''\n };\n font.string = toFontString(font);\n return font;\n}\n/**\n * Evaluates the given `inputs` sequentially and returns the first defined value.\n * @param inputs - An array of values, falling back to the last value.\n * @param context - If defined and the current value is a function, the value\n * is called with `context` as first argument and the result becomes the new input.\n * @param index - If defined and the current value is an array, the value\n * at `index` become the new input.\n * @param info - object to return information about resolution in\n * @param info.cacheable - Will be set to `false` if option is not cacheable.\n * @since 2.7.0\n */ function resolve(inputs, context, index, info) {\n let cacheable = true;\n let i, ilen, value;\n for(i = 0, ilen = inputs.length; i < ilen; ++i){\n value = inputs[i];\n if (value === undefined) {\n continue;\n }\n if (context !== undefined && typeof value === 'function') {\n value = value(context);\n cacheable = false;\n }\n if (index !== undefined && isArray(value)) {\n value = value[index % value.length];\n cacheable = false;\n }\n if (value !== undefined) {\n if (info && !cacheable) {\n info.cacheable = false;\n }\n return value;\n }\n }\n}\n/**\n * @param minmax\n * @param grace\n * @param beginAtZero\n * @private\n */ function _addGrace(minmax, grace, beginAtZero) {\n const { min , max } = minmax;\n const change = toDimension(grace, (max - min) / 2);\n const keepZero = (value, add)=>beginAtZero && value === 0 ? 0 : value + add;\n return {\n min: keepZero(min, -Math.abs(change)),\n max: keepZero(max, change)\n };\n}\nfunction createContext(parentContext, context) {\n return Object.assign(Object.create(parentContext), context);\n}\n\n/**\n * Creates a Proxy for resolving raw values for options.\n * @param scopes - The option scopes to look for values, in resolution order\n * @param prefixes - The prefixes for values, in resolution order.\n * @param rootScopes - The root option scopes\n * @param fallback - Parent scopes fallback\n * @param getTarget - callback for getting the target for changed values\n * @returns Proxy\n * @private\n */ function _createResolver(scopes, prefixes = [\n ''\n], rootScopes, fallback, getTarget = ()=>scopes[0]) {\n const finalRootScopes = rootScopes || scopes;\n if (typeof fallback === 'undefined') {\n fallback = _resolve('_fallback', scopes);\n }\n const cache = {\n [Symbol.toStringTag]: 'Object',\n _cacheable: true,\n _scopes: scopes,\n _rootScopes: finalRootScopes,\n _fallback: fallback,\n _getTarget: getTarget,\n override: (scope)=>_createResolver([\n scope,\n ...scopes\n ], prefixes, finalRootScopes, fallback)\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */ deleteProperty (target, prop) {\n delete target[prop]; // remove from cache\n delete target._keys; // remove cached keys\n delete scopes[0][prop]; // remove from top level scope\n return true;\n },\n /**\n * A trap for getting property values.\n */ get (target, prop) {\n return _cached(target, prop, ()=>_resolveWithPrefixes(prop, prefixes, scopes, target));\n },\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */ getOwnPropertyDescriptor (target, prop) {\n return Reflect.getOwnPropertyDescriptor(target._scopes[0], prop);\n },\n /**\n * A trap for Object.getPrototypeOf.\n */ getPrototypeOf () {\n return Reflect.getPrototypeOf(scopes[0]);\n },\n /**\n * A trap for the in operator.\n */ has (target, prop) {\n return getKeysFromAllScopes(target).includes(prop);\n },\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */ ownKeys (target) {\n return getKeysFromAllScopes(target);\n },\n /**\n * A trap for setting property values.\n */ set (target, prop, value) {\n const storage = target._storage || (target._storage = getTarget());\n target[prop] = storage[prop] = value; // set to top level scope + cache\n delete target._keys; // remove cached keys\n return true;\n }\n });\n}\n/**\n * Returns an Proxy for resolving option values with context.\n * @param proxy - The Proxy returned by `_createResolver`\n * @param context - Context object for scriptable/indexable options\n * @param subProxy - The proxy provided for scriptable options\n * @param descriptorDefaults - Defaults for descriptors\n * @private\n */ function _attachContext(proxy, context, subProxy, descriptorDefaults) {\n const cache = {\n _cacheable: false,\n _proxy: proxy,\n _context: context,\n _subProxy: subProxy,\n _stack: new Set(),\n _descriptors: _descriptors(proxy, descriptorDefaults),\n setContext: (ctx)=>_attachContext(proxy, ctx, subProxy, descriptorDefaults),\n override: (scope)=>_attachContext(proxy.override(scope), context, subProxy, descriptorDefaults)\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */ deleteProperty (target, prop) {\n delete target[prop]; // remove from cache\n delete proxy[prop]; // remove from proxy\n return true;\n },\n /**\n * A trap for getting property values.\n */ get (target, prop, receiver) {\n return _cached(target, prop, ()=>_resolveWithContext(target, prop, receiver));\n },\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */ getOwnPropertyDescriptor (target, prop) {\n return target._descriptors.allKeys ? Reflect.has(proxy, prop) ? {\n enumerable: true,\n configurable: true\n } : undefined : Reflect.getOwnPropertyDescriptor(proxy, prop);\n },\n /**\n * A trap for Object.getPrototypeOf.\n */ getPrototypeOf () {\n return Reflect.getPrototypeOf(proxy);\n },\n /**\n * A trap for the in operator.\n */ has (target, prop) {\n return Reflect.has(proxy, prop);\n },\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */ ownKeys () {\n return Reflect.ownKeys(proxy);\n },\n /**\n * A trap for setting property values.\n */ set (target, prop, value) {\n proxy[prop] = value; // set to proxy\n delete target[prop]; // remove from cache\n return true;\n }\n });\n}\n/**\n * @private\n */ function _descriptors(proxy, defaults = {\n scriptable: true,\n indexable: true\n}) {\n const { _scriptable =defaults.scriptable , _indexable =defaults.indexable , _allKeys =defaults.allKeys } = proxy;\n return {\n allKeys: _allKeys,\n scriptable: _scriptable,\n indexable: _indexable,\n isScriptable: isFunction(_scriptable) ? _scriptable : ()=>_scriptable,\n isIndexable: isFunction(_indexable) ? _indexable : ()=>_indexable\n };\n}\nconst readKey = (prefix, name)=>prefix ? prefix + _capitalize(name) : name;\nconst needsSubResolver = (prop, value)=>isObject(value) && prop !== 'adapters' && (Object.getPrototypeOf(value) === null || value.constructor === Object);\nfunction _cached(target, prop, resolve) {\n if (Object.prototype.hasOwnProperty.call(target, prop) || prop === 'constructor') {\n return target[prop];\n }\n const value = resolve();\n // cache the resolved value\n target[prop] = value;\n return value;\n}\nfunction _resolveWithContext(target, prop, receiver) {\n const { _proxy , _context , _subProxy , _descriptors: descriptors } = target;\n let value = _proxy[prop]; // resolve from proxy\n // resolve with context\n if (isFunction(value) && descriptors.isScriptable(prop)) {\n value = _resolveScriptable(prop, value, target, receiver);\n }\n if (isArray(value) && value.length) {\n value = _resolveArray(prop, value, target, descriptors.isIndexable);\n }\n if (needsSubResolver(prop, value)) {\n // if the resolved value is an object, create a sub resolver for it\n value = _attachContext(value, _context, _subProxy && _subProxy[prop], descriptors);\n }\n return value;\n}\nfunction _resolveScriptable(prop, getValue, target, receiver) {\n const { _proxy , _context , _subProxy , _stack } = target;\n if (_stack.has(prop)) {\n throw new Error('Recursion detected: ' + Array.from(_stack).join('->') + '->' + prop);\n }\n _stack.add(prop);\n let value = getValue(_context, _subProxy || receiver);\n _stack.delete(prop);\n if (needsSubResolver(prop, value)) {\n // When scriptable option returns an object, create a resolver on that.\n value = createSubResolver(_proxy._scopes, _proxy, prop, value);\n }\n return value;\n}\nfunction _resolveArray(prop, value, target, isIndexable) {\n const { _proxy , _context , _subProxy , _descriptors: descriptors } = target;\n if (typeof _context.index !== 'undefined' && isIndexable(prop)) {\n return value[_context.index % value.length];\n } else if (isObject(value[0])) {\n // Array of objects, return array or resolvers\n const arr = value;\n const scopes = _proxy._scopes.filter((s)=>s !== arr);\n value = [];\n for (const item of arr){\n const resolver = createSubResolver(scopes, _proxy, prop, item);\n value.push(_attachContext(resolver, _context, _subProxy && _subProxy[prop], descriptors));\n }\n }\n return value;\n}\nfunction resolveFallback(fallback, prop, value) {\n return isFunction(fallback) ? fallback(prop, value) : fallback;\n}\nconst getScope = (key, parent)=>key === true ? parent : typeof key === 'string' ? resolveObjectKey(parent, key) : undefined;\nfunction addScopes(set, parentScopes, key, parentFallback, value) {\n for (const parent of parentScopes){\n const scope = getScope(key, parent);\n if (scope) {\n set.add(scope);\n const fallback = resolveFallback(scope._fallback, key, value);\n if (typeof fallback !== 'undefined' && fallback !== key && fallback !== parentFallback) {\n // When we reach the descriptor that defines a new _fallback, return that.\n // The fallback will resume to that new scope.\n return fallback;\n }\n } else if (scope === false && typeof parentFallback !== 'undefined' && key !== parentFallback) {\n // Fallback to `false` results to `false`, when falling back to different key.\n // For example `interaction` from `hover` or `plugins.tooltip` and `animation` from `animations`\n return null;\n }\n }\n return false;\n}\nfunction createSubResolver(parentScopes, resolver, prop, value) {\n const rootScopes = resolver._rootScopes;\n const fallback = resolveFallback(resolver._fallback, prop, value);\n const allScopes = [\n ...parentScopes,\n ...rootScopes\n ];\n const set = new Set();\n set.add(value);\n let key = addScopesFromKey(set, allScopes, prop, fallback || prop, value);\n if (key === null) {\n return false;\n }\n if (typeof fallback !== 'undefined' && fallback !== prop) {\n key = addScopesFromKey(set, allScopes, fallback, key, value);\n if (key === null) {\n return false;\n }\n }\n return _createResolver(Array.from(set), [\n ''\n ], rootScopes, fallback, ()=>subGetTarget(resolver, prop, value));\n}\nfunction addScopesFromKey(set, allScopes, key, fallback, item) {\n while(key){\n key = addScopes(set, allScopes, key, fallback, item);\n }\n return key;\n}\nfunction subGetTarget(resolver, prop, value) {\n const parent = resolver._getTarget();\n if (!(prop in parent)) {\n parent[prop] = {};\n }\n const target = parent[prop];\n if (isArray(target) && isObject(value)) {\n // For array of objects, the object is used to store updated values\n return value;\n }\n return target || {};\n}\nfunction _resolveWithPrefixes(prop, prefixes, scopes, proxy) {\n let value;\n for (const prefix of prefixes){\n value = _resolve(readKey(prefix, prop), scopes);\n if (typeof value !== 'undefined') {\n return needsSubResolver(prop, value) ? createSubResolver(scopes, proxy, prop, value) : value;\n }\n }\n}\nfunction _resolve(key, scopes) {\n for (const scope of scopes){\n if (!scope) {\n continue;\n }\n const value = scope[key];\n if (typeof value !== 'undefined') {\n return value;\n }\n }\n}\nfunction getKeysFromAllScopes(target) {\n let keys = target._keys;\n if (!keys) {\n keys = target._keys = resolveKeysFromAllScopes(target._scopes);\n }\n return keys;\n}\nfunction resolveKeysFromAllScopes(scopes) {\n const set = new Set();\n for (const scope of scopes){\n for (const key of Object.keys(scope).filter((k)=>!k.startsWith('_'))){\n set.add(key);\n }\n }\n return Array.from(set);\n}\nfunction _parseObjectDataRadialScale(meta, data, start, count) {\n const { iScale } = meta;\n const { key ='r' } = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n r: iScale.parse(resolveObjectKey(item, key), index)\n };\n }\n return parsed;\n}\n\nconst EPSILON = Number.EPSILON || 1e-14;\nconst getPoint = (points, i)=>i < points.length && !points[i].skip && points[i];\nconst getValueAxis = (indexAxis)=>indexAxis === 'x' ? 'y' : 'x';\nfunction splineCurve(firstPoint, middlePoint, afterPoint, t) {\n // Props to Rob Spencer at scaled innovation for his post on splining between points\n // http://scaledinnovation.com/analytics/splines/aboutSplines.html\n // This function must also respect \"skipped\" points\n const previous = firstPoint.skip ? middlePoint : firstPoint;\n const current = middlePoint;\n const next = afterPoint.skip ? middlePoint : afterPoint;\n const d01 = distanceBetweenPoints(current, previous);\n const d12 = distanceBetweenPoints(next, current);\n let s01 = d01 / (d01 + d12);\n let s12 = d12 / (d01 + d12);\n // If all points are the same, s01 & s02 will be inf\n s01 = isNaN(s01) ? 0 : s01;\n s12 = isNaN(s12) ? 0 : s12;\n const fa = t * s01; // scaling factor for triangle Ta\n const fb = t * s12;\n return {\n previous: {\n x: current.x - fa * (next.x - previous.x),\n y: current.y - fa * (next.y - previous.y)\n },\n next: {\n x: current.x + fb * (next.x - previous.x),\n y: current.y + fb * (next.y - previous.y)\n }\n };\n}\n/**\n * Adjust tangents to ensure monotonic properties\n */ function monotoneAdjust(points, deltaK, mK) {\n const pointsLen = points.length;\n let alphaK, betaK, tauK, squaredMagnitude, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(let i = 0; i < pointsLen - 1; ++i){\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent || !pointAfter) {\n continue;\n }\n if (almostEquals(deltaK[i], 0, EPSILON)) {\n mK[i] = mK[i + 1] = 0;\n continue;\n }\n alphaK = mK[i] / deltaK[i];\n betaK = mK[i + 1] / deltaK[i];\n squaredMagnitude = Math.pow(alphaK, 2) + Math.pow(betaK, 2);\n if (squaredMagnitude <= 9) {\n continue;\n }\n tauK = 3 / Math.sqrt(squaredMagnitude);\n mK[i] = alphaK * tauK * deltaK[i];\n mK[i + 1] = betaK * tauK * deltaK[i];\n }\n}\nfunction monotoneCompute(points, mK, indexAxis = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n let delta, pointBefore, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(let i = 0; i < pointsLen; ++i){\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n const iPixel = pointCurrent[indexAxis];\n const vPixel = pointCurrent[valueAxis];\n if (pointBefore) {\n delta = (iPixel - pointBefore[indexAxis]) / 3;\n pointCurrent[`cp1${indexAxis}`] = iPixel - delta;\n pointCurrent[`cp1${valueAxis}`] = vPixel - delta * mK[i];\n }\n if (pointAfter) {\n delta = (pointAfter[indexAxis] - iPixel) / 3;\n pointCurrent[`cp2${indexAxis}`] = iPixel + delta;\n pointCurrent[`cp2${valueAxis}`] = vPixel + delta * mK[i];\n }\n }\n}\n/**\n * This function calculates Bézier control points in a similar way than |splineCurve|,\n * but preserves monotonicity of the provided data and ensures no local extremums are added\n * between the dataset discrete points due to the interpolation.\n * See : https://en.wikipedia.org/wiki/Monotone_cubic_interpolation\n */ function splineCurveMonotone(points, indexAxis = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n const deltaK = Array(pointsLen).fill(0);\n const mK = Array(pointsLen);\n // Calculate slopes (deltaK) and initialize tangents (mK)\n let i, pointBefore, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(i = 0; i < pointsLen; ++i){\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n if (pointAfter) {\n const slopeDelta = pointAfter[indexAxis] - pointCurrent[indexAxis];\n // In the case of two points that appear at the same x pixel, slopeDeltaX is 0\n deltaK[i] = slopeDelta !== 0 ? (pointAfter[valueAxis] - pointCurrent[valueAxis]) / slopeDelta : 0;\n }\n mK[i] = !pointBefore ? deltaK[i] : !pointAfter ? deltaK[i - 1] : sign(deltaK[i - 1]) !== sign(deltaK[i]) ? 0 : (deltaK[i - 1] + deltaK[i]) / 2;\n }\n monotoneAdjust(points, deltaK, mK);\n monotoneCompute(points, mK, indexAxis);\n}\nfunction capControlPoint(pt, min, max) {\n return Math.max(Math.min(pt, max), min);\n}\nfunction capBezierPoints(points, area) {\n let i, ilen, point, inArea, inAreaPrev;\n let inAreaNext = _isPointInArea(points[0], area);\n for(i = 0, ilen = points.length; i < ilen; ++i){\n inAreaPrev = inArea;\n inArea = inAreaNext;\n inAreaNext = i < ilen - 1 && _isPointInArea(points[i + 1], area);\n if (!inArea) {\n continue;\n }\n point = points[i];\n if (inAreaPrev) {\n point.cp1x = capControlPoint(point.cp1x, area.left, area.right);\n point.cp1y = capControlPoint(point.cp1y, area.top, area.bottom);\n }\n if (inAreaNext) {\n point.cp2x = capControlPoint(point.cp2x, area.left, area.right);\n point.cp2y = capControlPoint(point.cp2y, area.top, area.bottom);\n }\n }\n}\n/**\n * @private\n */ function _updateBezierControlPoints(points, options, area, loop, indexAxis) {\n let i, ilen, point, controlPoints;\n // Only consider points that are drawn in case the spanGaps option is used\n if (options.spanGaps) {\n points = points.filter((pt)=>!pt.skip);\n }\n if (options.cubicInterpolationMode === 'monotone') {\n splineCurveMonotone(points, indexAxis);\n } else {\n let prev = loop ? points[points.length - 1] : points[0];\n for(i = 0, ilen = points.length; i < ilen; ++i){\n point = points[i];\n controlPoints = splineCurve(prev, point, points[Math.min(i + 1, ilen - (loop ? 0 : 1)) % ilen], options.tension);\n point.cp1x = controlPoints.previous.x;\n point.cp1y = controlPoints.previous.y;\n point.cp2x = controlPoints.next.x;\n point.cp2y = controlPoints.next.y;\n prev = point;\n }\n }\n if (options.capBezierPoints) {\n capBezierPoints(points, area);\n }\n}\n\n/**\n * Note: typedefs are auto-exported, so use a made-up `dom` namespace where\n * necessary to avoid duplicates with `export * from './helpers`; see\n * https://github.com/microsoft/TypeScript/issues/46011\n * @typedef { import('../core/core.controller.js').default } dom.Chart\n * @typedef { import('../../types').ChartEvent } ChartEvent\n */ /**\n * @private\n */ function _isDomSupported() {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n/**\n * @private\n */ function _getParentNode(domNode) {\n let parent = domNode.parentNode;\n if (parent && parent.toString() === '[object ShadowRoot]') {\n parent = parent.host;\n }\n return parent;\n}\n/**\n * convert max-width/max-height values that may be percentages into a number\n * @private\n */ function parseMaxStyle(styleValue, node, parentProperty) {\n let valueInPixels;\n if (typeof styleValue === 'string') {\n valueInPixels = parseInt(styleValue, 10);\n if (styleValue.indexOf('%') !== -1) {\n // percentage * size in dimension\n valueInPixels = valueInPixels / 100 * node.parentNode[parentProperty];\n }\n } else {\n valueInPixels = styleValue;\n }\n return valueInPixels;\n}\nconst getComputedStyle = (element)=>element.ownerDocument.defaultView.getComputedStyle(element, null);\nfunction getStyle(el, property) {\n return getComputedStyle(el).getPropertyValue(property);\n}\nconst positions = [\n 'top',\n 'right',\n 'bottom',\n 'left'\n];\nfunction getPositionedStyle(styles, style, suffix) {\n const result = {};\n suffix = suffix ? '-' + suffix : '';\n for(let i = 0; i < 4; i++){\n const pos = positions[i];\n result[pos] = parseFloat(styles[style + '-' + pos + suffix]) || 0;\n }\n result.width = result.left + result.right;\n result.height = result.top + result.bottom;\n return result;\n}\nconst useOffsetPos = (x, y, target)=>(x > 0 || y > 0) && (!target || !target.shadowRoot);\n/**\n * @param e\n * @param canvas\n * @returns Canvas position\n */ function getCanvasPosition(e, canvas) {\n const touches = e.touches;\n const source = touches && touches.length ? touches[0] : e;\n const { offsetX , offsetY } = source;\n let box = false;\n let x, y;\n if (useOffsetPos(offsetX, offsetY, e.target)) {\n x = offsetX;\n y = offsetY;\n } else {\n const rect = canvas.getBoundingClientRect();\n x = source.clientX - rect.left;\n y = source.clientY - rect.top;\n box = true;\n }\n return {\n x,\n y,\n box\n };\n}\n/**\n * Gets an event's x, y coordinates, relative to the chart area\n * @param event\n * @param chart\n * @returns x and y coordinates of the event\n */ function getRelativePosition(event, chart) {\n if ('native' in event) {\n return event;\n }\n const { canvas , currentDevicePixelRatio } = chart;\n const style = getComputedStyle(canvas);\n const borderBox = style.boxSizing === 'border-box';\n const paddings = getPositionedStyle(style, 'padding');\n const borders = getPositionedStyle(style, 'border', 'width');\n const { x , y , box } = getCanvasPosition(event, canvas);\n const xOffset = paddings.left + (box && borders.left);\n const yOffset = paddings.top + (box && borders.top);\n let { width , height } = chart;\n if (borderBox) {\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n return {\n x: Math.round((x - xOffset) / width * canvas.width / currentDevicePixelRatio),\n y: Math.round((y - yOffset) / height * canvas.height / currentDevicePixelRatio)\n };\n}\nfunction getContainerSize(canvas, width, height) {\n let maxWidth, maxHeight;\n if (width === undefined || height === undefined) {\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n width = canvas.clientWidth;\n height = canvas.clientHeight;\n } else {\n const rect = container.getBoundingClientRect(); // this is the border box of the container\n const containerStyle = getComputedStyle(container);\n const containerBorder = getPositionedStyle(containerStyle, 'border', 'width');\n const containerPadding = getPositionedStyle(containerStyle, 'padding');\n width = rect.width - containerPadding.width - containerBorder.width;\n height = rect.height - containerPadding.height - containerBorder.height;\n maxWidth = parseMaxStyle(containerStyle.maxWidth, container, 'clientWidth');\n maxHeight = parseMaxStyle(containerStyle.maxHeight, container, 'clientHeight');\n }\n }\n return {\n width,\n height,\n maxWidth: maxWidth || INFINITY,\n maxHeight: maxHeight || INFINITY\n };\n}\nconst round1 = (v)=>Math.round(v * 10) / 10;\n// eslint-disable-next-line complexity\nfunction getMaximumSize(canvas, bbWidth, bbHeight, aspectRatio) {\n const style = getComputedStyle(canvas);\n const margins = getPositionedStyle(style, 'margin');\n const maxWidth = parseMaxStyle(style.maxWidth, canvas, 'clientWidth') || INFINITY;\n const maxHeight = parseMaxStyle(style.maxHeight, canvas, 'clientHeight') || INFINITY;\n const containerSize = getContainerSize(canvas, bbWidth, bbHeight);\n let { width , height } = containerSize;\n if (style.boxSizing === 'content-box') {\n const borders = getPositionedStyle(style, 'border', 'width');\n const paddings = getPositionedStyle(style, 'padding');\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n width = Math.max(0, width - margins.width);\n height = Math.max(0, aspectRatio ? width / aspectRatio : height - margins.height);\n width = round1(Math.min(width, maxWidth, containerSize.maxWidth));\n height = round1(Math.min(height, maxHeight, containerSize.maxHeight));\n if (width && !height) {\n // https://github.com/chartjs/Chart.js/issues/4659\n // If the canvas has width, but no height, default to aspectRatio of 2 (canvas default)\n height = round1(width / 2);\n }\n const maintainHeight = bbWidth !== undefined || bbHeight !== undefined;\n if (maintainHeight && aspectRatio && containerSize.height && height > containerSize.height) {\n height = containerSize.height;\n width = round1(Math.floor(height * aspectRatio));\n }\n return {\n width,\n height\n };\n}\n/**\n * @param chart\n * @param forceRatio\n * @param forceStyle\n * @returns True if the canvas context size or transformation has changed.\n */ function retinaScale(chart, forceRatio, forceStyle) {\n const pixelRatio = forceRatio || 1;\n const deviceHeight = Math.floor(chart.height * pixelRatio);\n const deviceWidth = Math.floor(chart.width * pixelRatio);\n chart.height = Math.floor(chart.height);\n chart.width = Math.floor(chart.width);\n const canvas = chart.canvas;\n // If no style has been set on the canvas, the render size is used as display size,\n // making the chart visually bigger, so let's enforce it to the \"correct\" values.\n // See https://github.com/chartjs/Chart.js/issues/3575\n if (canvas.style && (forceStyle || !canvas.style.height && !canvas.style.width)) {\n canvas.style.height = `${chart.height}px`;\n canvas.style.width = `${chart.width}px`;\n }\n if (chart.currentDevicePixelRatio !== pixelRatio || canvas.height !== deviceHeight || canvas.width !== deviceWidth) {\n chart.currentDevicePixelRatio = pixelRatio;\n canvas.height = deviceHeight;\n canvas.width = deviceWidth;\n chart.ctx.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n return true;\n }\n return false;\n}\n/**\n * Detects support for options object argument in addEventListener.\n * https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support\n * @private\n */ const supportsEventListenerOptions = function() {\n let passiveSupported = false;\n try {\n const options = {\n get passive () {\n passiveSupported = true;\n return false;\n }\n };\n if (_isDomSupported()) {\n window.addEventListener('test', null, options);\n window.removeEventListener('test', null, options);\n }\n } catch (e) {\n // continue regardless of error\n }\n return passiveSupported;\n}();\n/**\n * The \"used\" size is the final value of a dimension property after all calculations have\n * been performed. This method uses the computed style of `element` but returns undefined\n * if the computed style is not expressed in pixels. That can happen in some cases where\n * `element` has a size relative to its parent and this last one is not yet displayed,\n * for example because of `display: none` on a parent node.\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/used_value\n * @returns Size in pixels or undefined if unknown.\n */ function readUsedSize(element, property) {\n const value = getStyle(element, property);\n const matches = value && value.match(/^(\\d+)(\\.\\d+)?px$/);\n return matches ? +matches[1] : undefined;\n}\n\n/**\n * @private\n */ function _pointInLine(p1, p2, t, mode) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: p1.y + t * (p2.y - p1.y)\n };\n}\n/**\n * @private\n */ function _steppedInterpolation(p1, p2, t, mode) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: mode === 'middle' ? t < 0.5 ? p1.y : p2.y : mode === 'after' ? t < 1 ? p1.y : p2.y : t > 0 ? p2.y : p1.y\n };\n}\n/**\n * @private\n */ function _bezierInterpolation(p1, p2, t, mode) {\n const cp1 = {\n x: p1.cp2x,\n y: p1.cp2y\n };\n const cp2 = {\n x: p2.cp1x,\n y: p2.cp1y\n };\n const a = _pointInLine(p1, cp1, t);\n const b = _pointInLine(cp1, cp2, t);\n const c = _pointInLine(cp2, p2, t);\n const d = _pointInLine(a, b, t);\n const e = _pointInLine(b, c, t);\n return _pointInLine(d, e, t);\n}\n\nconst getRightToLeftAdapter = function(rectX, width) {\n return {\n x (x) {\n return rectX + rectX + width - x;\n },\n setWidth (w) {\n width = w;\n },\n textAlign (align) {\n if (align === 'center') {\n return align;\n }\n return align === 'right' ? 'left' : 'right';\n },\n xPlus (x, value) {\n return x - value;\n },\n leftForLtr (x, itemWidth) {\n return x - itemWidth;\n }\n };\n};\nconst getLeftToRightAdapter = function() {\n return {\n x (x) {\n return x;\n },\n setWidth (w) {},\n textAlign (align) {\n return align;\n },\n xPlus (x, value) {\n return x + value;\n },\n leftForLtr (x, _itemWidth) {\n return x;\n }\n };\n};\nfunction getRtlAdapter(rtl, rectX, width) {\n return rtl ? getRightToLeftAdapter(rectX, width) : getLeftToRightAdapter();\n}\nfunction overrideTextDirection(ctx, direction) {\n let style, original;\n if (direction === 'ltr' || direction === 'rtl') {\n style = ctx.canvas.style;\n original = [\n style.getPropertyValue('direction'),\n style.getPropertyPriority('direction')\n ];\n style.setProperty('direction', direction, 'important');\n ctx.prevTextDirection = original;\n }\n}\nfunction restoreTextDirection(ctx, original) {\n if (original !== undefined) {\n delete ctx.prevTextDirection;\n ctx.canvas.style.setProperty('direction', original[0], original[1]);\n }\n}\n\nfunction propertyFn(property) {\n if (property === 'angle') {\n return {\n between: _angleBetween,\n compare: _angleDiff,\n normalize: _normalizeAngle\n };\n }\n return {\n between: _isBetween,\n compare: (a, b)=>a - b,\n normalize: (x)=>x\n };\n}\nfunction normalizeSegment({ start , end , count , loop , style }) {\n return {\n start: start % count,\n end: end % count,\n loop: loop && (end - start + 1) % count === 0,\n style\n };\n}\nfunction getSegment(segment, points, bounds) {\n const { property , start: startBound , end: endBound } = bounds;\n const { between , normalize } = propertyFn(property);\n const count = points.length;\n let { start , end , loop } = segment;\n let i, ilen;\n if (loop) {\n start += count;\n end += count;\n for(i = 0, ilen = count; i < ilen; ++i){\n if (!between(normalize(points[start % count][property]), startBound, endBound)) {\n break;\n }\n start--;\n end--;\n }\n start %= count;\n end %= count;\n }\n if (end < start) {\n end += count;\n }\n return {\n start,\n end,\n loop,\n style: segment.style\n };\n}\n function _boundSegment(segment, points, bounds) {\n if (!bounds) {\n return [\n segment\n ];\n }\n const { property , start: startBound , end: endBound } = bounds;\n const count = points.length;\n const { compare , between , normalize } = propertyFn(property);\n const { start , end , loop , style } = getSegment(segment, points, bounds);\n const result = [];\n let inside = false;\n let subStart = null;\n let value, point, prevValue;\n const startIsBefore = ()=>between(startBound, prevValue, value) && compare(startBound, prevValue) !== 0;\n const endIsBefore = ()=>compare(endBound, value) === 0 || between(endBound, prevValue, value);\n const shouldStart = ()=>inside || startIsBefore();\n const shouldStop = ()=>!inside || endIsBefore();\n for(let i = start, prev = start; i <= end; ++i){\n point = points[i % count];\n if (point.skip) {\n continue;\n }\n value = normalize(point[property]);\n if (value === prevValue) {\n continue;\n }\n inside = between(value, startBound, endBound);\n if (subStart === null && shouldStart()) {\n subStart = compare(value, startBound) === 0 ? i : prev;\n }\n if (subStart !== null && shouldStop()) {\n result.push(normalizeSegment({\n start: subStart,\n end: i,\n loop,\n count,\n style\n }));\n subStart = null;\n }\n prev = i;\n prevValue = value;\n }\n if (subStart !== null) {\n result.push(normalizeSegment({\n start: subStart,\n end,\n loop,\n count,\n style\n }));\n }\n return result;\n}\n function _boundSegments(line, bounds) {\n const result = [];\n const segments = line.segments;\n for(let i = 0; i < segments.length; i++){\n const sub = _boundSegment(segments[i], line.points, bounds);\n if (sub.length) {\n result.push(...sub);\n }\n }\n return result;\n}\n function findStartAndEnd(points, count, loop, spanGaps) {\n let start = 0;\n let end = count - 1;\n if (loop && !spanGaps) {\n while(start < count && !points[start].skip){\n start++;\n }\n }\n while(start < count && points[start].skip){\n start++;\n }\n start %= count;\n if (loop) {\n end += start;\n }\n while(end > start && points[end % count].skip){\n end--;\n }\n end %= count;\n return {\n start,\n end\n };\n}\n function solidSegments(points, start, max, loop) {\n const count = points.length;\n const result = [];\n let last = start;\n let prev = points[start];\n let end;\n for(end = start + 1; end <= max; ++end){\n const cur = points[end % count];\n if (cur.skip || cur.stop) {\n if (!prev.skip) {\n loop = false;\n result.push({\n start: start % count,\n end: (end - 1) % count,\n loop\n });\n start = last = cur.stop ? end : null;\n }\n } else {\n last = end;\n if (prev.skip) {\n start = end;\n }\n }\n prev = cur;\n }\n if (last !== null) {\n result.push({\n start: start % count,\n end: last % count,\n loop\n });\n }\n return result;\n}\n function _computeSegments(line, segmentOptions) {\n const points = line.points;\n const spanGaps = line.options.spanGaps;\n const count = points.length;\n if (!count) {\n return [];\n }\n const loop = !!line._loop;\n const { start , end } = findStartAndEnd(points, count, loop, spanGaps);\n if (spanGaps === true) {\n return splitByStyles(line, [\n {\n start,\n end,\n loop\n }\n ], points, segmentOptions);\n }\n const max = end < start ? end + count : end;\n const completeLoop = !!line._fullLoop && start === 0 && end === count - 1;\n return splitByStyles(line, solidSegments(points, start, max, completeLoop), points, segmentOptions);\n}\n function splitByStyles(line, segments, points, segmentOptions) {\n if (!segmentOptions || !segmentOptions.setContext || !points) {\n return segments;\n }\n return doSplitByStyles(line, segments, points, segmentOptions);\n}\n function doSplitByStyles(line, segments, points, segmentOptions) {\n const chartContext = line._chart.getContext();\n const baseStyle = readStyle(line.options);\n const { _datasetIndex: datasetIndex , options: { spanGaps } } = line;\n const count = points.length;\n const result = [];\n let prevStyle = baseStyle;\n let start = segments[0].start;\n let i = start;\n function addStyle(s, e, l, st) {\n const dir = spanGaps ? -1 : 1;\n if (s === e) {\n return;\n }\n s += count;\n while(points[s % count].skip){\n s -= dir;\n }\n while(points[e % count].skip){\n e += dir;\n }\n if (s % count !== e % count) {\n result.push({\n start: s % count,\n end: e % count,\n loop: l,\n style: st\n });\n prevStyle = st;\n start = e % count;\n }\n }\n for (const segment of segments){\n start = spanGaps ? start : segment.start;\n let prev = points[start % count];\n let style;\n for(i = start + 1; i <= segment.end; i++){\n const pt = points[i % count];\n style = readStyle(segmentOptions.setContext(createContext(chartContext, {\n type: 'segment',\n p0: prev,\n p1: pt,\n p0DataIndex: (i - 1) % count,\n p1DataIndex: i % count,\n datasetIndex\n })));\n if (styleChanged(style, prevStyle)) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n prev = pt;\n prevStyle = style;\n }\n if (start < i - 1) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n }\n return result;\n}\nfunction readStyle(options) {\n return {\n backgroundColor: options.backgroundColor,\n borderCapStyle: options.borderCapStyle,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderJoinStyle: options.borderJoinStyle,\n borderWidth: options.borderWidth,\n borderColor: options.borderColor\n };\n}\nfunction styleChanged(style, prevStyle) {\n if (!prevStyle) {\n return false;\n }\n const cache = [];\n const replacer = function(key, value) {\n if (!isPatternOrGradient(value)) {\n return value;\n }\n if (!cache.includes(value)) {\n cache.push(value);\n }\n return cache.indexOf(value);\n };\n return JSON.stringify(style, replacer) !== JSON.stringify(prevStyle, replacer);\n}\n\nexport { unclipArea as $, _rlookupByKey as A, _lookupByKey as B, _isPointInArea as C, getAngleFromPoint as D, toPadding as E, each as F, getMaximumSize as G, HALF_PI as H, _getParentNode as I, readUsedSize as J, supportsEventListenerOptions as K, throttled as L, _isDomSupported as M, _factorize as N, finiteOrDefault as O, PI as P, callback as Q, _addGrace as R, _limitValue as S, TAU as T, toDegrees as U, _measureText as V, _int16Range as W, _alignPixel as X, clipArea as Y, renderText as Z, _arrayUnique as _, resolve as a, fontString as a$, toFont as a0, _toLeftRightCenter as a1, _alignStartEnd as a2, overrides as a3, merge as a4, _capitalize as a5, descriptors as a6, isFunction as a7, _attachContext as a8, _createResolver as a9, overrideTextDirection as aA, _textX as aB, restoreTextDirection as aC, drawPointLegend as aD, distanceBetweenPoints as aE, noop as aF, _setMinAndMaxByKey as aG, niceNum as aH, almostWhole as aI, almostEquals as aJ, _decimalPlaces as aK, Ticks as aL, log10 as aM, _longestText as aN, _filterBetween as aO, _lookup as aP, isPatternOrGradient as aQ, getHoverColor as aR, clone as aS, _merger as aT, _mergerIf as aU, _deprecated as aV, _splitKey as aW, toFontString as aX, splineCurve as aY, splineCurveMonotone as aZ, getStyle as a_, _descriptors as aa, mergeIf as ab, uid as ac, debounce as ad, retinaScale as ae, clearCanvas as af, setsEqual as ag, _elementsEqual as ah, _isClickEvent as ai, _isBetween as aj, _readValueToProps as ak, _updateBezierControlPoints as al, _computeSegments as am, _boundSegments as an, _steppedInterpolation as ao, _bezierInterpolation as ap, _pointInLine as aq, _steppedLineTo as ar, _bezierCurveTo as as, drawPoint as at, addRoundedRectPath as au, toTRBL as av, toTRBLCorners as aw, _boundSegment as ax, _normalizeAngle as ay, getRtlAdapter as az, isArray as b, toLineHeight as b0, PITAU as b1, INFINITY as b2, RAD_PER_DEG as b3, QUARTER_PI as b4, TWO_THIRDS_PI as b5, _angleDiff as b6, color as c, defaults as d, effects as e, resolveObjectKey as f, isNumberFinite as g, defined as h, isObject as i, createContext as j, isNullOrUndef as k, listenArrayEvents as l, toPercentage as m, toDimension as n, formatNumber as o, _angleBetween as p, _getStartAndCountOfVisiblePoints as q, requestAnimFrame as r, sign as s, toRadians as t, unlistenArrayEvents as u, valueOrDefault as v, _scaleRangesChanged as w, isNumber as x, _parseObjectDataRadialScale as y, getRelativePosition as z };\n//# sourceMappingURL=helpers.segment.js.map\n","/*!\n * Chart.js v4.4.6\n * https://www.chartjs.org\n * (c) 2024 Chart.js Contributors\n * Released under the MIT License\n */\nimport { r as requestAnimFrame, a as resolve, e as effects, c as color, i as isObject, d as defaults, b as isArray, v as valueOrDefault, u as unlistenArrayEvents, l as listenArrayEvents, f as resolveObjectKey, g as isNumberFinite, h as defined, s as sign, j as createContext, k as isNullOrUndef, _ as _arrayUnique, t as toRadians, m as toPercentage, n as toDimension, T as TAU, o as formatNumber, p as _angleBetween, H as HALF_PI, P as PI, q as _getStartAndCountOfVisiblePoints, w as _scaleRangesChanged, x as isNumber, y as _parseObjectDataRadialScale, z as getRelativePosition, A as _rlookupByKey, B as _lookupByKey, C as _isPointInArea, D as getAngleFromPoint, E as toPadding, F as each, G as getMaximumSize, I as _getParentNode, J as readUsedSize, K as supportsEventListenerOptions, L as throttled, M as _isDomSupported, N as _factorize, O as finiteOrDefault, Q as callback, R as _addGrace, S as _limitValue, U as toDegrees, V as _measureText, W as _int16Range, X as _alignPixel, Y as clipArea, Z as renderText, $ as unclipArea, a0 as toFont, a1 as _toLeftRightCenter, a2 as _alignStartEnd, a3 as overrides, a4 as merge, a5 as _capitalize, a6 as descriptors, a7 as isFunction, a8 as _attachContext, a9 as _createResolver, aa as _descriptors, ab as mergeIf, ac as uid, ad as debounce, ae as retinaScale, af as clearCanvas, ag as setsEqual, ah as _elementsEqual, ai as _isClickEvent, aj as _isBetween, ak as _readValueToProps, al as _updateBezierControlPoints, am as _computeSegments, an as _boundSegments, ao as _steppedInterpolation, ap as _bezierInterpolation, aq as _pointInLine, ar as _steppedLineTo, as as _bezierCurveTo, at as drawPoint, au as addRoundedRectPath, av as toTRBL, aw as toTRBLCorners, ax as _boundSegment, ay as _normalizeAngle, az as getRtlAdapter, aA as overrideTextDirection, aB as _textX, aC as restoreTextDirection, aD as drawPointLegend, aE as distanceBetweenPoints, aF as noop, aG as _setMinAndMaxByKey, aH as niceNum, aI as almostWhole, aJ as almostEquals, aK as _decimalPlaces, aL as Ticks, aM as log10, aN as _longestText, aO as _filterBetween, aP as _lookup } from './chunks/helpers.segment.js';\nimport '@kurkle/color';\n\nclass Animator {\n constructor(){\n this._request = null;\n this._charts = new Map();\n this._running = false;\n this._lastDate = undefined;\n }\n _notify(chart, anims, date, type) {\n const callbacks = anims.listeners[type];\n const numSteps = anims.duration;\n callbacks.forEach((fn)=>fn({\n chart,\n initial: anims.initial,\n numSteps,\n currentStep: Math.min(date - anims.start, numSteps)\n }));\n }\n _refresh() {\n if (this._request) {\n return;\n }\n this._running = true;\n this._request = requestAnimFrame.call(window, ()=>{\n this._update();\n this._request = null;\n if (this._running) {\n this._refresh();\n }\n });\n }\n _update(date = Date.now()) {\n let remaining = 0;\n this._charts.forEach((anims, chart)=>{\n if (!anims.running || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n let draw = false;\n let item;\n for(; i >= 0; --i){\n item = items[i];\n if (item._active) {\n if (item._total > anims.duration) {\n anims.duration = item._total;\n }\n item.tick(date);\n draw = true;\n } else {\n items[i] = items[items.length - 1];\n items.pop();\n }\n }\n if (draw) {\n chart.draw();\n this._notify(chart, anims, date, 'progress');\n }\n if (!items.length) {\n anims.running = false;\n this._notify(chart, anims, date, 'complete');\n anims.initial = false;\n }\n remaining += items.length;\n });\n this._lastDate = date;\n if (remaining === 0) {\n this._running = false;\n }\n }\n _getAnims(chart) {\n const charts = this._charts;\n let anims = charts.get(chart);\n if (!anims) {\n anims = {\n running: false,\n initial: true,\n items: [],\n listeners: {\n complete: [],\n progress: []\n }\n };\n charts.set(chart, anims);\n }\n return anims;\n }\n listen(chart, event, cb) {\n this._getAnims(chart).listeners[event].push(cb);\n }\n add(chart, items) {\n if (!items || !items.length) {\n return;\n }\n this._getAnims(chart).items.push(...items);\n }\n has(chart) {\n return this._getAnims(chart).items.length > 0;\n }\n start(chart) {\n const anims = this._charts.get(chart);\n if (!anims) {\n return;\n }\n anims.running = true;\n anims.start = Date.now();\n anims.duration = anims.items.reduce((acc, cur)=>Math.max(acc, cur._duration), 0);\n this._refresh();\n }\n running(chart) {\n if (!this._running) {\n return false;\n }\n const anims = this._charts.get(chart);\n if (!anims || !anims.running || !anims.items.length) {\n return false;\n }\n return true;\n }\n stop(chart) {\n const anims = this._charts.get(chart);\n if (!anims || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n for(; i >= 0; --i){\n items[i].cancel();\n }\n anims.items = [];\n this._notify(chart, anims, Date.now(), 'complete');\n }\n remove(chart) {\n return this._charts.delete(chart);\n }\n}\nvar animator = /* #__PURE__ */ new Animator();\n\nconst transparent = 'transparent';\nconst interpolators = {\n boolean (from, to, factor) {\n return factor > 0.5 ? to : from;\n },\n color (from, to, factor) {\n const c0 = color(from || transparent);\n const c1 = c0.valid && color(to || transparent);\n return c1 && c1.valid ? c1.mix(c0, factor).hexString() : to;\n },\n number (from, to, factor) {\n return from + (to - from) * factor;\n }\n};\nclass Animation {\n constructor(cfg, target, prop, to){\n const currentValue = target[prop];\n to = resolve([\n cfg.to,\n to,\n currentValue,\n cfg.from\n ]);\n const from = resolve([\n cfg.from,\n currentValue,\n to\n ]);\n this._active = true;\n this._fn = cfg.fn || interpolators[cfg.type || typeof from];\n this._easing = effects[cfg.easing] || effects.linear;\n this._start = Math.floor(Date.now() + (cfg.delay || 0));\n this._duration = this._total = Math.floor(cfg.duration);\n this._loop = !!cfg.loop;\n this._target = target;\n this._prop = prop;\n this._from = from;\n this._to = to;\n this._promises = undefined;\n }\n active() {\n return this._active;\n }\n update(cfg, to, date) {\n if (this._active) {\n this._notify(false);\n const currentValue = this._target[this._prop];\n const elapsed = date - this._start;\n const remain = this._duration - elapsed;\n this._start = date;\n this._duration = Math.floor(Math.max(remain, cfg.duration));\n this._total += elapsed;\n this._loop = !!cfg.loop;\n this._to = resolve([\n cfg.to,\n to,\n currentValue,\n cfg.from\n ]);\n this._from = resolve([\n cfg.from,\n currentValue,\n to\n ]);\n }\n }\n cancel() {\n if (this._active) {\n this.tick(Date.now());\n this._active = false;\n this._notify(false);\n }\n }\n tick(date) {\n const elapsed = date - this._start;\n const duration = this._duration;\n const prop = this._prop;\n const from = this._from;\n const loop = this._loop;\n const to = this._to;\n let factor;\n this._active = from !== to && (loop || elapsed < duration);\n if (!this._active) {\n this._target[prop] = to;\n this._notify(true);\n return;\n }\n if (elapsed < 0) {\n this._target[prop] = from;\n return;\n }\n factor = elapsed / duration % 2;\n factor = loop && factor > 1 ? 2 - factor : factor;\n factor = this._easing(Math.min(1, Math.max(0, factor)));\n this._target[prop] = this._fn(from, to, factor);\n }\n wait() {\n const promises = this._promises || (this._promises = []);\n return new Promise((res, rej)=>{\n promises.push({\n res,\n rej\n });\n });\n }\n _notify(resolved) {\n const method = resolved ? 'res' : 'rej';\n const promises = this._promises || [];\n for(let i = 0; i < promises.length; i++){\n promises[i][method]();\n }\n }\n}\n\nclass Animations {\n constructor(chart, config){\n this._chart = chart;\n this._properties = new Map();\n this.configure(config);\n }\n configure(config) {\n if (!isObject(config)) {\n return;\n }\n const animationOptions = Object.keys(defaults.animation);\n const animatedProps = this._properties;\n Object.getOwnPropertyNames(config).forEach((key)=>{\n const cfg = config[key];\n if (!isObject(cfg)) {\n return;\n }\n const resolved = {};\n for (const option of animationOptions){\n resolved[option] = cfg[option];\n }\n (isArray(cfg.properties) && cfg.properties || [\n key\n ]).forEach((prop)=>{\n if (prop === key || !animatedProps.has(prop)) {\n animatedProps.set(prop, resolved);\n }\n });\n });\n }\n _animateOptions(target, values) {\n const newOptions = values.options;\n const options = resolveTargetOptions(target, newOptions);\n if (!options) {\n return [];\n }\n const animations = this._createAnimations(options, newOptions);\n if (newOptions.$shared) {\n awaitAll(target.options.$animations, newOptions).then(()=>{\n target.options = newOptions;\n }, ()=>{\n });\n }\n return animations;\n }\n _createAnimations(target, values) {\n const animatedProps = this._properties;\n const animations = [];\n const running = target.$animations || (target.$animations = {});\n const props = Object.keys(values);\n const date = Date.now();\n let i;\n for(i = props.length - 1; i >= 0; --i){\n const prop = props[i];\n if (prop.charAt(0) === '$') {\n continue;\n }\n if (prop === 'options') {\n animations.push(...this._animateOptions(target, values));\n continue;\n }\n const value = values[prop];\n let animation = running[prop];\n const cfg = animatedProps.get(prop);\n if (animation) {\n if (cfg && animation.active()) {\n animation.update(cfg, value, date);\n continue;\n } else {\n animation.cancel();\n }\n }\n if (!cfg || !cfg.duration) {\n target[prop] = value;\n continue;\n }\n running[prop] = animation = new Animation(cfg, target, prop, value);\n animations.push(animation);\n }\n return animations;\n }\n update(target, values) {\n if (this._properties.size === 0) {\n Object.assign(target, values);\n return;\n }\n const animations = this._createAnimations(target, values);\n if (animations.length) {\n animator.add(this._chart, animations);\n return true;\n }\n }\n}\nfunction awaitAll(animations, properties) {\n const running = [];\n const keys = Object.keys(properties);\n for(let i = 0; i < keys.length; i++){\n const anim = animations[keys[i]];\n if (anim && anim.active()) {\n running.push(anim.wait());\n }\n }\n return Promise.all(running);\n}\nfunction resolveTargetOptions(target, newOptions) {\n if (!newOptions) {\n return;\n }\n let options = target.options;\n if (!options) {\n target.options = newOptions;\n return;\n }\n if (options.$shared) {\n target.options = options = Object.assign({}, options, {\n $shared: false,\n $animations: {}\n });\n }\n return options;\n}\n\nfunction scaleClip(scale, allowedOverflow) {\n const opts = scale && scale.options || {};\n const reverse = opts.reverse;\n const min = opts.min === undefined ? allowedOverflow : 0;\n const max = opts.max === undefined ? allowedOverflow : 0;\n return {\n start: reverse ? max : min,\n end: reverse ? min : max\n };\n}\nfunction defaultClip(xScale, yScale, allowedOverflow) {\n if (allowedOverflow === false) {\n return false;\n }\n const x = scaleClip(xScale, allowedOverflow);\n const y = scaleClip(yScale, allowedOverflow);\n return {\n top: y.end,\n right: x.end,\n bottom: y.start,\n left: x.start\n };\n}\nfunction toClip(value) {\n let t, r, b, l;\n if (isObject(value)) {\n t = value.top;\n r = value.right;\n b = value.bottom;\n l = value.left;\n } else {\n t = r = b = l = value;\n }\n return {\n top: t,\n right: r,\n bottom: b,\n left: l,\n disabled: value === false\n };\n}\nfunction getSortedDatasetIndices(chart, filterVisible) {\n const keys = [];\n const metasets = chart._getSortedDatasetMetas(filterVisible);\n let i, ilen;\n for(i = 0, ilen = metasets.length; i < ilen; ++i){\n keys.push(metasets[i].index);\n }\n return keys;\n}\nfunction applyStack(stack, value, dsIndex, options = {}) {\n const keys = stack.keys;\n const singleMode = options.mode === 'single';\n let i, ilen, datasetIndex, otherValue;\n if (value === null) {\n return;\n }\n let found = false;\n for(i = 0, ilen = keys.length; i < ilen; ++i){\n datasetIndex = +keys[i];\n if (datasetIndex === dsIndex) {\n found = true;\n if (options.all) {\n continue;\n }\n break;\n }\n otherValue = stack.values[datasetIndex];\n if (isNumberFinite(otherValue) && (singleMode || value === 0 || sign(value) === sign(otherValue))) {\n value += otherValue;\n }\n }\n if (!found && !options.all) {\n return 0;\n }\n return value;\n}\nfunction convertObjectDataToArray(data, meta) {\n const { iScale , vScale } = meta;\n const iAxisKey = iScale.axis === 'x' ? 'x' : 'y';\n const vAxisKey = vScale.axis === 'x' ? 'x' : 'y';\n const keys = Object.keys(data);\n const adata = new Array(keys.length);\n let i, ilen, key;\n for(i = 0, ilen = keys.length; i < ilen; ++i){\n key = keys[i];\n adata[i] = {\n [iAxisKey]: key,\n [vAxisKey]: data[key]\n };\n }\n return adata;\n}\nfunction isStacked(scale, meta) {\n const stacked = scale && scale.options.stacked;\n return stacked || stacked === undefined && meta.stack !== undefined;\n}\nfunction getStackKey(indexScale, valueScale, meta) {\n return `${indexScale.id}.${valueScale.id}.${meta.stack || meta.type}`;\n}\nfunction getUserBounds(scale) {\n const { min , max , minDefined , maxDefined } = scale.getUserBounds();\n return {\n min: minDefined ? min : Number.NEGATIVE_INFINITY,\n max: maxDefined ? max : Number.POSITIVE_INFINITY\n };\n}\nfunction getOrCreateStack(stacks, stackKey, indexValue) {\n const subStack = stacks[stackKey] || (stacks[stackKey] = {});\n return subStack[indexValue] || (subStack[indexValue] = {});\n}\nfunction getLastIndexInStack(stack, vScale, positive, type) {\n for (const meta of vScale.getMatchingVisibleMetas(type).reverse()){\n const value = stack[meta.index];\n if (positive && value > 0 || !positive && value < 0) {\n return meta.index;\n }\n }\n return null;\n}\nfunction updateStacks(controller, parsed) {\n const { chart , _cachedMeta: meta } = controller;\n const stacks = chart._stacks || (chart._stacks = {});\n const { iScale , vScale , index: datasetIndex } = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const key = getStackKey(iScale, vScale, meta);\n const ilen = parsed.length;\n let stack;\n for(let i = 0; i < ilen; ++i){\n const item = parsed[i];\n const { [iAxis]: index , [vAxis]: value } = item;\n const itemStacks = item._stacks || (item._stacks = {});\n stack = itemStacks[vAxis] = getOrCreateStack(stacks, key, index);\n stack[datasetIndex] = value;\n stack._top = getLastIndexInStack(stack, vScale, true, meta.type);\n stack._bottom = getLastIndexInStack(stack, vScale, false, meta.type);\n const visualValues = stack._visualValues || (stack._visualValues = {});\n visualValues[datasetIndex] = value;\n }\n}\nfunction getFirstScaleId(chart, axis) {\n const scales = chart.scales;\n return Object.keys(scales).filter((key)=>scales[key].axis === axis).shift();\n}\nfunction createDatasetContext(parent, index) {\n return createContext(parent, {\n active: false,\n dataset: undefined,\n datasetIndex: index,\n index,\n mode: 'default',\n type: 'dataset'\n });\n}\nfunction createDataContext(parent, index, element) {\n return createContext(parent, {\n active: false,\n dataIndex: index,\n parsed: undefined,\n raw: undefined,\n element,\n index,\n mode: 'default',\n type: 'data'\n });\n}\nfunction clearStacks(meta, items) {\n const datasetIndex = meta.controller.index;\n const axis = meta.vScale && meta.vScale.axis;\n if (!axis) {\n return;\n }\n items = items || meta._parsed;\n for (const parsed of items){\n const stacks = parsed._stacks;\n if (!stacks || stacks[axis] === undefined || stacks[axis][datasetIndex] === undefined) {\n return;\n }\n delete stacks[axis][datasetIndex];\n if (stacks[axis]._visualValues !== undefined && stacks[axis]._visualValues[datasetIndex] !== undefined) {\n delete stacks[axis]._visualValues[datasetIndex];\n }\n }\n}\nconst isDirectUpdateMode = (mode)=>mode === 'reset' || mode === 'none';\nconst cloneIfNotShared = (cached, shared)=>shared ? cached : Object.assign({}, cached);\nconst createStack = (canStack, meta, chart)=>canStack && !meta.hidden && meta._stacked && {\n keys: getSortedDatasetIndices(chart, true),\n values: null\n };\nclass DatasetController {\n static defaults = {};\n static datasetElementType = null;\n static dataElementType = null;\n constructor(chart, datasetIndex){\n this.chart = chart;\n this._ctx = chart.ctx;\n this.index = datasetIndex;\n this._cachedDataOpts = {};\n this._cachedMeta = this.getMeta();\n this._type = this._cachedMeta.type;\n this.options = undefined;\n this._parsing = false;\n this._data = undefined;\n this._objectData = undefined;\n this._sharedOptions = undefined;\n this._drawStart = undefined;\n this._drawCount = undefined;\n this.enableOptionSharing = false;\n this.supportsDecimation = false;\n this.$context = undefined;\n this._syncList = [];\n this.datasetElementType = new.target.datasetElementType;\n this.dataElementType = new.target.dataElementType;\n this.initialize();\n }\n initialize() {\n const meta = this._cachedMeta;\n this.configure();\n this.linkScales();\n meta._stacked = isStacked(meta.vScale, meta);\n this.addElements();\n if (this.options.fill && !this.chart.isPluginEnabled('filler')) {\n console.warn(\"Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options\");\n }\n }\n updateIndex(datasetIndex) {\n if (this.index !== datasetIndex) {\n clearStacks(this._cachedMeta);\n }\n this.index = datasetIndex;\n }\n linkScales() {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n const chooseId = (axis, x, y, r)=>axis === 'x' ? x : axis === 'r' ? r : y;\n const xid = meta.xAxisID = valueOrDefault(dataset.xAxisID, getFirstScaleId(chart, 'x'));\n const yid = meta.yAxisID = valueOrDefault(dataset.yAxisID, getFirstScaleId(chart, 'y'));\n const rid = meta.rAxisID = valueOrDefault(dataset.rAxisID, getFirstScaleId(chart, 'r'));\n const indexAxis = meta.indexAxis;\n const iid = meta.iAxisID = chooseId(indexAxis, xid, yid, rid);\n const vid = meta.vAxisID = chooseId(indexAxis, yid, xid, rid);\n meta.xScale = this.getScaleForId(xid);\n meta.yScale = this.getScaleForId(yid);\n meta.rScale = this.getScaleForId(rid);\n meta.iScale = this.getScaleForId(iid);\n meta.vScale = this.getScaleForId(vid);\n }\n getDataset() {\n return this.chart.data.datasets[this.index];\n }\n getMeta() {\n return this.chart.getDatasetMeta(this.index);\n }\n getScaleForId(scaleID) {\n return this.chart.scales[scaleID];\n }\n _getOtherScale(scale) {\n const meta = this._cachedMeta;\n return scale === meta.iScale ? meta.vScale : meta.iScale;\n }\n reset() {\n this._update('reset');\n }\n _destroy() {\n const meta = this._cachedMeta;\n if (this._data) {\n unlistenArrayEvents(this._data, this);\n }\n if (meta._stacked) {\n clearStacks(meta);\n }\n }\n _dataCheck() {\n const dataset = this.getDataset();\n const data = dataset.data || (dataset.data = []);\n const _data = this._data;\n if (isObject(data)) {\n const meta = this._cachedMeta;\n this._data = convertObjectDataToArray(data, meta);\n } else if (_data !== data) {\n if (_data) {\n unlistenArrayEvents(_data, this);\n const meta = this._cachedMeta;\n clearStacks(meta);\n meta._parsed = [];\n }\n if (data && Object.isExtensible(data)) {\n listenArrayEvents(data, this);\n }\n this._syncList = [];\n this._data = data;\n }\n }\n addElements() {\n const meta = this._cachedMeta;\n this._dataCheck();\n if (this.datasetElementType) {\n meta.dataset = new this.datasetElementType();\n }\n }\n buildOrUpdateElements(resetNewElements) {\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n let stackChanged = false;\n this._dataCheck();\n const oldStacked = meta._stacked;\n meta._stacked = isStacked(meta.vScale, meta);\n if (meta.stack !== dataset.stack) {\n stackChanged = true;\n clearStacks(meta);\n meta.stack = dataset.stack;\n }\n this._resyncElements(resetNewElements);\n if (stackChanged || oldStacked !== meta._stacked) {\n updateStacks(this, meta._parsed);\n meta._stacked = isStacked(meta.vScale, meta);\n }\n }\n configure() {\n const config = this.chart.config;\n const scopeKeys = config.datasetScopeKeys(this._type);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys, true);\n this.options = config.createResolver(scopes, this.getContext());\n this._parsing = this.options.parsing;\n this._cachedDataOpts = {};\n }\n parse(start, count) {\n const { _cachedMeta: meta , _data: data } = this;\n const { iScale , _stacked } = meta;\n const iAxis = iScale.axis;\n let sorted = start === 0 && count === data.length ? true : meta._sorted;\n let prev = start > 0 && meta._parsed[start - 1];\n let i, cur, parsed;\n if (this._parsing === false) {\n meta._parsed = data;\n meta._sorted = true;\n parsed = data;\n } else {\n if (isArray(data[start])) {\n parsed = this.parseArrayData(meta, data, start, count);\n } else if (isObject(data[start])) {\n parsed = this.parseObjectData(meta, data, start, count);\n } else {\n parsed = this.parsePrimitiveData(meta, data, start, count);\n }\n const isNotInOrderComparedToPrev = ()=>cur[iAxis] === null || prev && cur[iAxis] < prev[iAxis];\n for(i = 0; i < count; ++i){\n meta._parsed[i + start] = cur = parsed[i];\n if (sorted) {\n if (isNotInOrderComparedToPrev()) {\n sorted = false;\n }\n prev = cur;\n }\n }\n meta._sorted = sorted;\n }\n if (_stacked) {\n updateStacks(this, parsed);\n }\n }\n parsePrimitiveData(meta, data, start, count) {\n const { iScale , vScale } = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = new Array(count);\n let i, ilen, index;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n parsed[i] = {\n [iAxis]: singleScale || iScale.parse(labels[index], index),\n [vAxis]: vScale.parse(data[index], index)\n };\n }\n return parsed;\n }\n parseArrayData(meta, data, start, count) {\n const { xScale , yScale } = meta;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(item[0], index),\n y: yScale.parse(item[1], index)\n };\n }\n return parsed;\n }\n parseObjectData(meta, data, start, count) {\n const { xScale , yScale } = meta;\n const { xAxisKey ='x' , yAxisKey ='y' } = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(resolveObjectKey(item, xAxisKey), index),\n y: yScale.parse(resolveObjectKey(item, yAxisKey), index)\n };\n }\n return parsed;\n }\n getParsed(index) {\n return this._cachedMeta._parsed[index];\n }\n getDataElement(index) {\n return this._cachedMeta.data[index];\n }\n applyStack(scale, parsed, mode) {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const value = parsed[scale.axis];\n const stack = {\n keys: getSortedDatasetIndices(chart, true),\n values: parsed._stacks[scale.axis]._visualValues\n };\n return applyStack(stack, value, meta.index, {\n mode\n });\n }\n updateRangeFromParsed(range, scale, parsed, stack) {\n const parsedValue = parsed[scale.axis];\n let value = parsedValue === null ? NaN : parsedValue;\n const values = stack && parsed._stacks[scale.axis];\n if (stack && values) {\n stack.values = values;\n value = applyStack(stack, parsedValue, this._cachedMeta.index);\n }\n range.min = Math.min(range.min, value);\n range.max = Math.max(range.max, value);\n }\n getMinMax(scale, canStack) {\n const meta = this._cachedMeta;\n const _parsed = meta._parsed;\n const sorted = meta._sorted && scale === meta.iScale;\n const ilen = _parsed.length;\n const otherScale = this._getOtherScale(scale);\n const stack = createStack(canStack, meta, this.chart);\n const range = {\n min: Number.POSITIVE_INFINITY,\n max: Number.NEGATIVE_INFINITY\n };\n const { min: otherMin , max: otherMax } = getUserBounds(otherScale);\n let i, parsed;\n function _skip() {\n parsed = _parsed[i];\n const otherValue = parsed[otherScale.axis];\n return !isNumberFinite(parsed[scale.axis]) || otherMin > otherValue || otherMax < otherValue;\n }\n for(i = 0; i < ilen; ++i){\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n if (sorted) {\n break;\n }\n }\n if (sorted) {\n for(i = ilen - 1; i >= 0; --i){\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n break;\n }\n }\n return range;\n }\n getAllParsedValues(scale) {\n const parsed = this._cachedMeta._parsed;\n const values = [];\n let i, ilen, value;\n for(i = 0, ilen = parsed.length; i < ilen; ++i){\n value = parsed[i][scale.axis];\n if (isNumberFinite(value)) {\n values.push(value);\n }\n }\n return values;\n }\n getMaxOverflow() {\n return false;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const parsed = this.getParsed(index);\n return {\n label: iScale ? '' + iScale.getLabelForValue(parsed[iScale.axis]) : '',\n value: vScale ? '' + vScale.getLabelForValue(parsed[vScale.axis]) : ''\n };\n }\n _update(mode) {\n const meta = this._cachedMeta;\n this.update(mode || 'default');\n meta._clip = toClip(valueOrDefault(this.options.clip, defaultClip(meta.xScale, meta.yScale, this.getMaxOverflow())));\n }\n update(mode) {}\n draw() {\n const ctx = this._ctx;\n const chart = this.chart;\n const meta = this._cachedMeta;\n const elements = meta.data || [];\n const area = chart.chartArea;\n const active = [];\n const start = this._drawStart || 0;\n const count = this._drawCount || elements.length - start;\n const drawActiveElementsOnTop = this.options.drawActiveElementsOnTop;\n let i;\n if (meta.dataset) {\n meta.dataset.draw(ctx, area, start, count);\n }\n for(i = start; i < start + count; ++i){\n const element = elements[i];\n if (element.hidden) {\n continue;\n }\n if (element.active && drawActiveElementsOnTop) {\n active.push(element);\n } else {\n element.draw(ctx, area);\n }\n }\n for(i = 0; i < active.length; ++i){\n active[i].draw(ctx, area);\n }\n }\n getStyle(index, active) {\n const mode = active ? 'active' : 'default';\n return index === undefined && this._cachedMeta.dataset ? this.resolveDatasetElementOptions(mode) : this.resolveDataElementOptions(index || 0, mode);\n }\n getContext(index, active, mode) {\n const dataset = this.getDataset();\n let context;\n if (index >= 0 && index < this._cachedMeta.data.length) {\n const element = this._cachedMeta.data[index];\n context = element.$context || (element.$context = createDataContext(this.getContext(), index, element));\n context.parsed = this.getParsed(index);\n context.raw = dataset.data[index];\n context.index = context.dataIndex = index;\n } else {\n context = this.$context || (this.$context = createDatasetContext(this.chart.getContext(), this.index));\n context.dataset = dataset;\n context.index = context.datasetIndex = this.index;\n }\n context.active = !!active;\n context.mode = mode;\n return context;\n }\n resolveDatasetElementOptions(mode) {\n return this._resolveElementOptions(this.datasetElementType.id, mode);\n }\n resolveDataElementOptions(index, mode) {\n return this._resolveElementOptions(this.dataElementType.id, mode, index);\n }\n _resolveElementOptions(elementType, mode = 'default', index) {\n const active = mode === 'active';\n const cache = this._cachedDataOpts;\n const cacheKey = elementType + '-' + mode;\n const cached = cache[cacheKey];\n const sharing = this.enableOptionSharing && defined(index);\n if (cached) {\n return cloneIfNotShared(cached, sharing);\n }\n const config = this.chart.config;\n const scopeKeys = config.datasetElementScopeKeys(this._type, elementType);\n const prefixes = active ? [\n `${elementType}Hover`,\n 'hover',\n elementType,\n ''\n ] : [\n elementType,\n ''\n ];\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n const names = Object.keys(defaults.elements[elementType]);\n const context = ()=>this.getContext(index, active, mode);\n const values = config.resolveNamedOptions(scopes, names, context, prefixes);\n if (values.$shared) {\n values.$shared = sharing;\n cache[cacheKey] = Object.freeze(cloneIfNotShared(values, sharing));\n }\n return values;\n }\n _resolveAnimations(index, transition, active) {\n const chart = this.chart;\n const cache = this._cachedDataOpts;\n const cacheKey = `animation-${transition}`;\n const cached = cache[cacheKey];\n if (cached) {\n return cached;\n }\n let options;\n if (chart.options.animation !== false) {\n const config = this.chart.config;\n const scopeKeys = config.datasetAnimationScopeKeys(this._type, transition);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n options = config.createResolver(scopes, this.getContext(index, active, transition));\n }\n const animations = new Animations(chart, options && options.animations);\n if (options && options._cacheable) {\n cache[cacheKey] = Object.freeze(animations);\n }\n return animations;\n }\n getSharedOptions(options) {\n if (!options.$shared) {\n return;\n }\n return this._sharedOptions || (this._sharedOptions = Object.assign({}, options));\n }\n includeOptions(mode, sharedOptions) {\n return !sharedOptions || isDirectUpdateMode(mode) || this.chart._animationsDisabled;\n }\n _getSharedOptions(start, mode) {\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const previouslySharedOptions = this._sharedOptions;\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions) || sharedOptions !== previouslySharedOptions;\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n return {\n sharedOptions,\n includeOptions\n };\n }\n updateElement(element, index, properties, mode) {\n if (isDirectUpdateMode(mode)) {\n Object.assign(element, properties);\n } else {\n this._resolveAnimations(index, mode).update(element, properties);\n }\n }\n updateSharedOptions(sharedOptions, mode, newOptions) {\n if (sharedOptions && !isDirectUpdateMode(mode)) {\n this._resolveAnimations(undefined, mode).update(sharedOptions, newOptions);\n }\n }\n _setStyle(element, index, mode, active) {\n element.active = active;\n const options = this.getStyle(index, active);\n this._resolveAnimations(index, mode, active).update(element, {\n options: !active && this.getSharedOptions(options) || options\n });\n }\n removeHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', false);\n }\n setHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', true);\n }\n _removeDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n if (element) {\n this._setStyle(element, undefined, 'active', false);\n }\n }\n _setDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n if (element) {\n this._setStyle(element, undefined, 'active', true);\n }\n }\n _resyncElements(resetNewElements) {\n const data = this._data;\n const elements = this._cachedMeta.data;\n for (const [method, arg1, arg2] of this._syncList){\n this[method](arg1, arg2);\n }\n this._syncList = [];\n const numMeta = elements.length;\n const numData = data.length;\n const count = Math.min(numData, numMeta);\n if (count) {\n this.parse(0, count);\n }\n if (numData > numMeta) {\n this._insertElements(numMeta, numData - numMeta, resetNewElements);\n } else if (numData < numMeta) {\n this._removeElements(numData, numMeta - numData);\n }\n }\n _insertElements(start, count, resetNewElements = true) {\n const meta = this._cachedMeta;\n const data = meta.data;\n const end = start + count;\n let i;\n const move = (arr)=>{\n arr.length += count;\n for(i = arr.length - 1; i >= end; i--){\n arr[i] = arr[i - count];\n }\n };\n move(data);\n for(i = start; i < end; ++i){\n data[i] = new this.dataElementType();\n }\n if (this._parsing) {\n move(meta._parsed);\n }\n this.parse(start, count);\n if (resetNewElements) {\n this.updateElements(data, start, count, 'reset');\n }\n }\n updateElements(element, start, count, mode) {}\n _removeElements(start, count) {\n const meta = this._cachedMeta;\n if (this._parsing) {\n const removed = meta._parsed.splice(start, count);\n if (meta._stacked) {\n clearStacks(meta, removed);\n }\n }\n meta.data.splice(start, count);\n }\n _sync(args) {\n if (this._parsing) {\n this._syncList.push(args);\n } else {\n const [method, arg1, arg2] = args;\n this[method](arg1, arg2);\n }\n this.chart._dataChanges.push([\n this.index,\n ...args\n ]);\n }\n _onDataPush() {\n const count = arguments.length;\n this._sync([\n '_insertElements',\n this.getDataset().data.length - count,\n count\n ]);\n }\n _onDataPop() {\n this._sync([\n '_removeElements',\n this._cachedMeta.data.length - 1,\n 1\n ]);\n }\n _onDataShift() {\n this._sync([\n '_removeElements',\n 0,\n 1\n ]);\n }\n _onDataSplice(start, count) {\n if (count) {\n this._sync([\n '_removeElements',\n start,\n count\n ]);\n }\n const newCount = arguments.length - 2;\n if (newCount) {\n this._sync([\n '_insertElements',\n start,\n newCount\n ]);\n }\n }\n _onDataUnshift() {\n this._sync([\n '_insertElements',\n 0,\n arguments.length\n ]);\n }\n}\n\nfunction getAllScaleValues(scale, type) {\n if (!scale._cache.$bar) {\n const visibleMetas = scale.getMatchingVisibleMetas(type);\n let values = [];\n for(let i = 0, ilen = visibleMetas.length; i < ilen; i++){\n values = values.concat(visibleMetas[i].controller.getAllParsedValues(scale));\n }\n scale._cache.$bar = _arrayUnique(values.sort((a, b)=>a - b));\n }\n return scale._cache.$bar;\n}\n function computeMinSampleSize(meta) {\n const scale = meta.iScale;\n const values = getAllScaleValues(scale, meta.type);\n let min = scale._length;\n let i, ilen, curr, prev;\n const updateMinAndPrev = ()=>{\n if (curr === 32767 || curr === -32768) {\n return;\n }\n if (defined(prev)) {\n min = Math.min(min, Math.abs(curr - prev) || min);\n }\n prev = curr;\n };\n for(i = 0, ilen = values.length; i < ilen; ++i){\n curr = scale.getPixelForValue(values[i]);\n updateMinAndPrev();\n }\n prev = undefined;\n for(i = 0, ilen = scale.ticks.length; i < ilen; ++i){\n curr = scale.getPixelForTick(i);\n updateMinAndPrev();\n }\n return min;\n}\n function computeFitCategoryTraits(index, ruler, options, stackCount) {\n const thickness = options.barThickness;\n let size, ratio;\n if (isNullOrUndef(thickness)) {\n size = ruler.min * options.categoryPercentage;\n ratio = options.barPercentage;\n } else {\n size = thickness * stackCount;\n ratio = 1;\n }\n return {\n chunk: size / stackCount,\n ratio,\n start: ruler.pixels[index] - size / 2\n };\n}\n function computeFlexCategoryTraits(index, ruler, options, stackCount) {\n const pixels = ruler.pixels;\n const curr = pixels[index];\n let prev = index > 0 ? pixels[index - 1] : null;\n let next = index < pixels.length - 1 ? pixels[index + 1] : null;\n const percent = options.categoryPercentage;\n if (prev === null) {\n prev = curr - (next === null ? ruler.end - ruler.start : next - curr);\n }\n if (next === null) {\n next = curr + curr - prev;\n }\n const start = curr - (curr - Math.min(prev, next)) / 2 * percent;\n const size = Math.abs(next - prev) / 2 * percent;\n return {\n chunk: size / stackCount,\n ratio: options.barPercentage,\n start\n };\n}\nfunction parseFloatBar(entry, item, vScale, i) {\n const startValue = vScale.parse(entry[0], i);\n const endValue = vScale.parse(entry[1], i);\n const min = Math.min(startValue, endValue);\n const max = Math.max(startValue, endValue);\n let barStart = min;\n let barEnd = max;\n if (Math.abs(min) > Math.abs(max)) {\n barStart = max;\n barEnd = min;\n }\n item[vScale.axis] = barEnd;\n item._custom = {\n barStart,\n barEnd,\n start: startValue,\n end: endValue,\n min,\n max\n };\n}\nfunction parseValue(entry, item, vScale, i) {\n if (isArray(entry)) {\n parseFloatBar(entry, item, vScale, i);\n } else {\n item[vScale.axis] = vScale.parse(entry, i);\n }\n return item;\n}\nfunction parseArrayOrPrimitive(meta, data, start, count) {\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = [];\n let i, ilen, item, entry;\n for(i = start, ilen = start + count; i < ilen; ++i){\n entry = data[i];\n item = {};\n item[iScale.axis] = singleScale || iScale.parse(labels[i], i);\n parsed.push(parseValue(entry, item, vScale, i));\n }\n return parsed;\n}\nfunction isFloatBar(custom) {\n return custom && custom.barStart !== undefined && custom.barEnd !== undefined;\n}\nfunction barSign(size, vScale, actualBase) {\n if (size !== 0) {\n return sign(size);\n }\n return (vScale.isHorizontal() ? 1 : -1) * (vScale.min >= actualBase ? 1 : -1);\n}\nfunction borderProps(properties) {\n let reverse, start, end, top, bottom;\n if (properties.horizontal) {\n reverse = properties.base > properties.x;\n start = 'left';\n end = 'right';\n } else {\n reverse = properties.base < properties.y;\n start = 'bottom';\n end = 'top';\n }\n if (reverse) {\n top = 'end';\n bottom = 'start';\n } else {\n top = 'start';\n bottom = 'end';\n }\n return {\n start,\n end,\n reverse,\n top,\n bottom\n };\n}\nfunction setBorderSkipped(properties, options, stack, index) {\n let edge = options.borderSkipped;\n const res = {};\n if (!edge) {\n properties.borderSkipped = res;\n return;\n }\n if (edge === true) {\n properties.borderSkipped = {\n top: true,\n right: true,\n bottom: true,\n left: true\n };\n return;\n }\n const { start , end , reverse , top , bottom } = borderProps(properties);\n if (edge === 'middle' && stack) {\n properties.enableBorderRadius = true;\n if ((stack._top || 0) === index) {\n edge = top;\n } else if ((stack._bottom || 0) === index) {\n edge = bottom;\n } else {\n res[parseEdge(bottom, start, end, reverse)] = true;\n edge = top;\n }\n }\n res[parseEdge(edge, start, end, reverse)] = true;\n properties.borderSkipped = res;\n}\nfunction parseEdge(edge, a, b, reverse) {\n if (reverse) {\n edge = swap(edge, a, b);\n edge = startEnd(edge, b, a);\n } else {\n edge = startEnd(edge, a, b);\n }\n return edge;\n}\nfunction swap(orig, v1, v2) {\n return orig === v1 ? v2 : orig === v2 ? v1 : orig;\n}\nfunction startEnd(v, start, end) {\n return v === 'start' ? start : v === 'end' ? end : v;\n}\nfunction setInflateAmount(properties, { inflateAmount }, ratio) {\n properties.inflateAmount = inflateAmount === 'auto' ? ratio === 1 ? 0.33 : 0 : inflateAmount;\n}\nclass BarController extends DatasetController {\n static id = 'bar';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'bar',\n categoryPercentage: 0.8,\n barPercentage: 0.9,\n grouped: true,\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'base',\n 'width',\n 'height'\n ]\n }\n }\n };\n static overrides = {\n scales: {\n _index_: {\n type: 'category',\n offset: true,\n grid: {\n offset: true\n }\n },\n _value_: {\n type: 'linear',\n beginAtZero: true\n }\n }\n };\n parsePrimitiveData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n parseArrayData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n parseObjectData(meta, data, start, count) {\n const { iScale , vScale } = meta;\n const { xAxisKey ='x' , yAxisKey ='y' } = this._parsing;\n const iAxisKey = iScale.axis === 'x' ? xAxisKey : yAxisKey;\n const vAxisKey = vScale.axis === 'x' ? xAxisKey : yAxisKey;\n const parsed = [];\n let i, ilen, item, obj;\n for(i = start, ilen = start + count; i < ilen; ++i){\n obj = data[i];\n item = {};\n item[iScale.axis] = iScale.parse(resolveObjectKey(obj, iAxisKey), i);\n parsed.push(parseValue(resolveObjectKey(obj, vAxisKey), item, vScale, i));\n }\n return parsed;\n }\n updateRangeFromParsed(range, scale, parsed, stack) {\n super.updateRangeFromParsed(range, scale, parsed, stack);\n const custom = parsed._custom;\n if (custom && scale === this._cachedMeta.vScale) {\n range.min = Math.min(range.min, custom.min);\n range.max = Math.max(range.max, custom.max);\n }\n }\n getMaxOverflow() {\n return 0;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const { iScale , vScale } = meta;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const value = isFloatBar(custom) ? '[' + custom.start + ', ' + custom.end + ']' : '' + vScale.getLabelForValue(parsed[vScale.axis]);\n return {\n label: '' + iScale.getLabelForValue(parsed[iScale.axis]),\n value\n };\n }\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n const meta = this._cachedMeta;\n meta.stack = this.getDataset().stack;\n }\n update(mode) {\n const meta = this._cachedMeta;\n this.updateElements(meta.data, 0, meta.data.length, mode);\n }\n updateElements(bars, start, count, mode) {\n const reset = mode === 'reset';\n const { index , _cachedMeta: { vScale } } = this;\n const base = vScale.getBasePixel();\n const horizontal = vScale.isHorizontal();\n const ruler = this._getRuler();\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n for(let i = start; i < start + count; i++){\n const parsed = this.getParsed(i);\n const vpixels = reset || isNullOrUndef(parsed[vScale.axis]) ? {\n base,\n head: base\n } : this._calculateBarValuePixels(i);\n const ipixels = this._calculateBarIndexPixels(i, ruler);\n const stack = (parsed._stacks || {})[vScale.axis];\n const properties = {\n horizontal,\n base: vpixels.base,\n enableBorderRadius: !stack || isFloatBar(parsed._custom) || index === stack._top || index === stack._bottom,\n x: horizontal ? vpixels.head : ipixels.center,\n y: horizontal ? ipixels.center : vpixels.head,\n height: horizontal ? ipixels.size : Math.abs(vpixels.size),\n width: horizontal ? Math.abs(vpixels.size) : ipixels.size\n };\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, bars[i].active ? 'active' : mode);\n }\n const options = properties.options || bars[i].options;\n setBorderSkipped(properties, options, stack, index);\n setInflateAmount(properties, options, ruler.ratio);\n this.updateElement(bars[i], i, properties, mode);\n }\n }\n _getStacks(last, dataIndex) {\n const { iScale } = this._cachedMeta;\n const metasets = iScale.getMatchingVisibleMetas(this._type).filter((meta)=>meta.controller.options.grouped);\n const stacked = iScale.options.stacked;\n const stacks = [];\n const currentParsed = this._cachedMeta.controller.getParsed(dataIndex);\n const iScaleValue = currentParsed && currentParsed[iScale.axis];\n const skipNull = (meta)=>{\n const parsed = meta._parsed.find((item)=>item[iScale.axis] === iScaleValue);\n const val = parsed && parsed[meta.vScale.axis];\n if (isNullOrUndef(val) || isNaN(val)) {\n return true;\n }\n };\n for (const meta of metasets){\n if (dataIndex !== undefined && skipNull(meta)) {\n continue;\n }\n if (stacked === false || stacks.indexOf(meta.stack) === -1 || stacked === undefined && meta.stack === undefined) {\n stacks.push(meta.stack);\n }\n if (meta.index === last) {\n break;\n }\n }\n if (!stacks.length) {\n stacks.push(undefined);\n }\n return stacks;\n }\n _getStackCount(index) {\n return this._getStacks(undefined, index).length;\n }\n _getStackIndex(datasetIndex, name, dataIndex) {\n const stacks = this._getStacks(datasetIndex, dataIndex);\n const index = name !== undefined ? stacks.indexOf(name) : -1;\n return index === -1 ? stacks.length - 1 : index;\n }\n _getRuler() {\n const opts = this.options;\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const pixels = [];\n let i, ilen;\n for(i = 0, ilen = meta.data.length; i < ilen; ++i){\n pixels.push(iScale.getPixelForValue(this.getParsed(i)[iScale.axis], i));\n }\n const barThickness = opts.barThickness;\n const min = barThickness || computeMinSampleSize(meta);\n return {\n min,\n pixels,\n start: iScale._startPixel,\n end: iScale._endPixel,\n stackCount: this._getStackCount(),\n scale: iScale,\n grouped: opts.grouped,\n ratio: barThickness ? 1 : opts.categoryPercentage * opts.barPercentage\n };\n }\n _calculateBarValuePixels(index) {\n const { _cachedMeta: { vScale , _stacked , index: datasetIndex } , options: { base: baseValue , minBarLength } } = this;\n const actualBase = baseValue || 0;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const floating = isFloatBar(custom);\n let value = parsed[vScale.axis];\n let start = 0;\n let length = _stacked ? this.applyStack(vScale, parsed, _stacked) : value;\n let head, size;\n if (length !== value) {\n start = length - value;\n length = value;\n }\n if (floating) {\n value = custom.barStart;\n length = custom.barEnd - custom.barStart;\n if (value !== 0 && sign(value) !== sign(custom.barEnd)) {\n start = 0;\n }\n start += value;\n }\n const startValue = !isNullOrUndef(baseValue) && !floating ? baseValue : start;\n let base = vScale.getPixelForValue(startValue);\n if (this.chart.getDataVisibility(index)) {\n head = vScale.getPixelForValue(start + length);\n } else {\n head = base;\n }\n size = head - base;\n if (Math.abs(size) < minBarLength) {\n size = barSign(size, vScale, actualBase) * minBarLength;\n if (value === actualBase) {\n base -= size / 2;\n }\n const startPixel = vScale.getPixelForDecimal(0);\n const endPixel = vScale.getPixelForDecimal(1);\n const min = Math.min(startPixel, endPixel);\n const max = Math.max(startPixel, endPixel);\n base = Math.max(Math.min(base, max), min);\n head = base + size;\n if (_stacked && !floating) {\n parsed._stacks[vScale.axis]._visualValues[datasetIndex] = vScale.getValueForPixel(head) - vScale.getValueForPixel(base);\n }\n }\n if (base === vScale.getPixelForValue(actualBase)) {\n const halfGrid = sign(size) * vScale.getLineWidthForValue(actualBase) / 2;\n base += halfGrid;\n size -= halfGrid;\n }\n return {\n size,\n base,\n head,\n center: head + size / 2\n };\n }\n _calculateBarIndexPixels(index, ruler) {\n const scale = ruler.scale;\n const options = this.options;\n const skipNull = options.skipNull;\n const maxBarThickness = valueOrDefault(options.maxBarThickness, Infinity);\n let center, size;\n if (ruler.grouped) {\n const stackCount = skipNull ? this._getStackCount(index) : ruler.stackCount;\n const range = options.barThickness === 'flex' ? computeFlexCategoryTraits(index, ruler, options, stackCount) : computeFitCategoryTraits(index, ruler, options, stackCount);\n const stackIndex = this._getStackIndex(this.index, this._cachedMeta.stack, skipNull ? index : undefined);\n center = range.start + range.chunk * stackIndex + range.chunk / 2;\n size = Math.min(maxBarThickness, range.chunk * range.ratio);\n } else {\n center = scale.getPixelForValue(this.getParsed(index)[scale.axis], index);\n size = Math.min(maxBarThickness, ruler.min * ruler.ratio);\n }\n return {\n base: center - size / 2,\n head: center + size / 2,\n center,\n size\n };\n }\n draw() {\n const meta = this._cachedMeta;\n const vScale = meta.vScale;\n const rects = meta.data;\n const ilen = rects.length;\n let i = 0;\n for(; i < ilen; ++i){\n if (this.getParsed(i)[vScale.axis] !== null && !rects[i].hidden) {\n rects[i].draw(this._ctx);\n }\n }\n }\n}\n\nclass BubbleController extends DatasetController {\n static id = 'bubble';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'borderWidth',\n 'radius'\n ]\n }\n }\n };\n static overrides = {\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n }\n parsePrimitiveData(meta, data, start, count) {\n const parsed = super.parsePrimitiveData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n parsed[i]._custom = this.resolveDataElementOptions(i + start).radius;\n }\n return parsed;\n }\n parseArrayData(meta, data, start, count) {\n const parsed = super.parseArrayData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item[2], this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n parseObjectData(meta, data, start, count) {\n const parsed = super.parseObjectData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item && item.r && +item.r, this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n getMaxOverflow() {\n const data = this._cachedMeta.data;\n let max = 0;\n for(let i = data.length - 1; i >= 0; --i){\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const { xScale , yScale } = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n const r = parsed._custom;\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + (r ? ', ' + r : '') + ')'\n };\n }\n update(mode) {\n const points = this._cachedMeta.data;\n this.updateElements(points, 0, points.length, mode);\n }\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const { iScale , vScale } = this._cachedMeta;\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n for(let i = start; i < start + count; i++){\n const point = points[i];\n const parsed = !reset && this.getParsed(i);\n const properties = {};\n const iPixel = properties[iAxis] = reset ? iScale.getPixelForDecimal(0.5) : iScale.getPixelForValue(parsed[iAxis]);\n const vPixel = properties[vAxis] = reset ? vScale.getBasePixel() : vScale.getPixelForValue(parsed[vAxis]);\n properties.skip = isNaN(iPixel) || isNaN(vPixel);\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n if (reset) {\n properties.options.radius = 0;\n }\n }\n this.updateElement(point, i, properties, mode);\n }\n }\n resolveDataElementOptions(index, mode) {\n const parsed = this.getParsed(index);\n let values = super.resolveDataElementOptions(index, mode);\n if (values.$shared) {\n values = Object.assign({}, values, {\n $shared: false\n });\n }\n const radius = values.radius;\n if (mode !== 'active') {\n values.radius = 0;\n }\n values.radius += valueOrDefault(parsed && parsed._custom, radius);\n return values;\n }\n}\n\nfunction getRatioAndOffset(rotation, circumference, cutout) {\n let ratioX = 1;\n let ratioY = 1;\n let offsetX = 0;\n let offsetY = 0;\n if (circumference < TAU) {\n const startAngle = rotation;\n const endAngle = startAngle + circumference;\n const startX = Math.cos(startAngle);\n const startY = Math.sin(startAngle);\n const endX = Math.cos(endAngle);\n const endY = Math.sin(endAngle);\n const calcMax = (angle, a, b)=>_angleBetween(angle, startAngle, endAngle, true) ? 1 : Math.max(a, a * cutout, b, b * cutout);\n const calcMin = (angle, a, b)=>_angleBetween(angle, startAngle, endAngle, true) ? -1 : Math.min(a, a * cutout, b, b * cutout);\n const maxX = calcMax(0, startX, endX);\n const maxY = calcMax(HALF_PI, startY, endY);\n const minX = calcMin(PI, startX, endX);\n const minY = calcMin(PI + HALF_PI, startY, endY);\n ratioX = (maxX - minX) / 2;\n ratioY = (maxY - minY) / 2;\n offsetX = -(maxX + minX) / 2;\n offsetY = -(maxY + minY) / 2;\n }\n return {\n ratioX,\n ratioY,\n offsetX,\n offsetY\n };\n}\nclass DoughnutController extends DatasetController {\n static id = 'doughnut';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'arc',\n animation: {\n animateRotate: true,\n animateScale: false\n },\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'circumference',\n 'endAngle',\n 'innerRadius',\n 'outerRadius',\n 'startAngle',\n 'x',\n 'y',\n 'offset',\n 'borderWidth',\n 'spacing'\n ]\n }\n },\n cutout: '50%',\n rotation: 0,\n circumference: 360,\n radius: '100%',\n spacing: 0,\n indexAxis: 'r'\n };\n static descriptors = {\n _scriptable: (name)=>name !== 'spacing',\n _indexable: (name)=>name !== 'spacing' && !name.startsWith('borderDash') && !name.startsWith('hoverBorderDash')\n };\n static overrides = {\n aspectRatio: 1,\n plugins: {\n legend: {\n labels: {\n generateLabels (chart) {\n const data = chart.data;\n if (data.labels.length && data.datasets.length) {\n const { labels: { pointStyle , color } } = chart.legend.options;\n return data.labels.map((label, i)=>{\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n return {\n text: label,\n fillStyle: style.backgroundColor,\n strokeStyle: style.borderColor,\n fontColor: color,\n lineWidth: style.borderWidth,\n pointStyle: pointStyle,\n hidden: !chart.getDataVisibility(i),\n index: i\n };\n });\n }\n return [];\n }\n },\n onClick (e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n }\n };\n constructor(chart, datasetIndex){\n super(chart, datasetIndex);\n this.enableOptionSharing = true;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.offsetX = undefined;\n this.offsetY = undefined;\n }\n linkScales() {}\n parse(start, count) {\n const data = this.getDataset().data;\n const meta = this._cachedMeta;\n if (this._parsing === false) {\n meta._parsed = data;\n } else {\n let getter = (i)=>+data[i];\n if (isObject(data[start])) {\n const { key ='value' } = this._parsing;\n getter = (i)=>+resolveObjectKey(data[i], key);\n }\n let i, ilen;\n for(i = start, ilen = start + count; i < ilen; ++i){\n meta._parsed[i] = getter(i);\n }\n }\n }\n _getRotation() {\n return toRadians(this.options.rotation - 90);\n }\n _getCircumference() {\n return toRadians(this.options.circumference);\n }\n _getRotationExtents() {\n let min = TAU;\n let max = -TAU;\n for(let i = 0; i < this.chart.data.datasets.length; ++i){\n if (this.chart.isDatasetVisible(i) && this.chart.getDatasetMeta(i).type === this._type) {\n const controller = this.chart.getDatasetMeta(i).controller;\n const rotation = controller._getRotation();\n const circumference = controller._getCircumference();\n min = Math.min(min, rotation);\n max = Math.max(max, rotation + circumference);\n }\n }\n return {\n rotation: min,\n circumference: max - min\n };\n }\n update(mode) {\n const chart = this.chart;\n const { chartArea } = chart;\n const meta = this._cachedMeta;\n const arcs = meta.data;\n const spacing = this.getMaxBorderWidth() + this.getMaxOffset(arcs) + this.options.spacing;\n const maxSize = Math.max((Math.min(chartArea.width, chartArea.height) - spacing) / 2, 0);\n const cutout = Math.min(toPercentage(this.options.cutout, maxSize), 1);\n const chartWeight = this._getRingWeight(this.index);\n const { circumference , rotation } = this._getRotationExtents();\n const { ratioX , ratioY , offsetX , offsetY } = getRatioAndOffset(rotation, circumference, cutout);\n const maxWidth = (chartArea.width - spacing) / ratioX;\n const maxHeight = (chartArea.height - spacing) / ratioY;\n const maxRadius = Math.max(Math.min(maxWidth, maxHeight) / 2, 0);\n const outerRadius = toDimension(this.options.radius, maxRadius);\n const innerRadius = Math.max(outerRadius * cutout, 0);\n const radiusLength = (outerRadius - innerRadius) / this._getVisibleDatasetWeightTotal();\n this.offsetX = offsetX * outerRadius;\n this.offsetY = offsetY * outerRadius;\n meta.total = this.calculateTotal();\n this.outerRadius = outerRadius - radiusLength * this._getRingWeightOffset(this.index);\n this.innerRadius = Math.max(this.outerRadius - radiusLength * chartWeight, 0);\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n _circumference(i, reset) {\n const opts = this.options;\n const meta = this._cachedMeta;\n const circumference = this._getCircumference();\n if (reset && opts.animation.animateRotate || !this.chart.getDataVisibility(i) || meta._parsed[i] === null || meta.data[i].hidden) {\n return 0;\n }\n return this.calculateCircumference(meta._parsed[i] * circumference / TAU);\n }\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const centerX = (chartArea.left + chartArea.right) / 2;\n const centerY = (chartArea.top + chartArea.bottom) / 2;\n const animateScale = reset && animationOpts.animateScale;\n const innerRadius = animateScale ? 0 : this.innerRadius;\n const outerRadius = animateScale ? 0 : this.outerRadius;\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n let startAngle = this._getRotation();\n let i;\n for(i = 0; i < start; ++i){\n startAngle += this._circumference(i, reset);\n }\n for(i = start; i < start + count; ++i){\n const circumference = this._circumference(i, reset);\n const arc = arcs[i];\n const properties = {\n x: centerX + this.offsetX,\n y: centerY + this.offsetY,\n startAngle,\n endAngle: startAngle + circumference,\n circumference,\n outerRadius,\n innerRadius\n };\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, arc.active ? 'active' : mode);\n }\n startAngle += circumference;\n this.updateElement(arc, i, properties, mode);\n }\n }\n calculateTotal() {\n const meta = this._cachedMeta;\n const metaData = meta.data;\n let total = 0;\n let i;\n for(i = 0; i < metaData.length; i++){\n const value = meta._parsed[i];\n if (value !== null && !isNaN(value) && this.chart.getDataVisibility(i) && !metaData[i].hidden) {\n total += Math.abs(value);\n }\n }\n return total;\n }\n calculateCircumference(value) {\n const total = this._cachedMeta.total;\n if (total > 0 && !isNaN(value)) {\n return TAU * (Math.abs(value) / total);\n }\n return 0;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index], chart.options.locale);\n return {\n label: labels[index] || '',\n value\n };\n }\n getMaxBorderWidth(arcs) {\n let max = 0;\n const chart = this.chart;\n let i, ilen, meta, controller, options;\n if (!arcs) {\n for(i = 0, ilen = chart.data.datasets.length; i < ilen; ++i){\n if (chart.isDatasetVisible(i)) {\n meta = chart.getDatasetMeta(i);\n arcs = meta.data;\n controller = meta.controller;\n break;\n }\n }\n }\n if (!arcs) {\n return 0;\n }\n for(i = 0, ilen = arcs.length; i < ilen; ++i){\n options = controller.resolveDataElementOptions(i);\n if (options.borderAlign !== 'inner') {\n max = Math.max(max, options.borderWidth || 0, options.hoverBorderWidth || 0);\n }\n }\n return max;\n }\n getMaxOffset(arcs) {\n let max = 0;\n for(let i = 0, ilen = arcs.length; i < ilen; ++i){\n const options = this.resolveDataElementOptions(i);\n max = Math.max(max, options.offset || 0, options.hoverOffset || 0);\n }\n return max;\n }\n _getRingWeightOffset(datasetIndex) {\n let ringWeightOffset = 0;\n for(let i = 0; i < datasetIndex; ++i){\n if (this.chart.isDatasetVisible(i)) {\n ringWeightOffset += this._getRingWeight(i);\n }\n }\n return ringWeightOffset;\n }\n _getRingWeight(datasetIndex) {\n return Math.max(valueOrDefault(this.chart.data.datasets[datasetIndex].weight, 1), 0);\n }\n _getVisibleDatasetWeightTotal() {\n return this._getRingWeightOffset(this.chart.data.datasets.length) || 1;\n }\n}\n\nclass LineController extends DatasetController {\n static id = 'line';\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n showLine: true,\n spanGaps: false\n };\n static overrides = {\n scales: {\n _index_: {\n type: 'category'\n },\n _value_: {\n type: 'linear'\n }\n }\n };\n initialize() {\n this.enableOptionSharing = true;\n this.supportsDecimation = true;\n super.initialize();\n }\n update(mode) {\n const meta = this._cachedMeta;\n const { dataset: line , data: points = [] , _dataset } = meta;\n const animationsDisabled = this.chart._animationsDisabled;\n let { start , count } = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n this._drawStart = start;\n this._drawCount = count;\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n this.updateElements(points, start, count, mode);\n }\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const { iScale , vScale , _stacked , _dataset } = this._cachedMeta;\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const { spanGaps , segment } = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n const end = start + count;\n const pointsCount = points.length;\n let prevParsed = start > 0 && this.getParsed(start - 1);\n for(let i = 0; i < pointsCount; ++i){\n const point = points[i];\n const properties = directUpdate ? point : {};\n if (i < start || i >= end) {\n properties.skip = true;\n continue;\n }\n const parsed = this.getParsed(i);\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && Math.abs(parsed[iAxis] - prevParsed[iAxis]) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n prevParsed = parsed;\n }\n }\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n const data = meta.data || [];\n if (!data.length) {\n return border;\n }\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n draw() {\n const meta = this._cachedMeta;\n meta.dataset.updateControlPoints(this.chart.chartArea, meta.iScale.axis);\n super.draw();\n }\n}\n\nclass PolarAreaController extends DatasetController {\n static id = 'polarArea';\n static defaults = {\n dataElementType: 'arc',\n animation: {\n animateRotate: true,\n animateScale: true\n },\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius'\n ]\n }\n },\n indexAxis: 'r',\n startAngle: 0\n };\n static overrides = {\n aspectRatio: 1,\n plugins: {\n legend: {\n labels: {\n generateLabels (chart) {\n const data = chart.data;\n if (data.labels.length && data.datasets.length) {\n const { labels: { pointStyle , color } } = chart.legend.options;\n return data.labels.map((label, i)=>{\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n return {\n text: label,\n fillStyle: style.backgroundColor,\n strokeStyle: style.borderColor,\n fontColor: color,\n lineWidth: style.borderWidth,\n pointStyle: pointStyle,\n hidden: !chart.getDataVisibility(i),\n index: i\n };\n });\n }\n return [];\n }\n },\n onClick (e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n },\n scales: {\n r: {\n type: 'radialLinear',\n angleLines: {\n display: false\n },\n beginAtZero: true,\n grid: {\n circular: true\n },\n pointLabels: {\n display: false\n },\n startAngle: 0\n }\n }\n };\n constructor(chart, datasetIndex){\n super(chart, datasetIndex);\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index].r, chart.options.locale);\n return {\n label: labels[index] || '',\n value\n };\n }\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n update(mode) {\n const arcs = this._cachedMeta.data;\n this._updateRadius();\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n getMinMax() {\n const meta = this._cachedMeta;\n const range = {\n min: Number.POSITIVE_INFINITY,\n max: Number.NEGATIVE_INFINITY\n };\n meta.data.forEach((element, index)=>{\n const parsed = this.getParsed(index).r;\n if (!isNaN(parsed) && this.chart.getDataVisibility(index)) {\n if (parsed < range.min) {\n range.min = parsed;\n }\n if (parsed > range.max) {\n range.max = parsed;\n }\n }\n });\n return range;\n }\n _updateRadius() {\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const minSize = Math.min(chartArea.right - chartArea.left, chartArea.bottom - chartArea.top);\n const outerRadius = Math.max(minSize / 2, 0);\n const innerRadius = Math.max(opts.cutoutPercentage ? outerRadius / 100 * opts.cutoutPercentage : 1, 0);\n const radiusLength = (outerRadius - innerRadius) / chart.getVisibleDatasetCount();\n this.outerRadius = outerRadius - radiusLength * this.index;\n this.innerRadius = this.outerRadius - radiusLength;\n }\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const scale = this._cachedMeta.rScale;\n const centerX = scale.xCenter;\n const centerY = scale.yCenter;\n const datasetStartAngle = scale.getIndexAngle(0) - 0.5 * PI;\n let angle = datasetStartAngle;\n let i;\n const defaultAngle = 360 / this.countVisibleElements();\n for(i = 0; i < start; ++i){\n angle += this._computeAngle(i, mode, defaultAngle);\n }\n for(i = start; i < start + count; i++){\n const arc = arcs[i];\n let startAngle = angle;\n let endAngle = angle + this._computeAngle(i, mode, defaultAngle);\n let outerRadius = chart.getDataVisibility(i) ? scale.getDistanceFromCenterForValue(this.getParsed(i).r) : 0;\n angle = endAngle;\n if (reset) {\n if (animationOpts.animateScale) {\n outerRadius = 0;\n }\n if (animationOpts.animateRotate) {\n startAngle = endAngle = datasetStartAngle;\n }\n }\n const properties = {\n x: centerX,\n y: centerY,\n innerRadius: 0,\n outerRadius,\n startAngle,\n endAngle,\n options: this.resolveDataElementOptions(i, arc.active ? 'active' : mode)\n };\n this.updateElement(arc, i, properties, mode);\n }\n }\n countVisibleElements() {\n const meta = this._cachedMeta;\n let count = 0;\n meta.data.forEach((element, index)=>{\n if (!isNaN(this.getParsed(index).r) && this.chart.getDataVisibility(index)) {\n count++;\n }\n });\n return count;\n }\n _computeAngle(index, mode, defaultAngle) {\n return this.chart.getDataVisibility(index) ? toRadians(this.resolveDataElementOptions(index, mode).angle || defaultAngle) : 0;\n }\n}\n\nclass PieController extends DoughnutController {\n static id = 'pie';\n static defaults = {\n cutout: 0,\n rotation: 0,\n circumference: 360,\n radius: '100%'\n };\n}\n\nclass RadarController extends DatasetController {\n static id = 'radar';\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n indexAxis: 'r',\n showLine: true,\n elements: {\n line: {\n fill: 'start'\n }\n }\n };\n static overrides = {\n aspectRatio: 1,\n scales: {\n r: {\n type: 'radialLinear'\n }\n }\n };\n getLabelAndValue(index) {\n const vScale = this._cachedMeta.vScale;\n const parsed = this.getParsed(index);\n return {\n label: vScale.getLabels()[index],\n value: '' + vScale.getLabelForValue(parsed[vScale.axis])\n };\n }\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n update(mode) {\n const meta = this._cachedMeta;\n const line = meta.dataset;\n const points = meta.data || [];\n const labels = meta.iScale.getLabels();\n line.points = points;\n if (mode !== 'resize') {\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n const properties = {\n _loop: true,\n _fullLoop: labels.length === points.length,\n options\n };\n this.updateElement(line, undefined, properties, mode);\n }\n this.updateElements(points, 0, points.length, mode);\n }\n updateElements(points, start, count, mode) {\n const scale = this._cachedMeta.rScale;\n const reset = mode === 'reset';\n for(let i = start; i < start + count; i++){\n const point = points[i];\n const options = this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n const pointPosition = scale.getPointPositionForValue(i, this.getParsed(i).r);\n const x = reset ? scale.xCenter : pointPosition.x;\n const y = reset ? scale.yCenter : pointPosition.y;\n const properties = {\n x,\n y,\n angle: pointPosition.angle,\n skip: isNaN(x) || isNaN(y),\n options\n };\n this.updateElement(point, i, properties, mode);\n }\n }\n}\n\nclass ScatterController extends DatasetController {\n static id = 'scatter';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n showLine: false,\n fill: false\n };\n static overrides = {\n interaction: {\n mode: 'point'\n },\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const { xScale , yScale } = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + ')'\n };\n }\n update(mode) {\n const meta = this._cachedMeta;\n const { data: points = [] } = meta;\n const animationsDisabled = this.chart._animationsDisabled;\n let { start , count } = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n this._drawStart = start;\n this._drawCount = count;\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n if (this.options.showLine) {\n if (!this.datasetElementType) {\n this.addElements();\n }\n const { dataset: line , _dataset } = meta;\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n const options = this.resolveDatasetElementOptions(mode);\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n } else if (this.datasetElementType) {\n delete meta.dataset;\n this.datasetElementType = false;\n }\n this.updateElements(points, start, count, mode);\n }\n addElements() {\n const { showLine } = this.options;\n if (!this.datasetElementType && showLine) {\n this.datasetElementType = this.chart.registry.getElement('line');\n }\n super.addElements();\n }\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const { iScale , vScale , _stacked , _dataset } = this._cachedMeta;\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const { spanGaps , segment } = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n let prevParsed = start > 0 && this.getParsed(start - 1);\n for(let i = start; i < start + count; ++i){\n const point = points[i];\n const parsed = this.getParsed(i);\n const properties = directUpdate ? point : {};\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && Math.abs(parsed[iAxis] - prevParsed[iAxis]) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n prevParsed = parsed;\n }\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n }\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const data = meta.data || [];\n if (!this.options.showLine) {\n let max = 0;\n for(let i = data.length - 1; i >= 0; --i){\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n if (!data.length) {\n return border;\n }\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n}\n\nvar controllers = /*#__PURE__*/Object.freeze({\n__proto__: null,\nBarController: BarController,\nBubbleController: BubbleController,\nDoughnutController: DoughnutController,\nLineController: LineController,\nPieController: PieController,\nPolarAreaController: PolarAreaController,\nRadarController: RadarController,\nScatterController: ScatterController\n});\n\n/**\n * @namespace Chart._adapters\n * @since 2.8.0\n * @private\n */ function abstract() {\n throw new Error('This method is not implemented: Check that a complete date adapter is provided.');\n}\n/**\n * Date adapter (current used by the time scale)\n * @namespace Chart._adapters._date\n * @memberof Chart._adapters\n * @private\n */ class DateAdapterBase {\n /**\n * Override default date adapter methods.\n * Accepts type parameter to define options type.\n * @example\n * Chart._adapters._date.override<{myAdapterOption: string}>({\n * init() {\n * console.log(this.options.myAdapterOption);\n * }\n * })\n */ static override(members) {\n Object.assign(DateAdapterBase.prototype, members);\n }\n options;\n constructor(options){\n this.options = options || {};\n }\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n init() {}\n formats() {\n return abstract();\n }\n parse() {\n return abstract();\n }\n format() {\n return abstract();\n }\n add() {\n return abstract();\n }\n diff() {\n return abstract();\n }\n startOf() {\n return abstract();\n }\n endOf() {\n return abstract();\n }\n}\nvar adapters = {\n _date: DateAdapterBase\n};\n\nfunction binarySearch(metaset, axis, value, intersect) {\n const { controller , data , _sorted } = metaset;\n const iScale = controller._cachedMeta.iScale;\n if (iScale && axis === iScale.axis && axis !== 'r' && _sorted && data.length) {\n const lookupMethod = iScale._reversePixels ? _rlookupByKey : _lookupByKey;\n if (!intersect) {\n return lookupMethod(data, axis, value);\n } else if (controller._sharedOptions) {\n const el = data[0];\n const range = typeof el.getRange === 'function' && el.getRange(axis);\n if (range) {\n const start = lookupMethod(data, axis, value - range);\n const end = lookupMethod(data, axis, value + range);\n return {\n lo: start.lo,\n hi: end.hi\n };\n }\n }\n }\n return {\n lo: 0,\n hi: data.length - 1\n };\n}\n function evaluateInteractionItems(chart, axis, position, handler, intersect) {\n const metasets = chart.getSortedVisibleDatasetMetas();\n const value = position[axis];\n for(let i = 0, ilen = metasets.length; i < ilen; ++i){\n const { index , data } = metasets[i];\n const { lo , hi } = binarySearch(metasets[i], axis, value, intersect);\n for(let j = lo; j <= hi; ++j){\n const element = data[j];\n if (!element.skip) {\n handler(element, index, j);\n }\n }\n }\n}\n function getDistanceMetricForAxis(axis) {\n const useX = axis.indexOf('x') !== -1;\n const useY = axis.indexOf('y') !== -1;\n return function(pt1, pt2) {\n const deltaX = useX ? Math.abs(pt1.x - pt2.x) : 0;\n const deltaY = useY ? Math.abs(pt1.y - pt2.y) : 0;\n return Math.sqrt(Math.pow(deltaX, 2) + Math.pow(deltaY, 2));\n };\n}\n function getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) {\n const items = [];\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return items;\n }\n const evaluationFunc = function(element, datasetIndex, index) {\n if (!includeInvisible && !_isPointInArea(element, chart.chartArea, 0)) {\n return;\n }\n if (element.inRange(position.x, position.y, useFinalPosition)) {\n items.push({\n element,\n datasetIndex,\n index\n });\n }\n };\n evaluateInteractionItems(chart, axis, position, evaluationFunc, true);\n return items;\n}\n function getNearestRadialItems(chart, position, axis, useFinalPosition) {\n let items = [];\n function evaluationFunc(element, datasetIndex, index) {\n const { startAngle , endAngle } = element.getProps([\n 'startAngle',\n 'endAngle'\n ], useFinalPosition);\n const { angle } = getAngleFromPoint(element, {\n x: position.x,\n y: position.y\n });\n if (_angleBetween(angle, startAngle, endAngle)) {\n items.push({\n element,\n datasetIndex,\n index\n });\n }\n }\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n function getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n let items = [];\n const distanceMetric = getDistanceMetricForAxis(axis);\n let minDistance = Number.POSITIVE_INFINITY;\n function evaluationFunc(element, datasetIndex, index) {\n const inRange = element.inRange(position.x, position.y, useFinalPosition);\n if (intersect && !inRange) {\n return;\n }\n const center = element.getCenterPoint(useFinalPosition);\n const pointInArea = !!includeInvisible || chart.isPointInArea(center);\n if (!pointInArea && !inRange) {\n return;\n }\n const distance = distanceMetric(position, center);\n if (distance < minDistance) {\n items = [\n {\n element,\n datasetIndex,\n index\n }\n ];\n minDistance = distance;\n } else if (distance === minDistance) {\n items.push({\n element,\n datasetIndex,\n index\n });\n }\n }\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n function getNearestItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return [];\n }\n return axis === 'r' && !intersect ? getNearestRadialItems(chart, position, axis, useFinalPosition) : getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible);\n}\n function getAxisItems(chart, position, axis, intersect, useFinalPosition) {\n const items = [];\n const rangeMethod = axis === 'x' ? 'inXRange' : 'inYRange';\n let intersectsItem = false;\n evaluateInteractionItems(chart, axis, position, (element, datasetIndex, index)=>{\n if (element[rangeMethod] && element[rangeMethod](position[axis], useFinalPosition)) {\n items.push({\n element,\n datasetIndex,\n index\n });\n intersectsItem = intersectsItem || element.inRange(position.x, position.y, useFinalPosition);\n }\n });\n if (intersect && !intersectsItem) {\n return [];\n }\n return items;\n}\n var Interaction = {\n evaluateInteractionItems,\n modes: {\n index (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'x';\n const includeInvisible = options.includeInvisible || false;\n const items = options.intersect ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) : getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n const elements = [];\n if (!items.length) {\n return [];\n }\n chart.getSortedVisibleDatasetMetas().forEach((meta)=>{\n const index = items[0].index;\n const element = meta.data[index];\n if (element && !element.skip) {\n elements.push({\n element,\n datasetIndex: meta.index,\n index\n });\n }\n });\n return elements;\n },\n dataset (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n let items = options.intersect ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) : getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n if (items.length > 0) {\n const datasetIndex = items[0].datasetIndex;\n const data = chart.getDatasetMeta(datasetIndex).data;\n items = [];\n for(let i = 0; i < data.length; ++i){\n items.push({\n element: data[i],\n datasetIndex,\n index: i\n });\n }\n }\n return items;\n },\n point (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible);\n },\n nearest (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getNearestItems(chart, position, axis, options.intersect, useFinalPosition, includeInvisible);\n },\n x (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'x', options.intersect, useFinalPosition);\n },\n y (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'y', options.intersect, useFinalPosition);\n }\n }\n};\n\nconst STATIC_POSITIONS = [\n 'left',\n 'top',\n 'right',\n 'bottom'\n];\nfunction filterByPosition(array, position) {\n return array.filter((v)=>v.pos === position);\n}\nfunction filterDynamicPositionByAxis(array, axis) {\n return array.filter((v)=>STATIC_POSITIONS.indexOf(v.pos) === -1 && v.box.axis === axis);\n}\nfunction sortByWeight(array, reverse) {\n return array.sort((a, b)=>{\n const v0 = reverse ? b : a;\n const v1 = reverse ? a : b;\n return v0.weight === v1.weight ? v0.index - v1.index : v0.weight - v1.weight;\n });\n}\nfunction wrapBoxes(boxes) {\n const layoutBoxes = [];\n let i, ilen, box, pos, stack, stackWeight;\n for(i = 0, ilen = (boxes || []).length; i < ilen; ++i){\n box = boxes[i];\n ({ position: pos , options: { stack , stackWeight =1 } } = box);\n layoutBoxes.push({\n index: i,\n box,\n pos,\n horizontal: box.isHorizontal(),\n weight: box.weight,\n stack: stack && pos + stack,\n stackWeight\n });\n }\n return layoutBoxes;\n}\nfunction buildStacks(layouts) {\n const stacks = {};\n for (const wrap of layouts){\n const { stack , pos , stackWeight } = wrap;\n if (!stack || !STATIC_POSITIONS.includes(pos)) {\n continue;\n }\n const _stack = stacks[stack] || (stacks[stack] = {\n count: 0,\n placed: 0,\n weight: 0,\n size: 0\n });\n _stack.count++;\n _stack.weight += stackWeight;\n }\n return stacks;\n}\n function setLayoutDims(layouts, params) {\n const stacks = buildStacks(layouts);\n const { vBoxMaxWidth , hBoxMaxHeight } = params;\n let i, ilen, layout;\n for(i = 0, ilen = layouts.length; i < ilen; ++i){\n layout = layouts[i];\n const { fullSize } = layout.box;\n const stack = stacks[layout.stack];\n const factor = stack && layout.stackWeight / stack.weight;\n if (layout.horizontal) {\n layout.width = factor ? factor * vBoxMaxWidth : fullSize && params.availableWidth;\n layout.height = hBoxMaxHeight;\n } else {\n layout.width = vBoxMaxWidth;\n layout.height = factor ? factor * hBoxMaxHeight : fullSize && params.availableHeight;\n }\n }\n return stacks;\n}\nfunction buildLayoutBoxes(boxes) {\n const layoutBoxes = wrapBoxes(boxes);\n const fullSize = sortByWeight(layoutBoxes.filter((wrap)=>wrap.box.fullSize), true);\n const left = sortByWeight(filterByPosition(layoutBoxes, 'left'), true);\n const right = sortByWeight(filterByPosition(layoutBoxes, 'right'));\n const top = sortByWeight(filterByPosition(layoutBoxes, 'top'), true);\n const bottom = sortByWeight(filterByPosition(layoutBoxes, 'bottom'));\n const centerHorizontal = filterDynamicPositionByAxis(layoutBoxes, 'x');\n const centerVertical = filterDynamicPositionByAxis(layoutBoxes, 'y');\n return {\n fullSize,\n leftAndTop: left.concat(top),\n rightAndBottom: right.concat(centerVertical).concat(bottom).concat(centerHorizontal),\n chartArea: filterByPosition(layoutBoxes, 'chartArea'),\n vertical: left.concat(right).concat(centerVertical),\n horizontal: top.concat(bottom).concat(centerHorizontal)\n };\n}\nfunction getCombinedMax(maxPadding, chartArea, a, b) {\n return Math.max(maxPadding[a], chartArea[a]) + Math.max(maxPadding[b], chartArea[b]);\n}\nfunction updateMaxPadding(maxPadding, boxPadding) {\n maxPadding.top = Math.max(maxPadding.top, boxPadding.top);\n maxPadding.left = Math.max(maxPadding.left, boxPadding.left);\n maxPadding.bottom = Math.max(maxPadding.bottom, boxPadding.bottom);\n maxPadding.right = Math.max(maxPadding.right, boxPadding.right);\n}\nfunction updateDims(chartArea, params, layout, stacks) {\n const { pos , box } = layout;\n const maxPadding = chartArea.maxPadding;\n if (!isObject(pos)) {\n if (layout.size) {\n chartArea[pos] -= layout.size;\n }\n const stack = stacks[layout.stack] || {\n size: 0,\n count: 1\n };\n stack.size = Math.max(stack.size, layout.horizontal ? box.height : box.width);\n layout.size = stack.size / stack.count;\n chartArea[pos] += layout.size;\n }\n if (box.getPadding) {\n updateMaxPadding(maxPadding, box.getPadding());\n }\n const newWidth = Math.max(0, params.outerWidth - getCombinedMax(maxPadding, chartArea, 'left', 'right'));\n const newHeight = Math.max(0, params.outerHeight - getCombinedMax(maxPadding, chartArea, 'top', 'bottom'));\n const widthChanged = newWidth !== chartArea.w;\n const heightChanged = newHeight !== chartArea.h;\n chartArea.w = newWidth;\n chartArea.h = newHeight;\n return layout.horizontal ? {\n same: widthChanged,\n other: heightChanged\n } : {\n same: heightChanged,\n other: widthChanged\n };\n}\nfunction handleMaxPadding(chartArea) {\n const maxPadding = chartArea.maxPadding;\n function updatePos(pos) {\n const change = Math.max(maxPadding[pos] - chartArea[pos], 0);\n chartArea[pos] += change;\n return change;\n }\n chartArea.y += updatePos('top');\n chartArea.x += updatePos('left');\n updatePos('right');\n updatePos('bottom');\n}\nfunction getMargins(horizontal, chartArea) {\n const maxPadding = chartArea.maxPadding;\n function marginForPositions(positions) {\n const margin = {\n left: 0,\n top: 0,\n right: 0,\n bottom: 0\n };\n positions.forEach((pos)=>{\n margin[pos] = Math.max(chartArea[pos], maxPadding[pos]);\n });\n return margin;\n }\n return horizontal ? marginForPositions([\n 'left',\n 'right'\n ]) : marginForPositions([\n 'top',\n 'bottom'\n ]);\n}\nfunction fitBoxes(boxes, chartArea, params, stacks) {\n const refitBoxes = [];\n let i, ilen, layout, box, refit, changed;\n for(i = 0, ilen = boxes.length, refit = 0; i < ilen; ++i){\n layout = boxes[i];\n box = layout.box;\n box.update(layout.width || chartArea.w, layout.height || chartArea.h, getMargins(layout.horizontal, chartArea));\n const { same , other } = updateDims(chartArea, params, layout, stacks);\n refit |= same && refitBoxes.length;\n changed = changed || other;\n if (!box.fullSize) {\n refitBoxes.push(layout);\n }\n }\n return refit && fitBoxes(refitBoxes, chartArea, params, stacks) || changed;\n}\nfunction setBoxDims(box, left, top, width, height) {\n box.top = top;\n box.left = left;\n box.right = left + width;\n box.bottom = top + height;\n box.width = width;\n box.height = height;\n}\nfunction placeBoxes(boxes, chartArea, params, stacks) {\n const userPadding = params.padding;\n let { x , y } = chartArea;\n for (const layout of boxes){\n const box = layout.box;\n const stack = stacks[layout.stack] || {\n count: 1,\n placed: 0,\n weight: 1\n };\n const weight = layout.stackWeight / stack.weight || 1;\n if (layout.horizontal) {\n const width = chartArea.w * weight;\n const height = stack.size || box.height;\n if (defined(stack.start)) {\n y = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, userPadding.left, y, params.outerWidth - userPadding.right - userPadding.left, height);\n } else {\n setBoxDims(box, chartArea.left + stack.placed, y, width, height);\n }\n stack.start = y;\n stack.placed += width;\n y = box.bottom;\n } else {\n const height = chartArea.h * weight;\n const width = stack.size || box.width;\n if (defined(stack.start)) {\n x = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, x, userPadding.top, width, params.outerHeight - userPadding.bottom - userPadding.top);\n } else {\n setBoxDims(box, x, chartArea.top + stack.placed, width, height);\n }\n stack.start = x;\n stack.placed += height;\n x = box.right;\n }\n }\n chartArea.x = x;\n chartArea.y = y;\n}\nvar layouts = {\n addBox (chart, item) {\n if (!chart.boxes) {\n chart.boxes = [];\n }\n item.fullSize = item.fullSize || false;\n item.position = item.position || 'top';\n item.weight = item.weight || 0;\n item._layers = item._layers || function() {\n return [\n {\n z: 0,\n draw (chartArea) {\n item.draw(chartArea);\n }\n }\n ];\n };\n chart.boxes.push(item);\n },\n removeBox (chart, layoutItem) {\n const index = chart.boxes ? chart.boxes.indexOf(layoutItem) : -1;\n if (index !== -1) {\n chart.boxes.splice(index, 1);\n }\n },\n configure (chart, item, options) {\n item.fullSize = options.fullSize;\n item.position = options.position;\n item.weight = options.weight;\n },\n update (chart, width, height, minPadding) {\n if (!chart) {\n return;\n }\n const padding = toPadding(chart.options.layout.padding);\n const availableWidth = Math.max(width - padding.width, 0);\n const availableHeight = Math.max(height - padding.height, 0);\n const boxes = buildLayoutBoxes(chart.boxes);\n const verticalBoxes = boxes.vertical;\n const horizontalBoxes = boxes.horizontal;\n each(chart.boxes, (box)=>{\n if (typeof box.beforeLayout === 'function') {\n box.beforeLayout();\n }\n });\n const visibleVerticalBoxCount = verticalBoxes.reduce((total, wrap)=>wrap.box.options && wrap.box.options.display === false ? total : total + 1, 0) || 1;\n const params = Object.freeze({\n outerWidth: width,\n outerHeight: height,\n padding,\n availableWidth,\n availableHeight,\n vBoxMaxWidth: availableWidth / 2 / visibleVerticalBoxCount,\n hBoxMaxHeight: availableHeight / 2\n });\n const maxPadding = Object.assign({}, padding);\n updateMaxPadding(maxPadding, toPadding(minPadding));\n const chartArea = Object.assign({\n maxPadding,\n w: availableWidth,\n h: availableHeight,\n x: padding.left,\n y: padding.top\n }, padding);\n const stacks = setLayoutDims(verticalBoxes.concat(horizontalBoxes), params);\n fitBoxes(boxes.fullSize, chartArea, params, stacks);\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n if (fitBoxes(horizontalBoxes, chartArea, params, stacks)) {\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n }\n handleMaxPadding(chartArea);\n placeBoxes(boxes.leftAndTop, chartArea, params, stacks);\n chartArea.x += chartArea.w;\n chartArea.y += chartArea.h;\n placeBoxes(boxes.rightAndBottom, chartArea, params, stacks);\n chart.chartArea = {\n left: chartArea.left,\n top: chartArea.top,\n right: chartArea.left + chartArea.w,\n bottom: chartArea.top + chartArea.h,\n height: chartArea.h,\n width: chartArea.w\n };\n each(boxes.chartArea, (layout)=>{\n const box = layout.box;\n Object.assign(box, chart.chartArea);\n box.update(chartArea.w, chartArea.h, {\n left: 0,\n top: 0,\n right: 0,\n bottom: 0\n });\n });\n }\n};\n\nclass BasePlatform {\n acquireContext(canvas, aspectRatio) {}\n releaseContext(context) {\n return false;\n }\n addEventListener(chart, type, listener) {}\n removeEventListener(chart, type, listener) {}\n getDevicePixelRatio() {\n return 1;\n }\n getMaximumSize(element, width, height, aspectRatio) {\n width = Math.max(0, width || element.width);\n height = height || element.height;\n return {\n width,\n height: Math.max(0, aspectRatio ? Math.floor(width / aspectRatio) : height)\n };\n }\n isAttached(canvas) {\n return true;\n }\n updateConfig(config) {\n }\n}\n\nclass BasicPlatform extends BasePlatform {\n acquireContext(item) {\n return item && item.getContext && item.getContext('2d') || null;\n }\n updateConfig(config) {\n config.options.animation = false;\n }\n}\n\nconst EXPANDO_KEY = '$chartjs';\n const EVENT_TYPES = {\n touchstart: 'mousedown',\n touchmove: 'mousemove',\n touchend: 'mouseup',\n pointerenter: 'mouseenter',\n pointerdown: 'mousedown',\n pointermove: 'mousemove',\n pointerup: 'mouseup',\n pointerleave: 'mouseout',\n pointerout: 'mouseout'\n};\nconst isNullOrEmpty = (value)=>value === null || value === '';\n function initCanvas(canvas, aspectRatio) {\n const style = canvas.style;\n const renderHeight = canvas.getAttribute('height');\n const renderWidth = canvas.getAttribute('width');\n canvas[EXPANDO_KEY] = {\n initial: {\n height: renderHeight,\n width: renderWidth,\n style: {\n display: style.display,\n height: style.height,\n width: style.width\n }\n }\n };\n style.display = style.display || 'block';\n style.boxSizing = style.boxSizing || 'border-box';\n if (isNullOrEmpty(renderWidth)) {\n const displayWidth = readUsedSize(canvas, 'width');\n if (displayWidth !== undefined) {\n canvas.width = displayWidth;\n }\n }\n if (isNullOrEmpty(renderHeight)) {\n if (canvas.style.height === '') {\n canvas.height = canvas.width / (aspectRatio || 2);\n } else {\n const displayHeight = readUsedSize(canvas, 'height');\n if (displayHeight !== undefined) {\n canvas.height = displayHeight;\n }\n }\n }\n return canvas;\n}\nconst eventListenerOptions = supportsEventListenerOptions ? {\n passive: true\n} : false;\nfunction addListener(node, type, listener) {\n if (node) {\n node.addEventListener(type, listener, eventListenerOptions);\n }\n}\nfunction removeListener(chart, type, listener) {\n if (chart && chart.canvas) {\n chart.canvas.removeEventListener(type, listener, eventListenerOptions);\n }\n}\nfunction fromNativeEvent(event, chart) {\n const type = EVENT_TYPES[event.type] || event.type;\n const { x , y } = getRelativePosition(event, chart);\n return {\n type,\n chart,\n native: event,\n x: x !== undefined ? x : null,\n y: y !== undefined ? y : null\n };\n}\nfunction nodeListContains(nodeList, canvas) {\n for (const node of nodeList){\n if (node === canvas || node.contains(canvas)) {\n return true;\n }\n }\n}\nfunction createAttachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver((entries)=>{\n let trigger = false;\n for (const entry of entries){\n trigger = trigger || nodeListContains(entry.addedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.removedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {\n childList: true,\n subtree: true\n });\n return observer;\n}\nfunction createDetachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver((entries)=>{\n let trigger = false;\n for (const entry of entries){\n trigger = trigger || nodeListContains(entry.removedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.addedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {\n childList: true,\n subtree: true\n });\n return observer;\n}\nconst drpListeningCharts = new Map();\nlet oldDevicePixelRatio = 0;\nfunction onWindowResize() {\n const dpr = window.devicePixelRatio;\n if (dpr === oldDevicePixelRatio) {\n return;\n }\n oldDevicePixelRatio = dpr;\n drpListeningCharts.forEach((resize, chart)=>{\n if (chart.currentDevicePixelRatio !== dpr) {\n resize();\n }\n });\n}\nfunction listenDevicePixelRatioChanges(chart, resize) {\n if (!drpListeningCharts.size) {\n window.addEventListener('resize', onWindowResize);\n }\n drpListeningCharts.set(chart, resize);\n}\nfunction unlistenDevicePixelRatioChanges(chart) {\n drpListeningCharts.delete(chart);\n if (!drpListeningCharts.size) {\n window.removeEventListener('resize', onWindowResize);\n }\n}\nfunction createResizeObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n return;\n }\n const resize = throttled((width, height)=>{\n const w = container.clientWidth;\n listener(width, height);\n if (w < container.clientWidth) {\n listener();\n }\n }, window);\n const observer = new ResizeObserver((entries)=>{\n const entry = entries[0];\n const width = entry.contentRect.width;\n const height = entry.contentRect.height;\n if (width === 0 && height === 0) {\n return;\n }\n resize(width, height);\n });\n observer.observe(container);\n listenDevicePixelRatioChanges(chart, resize);\n return observer;\n}\nfunction releaseObserver(chart, type, observer) {\n if (observer) {\n observer.disconnect();\n }\n if (type === 'resize') {\n unlistenDevicePixelRatioChanges(chart);\n }\n}\nfunction createProxyAndListen(chart, type, listener) {\n const canvas = chart.canvas;\n const proxy = throttled((event)=>{\n if (chart.ctx !== null) {\n listener(fromNativeEvent(event, chart));\n }\n }, chart);\n addListener(canvas, type, proxy);\n return proxy;\n}\n class DomPlatform extends BasePlatform {\n acquireContext(canvas, aspectRatio) {\n const context = canvas && canvas.getContext && canvas.getContext('2d');\n if (context && context.canvas === canvas) {\n initCanvas(canvas, aspectRatio);\n return context;\n }\n return null;\n }\n releaseContext(context) {\n const canvas = context.canvas;\n if (!canvas[EXPANDO_KEY]) {\n return false;\n }\n const initial = canvas[EXPANDO_KEY].initial;\n [\n 'height',\n 'width'\n ].forEach((prop)=>{\n const value = initial[prop];\n if (isNullOrUndef(value)) {\n canvas.removeAttribute(prop);\n } else {\n canvas.setAttribute(prop, value);\n }\n });\n const style = initial.style || {};\n Object.keys(style).forEach((key)=>{\n canvas.style[key] = style[key];\n });\n canvas.width = canvas.width;\n delete canvas[EXPANDO_KEY];\n return true;\n }\n addEventListener(chart, type, listener) {\n this.removeEventListener(chart, type);\n const proxies = chart.$proxies || (chart.$proxies = {});\n const handlers = {\n attach: createAttachObserver,\n detach: createDetachObserver,\n resize: createResizeObserver\n };\n const handler = handlers[type] || createProxyAndListen;\n proxies[type] = handler(chart, type, listener);\n }\n removeEventListener(chart, type) {\n const proxies = chart.$proxies || (chart.$proxies = {});\n const proxy = proxies[type];\n if (!proxy) {\n return;\n }\n const handlers = {\n attach: releaseObserver,\n detach: releaseObserver,\n resize: releaseObserver\n };\n const handler = handlers[type] || removeListener;\n handler(chart, type, proxy);\n proxies[type] = undefined;\n }\n getDevicePixelRatio() {\n return window.devicePixelRatio;\n }\n getMaximumSize(canvas, width, height, aspectRatio) {\n return getMaximumSize(canvas, width, height, aspectRatio);\n }\n isAttached(canvas) {\n const container = canvas && _getParentNode(canvas);\n return !!(container && container.isConnected);\n }\n}\n\nfunction _detectPlatform(canvas) {\n if (!_isDomSupported() || typeof OffscreenCanvas !== 'undefined' && canvas instanceof OffscreenCanvas) {\n return BasicPlatform;\n }\n return DomPlatform;\n}\n\nclass Element {\n static defaults = {};\n static defaultRoutes = undefined;\n x;\n y;\n active = false;\n options;\n $animations;\n tooltipPosition(useFinalPosition) {\n const { x , y } = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n return {\n x,\n y\n };\n }\n hasValue() {\n return isNumber(this.x) && isNumber(this.y);\n }\n getProps(props, final) {\n const anims = this.$animations;\n if (!final || !anims) {\n // let's not create an object, if not needed\n return this;\n }\n const ret = {};\n props.forEach((prop)=>{\n ret[prop] = anims[prop] && anims[prop].active() ? anims[prop]._to : this[prop];\n });\n return ret;\n }\n}\n\nfunction autoSkip(scale, ticks) {\n const tickOpts = scale.options.ticks;\n const determinedMaxTicks = determineMaxTicks(scale);\n const ticksLimit = Math.min(tickOpts.maxTicksLimit || determinedMaxTicks, determinedMaxTicks);\n const majorIndices = tickOpts.major.enabled ? getMajorIndices(ticks) : [];\n const numMajorIndices = majorIndices.length;\n const first = majorIndices[0];\n const last = majorIndices[numMajorIndices - 1];\n const newTicks = [];\n if (numMajorIndices > ticksLimit) {\n skipMajors(ticks, newTicks, majorIndices, numMajorIndices / ticksLimit);\n return newTicks;\n }\n const spacing = calculateSpacing(majorIndices, ticks, ticksLimit);\n if (numMajorIndices > 0) {\n let i, ilen;\n const avgMajorSpacing = numMajorIndices > 1 ? Math.round((last - first) / (numMajorIndices - 1)) : null;\n skip(ticks, newTicks, spacing, isNullOrUndef(avgMajorSpacing) ? 0 : first - avgMajorSpacing, first);\n for(i = 0, ilen = numMajorIndices - 1; i < ilen; i++){\n skip(ticks, newTicks, spacing, majorIndices[i], majorIndices[i + 1]);\n }\n skip(ticks, newTicks, spacing, last, isNullOrUndef(avgMajorSpacing) ? ticks.length : last + avgMajorSpacing);\n return newTicks;\n }\n skip(ticks, newTicks, spacing);\n return newTicks;\n}\nfunction determineMaxTicks(scale) {\n const offset = scale.options.offset;\n const tickLength = scale._tickSize();\n const maxScale = scale._length / tickLength + (offset ? 0 : 1);\n const maxChart = scale._maxLength / tickLength;\n return Math.floor(Math.min(maxScale, maxChart));\n}\n function calculateSpacing(majorIndices, ticks, ticksLimit) {\n const evenMajorSpacing = getEvenSpacing(majorIndices);\n const spacing = ticks.length / ticksLimit;\n if (!evenMajorSpacing) {\n return Math.max(spacing, 1);\n }\n const factors = _factorize(evenMajorSpacing);\n for(let i = 0, ilen = factors.length - 1; i < ilen; i++){\n const factor = factors[i];\n if (factor > spacing) {\n return factor;\n }\n }\n return Math.max(spacing, 1);\n}\n function getMajorIndices(ticks) {\n const result = [];\n let i, ilen;\n for(i = 0, ilen = ticks.length; i < ilen; i++){\n if (ticks[i].major) {\n result.push(i);\n }\n }\n return result;\n}\n function skipMajors(ticks, newTicks, majorIndices, spacing) {\n let count = 0;\n let next = majorIndices[0];\n let i;\n spacing = Math.ceil(spacing);\n for(i = 0; i < ticks.length; i++){\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = majorIndices[count * spacing];\n }\n }\n}\n function skip(ticks, newTicks, spacing, majorStart, majorEnd) {\n const start = valueOrDefault(majorStart, 0);\n const end = Math.min(valueOrDefault(majorEnd, ticks.length), ticks.length);\n let count = 0;\n let length, i, next;\n spacing = Math.ceil(spacing);\n if (majorEnd) {\n length = majorEnd - majorStart;\n spacing = length / Math.floor(length / spacing);\n }\n next = start;\n while(next < 0){\n count++;\n next = Math.round(start + count * spacing);\n }\n for(i = Math.max(start, 0); i < end; i++){\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = Math.round(start + count * spacing);\n }\n }\n}\n function getEvenSpacing(arr) {\n const len = arr.length;\n let i, diff;\n if (len < 2) {\n return false;\n }\n for(diff = arr[0], i = 1; i < len; ++i){\n if (arr[i] - arr[i - 1] !== diff) {\n return false;\n }\n }\n return diff;\n}\n\nconst reverseAlign = (align)=>align === 'left' ? 'right' : align === 'right' ? 'left' : align;\nconst offsetFromEdge = (scale, edge, offset)=>edge === 'top' || edge === 'left' ? scale[edge] + offset : scale[edge] - offset;\nconst getTicksLimit = (ticksLength, maxTicksLimit)=>Math.min(maxTicksLimit || ticksLength, ticksLength);\n function sample(arr, numItems) {\n const result = [];\n const increment = arr.length / numItems;\n const len = arr.length;\n let i = 0;\n for(; i < len; i += increment){\n result.push(arr[Math.floor(i)]);\n }\n return result;\n}\n function getPixelForGridLine(scale, index, offsetGridLines) {\n const length = scale.ticks.length;\n const validIndex = Math.min(index, length - 1);\n const start = scale._startPixel;\n const end = scale._endPixel;\n const epsilon = 1e-6;\n let lineValue = scale.getPixelForTick(validIndex);\n let offset;\n if (offsetGridLines) {\n if (length === 1) {\n offset = Math.max(lineValue - start, end - lineValue);\n } else if (index === 0) {\n offset = (scale.getPixelForTick(1) - lineValue) / 2;\n } else {\n offset = (lineValue - scale.getPixelForTick(validIndex - 1)) / 2;\n }\n lineValue += validIndex < index ? offset : -offset;\n if (lineValue < start - epsilon || lineValue > end + epsilon) {\n return;\n }\n }\n return lineValue;\n}\n function garbageCollect(caches, length) {\n each(caches, (cache)=>{\n const gc = cache.gc;\n const gcLen = gc.length / 2;\n let i;\n if (gcLen > length) {\n for(i = 0; i < gcLen; ++i){\n delete cache.data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n });\n}\n function getTickMarkLength(options) {\n return options.drawTicks ? options.tickLength : 0;\n}\n function getTitleHeight(options, fallback) {\n if (!options.display) {\n return 0;\n }\n const font = toFont(options.font, fallback);\n const padding = toPadding(options.padding);\n const lines = isArray(options.text) ? options.text.length : 1;\n return lines * font.lineHeight + padding.height;\n}\nfunction createScaleContext(parent, scale) {\n return createContext(parent, {\n scale,\n type: 'scale'\n });\n}\nfunction createTickContext(parent, index, tick) {\n return createContext(parent, {\n tick,\n index,\n type: 'tick'\n });\n}\nfunction titleAlign(align, position, reverse) {\n let ret = _toLeftRightCenter(align);\n if (reverse && position !== 'right' || !reverse && position === 'right') {\n ret = reverseAlign(ret);\n }\n return ret;\n}\nfunction titleArgs(scale, offset, position, align) {\n const { top , left , bottom , right , chart } = scale;\n const { chartArea , scales } = chart;\n let rotation = 0;\n let maxWidth, titleX, titleY;\n const height = bottom - top;\n const width = right - left;\n if (scale.isHorizontal()) {\n titleX = _alignStartEnd(align, left, right);\n if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n titleY = scales[positionAxisID].getPixelForValue(value) + height - offset;\n } else if (position === 'center') {\n titleY = (chartArea.bottom + chartArea.top) / 2 + height - offset;\n } else {\n titleY = offsetFromEdge(scale, position, offset);\n }\n maxWidth = right - left;\n } else {\n if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n titleX = scales[positionAxisID].getPixelForValue(value) - width + offset;\n } else if (position === 'center') {\n titleX = (chartArea.left + chartArea.right) / 2 - width + offset;\n } else {\n titleX = offsetFromEdge(scale, position, offset);\n }\n titleY = _alignStartEnd(align, bottom, top);\n rotation = position === 'left' ? -HALF_PI : HALF_PI;\n }\n return {\n titleX,\n titleY,\n maxWidth,\n rotation\n };\n}\nclass Scale extends Element {\n constructor(cfg){\n super();\n this.id = cfg.id;\n this.type = cfg.type;\n this.options = undefined;\n this.ctx = cfg.ctx;\n this.chart = cfg.chart;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.width = undefined;\n this.height = undefined;\n this._margins = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n };\n this.maxWidth = undefined;\n this.maxHeight = undefined;\n this.paddingTop = undefined;\n this.paddingBottom = undefined;\n this.paddingLeft = undefined;\n this.paddingRight = undefined;\n this.axis = undefined;\n this.labelRotation = undefined;\n this.min = undefined;\n this.max = undefined;\n this._range = undefined;\n this.ticks = [];\n this._gridLineItems = null;\n this._labelItems = null;\n this._labelSizes = null;\n this._length = 0;\n this._maxLength = 0;\n this._longestTextCache = {};\n this._startPixel = undefined;\n this._endPixel = undefined;\n this._reversePixels = false;\n this._userMax = undefined;\n this._userMin = undefined;\n this._suggestedMax = undefined;\n this._suggestedMin = undefined;\n this._ticksLength = 0;\n this._borderValue = 0;\n this._cache = {};\n this._dataLimitsCached = false;\n this.$context = undefined;\n }\n init(options) {\n this.options = options.setContext(this.getContext());\n this.axis = options.axis;\n this._userMin = this.parse(options.min);\n this._userMax = this.parse(options.max);\n this._suggestedMin = this.parse(options.suggestedMin);\n this._suggestedMax = this.parse(options.suggestedMax);\n }\n parse(raw, index) {\n return raw;\n }\n getUserBounds() {\n let { _userMin , _userMax , _suggestedMin , _suggestedMax } = this;\n _userMin = finiteOrDefault(_userMin, Number.POSITIVE_INFINITY);\n _userMax = finiteOrDefault(_userMax, Number.NEGATIVE_INFINITY);\n _suggestedMin = finiteOrDefault(_suggestedMin, Number.POSITIVE_INFINITY);\n _suggestedMax = finiteOrDefault(_suggestedMax, Number.NEGATIVE_INFINITY);\n return {\n min: finiteOrDefault(_userMin, _suggestedMin),\n max: finiteOrDefault(_userMax, _suggestedMax),\n minDefined: isNumberFinite(_userMin),\n maxDefined: isNumberFinite(_userMax)\n };\n }\n getMinMax(canStack) {\n let { min , max , minDefined , maxDefined } = this.getUserBounds();\n let range;\n if (minDefined && maxDefined) {\n return {\n min,\n max\n };\n }\n const metas = this.getMatchingVisibleMetas();\n for(let i = 0, ilen = metas.length; i < ilen; ++i){\n range = metas[i].controller.getMinMax(this, canStack);\n if (!minDefined) {\n min = Math.min(min, range.min);\n }\n if (!maxDefined) {\n max = Math.max(max, range.max);\n }\n }\n min = maxDefined && min > max ? max : min;\n max = minDefined && min > max ? min : max;\n return {\n min: finiteOrDefault(min, finiteOrDefault(max, min)),\n max: finiteOrDefault(max, finiteOrDefault(min, max))\n };\n }\n getPadding() {\n return {\n left: this.paddingLeft || 0,\n top: this.paddingTop || 0,\n right: this.paddingRight || 0,\n bottom: this.paddingBottom || 0\n };\n }\n getTicks() {\n return this.ticks;\n }\n getLabels() {\n const data = this.chart.data;\n return this.options.labels || (this.isHorizontal() ? data.xLabels : data.yLabels) || data.labels || [];\n }\n getLabelItems(chartArea = this.chart.chartArea) {\n const items = this._labelItems || (this._labelItems = this._computeLabelItems(chartArea));\n return items;\n }\n beforeLayout() {\n this._cache = {};\n this._dataLimitsCached = false;\n }\n beforeUpdate() {\n callback(this.options.beforeUpdate, [\n this\n ]);\n }\n update(maxWidth, maxHeight, margins) {\n const { beginAtZero , grace , ticks: tickOpts } = this.options;\n const sampleSize = tickOpts.sampleSize;\n this.beforeUpdate();\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins = Object.assign({\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n }, margins);\n this.ticks = null;\n this._labelSizes = null;\n this._gridLineItems = null;\n this._labelItems = null;\n this.beforeSetDimensions();\n this.setDimensions();\n this.afterSetDimensions();\n this._maxLength = this.isHorizontal() ? this.width + margins.left + margins.right : this.height + margins.top + margins.bottom;\n if (!this._dataLimitsCached) {\n this.beforeDataLimits();\n this.determineDataLimits();\n this.afterDataLimits();\n this._range = _addGrace(this, grace, beginAtZero);\n this._dataLimitsCached = true;\n }\n this.beforeBuildTicks();\n this.ticks = this.buildTicks() || [];\n this.afterBuildTicks();\n const samplingEnabled = sampleSize < this.ticks.length;\n this._convertTicksToLabels(samplingEnabled ? sample(this.ticks, sampleSize) : this.ticks);\n this.configure();\n this.beforeCalculateLabelRotation();\n this.calculateLabelRotation();\n this.afterCalculateLabelRotation();\n if (tickOpts.display && (tickOpts.autoSkip || tickOpts.source === 'auto')) {\n this.ticks = autoSkip(this, this.ticks);\n this._labelSizes = null;\n this.afterAutoSkip();\n }\n if (samplingEnabled) {\n this._convertTicksToLabels(this.ticks);\n }\n this.beforeFit();\n this.fit();\n this.afterFit();\n this.afterUpdate();\n }\n configure() {\n let reversePixels = this.options.reverse;\n let startPixel, endPixel;\n if (this.isHorizontal()) {\n startPixel = this.left;\n endPixel = this.right;\n } else {\n startPixel = this.top;\n endPixel = this.bottom;\n reversePixels = !reversePixels;\n }\n this._startPixel = startPixel;\n this._endPixel = endPixel;\n this._reversePixels = reversePixels;\n this._length = endPixel - startPixel;\n this._alignToPixels = this.options.alignToPixels;\n }\n afterUpdate() {\n callback(this.options.afterUpdate, [\n this\n ]);\n }\n beforeSetDimensions() {\n callback(this.options.beforeSetDimensions, [\n this\n ]);\n }\n setDimensions() {\n if (this.isHorizontal()) {\n this.width = this.maxWidth;\n this.left = 0;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n this.top = 0;\n this.bottom = this.height;\n }\n this.paddingLeft = 0;\n this.paddingTop = 0;\n this.paddingRight = 0;\n this.paddingBottom = 0;\n }\n afterSetDimensions() {\n callback(this.options.afterSetDimensions, [\n this\n ]);\n }\n _callHooks(name) {\n this.chart.notifyPlugins(name, this.getContext());\n callback(this.options[name], [\n this\n ]);\n }\n beforeDataLimits() {\n this._callHooks('beforeDataLimits');\n }\n determineDataLimits() {}\n afterDataLimits() {\n this._callHooks('afterDataLimits');\n }\n beforeBuildTicks() {\n this._callHooks('beforeBuildTicks');\n }\n buildTicks() {\n return [];\n }\n afterBuildTicks() {\n this._callHooks('afterBuildTicks');\n }\n beforeTickToLabelConversion() {\n callback(this.options.beforeTickToLabelConversion, [\n this\n ]);\n }\n generateTickLabels(ticks) {\n const tickOpts = this.options.ticks;\n let i, ilen, tick;\n for(i = 0, ilen = ticks.length; i < ilen; i++){\n tick = ticks[i];\n tick.label = callback(tickOpts.callback, [\n tick.value,\n i,\n ticks\n ], this);\n }\n }\n afterTickToLabelConversion() {\n callback(this.options.afterTickToLabelConversion, [\n this\n ]);\n }\n beforeCalculateLabelRotation() {\n callback(this.options.beforeCalculateLabelRotation, [\n this\n ]);\n }\n calculateLabelRotation() {\n const options = this.options;\n const tickOpts = options.ticks;\n const numTicks = getTicksLimit(this.ticks.length, options.ticks.maxTicksLimit);\n const minRotation = tickOpts.minRotation || 0;\n const maxRotation = tickOpts.maxRotation;\n let labelRotation = minRotation;\n let tickWidth, maxHeight, maxLabelDiagonal;\n if (!this._isVisible() || !tickOpts.display || minRotation >= maxRotation || numTicks <= 1 || !this.isHorizontal()) {\n this.labelRotation = minRotation;\n return;\n }\n const labelSizes = this._getLabelSizes();\n const maxLabelWidth = labelSizes.widest.width;\n const maxLabelHeight = labelSizes.highest.height;\n const maxWidth = _limitValue(this.chart.width - maxLabelWidth, 0, this.maxWidth);\n tickWidth = options.offset ? this.maxWidth / numTicks : maxWidth / (numTicks - 1);\n if (maxLabelWidth + 6 > tickWidth) {\n tickWidth = maxWidth / (numTicks - (options.offset ? 0.5 : 1));\n maxHeight = this.maxHeight - getTickMarkLength(options.grid) - tickOpts.padding - getTitleHeight(options.title, this.chart.options.font);\n maxLabelDiagonal = Math.sqrt(maxLabelWidth * maxLabelWidth + maxLabelHeight * maxLabelHeight);\n labelRotation = toDegrees(Math.min(Math.asin(_limitValue((labelSizes.highest.height + 6) / tickWidth, -1, 1)), Math.asin(_limitValue(maxHeight / maxLabelDiagonal, -1, 1)) - Math.asin(_limitValue(maxLabelHeight / maxLabelDiagonal, -1, 1))));\n labelRotation = Math.max(minRotation, Math.min(maxRotation, labelRotation));\n }\n this.labelRotation = labelRotation;\n }\n afterCalculateLabelRotation() {\n callback(this.options.afterCalculateLabelRotation, [\n this\n ]);\n }\n afterAutoSkip() {}\n beforeFit() {\n callback(this.options.beforeFit, [\n this\n ]);\n }\n fit() {\n const minSize = {\n width: 0,\n height: 0\n };\n const { chart , options: { ticks: tickOpts , title: titleOpts , grid: gridOpts } } = this;\n const display = this._isVisible();\n const isHorizontal = this.isHorizontal();\n if (display) {\n const titleHeight = getTitleHeight(titleOpts, chart.options.font);\n if (isHorizontal) {\n minSize.width = this.maxWidth;\n minSize.height = getTickMarkLength(gridOpts) + titleHeight;\n } else {\n minSize.height = this.maxHeight;\n minSize.width = getTickMarkLength(gridOpts) + titleHeight;\n }\n if (tickOpts.display && this.ticks.length) {\n const { first , last , widest , highest } = this._getLabelSizes();\n const tickPadding = tickOpts.padding * 2;\n const angleRadians = toRadians(this.labelRotation);\n const cos = Math.cos(angleRadians);\n const sin = Math.sin(angleRadians);\n if (isHorizontal) {\n const labelHeight = tickOpts.mirror ? 0 : sin * widest.width + cos * highest.height;\n minSize.height = Math.min(this.maxHeight, minSize.height + labelHeight + tickPadding);\n } else {\n const labelWidth = tickOpts.mirror ? 0 : cos * widest.width + sin * highest.height;\n minSize.width = Math.min(this.maxWidth, minSize.width + labelWidth + tickPadding);\n }\n this._calculatePadding(first, last, sin, cos);\n }\n }\n this._handleMargins();\n if (isHorizontal) {\n this.width = this._length = chart.width - this._margins.left - this._margins.right;\n this.height = minSize.height;\n } else {\n this.width = minSize.width;\n this.height = this._length = chart.height - this._margins.top - this._margins.bottom;\n }\n }\n _calculatePadding(first, last, sin, cos) {\n const { ticks: { align , padding } , position } = this.options;\n const isRotated = this.labelRotation !== 0;\n const labelsBelowTicks = position !== 'top' && this.axis === 'x';\n if (this.isHorizontal()) {\n const offsetLeft = this.getPixelForTick(0) - this.left;\n const offsetRight = this.right - this.getPixelForTick(this.ticks.length - 1);\n let paddingLeft = 0;\n let paddingRight = 0;\n if (isRotated) {\n if (labelsBelowTicks) {\n paddingLeft = cos * first.width;\n paddingRight = sin * last.height;\n } else {\n paddingLeft = sin * first.height;\n paddingRight = cos * last.width;\n }\n } else if (align === 'start') {\n paddingRight = last.width;\n } else if (align === 'end') {\n paddingLeft = first.width;\n } else if (align !== 'inner') {\n paddingLeft = first.width / 2;\n paddingRight = last.width / 2;\n }\n this.paddingLeft = Math.max((paddingLeft - offsetLeft + padding) * this.width / (this.width - offsetLeft), 0);\n this.paddingRight = Math.max((paddingRight - offsetRight + padding) * this.width / (this.width - offsetRight), 0);\n } else {\n let paddingTop = last.height / 2;\n let paddingBottom = first.height / 2;\n if (align === 'start') {\n paddingTop = 0;\n paddingBottom = first.height;\n } else if (align === 'end') {\n paddingTop = last.height;\n paddingBottom = 0;\n }\n this.paddingTop = paddingTop + padding;\n this.paddingBottom = paddingBottom + padding;\n }\n }\n _handleMargins() {\n if (this._margins) {\n this._margins.left = Math.max(this.paddingLeft, this._margins.left);\n this._margins.top = Math.max(this.paddingTop, this._margins.top);\n this._margins.right = Math.max(this.paddingRight, this._margins.right);\n this._margins.bottom = Math.max(this.paddingBottom, this._margins.bottom);\n }\n }\n afterFit() {\n callback(this.options.afterFit, [\n this\n ]);\n }\n isHorizontal() {\n const { axis , position } = this.options;\n return position === 'top' || position === 'bottom' || axis === 'x';\n }\n isFullSize() {\n return this.options.fullSize;\n }\n _convertTicksToLabels(ticks) {\n this.beforeTickToLabelConversion();\n this.generateTickLabels(ticks);\n let i, ilen;\n for(i = 0, ilen = ticks.length; i < ilen; i++){\n if (isNullOrUndef(ticks[i].label)) {\n ticks.splice(i, 1);\n ilen--;\n i--;\n }\n }\n this.afterTickToLabelConversion();\n }\n _getLabelSizes() {\n let labelSizes = this._labelSizes;\n if (!labelSizes) {\n const sampleSize = this.options.ticks.sampleSize;\n let ticks = this.ticks;\n if (sampleSize < ticks.length) {\n ticks = sample(ticks, sampleSize);\n }\n this._labelSizes = labelSizes = this._computeLabelSizes(ticks, ticks.length, this.options.ticks.maxTicksLimit);\n }\n return labelSizes;\n }\n _computeLabelSizes(ticks, length, maxTicksLimit) {\n const { ctx , _longestTextCache: caches } = this;\n const widths = [];\n const heights = [];\n const increment = Math.floor(length / getTicksLimit(length, maxTicksLimit));\n let widestLabelSize = 0;\n let highestLabelSize = 0;\n let i, j, jlen, label, tickFont, fontString, cache, lineHeight, width, height, nestedLabel;\n for(i = 0; i < length; i += increment){\n label = ticks[i].label;\n tickFont = this._resolveTickFontOptions(i);\n ctx.font = fontString = tickFont.string;\n cache = caches[fontString] = caches[fontString] || {\n data: {},\n gc: []\n };\n lineHeight = tickFont.lineHeight;\n width = height = 0;\n if (!isNullOrUndef(label) && !isArray(label)) {\n width = _measureText(ctx, cache.data, cache.gc, width, label);\n height = lineHeight;\n } else if (isArray(label)) {\n for(j = 0, jlen = label.length; j < jlen; ++j){\n nestedLabel = label[j];\n if (!isNullOrUndef(nestedLabel) && !isArray(nestedLabel)) {\n width = _measureText(ctx, cache.data, cache.gc, width, nestedLabel);\n height += lineHeight;\n }\n }\n }\n widths.push(width);\n heights.push(height);\n widestLabelSize = Math.max(width, widestLabelSize);\n highestLabelSize = Math.max(height, highestLabelSize);\n }\n garbageCollect(caches, length);\n const widest = widths.indexOf(widestLabelSize);\n const highest = heights.indexOf(highestLabelSize);\n const valueAt = (idx)=>({\n width: widths[idx] || 0,\n height: heights[idx] || 0\n });\n return {\n first: valueAt(0),\n last: valueAt(length - 1),\n widest: valueAt(widest),\n highest: valueAt(highest),\n widths,\n heights\n };\n }\n getLabelForValue(value) {\n return value;\n }\n getPixelForValue(value, index) {\n return NaN;\n }\n getValueForPixel(pixel) {}\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n getPixelForDecimal(decimal) {\n if (this._reversePixels) {\n decimal = 1 - decimal;\n }\n const pixel = this._startPixel + decimal * this._length;\n return _int16Range(this._alignToPixels ? _alignPixel(this.chart, pixel, 0) : pixel);\n }\n getDecimalForPixel(pixel) {\n const decimal = (pixel - this._startPixel) / this._length;\n return this._reversePixels ? 1 - decimal : decimal;\n }\n getBasePixel() {\n return this.getPixelForValue(this.getBaseValue());\n }\n getBaseValue() {\n const { min , max } = this;\n return min < 0 && max < 0 ? max : min > 0 && max > 0 ? min : 0;\n }\n getContext(index) {\n const ticks = this.ticks || [];\n if (index >= 0 && index < ticks.length) {\n const tick = ticks[index];\n return tick.$context || (tick.$context = createTickContext(this.getContext(), index, tick));\n }\n return this.$context || (this.$context = createScaleContext(this.chart.getContext(), this));\n }\n _tickSize() {\n const optionTicks = this.options.ticks;\n const rot = toRadians(this.labelRotation);\n const cos = Math.abs(Math.cos(rot));\n const sin = Math.abs(Math.sin(rot));\n const labelSizes = this._getLabelSizes();\n const padding = optionTicks.autoSkipPadding || 0;\n const w = labelSizes ? labelSizes.widest.width + padding : 0;\n const h = labelSizes ? labelSizes.highest.height + padding : 0;\n return this.isHorizontal() ? h * cos > w * sin ? w / cos : h / sin : h * sin < w * cos ? h / cos : w / sin;\n }\n _isVisible() {\n const display = this.options.display;\n if (display !== 'auto') {\n return !!display;\n }\n return this.getMatchingVisibleMetas().length > 0;\n }\n _computeGridLineItems(chartArea) {\n const axis = this.axis;\n const chart = this.chart;\n const options = this.options;\n const { grid , position , border } = options;\n const offset = grid.offset;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const ticksLength = ticks.length + (offset ? 1 : 0);\n const tl = getTickMarkLength(grid);\n const items = [];\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = borderOpts.display ? borderOpts.width : 0;\n const axisHalfWidth = axisWidth / 2;\n const alignBorderValue = function(pixel) {\n return _alignPixel(chart, pixel, axisWidth);\n };\n let borderValue, i, lineValue, alignedLineValue;\n let tx1, ty1, tx2, ty2, x1, y1, x2, y2;\n if (position === 'top') {\n borderValue = alignBorderValue(this.bottom);\n ty1 = this.bottom - tl;\n ty2 = borderValue - axisHalfWidth;\n y1 = alignBorderValue(chartArea.top) + axisHalfWidth;\n y2 = chartArea.bottom;\n } else if (position === 'bottom') {\n borderValue = alignBorderValue(this.top);\n y1 = chartArea.top;\n y2 = alignBorderValue(chartArea.bottom) - axisHalfWidth;\n ty1 = borderValue + axisHalfWidth;\n ty2 = this.top + tl;\n } else if (position === 'left') {\n borderValue = alignBorderValue(this.right);\n tx1 = this.right - tl;\n tx2 = borderValue - axisHalfWidth;\n x1 = alignBorderValue(chartArea.left) + axisHalfWidth;\n x2 = chartArea.right;\n } else if (position === 'right') {\n borderValue = alignBorderValue(this.left);\n x1 = chartArea.left;\n x2 = alignBorderValue(chartArea.right) - axisHalfWidth;\n tx1 = borderValue + axisHalfWidth;\n tx2 = this.left + tl;\n } else if (axis === 'x') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.top + chartArea.bottom) / 2 + 0.5);\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\n }\n y1 = chartArea.top;\n y2 = chartArea.bottom;\n ty1 = borderValue + axisHalfWidth;\n ty2 = ty1 + tl;\n } else if (axis === 'y') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.left + chartArea.right) / 2);\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\n }\n tx1 = borderValue - axisHalfWidth;\n tx2 = tx1 - tl;\n x1 = chartArea.left;\n x2 = chartArea.right;\n }\n const limit = valueOrDefault(options.ticks.maxTicksLimit, ticksLength);\n const step = Math.max(1, Math.ceil(ticksLength / limit));\n for(i = 0; i < ticksLength; i += step){\n const context = this.getContext(i);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n const lineWidth = optsAtIndex.lineWidth;\n const lineColor = optsAtIndex.color;\n const borderDash = optsAtIndexBorder.dash || [];\n const borderDashOffset = optsAtIndexBorder.dashOffset;\n const tickWidth = optsAtIndex.tickWidth;\n const tickColor = optsAtIndex.tickColor;\n const tickBorderDash = optsAtIndex.tickBorderDash || [];\n const tickBorderDashOffset = optsAtIndex.tickBorderDashOffset;\n lineValue = getPixelForGridLine(this, i, offset);\n if (lineValue === undefined) {\n continue;\n }\n alignedLineValue = _alignPixel(chart, lineValue, lineWidth);\n if (isHorizontal) {\n tx1 = tx2 = x1 = x2 = alignedLineValue;\n } else {\n ty1 = ty2 = y1 = y2 = alignedLineValue;\n }\n items.push({\n tx1,\n ty1,\n tx2,\n ty2,\n x1,\n y1,\n x2,\n y2,\n width: lineWidth,\n color: lineColor,\n borderDash,\n borderDashOffset,\n tickWidth,\n tickColor,\n tickBorderDash,\n tickBorderDashOffset\n });\n }\n this._ticksLength = ticksLength;\n this._borderValue = borderValue;\n return items;\n }\n _computeLabelItems(chartArea) {\n const axis = this.axis;\n const options = this.options;\n const { position , ticks: optionTicks } = options;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const { align , crossAlign , padding , mirror } = optionTicks;\n const tl = getTickMarkLength(options.grid);\n const tickAndPadding = tl + padding;\n const hTickAndPadding = mirror ? -padding : tickAndPadding;\n const rotation = -toRadians(this.labelRotation);\n const items = [];\n let i, ilen, tick, label, x, y, textAlign, pixel, font, lineHeight, lineCount, textOffset;\n let textBaseline = 'middle';\n if (position === 'top') {\n y = this.bottom - hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'bottom') {\n y = this.top + hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'left') {\n const ret = this._getYAxisLabelAlignment(tl);\n textAlign = ret.textAlign;\n x = ret.x;\n } else if (position === 'right') {\n const ret = this._getYAxisLabelAlignment(tl);\n textAlign = ret.textAlign;\n x = ret.x;\n } else if (axis === 'x') {\n if (position === 'center') {\n y = (chartArea.top + chartArea.bottom) / 2 + tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n y = this.chart.scales[positionAxisID].getPixelForValue(value) + tickAndPadding;\n }\n textAlign = this._getXAxisLabelAlignment();\n } else if (axis === 'y') {\n if (position === 'center') {\n x = (chartArea.left + chartArea.right) / 2 - tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n x = this.chart.scales[positionAxisID].getPixelForValue(value);\n }\n textAlign = this._getYAxisLabelAlignment(tl).textAlign;\n }\n if (axis === 'y') {\n if (align === 'start') {\n textBaseline = 'top';\n } else if (align === 'end') {\n textBaseline = 'bottom';\n }\n }\n const labelSizes = this._getLabelSizes();\n for(i = 0, ilen = ticks.length; i < ilen; ++i){\n tick = ticks[i];\n label = tick.label;\n const optsAtIndex = optionTicks.setContext(this.getContext(i));\n pixel = this.getPixelForTick(i) + optionTicks.labelOffset;\n font = this._resolveTickFontOptions(i);\n lineHeight = font.lineHeight;\n lineCount = isArray(label) ? label.length : 1;\n const halfCount = lineCount / 2;\n const color = optsAtIndex.color;\n const strokeColor = optsAtIndex.textStrokeColor;\n const strokeWidth = optsAtIndex.textStrokeWidth;\n let tickTextAlign = textAlign;\n if (isHorizontal) {\n x = pixel;\n if (textAlign === 'inner') {\n if (i === ilen - 1) {\n tickTextAlign = !this.options.reverse ? 'right' : 'left';\n } else if (i === 0) {\n tickTextAlign = !this.options.reverse ? 'left' : 'right';\n } else {\n tickTextAlign = 'center';\n }\n }\n if (position === 'top') {\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = -lineCount * lineHeight + lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = -labelSizes.highest.height / 2 - halfCount * lineHeight + lineHeight;\n } else {\n textOffset = -labelSizes.highest.height + lineHeight / 2;\n }\n } else {\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = labelSizes.highest.height / 2 - halfCount * lineHeight;\n } else {\n textOffset = labelSizes.highest.height - lineCount * lineHeight;\n }\n }\n if (mirror) {\n textOffset *= -1;\n }\n if (rotation !== 0 && !optsAtIndex.showLabelBackdrop) {\n x += lineHeight / 2 * Math.sin(rotation);\n }\n } else {\n y = pixel;\n textOffset = (1 - lineCount) * lineHeight / 2;\n }\n let backdrop;\n if (optsAtIndex.showLabelBackdrop) {\n const labelPadding = toPadding(optsAtIndex.backdropPadding);\n const height = labelSizes.heights[i];\n const width = labelSizes.widths[i];\n let top = textOffset - labelPadding.top;\n let left = 0 - labelPadding.left;\n switch(textBaseline){\n case 'middle':\n top -= height / 2;\n break;\n case 'bottom':\n top -= height;\n break;\n }\n switch(textAlign){\n case 'center':\n left -= width / 2;\n break;\n case 'right':\n left -= width;\n break;\n case 'inner':\n if (i === ilen - 1) {\n left -= width;\n } else if (i > 0) {\n left -= width / 2;\n }\n break;\n }\n backdrop = {\n left,\n top,\n width: width + labelPadding.width,\n height: height + labelPadding.height,\n color: optsAtIndex.backdropColor\n };\n }\n items.push({\n label,\n font,\n textOffset,\n options: {\n rotation,\n color,\n strokeColor,\n strokeWidth,\n textAlign: tickTextAlign,\n textBaseline,\n translation: [\n x,\n y\n ],\n backdrop\n }\n });\n }\n return items;\n }\n _getXAxisLabelAlignment() {\n const { position , ticks } = this.options;\n const rotation = -toRadians(this.labelRotation);\n if (rotation) {\n return position === 'top' ? 'left' : 'right';\n }\n let align = 'center';\n if (ticks.align === 'start') {\n align = 'left';\n } else if (ticks.align === 'end') {\n align = 'right';\n } else if (ticks.align === 'inner') {\n align = 'inner';\n }\n return align;\n }\n _getYAxisLabelAlignment(tl) {\n const { position , ticks: { crossAlign , mirror , padding } } = this.options;\n const labelSizes = this._getLabelSizes();\n const tickAndPadding = tl + padding;\n const widest = labelSizes.widest.width;\n let textAlign;\n let x;\n if (position === 'left') {\n if (mirror) {\n x = this.right + padding;\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += widest / 2;\n } else {\n textAlign = 'right';\n x += widest;\n }\n } else {\n x = this.right - tickAndPadding;\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= widest / 2;\n } else {\n textAlign = 'left';\n x = this.left;\n }\n }\n } else if (position === 'right') {\n if (mirror) {\n x = this.left + padding;\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= widest / 2;\n } else {\n textAlign = 'left';\n x -= widest;\n }\n } else {\n x = this.left + tickAndPadding;\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += widest / 2;\n } else {\n textAlign = 'right';\n x = this.right;\n }\n }\n } else {\n textAlign = 'right';\n }\n return {\n textAlign,\n x\n };\n }\n _computeLabelArea() {\n if (this.options.ticks.mirror) {\n return;\n }\n const chart = this.chart;\n const position = this.options.position;\n if (position === 'left' || position === 'right') {\n return {\n top: 0,\n left: this.left,\n bottom: chart.height,\n right: this.right\n };\n }\n if (position === 'top' || position === 'bottom') {\n return {\n top: this.top,\n left: 0,\n bottom: this.bottom,\n right: chart.width\n };\n }\n }\n drawBackground() {\n const { ctx , options: { backgroundColor } , left , top , width , height } = this;\n if (backgroundColor) {\n ctx.save();\n ctx.fillStyle = backgroundColor;\n ctx.fillRect(left, top, width, height);\n ctx.restore();\n }\n }\n getLineWidthForValue(value) {\n const grid = this.options.grid;\n if (!this._isVisible() || !grid.display) {\n return 0;\n }\n const ticks = this.ticks;\n const index = ticks.findIndex((t)=>t.value === value);\n if (index >= 0) {\n const opts = grid.setContext(this.getContext(index));\n return opts.lineWidth;\n }\n return 0;\n }\n drawGrid(chartArea) {\n const grid = this.options.grid;\n const ctx = this.ctx;\n const items = this._gridLineItems || (this._gridLineItems = this._computeGridLineItems(chartArea));\n let i, ilen;\n const drawLine = (p1, p2, style)=>{\n if (!style.width || !style.color) {\n return;\n }\n ctx.save();\n ctx.lineWidth = style.width;\n ctx.strokeStyle = style.color;\n ctx.setLineDash(style.borderDash || []);\n ctx.lineDashOffset = style.borderDashOffset;\n ctx.beginPath();\n ctx.moveTo(p1.x, p1.y);\n ctx.lineTo(p2.x, p2.y);\n ctx.stroke();\n ctx.restore();\n };\n if (grid.display) {\n for(i = 0, ilen = items.length; i < ilen; ++i){\n const item = items[i];\n if (grid.drawOnChartArea) {\n drawLine({\n x: item.x1,\n y: item.y1\n }, {\n x: item.x2,\n y: item.y2\n }, item);\n }\n if (grid.drawTicks) {\n drawLine({\n x: item.tx1,\n y: item.ty1\n }, {\n x: item.tx2,\n y: item.ty2\n }, {\n color: item.tickColor,\n width: item.tickWidth,\n borderDash: item.tickBorderDash,\n borderDashOffset: item.tickBorderDashOffset\n });\n }\n }\n }\n }\n drawBorder() {\n const { chart , ctx , options: { border , grid } } = this;\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = border.display ? borderOpts.width : 0;\n if (!axisWidth) {\n return;\n }\n const lastLineWidth = grid.setContext(this.getContext(0)).lineWidth;\n const borderValue = this._borderValue;\n let x1, x2, y1, y2;\n if (this.isHorizontal()) {\n x1 = _alignPixel(chart, this.left, axisWidth) - axisWidth / 2;\n x2 = _alignPixel(chart, this.right, lastLineWidth) + lastLineWidth / 2;\n y1 = y2 = borderValue;\n } else {\n y1 = _alignPixel(chart, this.top, axisWidth) - axisWidth / 2;\n y2 = _alignPixel(chart, this.bottom, lastLineWidth) + lastLineWidth / 2;\n x1 = x2 = borderValue;\n }\n ctx.save();\n ctx.lineWidth = borderOpts.width;\n ctx.strokeStyle = borderOpts.color;\n ctx.beginPath();\n ctx.moveTo(x1, y1);\n ctx.lineTo(x2, y2);\n ctx.stroke();\n ctx.restore();\n }\n drawLabels(chartArea) {\n const optionTicks = this.options.ticks;\n if (!optionTicks.display) {\n return;\n }\n const ctx = this.ctx;\n const area = this._computeLabelArea();\n if (area) {\n clipArea(ctx, area);\n }\n const items = this.getLabelItems(chartArea);\n for (const item of items){\n const renderTextOptions = item.options;\n const tickFont = item.font;\n const label = item.label;\n const y = item.textOffset;\n renderText(ctx, label, 0, y, tickFont, renderTextOptions);\n }\n if (area) {\n unclipArea(ctx);\n }\n }\n drawTitle() {\n const { ctx , options: { position , title , reverse } } = this;\n if (!title.display) {\n return;\n }\n const font = toFont(title.font);\n const padding = toPadding(title.padding);\n const align = title.align;\n let offset = font.lineHeight / 2;\n if (position === 'bottom' || position === 'center' || isObject(position)) {\n offset += padding.bottom;\n if (isArray(title.text)) {\n offset += font.lineHeight * (title.text.length - 1);\n }\n } else {\n offset += padding.top;\n }\n const { titleX , titleY , maxWidth , rotation } = titleArgs(this, offset, position, align);\n renderText(ctx, title.text, 0, 0, font, {\n color: title.color,\n maxWidth,\n rotation,\n textAlign: titleAlign(align, position, reverse),\n textBaseline: 'middle',\n translation: [\n titleX,\n titleY\n ]\n });\n }\n draw(chartArea) {\n if (!this._isVisible()) {\n return;\n }\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawBorder();\n this.drawTitle();\n this.drawLabels(chartArea);\n }\n _layers() {\n const opts = this.options;\n const tz = opts.ticks && opts.ticks.z || 0;\n const gz = valueOrDefault(opts.grid && opts.grid.z, -1);\n const bz = valueOrDefault(opts.border && opts.border.z, 0);\n if (!this._isVisible() || this.draw !== Scale.prototype.draw) {\n return [\n {\n z: tz,\n draw: (chartArea)=>{\n this.draw(chartArea);\n }\n }\n ];\n }\n return [\n {\n z: gz,\n draw: (chartArea)=>{\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawTitle();\n }\n },\n {\n z: bz,\n draw: ()=>{\n this.drawBorder();\n }\n },\n {\n z: tz,\n draw: (chartArea)=>{\n this.drawLabels(chartArea);\n }\n }\n ];\n }\n getMatchingVisibleMetas(type) {\n const metas = this.chart.getSortedVisibleDatasetMetas();\n const axisID = this.axis + 'AxisID';\n const result = [];\n let i, ilen;\n for(i = 0, ilen = metas.length; i < ilen; ++i){\n const meta = metas[i];\n if (meta[axisID] === this.id && (!type || meta.type === type)) {\n result.push(meta);\n }\n }\n return result;\n }\n _resolveTickFontOptions(index) {\n const opts = this.options.ticks.setContext(this.getContext(index));\n return toFont(opts.font);\n }\n _maxDigits() {\n const fontSize = this._resolveTickFontOptions(0).lineHeight;\n return (this.isHorizontal() ? this.width : this.height) / fontSize;\n }\n}\n\nclass TypedRegistry {\n constructor(type, scope, override){\n this.type = type;\n this.scope = scope;\n this.override = override;\n this.items = Object.create(null);\n }\n isForType(type) {\n return Object.prototype.isPrototypeOf.call(this.type.prototype, type.prototype);\n }\n register(item) {\n const proto = Object.getPrototypeOf(item);\n let parentScope;\n if (isIChartComponent(proto)) {\n parentScope = this.register(proto);\n }\n const items = this.items;\n const id = item.id;\n const scope = this.scope + '.' + id;\n if (!id) {\n throw new Error('class does not have id: ' + item);\n }\n if (id in items) {\n return scope;\n }\n items[id] = item;\n registerDefaults(item, scope, parentScope);\n if (this.override) {\n defaults.override(item.id, item.overrides);\n }\n return scope;\n }\n get(id) {\n return this.items[id];\n }\n unregister(item) {\n const items = this.items;\n const id = item.id;\n const scope = this.scope;\n if (id in items) {\n delete items[id];\n }\n if (scope && id in defaults[scope]) {\n delete defaults[scope][id];\n if (this.override) {\n delete overrides[id];\n }\n }\n }\n}\nfunction registerDefaults(item, scope, parentScope) {\n const itemDefaults = merge(Object.create(null), [\n parentScope ? defaults.get(parentScope) : {},\n defaults.get(scope),\n item.defaults\n ]);\n defaults.set(scope, itemDefaults);\n if (item.defaultRoutes) {\n routeDefaults(scope, item.defaultRoutes);\n }\n if (item.descriptors) {\n defaults.describe(scope, item.descriptors);\n }\n}\nfunction routeDefaults(scope, routes) {\n Object.keys(routes).forEach((property)=>{\n const propertyParts = property.split('.');\n const sourceName = propertyParts.pop();\n const sourceScope = [\n scope\n ].concat(propertyParts).join('.');\n const parts = routes[property].split('.');\n const targetName = parts.pop();\n const targetScope = parts.join('.');\n defaults.route(sourceScope, sourceName, targetScope, targetName);\n });\n}\nfunction isIChartComponent(proto) {\n return 'id' in proto && 'defaults' in proto;\n}\n\nclass Registry {\n constructor(){\n this.controllers = new TypedRegistry(DatasetController, 'datasets', true);\n this.elements = new TypedRegistry(Element, 'elements');\n this.plugins = new TypedRegistry(Object, 'plugins');\n this.scales = new TypedRegistry(Scale, 'scales');\n this._typedRegistries = [\n this.controllers,\n this.scales,\n this.elements\n ];\n }\n add(...args) {\n this._each('register', args);\n }\n remove(...args) {\n this._each('unregister', args);\n }\n addControllers(...args) {\n this._each('register', args, this.controllers);\n }\n addElements(...args) {\n this._each('register', args, this.elements);\n }\n addPlugins(...args) {\n this._each('register', args, this.plugins);\n }\n addScales(...args) {\n this._each('register', args, this.scales);\n }\n getController(id) {\n return this._get(id, this.controllers, 'controller');\n }\n getElement(id) {\n return this._get(id, this.elements, 'element');\n }\n getPlugin(id) {\n return this._get(id, this.plugins, 'plugin');\n }\n getScale(id) {\n return this._get(id, this.scales, 'scale');\n }\n removeControllers(...args) {\n this._each('unregister', args, this.controllers);\n }\n removeElements(...args) {\n this._each('unregister', args, this.elements);\n }\n removePlugins(...args) {\n this._each('unregister', args, this.plugins);\n }\n removeScales(...args) {\n this._each('unregister', args, this.scales);\n }\n _each(method, args, typedRegistry) {\n [\n ...args\n ].forEach((arg)=>{\n const reg = typedRegistry || this._getRegistryForType(arg);\n if (typedRegistry || reg.isForType(arg) || reg === this.plugins && arg.id) {\n this._exec(method, reg, arg);\n } else {\n each(arg, (item)=>{\n const itemReg = typedRegistry || this._getRegistryForType(item);\n this._exec(method, itemReg, item);\n });\n }\n });\n }\n _exec(method, registry, component) {\n const camelMethod = _capitalize(method);\n callback(component['before' + camelMethod], [], component);\n registry[method](component);\n callback(component['after' + camelMethod], [], component);\n }\n _getRegistryForType(type) {\n for(let i = 0; i < this._typedRegistries.length; i++){\n const reg = this._typedRegistries[i];\n if (reg.isForType(type)) {\n return reg;\n }\n }\n return this.plugins;\n }\n _get(id, typedRegistry, type) {\n const item = typedRegistry.get(id);\n if (item === undefined) {\n throw new Error('\"' + id + '\" is not a registered ' + type + '.');\n }\n return item;\n }\n}\nvar registry = /* #__PURE__ */ new Registry();\n\nclass PluginService {\n constructor(){\n this._init = [];\n }\n notify(chart, hook, args, filter) {\n if (hook === 'beforeInit') {\n this._init = this._createDescriptors(chart, true);\n this._notify(this._init, chart, 'install');\n }\n const descriptors = filter ? this._descriptors(chart).filter(filter) : this._descriptors(chart);\n const result = this._notify(descriptors, chart, hook, args);\n if (hook === 'afterDestroy') {\n this._notify(descriptors, chart, 'stop');\n this._notify(this._init, chart, 'uninstall');\n }\n return result;\n }\n _notify(descriptors, chart, hook, args) {\n args = args || {};\n for (const descriptor of descriptors){\n const plugin = descriptor.plugin;\n const method = plugin[hook];\n const params = [\n chart,\n args,\n descriptor.options\n ];\n if (callback(method, params, plugin) === false && args.cancelable) {\n return false;\n }\n }\n return true;\n }\n invalidate() {\n if (!isNullOrUndef(this._cache)) {\n this._oldCache = this._cache;\n this._cache = undefined;\n }\n }\n _descriptors(chart) {\n if (this._cache) {\n return this._cache;\n }\n const descriptors = this._cache = this._createDescriptors(chart);\n this._notifyStateChanges(chart);\n return descriptors;\n }\n _createDescriptors(chart, all) {\n const config = chart && chart.config;\n const options = valueOrDefault(config.options && config.options.plugins, {});\n const plugins = allPlugins(config);\n return options === false && !all ? [] : createDescriptors(chart, plugins, options, all);\n }\n _notifyStateChanges(chart) {\n const previousDescriptors = this._oldCache || [];\n const descriptors = this._cache;\n const diff = (a, b)=>a.filter((x)=>!b.some((y)=>x.plugin.id === y.plugin.id));\n this._notify(diff(previousDescriptors, descriptors), chart, 'stop');\n this._notify(diff(descriptors, previousDescriptors), chart, 'start');\n }\n}\n function allPlugins(config) {\n const localIds = {};\n const plugins = [];\n const keys = Object.keys(registry.plugins.items);\n for(let i = 0; i < keys.length; i++){\n plugins.push(registry.getPlugin(keys[i]));\n }\n const local = config.plugins || [];\n for(let i = 0; i < local.length; i++){\n const plugin = local[i];\n if (plugins.indexOf(plugin) === -1) {\n plugins.push(plugin);\n localIds[plugin.id] = true;\n }\n }\n return {\n plugins,\n localIds\n };\n}\nfunction getOpts(options, all) {\n if (!all && options === false) {\n return null;\n }\n if (options === true) {\n return {};\n }\n return options;\n}\nfunction createDescriptors(chart, { plugins , localIds }, options, all) {\n const result = [];\n const context = chart.getContext();\n for (const plugin of plugins){\n const id = plugin.id;\n const opts = getOpts(options[id], all);\n if (opts === null) {\n continue;\n }\n result.push({\n plugin,\n options: pluginOpts(chart.config, {\n plugin,\n local: localIds[id]\n }, opts, context)\n });\n }\n return result;\n}\nfunction pluginOpts(config, { plugin , local }, opts, context) {\n const keys = config.pluginScopeKeys(plugin);\n const scopes = config.getOptionScopes(opts, keys);\n if (local && plugin.defaults) {\n scopes.push(plugin.defaults);\n }\n return config.createResolver(scopes, context, [\n ''\n ], {\n scriptable: false,\n indexable: false,\n allKeys: true\n });\n}\n\nfunction getIndexAxis(type, options) {\n const datasetDefaults = defaults.datasets[type] || {};\n const datasetOptions = (options.datasets || {})[type] || {};\n return datasetOptions.indexAxis || options.indexAxis || datasetDefaults.indexAxis || 'x';\n}\nfunction getAxisFromDefaultScaleID(id, indexAxis) {\n let axis = id;\n if (id === '_index_') {\n axis = indexAxis;\n } else if (id === '_value_') {\n axis = indexAxis === 'x' ? 'y' : 'x';\n }\n return axis;\n}\nfunction getDefaultScaleIDFromAxis(axis, indexAxis) {\n return axis === indexAxis ? '_index_' : '_value_';\n}\nfunction idMatchesAxis(id) {\n if (id === 'x' || id === 'y' || id === 'r') {\n return id;\n }\n}\nfunction axisFromPosition(position) {\n if (position === 'top' || position === 'bottom') {\n return 'x';\n }\n if (position === 'left' || position === 'right') {\n return 'y';\n }\n}\nfunction determineAxis(id, ...scaleOptions) {\n if (idMatchesAxis(id)) {\n return id;\n }\n for (const opts of scaleOptions){\n const axis = opts.axis || axisFromPosition(opts.position) || id.length > 1 && idMatchesAxis(id[0].toLowerCase());\n if (axis) {\n return axis;\n }\n }\n throw new Error(`Cannot determine type of '${id}' axis. Please provide 'axis' or 'position' option.`);\n}\nfunction getAxisFromDataset(id, axis, dataset) {\n if (dataset[axis + 'AxisID'] === id) {\n return {\n axis\n };\n }\n}\nfunction retrieveAxisFromDatasets(id, config) {\n if (config.data && config.data.datasets) {\n const boundDs = config.data.datasets.filter((d)=>d.xAxisID === id || d.yAxisID === id);\n if (boundDs.length) {\n return getAxisFromDataset(id, 'x', boundDs[0]) || getAxisFromDataset(id, 'y', boundDs[0]);\n }\n }\n return {};\n}\nfunction mergeScaleConfig(config, options) {\n const chartDefaults = overrides[config.type] || {\n scales: {}\n };\n const configScales = options.scales || {};\n const chartIndexAxis = getIndexAxis(config.type, options);\n const scales = Object.create(null);\n Object.keys(configScales).forEach((id)=>{\n const scaleConf = configScales[id];\n if (!isObject(scaleConf)) {\n return console.error(`Invalid scale configuration for scale: ${id}`);\n }\n if (scaleConf._proxy) {\n return console.warn(`Ignoring resolver passed as options for scale: ${id}`);\n }\n const axis = determineAxis(id, scaleConf, retrieveAxisFromDatasets(id, config), defaults.scales[scaleConf.type]);\n const defaultId = getDefaultScaleIDFromAxis(axis, chartIndexAxis);\n const defaultScaleOptions = chartDefaults.scales || {};\n scales[id] = mergeIf(Object.create(null), [\n {\n axis\n },\n scaleConf,\n defaultScaleOptions[axis],\n defaultScaleOptions[defaultId]\n ]);\n });\n config.data.datasets.forEach((dataset)=>{\n const type = dataset.type || config.type;\n const indexAxis = dataset.indexAxis || getIndexAxis(type, options);\n const datasetDefaults = overrides[type] || {};\n const defaultScaleOptions = datasetDefaults.scales || {};\n Object.keys(defaultScaleOptions).forEach((defaultID)=>{\n const axis = getAxisFromDefaultScaleID(defaultID, indexAxis);\n const id = dataset[axis + 'AxisID'] || axis;\n scales[id] = scales[id] || Object.create(null);\n mergeIf(scales[id], [\n {\n axis\n },\n configScales[id],\n defaultScaleOptions[defaultID]\n ]);\n });\n });\n Object.keys(scales).forEach((key)=>{\n const scale = scales[key];\n mergeIf(scale, [\n defaults.scales[scale.type],\n defaults.scale\n ]);\n });\n return scales;\n}\nfunction initOptions(config) {\n const options = config.options || (config.options = {});\n options.plugins = valueOrDefault(options.plugins, {});\n options.scales = mergeScaleConfig(config, options);\n}\nfunction initData(data) {\n data = data || {};\n data.datasets = data.datasets || [];\n data.labels = data.labels || [];\n return data;\n}\nfunction initConfig(config) {\n config = config || {};\n config.data = initData(config.data);\n initOptions(config);\n return config;\n}\nconst keyCache = new Map();\nconst keysCached = new Set();\nfunction cachedKeys(cacheKey, generate) {\n let keys = keyCache.get(cacheKey);\n if (!keys) {\n keys = generate();\n keyCache.set(cacheKey, keys);\n keysCached.add(keys);\n }\n return keys;\n}\nconst addIfFound = (set, obj, key)=>{\n const opts = resolveObjectKey(obj, key);\n if (opts !== undefined) {\n set.add(opts);\n }\n};\nclass Config {\n constructor(config){\n this._config = initConfig(config);\n this._scopeCache = new Map();\n this._resolverCache = new Map();\n }\n get platform() {\n return this._config.platform;\n }\n get type() {\n return this._config.type;\n }\n set type(type) {\n this._config.type = type;\n }\n get data() {\n return this._config.data;\n }\n set data(data) {\n this._config.data = initData(data);\n }\n get options() {\n return this._config.options;\n }\n set options(options) {\n this._config.options = options;\n }\n get plugins() {\n return this._config.plugins;\n }\n update() {\n const config = this._config;\n this.clearCache();\n initOptions(config);\n }\n clearCache() {\n this._scopeCache.clear();\n this._resolverCache.clear();\n }\n datasetScopeKeys(datasetType) {\n return cachedKeys(datasetType, ()=>[\n [\n `datasets.${datasetType}`,\n ''\n ]\n ]);\n }\n datasetAnimationScopeKeys(datasetType, transition) {\n return cachedKeys(`${datasetType}.transition.${transition}`, ()=>[\n [\n `datasets.${datasetType}.transitions.${transition}`,\n `transitions.${transition}`\n ],\n [\n `datasets.${datasetType}`,\n ''\n ]\n ]);\n }\n datasetElementScopeKeys(datasetType, elementType) {\n return cachedKeys(`${datasetType}-${elementType}`, ()=>[\n [\n `datasets.${datasetType}.elements.${elementType}`,\n `datasets.${datasetType}`,\n `elements.${elementType}`,\n ''\n ]\n ]);\n }\n pluginScopeKeys(plugin) {\n const id = plugin.id;\n const type = this.type;\n return cachedKeys(`${type}-plugin-${id}`, ()=>[\n [\n `plugins.${id}`,\n ...plugin.additionalOptionScopes || []\n ]\n ]);\n }\n _cachedScopes(mainScope, resetCache) {\n const _scopeCache = this._scopeCache;\n let cache = _scopeCache.get(mainScope);\n if (!cache || resetCache) {\n cache = new Map();\n _scopeCache.set(mainScope, cache);\n }\n return cache;\n }\n getOptionScopes(mainScope, keyLists, resetCache) {\n const { options , type } = this;\n const cache = this._cachedScopes(mainScope, resetCache);\n const cached = cache.get(keyLists);\n if (cached) {\n return cached;\n }\n const scopes = new Set();\n keyLists.forEach((keys)=>{\n if (mainScope) {\n scopes.add(mainScope);\n keys.forEach((key)=>addIfFound(scopes, mainScope, key));\n }\n keys.forEach((key)=>addIfFound(scopes, options, key));\n keys.forEach((key)=>addIfFound(scopes, overrides[type] || {}, key));\n keys.forEach((key)=>addIfFound(scopes, defaults, key));\n keys.forEach((key)=>addIfFound(scopes, descriptors, key));\n });\n const array = Array.from(scopes);\n if (array.length === 0) {\n array.push(Object.create(null));\n }\n if (keysCached.has(keyLists)) {\n cache.set(keyLists, array);\n }\n return array;\n }\n chartOptionScopes() {\n const { options , type } = this;\n return [\n options,\n overrides[type] || {},\n defaults.datasets[type] || {},\n {\n type\n },\n defaults,\n descriptors\n ];\n }\n resolveNamedOptions(scopes, names, context, prefixes = [\n ''\n ]) {\n const result = {\n $shared: true\n };\n const { resolver , subPrefixes } = getResolver(this._resolverCache, scopes, prefixes);\n let options = resolver;\n if (needContext(resolver, names)) {\n result.$shared = false;\n context = isFunction(context) ? context() : context;\n const subResolver = this.createResolver(scopes, context, subPrefixes);\n options = _attachContext(resolver, context, subResolver);\n }\n for (const prop of names){\n result[prop] = options[prop];\n }\n return result;\n }\n createResolver(scopes, context, prefixes = [\n ''\n ], descriptorDefaults) {\n const { resolver } = getResolver(this._resolverCache, scopes, prefixes);\n return isObject(context) ? _attachContext(resolver, context, undefined, descriptorDefaults) : resolver;\n }\n}\nfunction getResolver(resolverCache, scopes, prefixes) {\n let cache = resolverCache.get(scopes);\n if (!cache) {\n cache = new Map();\n resolverCache.set(scopes, cache);\n }\n const cacheKey = prefixes.join();\n let cached = cache.get(cacheKey);\n if (!cached) {\n const resolver = _createResolver(scopes, prefixes);\n cached = {\n resolver,\n subPrefixes: prefixes.filter((p)=>!p.toLowerCase().includes('hover'))\n };\n cache.set(cacheKey, cached);\n }\n return cached;\n}\nconst hasFunction = (value)=>isObject(value) && Object.getOwnPropertyNames(value).some((key)=>isFunction(value[key]));\nfunction needContext(proxy, names) {\n const { isScriptable , isIndexable } = _descriptors(proxy);\n for (const prop of names){\n const scriptable = isScriptable(prop);\n const indexable = isIndexable(prop);\n const value = (indexable || scriptable) && proxy[prop];\n if (scriptable && (isFunction(value) || hasFunction(value)) || indexable && isArray(value)) {\n return true;\n }\n }\n return false;\n}\n\nvar version = \"4.4.6\";\n\nconst KNOWN_POSITIONS = [\n 'top',\n 'bottom',\n 'left',\n 'right',\n 'chartArea'\n];\nfunction positionIsHorizontal(position, axis) {\n return position === 'top' || position === 'bottom' || KNOWN_POSITIONS.indexOf(position) === -1 && axis === 'x';\n}\nfunction compare2Level(l1, l2) {\n return function(a, b) {\n return a[l1] === b[l1] ? a[l2] - b[l2] : a[l1] - b[l1];\n };\n}\nfunction onAnimationsComplete(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n chart.notifyPlugins('afterRender');\n callback(animationOptions && animationOptions.onComplete, [\n context\n ], chart);\n}\nfunction onAnimationProgress(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n callback(animationOptions && animationOptions.onProgress, [\n context\n ], chart);\n}\n function getCanvas(item) {\n if (_isDomSupported() && typeof item === 'string') {\n item = document.getElementById(item);\n } else if (item && item.length) {\n item = item[0];\n }\n if (item && item.canvas) {\n item = item.canvas;\n }\n return item;\n}\nconst instances = {};\nconst getChart = (key)=>{\n const canvas = getCanvas(key);\n return Object.values(instances).filter((c)=>c.canvas === canvas).pop();\n};\nfunction moveNumericKeys(obj, start, move) {\n const keys = Object.keys(obj);\n for (const key of keys){\n const intKey = +key;\n if (intKey >= start) {\n const value = obj[key];\n delete obj[key];\n if (move > 0 || intKey > start) {\n obj[intKey + move] = value;\n }\n }\n }\n}\n function determineLastEvent(e, lastEvent, inChartArea, isClick) {\n if (!inChartArea || e.type === 'mouseout') {\n return null;\n }\n if (isClick) {\n return lastEvent;\n }\n return e;\n}\nfunction getSizeForArea(scale, chartArea, field) {\n return scale.options.clip ? scale[field] : chartArea[field];\n}\nfunction getDatasetArea(meta, chartArea) {\n const { xScale , yScale } = meta;\n if (xScale && yScale) {\n return {\n left: getSizeForArea(xScale, chartArea, 'left'),\n right: getSizeForArea(xScale, chartArea, 'right'),\n top: getSizeForArea(yScale, chartArea, 'top'),\n bottom: getSizeForArea(yScale, chartArea, 'bottom')\n };\n }\n return chartArea;\n}\nclass Chart {\n static defaults = defaults;\n static instances = instances;\n static overrides = overrides;\n static registry = registry;\n static version = version;\n static getChart = getChart;\n static register(...items) {\n registry.add(...items);\n invalidatePlugins();\n }\n static unregister(...items) {\n registry.remove(...items);\n invalidatePlugins();\n }\n constructor(item, userConfig){\n const config = this.config = new Config(userConfig);\n const initialCanvas = getCanvas(item);\n const existingChart = getChart(initialCanvas);\n if (existingChart) {\n throw new Error('Canvas is already in use. Chart with ID \\'' + existingChart.id + '\\'' + ' must be destroyed before the canvas with ID \\'' + existingChart.canvas.id + '\\' can be reused.');\n }\n const options = config.createResolver(config.chartOptionScopes(), this.getContext());\n this.platform = new (config.platform || _detectPlatform(initialCanvas))();\n this.platform.updateConfig(config);\n const context = this.platform.acquireContext(initialCanvas, options.aspectRatio);\n const canvas = context && context.canvas;\n const height = canvas && canvas.height;\n const width = canvas && canvas.width;\n this.id = uid();\n this.ctx = context;\n this.canvas = canvas;\n this.width = width;\n this.height = height;\n this._options = options;\n this._aspectRatio = this.aspectRatio;\n this._layers = [];\n this._metasets = [];\n this._stacks = undefined;\n this.boxes = [];\n this.currentDevicePixelRatio = undefined;\n this.chartArea = undefined;\n this._active = [];\n this._lastEvent = undefined;\n this._listeners = {};\n this._responsiveListeners = undefined;\n this._sortedMetasets = [];\n this.scales = {};\n this._plugins = new PluginService();\n this.$proxies = {};\n this._hiddenIndices = {};\n this.attached = false;\n this._animationsDisabled = undefined;\n this.$context = undefined;\n this._doResize = debounce((mode)=>this.update(mode), options.resizeDelay || 0);\n this._dataChanges = [];\n instances[this.id] = this;\n if (!context || !canvas) {\n console.error(\"Failed to create chart: can't acquire context from the given item\");\n return;\n }\n animator.listen(this, 'complete', onAnimationsComplete);\n animator.listen(this, 'progress', onAnimationProgress);\n this._initialize();\n if (this.attached) {\n this.update();\n }\n }\n get aspectRatio() {\n const { options: { aspectRatio , maintainAspectRatio } , width , height , _aspectRatio } = this;\n if (!isNullOrUndef(aspectRatio)) {\n return aspectRatio;\n }\n if (maintainAspectRatio && _aspectRatio) {\n return _aspectRatio;\n }\n return height ? width / height : null;\n }\n get data() {\n return this.config.data;\n }\n set data(data) {\n this.config.data = data;\n }\n get options() {\n return this._options;\n }\n set options(options) {\n this.config.options = options;\n }\n get registry() {\n return registry;\n }\n _initialize() {\n this.notifyPlugins('beforeInit');\n if (this.options.responsive) {\n this.resize();\n } else {\n retinaScale(this, this.options.devicePixelRatio);\n }\n this.bindEvents();\n this.notifyPlugins('afterInit');\n return this;\n }\n clear() {\n clearCanvas(this.canvas, this.ctx);\n return this;\n }\n stop() {\n animator.stop(this);\n return this;\n }\n resize(width, height) {\n if (!animator.running(this)) {\n this._resize(width, height);\n } else {\n this._resizeBeforeDraw = {\n width,\n height\n };\n }\n }\n _resize(width, height) {\n const options = this.options;\n const canvas = this.canvas;\n const aspectRatio = options.maintainAspectRatio && this.aspectRatio;\n const newSize = this.platform.getMaximumSize(canvas, width, height, aspectRatio);\n const newRatio = options.devicePixelRatio || this.platform.getDevicePixelRatio();\n const mode = this.width ? 'resize' : 'attach';\n this.width = newSize.width;\n this.height = newSize.height;\n this._aspectRatio = this.aspectRatio;\n if (!retinaScale(this, newRatio, true)) {\n return;\n }\n this.notifyPlugins('resize', {\n size: newSize\n });\n callback(options.onResize, [\n this,\n newSize\n ], this);\n if (this.attached) {\n if (this._doResize(mode)) {\n this.render();\n }\n }\n }\n ensureScalesHaveIDs() {\n const options = this.options;\n const scalesOptions = options.scales || {};\n each(scalesOptions, (axisOptions, axisID)=>{\n axisOptions.id = axisID;\n });\n }\n buildOrUpdateScales() {\n const options = this.options;\n const scaleOpts = options.scales;\n const scales = this.scales;\n const updated = Object.keys(scales).reduce((obj, id)=>{\n obj[id] = false;\n return obj;\n }, {});\n let items = [];\n if (scaleOpts) {\n items = items.concat(Object.keys(scaleOpts).map((id)=>{\n const scaleOptions = scaleOpts[id];\n const axis = determineAxis(id, scaleOptions);\n const isRadial = axis === 'r';\n const isHorizontal = axis === 'x';\n return {\n options: scaleOptions,\n dposition: isRadial ? 'chartArea' : isHorizontal ? 'bottom' : 'left',\n dtype: isRadial ? 'radialLinear' : isHorizontal ? 'category' : 'linear'\n };\n }));\n }\n each(items, (item)=>{\n const scaleOptions = item.options;\n const id = scaleOptions.id;\n const axis = determineAxis(id, scaleOptions);\n const scaleType = valueOrDefault(scaleOptions.type, item.dtype);\n if (scaleOptions.position === undefined || positionIsHorizontal(scaleOptions.position, axis) !== positionIsHorizontal(item.dposition)) {\n scaleOptions.position = item.dposition;\n }\n updated[id] = true;\n let scale = null;\n if (id in scales && scales[id].type === scaleType) {\n scale = scales[id];\n } else {\n const scaleClass = registry.getScale(scaleType);\n scale = new scaleClass({\n id,\n type: scaleType,\n ctx: this.ctx,\n chart: this\n });\n scales[scale.id] = scale;\n }\n scale.init(scaleOptions, options);\n });\n each(updated, (hasUpdated, id)=>{\n if (!hasUpdated) {\n delete scales[id];\n }\n });\n each(scales, (scale)=>{\n layouts.configure(this, scale, scale.options);\n layouts.addBox(this, scale);\n });\n }\n _updateMetasets() {\n const metasets = this._metasets;\n const numData = this.data.datasets.length;\n const numMeta = metasets.length;\n metasets.sort((a, b)=>a.index - b.index);\n if (numMeta > numData) {\n for(let i = numData; i < numMeta; ++i){\n this._destroyDatasetMeta(i);\n }\n metasets.splice(numData, numMeta - numData);\n }\n this._sortedMetasets = metasets.slice(0).sort(compare2Level('order', 'index'));\n }\n _removeUnreferencedMetasets() {\n const { _metasets: metasets , data: { datasets } } = this;\n if (metasets.length > datasets.length) {\n delete this._stacks;\n }\n metasets.forEach((meta, index)=>{\n if (datasets.filter((x)=>x === meta._dataset).length === 0) {\n this._destroyDatasetMeta(index);\n }\n });\n }\n buildOrUpdateControllers() {\n const newControllers = [];\n const datasets = this.data.datasets;\n let i, ilen;\n this._removeUnreferencedMetasets();\n for(i = 0, ilen = datasets.length; i < ilen; i++){\n const dataset = datasets[i];\n let meta = this.getDatasetMeta(i);\n const type = dataset.type || this.config.type;\n if (meta.type && meta.type !== type) {\n this._destroyDatasetMeta(i);\n meta = this.getDatasetMeta(i);\n }\n meta.type = type;\n meta.indexAxis = dataset.indexAxis || getIndexAxis(type, this.options);\n meta.order = dataset.order || 0;\n meta.index = i;\n meta.label = '' + dataset.label;\n meta.visible = this.isDatasetVisible(i);\n if (meta.controller) {\n meta.controller.updateIndex(i);\n meta.controller.linkScales();\n } else {\n const ControllerClass = registry.getController(type);\n const { datasetElementType , dataElementType } = defaults.datasets[type];\n Object.assign(ControllerClass, {\n dataElementType: registry.getElement(dataElementType),\n datasetElementType: datasetElementType && registry.getElement(datasetElementType)\n });\n meta.controller = new ControllerClass(this, i);\n newControllers.push(meta.controller);\n }\n }\n this._updateMetasets();\n return newControllers;\n }\n _resetElements() {\n each(this.data.datasets, (dataset, datasetIndex)=>{\n this.getDatasetMeta(datasetIndex).controller.reset();\n }, this);\n }\n reset() {\n this._resetElements();\n this.notifyPlugins('reset');\n }\n update(mode) {\n const config = this.config;\n config.update();\n const options = this._options = config.createResolver(config.chartOptionScopes(), this.getContext());\n const animsDisabled = this._animationsDisabled = !options.animation;\n this._updateScales();\n this._checkEventBindings();\n this._updateHiddenIndices();\n this._plugins.invalidate();\n if (this.notifyPlugins('beforeUpdate', {\n mode,\n cancelable: true\n }) === false) {\n return;\n }\n const newControllers = this.buildOrUpdateControllers();\n this.notifyPlugins('beforeElementsUpdate');\n let minPadding = 0;\n for(let i = 0, ilen = this.data.datasets.length; i < ilen; i++){\n const { controller } = this.getDatasetMeta(i);\n const reset = !animsDisabled && newControllers.indexOf(controller) === -1;\n controller.buildOrUpdateElements(reset);\n minPadding = Math.max(+controller.getMaxOverflow(), minPadding);\n }\n minPadding = this._minPadding = options.layout.autoPadding ? minPadding : 0;\n this._updateLayout(minPadding);\n if (!animsDisabled) {\n each(newControllers, (controller)=>{\n controller.reset();\n });\n }\n this._updateDatasets(mode);\n this.notifyPlugins('afterUpdate', {\n mode\n });\n this._layers.sort(compare2Level('z', '_idx'));\n const { _active , _lastEvent } = this;\n if (_lastEvent) {\n this._eventHandler(_lastEvent, true);\n } else if (_active.length) {\n this._updateHoverStyles(_active, _active, true);\n }\n this.render();\n }\n _updateScales() {\n each(this.scales, (scale)=>{\n layouts.removeBox(this, scale);\n });\n this.ensureScalesHaveIDs();\n this.buildOrUpdateScales();\n }\n _checkEventBindings() {\n const options = this.options;\n const existingEvents = new Set(Object.keys(this._listeners));\n const newEvents = new Set(options.events);\n if (!setsEqual(existingEvents, newEvents) || !!this._responsiveListeners !== options.responsive) {\n this.unbindEvents();\n this.bindEvents();\n }\n }\n _updateHiddenIndices() {\n const { _hiddenIndices } = this;\n const changes = this._getUniformDataChanges() || [];\n for (const { method , start , count } of changes){\n const move = method === '_removeElements' ? -count : count;\n moveNumericKeys(_hiddenIndices, start, move);\n }\n }\n _getUniformDataChanges() {\n const _dataChanges = this._dataChanges;\n if (!_dataChanges || !_dataChanges.length) {\n return;\n }\n this._dataChanges = [];\n const datasetCount = this.data.datasets.length;\n const makeSet = (idx)=>new Set(_dataChanges.filter((c)=>c[0] === idx).map((c, i)=>i + ',' + c.splice(1).join(',')));\n const changeSet = makeSet(0);\n for(let i = 1; i < datasetCount; i++){\n if (!setsEqual(changeSet, makeSet(i))) {\n return;\n }\n }\n return Array.from(changeSet).map((c)=>c.split(',')).map((a)=>({\n method: a[1],\n start: +a[2],\n count: +a[3]\n }));\n }\n _updateLayout(minPadding) {\n if (this.notifyPlugins('beforeLayout', {\n cancelable: true\n }) === false) {\n return;\n }\n layouts.update(this, this.width, this.height, minPadding);\n const area = this.chartArea;\n const noArea = area.width <= 0 || area.height <= 0;\n this._layers = [];\n each(this.boxes, (box)=>{\n if (noArea && box.position === 'chartArea') {\n return;\n }\n if (box.configure) {\n box.configure();\n }\n this._layers.push(...box._layers());\n }, this);\n this._layers.forEach((item, index)=>{\n item._idx = index;\n });\n this.notifyPlugins('afterLayout');\n }\n _updateDatasets(mode) {\n if (this.notifyPlugins('beforeDatasetsUpdate', {\n mode,\n cancelable: true\n }) === false) {\n return;\n }\n for(let i = 0, ilen = this.data.datasets.length; i < ilen; ++i){\n this.getDatasetMeta(i).controller.configure();\n }\n for(let i = 0, ilen = this.data.datasets.length; i < ilen; ++i){\n this._updateDataset(i, isFunction(mode) ? mode({\n datasetIndex: i\n }) : mode);\n }\n this.notifyPlugins('afterDatasetsUpdate', {\n mode\n });\n }\n _updateDataset(index, mode) {\n const meta = this.getDatasetMeta(index);\n const args = {\n meta,\n index,\n mode,\n cancelable: true\n };\n if (this.notifyPlugins('beforeDatasetUpdate', args) === false) {\n return;\n }\n meta.controller._update(mode);\n args.cancelable = false;\n this.notifyPlugins('afterDatasetUpdate', args);\n }\n render() {\n if (this.notifyPlugins('beforeRender', {\n cancelable: true\n }) === false) {\n return;\n }\n if (animator.has(this)) {\n if (this.attached && !animator.running(this)) {\n animator.start(this);\n }\n } else {\n this.draw();\n onAnimationsComplete({\n chart: this\n });\n }\n }\n draw() {\n let i;\n if (this._resizeBeforeDraw) {\n const { width , height } = this._resizeBeforeDraw;\n this._resizeBeforeDraw = null;\n this._resize(width, height);\n }\n this.clear();\n if (this.width <= 0 || this.height <= 0) {\n return;\n }\n if (this.notifyPlugins('beforeDraw', {\n cancelable: true\n }) === false) {\n return;\n }\n const layers = this._layers;\n for(i = 0; i < layers.length && layers[i].z <= 0; ++i){\n layers[i].draw(this.chartArea);\n }\n this._drawDatasets();\n for(; i < layers.length; ++i){\n layers[i].draw(this.chartArea);\n }\n this.notifyPlugins('afterDraw');\n }\n _getSortedDatasetMetas(filterVisible) {\n const metasets = this._sortedMetasets;\n const result = [];\n let i, ilen;\n for(i = 0, ilen = metasets.length; i < ilen; ++i){\n const meta = metasets[i];\n if (!filterVisible || meta.visible) {\n result.push(meta);\n }\n }\n return result;\n }\n getSortedVisibleDatasetMetas() {\n return this._getSortedDatasetMetas(true);\n }\n _drawDatasets() {\n if (this.notifyPlugins('beforeDatasetsDraw', {\n cancelable: true\n }) === false) {\n return;\n }\n const metasets = this.getSortedVisibleDatasetMetas();\n for(let i = metasets.length - 1; i >= 0; --i){\n this._drawDataset(metasets[i]);\n }\n this.notifyPlugins('afterDatasetsDraw');\n }\n _drawDataset(meta) {\n const ctx = this.ctx;\n const clip = meta._clip;\n const useClip = !clip.disabled;\n const area = getDatasetArea(meta, this.chartArea);\n const args = {\n meta,\n index: meta.index,\n cancelable: true\n };\n if (this.notifyPlugins('beforeDatasetDraw', args) === false) {\n return;\n }\n if (useClip) {\n clipArea(ctx, {\n left: clip.left === false ? 0 : area.left - clip.left,\n right: clip.right === false ? this.width : area.right + clip.right,\n top: clip.top === false ? 0 : area.top - clip.top,\n bottom: clip.bottom === false ? this.height : area.bottom + clip.bottom\n });\n }\n meta.controller.draw();\n if (useClip) {\n unclipArea(ctx);\n }\n args.cancelable = false;\n this.notifyPlugins('afterDatasetDraw', args);\n }\n isPointInArea(point) {\n return _isPointInArea(point, this.chartArea, this._minPadding);\n }\n getElementsAtEventForMode(e, mode, options, useFinalPosition) {\n const method = Interaction.modes[mode];\n if (typeof method === 'function') {\n return method(this, e, options, useFinalPosition);\n }\n return [];\n }\n getDatasetMeta(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n const metasets = this._metasets;\n let meta = metasets.filter((x)=>x && x._dataset === dataset).pop();\n if (!meta) {\n meta = {\n type: null,\n data: [],\n dataset: null,\n controller: null,\n hidden: null,\n xAxisID: null,\n yAxisID: null,\n order: dataset && dataset.order || 0,\n index: datasetIndex,\n _dataset: dataset,\n _parsed: [],\n _sorted: false\n };\n metasets.push(meta);\n }\n return meta;\n }\n getContext() {\n return this.$context || (this.$context = createContext(null, {\n chart: this,\n type: 'chart'\n }));\n }\n getVisibleDatasetCount() {\n return this.getSortedVisibleDatasetMetas().length;\n }\n isDatasetVisible(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n if (!dataset) {\n return false;\n }\n const meta = this.getDatasetMeta(datasetIndex);\n return typeof meta.hidden === 'boolean' ? !meta.hidden : !dataset.hidden;\n }\n setDatasetVisibility(datasetIndex, visible) {\n const meta = this.getDatasetMeta(datasetIndex);\n meta.hidden = !visible;\n }\n toggleDataVisibility(index) {\n this._hiddenIndices[index] = !this._hiddenIndices[index];\n }\n getDataVisibility(index) {\n return !this._hiddenIndices[index];\n }\n _updateVisibility(datasetIndex, dataIndex, visible) {\n const mode = visible ? 'show' : 'hide';\n const meta = this.getDatasetMeta(datasetIndex);\n const anims = meta.controller._resolveAnimations(undefined, mode);\n if (defined(dataIndex)) {\n meta.data[dataIndex].hidden = !visible;\n this.update();\n } else {\n this.setDatasetVisibility(datasetIndex, visible);\n anims.update(meta, {\n visible\n });\n this.update((ctx)=>ctx.datasetIndex === datasetIndex ? mode : undefined);\n }\n }\n hide(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, false);\n }\n show(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, true);\n }\n _destroyDatasetMeta(datasetIndex) {\n const meta = this._metasets[datasetIndex];\n if (meta && meta.controller) {\n meta.controller._destroy();\n }\n delete this._metasets[datasetIndex];\n }\n _stop() {\n let i, ilen;\n this.stop();\n animator.remove(this);\n for(i = 0, ilen = this.data.datasets.length; i < ilen; ++i){\n this._destroyDatasetMeta(i);\n }\n }\n destroy() {\n this.notifyPlugins('beforeDestroy');\n const { canvas , ctx } = this;\n this._stop();\n this.config.clearCache();\n if (canvas) {\n this.unbindEvents();\n clearCanvas(canvas, ctx);\n this.platform.releaseContext(ctx);\n this.canvas = null;\n this.ctx = null;\n }\n delete instances[this.id];\n this.notifyPlugins('afterDestroy');\n }\n toBase64Image(...args) {\n return this.canvas.toDataURL(...args);\n }\n bindEvents() {\n this.bindUserEvents();\n if (this.options.responsive) {\n this.bindResponsiveEvents();\n } else {\n this.attached = true;\n }\n }\n bindUserEvents() {\n const listeners = this._listeners;\n const platform = this.platform;\n const _add = (type, listener)=>{\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const listener = (e, x, y)=>{\n e.offsetX = x;\n e.offsetY = y;\n this._eventHandler(e);\n };\n each(this.options.events, (type)=>_add(type, listener));\n }\n bindResponsiveEvents() {\n if (!this._responsiveListeners) {\n this._responsiveListeners = {};\n }\n const listeners = this._responsiveListeners;\n const platform = this.platform;\n const _add = (type, listener)=>{\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const _remove = (type, listener)=>{\n if (listeners[type]) {\n platform.removeEventListener(this, type, listener);\n delete listeners[type];\n }\n };\n const listener = (width, height)=>{\n if (this.canvas) {\n this.resize(width, height);\n }\n };\n let detached;\n const attached = ()=>{\n _remove('attach', attached);\n this.attached = true;\n this.resize();\n _add('resize', listener);\n _add('detach', detached);\n };\n detached = ()=>{\n this.attached = false;\n _remove('resize', listener);\n this._stop();\n this._resize(0, 0);\n _add('attach', attached);\n };\n if (platform.isAttached(this.canvas)) {\n attached();\n } else {\n detached();\n }\n }\n unbindEvents() {\n each(this._listeners, (listener, type)=>{\n this.platform.removeEventListener(this, type, listener);\n });\n this._listeners = {};\n each(this._responsiveListeners, (listener, type)=>{\n this.platform.removeEventListener(this, type, listener);\n });\n this._responsiveListeners = undefined;\n }\n updateHoverStyle(items, mode, enabled) {\n const prefix = enabled ? 'set' : 'remove';\n let meta, item, i, ilen;\n if (mode === 'dataset') {\n meta = this.getDatasetMeta(items[0].datasetIndex);\n meta.controller['_' + prefix + 'DatasetHoverStyle']();\n }\n for(i = 0, ilen = items.length; i < ilen; ++i){\n item = items[i];\n const controller = item && this.getDatasetMeta(item.datasetIndex).controller;\n if (controller) {\n controller[prefix + 'HoverStyle'](item.element, item.datasetIndex, item.index);\n }\n }\n }\n getActiveElements() {\n return this._active || [];\n }\n setActiveElements(activeElements) {\n const lastActive = this._active || [];\n const active = activeElements.map(({ datasetIndex , index })=>{\n const meta = this.getDatasetMeta(datasetIndex);\n if (!meta) {\n throw new Error('No dataset found at index ' + datasetIndex);\n }\n return {\n datasetIndex,\n element: meta.data[index],\n index\n };\n });\n const changed = !_elementsEqual(active, lastActive);\n if (changed) {\n this._active = active;\n this._lastEvent = null;\n this._updateHoverStyles(active, lastActive);\n }\n }\n notifyPlugins(hook, args, filter) {\n return this._plugins.notify(this, hook, args, filter);\n }\n isPluginEnabled(pluginId) {\n return this._plugins._cache.filter((p)=>p.plugin.id === pluginId).length === 1;\n }\n _updateHoverStyles(active, lastActive, replay) {\n const hoverOptions = this.options.hover;\n const diff = (a, b)=>a.filter((x)=>!b.some((y)=>x.datasetIndex === y.datasetIndex && x.index === y.index));\n const deactivated = diff(lastActive, active);\n const activated = replay ? active : diff(active, lastActive);\n if (deactivated.length) {\n this.updateHoverStyle(deactivated, hoverOptions.mode, false);\n }\n if (activated.length && hoverOptions.mode) {\n this.updateHoverStyle(activated, hoverOptions.mode, true);\n }\n }\n _eventHandler(e, replay) {\n const args = {\n event: e,\n replay,\n cancelable: true,\n inChartArea: this.isPointInArea(e)\n };\n const eventFilter = (plugin)=>(plugin.options.events || this.options.events).includes(e.native.type);\n if (this.notifyPlugins('beforeEvent', args, eventFilter) === false) {\n return;\n }\n const changed = this._handleEvent(e, replay, args.inChartArea);\n args.cancelable = false;\n this.notifyPlugins('afterEvent', args, eventFilter);\n if (changed || args.changed) {\n this.render();\n }\n return this;\n }\n _handleEvent(e, replay, inChartArea) {\n const { _active: lastActive = [] , options } = this;\n const useFinalPosition = replay;\n const active = this._getActiveElements(e, lastActive, inChartArea, useFinalPosition);\n const isClick = _isClickEvent(e);\n const lastEvent = determineLastEvent(e, this._lastEvent, inChartArea, isClick);\n if (inChartArea) {\n this._lastEvent = null;\n callback(options.onHover, [\n e,\n active,\n this\n ], this);\n if (isClick) {\n callback(options.onClick, [\n e,\n active,\n this\n ], this);\n }\n }\n const changed = !_elementsEqual(active, lastActive);\n if (changed || replay) {\n this._active = active;\n this._updateHoverStyles(active, lastActive, replay);\n }\n this._lastEvent = lastEvent;\n return changed;\n }\n _getActiveElements(e, lastActive, inChartArea, useFinalPosition) {\n if (e.type === 'mouseout') {\n return [];\n }\n if (!inChartArea) {\n return lastActive;\n }\n const hoverOptions = this.options.hover;\n return this.getElementsAtEventForMode(e, hoverOptions.mode, hoverOptions, useFinalPosition);\n }\n}\nfunction invalidatePlugins() {\n return each(Chart.instances, (chart)=>chart._plugins.invalidate());\n}\n\nfunction clipArc(ctx, element, endAngle) {\n const { startAngle , pixelMargin , x , y , outerRadius , innerRadius } = element;\n let angleMargin = pixelMargin / outerRadius;\n // Draw an inner border by clipping the arc and drawing a double-width border\n // Enlarge the clipping arc by 0.33 pixels to eliminate glitches between borders\n ctx.beginPath();\n ctx.arc(x, y, outerRadius, startAngle - angleMargin, endAngle + angleMargin);\n if (innerRadius > pixelMargin) {\n angleMargin = pixelMargin / innerRadius;\n ctx.arc(x, y, innerRadius, endAngle + angleMargin, startAngle - angleMargin, true);\n } else {\n ctx.arc(x, y, pixelMargin, endAngle + HALF_PI, startAngle - HALF_PI);\n }\n ctx.closePath();\n ctx.clip();\n}\nfunction toRadiusCorners(value) {\n return _readValueToProps(value, [\n 'outerStart',\n 'outerEnd',\n 'innerStart',\n 'innerEnd'\n ]);\n}\n/**\n * Parse border radius from the provided options\n */ function parseBorderRadius$1(arc, innerRadius, outerRadius, angleDelta) {\n const o = toRadiusCorners(arc.options.borderRadius);\n const halfThickness = (outerRadius - innerRadius) / 2;\n const innerLimit = Math.min(halfThickness, angleDelta * innerRadius / 2);\n // Outer limits are complicated. We want to compute the available angular distance at\n // a radius of outerRadius - borderRadius because for small angular distances, this term limits.\n // We compute at r = outerRadius - borderRadius because this circle defines the center of the border corners.\n //\n // If the borderRadius is large, that value can become negative.\n // This causes the outer borders to lose their radius entirely, which is rather unexpected. To solve that, if borderRadius > outerRadius\n // we know that the thickness term will dominate and compute the limits at that point\n const computeOuterLimit = (val)=>{\n const outerArcLimit = (outerRadius - Math.min(halfThickness, val)) * angleDelta / 2;\n return _limitValue(val, 0, Math.min(halfThickness, outerArcLimit));\n };\n return {\n outerStart: computeOuterLimit(o.outerStart),\n outerEnd: computeOuterLimit(o.outerEnd),\n innerStart: _limitValue(o.innerStart, 0, innerLimit),\n innerEnd: _limitValue(o.innerEnd, 0, innerLimit)\n };\n}\n/**\n * Convert (r, 𝜃) to (x, y)\n */ function rThetaToXY(r, theta, x, y) {\n return {\n x: x + r * Math.cos(theta),\n y: y + r * Math.sin(theta)\n };\n}\n/**\n * Path the arc, respecting border radius by separating into left and right halves.\n *\n * Start End\n *\n * 1--->a--->2 Outer\n * / \\\n * 8 3\n * | |\n * | |\n * 7 4\n * \\ /\n * 6<---b<---5 Inner\n */ function pathArc(ctx, element, offset, spacing, end, circular) {\n const { x , y , startAngle: start , pixelMargin , innerRadius: innerR } = element;\n const outerRadius = Math.max(element.outerRadius + spacing + offset - pixelMargin, 0);\n const innerRadius = innerR > 0 ? innerR + spacing + offset + pixelMargin : 0;\n let spacingOffset = 0;\n const alpha = end - start;\n if (spacing) {\n // When spacing is present, it is the same for all items\n // So we adjust the start and end angle of the arc such that\n // the distance is the same as it would be without the spacing\n const noSpacingInnerRadius = innerR > 0 ? innerR - spacing : 0;\n const noSpacingOuterRadius = outerRadius > 0 ? outerRadius - spacing : 0;\n const avNogSpacingRadius = (noSpacingInnerRadius + noSpacingOuterRadius) / 2;\n const adjustedAngle = avNogSpacingRadius !== 0 ? alpha * avNogSpacingRadius / (avNogSpacingRadius + spacing) : alpha;\n spacingOffset = (alpha - adjustedAngle) / 2;\n }\n const beta = Math.max(0.001, alpha * outerRadius - offset / PI) / outerRadius;\n const angleOffset = (alpha - beta) / 2;\n const startAngle = start + angleOffset + spacingOffset;\n const endAngle = end - angleOffset - spacingOffset;\n const { outerStart , outerEnd , innerStart , innerEnd } = parseBorderRadius$1(element, innerRadius, outerRadius, endAngle - startAngle);\n const outerStartAdjustedRadius = outerRadius - outerStart;\n const outerEndAdjustedRadius = outerRadius - outerEnd;\n const outerStartAdjustedAngle = startAngle + outerStart / outerStartAdjustedRadius;\n const outerEndAdjustedAngle = endAngle - outerEnd / outerEndAdjustedRadius;\n const innerStartAdjustedRadius = innerRadius + innerStart;\n const innerEndAdjustedRadius = innerRadius + innerEnd;\n const innerStartAdjustedAngle = startAngle + innerStart / innerStartAdjustedRadius;\n const innerEndAdjustedAngle = endAngle - innerEnd / innerEndAdjustedRadius;\n ctx.beginPath();\n if (circular) {\n // The first arc segments from point 1 to point a to point 2\n const outerMidAdjustedAngle = (outerStartAdjustedAngle + outerEndAdjustedAngle) / 2;\n ctx.arc(x, y, outerRadius, outerStartAdjustedAngle, outerMidAdjustedAngle);\n ctx.arc(x, y, outerRadius, outerMidAdjustedAngle, outerEndAdjustedAngle);\n // The corner segment from point 2 to point 3\n if (outerEnd > 0) {\n const pCenter = rThetaToXY(outerEndAdjustedRadius, outerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerEnd, outerEndAdjustedAngle, endAngle + HALF_PI);\n }\n // The line from point 3 to point 4\n const p4 = rThetaToXY(innerEndAdjustedRadius, endAngle, x, y);\n ctx.lineTo(p4.x, p4.y);\n // The corner segment from point 4 to point 5\n if (innerEnd > 0) {\n const pCenter = rThetaToXY(innerEndAdjustedRadius, innerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, innerEnd, endAngle + HALF_PI, innerEndAdjustedAngle + Math.PI);\n }\n // The inner arc from point 5 to point b to point 6\n const innerMidAdjustedAngle = (endAngle - innerEnd / innerRadius + (startAngle + innerStart / innerRadius)) / 2;\n ctx.arc(x, y, innerRadius, endAngle - innerEnd / innerRadius, innerMidAdjustedAngle, true);\n ctx.arc(x, y, innerRadius, innerMidAdjustedAngle, startAngle + innerStart / innerRadius, true);\n // The corner segment from point 6 to point 7\n if (innerStart > 0) {\n const pCenter = rThetaToXY(innerStartAdjustedRadius, innerStartAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, innerStart, innerStartAdjustedAngle + Math.PI, startAngle - HALF_PI);\n }\n // The line from point 7 to point 8\n const p8 = rThetaToXY(outerStartAdjustedRadius, startAngle, x, y);\n ctx.lineTo(p8.x, p8.y);\n // The corner segment from point 8 to point 1\n if (outerStart > 0) {\n const pCenter = rThetaToXY(outerStartAdjustedRadius, outerStartAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerStart, startAngle - HALF_PI, outerStartAdjustedAngle);\n }\n } else {\n ctx.moveTo(x, y);\n const outerStartX = Math.cos(outerStartAdjustedAngle) * outerRadius + x;\n const outerStartY = Math.sin(outerStartAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerStartX, outerStartY);\n const outerEndX = Math.cos(outerEndAdjustedAngle) * outerRadius + x;\n const outerEndY = Math.sin(outerEndAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerEndX, outerEndY);\n }\n ctx.closePath();\n}\nfunction drawArc(ctx, element, offset, spacing, circular) {\n const { fullCircles , startAngle , circumference } = element;\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for(let i = 0; i < fullCircles; ++i){\n ctx.fill();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.fill();\n return endAngle;\n}\nfunction drawBorder(ctx, element, offset, spacing, circular) {\n const { fullCircles , startAngle , circumference , options } = element;\n const { borderWidth , borderJoinStyle , borderDash , borderDashOffset } = options;\n const inner = options.borderAlign === 'inner';\n if (!borderWidth) {\n return;\n }\n ctx.setLineDash(borderDash || []);\n ctx.lineDashOffset = borderDashOffset;\n if (inner) {\n ctx.lineWidth = borderWidth * 2;\n ctx.lineJoin = borderJoinStyle || 'round';\n } else {\n ctx.lineWidth = borderWidth;\n ctx.lineJoin = borderJoinStyle || 'bevel';\n }\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for(let i = 0; i < fullCircles; ++i){\n ctx.stroke();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n if (inner) {\n clipArc(ctx, element, endAngle);\n }\n if (!fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.stroke();\n }\n}\nclass ArcElement extends Element {\n static id = 'arc';\n static defaults = {\n borderAlign: 'center',\n borderColor: '#fff',\n borderDash: [],\n borderDashOffset: 0,\n borderJoinStyle: undefined,\n borderRadius: 0,\n borderWidth: 2,\n offset: 0,\n spacing: 0,\n angle: undefined,\n circular: true\n };\n static defaultRoutes = {\n backgroundColor: 'backgroundColor'\n };\n static descriptors = {\n _scriptable: true,\n _indexable: (name)=>name !== 'borderDash'\n };\n circumference;\n endAngle;\n fullCircles;\n innerRadius;\n outerRadius;\n pixelMargin;\n startAngle;\n constructor(cfg){\n super();\n this.options = undefined;\n this.circumference = undefined;\n this.startAngle = undefined;\n this.endAngle = undefined;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.pixelMargin = 0;\n this.fullCircles = 0;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n inRange(chartX, chartY, useFinalPosition) {\n const point = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n const { angle , distance } = getAngleFromPoint(point, {\n x: chartX,\n y: chartY\n });\n const { startAngle , endAngle , innerRadius , outerRadius , circumference } = this.getProps([\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius',\n 'circumference'\n ], useFinalPosition);\n const rAdjust = (this.options.spacing + this.options.borderWidth) / 2;\n const _circumference = valueOrDefault(circumference, endAngle - startAngle);\n const nonZeroBetween = _angleBetween(angle, startAngle, endAngle) && startAngle !== endAngle;\n const betweenAngles = _circumference >= TAU || nonZeroBetween;\n const withinRadius = _isBetween(distance, innerRadius + rAdjust, outerRadius + rAdjust);\n return betweenAngles && withinRadius;\n }\n getCenterPoint(useFinalPosition) {\n const { x , y , startAngle , endAngle , innerRadius , outerRadius } = this.getProps([\n 'x',\n 'y',\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius'\n ], useFinalPosition);\n const { offset , spacing } = this.options;\n const halfAngle = (startAngle + endAngle) / 2;\n const halfRadius = (innerRadius + outerRadius + spacing + offset) / 2;\n return {\n x: x + Math.cos(halfAngle) * halfRadius,\n y: y + Math.sin(halfAngle) * halfRadius\n };\n }\n tooltipPosition(useFinalPosition) {\n return this.getCenterPoint(useFinalPosition);\n }\n draw(ctx) {\n const { options , circumference } = this;\n const offset = (options.offset || 0) / 4;\n const spacing = (options.spacing || 0) / 2;\n const circular = options.circular;\n this.pixelMargin = options.borderAlign === 'inner' ? 0.33 : 0;\n this.fullCircles = circumference > TAU ? Math.floor(circumference / TAU) : 0;\n if (circumference === 0 || this.innerRadius < 0 || this.outerRadius < 0) {\n return;\n }\n ctx.save();\n const halfAngle = (this.startAngle + this.endAngle) / 2;\n ctx.translate(Math.cos(halfAngle) * offset, Math.sin(halfAngle) * offset);\n const fix = 1 - Math.sin(Math.min(PI, circumference || 0));\n const radiusOffset = offset * fix;\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n drawArc(ctx, this, radiusOffset, spacing, circular);\n drawBorder(ctx, this, radiusOffset, spacing, circular);\n ctx.restore();\n }\n}\n\nfunction setStyle(ctx, options, style = options) {\n ctx.lineCap = valueOrDefault(style.borderCapStyle, options.borderCapStyle);\n ctx.setLineDash(valueOrDefault(style.borderDash, options.borderDash));\n ctx.lineDashOffset = valueOrDefault(style.borderDashOffset, options.borderDashOffset);\n ctx.lineJoin = valueOrDefault(style.borderJoinStyle, options.borderJoinStyle);\n ctx.lineWidth = valueOrDefault(style.borderWidth, options.borderWidth);\n ctx.strokeStyle = valueOrDefault(style.borderColor, options.borderColor);\n}\nfunction lineTo(ctx, previous, target) {\n ctx.lineTo(target.x, target.y);\n}\n function getLineMethod(options) {\n if (options.stepped) {\n return _steppedLineTo;\n }\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierCurveTo;\n }\n return lineTo;\n}\nfunction pathVars(points, segment, params = {}) {\n const count = points.length;\n const { start: paramsStart = 0 , end: paramsEnd = count - 1 } = params;\n const { start: segmentStart , end: segmentEnd } = segment;\n const start = Math.max(paramsStart, segmentStart);\n const end = Math.min(paramsEnd, segmentEnd);\n const outside = paramsStart < segmentStart && paramsEnd < segmentStart || paramsStart > segmentEnd && paramsEnd > segmentEnd;\n return {\n count,\n start,\n loop: segment.loop,\n ilen: end < start && !outside ? count + end - start : end - start\n };\n}\n function pathSegment(ctx, line, segment, params) {\n const { points , options } = line;\n const { count , start , loop , ilen } = pathVars(points, segment, params);\n const lineMethod = getLineMethod(options);\n let { move =true , reverse } = params || {};\n let i, point, prev;\n for(i = 0; i <= ilen; ++i){\n point = points[(start + (reverse ? ilen - i : i)) % count];\n if (point.skip) {\n continue;\n } else if (move) {\n ctx.moveTo(point.x, point.y);\n move = false;\n } else {\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n prev = point;\n }\n if (loop) {\n point = points[(start + (reverse ? ilen : 0)) % count];\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n return !!loop;\n}\n function fastPathSegment(ctx, line, segment, params) {\n const points = line.points;\n const { count , start , ilen } = pathVars(points, segment, params);\n const { move =true , reverse } = params || {};\n let avgX = 0;\n let countX = 0;\n let i, point, prevX, minY, maxY, lastY;\n const pointIndex = (index)=>(start + (reverse ? ilen - index : index)) % count;\n const drawX = ()=>{\n if (minY !== maxY) {\n ctx.lineTo(avgX, maxY);\n ctx.lineTo(avgX, minY);\n ctx.lineTo(avgX, lastY);\n }\n };\n if (move) {\n point = points[pointIndex(0)];\n ctx.moveTo(point.x, point.y);\n }\n for(i = 0; i <= ilen; ++i){\n point = points[pointIndex(i)];\n if (point.skip) {\n continue;\n }\n const x = point.x;\n const y = point.y;\n const truncX = x | 0;\n if (truncX === prevX) {\n if (y < minY) {\n minY = y;\n } else if (y > maxY) {\n maxY = y;\n }\n avgX = (countX * avgX + x) / ++countX;\n } else {\n drawX();\n ctx.lineTo(x, y);\n prevX = truncX;\n countX = 0;\n minY = maxY = y;\n }\n lastY = y;\n }\n drawX();\n}\n function _getSegmentMethod(line) {\n const opts = line.options;\n const borderDash = opts.borderDash && opts.borderDash.length;\n const useFastPath = !line._decimated && !line._loop && !opts.tension && opts.cubicInterpolationMode !== 'monotone' && !opts.stepped && !borderDash;\n return useFastPath ? fastPathSegment : pathSegment;\n}\n function _getInterpolationMethod(options) {\n if (options.stepped) {\n return _steppedInterpolation;\n }\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierInterpolation;\n }\n return _pointInLine;\n}\nfunction strokePathWithCache(ctx, line, start, count) {\n let path = line._path;\n if (!path) {\n path = line._path = new Path2D();\n if (line.path(path, start, count)) {\n path.closePath();\n }\n }\n setStyle(ctx, line.options);\n ctx.stroke(path);\n}\nfunction strokePathDirect(ctx, line, start, count) {\n const { segments , options } = line;\n const segmentMethod = _getSegmentMethod(line);\n for (const segment of segments){\n setStyle(ctx, options, segment.style);\n ctx.beginPath();\n if (segmentMethod(ctx, line, segment, {\n start,\n end: start + count - 1\n })) {\n ctx.closePath();\n }\n ctx.stroke();\n }\n}\nconst usePath2D = typeof Path2D === 'function';\nfunction draw(ctx, line, start, count) {\n if (usePath2D && !line.options.segment) {\n strokePathWithCache(ctx, line, start, count);\n } else {\n strokePathDirect(ctx, line, start, count);\n }\n}\nclass LineElement extends Element {\n static id = 'line';\n static defaults = {\n borderCapStyle: 'butt',\n borderDash: [],\n borderDashOffset: 0,\n borderJoinStyle: 'miter',\n borderWidth: 3,\n capBezierPoints: true,\n cubicInterpolationMode: 'default',\n fill: false,\n spanGaps: false,\n stepped: false,\n tension: 0\n };\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n static descriptors = {\n _scriptable: true,\n _indexable: (name)=>name !== 'borderDash' && name !== 'fill'\n };\n constructor(cfg){\n super();\n this.animated = true;\n this.options = undefined;\n this._chart = undefined;\n this._loop = undefined;\n this._fullLoop = undefined;\n this._path = undefined;\n this._points = undefined;\n this._segments = undefined;\n this._decimated = false;\n this._pointsUpdated = false;\n this._datasetIndex = undefined;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n updateControlPoints(chartArea, indexAxis) {\n const options = this.options;\n if ((options.tension || options.cubicInterpolationMode === 'monotone') && !options.stepped && !this._pointsUpdated) {\n const loop = options.spanGaps ? this._loop : this._fullLoop;\n _updateBezierControlPoints(this._points, options, chartArea, loop, indexAxis);\n this._pointsUpdated = true;\n }\n }\n set points(points) {\n this._points = points;\n delete this._segments;\n delete this._path;\n this._pointsUpdated = false;\n }\n get points() {\n return this._points;\n }\n get segments() {\n return this._segments || (this._segments = _computeSegments(this, this.options.segment));\n }\n first() {\n const segments = this.segments;\n const points = this.points;\n return segments.length && points[segments[0].start];\n }\n last() {\n const segments = this.segments;\n const points = this.points;\n const count = segments.length;\n return count && points[segments[count - 1].end];\n }\n interpolate(point, property) {\n const options = this.options;\n const value = point[property];\n const points = this.points;\n const segments = _boundSegments(this, {\n property,\n start: value,\n end: value\n });\n if (!segments.length) {\n return;\n }\n const result = [];\n const _interpolate = _getInterpolationMethod(options);\n let i, ilen;\n for(i = 0, ilen = segments.length; i < ilen; ++i){\n const { start , end } = segments[i];\n const p1 = points[start];\n const p2 = points[end];\n if (p1 === p2) {\n result.push(p1);\n continue;\n }\n const t = Math.abs((value - p1[property]) / (p2[property] - p1[property]));\n const interpolated = _interpolate(p1, p2, t, options.stepped);\n interpolated[property] = point[property];\n result.push(interpolated);\n }\n return result.length === 1 ? result[0] : result;\n }\n pathSegment(ctx, segment, params) {\n const segmentMethod = _getSegmentMethod(this);\n return segmentMethod(ctx, this, segment, params);\n }\n path(ctx, start, count) {\n const segments = this.segments;\n const segmentMethod = _getSegmentMethod(this);\n let loop = this._loop;\n start = start || 0;\n count = count || this.points.length - start;\n for (const segment of segments){\n loop &= segmentMethod(ctx, this, segment, {\n start,\n end: start + count - 1\n });\n }\n return !!loop;\n }\n draw(ctx, chartArea, start, count) {\n const options = this.options || {};\n const points = this.points || [];\n if (points.length && options.borderWidth) {\n ctx.save();\n draw(ctx, this, start, count);\n ctx.restore();\n }\n if (this.animated) {\n this._pointsUpdated = false;\n this._path = undefined;\n }\n }\n}\n\nfunction inRange$1(el, pos, axis, useFinalPosition) {\n const options = el.options;\n const { [axis]: value } = el.getProps([\n axis\n ], useFinalPosition);\n return Math.abs(pos - value) < options.radius + options.hitRadius;\n}\nclass PointElement extends Element {\n static id = 'point';\n parsed;\n skip;\n stop;\n /**\n * @type {any}\n */ static defaults = {\n borderWidth: 1,\n hitRadius: 1,\n hoverBorderWidth: 1,\n hoverRadius: 4,\n pointStyle: 'circle',\n radius: 3,\n rotation: 0\n };\n /**\n * @type {any}\n */ static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n constructor(cfg){\n super();\n this.options = undefined;\n this.parsed = undefined;\n this.skip = undefined;\n this.stop = undefined;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n inRange(mouseX, mouseY, useFinalPosition) {\n const options = this.options;\n const { x , y } = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n return Math.pow(mouseX - x, 2) + Math.pow(mouseY - y, 2) < Math.pow(options.hitRadius + options.radius, 2);\n }\n inXRange(mouseX, useFinalPosition) {\n return inRange$1(this, mouseX, 'x', useFinalPosition);\n }\n inYRange(mouseY, useFinalPosition) {\n return inRange$1(this, mouseY, 'y', useFinalPosition);\n }\n getCenterPoint(useFinalPosition) {\n const { x , y } = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n return {\n x,\n y\n };\n }\n size(options) {\n options = options || this.options || {};\n let radius = options.radius || 0;\n radius = Math.max(radius, radius && options.hoverRadius || 0);\n const borderWidth = radius && options.borderWidth || 0;\n return (radius + borderWidth) * 2;\n }\n draw(ctx, area) {\n const options = this.options;\n if (this.skip || options.radius < 0.1 || !_isPointInArea(this, area, this.size(options) / 2)) {\n return;\n }\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n ctx.fillStyle = options.backgroundColor;\n drawPoint(ctx, options, this.x, this.y);\n }\n getRange() {\n const options = this.options || {};\n // @ts-expect-error Fallbacks should never be hit in practice\n return options.radius + options.hitRadius;\n }\n}\n\nfunction getBarBounds(bar, useFinalPosition) {\n const { x , y , base , width , height } = bar.getProps([\n 'x',\n 'y',\n 'base',\n 'width',\n 'height'\n ], useFinalPosition);\n let left, right, top, bottom, half;\n if (bar.horizontal) {\n half = height / 2;\n left = Math.min(x, base);\n right = Math.max(x, base);\n top = y - half;\n bottom = y + half;\n } else {\n half = width / 2;\n left = x - half;\n right = x + half;\n top = Math.min(y, base);\n bottom = Math.max(y, base);\n }\n return {\n left,\n top,\n right,\n bottom\n };\n}\nfunction skipOrLimit(skip, value, min, max) {\n return skip ? 0 : _limitValue(value, min, max);\n}\nfunction parseBorderWidth(bar, maxW, maxH) {\n const value = bar.options.borderWidth;\n const skip = bar.borderSkipped;\n const o = toTRBL(value);\n return {\n t: skipOrLimit(skip.top, o.top, 0, maxH),\n r: skipOrLimit(skip.right, o.right, 0, maxW),\n b: skipOrLimit(skip.bottom, o.bottom, 0, maxH),\n l: skipOrLimit(skip.left, o.left, 0, maxW)\n };\n}\nfunction parseBorderRadius(bar, maxW, maxH) {\n const { enableBorderRadius } = bar.getProps([\n 'enableBorderRadius'\n ]);\n const value = bar.options.borderRadius;\n const o = toTRBLCorners(value);\n const maxR = Math.min(maxW, maxH);\n const skip = bar.borderSkipped;\n const enableBorder = enableBorderRadius || isObject(value);\n return {\n topLeft: skipOrLimit(!enableBorder || skip.top || skip.left, o.topLeft, 0, maxR),\n topRight: skipOrLimit(!enableBorder || skip.top || skip.right, o.topRight, 0, maxR),\n bottomLeft: skipOrLimit(!enableBorder || skip.bottom || skip.left, o.bottomLeft, 0, maxR),\n bottomRight: skipOrLimit(!enableBorder || skip.bottom || skip.right, o.bottomRight, 0, maxR)\n };\n}\nfunction boundingRects(bar) {\n const bounds = getBarBounds(bar);\n const width = bounds.right - bounds.left;\n const height = bounds.bottom - bounds.top;\n const border = parseBorderWidth(bar, width / 2, height / 2);\n const radius = parseBorderRadius(bar, width / 2, height / 2);\n return {\n outer: {\n x: bounds.left,\n y: bounds.top,\n w: width,\n h: height,\n radius\n },\n inner: {\n x: bounds.left + border.l,\n y: bounds.top + border.t,\n w: width - border.l - border.r,\n h: height - border.t - border.b,\n radius: {\n topLeft: Math.max(0, radius.topLeft - Math.max(border.t, border.l)),\n topRight: Math.max(0, radius.topRight - Math.max(border.t, border.r)),\n bottomLeft: Math.max(0, radius.bottomLeft - Math.max(border.b, border.l)),\n bottomRight: Math.max(0, radius.bottomRight - Math.max(border.b, border.r))\n }\n }\n };\n}\nfunction inRange(bar, x, y, useFinalPosition) {\n const skipX = x === null;\n const skipY = y === null;\n const skipBoth = skipX && skipY;\n const bounds = bar && !skipBoth && getBarBounds(bar, useFinalPosition);\n return bounds && (skipX || _isBetween(x, bounds.left, bounds.right)) && (skipY || _isBetween(y, bounds.top, bounds.bottom));\n}\nfunction hasRadius(radius) {\n return radius.topLeft || radius.topRight || radius.bottomLeft || radius.bottomRight;\n}\n function addNormalRectPath(ctx, rect) {\n ctx.rect(rect.x, rect.y, rect.w, rect.h);\n}\nfunction inflateRect(rect, amount, refRect = {}) {\n const x = rect.x !== refRect.x ? -amount : 0;\n const y = rect.y !== refRect.y ? -amount : 0;\n const w = (rect.x + rect.w !== refRect.x + refRect.w ? amount : 0) - x;\n const h = (rect.y + rect.h !== refRect.y + refRect.h ? amount : 0) - y;\n return {\n x: rect.x + x,\n y: rect.y + y,\n w: rect.w + w,\n h: rect.h + h,\n radius: rect.radius\n };\n}\nclass BarElement extends Element {\n static id = 'bar';\n static defaults = {\n borderSkipped: 'start',\n borderWidth: 0,\n borderRadius: 0,\n inflateAmount: 'auto',\n pointStyle: undefined\n };\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n constructor(cfg){\n super();\n this.options = undefined;\n this.horizontal = undefined;\n this.base = undefined;\n this.width = undefined;\n this.height = undefined;\n this.inflateAmount = undefined;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n draw(ctx) {\n const { inflateAmount , options: { borderColor , backgroundColor } } = this;\n const { inner , outer } = boundingRects(this);\n const addRectPath = hasRadius(outer.radius) ? addRoundedRectPath : addNormalRectPath;\n ctx.save();\n if (outer.w !== inner.w || outer.h !== inner.h) {\n ctx.beginPath();\n addRectPath(ctx, inflateRect(outer, inflateAmount, inner));\n ctx.clip();\n addRectPath(ctx, inflateRect(inner, -inflateAmount, outer));\n ctx.fillStyle = borderColor;\n ctx.fill('evenodd');\n }\n ctx.beginPath();\n addRectPath(ctx, inflateRect(inner, inflateAmount));\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n ctx.restore();\n }\n inRange(mouseX, mouseY, useFinalPosition) {\n return inRange(this, mouseX, mouseY, useFinalPosition);\n }\n inXRange(mouseX, useFinalPosition) {\n return inRange(this, mouseX, null, useFinalPosition);\n }\n inYRange(mouseY, useFinalPosition) {\n return inRange(this, null, mouseY, useFinalPosition);\n }\n getCenterPoint(useFinalPosition) {\n const { x , y , base , horizontal } = this.getProps([\n 'x',\n 'y',\n 'base',\n 'horizontal'\n ], useFinalPosition);\n return {\n x: horizontal ? (x + base) / 2 : x,\n y: horizontal ? y : (y + base) / 2\n };\n }\n getRange(axis) {\n return axis === 'x' ? this.width / 2 : this.height / 2;\n }\n}\n\nvar elements = /*#__PURE__*/Object.freeze({\n__proto__: null,\nArcElement: ArcElement,\nBarElement: BarElement,\nLineElement: LineElement,\nPointElement: PointElement\n});\n\nconst BORDER_COLORS = [\n 'rgb(54, 162, 235)',\n 'rgb(255, 99, 132)',\n 'rgb(255, 159, 64)',\n 'rgb(255, 205, 86)',\n 'rgb(75, 192, 192)',\n 'rgb(153, 102, 255)',\n 'rgb(201, 203, 207)' // grey\n];\n// Border colors with 50% transparency\nconst BACKGROUND_COLORS = /* #__PURE__ */ BORDER_COLORS.map((color)=>color.replace('rgb(', 'rgba(').replace(')', ', 0.5)'));\nfunction getBorderColor(i) {\n return BORDER_COLORS[i % BORDER_COLORS.length];\n}\nfunction getBackgroundColor(i) {\n return BACKGROUND_COLORS[i % BACKGROUND_COLORS.length];\n}\nfunction colorizeDefaultDataset(dataset, i) {\n dataset.borderColor = getBorderColor(i);\n dataset.backgroundColor = getBackgroundColor(i);\n return ++i;\n}\nfunction colorizeDoughnutDataset(dataset, i) {\n dataset.backgroundColor = dataset.data.map(()=>getBorderColor(i++));\n return i;\n}\nfunction colorizePolarAreaDataset(dataset, i) {\n dataset.backgroundColor = dataset.data.map(()=>getBackgroundColor(i++));\n return i;\n}\nfunction getColorizer(chart) {\n let i = 0;\n return (dataset, datasetIndex)=>{\n const controller = chart.getDatasetMeta(datasetIndex).controller;\n if (controller instanceof DoughnutController) {\n i = colorizeDoughnutDataset(dataset, i);\n } else if (controller instanceof PolarAreaController) {\n i = colorizePolarAreaDataset(dataset, i);\n } else if (controller) {\n i = colorizeDefaultDataset(dataset, i);\n }\n };\n}\nfunction containsColorsDefinitions(descriptors) {\n let k;\n for(k in descriptors){\n if (descriptors[k].borderColor || descriptors[k].backgroundColor) {\n return true;\n }\n }\n return false;\n}\nfunction containsColorsDefinition(descriptor) {\n return descriptor && (descriptor.borderColor || descriptor.backgroundColor);\n}\nfunction containsDefaultColorsDefenitions() {\n return defaults.borderColor !== 'rgba(0,0,0,0.1)' || defaults.backgroundColor !== 'rgba(0,0,0,0.1)';\n}\nvar plugin_colors = {\n id: 'colors',\n defaults: {\n enabled: true,\n forceOverride: false\n },\n beforeLayout (chart, _args, options) {\n if (!options.enabled) {\n return;\n }\n const { data: { datasets } , options: chartOptions } = chart.config;\n const { elements } = chartOptions;\n const containsColorDefenition = containsColorsDefinitions(datasets) || containsColorsDefinition(chartOptions) || elements && containsColorsDefinitions(elements) || containsDefaultColorsDefenitions();\n if (!options.forceOverride && containsColorDefenition) {\n return;\n }\n const colorizer = getColorizer(chart);\n datasets.forEach(colorizer);\n }\n};\n\nfunction lttbDecimation(data, start, count, availableWidth, options) {\n const samples = options.samples || availableWidth;\n if (samples >= count) {\n return data.slice(start, start + count);\n }\n const decimated = [];\n const bucketWidth = (count - 2) / (samples - 2);\n let sampledIndex = 0;\n const endIndex = start + count - 1;\n let a = start;\n let i, maxAreaPoint, maxArea, area, nextA;\n decimated[sampledIndex++] = data[a];\n for(i = 0; i < samples - 2; i++){\n let avgX = 0;\n let avgY = 0;\n let j;\n const avgRangeStart = Math.floor((i + 1) * bucketWidth) + 1 + start;\n const avgRangeEnd = Math.min(Math.floor((i + 2) * bucketWidth) + 1, count) + start;\n const avgRangeLength = avgRangeEnd - avgRangeStart;\n for(j = avgRangeStart; j < avgRangeEnd; j++){\n avgX += data[j].x;\n avgY += data[j].y;\n }\n avgX /= avgRangeLength;\n avgY /= avgRangeLength;\n const rangeOffs = Math.floor(i * bucketWidth) + 1 + start;\n const rangeTo = Math.min(Math.floor((i + 1) * bucketWidth) + 1, count) + start;\n const { x: pointAx , y: pointAy } = data[a];\n maxArea = area = -1;\n for(j = rangeOffs; j < rangeTo; j++){\n area = 0.5 * Math.abs((pointAx - avgX) * (data[j].y - pointAy) - (pointAx - data[j].x) * (avgY - pointAy));\n if (area > maxArea) {\n maxArea = area;\n maxAreaPoint = data[j];\n nextA = j;\n }\n }\n decimated[sampledIndex++] = maxAreaPoint;\n a = nextA;\n }\n decimated[sampledIndex++] = data[endIndex];\n return decimated;\n}\nfunction minMaxDecimation(data, start, count, availableWidth) {\n let avgX = 0;\n let countX = 0;\n let i, point, x, y, prevX, minIndex, maxIndex, startIndex, minY, maxY;\n const decimated = [];\n const endIndex = start + count - 1;\n const xMin = data[start].x;\n const xMax = data[endIndex].x;\n const dx = xMax - xMin;\n for(i = start; i < start + count; ++i){\n point = data[i];\n x = (point.x - xMin) / dx * availableWidth;\n y = point.y;\n const truncX = x | 0;\n if (truncX === prevX) {\n if (y < minY) {\n minY = y;\n minIndex = i;\n } else if (y > maxY) {\n maxY = y;\n maxIndex = i;\n }\n avgX = (countX * avgX + point.x) / ++countX;\n } else {\n const lastIndex = i - 1;\n if (!isNullOrUndef(minIndex) && !isNullOrUndef(maxIndex)) {\n const intermediateIndex1 = Math.min(minIndex, maxIndex);\n const intermediateIndex2 = Math.max(minIndex, maxIndex);\n if (intermediateIndex1 !== startIndex && intermediateIndex1 !== lastIndex) {\n decimated.push({\n ...data[intermediateIndex1],\n x: avgX\n });\n }\n if (intermediateIndex2 !== startIndex && intermediateIndex2 !== lastIndex) {\n decimated.push({\n ...data[intermediateIndex2],\n x: avgX\n });\n }\n }\n if (i > 0 && lastIndex !== startIndex) {\n decimated.push(data[lastIndex]);\n }\n decimated.push(point);\n prevX = truncX;\n countX = 0;\n minY = maxY = y;\n minIndex = maxIndex = startIndex = i;\n }\n }\n return decimated;\n}\nfunction cleanDecimatedDataset(dataset) {\n if (dataset._decimated) {\n const data = dataset._data;\n delete dataset._decimated;\n delete dataset._data;\n Object.defineProperty(dataset, 'data', {\n configurable: true,\n enumerable: true,\n writable: true,\n value: data\n });\n }\n}\nfunction cleanDecimatedData(chart) {\n chart.data.datasets.forEach((dataset)=>{\n cleanDecimatedDataset(dataset);\n });\n}\nfunction getStartAndCountOfVisiblePointsSimplified(meta, points) {\n const pointCount = points.length;\n let start = 0;\n let count;\n const { iScale } = meta;\n const { min , max , minDefined , maxDefined } = iScale.getUserBounds();\n if (minDefined) {\n start = _limitValue(_lookupByKey(points, iScale.axis, min).lo, 0, pointCount - 1);\n }\n if (maxDefined) {\n count = _limitValue(_lookupByKey(points, iScale.axis, max).hi + 1, start, pointCount) - start;\n } else {\n count = pointCount - start;\n }\n return {\n start,\n count\n };\n}\nvar plugin_decimation = {\n id: 'decimation',\n defaults: {\n algorithm: 'min-max',\n enabled: false\n },\n beforeElementsUpdate: (chart, args, options)=>{\n if (!options.enabled) {\n cleanDecimatedData(chart);\n return;\n }\n const availableWidth = chart.width;\n chart.data.datasets.forEach((dataset, datasetIndex)=>{\n const { _data , indexAxis } = dataset;\n const meta = chart.getDatasetMeta(datasetIndex);\n const data = _data || dataset.data;\n if (resolve([\n indexAxis,\n chart.options.indexAxis\n ]) === 'y') {\n return;\n }\n if (!meta.controller.supportsDecimation) {\n return;\n }\n const xAxis = chart.scales[meta.xAxisID];\n if (xAxis.type !== 'linear' && xAxis.type !== 'time') {\n return;\n }\n if (chart.options.parsing) {\n return;\n }\n let { start , count } = getStartAndCountOfVisiblePointsSimplified(meta, data);\n const threshold = options.threshold || 4 * availableWidth;\n if (count <= threshold) {\n cleanDecimatedDataset(dataset);\n return;\n }\n if (isNullOrUndef(_data)) {\n dataset._data = data;\n delete dataset.data;\n Object.defineProperty(dataset, 'data', {\n configurable: true,\n enumerable: true,\n get: function() {\n return this._decimated;\n },\n set: function(d) {\n this._data = d;\n }\n });\n }\n let decimated;\n switch(options.algorithm){\n case 'lttb':\n decimated = lttbDecimation(data, start, count, availableWidth, options);\n break;\n case 'min-max':\n decimated = minMaxDecimation(data, start, count, availableWidth);\n break;\n default:\n throw new Error(`Unsupported decimation algorithm '${options.algorithm}'`);\n }\n dataset._decimated = decimated;\n });\n },\n destroy (chart) {\n cleanDecimatedData(chart);\n }\n};\n\nfunction _segments(line, target, property) {\n const segments = line.segments;\n const points = line.points;\n const tpoints = target.points;\n const parts = [];\n for (const segment of segments){\n let { start , end } = segment;\n end = _findSegmentEnd(start, end, points);\n const bounds = _getBounds(property, points[start], points[end], segment.loop);\n if (!target.segments) {\n parts.push({\n source: segment,\n target: bounds,\n start: points[start],\n end: points[end]\n });\n continue;\n }\n const targetSegments = _boundSegments(target, bounds);\n for (const tgt of targetSegments){\n const subBounds = _getBounds(property, tpoints[tgt.start], tpoints[tgt.end], tgt.loop);\n const fillSources = _boundSegment(segment, points, subBounds);\n for (const fillSource of fillSources){\n parts.push({\n source: fillSource,\n target: tgt,\n start: {\n [property]: _getEdge(bounds, subBounds, 'start', Math.max)\n },\n end: {\n [property]: _getEdge(bounds, subBounds, 'end', Math.min)\n }\n });\n }\n }\n }\n return parts;\n}\nfunction _getBounds(property, first, last, loop) {\n if (loop) {\n return;\n }\n let start = first[property];\n let end = last[property];\n if (property === 'angle') {\n start = _normalizeAngle(start);\n end = _normalizeAngle(end);\n }\n return {\n property,\n start,\n end\n };\n}\nfunction _pointsFromSegments(boundary, line) {\n const { x =null , y =null } = boundary || {};\n const linePoints = line.points;\n const points = [];\n line.segments.forEach(({ start , end })=>{\n end = _findSegmentEnd(start, end, linePoints);\n const first = linePoints[start];\n const last = linePoints[end];\n if (y !== null) {\n points.push({\n x: first.x,\n y\n });\n points.push({\n x: last.x,\n y\n });\n } else if (x !== null) {\n points.push({\n x,\n y: first.y\n });\n points.push({\n x,\n y: last.y\n });\n }\n });\n return points;\n}\nfunction _findSegmentEnd(start, end, points) {\n for(; end > start; end--){\n const point = points[end];\n if (!isNaN(point.x) && !isNaN(point.y)) {\n break;\n }\n }\n return end;\n}\nfunction _getEdge(a, b, prop, fn) {\n if (a && b) {\n return fn(a[prop], b[prop]);\n }\n return a ? a[prop] : b ? b[prop] : 0;\n}\n\nfunction _createBoundaryLine(boundary, line) {\n let points = [];\n let _loop = false;\n if (isArray(boundary)) {\n _loop = true;\n points = boundary;\n } else {\n points = _pointsFromSegments(boundary, line);\n }\n return points.length ? new LineElement({\n points,\n options: {\n tension: 0\n },\n _loop,\n _fullLoop: _loop\n }) : null;\n}\nfunction _shouldApplyFill(source) {\n return source && source.fill !== false;\n}\n\nfunction _resolveTarget(sources, index, propagate) {\n const source = sources[index];\n let fill = source.fill;\n const visited = [\n index\n ];\n let target;\n if (!propagate) {\n return fill;\n }\n while(fill !== false && visited.indexOf(fill) === -1){\n if (!isNumberFinite(fill)) {\n return fill;\n }\n target = sources[fill];\n if (!target) {\n return false;\n }\n if (target.visible) {\n return fill;\n }\n visited.push(fill);\n fill = target.fill;\n }\n return false;\n}\n function _decodeFill(line, index, count) {\n const fill = parseFillOption(line);\n if (isObject(fill)) {\n return isNaN(fill.value) ? false : fill;\n }\n let target = parseFloat(fill);\n if (isNumberFinite(target) && Math.floor(target) === target) {\n return decodeTargetIndex(fill[0], index, target, count);\n }\n return [\n 'origin',\n 'start',\n 'end',\n 'stack',\n 'shape'\n ].indexOf(fill) >= 0 && fill;\n}\nfunction decodeTargetIndex(firstCh, index, target, count) {\n if (firstCh === '-' || firstCh === '+') {\n target = index + target;\n }\n if (target === index || target < 0 || target >= count) {\n return false;\n }\n return target;\n}\n function _getTargetPixel(fill, scale) {\n let pixel = null;\n if (fill === 'start') {\n pixel = scale.bottom;\n } else if (fill === 'end') {\n pixel = scale.top;\n } else if (isObject(fill)) {\n pixel = scale.getPixelForValue(fill.value);\n } else if (scale.getBasePixel) {\n pixel = scale.getBasePixel();\n }\n return pixel;\n}\n function _getTargetValue(fill, scale, startValue) {\n let value;\n if (fill === 'start') {\n value = startValue;\n } else if (fill === 'end') {\n value = scale.options.reverse ? scale.min : scale.max;\n } else if (isObject(fill)) {\n value = fill.value;\n } else {\n value = scale.getBaseValue();\n }\n return value;\n}\n function parseFillOption(line) {\n const options = line.options;\n const fillOption = options.fill;\n let fill = valueOrDefault(fillOption && fillOption.target, fillOption);\n if (fill === undefined) {\n fill = !!options.backgroundColor;\n }\n if (fill === false || fill === null) {\n return false;\n }\n if (fill === true) {\n return 'origin';\n }\n return fill;\n}\n\nfunction _buildStackLine(source) {\n const { scale , index , line } = source;\n const points = [];\n const segments = line.segments;\n const sourcePoints = line.points;\n const linesBelow = getLinesBelow(scale, index);\n linesBelow.push(_createBoundaryLine({\n x: null,\n y: scale.bottom\n }, line));\n for(let i = 0; i < segments.length; i++){\n const segment = segments[i];\n for(let j = segment.start; j <= segment.end; j++){\n addPointsBelow(points, sourcePoints[j], linesBelow);\n }\n }\n return new LineElement({\n points,\n options: {}\n });\n}\n function getLinesBelow(scale, index) {\n const below = [];\n const metas = scale.getMatchingVisibleMetas('line');\n for(let i = 0; i < metas.length; i++){\n const meta = metas[i];\n if (meta.index === index) {\n break;\n }\n if (!meta.hidden) {\n below.unshift(meta.dataset);\n }\n }\n return below;\n}\n function addPointsBelow(points, sourcePoint, linesBelow) {\n const postponed = [];\n for(let j = 0; j < linesBelow.length; j++){\n const line = linesBelow[j];\n const { first , last , point } = findPoint(line, sourcePoint, 'x');\n if (!point || first && last) {\n continue;\n }\n if (first) {\n postponed.unshift(point);\n } else {\n points.push(point);\n if (!last) {\n break;\n }\n }\n }\n points.push(...postponed);\n}\n function findPoint(line, sourcePoint, property) {\n const point = line.interpolate(sourcePoint, property);\n if (!point) {\n return {};\n }\n const pointValue = point[property];\n const segments = line.segments;\n const linePoints = line.points;\n let first = false;\n let last = false;\n for(let i = 0; i < segments.length; i++){\n const segment = segments[i];\n const firstValue = linePoints[segment.start][property];\n const lastValue = linePoints[segment.end][property];\n if (_isBetween(pointValue, firstValue, lastValue)) {\n first = pointValue === firstValue;\n last = pointValue === lastValue;\n break;\n }\n }\n return {\n first,\n last,\n point\n };\n}\n\nclass simpleArc {\n constructor(opts){\n this.x = opts.x;\n this.y = opts.y;\n this.radius = opts.radius;\n }\n pathSegment(ctx, bounds, opts) {\n const { x , y , radius } = this;\n bounds = bounds || {\n start: 0,\n end: TAU\n };\n ctx.arc(x, y, radius, bounds.end, bounds.start, true);\n return !opts.bounds;\n }\n interpolate(point) {\n const { x , y , radius } = this;\n const angle = point.angle;\n return {\n x: x + Math.cos(angle) * radius,\n y: y + Math.sin(angle) * radius,\n angle\n };\n }\n}\n\nfunction _getTarget(source) {\n const { chart , fill , line } = source;\n if (isNumberFinite(fill)) {\n return getLineByIndex(chart, fill);\n }\n if (fill === 'stack') {\n return _buildStackLine(source);\n }\n if (fill === 'shape') {\n return true;\n }\n const boundary = computeBoundary(source);\n if (boundary instanceof simpleArc) {\n return boundary;\n }\n return _createBoundaryLine(boundary, line);\n}\n function getLineByIndex(chart, index) {\n const meta = chart.getDatasetMeta(index);\n const visible = meta && chart.isDatasetVisible(index);\n return visible ? meta.dataset : null;\n}\nfunction computeBoundary(source) {\n const scale = source.scale || {};\n if (scale.getPointPositionForValue) {\n return computeCircularBoundary(source);\n }\n return computeLinearBoundary(source);\n}\nfunction computeLinearBoundary(source) {\n const { scale ={} , fill } = source;\n const pixel = _getTargetPixel(fill, scale);\n if (isNumberFinite(pixel)) {\n const horizontal = scale.isHorizontal();\n return {\n x: horizontal ? pixel : null,\n y: horizontal ? null : pixel\n };\n }\n return null;\n}\nfunction computeCircularBoundary(source) {\n const { scale , fill } = source;\n const options = scale.options;\n const length = scale.getLabels().length;\n const start = options.reverse ? scale.max : scale.min;\n const value = _getTargetValue(fill, scale, start);\n const target = [];\n if (options.grid.circular) {\n const center = scale.getPointPositionForValue(0, start);\n return new simpleArc({\n x: center.x,\n y: center.y,\n radius: scale.getDistanceFromCenterForValue(value)\n });\n }\n for(let i = 0; i < length; ++i){\n target.push(scale.getPointPositionForValue(i, value));\n }\n return target;\n}\n\nfunction _drawfill(ctx, source, area) {\n const target = _getTarget(source);\n const { line , scale , axis } = source;\n const lineOpts = line.options;\n const fillOption = lineOpts.fill;\n const color = lineOpts.backgroundColor;\n const { above =color , below =color } = fillOption || {};\n if (target && line.points.length) {\n clipArea(ctx, area);\n doFill(ctx, {\n line,\n target,\n above,\n below,\n area,\n scale,\n axis\n });\n unclipArea(ctx);\n }\n}\nfunction doFill(ctx, cfg) {\n const { line , target , above , below , area , scale } = cfg;\n const property = line._loop ? 'angle' : cfg.axis;\n ctx.save();\n if (property === 'x' && below !== above) {\n clipVertical(ctx, target, area.top);\n fill(ctx, {\n line,\n target,\n color: above,\n scale,\n property\n });\n ctx.restore();\n ctx.save();\n clipVertical(ctx, target, area.bottom);\n }\n fill(ctx, {\n line,\n target,\n color: below,\n scale,\n property\n });\n ctx.restore();\n}\nfunction clipVertical(ctx, target, clipY) {\n const { segments , points } = target;\n let first = true;\n let lineLoop = false;\n ctx.beginPath();\n for (const segment of segments){\n const { start , end } = segment;\n const firstPoint = points[start];\n const lastPoint = points[_findSegmentEnd(start, end, points)];\n if (first) {\n ctx.moveTo(firstPoint.x, firstPoint.y);\n first = false;\n } else {\n ctx.lineTo(firstPoint.x, clipY);\n ctx.lineTo(firstPoint.x, firstPoint.y);\n }\n lineLoop = !!target.pathSegment(ctx, segment, {\n move: lineLoop\n });\n if (lineLoop) {\n ctx.closePath();\n } else {\n ctx.lineTo(lastPoint.x, clipY);\n }\n }\n ctx.lineTo(target.first().x, clipY);\n ctx.closePath();\n ctx.clip();\n}\nfunction fill(ctx, cfg) {\n const { line , target , property , color , scale } = cfg;\n const segments = _segments(line, target, property);\n for (const { source: src , target: tgt , start , end } of segments){\n const { style: { backgroundColor =color } = {} } = src;\n const notShape = target !== true;\n ctx.save();\n ctx.fillStyle = backgroundColor;\n clipBounds(ctx, scale, notShape && _getBounds(property, start, end));\n ctx.beginPath();\n const lineLoop = !!line.pathSegment(ctx, src);\n let loop;\n if (notShape) {\n if (lineLoop) {\n ctx.closePath();\n } else {\n interpolatedLineTo(ctx, target, end, property);\n }\n const targetLoop = !!target.pathSegment(ctx, tgt, {\n move: lineLoop,\n reverse: true\n });\n loop = lineLoop && targetLoop;\n if (!loop) {\n interpolatedLineTo(ctx, target, start, property);\n }\n }\n ctx.closePath();\n ctx.fill(loop ? 'evenodd' : 'nonzero');\n ctx.restore();\n }\n}\nfunction clipBounds(ctx, scale, bounds) {\n const { top , bottom } = scale.chart.chartArea;\n const { property , start , end } = bounds || {};\n if (property === 'x') {\n ctx.beginPath();\n ctx.rect(start, top, end - start, bottom - top);\n ctx.clip();\n }\n}\nfunction interpolatedLineTo(ctx, target, point, property) {\n const interpolatedPoint = target.interpolate(point, property);\n if (interpolatedPoint) {\n ctx.lineTo(interpolatedPoint.x, interpolatedPoint.y);\n }\n}\n\nvar index = {\n id: 'filler',\n afterDatasetsUpdate (chart, _args, options) {\n const count = (chart.data.datasets || []).length;\n const sources = [];\n let meta, i, line, source;\n for(i = 0; i < count; ++i){\n meta = chart.getDatasetMeta(i);\n line = meta.dataset;\n source = null;\n if (line && line.options && line instanceof LineElement) {\n source = {\n visible: chart.isDatasetVisible(i),\n index: i,\n fill: _decodeFill(line, i, count),\n chart,\n axis: meta.controller.options.indexAxis,\n scale: meta.vScale,\n line\n };\n }\n meta.$filler = source;\n sources.push(source);\n }\n for(i = 0; i < count; ++i){\n source = sources[i];\n if (!source || source.fill === false) {\n continue;\n }\n source.fill = _resolveTarget(sources, i, options.propagate);\n }\n },\n beforeDraw (chart, _args, options) {\n const draw = options.drawTime === 'beforeDraw';\n const metasets = chart.getSortedVisibleDatasetMetas();\n const area = chart.chartArea;\n for(let i = metasets.length - 1; i >= 0; --i){\n const source = metasets[i].$filler;\n if (!source) {\n continue;\n }\n source.line.updateControlPoints(area, source.axis);\n if (draw && source.fill) {\n _drawfill(chart.ctx, source, area);\n }\n }\n },\n beforeDatasetsDraw (chart, _args, options) {\n if (options.drawTime !== 'beforeDatasetsDraw') {\n return;\n }\n const metasets = chart.getSortedVisibleDatasetMetas();\n for(let i = metasets.length - 1; i >= 0; --i){\n const source = metasets[i].$filler;\n if (_shouldApplyFill(source)) {\n _drawfill(chart.ctx, source, chart.chartArea);\n }\n }\n },\n beforeDatasetDraw (chart, args, options) {\n const source = args.meta.$filler;\n if (!_shouldApplyFill(source) || options.drawTime !== 'beforeDatasetDraw') {\n return;\n }\n _drawfill(chart.ctx, source, chart.chartArea);\n },\n defaults: {\n propagate: true,\n drawTime: 'beforeDatasetDraw'\n }\n};\n\nconst getBoxSize = (labelOpts, fontSize)=>{\n let { boxHeight =fontSize , boxWidth =fontSize } = labelOpts;\n if (labelOpts.usePointStyle) {\n boxHeight = Math.min(boxHeight, fontSize);\n boxWidth = labelOpts.pointStyleWidth || Math.min(boxWidth, fontSize);\n }\n return {\n boxWidth,\n boxHeight,\n itemHeight: Math.max(fontSize, boxHeight)\n };\n};\nconst itemsEqual = (a, b)=>a !== null && b !== null && a.datasetIndex === b.datasetIndex && a.index === b.index;\nclass Legend extends Element {\n constructor(config){\n super();\n this._added = false;\n this.legendHitBoxes = [];\n this._hoveredItem = null;\n this.doughnutMode = false;\n this.chart = config.chart;\n this.options = config.options;\n this.ctx = config.ctx;\n this.legendItems = undefined;\n this.columnSizes = undefined;\n this.lineWidths = undefined;\n this.maxHeight = undefined;\n this.maxWidth = undefined;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.height = undefined;\n this.width = undefined;\n this._margins = undefined;\n this.position = undefined;\n this.weight = undefined;\n this.fullSize = undefined;\n }\n update(maxWidth, maxHeight, margins) {\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins;\n this.setDimensions();\n this.buildLabels();\n this.fit();\n }\n setDimensions() {\n if (this.isHorizontal()) {\n this.width = this.maxWidth;\n this.left = this._margins.left;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n this.top = this._margins.top;\n this.bottom = this.height;\n }\n }\n buildLabels() {\n const labelOpts = this.options.labels || {};\n let legendItems = callback(labelOpts.generateLabels, [\n this.chart\n ], this) || [];\n if (labelOpts.filter) {\n legendItems = legendItems.filter((item)=>labelOpts.filter(item, this.chart.data));\n }\n if (labelOpts.sort) {\n legendItems = legendItems.sort((a, b)=>labelOpts.sort(a, b, this.chart.data));\n }\n if (this.options.reverse) {\n legendItems.reverse();\n }\n this.legendItems = legendItems;\n }\n fit() {\n const { options , ctx } = this;\n if (!options.display) {\n this.width = this.height = 0;\n return;\n }\n const labelOpts = options.labels;\n const labelFont = toFont(labelOpts.font);\n const fontSize = labelFont.size;\n const titleHeight = this._computeTitleHeight();\n const { boxWidth , itemHeight } = getBoxSize(labelOpts, fontSize);\n let width, height;\n ctx.font = labelFont.string;\n if (this.isHorizontal()) {\n width = this.maxWidth;\n height = this._fitRows(titleHeight, fontSize, boxWidth, itemHeight) + 10;\n } else {\n height = this.maxHeight;\n width = this._fitCols(titleHeight, labelFont, boxWidth, itemHeight) + 10;\n }\n this.width = Math.min(width, options.maxWidth || this.maxWidth);\n this.height = Math.min(height, options.maxHeight || this.maxHeight);\n }\n _fitRows(titleHeight, fontSize, boxWidth, itemHeight) {\n const { ctx , maxWidth , options: { labels: { padding } } } = this;\n const hitboxes = this.legendHitBoxes = [];\n const lineWidths = this.lineWidths = [\n 0\n ];\n const lineHeight = itemHeight + padding;\n let totalHeight = titleHeight;\n ctx.textAlign = 'left';\n ctx.textBaseline = 'middle';\n let row = -1;\n let top = -lineHeight;\n this.legendItems.forEach((legendItem, i)=>{\n const itemWidth = boxWidth + fontSize / 2 + ctx.measureText(legendItem.text).width;\n if (i === 0 || lineWidths[lineWidths.length - 1] + itemWidth + 2 * padding > maxWidth) {\n totalHeight += lineHeight;\n lineWidths[lineWidths.length - (i > 0 ? 0 : 1)] = 0;\n top += lineHeight;\n row++;\n }\n hitboxes[i] = {\n left: 0,\n top,\n row,\n width: itemWidth,\n height: itemHeight\n };\n lineWidths[lineWidths.length - 1] += itemWidth + padding;\n });\n return totalHeight;\n }\n _fitCols(titleHeight, labelFont, boxWidth, _itemHeight) {\n const { ctx , maxHeight , options: { labels: { padding } } } = this;\n const hitboxes = this.legendHitBoxes = [];\n const columnSizes = this.columnSizes = [];\n const heightLimit = maxHeight - titleHeight;\n let totalWidth = padding;\n let currentColWidth = 0;\n let currentColHeight = 0;\n let left = 0;\n let col = 0;\n this.legendItems.forEach((legendItem, i)=>{\n const { itemWidth , itemHeight } = calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight);\n if (i > 0 && currentColHeight + itemHeight + 2 * padding > heightLimit) {\n totalWidth += currentColWidth + padding;\n columnSizes.push({\n width: currentColWidth,\n height: currentColHeight\n });\n left += currentColWidth + padding;\n col++;\n currentColWidth = currentColHeight = 0;\n }\n hitboxes[i] = {\n left,\n top: currentColHeight,\n col,\n width: itemWidth,\n height: itemHeight\n };\n currentColWidth = Math.max(currentColWidth, itemWidth);\n currentColHeight += itemHeight + padding;\n });\n totalWidth += currentColWidth;\n columnSizes.push({\n width: currentColWidth,\n height: currentColHeight\n });\n return totalWidth;\n }\n adjustHitBoxes() {\n if (!this.options.display) {\n return;\n }\n const titleHeight = this._computeTitleHeight();\n const { legendHitBoxes: hitboxes , options: { align , labels: { padding } , rtl } } = this;\n const rtlHelper = getRtlAdapter(rtl, this.left, this.width);\n if (this.isHorizontal()) {\n let row = 0;\n let left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n for (const hitbox of hitboxes){\n if (row !== hitbox.row) {\n row = hitbox.row;\n left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n }\n hitbox.top += this.top + titleHeight + padding;\n hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(left), hitbox.width);\n left += hitbox.width + padding;\n }\n } else {\n let col = 0;\n let top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n for (const hitbox of hitboxes){\n if (hitbox.col !== col) {\n col = hitbox.col;\n top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n }\n hitbox.top = top;\n hitbox.left += this.left + padding;\n hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(hitbox.left), hitbox.width);\n top += hitbox.height + padding;\n }\n }\n }\n isHorizontal() {\n return this.options.position === 'top' || this.options.position === 'bottom';\n }\n draw() {\n if (this.options.display) {\n const ctx = this.ctx;\n clipArea(ctx, this);\n this._draw();\n unclipArea(ctx);\n }\n }\n _draw() {\n const { options: opts , columnSizes , lineWidths , ctx } = this;\n const { align , labels: labelOpts } = opts;\n const defaultColor = defaults.color;\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const labelFont = toFont(labelOpts.font);\n const { padding } = labelOpts;\n const fontSize = labelFont.size;\n const halfFontSize = fontSize / 2;\n let cursor;\n this.drawTitle();\n ctx.textAlign = rtlHelper.textAlign('left');\n ctx.textBaseline = 'middle';\n ctx.lineWidth = 0.5;\n ctx.font = labelFont.string;\n const { boxWidth , boxHeight , itemHeight } = getBoxSize(labelOpts, fontSize);\n const drawLegendBox = function(x, y, legendItem) {\n if (isNaN(boxWidth) || boxWidth <= 0 || isNaN(boxHeight) || boxHeight < 0) {\n return;\n }\n ctx.save();\n const lineWidth = valueOrDefault(legendItem.lineWidth, 1);\n ctx.fillStyle = valueOrDefault(legendItem.fillStyle, defaultColor);\n ctx.lineCap = valueOrDefault(legendItem.lineCap, 'butt');\n ctx.lineDashOffset = valueOrDefault(legendItem.lineDashOffset, 0);\n ctx.lineJoin = valueOrDefault(legendItem.lineJoin, 'miter');\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = valueOrDefault(legendItem.strokeStyle, defaultColor);\n ctx.setLineDash(valueOrDefault(legendItem.lineDash, []));\n if (labelOpts.usePointStyle) {\n const drawOptions = {\n radius: boxHeight * Math.SQRT2 / 2,\n pointStyle: legendItem.pointStyle,\n rotation: legendItem.rotation,\n borderWidth: lineWidth\n };\n const centerX = rtlHelper.xPlus(x, boxWidth / 2);\n const centerY = y + halfFontSize;\n drawPointLegend(ctx, drawOptions, centerX, centerY, labelOpts.pointStyleWidth && boxWidth);\n } else {\n const yBoxTop = y + Math.max((fontSize - boxHeight) / 2, 0);\n const xBoxLeft = rtlHelper.leftForLtr(x, boxWidth);\n const borderRadius = toTRBLCorners(legendItem.borderRadius);\n ctx.beginPath();\n if (Object.values(borderRadius).some((v)=>v !== 0)) {\n addRoundedRectPath(ctx, {\n x: xBoxLeft,\n y: yBoxTop,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius\n });\n } else {\n ctx.rect(xBoxLeft, yBoxTop, boxWidth, boxHeight);\n }\n ctx.fill();\n if (lineWidth !== 0) {\n ctx.stroke();\n }\n }\n ctx.restore();\n };\n const fillText = function(x, y, legendItem) {\n renderText(ctx, legendItem.text, x, y + itemHeight / 2, labelFont, {\n strikethrough: legendItem.hidden,\n textAlign: rtlHelper.textAlign(legendItem.textAlign)\n });\n };\n const isHorizontal = this.isHorizontal();\n const titleHeight = this._computeTitleHeight();\n if (isHorizontal) {\n cursor = {\n x: _alignStartEnd(align, this.left + padding, this.right - lineWidths[0]),\n y: this.top + padding + titleHeight,\n line: 0\n };\n } else {\n cursor = {\n x: this.left + padding,\n y: _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[0].height),\n line: 0\n };\n }\n overrideTextDirection(this.ctx, opts.textDirection);\n const lineHeight = itemHeight + padding;\n this.legendItems.forEach((legendItem, i)=>{\n ctx.strokeStyle = legendItem.fontColor;\n ctx.fillStyle = legendItem.fontColor;\n const textWidth = ctx.measureText(legendItem.text).width;\n const textAlign = rtlHelper.textAlign(legendItem.textAlign || (legendItem.textAlign = labelOpts.textAlign));\n const width = boxWidth + halfFontSize + textWidth;\n let x = cursor.x;\n let y = cursor.y;\n rtlHelper.setWidth(this.width);\n if (isHorizontal) {\n if (i > 0 && x + width + padding > this.right) {\n y = cursor.y += lineHeight;\n cursor.line++;\n x = cursor.x = _alignStartEnd(align, this.left + padding, this.right - lineWidths[cursor.line]);\n }\n } else if (i > 0 && y + lineHeight > this.bottom) {\n x = cursor.x = x + columnSizes[cursor.line].width + padding;\n cursor.line++;\n y = cursor.y = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[cursor.line].height);\n }\n const realX = rtlHelper.x(x);\n drawLegendBox(realX, y, legendItem);\n x = _textX(textAlign, x + boxWidth + halfFontSize, isHorizontal ? x + width : this.right, opts.rtl);\n fillText(rtlHelper.x(x), y, legendItem);\n if (isHorizontal) {\n cursor.x += width + padding;\n } else if (typeof legendItem.text !== 'string') {\n const fontLineHeight = labelFont.lineHeight;\n cursor.y += calculateLegendItemHeight(legendItem, fontLineHeight) + padding;\n } else {\n cursor.y += lineHeight;\n }\n });\n restoreTextDirection(this.ctx, opts.textDirection);\n }\n drawTitle() {\n const opts = this.options;\n const titleOpts = opts.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n if (!titleOpts.display) {\n return;\n }\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const ctx = this.ctx;\n const position = titleOpts.position;\n const halfFontSize = titleFont.size / 2;\n const topPaddingPlusHalfFontSize = titlePadding.top + halfFontSize;\n let y;\n let left = this.left;\n let maxWidth = this.width;\n if (this.isHorizontal()) {\n maxWidth = Math.max(...this.lineWidths);\n y = this.top + topPaddingPlusHalfFontSize;\n left = _alignStartEnd(opts.align, left, this.right - maxWidth);\n } else {\n const maxHeight = this.columnSizes.reduce((acc, size)=>Math.max(acc, size.height), 0);\n y = topPaddingPlusHalfFontSize + _alignStartEnd(opts.align, this.top, this.bottom - maxHeight - opts.labels.padding - this._computeTitleHeight());\n }\n const x = _alignStartEnd(position, left, left + maxWidth);\n ctx.textAlign = rtlHelper.textAlign(_toLeftRightCenter(position));\n ctx.textBaseline = 'middle';\n ctx.strokeStyle = titleOpts.color;\n ctx.fillStyle = titleOpts.color;\n ctx.font = titleFont.string;\n renderText(ctx, titleOpts.text, x, y, titleFont);\n }\n _computeTitleHeight() {\n const titleOpts = this.options.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n return titleOpts.display ? titleFont.lineHeight + titlePadding.height : 0;\n }\n _getLegendItemAt(x, y) {\n let i, hitBox, lh;\n if (_isBetween(x, this.left, this.right) && _isBetween(y, this.top, this.bottom)) {\n lh = this.legendHitBoxes;\n for(i = 0; i < lh.length; ++i){\n hitBox = lh[i];\n if (_isBetween(x, hitBox.left, hitBox.left + hitBox.width) && _isBetween(y, hitBox.top, hitBox.top + hitBox.height)) {\n return this.legendItems[i];\n }\n }\n }\n return null;\n }\n handleEvent(e) {\n const opts = this.options;\n if (!isListened(e.type, opts)) {\n return;\n }\n const hoveredItem = this._getLegendItemAt(e.x, e.y);\n if (e.type === 'mousemove' || e.type === 'mouseout') {\n const previous = this._hoveredItem;\n const sameItem = itemsEqual(previous, hoveredItem);\n if (previous && !sameItem) {\n callback(opts.onLeave, [\n e,\n previous,\n this\n ], this);\n }\n this._hoveredItem = hoveredItem;\n if (hoveredItem && !sameItem) {\n callback(opts.onHover, [\n e,\n hoveredItem,\n this\n ], this);\n }\n } else if (hoveredItem) {\n callback(opts.onClick, [\n e,\n hoveredItem,\n this\n ], this);\n }\n }\n}\nfunction calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight) {\n const itemWidth = calculateItemWidth(legendItem, boxWidth, labelFont, ctx);\n const itemHeight = calculateItemHeight(_itemHeight, legendItem, labelFont.lineHeight);\n return {\n itemWidth,\n itemHeight\n };\n}\nfunction calculateItemWidth(legendItem, boxWidth, labelFont, ctx) {\n let legendItemText = legendItem.text;\n if (legendItemText && typeof legendItemText !== 'string') {\n legendItemText = legendItemText.reduce((a, b)=>a.length > b.length ? a : b);\n }\n return boxWidth + labelFont.size / 2 + ctx.measureText(legendItemText).width;\n}\nfunction calculateItemHeight(_itemHeight, legendItem, fontLineHeight) {\n let itemHeight = _itemHeight;\n if (typeof legendItem.text !== 'string') {\n itemHeight = calculateLegendItemHeight(legendItem, fontLineHeight);\n }\n return itemHeight;\n}\nfunction calculateLegendItemHeight(legendItem, fontLineHeight) {\n const labelHeight = legendItem.text ? legendItem.text.length : 0;\n return fontLineHeight * labelHeight;\n}\nfunction isListened(type, opts) {\n if ((type === 'mousemove' || type === 'mouseout') && (opts.onHover || opts.onLeave)) {\n return true;\n }\n if (opts.onClick && (type === 'click' || type === 'mouseup')) {\n return true;\n }\n return false;\n}\nvar plugin_legend = {\n id: 'legend',\n _element: Legend,\n start (chart, _args, options) {\n const legend = chart.legend = new Legend({\n ctx: chart.ctx,\n options,\n chart\n });\n layouts.configure(chart, legend, options);\n layouts.addBox(chart, legend);\n },\n stop (chart) {\n layouts.removeBox(chart, chart.legend);\n delete chart.legend;\n },\n beforeUpdate (chart, _args, options) {\n const legend = chart.legend;\n layouts.configure(chart, legend, options);\n legend.options = options;\n },\n afterUpdate (chart) {\n const legend = chart.legend;\n legend.buildLabels();\n legend.adjustHitBoxes();\n },\n afterEvent (chart, args) {\n if (!args.replay) {\n chart.legend.handleEvent(args.event);\n }\n },\n defaults: {\n display: true,\n position: 'top',\n align: 'center',\n fullSize: true,\n reverse: false,\n weight: 1000,\n onClick (e, legendItem, legend) {\n const index = legendItem.datasetIndex;\n const ci = legend.chart;\n if (ci.isDatasetVisible(index)) {\n ci.hide(index);\n legendItem.hidden = true;\n } else {\n ci.show(index);\n legendItem.hidden = false;\n }\n },\n onHover: null,\n onLeave: null,\n labels: {\n color: (ctx)=>ctx.chart.options.color,\n boxWidth: 40,\n padding: 10,\n generateLabels (chart) {\n const datasets = chart.data.datasets;\n const { labels: { usePointStyle , pointStyle , textAlign , color , useBorderRadius , borderRadius } } = chart.legend.options;\n return chart._getSortedDatasetMetas().map((meta)=>{\n const style = meta.controller.getStyle(usePointStyle ? 0 : undefined);\n const borderWidth = toPadding(style.borderWidth);\n return {\n text: datasets[meta.index].label,\n fillStyle: style.backgroundColor,\n fontColor: color,\n hidden: !meta.visible,\n lineCap: style.borderCapStyle,\n lineDash: style.borderDash,\n lineDashOffset: style.borderDashOffset,\n lineJoin: style.borderJoinStyle,\n lineWidth: (borderWidth.width + borderWidth.height) / 4,\n strokeStyle: style.borderColor,\n pointStyle: pointStyle || style.pointStyle,\n rotation: style.rotation,\n textAlign: textAlign || style.textAlign,\n borderRadius: useBorderRadius && (borderRadius || style.borderRadius),\n datasetIndex: meta.index\n };\n }, this);\n }\n },\n title: {\n color: (ctx)=>ctx.chart.options.color,\n display: false,\n position: 'center',\n text: ''\n }\n },\n descriptors: {\n _scriptable: (name)=>!name.startsWith('on'),\n labels: {\n _scriptable: (name)=>![\n 'generateLabels',\n 'filter',\n 'sort'\n ].includes(name)\n }\n }\n};\n\nclass Title extends Element {\n constructor(config){\n super();\n this.chart = config.chart;\n this.options = config.options;\n this.ctx = config.ctx;\n this._padding = undefined;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.width = undefined;\n this.height = undefined;\n this.position = undefined;\n this.weight = undefined;\n this.fullSize = undefined;\n }\n update(maxWidth, maxHeight) {\n const opts = this.options;\n this.left = 0;\n this.top = 0;\n if (!opts.display) {\n this.width = this.height = this.right = this.bottom = 0;\n return;\n }\n this.width = this.right = maxWidth;\n this.height = this.bottom = maxHeight;\n const lineCount = isArray(opts.text) ? opts.text.length : 1;\n this._padding = toPadding(opts.padding);\n const textSize = lineCount * toFont(opts.font).lineHeight + this._padding.height;\n if (this.isHorizontal()) {\n this.height = textSize;\n } else {\n this.width = textSize;\n }\n }\n isHorizontal() {\n const pos = this.options.position;\n return pos === 'top' || pos === 'bottom';\n }\n _drawArgs(offset) {\n const { top , left , bottom , right , options } = this;\n const align = options.align;\n let rotation = 0;\n let maxWidth, titleX, titleY;\n if (this.isHorizontal()) {\n titleX = _alignStartEnd(align, left, right);\n titleY = top + offset;\n maxWidth = right - left;\n } else {\n if (options.position === 'left') {\n titleX = left + offset;\n titleY = _alignStartEnd(align, bottom, top);\n rotation = PI * -0.5;\n } else {\n titleX = right - offset;\n titleY = _alignStartEnd(align, top, bottom);\n rotation = PI * 0.5;\n }\n maxWidth = bottom - top;\n }\n return {\n titleX,\n titleY,\n maxWidth,\n rotation\n };\n }\n draw() {\n const ctx = this.ctx;\n const opts = this.options;\n if (!opts.display) {\n return;\n }\n const fontOpts = toFont(opts.font);\n const lineHeight = fontOpts.lineHeight;\n const offset = lineHeight / 2 + this._padding.top;\n const { titleX , titleY , maxWidth , rotation } = this._drawArgs(offset);\n renderText(ctx, opts.text, 0, 0, fontOpts, {\n color: opts.color,\n maxWidth,\n rotation,\n textAlign: _toLeftRightCenter(opts.align),\n textBaseline: 'middle',\n translation: [\n titleX,\n titleY\n ]\n });\n }\n}\nfunction createTitle(chart, titleOpts) {\n const title = new Title({\n ctx: chart.ctx,\n options: titleOpts,\n chart\n });\n layouts.configure(chart, title, titleOpts);\n layouts.addBox(chart, title);\n chart.titleBlock = title;\n}\nvar plugin_title = {\n id: 'title',\n _element: Title,\n start (chart, _args, options) {\n createTitle(chart, options);\n },\n stop (chart) {\n const titleBlock = chart.titleBlock;\n layouts.removeBox(chart, titleBlock);\n delete chart.titleBlock;\n },\n beforeUpdate (chart, _args, options) {\n const title = chart.titleBlock;\n layouts.configure(chart, title, options);\n title.options = options;\n },\n defaults: {\n align: 'center',\n display: false,\n font: {\n weight: 'bold'\n },\n fullSize: true,\n padding: 10,\n position: 'top',\n text: '',\n weight: 2000\n },\n defaultRoutes: {\n color: 'color'\n },\n descriptors: {\n _scriptable: true,\n _indexable: false\n }\n};\n\nconst map = new WeakMap();\nvar plugin_subtitle = {\n id: 'subtitle',\n start (chart, _args, options) {\n const title = new Title({\n ctx: chart.ctx,\n options,\n chart\n });\n layouts.configure(chart, title, options);\n layouts.addBox(chart, title);\n map.set(chart, title);\n },\n stop (chart) {\n layouts.removeBox(chart, map.get(chart));\n map.delete(chart);\n },\n beforeUpdate (chart, _args, options) {\n const title = map.get(chart);\n layouts.configure(chart, title, options);\n title.options = options;\n },\n defaults: {\n align: 'center',\n display: false,\n font: {\n weight: 'normal'\n },\n fullSize: true,\n padding: 0,\n position: 'top',\n text: '',\n weight: 1500\n },\n defaultRoutes: {\n color: 'color'\n },\n descriptors: {\n _scriptable: true,\n _indexable: false\n }\n};\n\nconst positioners = {\n average (items) {\n if (!items.length) {\n return false;\n }\n let i, len;\n let xSet = new Set();\n let y = 0;\n let count = 0;\n for(i = 0, len = items.length; i < len; ++i){\n const el = items[i].element;\n if (el && el.hasValue()) {\n const pos = el.tooltipPosition();\n xSet.add(pos.x);\n y += pos.y;\n ++count;\n }\n }\n if (count === 0 || xSet.size === 0) {\n return false;\n }\n const xAverage = [\n ...xSet\n ].reduce((a, b)=>a + b) / xSet.size;\n return {\n x: xAverage,\n y: y / count\n };\n },\n nearest (items, eventPosition) {\n if (!items.length) {\n return false;\n }\n let x = eventPosition.x;\n let y = eventPosition.y;\n let minDistance = Number.POSITIVE_INFINITY;\n let i, len, nearestElement;\n for(i = 0, len = items.length; i < len; ++i){\n const el = items[i].element;\n if (el && el.hasValue()) {\n const center = el.getCenterPoint();\n const d = distanceBetweenPoints(eventPosition, center);\n if (d < minDistance) {\n minDistance = d;\n nearestElement = el;\n }\n }\n }\n if (nearestElement) {\n const tp = nearestElement.tooltipPosition();\n x = tp.x;\n y = tp.y;\n }\n return {\n x,\n y\n };\n }\n};\nfunction pushOrConcat(base, toPush) {\n if (toPush) {\n if (isArray(toPush)) {\n Array.prototype.push.apply(base, toPush);\n } else {\n base.push(toPush);\n }\n }\n return base;\n}\n function splitNewlines(str) {\n if ((typeof str === 'string' || str instanceof String) && str.indexOf('\\n') > -1) {\n return str.split('\\n');\n }\n return str;\n}\n function createTooltipItem(chart, item) {\n const { element , datasetIndex , index } = item;\n const controller = chart.getDatasetMeta(datasetIndex).controller;\n const { label , value } = controller.getLabelAndValue(index);\n return {\n chart,\n label,\n parsed: controller.getParsed(index),\n raw: chart.data.datasets[datasetIndex].data[index],\n formattedValue: value,\n dataset: controller.getDataset(),\n dataIndex: index,\n datasetIndex,\n element\n };\n}\n function getTooltipSize(tooltip, options) {\n const ctx = tooltip.chart.ctx;\n const { body , footer , title } = tooltip;\n const { boxWidth , boxHeight } = options;\n const bodyFont = toFont(options.bodyFont);\n const titleFont = toFont(options.titleFont);\n const footerFont = toFont(options.footerFont);\n const titleLineCount = title.length;\n const footerLineCount = footer.length;\n const bodyLineItemCount = body.length;\n const padding = toPadding(options.padding);\n let height = padding.height;\n let width = 0;\n let combinedBodyLength = body.reduce((count, bodyItem)=>count + bodyItem.before.length + bodyItem.lines.length + bodyItem.after.length, 0);\n combinedBodyLength += tooltip.beforeBody.length + tooltip.afterBody.length;\n if (titleLineCount) {\n height += titleLineCount * titleFont.lineHeight + (titleLineCount - 1) * options.titleSpacing + options.titleMarginBottom;\n }\n if (combinedBodyLength) {\n const bodyLineHeight = options.displayColors ? Math.max(boxHeight, bodyFont.lineHeight) : bodyFont.lineHeight;\n height += bodyLineItemCount * bodyLineHeight + (combinedBodyLength - bodyLineItemCount) * bodyFont.lineHeight + (combinedBodyLength - 1) * options.bodySpacing;\n }\n if (footerLineCount) {\n height += options.footerMarginTop + footerLineCount * footerFont.lineHeight + (footerLineCount - 1) * options.footerSpacing;\n }\n let widthPadding = 0;\n const maxLineWidth = function(line) {\n width = Math.max(width, ctx.measureText(line).width + widthPadding);\n };\n ctx.save();\n ctx.font = titleFont.string;\n each(tooltip.title, maxLineWidth);\n ctx.font = bodyFont.string;\n each(tooltip.beforeBody.concat(tooltip.afterBody), maxLineWidth);\n widthPadding = options.displayColors ? boxWidth + 2 + options.boxPadding : 0;\n each(body, (bodyItem)=>{\n each(bodyItem.before, maxLineWidth);\n each(bodyItem.lines, maxLineWidth);\n each(bodyItem.after, maxLineWidth);\n });\n widthPadding = 0;\n ctx.font = footerFont.string;\n each(tooltip.footer, maxLineWidth);\n ctx.restore();\n width += padding.width;\n return {\n width,\n height\n };\n}\nfunction determineYAlign(chart, size) {\n const { y , height } = size;\n if (y < height / 2) {\n return 'top';\n } else if (y > chart.height - height / 2) {\n return 'bottom';\n }\n return 'center';\n}\nfunction doesNotFitWithAlign(xAlign, chart, options, size) {\n const { x , width } = size;\n const caret = options.caretSize + options.caretPadding;\n if (xAlign === 'left' && x + width + caret > chart.width) {\n return true;\n }\n if (xAlign === 'right' && x - width - caret < 0) {\n return true;\n }\n}\nfunction determineXAlign(chart, options, size, yAlign) {\n const { x , width } = size;\n const { width: chartWidth , chartArea: { left , right } } = chart;\n let xAlign = 'center';\n if (yAlign === 'center') {\n xAlign = x <= (left + right) / 2 ? 'left' : 'right';\n } else if (x <= width / 2) {\n xAlign = 'left';\n } else if (x >= chartWidth - width / 2) {\n xAlign = 'right';\n }\n if (doesNotFitWithAlign(xAlign, chart, options, size)) {\n xAlign = 'center';\n }\n return xAlign;\n}\n function determineAlignment(chart, options, size) {\n const yAlign = size.yAlign || options.yAlign || determineYAlign(chart, size);\n return {\n xAlign: size.xAlign || options.xAlign || determineXAlign(chart, options, size, yAlign),\n yAlign\n };\n}\nfunction alignX(size, xAlign) {\n let { x , width } = size;\n if (xAlign === 'right') {\n x -= width;\n } else if (xAlign === 'center') {\n x -= width / 2;\n }\n return x;\n}\nfunction alignY(size, yAlign, paddingAndSize) {\n let { y , height } = size;\n if (yAlign === 'top') {\n y += paddingAndSize;\n } else if (yAlign === 'bottom') {\n y -= height + paddingAndSize;\n } else {\n y -= height / 2;\n }\n return y;\n}\n function getBackgroundPoint(options, size, alignment, chart) {\n const { caretSize , caretPadding , cornerRadius } = options;\n const { xAlign , yAlign } = alignment;\n const paddingAndSize = caretSize + caretPadding;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(cornerRadius);\n let x = alignX(size, xAlign);\n const y = alignY(size, yAlign, paddingAndSize);\n if (yAlign === 'center') {\n if (xAlign === 'left') {\n x += paddingAndSize;\n } else if (xAlign === 'right') {\n x -= paddingAndSize;\n }\n } else if (xAlign === 'left') {\n x -= Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x += Math.max(topRight, bottomRight) + caretSize;\n }\n return {\n x: _limitValue(x, 0, chart.width - size.width),\n y: _limitValue(y, 0, chart.height - size.height)\n };\n}\nfunction getAlignedX(tooltip, align, options) {\n const padding = toPadding(options.padding);\n return align === 'center' ? tooltip.x + tooltip.width / 2 : align === 'right' ? tooltip.x + tooltip.width - padding.right : tooltip.x + padding.left;\n}\n function getBeforeAfterBodyLines(callback) {\n return pushOrConcat([], splitNewlines(callback));\n}\nfunction createTooltipContext(parent, tooltip, tooltipItems) {\n return createContext(parent, {\n tooltip,\n tooltipItems,\n type: 'tooltip'\n });\n}\nfunction overrideCallbacks(callbacks, context) {\n const override = context && context.dataset && context.dataset.tooltip && context.dataset.tooltip.callbacks;\n return override ? callbacks.override(override) : callbacks;\n}\nconst defaultCallbacks = {\n beforeTitle: noop,\n title (tooltipItems) {\n if (tooltipItems.length > 0) {\n const item = tooltipItems[0];\n const labels = item.chart.data.labels;\n const labelCount = labels ? labels.length : 0;\n if (this && this.options && this.options.mode === 'dataset') {\n return item.dataset.label || '';\n } else if (item.label) {\n return item.label;\n } else if (labelCount > 0 && item.dataIndex < labelCount) {\n return labels[item.dataIndex];\n }\n }\n return '';\n },\n afterTitle: noop,\n beforeBody: noop,\n beforeLabel: noop,\n label (tooltipItem) {\n if (this && this.options && this.options.mode === 'dataset') {\n return tooltipItem.label + ': ' + tooltipItem.formattedValue || tooltipItem.formattedValue;\n }\n let label = tooltipItem.dataset.label || '';\n if (label) {\n label += ': ';\n }\n const value = tooltipItem.formattedValue;\n if (!isNullOrUndef(value)) {\n label += value;\n }\n return label;\n },\n labelColor (tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n borderColor: options.borderColor,\n backgroundColor: options.backgroundColor,\n borderWidth: options.borderWidth,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderRadius: 0\n };\n },\n labelTextColor () {\n return this.options.bodyColor;\n },\n labelPointStyle (tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n pointStyle: options.pointStyle,\n rotation: options.rotation\n };\n },\n afterLabel: noop,\n afterBody: noop,\n beforeFooter: noop,\n footer: noop,\n afterFooter: noop\n};\n function invokeCallbackWithFallback(callbacks, name, ctx, arg) {\n const result = callbacks[name].call(ctx, arg);\n if (typeof result === 'undefined') {\n return defaultCallbacks[name].call(ctx, arg);\n }\n return result;\n}\nclass Tooltip extends Element {\n static positioners = positioners;\n constructor(config){\n super();\n this.opacity = 0;\n this._active = [];\n this._eventPosition = undefined;\n this._size = undefined;\n this._cachedAnimations = undefined;\n this._tooltipItems = [];\n this.$animations = undefined;\n this.$context = undefined;\n this.chart = config.chart;\n this.options = config.options;\n this.dataPoints = undefined;\n this.title = undefined;\n this.beforeBody = undefined;\n this.body = undefined;\n this.afterBody = undefined;\n this.footer = undefined;\n this.xAlign = undefined;\n this.yAlign = undefined;\n this.x = undefined;\n this.y = undefined;\n this.height = undefined;\n this.width = undefined;\n this.caretX = undefined;\n this.caretY = undefined;\n this.labelColors = undefined;\n this.labelPointStyles = undefined;\n this.labelTextColors = undefined;\n }\n initialize(options) {\n this.options = options;\n this._cachedAnimations = undefined;\n this.$context = undefined;\n }\n _resolveAnimations() {\n const cached = this._cachedAnimations;\n if (cached) {\n return cached;\n }\n const chart = this.chart;\n const options = this.options.setContext(this.getContext());\n const opts = options.enabled && chart.options.animation && options.animations;\n const animations = new Animations(this.chart, opts);\n if (opts._cacheable) {\n this._cachedAnimations = Object.freeze(animations);\n }\n return animations;\n }\n getContext() {\n return this.$context || (this.$context = createTooltipContext(this.chart.getContext(), this, this._tooltipItems));\n }\n getTitle(context, options) {\n const { callbacks } = options;\n const beforeTitle = invokeCallbackWithFallback(callbacks, 'beforeTitle', this, context);\n const title = invokeCallbackWithFallback(callbacks, 'title', this, context);\n const afterTitle = invokeCallbackWithFallback(callbacks, 'afterTitle', this, context);\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeTitle));\n lines = pushOrConcat(lines, splitNewlines(title));\n lines = pushOrConcat(lines, splitNewlines(afterTitle));\n return lines;\n }\n getBeforeBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(invokeCallbackWithFallback(options.callbacks, 'beforeBody', this, tooltipItems));\n }\n getBody(tooltipItems, options) {\n const { callbacks } = options;\n const bodyItems = [];\n each(tooltipItems, (context)=>{\n const bodyItem = {\n before: [],\n lines: [],\n after: []\n };\n const scoped = overrideCallbacks(callbacks, context);\n pushOrConcat(bodyItem.before, splitNewlines(invokeCallbackWithFallback(scoped, 'beforeLabel', this, context)));\n pushOrConcat(bodyItem.lines, invokeCallbackWithFallback(scoped, 'label', this, context));\n pushOrConcat(bodyItem.after, splitNewlines(invokeCallbackWithFallback(scoped, 'afterLabel', this, context)));\n bodyItems.push(bodyItem);\n });\n return bodyItems;\n }\n getAfterBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(invokeCallbackWithFallback(options.callbacks, 'afterBody', this, tooltipItems));\n }\n getFooter(tooltipItems, options) {\n const { callbacks } = options;\n const beforeFooter = invokeCallbackWithFallback(callbacks, 'beforeFooter', this, tooltipItems);\n const footer = invokeCallbackWithFallback(callbacks, 'footer', this, tooltipItems);\n const afterFooter = invokeCallbackWithFallback(callbacks, 'afterFooter', this, tooltipItems);\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeFooter));\n lines = pushOrConcat(lines, splitNewlines(footer));\n lines = pushOrConcat(lines, splitNewlines(afterFooter));\n return lines;\n }\n _createItems(options) {\n const active = this._active;\n const data = this.chart.data;\n const labelColors = [];\n const labelPointStyles = [];\n const labelTextColors = [];\n let tooltipItems = [];\n let i, len;\n for(i = 0, len = active.length; i < len; ++i){\n tooltipItems.push(createTooltipItem(this.chart, active[i]));\n }\n if (options.filter) {\n tooltipItems = tooltipItems.filter((element, index, array)=>options.filter(element, index, array, data));\n }\n if (options.itemSort) {\n tooltipItems = tooltipItems.sort((a, b)=>options.itemSort(a, b, data));\n }\n each(tooltipItems, (context)=>{\n const scoped = overrideCallbacks(options.callbacks, context);\n labelColors.push(invokeCallbackWithFallback(scoped, 'labelColor', this, context));\n labelPointStyles.push(invokeCallbackWithFallback(scoped, 'labelPointStyle', this, context));\n labelTextColors.push(invokeCallbackWithFallback(scoped, 'labelTextColor', this, context));\n });\n this.labelColors = labelColors;\n this.labelPointStyles = labelPointStyles;\n this.labelTextColors = labelTextColors;\n this.dataPoints = tooltipItems;\n return tooltipItems;\n }\n update(changed, replay) {\n const options = this.options.setContext(this.getContext());\n const active = this._active;\n let properties;\n let tooltipItems = [];\n if (!active.length) {\n if (this.opacity !== 0) {\n properties = {\n opacity: 0\n };\n }\n } else {\n const position = positioners[options.position].call(this, active, this._eventPosition);\n tooltipItems = this._createItems(options);\n this.title = this.getTitle(tooltipItems, options);\n this.beforeBody = this.getBeforeBody(tooltipItems, options);\n this.body = this.getBody(tooltipItems, options);\n this.afterBody = this.getAfterBody(tooltipItems, options);\n this.footer = this.getFooter(tooltipItems, options);\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, size);\n const alignment = determineAlignment(this.chart, options, positionAndSize);\n const backgroundPoint = getBackgroundPoint(options, positionAndSize, alignment, this.chart);\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n properties = {\n opacity: 1,\n x: backgroundPoint.x,\n y: backgroundPoint.y,\n width: size.width,\n height: size.height,\n caretX: position.x,\n caretY: position.y\n };\n }\n this._tooltipItems = tooltipItems;\n this.$context = undefined;\n if (properties) {\n this._resolveAnimations().update(this, properties);\n }\n if (changed && options.external) {\n options.external.call(this, {\n chart: this.chart,\n tooltip: this,\n replay\n });\n }\n }\n drawCaret(tooltipPoint, ctx, size, options) {\n const caretPosition = this.getCaretPosition(tooltipPoint, size, options);\n ctx.lineTo(caretPosition.x1, caretPosition.y1);\n ctx.lineTo(caretPosition.x2, caretPosition.y2);\n ctx.lineTo(caretPosition.x3, caretPosition.y3);\n }\n getCaretPosition(tooltipPoint, size, options) {\n const { xAlign , yAlign } = this;\n const { caretSize , cornerRadius } = options;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(cornerRadius);\n const { x: ptX , y: ptY } = tooltipPoint;\n const { width , height } = size;\n let x1, x2, x3, y1, y2, y3;\n if (yAlign === 'center') {\n y2 = ptY + height / 2;\n if (xAlign === 'left') {\n x1 = ptX;\n x2 = x1 - caretSize;\n y1 = y2 + caretSize;\n y3 = y2 - caretSize;\n } else {\n x1 = ptX + width;\n x2 = x1 + caretSize;\n y1 = y2 - caretSize;\n y3 = y2 + caretSize;\n }\n x3 = x1;\n } else {\n if (xAlign === 'left') {\n x2 = ptX + Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x2 = ptX + width - Math.max(topRight, bottomRight) - caretSize;\n } else {\n x2 = this.caretX;\n }\n if (yAlign === 'top') {\n y1 = ptY;\n y2 = y1 - caretSize;\n x1 = x2 - caretSize;\n x3 = x2 + caretSize;\n } else {\n y1 = ptY + height;\n y2 = y1 + caretSize;\n x1 = x2 + caretSize;\n x3 = x2 - caretSize;\n }\n y3 = y1;\n }\n return {\n x1,\n x2,\n x3,\n y1,\n y2,\n y3\n };\n }\n drawTitle(pt, ctx, options) {\n const title = this.title;\n const length = title.length;\n let titleFont, titleSpacing, i;\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n pt.x = getAlignedX(this, options.titleAlign, options);\n ctx.textAlign = rtlHelper.textAlign(options.titleAlign);\n ctx.textBaseline = 'middle';\n titleFont = toFont(options.titleFont);\n titleSpacing = options.titleSpacing;\n ctx.fillStyle = options.titleColor;\n ctx.font = titleFont.string;\n for(i = 0; i < length; ++i){\n ctx.fillText(title[i], rtlHelper.x(pt.x), pt.y + titleFont.lineHeight / 2);\n pt.y += titleFont.lineHeight + titleSpacing;\n if (i + 1 === length) {\n pt.y += options.titleMarginBottom - titleSpacing;\n }\n }\n }\n }\n _drawColorBox(ctx, pt, i, rtlHelper, options) {\n const labelColor = this.labelColors[i];\n const labelPointStyle = this.labelPointStyles[i];\n const { boxHeight , boxWidth } = options;\n const bodyFont = toFont(options.bodyFont);\n const colorX = getAlignedX(this, 'left', options);\n const rtlColorX = rtlHelper.x(colorX);\n const yOffSet = boxHeight < bodyFont.lineHeight ? (bodyFont.lineHeight - boxHeight) / 2 : 0;\n const colorY = pt.y + yOffSet;\n if (options.usePointStyle) {\n const drawOptions = {\n radius: Math.min(boxWidth, boxHeight) / 2,\n pointStyle: labelPointStyle.pointStyle,\n rotation: labelPointStyle.rotation,\n borderWidth: 1\n };\n const centerX = rtlHelper.leftForLtr(rtlColorX, boxWidth) + boxWidth / 2;\n const centerY = colorY + boxHeight / 2;\n ctx.strokeStyle = options.multiKeyBackground;\n ctx.fillStyle = options.multiKeyBackground;\n drawPoint(ctx, drawOptions, centerX, centerY);\n ctx.strokeStyle = labelColor.borderColor;\n ctx.fillStyle = labelColor.backgroundColor;\n drawPoint(ctx, drawOptions, centerX, centerY);\n } else {\n ctx.lineWidth = isObject(labelColor.borderWidth) ? Math.max(...Object.values(labelColor.borderWidth)) : labelColor.borderWidth || 1;\n ctx.strokeStyle = labelColor.borderColor;\n ctx.setLineDash(labelColor.borderDash || []);\n ctx.lineDashOffset = labelColor.borderDashOffset || 0;\n const outerX = rtlHelper.leftForLtr(rtlColorX, boxWidth);\n const innerX = rtlHelper.leftForLtr(rtlHelper.xPlus(rtlColorX, 1), boxWidth - 2);\n const borderRadius = toTRBLCorners(labelColor.borderRadius);\n if (Object.values(borderRadius).some((v)=>v !== 0)) {\n ctx.beginPath();\n ctx.fillStyle = options.multiKeyBackground;\n addRoundedRectPath(ctx, {\n x: outerX,\n y: colorY,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius\n });\n ctx.fill();\n ctx.stroke();\n ctx.fillStyle = labelColor.backgroundColor;\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: innerX,\n y: colorY + 1,\n w: boxWidth - 2,\n h: boxHeight - 2,\n radius: borderRadius\n });\n ctx.fill();\n } else {\n ctx.fillStyle = options.multiKeyBackground;\n ctx.fillRect(outerX, colorY, boxWidth, boxHeight);\n ctx.strokeRect(outerX, colorY, boxWidth, boxHeight);\n ctx.fillStyle = labelColor.backgroundColor;\n ctx.fillRect(innerX, colorY + 1, boxWidth - 2, boxHeight - 2);\n }\n }\n ctx.fillStyle = this.labelTextColors[i];\n }\n drawBody(pt, ctx, options) {\n const { body } = this;\n const { bodySpacing , bodyAlign , displayColors , boxHeight , boxWidth , boxPadding } = options;\n const bodyFont = toFont(options.bodyFont);\n let bodyLineHeight = bodyFont.lineHeight;\n let xLinePadding = 0;\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n const fillLineOfText = function(line) {\n ctx.fillText(line, rtlHelper.x(pt.x + xLinePadding), pt.y + bodyLineHeight / 2);\n pt.y += bodyLineHeight + bodySpacing;\n };\n const bodyAlignForCalculation = rtlHelper.textAlign(bodyAlign);\n let bodyItem, textColor, lines, i, j, ilen, jlen;\n ctx.textAlign = bodyAlign;\n ctx.textBaseline = 'middle';\n ctx.font = bodyFont.string;\n pt.x = getAlignedX(this, bodyAlignForCalculation, options);\n ctx.fillStyle = options.bodyColor;\n each(this.beforeBody, fillLineOfText);\n xLinePadding = displayColors && bodyAlignForCalculation !== 'right' ? bodyAlign === 'center' ? boxWidth / 2 + boxPadding : boxWidth + 2 + boxPadding : 0;\n for(i = 0, ilen = body.length; i < ilen; ++i){\n bodyItem = body[i];\n textColor = this.labelTextColors[i];\n ctx.fillStyle = textColor;\n each(bodyItem.before, fillLineOfText);\n lines = bodyItem.lines;\n if (displayColors && lines.length) {\n this._drawColorBox(ctx, pt, i, rtlHelper, options);\n bodyLineHeight = Math.max(bodyFont.lineHeight, boxHeight);\n }\n for(j = 0, jlen = lines.length; j < jlen; ++j){\n fillLineOfText(lines[j]);\n bodyLineHeight = bodyFont.lineHeight;\n }\n each(bodyItem.after, fillLineOfText);\n }\n xLinePadding = 0;\n bodyLineHeight = bodyFont.lineHeight;\n each(this.afterBody, fillLineOfText);\n pt.y -= bodySpacing;\n }\n drawFooter(pt, ctx, options) {\n const footer = this.footer;\n const length = footer.length;\n let footerFont, i;\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n pt.x = getAlignedX(this, options.footerAlign, options);\n pt.y += options.footerMarginTop;\n ctx.textAlign = rtlHelper.textAlign(options.footerAlign);\n ctx.textBaseline = 'middle';\n footerFont = toFont(options.footerFont);\n ctx.fillStyle = options.footerColor;\n ctx.font = footerFont.string;\n for(i = 0; i < length; ++i){\n ctx.fillText(footer[i], rtlHelper.x(pt.x), pt.y + footerFont.lineHeight / 2);\n pt.y += footerFont.lineHeight + options.footerSpacing;\n }\n }\n }\n drawBackground(pt, ctx, tooltipSize, options) {\n const { xAlign , yAlign } = this;\n const { x , y } = pt;\n const { width , height } = tooltipSize;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(options.cornerRadius);\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n ctx.beginPath();\n ctx.moveTo(x + topLeft, y);\n if (yAlign === 'top') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width - topRight, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + topRight);\n if (yAlign === 'center' && xAlign === 'right') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width, y + height - bottomRight);\n ctx.quadraticCurveTo(x + width, y + height, x + width - bottomRight, y + height);\n if (yAlign === 'bottom') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + bottomLeft, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - bottomLeft);\n if (yAlign === 'center' && xAlign === 'left') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x, y + topLeft);\n ctx.quadraticCurveTo(x, y, x + topLeft, y);\n ctx.closePath();\n ctx.fill();\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n }\n _updateAnimationTarget(options) {\n const chart = this.chart;\n const anims = this.$animations;\n const animX = anims && anims.x;\n const animY = anims && anims.y;\n if (animX || animY) {\n const position = positioners[options.position].call(this, this._active, this._eventPosition);\n if (!position) {\n return;\n }\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, this._size);\n const alignment = determineAlignment(chart, options, positionAndSize);\n const point = getBackgroundPoint(options, positionAndSize, alignment, chart);\n if (animX._to !== point.x || animY._to !== point.y) {\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n this.width = size.width;\n this.height = size.height;\n this.caretX = position.x;\n this.caretY = position.y;\n this._resolveAnimations().update(this, point);\n }\n }\n }\n _willRender() {\n return !!this.opacity;\n }\n draw(ctx) {\n const options = this.options.setContext(this.getContext());\n let opacity = this.opacity;\n if (!opacity) {\n return;\n }\n this._updateAnimationTarget(options);\n const tooltipSize = {\n width: this.width,\n height: this.height\n };\n const pt = {\n x: this.x,\n y: this.y\n };\n opacity = Math.abs(opacity) < 1e-3 ? 0 : opacity;\n const padding = toPadding(options.padding);\n const hasTooltipContent = this.title.length || this.beforeBody.length || this.body.length || this.afterBody.length || this.footer.length;\n if (options.enabled && hasTooltipContent) {\n ctx.save();\n ctx.globalAlpha = opacity;\n this.drawBackground(pt, ctx, tooltipSize, options);\n overrideTextDirection(ctx, options.textDirection);\n pt.y += padding.top;\n this.drawTitle(pt, ctx, options);\n this.drawBody(pt, ctx, options);\n this.drawFooter(pt, ctx, options);\n restoreTextDirection(ctx, options.textDirection);\n ctx.restore();\n }\n }\n getActiveElements() {\n return this._active || [];\n }\n setActiveElements(activeElements, eventPosition) {\n const lastActive = this._active;\n const active = activeElements.map(({ datasetIndex , index })=>{\n const meta = this.chart.getDatasetMeta(datasetIndex);\n if (!meta) {\n throw new Error('Cannot find a dataset at index ' + datasetIndex);\n }\n return {\n datasetIndex,\n element: meta.data[index],\n index\n };\n });\n const changed = !_elementsEqual(lastActive, active);\n const positionChanged = this._positionChanged(active, eventPosition);\n if (changed || positionChanged) {\n this._active = active;\n this._eventPosition = eventPosition;\n this._ignoreReplayEvents = true;\n this.update(true);\n }\n }\n handleEvent(e, replay, inChartArea = true) {\n if (replay && this._ignoreReplayEvents) {\n return false;\n }\n this._ignoreReplayEvents = false;\n const options = this.options;\n const lastActive = this._active || [];\n const active = this._getActiveElements(e, lastActive, replay, inChartArea);\n const positionChanged = this._positionChanged(active, e);\n const changed = replay || !_elementsEqual(active, lastActive) || positionChanged;\n if (changed) {\n this._active = active;\n if (options.enabled || options.external) {\n this._eventPosition = {\n x: e.x,\n y: e.y\n };\n this.update(true, replay);\n }\n }\n return changed;\n }\n _getActiveElements(e, lastActive, replay, inChartArea) {\n const options = this.options;\n if (e.type === 'mouseout') {\n return [];\n }\n if (!inChartArea) {\n return lastActive.filter((i)=>this.chart.data.datasets[i.datasetIndex] && this.chart.getDatasetMeta(i.datasetIndex).controller.getParsed(i.index) !== undefined);\n }\n const active = this.chart.getElementsAtEventForMode(e, options.mode, options, replay);\n if (options.reverse) {\n active.reverse();\n }\n return active;\n }\n _positionChanged(active, e) {\n const { caretX , caretY , options } = this;\n const position = positioners[options.position].call(this, active, e);\n return position !== false && (caretX !== position.x || caretY !== position.y);\n }\n}\nvar plugin_tooltip = {\n id: 'tooltip',\n _element: Tooltip,\n positioners,\n afterInit (chart, _args, options) {\n if (options) {\n chart.tooltip = new Tooltip({\n chart,\n options\n });\n }\n },\n beforeUpdate (chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n reset (chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n afterDraw (chart) {\n const tooltip = chart.tooltip;\n if (tooltip && tooltip._willRender()) {\n const args = {\n tooltip\n };\n if (chart.notifyPlugins('beforeTooltipDraw', {\n ...args,\n cancelable: true\n }) === false) {\n return;\n }\n tooltip.draw(chart.ctx);\n chart.notifyPlugins('afterTooltipDraw', args);\n }\n },\n afterEvent (chart, args) {\n if (chart.tooltip) {\n const useFinalPosition = args.replay;\n if (chart.tooltip.handleEvent(args.event, useFinalPosition, args.inChartArea)) {\n args.changed = true;\n }\n }\n },\n defaults: {\n enabled: true,\n external: null,\n position: 'average',\n backgroundColor: 'rgba(0,0,0,0.8)',\n titleColor: '#fff',\n titleFont: {\n weight: 'bold'\n },\n titleSpacing: 2,\n titleMarginBottom: 6,\n titleAlign: 'left',\n bodyColor: '#fff',\n bodySpacing: 2,\n bodyFont: {},\n bodyAlign: 'left',\n footerColor: '#fff',\n footerSpacing: 2,\n footerMarginTop: 6,\n footerFont: {\n weight: 'bold'\n },\n footerAlign: 'left',\n padding: 6,\n caretPadding: 2,\n caretSize: 5,\n cornerRadius: 6,\n boxHeight: (ctx, opts)=>opts.bodyFont.size,\n boxWidth: (ctx, opts)=>opts.bodyFont.size,\n multiKeyBackground: '#fff',\n displayColors: true,\n boxPadding: 0,\n borderColor: 'rgba(0,0,0,0)',\n borderWidth: 0,\n animation: {\n duration: 400,\n easing: 'easeOutQuart'\n },\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'width',\n 'height',\n 'caretX',\n 'caretY'\n ]\n },\n opacity: {\n easing: 'linear',\n duration: 200\n }\n },\n callbacks: defaultCallbacks\n },\n defaultRoutes: {\n bodyFont: 'font',\n footerFont: 'font',\n titleFont: 'font'\n },\n descriptors: {\n _scriptable: (name)=>name !== 'filter' && name !== 'itemSort' && name !== 'external',\n _indexable: false,\n callbacks: {\n _scriptable: false,\n _indexable: false\n },\n animation: {\n _fallback: false\n },\n animations: {\n _fallback: 'animation'\n }\n },\n additionalOptionScopes: [\n 'interaction'\n ]\n};\n\nvar plugins = /*#__PURE__*/Object.freeze({\n__proto__: null,\nColors: plugin_colors,\nDecimation: plugin_decimation,\nFiller: index,\nLegend: plugin_legend,\nSubTitle: plugin_subtitle,\nTitle: plugin_title,\nTooltip: plugin_tooltip\n});\n\nconst addIfString = (labels, raw, index, addedLabels)=>{\n if (typeof raw === 'string') {\n index = labels.push(raw) - 1;\n addedLabels.unshift({\n index,\n label: raw\n });\n } else if (isNaN(raw)) {\n index = null;\n }\n return index;\n};\nfunction findOrAddLabel(labels, raw, index, addedLabels) {\n const first = labels.indexOf(raw);\n if (first === -1) {\n return addIfString(labels, raw, index, addedLabels);\n }\n const last = labels.lastIndexOf(raw);\n return first !== last ? index : first;\n}\nconst validIndex = (index, max)=>index === null ? null : _limitValue(Math.round(index), 0, max);\nfunction _getLabelForValue(value) {\n const labels = this.getLabels();\n if (value >= 0 && value < labels.length) {\n return labels[value];\n }\n return value;\n}\nclass CategoryScale extends Scale {\n static id = 'category';\n static defaults = {\n ticks: {\n callback: _getLabelForValue\n }\n };\n constructor(cfg){\n super(cfg);\n this._startValue = undefined;\n this._valueRange = 0;\n this._addedLabels = [];\n }\n init(scaleOptions) {\n const added = this._addedLabels;\n if (added.length) {\n const labels = this.getLabels();\n for (const { index , label } of added){\n if (labels[index] === label) {\n labels.splice(index, 1);\n }\n }\n this._addedLabels = [];\n }\n super.init(scaleOptions);\n }\n parse(raw, index) {\n if (isNullOrUndef(raw)) {\n return null;\n }\n const labels = this.getLabels();\n index = isFinite(index) && labels[index] === raw ? index : findOrAddLabel(labels, raw, valueOrDefault(index, raw), this._addedLabels);\n return validIndex(index, labels.length - 1);\n }\n determineDataLimits() {\n const { minDefined , maxDefined } = this.getUserBounds();\n let { min , max } = this.getMinMax(true);\n if (this.options.bounds === 'ticks') {\n if (!minDefined) {\n min = 0;\n }\n if (!maxDefined) {\n max = this.getLabels().length - 1;\n }\n }\n this.min = min;\n this.max = max;\n }\n buildTicks() {\n const min = this.min;\n const max = this.max;\n const offset = this.options.offset;\n const ticks = [];\n let labels = this.getLabels();\n labels = min === 0 && max === labels.length - 1 ? labels : labels.slice(min, max + 1);\n this._valueRange = Math.max(labels.length - (offset ? 0 : 1), 1);\n this._startValue = this.min - (offset ? 0.5 : 0);\n for(let value = min; value <= max; value++){\n ticks.push({\n value\n });\n }\n return ticks;\n }\n getLabelForValue(value) {\n return _getLabelForValue.call(this, value);\n }\n configure() {\n super.configure();\n if (!this.isHorizontal()) {\n this._reversePixels = !this._reversePixels;\n }\n }\n getPixelForValue(value) {\n if (typeof value !== 'number') {\n value = this.parse(value);\n }\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n getValueForPixel(pixel) {\n return Math.round(this._startValue + this.getDecimalForPixel(pixel) * this._valueRange);\n }\n getBasePixel() {\n return this.bottom;\n }\n}\n\nfunction generateTicks$1(generationOptions, dataRange) {\n const ticks = [];\n const MIN_SPACING = 1e-14;\n const { bounds , step , min , max , precision , count , maxTicks , maxDigits , includeBounds } = generationOptions;\n const unit = step || 1;\n const maxSpaces = maxTicks - 1;\n const { min: rmin , max: rmax } = dataRange;\n const minDefined = !isNullOrUndef(min);\n const maxDefined = !isNullOrUndef(max);\n const countDefined = !isNullOrUndef(count);\n const minSpacing = (rmax - rmin) / (maxDigits + 1);\n let spacing = niceNum((rmax - rmin) / maxSpaces / unit) * unit;\n let factor, niceMin, niceMax, numSpaces;\n if (spacing < MIN_SPACING && !minDefined && !maxDefined) {\n return [\n {\n value: rmin\n },\n {\n value: rmax\n }\n ];\n }\n numSpaces = Math.ceil(rmax / spacing) - Math.floor(rmin / spacing);\n if (numSpaces > maxSpaces) {\n spacing = niceNum(numSpaces * spacing / maxSpaces / unit) * unit;\n }\n if (!isNullOrUndef(precision)) {\n factor = Math.pow(10, precision);\n spacing = Math.ceil(spacing * factor) / factor;\n }\n if (bounds === 'ticks') {\n niceMin = Math.floor(rmin / spacing) * spacing;\n niceMax = Math.ceil(rmax / spacing) * spacing;\n } else {\n niceMin = rmin;\n niceMax = rmax;\n }\n if (minDefined && maxDefined && step && almostWhole((max - min) / step, spacing / 1000)) {\n numSpaces = Math.round(Math.min((max - min) / spacing, maxTicks));\n spacing = (max - min) / numSpaces;\n niceMin = min;\n niceMax = max;\n } else if (countDefined) {\n niceMin = minDefined ? min : niceMin;\n niceMax = maxDefined ? max : niceMax;\n numSpaces = count - 1;\n spacing = (niceMax - niceMin) / numSpaces;\n } else {\n numSpaces = (niceMax - niceMin) / spacing;\n if (almostEquals(numSpaces, Math.round(numSpaces), spacing / 1000)) {\n numSpaces = Math.round(numSpaces);\n } else {\n numSpaces = Math.ceil(numSpaces);\n }\n }\n const decimalPlaces = Math.max(_decimalPlaces(spacing), _decimalPlaces(niceMin));\n factor = Math.pow(10, isNullOrUndef(precision) ? decimalPlaces : precision);\n niceMin = Math.round(niceMin * factor) / factor;\n niceMax = Math.round(niceMax * factor) / factor;\n let j = 0;\n if (minDefined) {\n if (includeBounds && niceMin !== min) {\n ticks.push({\n value: min\n });\n if (niceMin < min) {\n j++;\n }\n if (almostEquals(Math.round((niceMin + j * spacing) * factor) / factor, min, relativeLabelSize(min, minSpacing, generationOptions))) {\n j++;\n }\n } else if (niceMin < min) {\n j++;\n }\n }\n for(; j < numSpaces; ++j){\n const tickValue = Math.round((niceMin + j * spacing) * factor) / factor;\n if (maxDefined && tickValue > max) {\n break;\n }\n ticks.push({\n value: tickValue\n });\n }\n if (maxDefined && includeBounds && niceMax !== max) {\n if (ticks.length && almostEquals(ticks[ticks.length - 1].value, max, relativeLabelSize(max, minSpacing, generationOptions))) {\n ticks[ticks.length - 1].value = max;\n } else {\n ticks.push({\n value: max\n });\n }\n } else if (!maxDefined || niceMax === max) {\n ticks.push({\n value: niceMax\n });\n }\n return ticks;\n}\nfunction relativeLabelSize(value, minSpacing, { horizontal , minRotation }) {\n const rad = toRadians(minRotation);\n const ratio = (horizontal ? Math.sin(rad) : Math.cos(rad)) || 0.001;\n const length = 0.75 * minSpacing * ('' + value).length;\n return Math.min(minSpacing / ratio, length);\n}\nclass LinearScaleBase extends Scale {\n constructor(cfg){\n super(cfg);\n this.start = undefined;\n this.end = undefined;\n this._startValue = undefined;\n this._endValue = undefined;\n this._valueRange = 0;\n }\n parse(raw, index) {\n if (isNullOrUndef(raw)) {\n return null;\n }\n if ((typeof raw === 'number' || raw instanceof Number) && !isFinite(+raw)) {\n return null;\n }\n return +raw;\n }\n handleTickRangeOptions() {\n const { beginAtZero } = this.options;\n const { minDefined , maxDefined } = this.getUserBounds();\n let { min , max } = this;\n const setMin = (v)=>min = minDefined ? min : v;\n const setMax = (v)=>max = maxDefined ? max : v;\n if (beginAtZero) {\n const minSign = sign(min);\n const maxSign = sign(max);\n if (minSign < 0 && maxSign < 0) {\n setMax(0);\n } else if (minSign > 0 && maxSign > 0) {\n setMin(0);\n }\n }\n if (min === max) {\n let offset = max === 0 ? 1 : Math.abs(max * 0.05);\n setMax(max + offset);\n if (!beginAtZero) {\n setMin(min - offset);\n }\n }\n this.min = min;\n this.max = max;\n }\n getTickLimit() {\n const tickOpts = this.options.ticks;\n let { maxTicksLimit , stepSize } = tickOpts;\n let maxTicks;\n if (stepSize) {\n maxTicks = Math.ceil(this.max / stepSize) - Math.floor(this.min / stepSize) + 1;\n if (maxTicks > 1000) {\n console.warn(`scales.${this.id}.ticks.stepSize: ${stepSize} would result generating up to ${maxTicks} ticks. Limiting to 1000.`);\n maxTicks = 1000;\n }\n } else {\n maxTicks = this.computeTickLimit();\n maxTicksLimit = maxTicksLimit || 11;\n }\n if (maxTicksLimit) {\n maxTicks = Math.min(maxTicksLimit, maxTicks);\n }\n return maxTicks;\n }\n computeTickLimit() {\n return Number.POSITIVE_INFINITY;\n }\n buildTicks() {\n const opts = this.options;\n const tickOpts = opts.ticks;\n let maxTicks = this.getTickLimit();\n maxTicks = Math.max(2, maxTicks);\n const numericGeneratorOptions = {\n maxTicks,\n bounds: opts.bounds,\n min: opts.min,\n max: opts.max,\n precision: tickOpts.precision,\n step: tickOpts.stepSize,\n count: tickOpts.count,\n maxDigits: this._maxDigits(),\n horizontal: this.isHorizontal(),\n minRotation: tickOpts.minRotation || 0,\n includeBounds: tickOpts.includeBounds !== false\n };\n const dataRange = this._range || this;\n const ticks = generateTicks$1(numericGeneratorOptions, dataRange);\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n if (opts.reverse) {\n ticks.reverse();\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n return ticks;\n }\n configure() {\n const ticks = this.ticks;\n let start = this.min;\n let end = this.max;\n super.configure();\n if (this.options.offset && ticks.length) {\n const offset = (end - start) / Math.max(ticks.length - 1, 1) / 2;\n start -= offset;\n end += offset;\n }\n this._startValue = start;\n this._endValue = end;\n this._valueRange = end - start;\n }\n getLabelForValue(value) {\n return formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n}\n\nclass LinearScale extends LinearScaleBase {\n static id = 'linear';\n static defaults = {\n ticks: {\n callback: Ticks.formatters.numeric\n }\n };\n determineDataLimits() {\n const { min , max } = this.getMinMax(true);\n this.min = isNumberFinite(min) ? min : 0;\n this.max = isNumberFinite(max) ? max : 1;\n this.handleTickRangeOptions();\n }\n computeTickLimit() {\n const horizontal = this.isHorizontal();\n const length = horizontal ? this.width : this.height;\n const minRotation = toRadians(this.options.ticks.minRotation);\n const ratio = (horizontal ? Math.sin(minRotation) : Math.cos(minRotation)) || 0.001;\n const tickFont = this._resolveTickFontOptions(0);\n return Math.ceil(length / Math.min(40, tickFont.lineHeight / ratio));\n }\n getPixelForValue(value) {\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n getValueForPixel(pixel) {\n return this._startValue + this.getDecimalForPixel(pixel) * this._valueRange;\n }\n}\n\nconst log10Floor = (v)=>Math.floor(log10(v));\nconst changeExponent = (v, m)=>Math.pow(10, log10Floor(v) + m);\nfunction isMajor(tickVal) {\n const remain = tickVal / Math.pow(10, log10Floor(tickVal));\n return remain === 1;\n}\nfunction steps(min, max, rangeExp) {\n const rangeStep = Math.pow(10, rangeExp);\n const start = Math.floor(min / rangeStep);\n const end = Math.ceil(max / rangeStep);\n return end - start;\n}\nfunction startExp(min, max) {\n const range = max - min;\n let rangeExp = log10Floor(range);\n while(steps(min, max, rangeExp) > 10){\n rangeExp++;\n }\n while(steps(min, max, rangeExp) < 10){\n rangeExp--;\n }\n return Math.min(rangeExp, log10Floor(min));\n}\n function generateTicks(generationOptions, { min , max }) {\n min = finiteOrDefault(generationOptions.min, min);\n const ticks = [];\n const minExp = log10Floor(min);\n let exp = startExp(min, max);\n let precision = exp < 0 ? Math.pow(10, Math.abs(exp)) : 1;\n const stepSize = Math.pow(10, exp);\n const base = minExp > exp ? Math.pow(10, minExp) : 0;\n const start = Math.round((min - base) * precision) / precision;\n const offset = Math.floor((min - base) / stepSize / 10) * stepSize * 10;\n let significand = Math.floor((start - offset) / Math.pow(10, exp));\n let value = finiteOrDefault(generationOptions.min, Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision);\n while(value < max){\n ticks.push({\n value,\n major: isMajor(value),\n significand\n });\n if (significand >= 10) {\n significand = significand < 15 ? 15 : 20;\n } else {\n significand++;\n }\n if (significand >= 20) {\n exp++;\n significand = 2;\n precision = exp >= 0 ? 1 : precision;\n }\n value = Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision;\n }\n const lastTick = finiteOrDefault(generationOptions.max, value);\n ticks.push({\n value: lastTick,\n major: isMajor(lastTick),\n significand\n });\n return ticks;\n}\nclass LogarithmicScale extends Scale {\n static id = 'logarithmic';\n static defaults = {\n ticks: {\n callback: Ticks.formatters.logarithmic,\n major: {\n enabled: true\n }\n }\n };\n constructor(cfg){\n super(cfg);\n this.start = undefined;\n this.end = undefined;\n this._startValue = undefined;\n this._valueRange = 0;\n }\n parse(raw, index) {\n const value = LinearScaleBase.prototype.parse.apply(this, [\n raw,\n index\n ]);\n if (value === 0) {\n this._zero = true;\n return undefined;\n }\n return isNumberFinite(value) && value > 0 ? value : null;\n }\n determineDataLimits() {\n const { min , max } = this.getMinMax(true);\n this.min = isNumberFinite(min) ? Math.max(0, min) : null;\n this.max = isNumberFinite(max) ? Math.max(0, max) : null;\n if (this.options.beginAtZero) {\n this._zero = true;\n }\n if (this._zero && this.min !== this._suggestedMin && !isNumberFinite(this._userMin)) {\n this.min = min === changeExponent(this.min, 0) ? changeExponent(this.min, -1) : changeExponent(this.min, 0);\n }\n this.handleTickRangeOptions();\n }\n handleTickRangeOptions() {\n const { minDefined , maxDefined } = this.getUserBounds();\n let min = this.min;\n let max = this.max;\n const setMin = (v)=>min = minDefined ? min : v;\n const setMax = (v)=>max = maxDefined ? max : v;\n if (min === max) {\n if (min <= 0) {\n setMin(1);\n setMax(10);\n } else {\n setMin(changeExponent(min, -1));\n setMax(changeExponent(max, +1));\n }\n }\n if (min <= 0) {\n setMin(changeExponent(max, -1));\n }\n if (max <= 0) {\n setMax(changeExponent(min, +1));\n }\n this.min = min;\n this.max = max;\n }\n buildTicks() {\n const opts = this.options;\n const generationOptions = {\n min: this._userMin,\n max: this._userMax\n };\n const ticks = generateTicks(generationOptions, this);\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n if (opts.reverse) {\n ticks.reverse();\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n return ticks;\n }\n getLabelForValue(value) {\n return value === undefined ? '0' : formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n configure() {\n const start = this.min;\n super.configure();\n this._startValue = log10(start);\n this._valueRange = log10(this.max) - log10(start);\n }\n getPixelForValue(value) {\n if (value === undefined || value === 0) {\n value = this.min;\n }\n if (value === null || isNaN(value)) {\n return NaN;\n }\n return this.getPixelForDecimal(value === this.min ? 0 : (log10(value) - this._startValue) / this._valueRange);\n }\n getValueForPixel(pixel) {\n const decimal = this.getDecimalForPixel(pixel);\n return Math.pow(10, this._startValue + decimal * this._valueRange);\n }\n}\n\nfunction getTickBackdropHeight(opts) {\n const tickOpts = opts.ticks;\n if (tickOpts.display && opts.display) {\n const padding = toPadding(tickOpts.backdropPadding);\n return valueOrDefault(tickOpts.font && tickOpts.font.size, defaults.font.size) + padding.height;\n }\n return 0;\n}\nfunction measureLabelSize(ctx, font, label) {\n label = isArray(label) ? label : [\n label\n ];\n return {\n w: _longestText(ctx, font.string, label),\n h: label.length * font.lineHeight\n };\n}\nfunction determineLimits(angle, pos, size, min, max) {\n if (angle === min || angle === max) {\n return {\n start: pos - size / 2,\n end: pos + size / 2\n };\n } else if (angle < min || angle > max) {\n return {\n start: pos - size,\n end: pos\n };\n }\n return {\n start: pos,\n end: pos + size\n };\n}\n function fitWithPointLabels(scale) {\n const orig = {\n l: scale.left + scale._padding.left,\n r: scale.right - scale._padding.right,\n t: scale.top + scale._padding.top,\n b: scale.bottom - scale._padding.bottom\n };\n const limits = Object.assign({}, orig);\n const labelSizes = [];\n const padding = [];\n const valueCount = scale._pointLabels.length;\n const pointLabelOpts = scale.options.pointLabels;\n const additionalAngle = pointLabelOpts.centerPointLabels ? PI / valueCount : 0;\n for(let i = 0; i < valueCount; i++){\n const opts = pointLabelOpts.setContext(scale.getPointLabelContext(i));\n padding[i] = opts.padding;\n const pointPosition = scale.getPointPosition(i, scale.drawingArea + padding[i], additionalAngle);\n const plFont = toFont(opts.font);\n const textSize = measureLabelSize(scale.ctx, plFont, scale._pointLabels[i]);\n labelSizes[i] = textSize;\n const angleRadians = _normalizeAngle(scale.getIndexAngle(i) + additionalAngle);\n const angle = Math.round(toDegrees(angleRadians));\n const hLimits = determineLimits(angle, pointPosition.x, textSize.w, 0, 180);\n const vLimits = determineLimits(angle, pointPosition.y, textSize.h, 90, 270);\n updateLimits(limits, orig, angleRadians, hLimits, vLimits);\n }\n scale.setCenterPoint(orig.l - limits.l, limits.r - orig.r, orig.t - limits.t, limits.b - orig.b);\n scale._pointLabelItems = buildPointLabelItems(scale, labelSizes, padding);\n}\nfunction updateLimits(limits, orig, angle, hLimits, vLimits) {\n const sin = Math.abs(Math.sin(angle));\n const cos = Math.abs(Math.cos(angle));\n let x = 0;\n let y = 0;\n if (hLimits.start < orig.l) {\n x = (orig.l - hLimits.start) / sin;\n limits.l = Math.min(limits.l, orig.l - x);\n } else if (hLimits.end > orig.r) {\n x = (hLimits.end - orig.r) / sin;\n limits.r = Math.max(limits.r, orig.r + x);\n }\n if (vLimits.start < orig.t) {\n y = (orig.t - vLimits.start) / cos;\n limits.t = Math.min(limits.t, orig.t - y);\n } else if (vLimits.end > orig.b) {\n y = (vLimits.end - orig.b) / cos;\n limits.b = Math.max(limits.b, orig.b + y);\n }\n}\nfunction createPointLabelItem(scale, index, itemOpts) {\n const outerDistance = scale.drawingArea;\n const { extra , additionalAngle , padding , size } = itemOpts;\n const pointLabelPosition = scale.getPointPosition(index, outerDistance + extra + padding, additionalAngle);\n const angle = Math.round(toDegrees(_normalizeAngle(pointLabelPosition.angle + HALF_PI)));\n const y = yForAngle(pointLabelPosition.y, size.h, angle);\n const textAlign = getTextAlignForAngle(angle);\n const left = leftForTextAlign(pointLabelPosition.x, size.w, textAlign);\n return {\n visible: true,\n x: pointLabelPosition.x,\n y,\n textAlign,\n left,\n top: y,\n right: left + size.w,\n bottom: y + size.h\n };\n}\nfunction isNotOverlapped(item, area) {\n if (!area) {\n return true;\n }\n const { left , top , right , bottom } = item;\n const apexesInArea = _isPointInArea({\n x: left,\n y: top\n }, area) || _isPointInArea({\n x: left,\n y: bottom\n }, area) || _isPointInArea({\n x: right,\n y: top\n }, area) || _isPointInArea({\n x: right,\n y: bottom\n }, area);\n return !apexesInArea;\n}\nfunction buildPointLabelItems(scale, labelSizes, padding) {\n const items = [];\n const valueCount = scale._pointLabels.length;\n const opts = scale.options;\n const { centerPointLabels , display } = opts.pointLabels;\n const itemOpts = {\n extra: getTickBackdropHeight(opts) / 2,\n additionalAngle: centerPointLabels ? PI / valueCount : 0\n };\n let area;\n for(let i = 0; i < valueCount; i++){\n itemOpts.padding = padding[i];\n itemOpts.size = labelSizes[i];\n const item = createPointLabelItem(scale, i, itemOpts);\n items.push(item);\n if (display === 'auto') {\n item.visible = isNotOverlapped(item, area);\n if (item.visible) {\n area = item;\n }\n }\n }\n return items;\n}\nfunction getTextAlignForAngle(angle) {\n if (angle === 0 || angle === 180) {\n return 'center';\n } else if (angle < 180) {\n return 'left';\n }\n return 'right';\n}\nfunction leftForTextAlign(x, w, align) {\n if (align === 'right') {\n x -= w;\n } else if (align === 'center') {\n x -= w / 2;\n }\n return x;\n}\nfunction yForAngle(y, h, angle) {\n if (angle === 90 || angle === 270) {\n y -= h / 2;\n } else if (angle > 270 || angle < 90) {\n y -= h;\n }\n return y;\n}\nfunction drawPointLabelBox(ctx, opts, item) {\n const { left , top , right , bottom } = item;\n const { backdropColor } = opts;\n if (!isNullOrUndef(backdropColor)) {\n const borderRadius = toTRBLCorners(opts.borderRadius);\n const padding = toPadding(opts.backdropPadding);\n ctx.fillStyle = backdropColor;\n const backdropLeft = left - padding.left;\n const backdropTop = top - padding.top;\n const backdropWidth = right - left + padding.width;\n const backdropHeight = bottom - top + padding.height;\n if (Object.values(borderRadius).some((v)=>v !== 0)) {\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: backdropLeft,\n y: backdropTop,\n w: backdropWidth,\n h: backdropHeight,\n radius: borderRadius\n });\n ctx.fill();\n } else {\n ctx.fillRect(backdropLeft, backdropTop, backdropWidth, backdropHeight);\n }\n }\n}\nfunction drawPointLabels(scale, labelCount) {\n const { ctx , options: { pointLabels } } = scale;\n for(let i = labelCount - 1; i >= 0; i--){\n const item = scale._pointLabelItems[i];\n if (!item.visible) {\n continue;\n }\n const optsAtIndex = pointLabels.setContext(scale.getPointLabelContext(i));\n drawPointLabelBox(ctx, optsAtIndex, item);\n const plFont = toFont(optsAtIndex.font);\n const { x , y , textAlign } = item;\n renderText(ctx, scale._pointLabels[i], x, y + plFont.lineHeight / 2, plFont, {\n color: optsAtIndex.color,\n textAlign: textAlign,\n textBaseline: 'middle'\n });\n }\n}\nfunction pathRadiusLine(scale, radius, circular, labelCount) {\n const { ctx } = scale;\n if (circular) {\n ctx.arc(scale.xCenter, scale.yCenter, radius, 0, TAU);\n } else {\n let pointPosition = scale.getPointPosition(0, radius);\n ctx.moveTo(pointPosition.x, pointPosition.y);\n for(let i = 1; i < labelCount; i++){\n pointPosition = scale.getPointPosition(i, radius);\n ctx.lineTo(pointPosition.x, pointPosition.y);\n }\n }\n}\nfunction drawRadiusLine(scale, gridLineOpts, radius, labelCount, borderOpts) {\n const ctx = scale.ctx;\n const circular = gridLineOpts.circular;\n const { color , lineWidth } = gridLineOpts;\n if (!circular && !labelCount || !color || !lineWidth || radius < 0) {\n return;\n }\n ctx.save();\n ctx.strokeStyle = color;\n ctx.lineWidth = lineWidth;\n ctx.setLineDash(borderOpts.dash || []);\n ctx.lineDashOffset = borderOpts.dashOffset;\n ctx.beginPath();\n pathRadiusLine(scale, radius, circular, labelCount);\n ctx.closePath();\n ctx.stroke();\n ctx.restore();\n}\nfunction createPointLabelContext(parent, index, label) {\n return createContext(parent, {\n label,\n index,\n type: 'pointLabel'\n });\n}\nclass RadialLinearScale extends LinearScaleBase {\n static id = 'radialLinear';\n static defaults = {\n display: true,\n animate: true,\n position: 'chartArea',\n angleLines: {\n display: true,\n lineWidth: 1,\n borderDash: [],\n borderDashOffset: 0.0\n },\n grid: {\n circular: false\n },\n startAngle: 0,\n ticks: {\n showLabelBackdrop: true,\n callback: Ticks.formatters.numeric\n },\n pointLabels: {\n backdropColor: undefined,\n backdropPadding: 2,\n display: true,\n font: {\n size: 10\n },\n callback (label) {\n return label;\n },\n padding: 5,\n centerPointLabels: false\n }\n };\n static defaultRoutes = {\n 'angleLines.color': 'borderColor',\n 'pointLabels.color': 'color',\n 'ticks.color': 'color'\n };\n static descriptors = {\n angleLines: {\n _fallback: 'grid'\n }\n };\n constructor(cfg){\n super(cfg);\n this.xCenter = undefined;\n this.yCenter = undefined;\n this.drawingArea = undefined;\n this._pointLabels = [];\n this._pointLabelItems = [];\n }\n setDimensions() {\n const padding = this._padding = toPadding(getTickBackdropHeight(this.options) / 2);\n const w = this.width = this.maxWidth - padding.width;\n const h = this.height = this.maxHeight - padding.height;\n this.xCenter = Math.floor(this.left + w / 2 + padding.left);\n this.yCenter = Math.floor(this.top + h / 2 + padding.top);\n this.drawingArea = Math.floor(Math.min(w, h) / 2);\n }\n determineDataLimits() {\n const { min , max } = this.getMinMax(false);\n this.min = isNumberFinite(min) && !isNaN(min) ? min : 0;\n this.max = isNumberFinite(max) && !isNaN(max) ? max : 0;\n this.handleTickRangeOptions();\n }\n computeTickLimit() {\n return Math.ceil(this.drawingArea / getTickBackdropHeight(this.options));\n }\n generateTickLabels(ticks) {\n LinearScaleBase.prototype.generateTickLabels.call(this, ticks);\n this._pointLabels = this.getLabels().map((value, index)=>{\n const label = callback(this.options.pointLabels.callback, [\n value,\n index\n ], this);\n return label || label === 0 ? label : '';\n }).filter((v, i)=>this.chart.getDataVisibility(i));\n }\n fit() {\n const opts = this.options;\n if (opts.display && opts.pointLabels.display) {\n fitWithPointLabels(this);\n } else {\n this.setCenterPoint(0, 0, 0, 0);\n }\n }\n setCenterPoint(leftMovement, rightMovement, topMovement, bottomMovement) {\n this.xCenter += Math.floor((leftMovement - rightMovement) / 2);\n this.yCenter += Math.floor((topMovement - bottomMovement) / 2);\n this.drawingArea -= Math.min(this.drawingArea / 2, Math.max(leftMovement, rightMovement, topMovement, bottomMovement));\n }\n getIndexAngle(index) {\n const angleMultiplier = TAU / (this._pointLabels.length || 1);\n const startAngle = this.options.startAngle || 0;\n return _normalizeAngle(index * angleMultiplier + toRadians(startAngle));\n }\n getDistanceFromCenterForValue(value) {\n if (isNullOrUndef(value)) {\n return NaN;\n }\n const scalingFactor = this.drawingArea / (this.max - this.min);\n if (this.options.reverse) {\n return (this.max - value) * scalingFactor;\n }\n return (value - this.min) * scalingFactor;\n }\n getValueForDistanceFromCenter(distance) {\n if (isNullOrUndef(distance)) {\n return NaN;\n }\n const scaledDistance = distance / (this.drawingArea / (this.max - this.min));\n return this.options.reverse ? this.max - scaledDistance : this.min + scaledDistance;\n }\n getPointLabelContext(index) {\n const pointLabels = this._pointLabels || [];\n if (index >= 0 && index < pointLabels.length) {\n const pointLabel = pointLabels[index];\n return createPointLabelContext(this.getContext(), index, pointLabel);\n }\n }\n getPointPosition(index, distanceFromCenter, additionalAngle = 0) {\n const angle = this.getIndexAngle(index) - HALF_PI + additionalAngle;\n return {\n x: Math.cos(angle) * distanceFromCenter + this.xCenter,\n y: Math.sin(angle) * distanceFromCenter + this.yCenter,\n angle\n };\n }\n getPointPositionForValue(index, value) {\n return this.getPointPosition(index, this.getDistanceFromCenterForValue(value));\n }\n getBasePosition(index) {\n return this.getPointPositionForValue(index || 0, this.getBaseValue());\n }\n getPointLabelPosition(index) {\n const { left , top , right , bottom } = this._pointLabelItems[index];\n return {\n left,\n top,\n right,\n bottom\n };\n }\n drawBackground() {\n const { backgroundColor , grid: { circular } } = this.options;\n if (backgroundColor) {\n const ctx = this.ctx;\n ctx.save();\n ctx.beginPath();\n pathRadiusLine(this, this.getDistanceFromCenterForValue(this._endValue), circular, this._pointLabels.length);\n ctx.closePath();\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n ctx.restore();\n }\n }\n drawGrid() {\n const ctx = this.ctx;\n const opts = this.options;\n const { angleLines , grid , border } = opts;\n const labelCount = this._pointLabels.length;\n let i, offset, position;\n if (opts.pointLabels.display) {\n drawPointLabels(this, labelCount);\n }\n if (grid.display) {\n this.ticks.forEach((tick, index)=>{\n if (index !== 0 || index === 0 && this.min < 0) {\n offset = this.getDistanceFromCenterForValue(tick.value);\n const context = this.getContext(index);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n drawRadiusLine(this, optsAtIndex, offset, labelCount, optsAtIndexBorder);\n }\n });\n }\n if (angleLines.display) {\n ctx.save();\n for(i = labelCount - 1; i >= 0; i--){\n const optsAtIndex = angleLines.setContext(this.getPointLabelContext(i));\n const { color , lineWidth } = optsAtIndex;\n if (!lineWidth || !color) {\n continue;\n }\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = color;\n ctx.setLineDash(optsAtIndex.borderDash);\n ctx.lineDashOffset = optsAtIndex.borderDashOffset;\n offset = this.getDistanceFromCenterForValue(opts.reverse ? this.min : this.max);\n position = this.getPointPosition(i, offset);\n ctx.beginPath();\n ctx.moveTo(this.xCenter, this.yCenter);\n ctx.lineTo(position.x, position.y);\n ctx.stroke();\n }\n ctx.restore();\n }\n }\n drawBorder() {}\n drawLabels() {\n const ctx = this.ctx;\n const opts = this.options;\n const tickOpts = opts.ticks;\n if (!tickOpts.display) {\n return;\n }\n const startAngle = this.getIndexAngle(0);\n let offset, width;\n ctx.save();\n ctx.translate(this.xCenter, this.yCenter);\n ctx.rotate(startAngle);\n ctx.textAlign = 'center';\n ctx.textBaseline = 'middle';\n this.ticks.forEach((tick, index)=>{\n if (index === 0 && this.min >= 0 && !opts.reverse) {\n return;\n }\n const optsAtIndex = tickOpts.setContext(this.getContext(index));\n const tickFont = toFont(optsAtIndex.font);\n offset = this.getDistanceFromCenterForValue(this.ticks[index].value);\n if (optsAtIndex.showLabelBackdrop) {\n ctx.font = tickFont.string;\n width = ctx.measureText(tick.label).width;\n ctx.fillStyle = optsAtIndex.backdropColor;\n const padding = toPadding(optsAtIndex.backdropPadding);\n ctx.fillRect(-width / 2 - padding.left, -offset - tickFont.size / 2 - padding.top, width + padding.width, tickFont.size + padding.height);\n }\n renderText(ctx, tick.label, 0, -offset, tickFont, {\n color: optsAtIndex.color,\n strokeColor: optsAtIndex.textStrokeColor,\n strokeWidth: optsAtIndex.textStrokeWidth\n });\n });\n ctx.restore();\n }\n drawTitle() {}\n}\n\nconst INTERVALS = {\n millisecond: {\n common: true,\n size: 1,\n steps: 1000\n },\n second: {\n common: true,\n size: 1000,\n steps: 60\n },\n minute: {\n common: true,\n size: 60000,\n steps: 60\n },\n hour: {\n common: true,\n size: 3600000,\n steps: 24\n },\n day: {\n common: true,\n size: 86400000,\n steps: 30\n },\n week: {\n common: false,\n size: 604800000,\n steps: 4\n },\n month: {\n common: true,\n size: 2.628e9,\n steps: 12\n },\n quarter: {\n common: false,\n size: 7.884e9,\n steps: 4\n },\n year: {\n common: true,\n size: 3.154e10\n }\n};\n const UNITS = /* #__PURE__ */ Object.keys(INTERVALS);\n function sorter(a, b) {\n return a - b;\n}\n function parse(scale, input) {\n if (isNullOrUndef(input)) {\n return null;\n }\n const adapter = scale._adapter;\n const { parser , round , isoWeekday } = scale._parseOpts;\n let value = input;\n if (typeof parser === 'function') {\n value = parser(value);\n }\n if (!isNumberFinite(value)) {\n value = typeof parser === 'string' ? adapter.parse(value, parser) : adapter.parse(value);\n }\n if (value === null) {\n return null;\n }\n if (round) {\n value = round === 'week' && (isNumber(isoWeekday) || isoWeekday === true) ? adapter.startOf(value, 'isoWeek', isoWeekday) : adapter.startOf(value, round);\n }\n return +value;\n}\n function determineUnitForAutoTicks(minUnit, min, max, capacity) {\n const ilen = UNITS.length;\n for(let i = UNITS.indexOf(minUnit); i < ilen - 1; ++i){\n const interval = INTERVALS[UNITS[i]];\n const factor = interval.steps ? interval.steps : Number.MAX_SAFE_INTEGER;\n if (interval.common && Math.ceil((max - min) / (factor * interval.size)) <= capacity) {\n return UNITS[i];\n }\n }\n return UNITS[ilen - 1];\n}\n function determineUnitForFormatting(scale, numTicks, minUnit, min, max) {\n for(let i = UNITS.length - 1; i >= UNITS.indexOf(minUnit); i--){\n const unit = UNITS[i];\n if (INTERVALS[unit].common && scale._adapter.diff(max, min, unit) >= numTicks - 1) {\n return unit;\n }\n }\n return UNITS[minUnit ? UNITS.indexOf(minUnit) : 0];\n}\n function determineMajorUnit(unit) {\n for(let i = UNITS.indexOf(unit) + 1, ilen = UNITS.length; i < ilen; ++i){\n if (INTERVALS[UNITS[i]].common) {\n return UNITS[i];\n }\n }\n}\n function addTick(ticks, time, timestamps) {\n if (!timestamps) {\n ticks[time] = true;\n } else if (timestamps.length) {\n const { lo , hi } = _lookup(timestamps, time);\n const timestamp = timestamps[lo] >= time ? timestamps[lo] : timestamps[hi];\n ticks[timestamp] = true;\n }\n}\n function setMajorTicks(scale, ticks, map, majorUnit) {\n const adapter = scale._adapter;\n const first = +adapter.startOf(ticks[0].value, majorUnit);\n const last = ticks[ticks.length - 1].value;\n let major, index;\n for(major = first; major <= last; major = +adapter.add(major, 1, majorUnit)){\n index = map[major];\n if (index >= 0) {\n ticks[index].major = true;\n }\n }\n return ticks;\n}\n function ticksFromTimestamps(scale, values, majorUnit) {\n const ticks = [];\n const map = {};\n const ilen = values.length;\n let i, value;\n for(i = 0; i < ilen; ++i){\n value = values[i];\n map[value] = i;\n ticks.push({\n value,\n major: false\n });\n }\n return ilen === 0 || !majorUnit ? ticks : setMajorTicks(scale, ticks, map, majorUnit);\n}\nclass TimeScale extends Scale {\n static id = 'time';\n static defaults = {\n bounds: 'data',\n adapters: {},\n time: {\n parser: false,\n unit: false,\n round: false,\n isoWeekday: false,\n minUnit: 'millisecond',\n displayFormats: {}\n },\n ticks: {\n source: 'auto',\n callback: false,\n major: {\n enabled: false\n }\n }\n };\n constructor(props){\n super(props);\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n this._unit = 'day';\n this._majorUnit = undefined;\n this._offsets = {};\n this._normalized = false;\n this._parseOpts = undefined;\n }\n init(scaleOpts, opts = {}) {\n const time = scaleOpts.time || (scaleOpts.time = {});\n const adapter = this._adapter = new adapters._date(scaleOpts.adapters.date);\n adapter.init(opts);\n mergeIf(time.displayFormats, adapter.formats());\n this._parseOpts = {\n parser: time.parser,\n round: time.round,\n isoWeekday: time.isoWeekday\n };\n super.init(scaleOpts);\n this._normalized = opts.normalized;\n }\n parse(raw, index) {\n if (raw === undefined) {\n return null;\n }\n return parse(this, raw);\n }\n beforeLayout() {\n super.beforeLayout();\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n }\n determineDataLimits() {\n const options = this.options;\n const adapter = this._adapter;\n const unit = options.time.unit || 'day';\n let { min , max , minDefined , maxDefined } = this.getUserBounds();\n function _applyBounds(bounds) {\n if (!minDefined && !isNaN(bounds.min)) {\n min = Math.min(min, bounds.min);\n }\n if (!maxDefined && !isNaN(bounds.max)) {\n max = Math.max(max, bounds.max);\n }\n }\n if (!minDefined || !maxDefined) {\n _applyBounds(this._getLabelBounds());\n if (options.bounds !== 'ticks' || options.ticks.source !== 'labels') {\n _applyBounds(this.getMinMax(false));\n }\n }\n min = isNumberFinite(min) && !isNaN(min) ? min : +adapter.startOf(Date.now(), unit);\n max = isNumberFinite(max) && !isNaN(max) ? max : +adapter.endOf(Date.now(), unit) + 1;\n this.min = Math.min(min, max - 1);\n this.max = Math.max(min + 1, max);\n }\n _getLabelBounds() {\n const arr = this.getLabelTimestamps();\n let min = Number.POSITIVE_INFINITY;\n let max = Number.NEGATIVE_INFINITY;\n if (arr.length) {\n min = arr[0];\n max = arr[arr.length - 1];\n }\n return {\n min,\n max\n };\n }\n buildTicks() {\n const options = this.options;\n const timeOpts = options.time;\n const tickOpts = options.ticks;\n const timestamps = tickOpts.source === 'labels' ? this.getLabelTimestamps() : this._generate();\n if (options.bounds === 'ticks' && timestamps.length) {\n this.min = this._userMin || timestamps[0];\n this.max = this._userMax || timestamps[timestamps.length - 1];\n }\n const min = this.min;\n const max = this.max;\n const ticks = _filterBetween(timestamps, min, max);\n this._unit = timeOpts.unit || (tickOpts.autoSkip ? determineUnitForAutoTicks(timeOpts.minUnit, this.min, this.max, this._getLabelCapacity(min)) : determineUnitForFormatting(this, ticks.length, timeOpts.minUnit, this.min, this.max));\n this._majorUnit = !tickOpts.major.enabled || this._unit === 'year' ? undefined : determineMajorUnit(this._unit);\n this.initOffsets(timestamps);\n if (options.reverse) {\n ticks.reverse();\n }\n return ticksFromTimestamps(this, ticks, this._majorUnit);\n }\n afterAutoSkip() {\n if (this.options.offsetAfterAutoskip) {\n this.initOffsets(this.ticks.map((tick)=>+tick.value));\n }\n }\n initOffsets(timestamps = []) {\n let start = 0;\n let end = 0;\n let first, last;\n if (this.options.offset && timestamps.length) {\n first = this.getDecimalForValue(timestamps[0]);\n if (timestamps.length === 1) {\n start = 1 - first;\n } else {\n start = (this.getDecimalForValue(timestamps[1]) - first) / 2;\n }\n last = this.getDecimalForValue(timestamps[timestamps.length - 1]);\n if (timestamps.length === 1) {\n end = last;\n } else {\n end = (last - this.getDecimalForValue(timestamps[timestamps.length - 2])) / 2;\n }\n }\n const limit = timestamps.length < 3 ? 0.5 : 0.25;\n start = _limitValue(start, 0, limit);\n end = _limitValue(end, 0, limit);\n this._offsets = {\n start,\n end,\n factor: 1 / (start + 1 + end)\n };\n }\n _generate() {\n const adapter = this._adapter;\n const min = this.min;\n const max = this.max;\n const options = this.options;\n const timeOpts = options.time;\n const minor = timeOpts.unit || determineUnitForAutoTicks(timeOpts.minUnit, min, max, this._getLabelCapacity(min));\n const stepSize = valueOrDefault(options.ticks.stepSize, 1);\n const weekday = minor === 'week' ? timeOpts.isoWeekday : false;\n const hasWeekday = isNumber(weekday) || weekday === true;\n const ticks = {};\n let first = min;\n let time, count;\n if (hasWeekday) {\n first = +adapter.startOf(first, 'isoWeek', weekday);\n }\n first = +adapter.startOf(first, hasWeekday ? 'day' : minor);\n if (adapter.diff(max, min, minor) > 100000 * stepSize) {\n throw new Error(min + ' and ' + max + ' are too far apart with stepSize of ' + stepSize + ' ' + minor);\n }\n const timestamps = options.ticks.source === 'data' && this.getDataTimestamps();\n for(time = first, count = 0; time < max; time = +adapter.add(time, stepSize, minor), count++){\n addTick(ticks, time, timestamps);\n }\n if (time === max || options.bounds === 'ticks' || count === 1) {\n addTick(ticks, time, timestamps);\n }\n return Object.keys(ticks).sort(sorter).map((x)=>+x);\n }\n getLabelForValue(value) {\n const adapter = this._adapter;\n const timeOpts = this.options.time;\n if (timeOpts.tooltipFormat) {\n return adapter.format(value, timeOpts.tooltipFormat);\n }\n return adapter.format(value, timeOpts.displayFormats.datetime);\n }\n format(value, format) {\n const options = this.options;\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const fmt = format || formats[unit];\n return this._adapter.format(value, fmt);\n }\n _tickFormatFunction(time, index, ticks, format) {\n const options = this.options;\n const formatter = options.ticks.callback;\n if (formatter) {\n return callback(formatter, [\n time,\n index,\n ticks\n ], this);\n }\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const majorUnit = this._majorUnit;\n const minorFormat = unit && formats[unit];\n const majorFormat = majorUnit && formats[majorUnit];\n const tick = ticks[index];\n const major = majorUnit && majorFormat && tick && tick.major;\n return this._adapter.format(time, format || (major ? majorFormat : minorFormat));\n }\n generateTickLabels(ticks) {\n let i, ilen, tick;\n for(i = 0, ilen = ticks.length; i < ilen; ++i){\n tick = ticks[i];\n tick.label = this._tickFormatFunction(tick.value, i, ticks);\n }\n }\n getDecimalForValue(value) {\n return value === null ? NaN : (value - this.min) / (this.max - this.min);\n }\n getPixelForValue(value) {\n const offsets = this._offsets;\n const pos = this.getDecimalForValue(value);\n return this.getPixelForDecimal((offsets.start + pos) * offsets.factor);\n }\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const pos = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return this.min + pos * (this.max - this.min);\n }\n _getLabelSize(label) {\n const ticksOpts = this.options.ticks;\n const tickLabelWidth = this.ctx.measureText(label).width;\n const angle = toRadians(this.isHorizontal() ? ticksOpts.maxRotation : ticksOpts.minRotation);\n const cosRotation = Math.cos(angle);\n const sinRotation = Math.sin(angle);\n const tickFontSize = this._resolveTickFontOptions(0).size;\n return {\n w: tickLabelWidth * cosRotation + tickFontSize * sinRotation,\n h: tickLabelWidth * sinRotation + tickFontSize * cosRotation\n };\n }\n _getLabelCapacity(exampleTime) {\n const timeOpts = this.options.time;\n const displayFormats = timeOpts.displayFormats;\n const format = displayFormats[timeOpts.unit] || displayFormats.millisecond;\n const exampleLabel = this._tickFormatFunction(exampleTime, 0, ticksFromTimestamps(this, [\n exampleTime\n ], this._majorUnit), format);\n const size = this._getLabelSize(exampleLabel);\n const capacity = Math.floor(this.isHorizontal() ? this.width / size.w : this.height / size.h) - 1;\n return capacity > 0 ? capacity : 1;\n }\n getDataTimestamps() {\n let timestamps = this._cache.data || [];\n let i, ilen;\n if (timestamps.length) {\n return timestamps;\n }\n const metas = this.getMatchingVisibleMetas();\n if (this._normalized && metas.length) {\n return this._cache.data = metas[0].controller.getAllParsedValues(this);\n }\n for(i = 0, ilen = metas.length; i < ilen; ++i){\n timestamps = timestamps.concat(metas[i].controller.getAllParsedValues(this));\n }\n return this._cache.data = this.normalize(timestamps);\n }\n getLabelTimestamps() {\n const timestamps = this._cache.labels || [];\n let i, ilen;\n if (timestamps.length) {\n return timestamps;\n }\n const labels = this.getLabels();\n for(i = 0, ilen = labels.length; i < ilen; ++i){\n timestamps.push(parse(this, labels[i]));\n }\n return this._cache.labels = this._normalized ? timestamps : this.normalize(timestamps);\n }\n normalize(values) {\n return _arrayUnique(values.sort(sorter));\n }\n}\n\nfunction interpolate(table, val, reverse) {\n let lo = 0;\n let hi = table.length - 1;\n let prevSource, nextSource, prevTarget, nextTarget;\n if (reverse) {\n if (val >= table[lo].pos && val <= table[hi].pos) {\n ({ lo , hi } = _lookupByKey(table, 'pos', val));\n }\n ({ pos: prevSource , time: prevTarget } = table[lo]);\n ({ pos: nextSource , time: nextTarget } = table[hi]);\n } else {\n if (val >= table[lo].time && val <= table[hi].time) {\n ({ lo , hi } = _lookupByKey(table, 'time', val));\n }\n ({ time: prevSource , pos: prevTarget } = table[lo]);\n ({ time: nextSource , pos: nextTarget } = table[hi]);\n }\n const span = nextSource - prevSource;\n return span ? prevTarget + (nextTarget - prevTarget) * (val - prevSource) / span : prevTarget;\n}\nclass TimeSeriesScale extends TimeScale {\n static id = 'timeseries';\n static defaults = TimeScale.defaults;\n constructor(props){\n super(props);\n this._table = [];\n this._minPos = undefined;\n this._tableRange = undefined;\n }\n initOffsets() {\n const timestamps = this._getTimestampsForTable();\n const table = this._table = this.buildLookupTable(timestamps);\n this._minPos = interpolate(table, this.min);\n this._tableRange = interpolate(table, this.max) - this._minPos;\n super.initOffsets(timestamps);\n }\n buildLookupTable(timestamps) {\n const { min , max } = this;\n const items = [];\n const table = [];\n let i, ilen, prev, curr, next;\n for(i = 0, ilen = timestamps.length; i < ilen; ++i){\n curr = timestamps[i];\n if (curr >= min && curr <= max) {\n items.push(curr);\n }\n }\n if (items.length < 2) {\n return [\n {\n time: min,\n pos: 0\n },\n {\n time: max,\n pos: 1\n }\n ];\n }\n for(i = 0, ilen = items.length; i < ilen; ++i){\n next = items[i + 1];\n prev = items[i - 1];\n curr = items[i];\n if (Math.round((next + prev) / 2) !== curr) {\n table.push({\n time: curr,\n pos: i / (ilen - 1)\n });\n }\n }\n return table;\n }\n _generate() {\n const min = this.min;\n const max = this.max;\n let timestamps = super.getDataTimestamps();\n if (!timestamps.includes(min) || !timestamps.length) {\n timestamps.splice(0, 0, min);\n }\n if (!timestamps.includes(max) || timestamps.length === 1) {\n timestamps.push(max);\n }\n return timestamps.sort((a, b)=>a - b);\n }\n _getTimestampsForTable() {\n let timestamps = this._cache.all || [];\n if (timestamps.length) {\n return timestamps;\n }\n const data = this.getDataTimestamps();\n const label = this.getLabelTimestamps();\n if (data.length && label.length) {\n timestamps = this.normalize(data.concat(label));\n } else {\n timestamps = data.length ? data : label;\n }\n timestamps = this._cache.all = timestamps;\n return timestamps;\n }\n getDecimalForValue(value) {\n return (interpolate(this._table, value) - this._minPos) / this._tableRange;\n }\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const decimal = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return interpolate(this._table, decimal * this._tableRange + this._minPos, true);\n }\n}\n\nvar scales = /*#__PURE__*/Object.freeze({\n__proto__: null,\nCategoryScale: CategoryScale,\nLinearScale: LinearScale,\nLogarithmicScale: LogarithmicScale,\nRadialLinearScale: RadialLinearScale,\nTimeScale: TimeScale,\nTimeSeriesScale: TimeSeriesScale\n});\n\nconst registerables = [\n controllers,\n elements,\n plugins,\n scales\n];\n\nexport { Animation, Animations, ArcElement, BarController, BarElement, BasePlatform, BasicPlatform, BubbleController, CategoryScale, Chart, plugin_colors as Colors, DatasetController, plugin_decimation as Decimation, DomPlatform, DoughnutController, Element, index as Filler, Interaction, plugin_legend as Legend, LineController, LineElement, LinearScale, LogarithmicScale, PieController, PointElement, PolarAreaController, RadarController, RadialLinearScale, Scale, ScatterController, plugin_subtitle as SubTitle, Ticks, TimeScale, TimeSeriesScale, plugin_title as Title, plugin_tooltip as Tooltip, adapters as _adapters, _detectPlatform, animator, controllers, defaults, elements, layouts, plugins, registerables, registry, scales };\n//# sourceMappingURL=chart.js.map\n","\n\n\n\t \n
\n\n\n","\n\n\n\t
\n\t\t\n\t\t\t\n\t\t\t\tName \n\t\t\t\t{file.name} \n\t\t\t \n\t\t\t\n\t\t\t\tURL \n\t\t\t\t{domain_url()}/u/{file.id} \n\t\t\t \n\t\t\t\n\t\t\t\tMime Type \n\t\t\t\t{file.mime_type} \n\t\t\t \n\t\t\t\n\t\t\t\tID \n\t\t\t\t{file.id} \n\t\t\t \n\t\t\t\n\t\t\t\tSize \n\t\t\t\t{formatDataVolume(file.size, 4)} ( {formatThousands(file.size)} B ) \n\t\t\t \n\t\t\t\n\t\t\t\tFree bandwidth used \n\t\t\t\t\n\t\t\t\t\t{formatDataVolume(file.bandwidth_used, 4)}\n\t\t\t\t\t( {formatThousands(file.bandwidth_used)} B ),\n\t\t\t\t\t{(file.bandwidth_used/file.size).toFixed(1)}x file size\n\t\t\t\t \n\t\t\t \n\t\t\t\n\t\t\t\tPremium bandwidth used \n\t\t\t\t\n\t\t\t\t\t{formatDataVolume(file.bandwidth_used_paid, 4)}\n\t\t\t\t\t( {formatThousands(file.bandwidth_used_paid)} B ),\n\t\t\t\t\t{(file.bandwidth_used_paid/file.size).toFixed(1)}x file size\n\t\t\t\t \n\t\t\t \n\t\t\t\n\t\t\t\t\n\t\t\t\t\tUnique downloads\n\t\t\t\t\t download_info = !download_info}\n\t\t\t\t\t>\n\t\t\t\t\t\thelp \n\t\t\t\t\t \n\t\t\t\t \n\t\t\t\t{formatThousands(file.downloads)} \n\t\t\t \n\t\t\t{#if download_info}\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\t\tThe unique download counter only counts downloads once per IP\n\t\t\t\t\t\taddress. So this number shows how many individual people have\n\t\t\t\t\t\tattempted to download the file. The download counter on the\n\t\t\t\t\t\ttoolbar on the other hand shows how many real downloads the file\n\t\t\t\t\t\thas had. Real downloads are counted by dividing the total\n\t\t\t\t\t\tbandwidth usage by the size of the file.\n\t\t\t\t\t \n\t\t\t\t \n\t\t\t{/if}\n\t\t\t\n\t\t\t\tUpload Date \n\t\t\t\t{formatDate(file.date_upload, true, true, true)} \n\t\t\t \n\t\t\t{#if file.description}\n\t\t\t\t\n\t\t\t\t\tDescription \n\t\t\t\t\t{file.description} \n\t\t\t\t \n\t\t\t{/if}\n\t\t\t\n\t\t\t\tSHA256 hash \n\t\t\t\t{file.hash_sha256} \n\t\t\t \n\t\t \n\t
\n\n\t
Views and downloads \n\n\t
\n\t\t{#each chart_timespans as ts}\n\t\t\t { update_chart(ts.span, ts.interval) }}\n\t\t\t\tclass:button_highlight={chart_timespan == ts.span}>\n\t\t\t\t{ts.label}\n\t\t\t \n\t\t{/each}\n\t
\n\n\t
\n\n\t
\n\t\tCharts rendered by the amazing Chart.js .\n\t
\n\n\t
Keyboard Controls \n\n\t
Global \n\t
\n\t\t
\n\t\t
\n\t\t
\n\t\t
g
Grab file (copy to your account)
\n\t\t
\n\t\t
\n\t\t
r
Show abuse report window
\n\t
\n\n\t
List \n\t
\n\t\t
\n\t\t
\n\t\t
shift + s
Download all files as zip
\n\t\t
\n\t
\n\n\t
Video / audio \n\t
\n\t\t
space
Pause / resume playback
\n\t\t
\n\t\t
\n\t\t
\n\t\t
h
Skip 20 seconds backward
\n\t\t
\n\t\t
\n\t\t
\n\t\t
\n\t\t
\n\t
\n
\n\n\n","\n\t\n\t\t \n\t \n \n\n\n","\ntype VideoPositions = {\n\t[key: string]: VideoPosition\n}\n\nexport type VideoPosition = {\n\ttime: number\n\tpos: number\n\tdur: number\n}\n\nconst storage_key = \"video_positions\"\nconst expiry_time = 28 * 24 * 60 * 60 * 1000\n\nlet position_cache: VideoPositions | null = null\nexport const get_video_positions = () => {\n\tif (position_cache !== null) {\n\t\treturn position_cache\n\t}\n\n\tlet video_positions = JSON.parse(window.localStorage.getItem(storage_key)) as VideoPositions\n\tif (video_positions === null) {\n\t\treturn {} as VideoPositions\n\t}\n\treturn video_positions\n}\n\nexport const save_video_position = (id: string, position: number, duration: number) => {\n\tif (duration < 300) {\n\t\treturn // Don't bother saving videos less than 5 minutes long\n\t}\n\n\tconst video_positions = get_video_positions()\n\n\t// Add our new entry\n\tvideo_positions[id] = {\n\t\ttime: (new Date).getTime(),\n\t\tpos: position,\n\t\tdur: duration,\n\t}\n\n\t// Remove old entries\n\tconst expiry_thresh = (new Date).getTime() - expiry_time\n\tfor (const key in video_positions) {\n\t\tif (video_positions[key].time < expiry_thresh) {\n\t\t\tdelete video_positions[key]\n\t\t\tconsole.debug(\"Delete old video position\", key)\n\t\t}\n\t}\n\n\t// Save updated object\n\twindow.localStorage.setItem(storage_key, JSON.stringify(video_positions))\n\n\t// Update the cache\n\tposition_cache = video_positions\n}\n\nexport const get_video_position = (id: string) => {\n\tconst video_positions = get_video_positions()\n\tif (video_positions[id] === undefined) {\n\t\treturn null\n\t}\n\treturn video_positions[id]\n}\n\nexport const video_position = (node: HTMLVideoElement, get_id: () => string) => {\n\tlet last_time = 0\n\n\tconst loadeddata = (e: Event) => {\n\t\tlast_time = 0\n\n\t\tconst vp = get_video_position(get_id())\n\t\tif (vp === null || vp.pos === 0 || vp.dur === 0) {\n\t\t\treturn\n\t\t} else if (vp.pos / vp.dur > 0.95) {\n\t\t\t// If the video is more than 95% complete we don't do anything\n\t\t\tconsole.debug(\"Video is at end, not setting time\")\n\t\t\treturn\n\t\t}\n\n\t\t(e.target as HTMLVideoElement).currentTime = vp.pos\n\t\tlast_time = vp.pos\n\t}\n\n\tconst timeupdate = (e: Event) => {\n\t\tconst vid = (e.target as HTMLVideoElement)\n\n\t\t// If the current timestamp is more than ten seconds off the last\n\t\t// timestamp we saved, then we save the new timestamp\n\t\tif (Math.abs(vid.currentTime - last_time) > 10) {\n\t\t\tsave_video_position(get_id(), vid.currentTime, vid.duration)\n\t\t\tlast_time = vid.currentTime\n\t\t}\n\t}\n\n\tnode.addEventListener(\"loadeddata\", loadeddata)\n\tnode.addEventListener(\"timeupdate\", timeupdate)\n\n\treturn {\n\t\tdestroy() {\n\t\t\tnode.removeEventListener(\"loadeddata\", loadeddata)\n\t\t\tnode.removeEventListener(\"timeupdate\", timeupdate)\n\t\t}\n\t}\n}\n","\n\n\n\t \n
\n\n\n","\n\n\n\n\n","import {\n\trun_all,\n\tsubscribe,\n\tnoop,\n\tsafe_not_equal,\n\tis_function,\n\tget_store_value\n} from '../internal/index.js';\n\nconst subscriber_queue = [];\n\n/**\n * Creates a `Readable` store that allows reading by subscription.\n *\n * https://svelte.dev/docs/svelte-store#readable\n * @template T\n * @param {T} [value] initial value\n * @param {import('./public.js').StartStopNotifier} [start]\n * @returns {import('./public.js').Readable}\n */\nexport function readable(value, start) {\n\treturn {\n\t\tsubscribe: writable(value, start).subscribe\n\t};\n}\n\n/**\n * Create a `Writable` store that allows both updating and reading by subscription.\n *\n * https://svelte.dev/docs/svelte-store#writable\n * @template T\n * @param {T} [value] initial value\n * @param {import('./public.js').StartStopNotifier} [start]\n * @returns {import('./public.js').Writable}\n */\nexport function writable(value, start = noop) {\n\t/** @type {import('./public.js').Unsubscriber} */\n\tlet stop;\n\t/** @type {Set>} */\n\tconst subscribers = new Set();\n\t/** @param {T} new_value\n\t * @returns {void}\n\t */\n\tfunction set(new_value) {\n\t\tif (safe_not_equal(value, new_value)) {\n\t\t\tvalue = new_value;\n\t\t\tif (stop) {\n\t\t\t\t// store is ready\n\t\t\t\tconst run_queue = !subscriber_queue.length;\n\t\t\t\tfor (const subscriber of subscribers) {\n\t\t\t\t\tsubscriber[1]();\n\t\t\t\t\tsubscriber_queue.push(subscriber, value);\n\t\t\t\t}\n\t\t\t\tif (run_queue) {\n\t\t\t\t\tfor (let i = 0; i < subscriber_queue.length; i += 2) {\n\t\t\t\t\t\tsubscriber_queue[i][0](subscriber_queue[i + 1]);\n\t\t\t\t\t}\n\t\t\t\t\tsubscriber_queue.length = 0;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * @param {import('./public.js').Updater} fn\n\t * @returns {void}\n\t */\n\tfunction update(fn) {\n\t\tset(fn(value));\n\t}\n\n\t/**\n\t * @param {import('./public.js').Subscriber} run\n\t * @param {import('./private.js').Invalidator} [invalidate]\n\t * @returns {import('./public.js').Unsubscriber}\n\t */\n\tfunction subscribe(run, invalidate = noop) {\n\t\t/** @type {import('./private.js').SubscribeInvalidateTuple} */\n\t\tconst subscriber = [run, invalidate];\n\t\tsubscribers.add(subscriber);\n\t\tif (subscribers.size === 1) {\n\t\t\tstop = start(set, update) || noop;\n\t\t}\n\t\trun(value);\n\t\treturn () => {\n\t\t\tsubscribers.delete(subscriber);\n\t\t\tif (subscribers.size === 0 && stop) {\n\t\t\t\tstop();\n\t\t\t\tstop = null;\n\t\t\t}\n\t\t};\n\t}\n\treturn { set, update, subscribe };\n}\n\n/**\n * Derived value store by synchronizing one or more readable stores and\n * applying an aggregation function over its input values.\n *\n * https://svelte.dev/docs/svelte-store#derived\n * @template {import('./private.js').Stores} S\n * @template T\n * @overload\n * @param {S} stores - input stores\n * @param {(values: import('./private.js').StoresValues, set: (value: T) => void, update: (fn: import('./public.js').Updater) => void) => import('./public.js').Unsubscriber | void} fn - function callback that aggregates the values\n * @param {T} [initial_value] - initial value\n * @returns {import('./public.js').Readable}\n */\n\n/**\n * Derived value store by synchronizing one or more readable stores and\n * applying an aggregation function over its input values.\n *\n * https://svelte.dev/docs/svelte-store#derived\n * @template {import('./private.js').Stores} S\n * @template T\n * @overload\n * @param {S} stores - input stores\n * @param {(values: import('./private.js').StoresValues) => T} fn - function callback that aggregates the values\n * @param {T} [initial_value] - initial value\n * @returns {import('./public.js').Readable}\n */\n\n/**\n * @template {import('./private.js').Stores} S\n * @template T\n * @param {S} stores\n * @param {Function} fn\n * @param {T} [initial_value]\n * @returns {import('./public.js').Readable}\n */\nexport function derived(stores, fn, initial_value) {\n\tconst single = !Array.isArray(stores);\n\t/** @type {Array>} */\n\tconst stores_array = single ? [stores] : stores;\n\tif (!stores_array.every(Boolean)) {\n\t\tthrow new Error('derived() expects stores as input, got a falsy value');\n\t}\n\tconst auto = fn.length < 2;\n\treturn readable(initial_value, (set, update) => {\n\t\tlet started = false;\n\t\tconst values = [];\n\t\tlet pending = 0;\n\t\tlet cleanup = noop;\n\t\tconst sync = () => {\n\t\t\tif (pending) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tcleanup();\n\t\t\tconst result = fn(single ? values[0] : values, set, update);\n\t\t\tif (auto) {\n\t\t\t\tset(result);\n\t\t\t} else {\n\t\t\t\tcleanup = is_function(result) ? result : noop;\n\t\t\t}\n\t\t};\n\t\tconst unsubscribers = stores_array.map((store, i) =>\n\t\t\tsubscribe(\n\t\t\t\tstore,\n\t\t\t\t(value) => {\n\t\t\t\t\tvalues[i] = value;\n\t\t\t\t\tpending &= ~(1 << i);\n\t\t\t\t\tif (started) {\n\t\t\t\t\t\tsync();\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t() => {\n\t\t\t\t\tpending |= 1 << i;\n\t\t\t\t}\n\t\t\t)\n\t\t);\n\t\tstarted = true;\n\t\tsync();\n\t\treturn function stop() {\n\t\t\trun_all(unsubscribers);\n\t\t\tcleanup();\n\t\t\t// We need to set this to false because callbacks can still happen despite having unsubscribed:\n\t\t\t// Callbacks might already be placed in the queue which doesn't know it should no longer\n\t\t\t// invoke this derived store.\n\t\t\tstarted = false;\n\t\t};\n\t});\n}\n\n/**\n * Takes a store and returns a new one derived from the old one that is readable.\n *\n * https://svelte.dev/docs/svelte-store#readonly\n * @template T\n * @param {import('./public.js').Readable} store - store to make readonly\n * @returns {import('./public.js').Readable}\n */\nexport function readonly(store) {\n\treturn {\n\t\tsubscribe: store.subscribe.bind(store)\n\t};\n}\n\nexport { get_store_value as get };\n","import { readable } from \"svelte/store\";\n\ntype SocketResults = {\n\tconnected: boolean,\n\tfile_stats_init: boolean,\n\tfile_stats: FileStats\n\tlimits_init: boolean,\n\tlimits: Limits,\n}\n\ntype FileStats = {\n\tviews: number,\n\tdownloads: number,\n\tbandwidth: number,\n\tbandwidth_paid: number,\n}\n\ntype Limits = {\n\tserver_overload: boolean,\n\tspeed_limit: number,\n\tdownload_limit: number,\n\tdownload_limit_used: number,\n\ttransfer_limit: number,\n\ttransfer_limit_used: number,\n}\n\ntype SocketCommand = {\n\ttype: string,\n\tdata?: Object,\n}\n\nlet results: SocketResults = {\n\tfile_stats: {} as FileStats,\n\tlimits: {} as Limits,\n} as SocketResults\n\nexport const stats = readable(\n\tresults,\n\t(set) => {\n\t\tstart_sock(set)\n\t\treturn () => stop_sock(set)\n\t},\n);\n\nlet socket: WebSocket = null\nconst start_sock = (set_func: (value: SocketResults) => void) => {\n\tif (socket !== null) {\n\t\treturn\n\t}\n\n\tconsole.log(\"Initializing stats socket\")\n\tsocket = new WebSocket(location.origin.replace(/^http/, 'ws') + \"/api/file_stats\")\n\n\tsocket.onopen = () => {\n\t\tresults.connected = true\n\t\t// set_func(results)\n\n\t\t// Subscribe to the rate limit feed. This will also process any queued\n\t\t// commands built up while the socket was down\n\t\tsend_cmd({ type: \"limits\" })\n\t}\n\tsocket.onmessage = (msg: MessageEvent) => {\n\t\tlet j = JSON.parse(msg.data)\n\t\tconsole.debug(\"WS update\", j)\n\n\t\tif (j.type === \"file_stats\") {\n\t\t\tresults.file_stats = j.file_stats\n\t\t\tresults.file_stats_init = true\n\t\t\tset_func(results)\n\t\t} else if (j.type === \"limits\") {\n\t\t\tresults.limits = j.limits\n\t\t\tresults.limits_init = true\n\t\t\tset_func(results)\n\t\t} else {\n\t\t\tconsole.error(\"Unknown ws message type\", j.type, \"data\", msg.data)\n\t\t}\n\t}\n\tsocket.onerror = (err: Event) => {\n\t\tconsole.error(\"Stats socket error\", err)\n\t\tstop_sock(set_func)\n\t\twindow.setTimeout(() => start_sock(set_func), 2000)\n\t}\n\tsocket.onclose = (e: CloseEvent) => {\n\t\tconsole.debug(\"Stats socket close\", e)\n\t\tstop_sock(set_func)\n\t\twindow.setTimeout(() => start_sock(set_func), 2000)\n\t}\n}\n\nconst stop_sock = (set_func: (value: SocketResults) => void) => {\n\tif (socket === null) {\n\t\treturn\n\t}\n\n\t// Prevent error handlers from re-initializing the socket\n\tsocket.onerror = null\n\tsocket.onclose = null\n\n\t// Close and delete the socket\n\tsocket.close()\n\tsocket = null\n\n\t// Reset the state\n\tresults.connected = false\n\tresults.file_stats_init = false\n\tresults.limits_init = false\n\tset_func(results)\n}\n\n\nexport const set_file = (file_id: string) => {\n\tsend_cmd({\n\t\ttype: \"file_stats\",\n\t\tdata: { file_id: file_id },\n\t})\n}\n\nlet queued_commands = []\nconst send_cmd = (cmd: SocketCommand) => {\n\tif (socket !== null && socket.readyState === WebSocket.OPEN) {\n\n\t\t// First empty the queue\n\t\twhile (queued_commands.length !== 0) {\n\t\t\tsocket.send(JSON.stringify(queued_commands.shift()))\n\t\t}\n\n\t\t// Send the requested command\n\t\tsocket.send(JSON.stringify(cmd))\n\t} else if (cmd !== null) {\n\t\tqueued_commands.push(cmd)\n\t\tconsole.debug(\"Socket is closed, command\", cmd, \"added to queue\")\n\t}\n}\n","\n\n{#if $stats.limits_init}\n\t\n\t\t{#if file.size > transfer_left}\n\t\t\t\n\t\t\t\tThis file is too large to download completely with your current\n\t\t\t\ttransfer limit. The first {formatDataVolume(transfer_left, 3)}\n\t\t\t\twill download at full speed, but the remaining\n\t\t\t\t{formatDataVolume(file.size - transfer_left, 3)} will take\n\t\t\t\tlonger\n\t\t\t
\n\t\t{/if}\n\n\t\t\n\t\t\tYou have used {formatDataVolume($stats.limits.transfer_limit_used, 3)} of\n\t\t\tyour daily {formatDataVolume($stats.limits.transfer_limit, 3)} transfer\n\t\t\tlimit. When the transfer limit is exceeded your download speed will\n\t\t\tbe reduced.\n\t\t
\n\n\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\tbolt Upgrade your account\n\t\t\t\t \n\t\t\t\tto disable the transfer limit\n\t\t\t \n\t\t
\n\n\t\t \n\t \n{/if}\n","\n\n\n\t
\n\t
\n\t\t \n\t
\n
\n\n\n","\n\n \n\n{#if file.allow_video_player}\n\t{#if !video_reload}\n\t\t\n\n\t\t\t{#if\n\t\t\t\tfile.mime_type === \"video/x-matroska\" ||\n\t\t\t\tfile.mime_type === \"video/quicktime\" ||\n\t\t\t\tfile.mime_type === \"video/x-ms-asf\"\n\t\t\t}\n\t\t\t\t
\n\t\t\t\t\tThis video file type is not compatible with every web\n\t\t\t\t\tbrowser. If the video fails to play you can try downloading\n\t\t\t\t\tthe video and watching it locally.\n\t\t\t\t
\n\t\t\t{/if}\n\n\t\t\t
\n\t\t\t\t\n\t\t\t\t
playing = false }\n\t\t\t\t\ton:play={() => playing = true }\n\t\t\t\t\ton:ended={() => dispatch(\"next\", {})}\n\t\t\t\t\ton:keydown={video_keydown}\n\t\t\t\t\tuse:video_position={() => file.id}\n\t\t\t\t>\n\t\t\t\t\t \n\t\t\t\t \n\n\t\t\t\t
\n\t\t\t\t\t
\n\t\t\t\t\t{#if is_list}\n\t\t\t\t\t\t
dispatch(\"prev\") }>\n\t\t\t\t\t\t\tskip_previous \n\t\t\t\t\t\t \n\t\t\t\t\t{/if}\n\t\t\t\t\t
seek(-10)}>\n\t\t\t\t\t\treplay_10 \n\t\t\t\t\t \n\t\t\t\t\t
\n\t\t\t\t\t\t{#if playing}\n\t\t\t\t\t\t\tpause \n\t\t\t\t\t\t{:else}\n\t\t\t\t\t\t\tplay_arrow \n\t\t\t\t\t\t{/if}\n\t\t\t\t\t \n\t\t\t\t\t
seek(10)}>\n\t\t\t\t\t\tforward_10 \n\t\t\t\t\t \n\t\t\t\t\t{#if is_list}\n\t\t\t\t\t\t
dispatch(\"next\") }>\n\t\t\t\t\t\t\tskip_next \n\t\t\t\t\t\t \n\t\t\t\t\t{/if}\n\t\t\t\t\t
\n\t\t\t\t\t
\n\t\t\t\t\t\t{#if player && player.muted}\n\t\t\t\t\t\t\tvolume_off \n\t\t\t\t\t\t{:else}\n\t\t\t\t\t\t\tvolume_up \n\t\t\t\t\t\t{/if}\n\t\t\t\t\t \n\t\t\t\t\t
\n\t\t\t\t\t\tfullscreen \n\t\t\t\t\t \n\t\t\t\t\t
\n\t\t\t\t
\n\t\t\t
\n\t\t
\n\n\t{/if}\n{:else}\n\t{file.name} \n\n\t\n\n\t\tThe online video player on pixeldrain is only available while logged in\n\t\tto an account, or if the uploading user has verified their e-mail\n\t\taddress. You can still download the video and watch it locally on your\n\t\tcomputer without an account.\n\n\t\t \n\t\t\n\t\t\tdownload Download\n\t\t \n\t\t\n\t\t\tlogin Log in\n\t\t \n\t\t\n\t\t\thow_to_reg Sign up\n\t\t \n\t \n\n\t{#if file.show_ads}\n\t\t \n\t{/if}\n{/if}\n\n\n","\n\n{title} \n\n\n","\n\n\n\t
\n\n\t{#if is_list}\n\t\t dispatch(\"prev\") }>\n\t\t\tskip_previous \n\t\t \n\t{/if}\n\t player.currentTime -= 10 }>\n\t\treplay_10 \n\t \n\t\n\t\t{#if playing}\n\t\t\tpause \n\t\t{:else}\n\t\t\tplay_arrow \n\t\t{/if}\n\t \n\t player.currentTime += 10 }>\n\t\tforward_10 \n\t \n\t{#if is_list}\n\t\t dispatch(\"next\") }>\n\t\t\tskip_next \n\t\t \n\t{/if}\n\t \n\n\t{#if file.id && !audio_reload}\n\t\t\n\t\t playing = false }\n\t\t\ton:play={() => playing = true }\n\t\t\ton:ended={() => {dispatch(\"next\", {})}}\n\t\t>\n\t\t\t \n\t\t \n\t{/if}\n\n\t \n\t{#if file.show_ads}\n\t\t \n\t{/if}\n \n\n\n","// Dead zone before the swipe action gets detected\nconst swipe_inital_offset = 25\n// Amount of pixels after which the navigation triggers\nconst swipe_trigger_offset = 75\n\nexport const swipe_nav = (\n\tnode: HTMLElement,\n\tprops: {\n\t\tenabled: boolean,\n\t\tprev: boolean,\n\t\tnext: boolean,\n\t\ton_prev: () => void,\n\t\ton_next: () => void,\n\t},\n) => {\n\tlet start_x = 0\n\tlet start_y = 0\n\tlet render_offset = 0\n\tlet enabled = props.enabled === undefined ? true : props.enabled\n\tlet prev = props.prev === undefined ? true : props.prev\n\tlet next = props.next === undefined ? true : props.next\n\n\tconst touchstart = (e: TouchEvent) => {\n\t\tstart_x = e.touches[0].clientX\n\t\tstart_y = e.touches[0].clientY\n\t\trender_offset = 0\n\t}\n\n\tconst touchmove = (e: TouchEvent) => {\n\t\tconst offset_x = e.touches[0].clientX - start_x\n\t\tif (!enabled || (offset_x < 0 && !next) || (offset_x > 0 && !prev)) {\n\t\t\treturn\n\t\t}\n\n\t\tconst abs_x = Math.abs(offset_x)\n\t\tconst abs_y = Math.abs(e.touches[0].clientY - start_y)\n\t\tconst neg = offset_x < 0 ? -1 : 1\n\n\t\t// The cursor must have moved at least 50 pixels and three times as much\n\t\t// on the x axis than the y axis for it to count as a swipe\n\t\tif (abs_x > swipe_inital_offset && abs_y < abs_x / 3) {\n\t\t\tset_offset((abs_x - swipe_inital_offset) * neg, false)\n\t\t} else {\n\t\t\tset_offset(0, true)\n\t\t}\n\t}\n\n\tconst touchend = (e: TouchEvent) => {\n\t\tif (!enabled) {\n\t\t\treturn\n\t\t}\n\n\t\tif (render_offset > swipe_trigger_offset) {\n\t\t\tset_offset(1000, true)\n\t\t\tprops.on_prev()\n\t\t} else if (render_offset < -swipe_trigger_offset) {\n\t\t\tset_offset(-1000, true)\n\t\t\tprops.on_next()\n\t\t} else {\n\t\t\tset_offset(0, true)\n\t\t}\n\t}\n\n\tconst set_offset = (off: number, animate: boolean) => {\n\t\trender_offset = off\n\n\t\tif (off === 0) {\n\t\t\t// Clear the transformation if the offset is zero\n\t\t\tnode.style.transform = \"\"\n\t\t\tnode.style.transition = \"\"\n\t\t} else {\n\t\t\tnode.style.transform = \"translateX(\" + off + \"px)\"\n\t\t\tif (animate) {\n\t\t\t\tnode.style.transition = \"transform 400ms\"\n\t\t\t}\n\t\t}\n\t}\n\n\tnode.addEventListener(\"touchstart\", touchstart)\n\tnode.addEventListener(\"touchmove\", touchmove)\n\tnode.addEventListener(\"touchend\", touchend)\n\n\t// Get the child image so we can listen for the loaded event. When the\n\t// loaded event fires we clear the transformations so that the image appears\n\t// in the original position again\n\tfor (let i = 0; i < node.childNodes.length; i++) {\n\t\tconst child = node.childNodes.item(i)\n\t\tif (child instanceof HTMLImageElement) {\n\t\t\tchild.addEventListener(\"load\", () => set_offset(0, false))\n\t\t}\n\t}\n\n\treturn {\n\t\tupdate(props: { enabled: boolean, prev: boolean, next: boolean }) {\n\t\t\tenabled = props.enabled === undefined ? true : props.enabled\n\t\t\tprev = props.prev === undefined ? true : props.prev\n\t\t\tnext = props.next === undefined ? true : props.next\n\t\t\tset_offset(0, false)\n\t\t},\n\t\tdestroy() {\n\t\t\tnode.removeEventListener(\"touchstart\", touchstart)\n\t\t\tnode.removeEventListener(\"touchmove\", touchmove)\n\t\t\tnode.removeEventListener(\"touchend\", touchend)\n\t\t}\n\t}\n}\n","\n\n \n\n dispatch(\"prev\"),\n\t\ton_next: () => dispatch(\"prev\"),\n\t}}\n>\n\t\n\t
\n
\n\n\n","\n\n\n\n\n","\n\n\n\n\t{#if text_type === \"markdown\"}\n\t\t
\n\t{:else if text_type === \"text\"}\n\t\t
\n\t\t\tLoading...\n\t\t \n\t{:else if text_type === \"code\"}\n\t\t
\n\t\t\tLoading...\n\t\t \n\t{/if}\n
\n\n\n","\n\n\n\n \n\n\n\tType: {file.mime_type} \n\tSize: {formatDataVolume(file.size, 3)} \n\tNo preview is available for this file type. Download to view it locally.\n\t \n\t {dispatch(\"download\")}}>\n\t\tdownload \n\t\tDownload \n\t \n \n\n{#if file.show_ads}\n\t \n{/if}\n","\n\n\n\n\n\tUnavailable for legal reasons \n\t\n\t\tThis file has been removed for violating pixeldrain's\n\t\tcontent policy . Type of abuse: {file.abuse_type}.\n\t
\n\t\n\t\t{#if file.abuse_reporter_name === \"User submitted reports\"}\n\n\t\t\tThe file was reported by users of pixeldrain with the report button\n\t\t\tin the toolbar.\n\n\t\t{:else}\n\n\t\t\tThe file was reported through pixeldrain's abuse e-mail address.\n\n\t\t{/if}\n\t
\n\t\n\t\tPixeldrain has zero tolerance towards abuse. The IP address this file\n\t\toriginated from has been banned and is no longer able to upload files to\n\t\tpixeldrain.\n\t
\n \n\n{#if file.can_download}\n\t\n\n\t\tThis file cannot be shared, but since you are the uploader of the file\n\t\tyou can still download it.\n\t\t \n\t\t {dispatch(\"download\")}}>\n\t\t\tdownload \n\t\t\tDownload \n\t\t \n\t \n{/if}\n","\n\n\n\t{#if file.availability === \"file_rate_limited_captcha_required\"}\n\t\t\n\t\t\tfile_download_off \n\t\t\tHotlink protection enabled\n\t\t \n\t\t\n\t\t\tHotlinking protection has been enabled for this file. This happens\n\t\t\twhen a file is downloaded many times outside of our file viewer page\n\t\t\t(this page). You can find more information about hotlink protection\n\t\t\ton the FAQ page .\n\t\t
\n\t{:else if file.availability === \"ip_download_limited_captcha_required\"}\n\t\t\n\t\t\tfile_download_off \n\t\t\tDownload limit reached\n\t\t \n\t\t\n\t\t\tYou have reached your download limit for today. Without a pixeldrain\n\t\t\taccount you are limited to downloading {$stats.limits.download_limit} files\n\t\t\tor {formatDataVolume($stats.limits.transfer_limit, 3)} per 48 hours. This limit\n\t\t\tis counted per IP address, so if you're on a shared network it's\n\t\t\tpossible that others have also contributed to this limit.\n\t\t
\n\t\t\n\t\t\tIn the last 24 hours you have downloaded\n\t\t\t{$stats.limits.download_limit_used} files and used\n\t\t\t{formatDataVolume($stats.limits.transfer_limit_used, 3)} bandwidth.\n\t\t
\n\t{/if}\n\t\n\t\tThis warning disappears when you have a\n\t\t\n\t\t\tpremium account\n\t\t \n\t\tor when the uploader of the file enables\n\t\thotlinking on their Pro account (and\n\t\ttheir data cap has not been used up). Using a download manager with a\n\t\tPro account is allowed, it will not trigger this warning for other\n\t\tfiles.\n\t
\n\t\n\t\tContinue downloading\n\t \n\t\n\t\tThe file can be downloaded like usual by clicking the download button.\n\t\tYou will have to complete a CAPTCHA test to prove that you're not a\n\t\trobot.\n\t
\n \n\n\n\tName: {file.name} \n\tType: {file.mime_type} \n\t {dispatch(\"download\")}}>\n\t\tdownload Download\n\t \n\t\n\t\tbolt Upgrade your account\n\t \n \n","\n\n\n\t\n\t\n\t\n \n","\n\n\n\t{#each Object.entries(item.children) as [name, child]}\n\t\t\n\t\t\t{name} ({formatDataVolume(child.size, 3)}) \n\t\t\t{#if child.children}\n\t\t\t\t \n\t\t\t{/if}\n\t\t \n\t{/each}\n \n\n\n","\n\n\n\tcontent_copy \n\t\n\t\t{#if success}\n\t\t\tCopied!\n\t\t{:else if failed}\n\t\t\tCopy failed\n\t\t{:else}\n\t\t\t \n\t\t{/if}\n\t \n \n\n\n","\n\n\n\n\n\t{#if status === \"finished\"}\n\t\tCreated by: {torrent.created_by} \n\t\tComment: {torrent.comment} \n\t\tCreated at: {formatDate(new Date(torrent.created_at), true, true, true)} \n\t\tInfo hash: {torrent.info_hash} \n\t\t\n\t\t\t \n\t\t\tOpen magnet link \n\t\t \n\t\tCopy magnet link \n\t{:else if status === \"too_large\"}\n\t\t\n\t\t\tTorrent file is too large to parse. Please download the file and\n\t\t\tadd it to your torrent client locally.\n\t\t
\n\t{:else if status === \"parse_failed\"}\n\t\t\n\t\t\tTorrent file could not be parsed. It may be corrupted.\n\t\t
\n\t{/if}\n\t {dispatch(\"download\")}} class=\"button\">\n\t\tdownload \n\t\tDownload torrent file \n\t \n \n\n\n\t\n\t\tHow do I download this? (expand for more information) \n\t\t\n\t\t\tThis is a torrent file, which means you will need a torrent client to\n\t\t\tdownload it. Here are some good torrent clients for various platforms:\n\t\t
\n\t\t\n\t\t\n\t\t\tAfter installing your torrent client you will be able to use the\n\t\t\t Open magnet link \n\t\t\tbutton to download the files in your torrent client.\n\t\t
\n\t\tWhat is a torrent? \n\t\t\n\t\t\tBitTorrent is a\n\t\t\tpeer-to-peer network for sharing files. This torrent file does not\n\t\t\tactually contain the files listed below, instead it contains\n\t\t\tinstructions for your torrent client to download the files from\n\t\t\tother people who happen to be downloading the same files currently.\n\t\t\tThis means that instead of connecting to a single server (like\n\t\t\tpixeldrain), you will be connecting to other people on the internet\n\t\t\tto download these files.\n\t\t
\n\t\t\n\t\t\tTorrents are a highly efficient and free method of transferring\n\t\t\tfiles over the internet. Since the bandwidth is shared directly\n\t\t\tbetween users there is no need for expensive servers to host the\n\t\t\tfiles for you.\n\t\t
\n\t\tIs this safe? \n\t\t\n\t\t\tYour torrent client will make sure that the files you receive from\n\t\t\tyour peers are actually what they say it is. This makes it just as\n\t\t\tsafe as any other form of downloading. Like always when downloading\n\t\t\tfiles you still need to be aware of what you are downloading. Don't\n\t\t\tjust blindly trust any file anyone sends you.\n\t\t
\n\t\tIs it private? \n\t\t\n\t\t\tWhen downloading a torrent file you will be part of the so-called\n\t\t\t'torrent swarm'. Anyone in the swarm can see each other's IP\n\t\t\taddresses. This is not a bad thing on its own, but there a few cases\n\t\t\tin which this can be abused.\n\t\t
\n\t\t\n\t\t\tAnyone in the swarm will be able to see what you are downloading,\n\t\t\teven across different torrents. This is something to keep in mind\n\t\t\twhen downloading torrents. If someone can link your IP address to\n\t\t\tyour identity then there are ways to find out which files you have\n\t\t\tdownloaded in the past (provided that your IP address has not\n\t\t\tchanged since then).\n\t\t
\n\t\t\n\t\t\tIf you are downloading copyrighted material (which I do not condone)\n\t\t\tthen rightsholders will be able to see your IP address. In most\n\t\t\tcases this is not a problem because your ISP will still protect your\n\t\t\tidentity. But there are some countries (notably the USA) where your\n\t\t\tISP will not respect your right to privacy and the rightsholder will\n\t\t\tbe able to contact you. If this worries you then you should look\n\t\t\tinto VPN services to protect your privacy, like Mullvad .\n\t\t
\n\t \n \n\n{#if status === \"finished\"}\n\t\n\t\tFiles in this torrent \n\t\t \n\t \n{/if}\n\n\n","\n\n\n{#each Object.entries(item.children) as [name, child]}\n\t{#if child.children}\n\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t{name}\n\t\t\t\t\t(\n\t\t\t\t\t\t{formatDataVolume(child.size, 3)}\n\t\t\t\t\t\t{#if child.download_url}\n\t\t\t\t\t\t\t
download \n\t\t\t\t\t\t{/if}\n\t\t\t\t\t)\n\t\t\t\t
\n\t\t\t \n\n\t\t\t\n\t\t\t{#if child.details_open}\n\t\t\t\t \n\t\t\t{/if}\n\t\t \n\t{/if}\n{/each}\n\n\n\n\t{#each Object.entries(item.children) as [name, child]}\n\t\t{#if !child.children}\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t{name}\n\t\t\t\t\t(\n\t\t\t\t\t\t{formatDataVolume(child.size, 3)}\n\t\t\t\t\t\t{#if child.download_url}\n\t\t\t\t\t\t\t
download \n\t\t\t\t\t\t{/if}\n\t\t\t\t\t)\n\t\t\t\t
\n\t\t\t \n\t\t{/if}\n\t{/each}\n \n\n\n","\n\n\n\n\n\t{#if archive_type === \"7z\"}\n\t\tThis is a 7-zip archive. You will need\n\t\t7-zip or compatible software to\n\t\textract it \n\t{/if}\n\n\tCompressed size: {formatDataVolume(file.size, 3)} \n\t{#if !truncated}\n\t\tUncompressed size: {formatDataVolume(zip.size, 3)} (Ratio: {comp_ratio.toFixed(2)}x) \n\t{/if}\n\tUploaded on: {formatDate(file.date_upload, true, true, true)}\n\t \n\t {dispatch(\"download\")}}>\n\t\tdownload \n\t\tDownload \n\t \n \n\n{#if file.show_ads}\n\t \n{/if}\n\n{#if status === \"finished\"}\n\t\n\t\tFiles in this archive \n\t\t{#if truncated}\n\t\t\t\n\t\t\t\tDue to the large size of this archive, the results have been\n\t\t\t\ttruncated. The list below is incomplete!\n\t\t\t
\n\t\t{/if}\n\n\t\t \n\t \n{:else if status === \"parse_failed\"}\n\t\n\t\t\n\t\t\tZip archive could not be parsed. This usually means that the archive\n\t\t\tis encrypted or that it uses an unsupported compression format.\n\t\t
\n\t \n{/if}\n","\n\n\n\t\n\t\n\t\tPixeldrain's free tier is supported by my Patrons. There's only so much\n\t\tthat you can do with the budget they provide.\n\t\t{formatDataVolume($stats.limits.transfer_limit, 3)} per day is about the\n\t\tmost I can give away for free while keeping it fair for everyone, and\n\t\taccording to our records you have already downloaded\n\t\t{formatDataVolume($stats.limits.transfer_limit_used, 3)}.\n\t
\n\t\n\t\tIt's not that I want to withold this file from you, it's just that I\n\t\tdon't want pixeldrain to fall into bankruptcy like so many of the\n\t\twebsites that came before me. So if you really want this file you have a\n\t\tfew options:\n\t
\n\t\n\t\t\n\t\t\tCome back tomorrow when your free transfer limit resets\n\t\t \n\t\t\n\t\t\tDownload the file at a limited rate of {formatDataVolume($stats.limits.speed_limit, 3)}/s. This will take at\n\t\t\tleast {formatDuration((file_size/($stats.limits.speed_limit))*1000, 0)}\n\t\t \n\t\t\n\t\t\t\n\t\t\t\tbolt Get Premium\n\t\t\t \n\t\t\tand earn my eternal gratitude\n\t\t\t{#if !window.user_authenticated}\n\t\t\t\t(you will need a pixeldrain account to\n\t\t\t\treceive the benefits)\n\t\t\t{/if}\n\t\t \n\t \n \n\n\n\t\n\t\t\n\t\t\t{file_name} \n\t\t\tType {file_type} \n\t\t\tSize {formatDataVolume(file_size, 3)} \n\t\t \n\t
\n\t {dispatch(\"download\")}}>\n\t\tdownload Download\n\t \n \n\n\n\tAlso, I believe you have my stapler. Please give it back.\n \n\n\n","\n\n{#if viewer_type === \"loading\"}\n\t\n\t\t \n\t
\n{:else if viewer_type === \"abuse\"}\n\t \n{:else if !premium_download && $stats.limits.transfer_limit_used > $stats.limits.transfer_limit}\n\t \n{:else if viewer_type === \"overload\"}\n\t\n\t\t\n\t\t\t
\n\t\t\t\tPixeldrain's servers are currently overloaded. There are too\n\t\t\t\tmany people downloading too many things. In order to ensure\n\t\t\t\tstability for our paying customers, free users are asked to\n\t\t\t\tcomplete a CAPTCHA before starting a new download.\n\t\t\t
\n\t\t
\n\t \n{:else if viewer_type === \"rate_limit\"}\n\t \n{:else if viewer_type === \"image\"}\n\t \n{:else if viewer_type === \"video\"}\n\t \n{:else if viewer_type === \"audio\"}\n\t \n{:else if viewer_type === \"pdf\"}\n\t \n{:else if viewer_type === \"text\"}\n\t \n{:else if viewer_type === \"torrent\"}\n\t \n{:else if viewer_type === \"zip\"}\n\t \n{:else if viewer_type === \"file\"}\n\t \n{/if}\n\n\n","\n\n\n\t
\n\t\tphoto_library \n\t\tGallery\n\t \n\t
\n
\n\n\n","\n\n\n\t
Views
\n\t
{formatThousands(views)}
\n\t
Downloads
\n\t
{formatThousands(downloads)}
\n\t
Size
\n\t
{formatDataVolume(size, 3)}
\n
\n\n\n","\n\n\n\t{#if loading}\n\t\t
\n\t\t\t \n\t\t
\n\t{/if}\n\t{#if result_text !== \"\"}\n\t\t
\n\t\t\t{result_text}\n\t\t
\n\t{/if}\n\n\t{#if list.can_edit}\n\t\t
Edit album \n\t\tName:
\n\t\t
\n\t\t
Delete \n\t\t
\n\t\t\tWhen you delete an album the files in the album will not be deleted,\n\t\t\tonly the album itself.\n\t\t
\n\t\t
\n\t\t\tdelete Delete album\n\t\t \n\t{/if}\n\n\t{#if file.can_edit}\n\t\t
Edit file \n\t\tName:
\n\t\t
\n\t\t
Delete \n\t\t
\n\t\t\tWhen you delete a file it cannot be recovered.\n\t\t\tNobody will be able to download it and the link will\n\t\t\tstop working. The file will also disappear from any\n\t\t\tlists it's contained in.\n\t\t
\n\t\t
\n\t\t\tdelete Delete file\n\t\t \n\t{/if}\n
\n\n\n","\n\n\n\t {set(\"\")}}>\n\t\tNone\n\t \n\t {set(\"nord\")}}>\n\t\tNord\n\t \n\t {set(\"nord_dark\")}}>\n\t\tdark\n\t \n\t {set(\"nord_light\")}}>\n\t\tlight\n\t \n\t {set(\"solarized\")}}>\n\t\tSolarized\n\t \n\t {set(\"solarized_dark\")}}>\n\t\tdark\n\t \n\t {set(\"solarized_light\")}}>\n\t\tlight\n\t \n\t {set(\"purple_drain\")}}>\n\t\tPurple drain\n\t \n\t {set(\"classic\")}}>\n\t\tClassic\n\t \n\t {set(\"maroon\")}}>\n\t\tMaroon\n\t \n\t {set(\"hacker\")}}>\n\t\tHacker\n\t \n\t {set(\"canta\")}}>\n\t\tCanta\n\t \n\t {set(\"skeuos\")}}>\n\t\tSkeuos\n\t \n\t {set(\"sweet\")}}>\n\t\tSweet\n\t \n
\n\n\n","\n\n\n\t
\n\t\t
\n\t\t\tIf you have a website you can embed pixeldrain files in your own\n\t\t\twebpages here.\n\t\t
\n\t\t
\n\t\t\tThe IFrame embed gives you a frame with a slightly more minimalistic\n\t\t\tfile viewer in it. The embedded file viewer has a fullscreen button\n\t\t\tand the toolbar is collapsed by default. If you do not have a\n\t\t\tpixeldrain Pro account the frame will also have advertisements in\n\t\t\tit.\n\t\t
\n\t\t
\n\t\t\tThe hotlink embed option only works for single files uploaded with a\n\t\t\tPro account. You can use this to directly embed a video player,\n\t\t\taudio player, photo element or a download button in your site. Make\n\t\t\tsure you have hotlinking enabled on your\n\t\t\tsharing settings page or the\n\t\t\tembed will not work.\n\t\t
\n\t
\n\t
\n\t\t\n\t\t\tcode \n\t\t\tIFrame\n\t\t \n\t\t{#if file.id}\n\t\t\t\n\t\t\t\tcode \n\t\t\t\tHotlink\n\t\t\t \n\t\t{/if}\n\t
\n\n\t
\n\t\t{#if tab === \"iframe\"}\n\t\t\t
Appearance \n\t\t\t
\n\t\t\t\tYou can change the pixeldrain theme for your embedded file. Try the\n\t\t\t\tavailable themes here .\n\t\t\t
\n\n\t\t\t
set_style(e.detail)}> \n\t\t{:else}\n\t\t\t
Direct link \n\t\t\t
\n\t\t\t\tHotlinking is only supported on Pro \n\t\t\t\taccounts. If this file was not uploaded with a Pro account the\n\t\t\t\tdownload will be blocked.\n\t\t\t
\n\t\t\t
\n\t\t\t\tYou can directly download the file from this link without using the\n\t\t\t\tfile viewer:\n\t\t\t\t \n\t\t\t\t{domain_url()}{file.get_href}\n\t\t\t
\n\t\t{/if}\n\n\t\t
Code \n\t\t
\n\t\t\tPut this code in your website to embed the file.\n\t\t
\n\t\t
\n\t\t\t\n\t\t\t \n\t\t\tCopy HTML \n\t\t\t\n\t\t\t\tvisibility Show example\n\t\t\t \n\t\t
\n\t\t
Example \n\t
\n\t
\n
\n\n\n","\n\n\n\t
\n\t\tIf you think this file violates pixeldrain's\n\t\tcontent policy you can report it for moderation\n\t\twith this form. For copyright infringement notices or urgent matters\n\t\tplease use our\n\t\tabuse e-mail address .\n\t
\n\t
\n
\n\n\n","\n\n{#if ad_type === \"patreon_support\"}\n\n\t\n\n{:else if ad_type === \"socials\"}\n\n\t\n\n{:else if ad_type === \"reviews\"}\n\n\t\n\n{:else if ad_type === \"ad_block\"}\n\n\t\n\n{/if}\n\n\n","\n\n\n\tShare on:
\n\t
\n\t\t\n\t\t\t \n\t\t \n\t\tE-Mail\n\t \n\t
\n\t\t\n\t\t\t \n\t\t \n\t\tReddit\n\t \n\t
\n\t\t\n\t\t\t \n\t\t \n\t\tTwitter\n\t \n\t
\n\t\t\n\t\t\t \n\t\t \n\t\tFacebook\n\t \n\t
\n\t\t\n\t\t\t \n\t\t \n\t\tTumblr\n\t \n
\n\n\n","import { cubicOut } from '../easing/index.js';\nimport { is_function } from '../internal/index.js';\n\n/**\n * The flip function calculates the start and end position of an element and animates between them, translating the x and y values.\n * `flip` stands for [First, Last, Invert, Play](https://aerotwist.com/blog/flip-your-animations/).\n *\n * https://svelte.dev/docs/svelte-animate#flip\n * @param {Element} node\n * @param {{ from: DOMRect; to: DOMRect }} fromTo\n * @param {import('./public.js').FlipParams} params\n * @returns {import('./public.js').AnimationConfig}\n */\nexport function flip(node, { from, to }, params = {}) {\n\tconst style = getComputedStyle(node);\n\tconst transform = style.transform === 'none' ? '' : style.transform;\n\tconst [ox, oy] = style.transformOrigin.split(' ').map(parseFloat);\n\tconst dx = from.left + (from.width * ox) / to.width - (to.left + ox);\n\tconst dy = from.top + (from.height * oy) / to.height - (to.top + oy);\n\tconst { delay = 0, duration = (d) => Math.sqrt(d) * 120, easing = cubicOut } = params;\n\treturn {\n\t\tdelay,\n\t\tduration: is_function(duration) ? duration(Math.sqrt(dx * dx + dy * dy)) : duration,\n\t\teasing,\n\t\tcss: (t, u) => {\n\t\t\tconst x = u * dx;\n\t\t\tconst y = u * dy;\n\t\t\tconst sx = t + (u * from.width) / to.width;\n\t\t\tconst sy = t + (u * from.height) / to.height;\n\t\t\treturn `transform: ${transform} translate(${x}px, ${y}px) scale(${sx}, ${sy});`;\n\t\t}\n\t};\n}\n","\n\n \n\n\n\t
\n\t\t{#each tableColumns as col}\n\t\t\t\n\t\t\t\t{col.name}\n\t\t\t \n\t\t{/each}\n\t
\n\t
\n\t\n
\n\n\n","\n\n \n\n\n\t\n\t\n\t\t \n\t
\n \n\n\n","\n\n\n\n {add_files(e.detail)}}\n\tmulti_select={true}\n\ttitle=\"Select files to add to album\">\n \n\n\n","\n\n\n\t{#if load_captcha_script}\n\t\t\n\t{/if}\n \n\n\n\t{#if captcha_type === \"rate_limit\"}\n\t\t\n\t\t\tThis file is using a suspicious amount of bandwidth relative to\n\t\t\tits popularity. To continue downloading this file you will have\n\t\t\tto prove that you're a human first.\n\t\t
\n\t{:else if captcha_type === \"malware\"}\n\t\t\n\t\t\tAccording to our scanning systems this file may contain a virus.\n\t\t\tYou can continue downloading this file at your own risk, but you\n\t\t\twill have to prove that you're a human first.\n\t\t
\n\t{:else if captcha_type === \"ip_rate_limit\"}\n\t\t\n\t\t\tA lot of downloads have originated from this IP address lately.\n\t\t\tPlease prove that you are not a robot:\n\t\t
\n\t{:else}\n\t\t\n\t\t\t{error_message}\n\t\t
\n\t\t\n\t\t\tReponse code: {error_code}\n\t\t
\n\t{/if}\n\t \n\t
\n \n\n\n\t\n\t\tCan't download file: {error_code}\n\t
\n\t\n\t\t{error_message}\n\t
\n \n\n\n","\n\n{#if src}\n\t\n{/if}\n\n\n","\n\n{#if loading}\n\t\n\t\t \n\t
\n{/if}\n\n\n","\n\n\n\n\t{#if $stats.limits_init}\n\t\t
\n\t\t\t{title}\n\t\t
\n\t\t
\n\t\t\t{title}\n\t\t
\n\t{/if}\n
\n\n\n","\n\n\n\t
Files
\n\t
{list.files.length}
\n\t
Views
\n\t
{formatThousands(views)}
\n\t
Downloads
\n\t
{formatThousands(downloads)}
\n\t
Size
\n\t
{formatDataVolume(size, 3)}
\n
\n\n\n","\n\n { dragging = true }}\n\ton:dragenter|preventDefault|stopPropagation={() => { dragging = true }}\n\ton:dragleave|preventDefault|stopPropagation={() => { dragging = false }}\n\ton:drop={drop}\n\ton:paste={paste}\n/>\n\n{#if dragging}\n\t\n\t\tDrop files here to upload them\n\t
\n{/if}\n\n\n","\n\n\n\t{job.name}
\n\t{#if error_code !== \"\"}\n\t\t{error_message}
\n\t\t{error_code}
\n\t{/if}\n\t
\n \n\n\n","// Uploads a file to the logged in user's pixeldrain account. If no user is\n// logged in the file is uploaded anonymously.\n//\n// on_progress reports progress on the file upload, parameter 1 is the uploaded\n// file size and parameter 2 is the total file size\n//\n// on_success is called when the upload is done, the only parameter is the file\n// ID\n//\n// on_error is called when the upload has failed. The parameters are the error\n// code and an error message\nexport const upload_file = (file, name, on_progress, on_success, on_error) => {\n\t// Check the file size limit. For free accounts it's 20 GB\n\tif (window.user.subscription.file_size_limit === 0) {\n\t\twindow.user.subscription.file_size_limit = 20e9\n\t}\n\n\tif (file.size > window.user.subscription.file_size_limit) {\n\t\ton_failure(\n\t\t\t\"file_too_large\",\n\t\t\t\"This file is too large. Check out the Pro subscription to increase the file size limit\"\n\t\t)\n\t\treturn\n\t}\n\n\tlet xhr = new XMLHttpRequest();\n\txhr.open(\"PUT\", window.api_endpoint + \"/file/\" + encodeURIComponent(name), true);\n\txhr.timeout = 86400000; // 24 hours, to account for slow connections\n\n\txhr.upload.addEventListener(\"progress\", evt => {\n\t\tif (on_progress && evt.lengthComputable) {\n\t\t\ton_progress(evt.loaded, evt.total)\n\t\t}\n\t});\n\n\txhr.onreadystatechange = () => {\n\t\t// readystate 4 means the upload is done\n\t\tif (xhr.readyState !== 4) {\n\t\t\treturn\n\t\t}\n\n\t\tif (xhr.status >= 100 && xhr.status < 400) {\n\t\t\t// Request is a success\n\t\t\ton_success(JSON.parse(xhr.response).id)\n\t\t} else if (xhr.status >= 400) {\n\t\t\t// Request failed\n\t\t\tconsole.log(\"Upload error. status: \" + xhr.status + \" response: \" + xhr.response);\n\n\t\t\tlet resp;\n\t\t\tif (xhr.status === 429) {\n\t\t\t\tresp = {\n\t\t\t\t\tvalue: \"too_many_requests\",\n\t\t\t\t\tmessage: \"Too many requests. Please wait a few seconds\",\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tresp = JSON.parse(xhr.response)\n\t\t\t}\n\n\t\t\ton_error(resp.value, resp.message)\n\t\t} else if (xhr.status === 0) {\n\t\t\ton_error(\"request_failed\", \"Your request did not arrive, check your network connection\")\n\t\t} else {\n\t\t\ton_error(xhr.responseText, xhr.responseText)\n\t\t}\n\t};\n\n\txhr.send(file);\n}\n","\n\n \n\n \n\n{#if visible}\n\t\n{/if}\n\n{#if drop_upload}\n\t upload_files(e.detail)}/>\n{/if}\n\n\n","\n\n\n\n uploads_finished(e.detail)}/>\n","\n\n\t \n \n\n\n","\n\n\n\t{symbol}\n\t 0}>\n\t\t{(amount / 1000000).toLocaleString(undefined, {minimumFractionDigits: precision, maximumFractionDigits: precision})}\n\t \n \n\n\n","// Response types\n// ==============\n\nexport type GenericResponse = {\n\tvalue: string,\n\tmessage: string,\n\terrors?: GenericResponse[],\n\textra?: { [index: string]: Object },\n}\n\nexport type User = {\n\tusername: string,\n\temail: string,\n\totp_enabled: boolean,\n\tsubscription: Subscription,\n\tstorage_space_used: number,\n\tfilesystem_storage_used: number,\n\tis_admin: boolean,\n\tbalance_micro_eur: number,\n\thotlinking_enabled: boolean,\n\tmonthly_transfer_cap: number,\n\tmonthly_transfer_used: number,\n\tfile_viewer_branding: Map,\n\tfile_embed_domains: string,\n\tskip_file_viewer: boolean,\n\taffiliate_user_name: string,\n}\n\nexport type Subscription = {\n\tid: string,\n\tname: string,\n\ttype: string,\n\tfile_size_limit: number,\n\tfile_expiry_days: number,\n\tstorage_space: number,\n\tprice_per_tb_storage: number,\n\tprice_per_tb_bandwidth: number,\n\tmonthly_transfer_cap: number,\n\tfile_viewer_branding: boolean,\n\tfilesystem_access: boolean,\n\tfilesystem_storage_limit: number,\n}\n\n// Utility funcs\n// =============\n\nexport const get_endpoint = () => {\n\tif ((window as any).api_endpoint !== undefined) {\n\t\treturn (window as any).api_endpoint as string\n\t}\n\tconsole.warn(\"api_endpoint property is not defined on window\")\n\treturn \"/api\"\n}\n\nexport const get_hostname = () => {\n\tif ((window as any).server_hostname !== undefined) {\n\t\treturn (window as any).server_hostname as string\n\t}\n\tconsole.warn(\"server_hostname property is not defined on window\")\n\treturn \"undefined\"\n}\n\nexport const check_response = async (resp: Response) => {\n\tlet text = await resp.text()\n\tif (resp.status >= 400) {\n\t\tlet error: any\n\t\ttry {\n\t\t\terror = JSON.parse(text) as GenericResponse\n\t\t} catch (err) {\n\t\t\terror = text\n\t\t}\n\t\tthrow error\n\t}\n\treturn JSON.parse(text)\n}\n\nexport const dict_to_form = (dict: Object) => {\n\tlet form = new FormData()\n\tfor (let key of Object.keys(dict)) {\n\t\tif (dict[key] === undefined) {\n\t\t\tcontinue\n\t\t} else if (dict[key] instanceof Date) {\n\t\t\tform.append(key, new Date(dict[key]).toISOString())\n\t\t} else if (typeof dict[key] === \"object\") {\n\t\t\tform.append(key, JSON.stringify(dict[key]))\n\t\t} else {\n\t\t\tform.append(key, dict[key])\n\t\t}\n\t}\n\treturn form\n}\n\n// API methods\n// ===========\n\nexport const get_user = async () => {\n\tif ((window as any).user !== undefined) {\n\t\treturn (window as any).user as User\n\t}\n\n\tconsole.warn(\"user property is not defined on window\")\n\n\treturn await check_response(await fetch(get_endpoint() + \"/user\")) as User\n}\n\nexport const put_user = async (data: Object) => {\n\tcheck_response(await fetch(\n\t\tget_endpoint() + \"/user\",\n\t\t{ method: \"PUT\", body: dict_to_form(data) },\n\t))\n\n\t// Update the window.user variable\n\tfor (let key of Object.keys(data)) {\n\t\t((window as any).user as User)[key] = data[key]\n\t}\n}\n\n\nexport type VATRate = {\n\tname: string,\n\tvat: number,\n\talpha2: string,\n\talpha3: string,\n}\nexport const get_misc_vat_rate = async (country_code: string) => {\n\treturn await check_response(await fetch(get_endpoint() + \"/misc/vat_rate/\" + country_code)) as VATRate\n}\n","import { writable } from \"svelte/store\";\nimport { get_user, type Subscription, type User } from \"./PixeldrainAPI\";\n\nexport const user = writable(\n\t{ subscription: {} as Subscription } as User,\n\t(set: (value: User) => void) => {\n\t\tget_user().then((u: User) => {\n\t\t\tset(u)\n\t\t}).catch((err: any) => {\n\t\t\talert(\"Could not fetch user:\\n\" + JSON.stringify(err))\n\t\t})\n\t}\n)\n","\n\n\n\t
\n\t\t{#if !hide_logo}\n\t\t\t \n\t\t{/if}\n\t\t\n\t\t\t{$user.username === \"\" ? no_login_label : $user.username}\n\t\t \n\t \n
\n\n\n\n\n\t\n \n\n\n","\n\n\n\t \n\t\n\t\t\n\t\t\tHi! {referral} wants you to sponsor their pixeldrain account. This\n\t\t\twill give them €0.50 every month in pixeldrain prepaid credit. They\n\t\t\tcan use this credit to get a discount on their file storage and\n\t\t\tsharing costs. Here is a short summary of what this entails:\n\t\t
\n\t\t\n\t\t\t\n\t\t\t\tSponsoring only works while you have an active subscription\n\t\t\t\tplan. When your subscription deactivates the creator will no\n\t\t\t\tlonger receive commissions.\n\t\t\t \n\t\t\t\n\t\t\t\tPixeldrain credit cannot be cashed out. So they are not earning\n\t\t\t\treal money with this.\n\t\t\t \n\t\t\t\n\t\t\t\tThis does not cost you any extra money. The commissions paid out\n\t\t\t\tto the creator are paid for by pixeldrain itself.\n\t\t\t \n\t\t\t\n\t\t\t\tYou can change who you are sponsoring at any time on your account settings page .\n\t\t\t \n\t\t\t\n\t\t\t\tIf you want to know more about the affiliate program check out\n\t\t\t\tthe Q&A page .\n\t\t\t \n\t\t \n\t\t\n\t\t\tIf you click 'Accept' then the requested affiliate code will be\n\t\t\tadded to your account and the creator will start earning. If you\n\t\t\tchoose 'Deny' then we will never show this pop-up again.\n\t\t
\n\t\t\n\t\t\t deny()}>\n\t\t\t\tDeny\n\t\t\t \n\t\t\t allow()}>\n\t\t\t\tAccept\n\t\t\t \n\t\t
\n\t \n \n\n\n","\n\n\n\n\n\t\n\n\t{#if is_list && view === \"file\"}\n\t\t
open_file_index(e.detail)}\n\t\t\ton:toggle_gallery={toggle_gallery}\n\t\t>\n\t\t \n\t{/if}\n\n\t
\n\n\t
\n\t\t
\n\n\t\t
\n\t\t\t{#if view === \"file\"}\n\t\t\t\t { if (list_navigator) { list_navigator.prev() }}}\n\t\t\t\t\ton:next={() => { if (list_navigator) { list_navigator.next() }}}\n\t\t\t\t\ton:loading={e => {loading = e.detail}}\n\t\t\t\t\ton:reload={reload}\n\t\t\t\t/>\n\t\t\t{:else if view === \"gallery\"}\n\t\t\t\t list_updater.update(e.detail)}\n\t\t\t\t\ton:pick_files={() => list_updater.pick_files()}\n\t\t\t\t\ton:upload_files={e => list_updater.upload_files(e.detail)}\n\t\t\t\t/>\n\t\t\t{/if}\n\t\t
\n\n\t\t
\n\t
\n\n\t{#if ads_enabled}\n\t\t
\n\t\t
\n\t{:else if custom_footer}\n\t\t
\n\t{/if}\n\n\t
{details_visible = e.detail}} title=\"File details\" width=\"1000px\">\n\t\t \n\t \n\n\t
{qr_visible = e.detail}} title=\"QR code\" width=\"500px\">\n\t\t \n\t \n\n\t
{edit_visible = e.detail}} title={\"Editing \"+file.name}>\n\t\t \n\t \n\n\t
{embed_visible = e.detail}} title=\"Embed file\" width=\"820px\">\n\t\t \n\t \n\n\t
{report_visible = e.detail}} title=\"Report abuse\" width=\"800px\">\n\t\t \n\t \n\n\t
\n\n\t{#if is_list && list.can_edit}\n\t\t
{loading = e.detail}}\n\t\t/>\n\t{/if}\n\n\t\n\t\n\n\t\n \n\n\n","import App from './file_viewer/FileViewer.svelte';\n\nconst app = new App({\n\ttarget: document.getElementById(\"body\"),\n\tprops: {}\n});\n\nexport default app;\n"],"names":["noop","src_url_equal_anchor","identity","x","run","fn","blank_object","Object","create","run_all","fns","forEach","is_function","thing","safe_not_equal","a","b","src_url_equal","element_src","url","document","createElement","href","component_subscribe","component","store","callback","$$","on_destroy","push","_len","arguments","length","callbacks","Array","_key","_step","_iterator","_createForOfIteratorHelper","s","n","done","value","undefined","err","e","f","unsub","subscribe","unsubscribe","create_slot","definition","ctx","$$scope","slot_ctx","get_slot_context","tar","src","k","assign","slice","get_slot_changes","dirty","lets","merged","len","Math","max","i","update_slot_base","slot","slot_definition","slot_changes","get_slot_context_fn","slot_context","p","get_all_dirty_from_scope","action_destroyer","action_result","destroy","is_client","window","now","performance","Date","raf","cb","requestAnimationFrame","tasks","Set","run_tasks","task","c","delete","size","loop","promise","Promise","fulfill","add","abort","globals","globalThis","global","append","target","node","appendChild","append_styles","style_sheet_id","styles","append_styles_to","get_root_for_style","getElementById","style","element","id","textContent","append_stylesheet","root","getRootNode","ownerDocument","host","append_empty_stylesheet","style_element","sheet","head","insert","anchor","insertBefore","detach","parentNode","removeChild","destroy_each","iterations","detaching","d","name","svg_element","createElementNS","text","data","createTextNode","space","empty","listen","event","handler","options","addEventListener","removeEventListener","prevent_default","preventDefault","call","this","stop_propagation","stopPropagation","attr","attribute","removeAttribute","getAttribute","setAttribute","init_binding_group","group","_inputs","inputs","input","r","splice","indexOf","set_data","set_input_value","set_style","key","important","removeProperty","setProperty","toggle_class","toggle","classList","custom_event","type","detail","_ref","_ref$bubbles","bubbles","_ref$cancelable","cancelable","CustomEvent","current_component","managed_styles","Map","active","create_rule","duration","delay","ease","uid","step","keyframes","t","concat","rule","str","hash","charCodeAt","doc","get","info","stylesheet","rules","set","create_style_information","insertRule","cssRules","animation","delete_rule","previous","split","next","filter","anim","deleted","join","ownerNode","clear","fix_position","getComputedStyle","position","width","height","getBoundingClientRect","left","top","transform","add_transform","set_current_component","get_current_component","Error","onMount","on_mount","createEventDispatcher","defaultPrevented","bubble","dirty_components","binding_callbacks","render_callbacks","flush_callbacks","resolved_promise","resolve","update_scheduled","schedule_update","then","flush","tick","add_render_callback","seen_callbacks","flushidx","saved_component","update","pop","has","fragment","before_update","after_update","dispatch","direction","kind","dispatchEvent","outros","outroing","group_outros","check_outros","transition_in","block","local","transition_out","o","null_transition","create_bidirectional_transition","params","intro","original_inert_value","config","running_program","pending_program","animation_name","clear_animation","init","program","abs","start","end","go","_ref3","_ref3$delay","_ref3$duration","_ref3$easing","easing","linear","_ref3$tick","css","inert","ensure_array_like","array_like_or_iterator","from","destroy_block","lookup","fix_and_outro_and_destroy_block","outro_and_destroy_block","update_keyed_each","old_blocks","get_key","dynamic","list","create_each_block","get_context","old_indexes","new_blocks","new_lookup","deltas","updates","_loop","child_ctx","will_move","did_move","m","first","new_block","old_block","new_key","old_key","create_component","mount_component","_component$$$","new_on_destroy","map","destroy_component","filtered","targets","instance","create_fragment","not_equal","props","parent_component","bound","on_disconnect","context","skip_bound","ready","ret","fill","make_dirty","hydrate","nodes","childNodes","children","l","SvelteComponent","constructor","_defineProperty","$destroy","$on","index","$set","obj","$$set","keys","__svelte","v","file_struct","bandwidth_used","bandwidth_used_paid","downloads","views","mime_type","availability","abuse_type","hash_sha256","show_ads","can_edit","can_download","get_href","info_href","download_href","icon_href","list_struct","title","files","file_set_href","file","api_endpoint","timeseries_href","file_type","endsWith","startsWith","cubicOut","fade","_ref2","_ref2$delay","_ref2$duration","_ref2$easing","opacity","if_block0","create_if_block_4","if_block1","create_if_block_3","create_if_block_2","create_if_block_1","button","span","create_if_block","_$$props$highlight","$$props","highlight","div5","div0","div3","div1","div2","div4","div5_transition","global_index","_$$props$form","form","_$$props$title","_$$props$width","_$$props$height","_$$props$padding","padding","_$$props$visible","visible","_$$props$style","set_visible","vis","$$invalidate","hide","background","zIndex","valueOf","activeElement","show","is_visible","formatThousands","amt","toString","replace","formatDataVolume","precision","toPrecision","minute","second","hour","day","formatDuration","ms","decimals","res","floor","toFixed","formatDate","date","hours","minutes","seconds","dateStr","getFullYear","getMonth","getDate","getHours","getMinutes","domain_url","location","protocol","hostname","port","color_by_name","documentElement","getPropertyValue","round","lim","h","min","p2b","n2b","b2n","n2p","map$1","A","B","C","D","E","F","hex","h1","h2","eq","hexString","g","isShort","alpha","HUE_RE","hsl2rgbn","hsv2rgbn","hwb2rgbn","w","rgb","rgb2hsl","hueValue","calln","isArray","hsl2rgb","hue","hueParse","exec","p1","p2","hwb2rgb","hsv2rgb","names","Z","Y","X","W","V","U","T","S","R","Q","P","O","N","M","L","K","G","H","I","J","names$1","OiceXe","antiquewEte","aqua","aquamarRe","azuY","beige","bisque","black","blanKedOmond","Xe","XeviTet","bPwn","burlywood","caMtXe","KartYuse","KocTate","cSO","cSnflowerXe","cSnsilk","crimson","cyan","xXe","xcyan","xgTMnPd","xWay","xgYF","xgYy","xkhaki","xmagFta","xTivegYF","xSange","xScEd","xYd","xsOmon","xsHgYF","xUXe","xUWay","xUgYy","xQe","xviTet","dAppRk","dApskyXe","dimWay","dimgYy","dodgerXe","fiYbrick","flSOwEte","foYstWAn","fuKsia","gaRsbSo","ghostwEte","gTd","gTMnPd","Way","gYF","gYFLw","gYy","honeyMw","hotpRk","RdianYd","Rdigo","ivSy","khaki","lavFMr","lavFMrXsh","lawngYF","NmoncEffon","ZXe","ZcSO","Zcyan","ZgTMnPdLw","ZWay","ZgYF","ZgYy","ZpRk","ZsOmon","ZsHgYF","ZskyXe","ZUWay","ZUgYy","ZstAlXe","ZLw","lime","limegYF","lRF","magFta","maPon","VaquamarRe","VXe","VScEd","VpurpN","VsHgYF","VUXe","VsprRggYF","VQe","VviTetYd","midnightXe","mRtcYam","mistyPse","moccasR","navajowEte","navy","Tdlace","Tive","TivedBb","Sange","SangeYd","ScEd","pOegTMnPd","pOegYF","pOeQe","pOeviTetYd","papayawEp","pHKpuff","peru","pRk","plum","powMrXe","purpN","YbeccapurpN","Yd","Psybrown","PyOXe","saddNbPwn","sOmon","sandybPwn","sHgYF","sHshell","siFna","silver","skyXe","UXe","UWay","UgYy","snow","sprRggYF","stAlXe","tan","teO","tEstN","tomato","Qe","viTet","JHt","wEte","wEtesmoke","Lw","LwgYF","nameParse","j","ok","nk","unpacked","tkeys","parseInt","unpack","transparent","toLowerCase","RGB_RE","to","pow","modHSL","ratio","tmp","clone","proto","fromObject","functionParse","charAt","rgbParse","Color","_rgb","_valid","valid","rgbString","hslString","mix","color","weight","w2","c1","c2","w1","interpolate","rgb1","rgb2","clearer","greyscale","val","opaquer","negate","lighten","darken","saturate","desaturate","rotate","deg","isNullOrUndef","prototype","isObject","isNumberFinite","Number","isFinite","finiteOrDefault","defaultValue","valueOrDefault","toDimension","dimension","parseFloat","args","thisArg","apply","each","loopable","reverse","_elementsEqual","a0","a1","ilen","v0","v1","datasetIndex","source","klen","isValidKey","_merger","tval","sval","merge","sources","current","merger","mergeIf","_mergerIf","hasOwnProperty","keyResolvers","y","_getKeyResolver","_splitKey","_step2","_iterator2","resolveObjectKey","_capitalize","toUpperCase","defined","isFunction","setsEqual","_step3","_iterator3","item","Animator","_request","_charts","_running","_lastDate","_notify","chart","anims","listeners","numSteps","initial","currentStep","_refresh","requestAnimFrame","_update","remaining","running","items","draw","_active","_total","_getAnims","charts","complete","progress","reduce","acc","cur","_duration","stop","cancel","remove","animator","div","canvas","chart_element","chart_object","Chart","register","PointElement","LineElement","LinearScale","CategoryScale","LineController","Filler","Tooltip","Legend","_$$props$data_type","data_type","_$$props$legend","legend","_$$props$tooltips","tooltips","_$$props$ticks","ticks","defaults","font","family","maintainAspectRatio","plugins","tooltip","mode","axis","intersect","getContext","labels","datasets","responsive","resizeDelay","display","boxWidth","boxHeight","enabled","layout","right","scales","values","formatNumber","beginAtZero","grid","drawBorder","sampleSize","minRotation","maxRotation","$$value","tr","t2_value","description","td0","td1","t2","label","t8_value","t12_value","t16_value","t20_value","t27_value","t36_value","date_upload","t56_value","a0_href_value","div67","table","tbody","tr0","tr1","td2","td3","tr2","td4","td5","tr3","td6","td7","tr4","td8","td9","tr5","td10","td11","tr6","td12","td13","tr7","td14","td15","tr8","td16","td17","tr9","td18","td19","h3","h40","div22","h41","div35","h42","div66","t8","t12","t16","t20","t22","t22_value","t27","t29","t29_value","t31","t31_value","t36","t38","t38_value","t40","t40_value","t46","t46_value","t51","t51_value","t56","_$$props$file","chart_timespan","chart_interval","chart_timespans","interval","update_chart","timespan","minutes_since_upload","getTime","parse","console","log","setMinutes","fetch","toISOString","resp","json","timestamps","idx","bandwidth","amounts","bandwidth_paid","download_info","borderWidth","pointRadius","borderColor","backgroundColor","update_file","click_handler","ts","svg","path","animateTransform","storage_key","position_cache","get_video_positions","video_positions","JSON","localStorage","getItem","get_video_position","video_position","get_id","last_time","loadeddata","vp","pos","dur","debug","currentTime","timeupdate","vid","save_video_position","time","expiry_thresh","setItem","stringify","_$$props$center","center","_$$props$total","total","_$$props$used","used","_$$props$animation","_$$props$speed","speed","_$$props$no_animation","no_animation","_$$props$no_margin","no_margin","percent","subscriber_queue","writable","subscribers","new_value","run_queue","subscriber","results","file_stats","limits","stats","start_sock","stop_sock","socket","set_func","WebSocket","origin","onopen","connected","send_cmd","onmessage","msg","file_stats_init","limits_init","error","onerror","setTimeout","onclose","close","queued_commands","cmd","readyState","OPEN","send","shift","t3_value","t1","t1_value","t3","transfer_limit_used","t4_value","transfer_limit","p0","t4","if_block","transfer_left","$stats","img","img_src_value","_$$props$icon_href","t0_value","create_if_block_7","t0","iconblock_changes","br","create_if_block_6","create_if_block_5","muted","source_src_value","source_type_value","video","button0","button1","button2","button3","button4","allow_video_player","player","_$$props$is_list","is_list","download_speed_limit","playing","video_reload","media_session","set_file","_asyncToGenerator","_regeneratorRuntime","mark","same_file","wrap","_context","prev","navigator","mediaSession","metadata","MediaMetadata","artist","album","_callee","_x","seek","delta","fastSeek","setActionHandler","play","pause","fullscreen","fullscreenElement","requestFullscreen","exitFullscreen","includes","toggle_playback","download","ctrlKey","altKey","metaKey","pause_handler","play_handler","ended_handler","video_position_function","click_handler_1","click_handler_2","click_handler_3","audio","filetitle","FileTitle","if_block4","br0","br1","br2","br3","filetitle_changes","audio_reload","swipe_nav","start_x","start_y","render_offset","touchstart","touches","clientX","clientY","touchmove","offset_x","abs_x","abs_y","set_offset","touchend","on_prev","on_next","off","animate","transition","child","HTMLImageElement","img_alt_value","container","swipe_nav_function","swipe_nav_function_1","iframe","iframe_src_value","encodeURIComponent","pre","section","md_container","text_pre","code_pre","text_type","markdown","reject","status","innerHTML","catch","innerText","_ref4","_context2","abrupt","_x2","code","_ref5","_context3","prettyprint","_x3","t5_value","abuse_reporter_name","t5","download_limit","t6_value","download_limit_used","t6","t10","t10_value","path0","path1","path2","li","each_value","entries","ul","each_blocks","_$$props$item","disabled","button_disabled_value","clipboard","writeText","created_by","comment","created_at","t7_value","info_hash","t7","details","summary","a3","h30","p3","h31","p4","h32","p5","p6","p7","torrentitem_changes","sent","torrent","magnet","trackers","tracker","finish","download_url","details_open","open","a_href_value","each_value_1","each_blocks_1","zip","comp_ratio","archive_type","truncated","properties","recursive_set_url","parent_path","speed_limit","user_authenticated","li0","li1","li2","t14","t14_value","_$$props$file_size","file_size","_$$props$file_name","file_name","_$$props$file_type","slowdown_changes","viewer","current_file","viewer_type","premium_download","toggle_mute","a_title_value","selected","file_list_div","_$$props$files","selected_file_index","history","toggle_gallery","rand_item","rand","random","selected_file","cst","itemWidth","offsetWidth","marginLeft","marginRight","scrollLeft","clientWidth","stepSize","animateScroll","div6","file_id","h4","if_block2","if_block3","_$$props$list","loading","result_success","result_text","list_name","rename_file","FormData","method","body","message","delete_file","confirm","_callee2","rename_list","listjson","_callee3","delete_list","_ref6","_context4","_callee4","_x4","button5","button6","button7","button8","button9","button10","button11","button12","button13","_$$props$theme","theme","t9_value","t9","textarea","preview_area","tab","embed_html","embed_iframe","update_example","style_part","embed_hotlink","html_escape","example","toggle_example","desc","__value","label0","input0","label1","input1","t_value","success","filter_visual","abuse_categories","filter_audio","single_or_all","submit","_i8","_files","report_description","errors","child_abuse_password","share_email","share_reddit","share_twitter","share_facebook","share_tumblr","flip","_style$transformOrigi2","_slicedToArray","transformOrigin","ox","oy","dx","dy","_params$delay","_params$duration","sqrt","_params$easing","u","sx","sy","field","dateCreated","sizeLabel","icon","span0","span1","span2","span3","directoryArea","nodeContainer","statusBar","allFiles","lastSearchTerm","search","term","sortBy","render_visible_files","currentSortField","currentSortAscending","tableColumns","fieldA","fieldB","colIdx","sort","localeCompare","numeric","render_timeout","paddingTop","scrollTop","ceil","clientHeight","totalFiles","totalSize","selectedFiles","selectedSize","selectionMode","shift_pressed","_$$props$multi_select","multi_select","last_selected_node","node_click","id_low","id_high","reset","addFile","renderFiles","getSelectedFiles","searchSubmit","modal","directory_element","input_search","setSelectionMode","get_files","keyCode","blur","selected_files","focus","progressbar_changes","a_draggable_value","stop_animation","bottom","_fn","_fn$delay","_fn$duration","_fn$easing","_fn$start","start_time","_fn$end","_fn$tick","started","create_animation","rect","file_picker","add_files","list_files","move_left","move_right","_ref7","_ref8","hovering","dragging","drag","dataTransfer","effectAllowed","dropEffect","setData","drop","getData","dragenter_handler","dragstart_handler","drop_handler_1","script","download_captcha_window","captcha_container","load_captcha_script","captcha_type","captcha_window_title","error_window","error_code","error_message","click","download_file","viewer_data","captcha_key","availability_message","captcha_complete_callback","token","captcha_script_loaded","grecaptcha","render","sitekey","download_list","_$$props$src","_$$props$link","link","_$$props$border_top","border_top","_$$props$loading","div8","div7","div_transition","clipboardData","_$$props$job","job","_$$props$loaded","loaded","upload_file","on_progress","on_success","on_error","user","subscription","file_size_limit","on_failure","xhr","XMLHttpRequest","timeout","upload","evt","lengthComputable","onreadystatechange","response","responseText","prog_loaded","prog_total","div2_transition","file_input_field","_$$props$drop_upload","drop_upload","upload_queue","task_id_counter","upload_files","task_id","total_size","loaded_size","start_upload","active_uploads","state","file_ids","nodeValue","returnValue","pick_files","upload_widget","new_files","_resp","alert","uploads_finished","toLocaleString","minimumFractionDigits","maximumFractionDigits","_$$props$symbol","symbol","_$$props$amount","amount","_$$props$precision","get_endpoint","warn","check_response","dict_to_form","dict","_i","_Object$keys","get_user","put_user","_i2","_Object$keys2","filesystem_storage_used","t13_value","monthly_transfer_used","filesystem_access","is_admin","div9","div10","t13","balance_micro_eur","euro_changes","username","button_1","dialog_1","dialog","deny","allow","pathname","listnavigator_props","listnavigator_changes","create_if_block_18","create_if_block_17","create_if_block_16","create_if_block_15","create_if_block_12","create_if_block_11","create_if_block_10","create_if_block_9","if_block9","create_if_block_8","if_block10","if_block11","file_viewer","file_preview","list_navigator","sharebar","downloader","list_updater","details_window","affiliate_prompt","qr_window","edit_window","report_window","embed_window","embedded","ads_enabled","view","list_downloadable","sharebar_visible","toggle_sharebar","share","toolbar_visible","innerWidth","details_visible","qr_visible","edit_visible","report_visible","embed_visible","open_list","api_response","open_file_index","file_preview_background","copy_btn","reload","apply_customizations","hash_change","matches","match","isInteger","set_item","custom_header","custom_header_link","custom_background","custom_footer","custom_footer_link","disable_download_button","disable_share_button","branding","header_image","header_link","footer_image","footer_link","prompt","background_image","backgroundImage","grab_file","toolbar_toggle","toggle_fullscreen","shiftKey","copy","pick_files_handler"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,15,16,21,22,23,30,60]}