{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "# Magnetic Force Microscopy" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Magnetic force microscopy (MFM) is a powerful technique for examining a sample's stray magnetic field.\n", "The contrast in MFM images originates from the interaction between the magnetic tip of an oscillating cantilever and the stray field.\n", "It has a key role in the imaging of magnetism in thin films and samples with flat surfaces.\n", "\n", "The cantilever in a dual pass MFM mode rasters across the same line scan twice, firstly mapping the topography by tapping along the surface at the resonant frequency $\\omega_0$ \\[[Kazakova 2019](https://aip.scitation.org/doi/10.1063/1.5050712)\\].\n", "The second pass lifts the cantilever a set height $z_0$ above the sample surface, which is determined by the first pass. The phase shift $\\Delta \\phi$ of the resonance is then measured as the probe rasters across the sample.\n", "The tip of an MFM is a complicated magnetic object but usually it can be characterised by an effective magnetic dipole moment and an effective magnetic monopole moment. These moments interact with the stray field produced by the magnetisation of the sample, changing the force on the magnetic tip and hence its resonance. Due to the non-zero size of the tip, the resolution of this technique can be on the scale of tens of nanometres.\n", "\n", "MFM is most commonly used to probe the out-of-plane stray magnetic field of a sample but it has the potential to measure different quantities with the tip magnetised in different directions." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## MFM Reference frame" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "In `mag2exp` the experimental reference for MFM is defined by cantilever oscillating in the $z$ direction.\n", "\n", "" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## The micromagnetic simulation" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "A micromagnetic simulation can be set up using `Ubermag` to obtain a 3-Dimentional magntic structure. As MFM is based on the field outside a sample, when simulating MFM we have to create an \"airbox\". Simply put, this is an area outside of the sample where we wish to perform the MFM measurements, in which we have set the saturation magnetisation equal to zero. It is equivalent to simulating the empty space around the sample. The demagnetisation term must be used as part of the energy equation when defining and relaxing the system as this is the process by which the stray field is calculated." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Here a simulation region is created with a 200 nm edge length and 20 nm in height which contains a magnetic sample." ] }, { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [], "source": [ "import discretisedfield as df\n", "import micromagneticmodel as mm\n", "import numpy as np\n", "import oommfc as oc\n", "import ubermagutil.units as uu\n", "\n", "np.random.seed(1)\n", "\n", "region = df.Region(p1=(-100e-9, -100e-9, -20e-9), p2=(100e-9, 100e-9, 0))\n", "mesh = df.Mesh(region=region, cell=(5e-9, 5e-9, 5e-9))\n", "\n", "system = mm.System(name=\"Box2\")\n", "\n", "system.energy = (\n", " mm.Exchange(A=1.6e-11)\n", " + mm.DMI(D=4e-3, crystalclass=\"T\")\n", " + mm.UniaxialAnisotropy(K=5.1e5, u=(0, 0, 1))\n", " + mm.Demag()\n", " + mm.Zeeman(H=(0, 0, 2e5))\n", ")\n", "\n", "Ms = 1.1e6\n", "\n", "\n", "def m_fun(pos):\n", " return 2 * np.random.rand(3) - 1\n", "\n", "\n", "# create system with above geometry and initial magnetisation\n", "system.m = df.Field(mesh, dim=3, value=m_fun, norm=Ms)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Initial magnetisation:" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" }, { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "system.m.plane(z=-5e-9).mpl()\n", "system.m.plane(\"x\").mpl()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Relax the system and plot its magnetisation." ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "# NBVAL_IGNORE_OUTPUT\n", "# minimize the energy\n", "md = oc.MinDriver()\n", "md.drive(system, verbose=0)\n", "\n", "# Plot relaxed configuration: vectors in z-plane\n", "system.m.plane(\"z\").mpl()" ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "system.m.plane(\"x\").mpl()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "`hvplot` can be used to interactively look through the slices of the magnetisation." ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [ { "data": { "application/javascript": [ "(function(root) {\n", " function now() {\n", " return new Date();\n", " }\n", "\n", " var force = true;\n", "\n", " if (typeof root._bokeh_onload_callbacks === \"undefined\" || force === true) {\n", " root._bokeh_onload_callbacks = [];\n", " root._bokeh_is_loading = undefined;\n", " }\n", "\n", " if (typeof (root._bokeh_timeout) === \"undefined\" || force === true) {\n", " root._bokeh_timeout = Date.now() + 5000;\n", " root._bokeh_failed_load = false;\n", " }\n", "\n", " function run_callbacks() {\n", " try {\n", " root._bokeh_onload_callbacks.forEach(function(callback) {\n", " if (callback != null)\n", " callback();\n", " });\n", " } finally {\n", " delete root._bokeh_onload_callbacks\n", " }\n", " console.debug(\"Bokeh: all callbacks have finished\");\n", " }\n", "\n", " function load_libs(css_urls, js_urls, js_modules, callback) {\n", " if (css_urls == null) css_urls = [];\n", " if (js_urls == null) js_urls = [];\n", " if (js_modules == null) js_modules = [];\n", "\n", " root._bokeh_onload_callbacks.push(callback);\n", " if (root._bokeh_is_loading > 0) {\n", " console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n", " return null;\n", " }\n", " if (js_urls.length === 0 && js_modules.length === 0) {\n", " run_callbacks();\n", " return null;\n", " }\n", " console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n", "\n", " function on_load() {\n", " root._bokeh_is_loading--;\n", " if (root._bokeh_is_loading === 0) {\n", " console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n", " run_callbacks()\n", " }\n", " }\n", "\n", " function on_error() {\n", " console.error(\"failed to load \" + url);\n", " }\n", "\n", " for (var i = 0; i < css_urls.length; i++) {\n", " var url = css_urls[i];\n", " const element = document.createElement(\"link\");\n", " element.onload = on_load;\n", " element.onerror = on_error;\n", " element.rel = \"stylesheet\";\n", " element.type = \"text/css\";\n", " element.href = url;\n", " console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n", " document.body.appendChild(element);\n", " }\n", "\n", " var skip = [];\n", " if (window.requirejs) {\n", " window.requirejs.config({'packages': {}, 'paths': {'gridstack': 'https://cdn.jsdelivr.net/npm/gridstack@4.2.5/dist/gridstack-h5', 'notyf': 'https://cdn.jsdelivr.net/npm/notyf@3/notyf.min'}, 'shim': {'gridstack': {'exports': 'GridStack'}}});\n", " require([\"gridstack\"], function(GridStack) {\n", "\twindow.GridStack = GridStack\n", "\ton_load()\n", " })\n", " require([\"notyf\"], function() {\n", "\ton_load()\n", " })\n", " root._bokeh_is_loading = css_urls.length + 2;\n", " } else {\n", " root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length;\n", " } if (((window['GridStack'] !== undefined) && (!(window['GridStack'] instanceof HTMLElement))) || window.requirejs) {\n", " var urls = ['https://cdn.jsdelivr.net/npm/gridstack@4.2.5/dist/gridstack-h5.js'];\n", " for (var i = 0; i < urls.length; i++) {\n", " skip.push(urls[i])\n", " }\n", " } if (((window['Notyf'] !== undefined) && (!(window['Notyf'] instanceof HTMLElement))) || window.requirejs) {\n", " var urls = ['https://cdn.jsdelivr.net/npm/notyf@3/notyf.min.js'];\n", " for (var i = 0; i < urls.length; i++) {\n", " skip.push(urls[i])\n", " }\n", " } for (var i = 0; i < js_urls.length; i++) {\n", " var url = js_urls[i];\n", " if (skip.indexOf(url) >= 0) {\n", "\tif (!window.requirejs) {\n", "\t on_load();\n", "\t}\n", "\tcontinue;\n", " }\n", " var element = document.createElement('script');\n", " element.onload = on_load;\n", " element.onerror = on_error;\n", " element.async = false;\n", " element.src = url;\n", " console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n", " document.head.appendChild(element);\n", " }\n", " for (var i = 0; i < js_modules.length; i++) {\n", " var url = js_modules[i];\n", " if (skip.indexOf(url) >= 0) {\n", "\tif (!window.requirejs) {\n", "\t on_load();\n", "\t}\n", "\tcontinue;\n", " }\n", " var element = document.createElement('script');\n", " element.onload = on_load;\n", " element.onerror = on_error;\n", " element.async = false;\n", " element.src = url;\n", " element.type = \"module\";\n", " console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n", " document.head.appendChild(element);\n", " }\n", " if (!js_urls.length && !js_modules.length) {\n", " on_load()\n", " }\n", " };\n", "\n", " function inject_raw_css(css) {\n", " const element = document.createElement(\"style\");\n", " element.appendChild(document.createTextNode(css));\n", " document.body.appendChild(element);\n", " }\n", "\n", " var js_urls = [\"https://cdn.jsdelivr.net/npm/notyf@3/notyf.min.js\"];\n", " var js_modules = [];\n", " var css_urls = [\"https://cdn.jsdelivr.net/npm/notyf@3/notyf.min.css\", \"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.1/css/all.min.css\"];\n", " var inline_js = [ function(Bokeh) {\n", " inject_raw_css(\".bk.pn-loading:before {\\n position: absolute;\\n height: 100%;\\n width: 100%;\\n content: '';\\n z-index: 1000;\\n background-color: rgb(255,255,255,0.50);\\n border-color: lightgray;\\n background-repeat: no-repeat;\\n background-position: center;\\n background-size: auto 50%;\\n border-width: 1px;\\n cursor: progress;\\n}\\n.bk.pn-loading.arcs:hover:before {\\n cursor: progress;\\n}\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\".bk.card {\\n border: 1px solid rgba(0,0,0,.125);\\n border-radius: 0.25rem;\\n}\\n.bk.accordion {\\n border: 1px solid rgba(0,0,0,.125);\\n}\\n.bk.card-header {\\n align-items: center;\\n background-color: rgba(0, 0, 0, 0.03);\\n border-radius: 0.25rem;\\n display: inline-flex;\\n justify-content: start;\\n width: 100%;\\n}\\n.bk.accordion-header {\\n align-items: center;\\n background-color: rgba(0, 0, 0, 0.03);\\n border-radius: 0;\\n display: flex;\\n justify-content: start;\\n width: 100%;\\n}\\n.bk.card-button {\\n background-color: transparent;\\n margin-left: 0.5em;\\n}\\n.bk.card-header-row {\\n position: relative !important;\\n}\\n.bk.card-title {\\n align-items: center;\\n font-size: 1.4em;\\n font-weight: bold;\\n overflow-wrap: break-word;\\n}\\n.bk.card-header-row > .bk {\\n overflow-wrap: break-word;\\n text-align: center;\\n}\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\".bk.panel-widget-box {\\n min-height: 20px;\\n background-color: #f5f5f5;\\n border: 1px solid #e3e3e3;\\n border-radius: 4px;\\n -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.05);\\n box-shadow: inset 0 1px 1px rgba(0,0,0,.05);\\n overflow-x: hidden;\\n overflow-y: hidden;\\n}\\n\\n.scrollable {\\n overflow: scroll;\\n}\\n\\nprogress {\\n appearance: none;\\n -moz-appearance: none;\\n -webkit-appearance: none;\\n border: none;\\n height: 20px;\\n background-color: whiteSmoke;\\n border-radius: 3px;\\n box-shadow: 0 2px 3px rgba(0,0,0,.5) inset;\\n color: royalblue;\\n position: relative;\\n margin: 0 0 1.5em;\\n}\\n\\nprogress[value]::-webkit-progress-bar {\\n background-color: whiteSmoke;\\n border-radius: 3px;\\n box-shadow: 0 2px 3px rgba(0,0,0,.5) inset;\\n}\\n\\nprogress[value]::-webkit-progress-value {\\n position: relative;\\n background-size: 35px 20px, 100% 100%, 100% 100%;\\n border-radius:3px;\\n}\\n\\nprogress.active:not([value])::before {\\n background-position: 10%;\\n animation-name: stripes;\\n animation-duration: 3s;\\n animation-timing-function: linear;\\n animation-iteration-count: infinite;\\n}\\n\\nprogress[value]::-moz-progress-bar {\\n background-size: 35px 20px, 100% 100%, 100% 100%;\\n border-radius:3px;\\n}\\n\\nprogress:not([value])::-moz-progress-bar {\\n border-radius:3px;\\n background: linear-gradient(-45deg, transparent 33%, rgba(0, 0, 0, 0.2) 33%, rgba(0, 0, 0, 0.2) 66%, transparent 66%) left/2.5em 1.5em;\\n}\\n\\nprogress.active:not([value])::-moz-progress-bar {\\n background-position: 10%;\\n animation-name: stripes;\\n animation-duration: 3s;\\n animation-timing-function: linear;\\n animation-iteration-count: infinite;\\n}\\n\\nprogress.active:not([value])::-webkit-progress-bar {\\n background-position: 10%;\\n animation-name: stripes;\\n animation-duration: 3s;\\n animation-timing-function: linear;\\n animation-iteration-count: infinite;\\n}\\n\\nprogress.primary[value]::-webkit-progress-value { background-color: #007bff; }\\nprogress.primary:not([value])::before { background-color: #007bff; }\\nprogress.primary:not([value])::-webkit-progress-bar { background-color: #007bff; }\\nprogress.primary::-moz-progress-bar { background-color: #007bff; }\\n\\nprogress.secondary[value]::-webkit-progress-value { background-color: #6c757d; }\\nprogress.secondary:not([value])::before { background-color: #6c757d; }\\nprogress.secondary:not([value])::-webkit-progress-bar { background-color: #6c757d; }\\nprogress.secondary::-moz-progress-bar { background-color: #6c757d; }\\n\\nprogress.success[value]::-webkit-progress-value { background-color: #28a745; }\\nprogress.success:not([value])::before { background-color: #28a745; }\\nprogress.success:not([value])::-webkit-progress-bar { background-color: #28a745; }\\nprogress.success::-moz-progress-bar { background-color: #28a745; }\\n\\nprogress.danger[value]::-webkit-progress-value { background-color: #dc3545; }\\nprogress.danger:not([value])::before { background-color: #dc3545; }\\nprogress.danger:not([value])::-webkit-progress-bar { background-color: #dc3545; }\\nprogress.danger::-moz-progress-bar { background-color: #dc3545; }\\n\\nprogress.warning[value]::-webkit-progress-value { background-color: #ffc107; }\\nprogress.warning:not([value])::before { background-color: #ffc107; }\\nprogress.warning:not([value])::-webkit-progress-bar { background-color: #ffc107; }\\nprogress.warning::-moz-progress-bar { background-color: #ffc107; }\\n\\nprogress.info[value]::-webkit-progress-value { background-color: #17a2b8; }\\nprogress.info:not([value])::before { background-color: #17a2b8; }\\nprogress.info:not([value])::-webkit-progress-bar { background-color: #17a2b8; }\\nprogress.info::-moz-progress-bar { background-color: #17a2b8; }\\n\\nprogress.light[value]::-webkit-progress-value { background-color: #f8f9fa; }\\nprogress.light:not([value])::before { background-color: #f8f9fa; }\\nprogress.light:not([value])::-webkit-progress-bar { background-color: #f8f9fa; }\\nprogress.light::-moz-progress-bar { background-color: #f8f9fa; }\\n\\nprogress.dark[value]::-webkit-progress-value { background-color: #343a40; }\\nprogress.dark:not([value])::-webkit-progress-bar { background-color: #343a40; }\\nprogress.dark:not([value])::before { background-color: #343a40; }\\nprogress.dark::-moz-progress-bar { background-color: #343a40; }\\n\\nprogress:not([value])::-webkit-progress-bar {\\n border-radius: 3px;\\n background: linear-gradient(-45deg, transparent 33%, rgba(0, 0, 0, 0.2) 33%, rgba(0, 0, 0, 0.2) 66%, transparent 66%) left/2.5em 1.5em;\\n}\\nprogress:not([value])::before {\\n content:\\\" \\\";\\n position:absolute;\\n height: 20px;\\n top:0;\\n left:0;\\n right:0;\\n bottom:0;\\n border-radius: 3px;\\n background: linear-gradient(-45deg, transparent 33%, rgba(0, 0, 0, 0.2) 33%, rgba(0, 0, 0, 0.2) 66%, transparent 66%) left/2.5em 1.5em;\\n}\\n\\n@keyframes stripes {\\n from {background-position: 0%}\\n to {background-position: 100%}\\n}\\n\\n.bk-root .bk.loader {\\n overflow: hidden;\\n}\\n\\n.bk.loader::after {\\n content: \\\"\\\";\\n border-radius: 50%;\\n -webkit-mask-image: radial-gradient(transparent 50%, rgba(0, 0, 0, 1) 54%);\\n width: 100%;\\n height: 100%;\\n left: 0;\\n top: 0;\\n position: absolute;\\n}\\n\\n.bk-root .bk.loader.dark::after {\\n background: #0f0f0f;\\n}\\n\\n.bk-root .bk.loader.light::after {\\n background: #f0f0f0;\\n}\\n\\n.bk-root .bk.loader.spin::after {\\n animation: spin 2s linear infinite;\\n}\\n\\n.bk-root div.bk.loader.spin.primary-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #007bff 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.secondary-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #6c757d 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.success-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #28a745 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.danger-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #dc3545 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.warning-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #ffc107 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.info-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #17a2b8 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.light-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #f8f9fa 50%);\\n}\\n\\n.bk-root div.bk.loader.dark-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #343a40 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.primary-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #007bff 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.secondary-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #6c757d 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.success-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #28a745 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.danger-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #dc3545 50%)\\n}\\n\\n.bk-root div.bk.loader.spin.warning-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #ffc107 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.info-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #17a2b8 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.light-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #f8f9fa 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.dark-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #343a40 50%);\\n}\\n\\n/* Safari */\\n@-webkit-keyframes spin {\\n 0% { -webkit-transform: rotate(0deg); }\\n 100% { -webkit-transform: rotate(360deg); }\\n}\\n\\n@keyframes spin {\\n 0% { transform: rotate(0deg); }\\n 100% { transform: rotate(360deg); }\\n}\\n\\n.dot div {\\n height: 100%;\\n width: 100%;\\n border: 1px solid #000 !important;\\n background-color: #fff;\\n border-radius: 50%;\\n display: inline-block;\\n}\\n\\n.dot-filled div {\\n height: 100%;\\n width: 100%;\\n border: 1px solid #000 !important;\\n border-radius: 50%;\\n display: inline-block;\\n}\\n\\n.dot-filled.primary div {\\n background-color: #007bff;\\n}\\n\\n.dot-filled.secondary div {\\n background-color: #6c757d;\\n}\\n\\n.dot-filled.success div {\\n background-color: #28a745;\\n}\\n\\n.dot-filled.danger div {\\n background-color: #dc3545;\\n}\\n\\n.dot-filled.warning div {\\n background-color: #ffc107;\\n}\\n\\n.dot-filled.info div {\\n background-color: #17a2b8;\\n}\\n\\n.dot-filled.dark div {\\n background-color: #343a40;\\n}\\n\\n.dot-filled.light div {\\n background-color: #f8f9fa;\\n}\\n\\n/* Slider editor */\\n.slider-edit .bk-input-group .bk-input {\\n border: 0;\\n border-radius: 0;\\n min-height: 0;\\n padding-left: 0;\\n padding-right: 0;\\n font-weight: bold;\\n}\\n\\n.slider-edit .bk-input-group .bk-spin-wrapper {\\n display: contents;\\n}\\n\\n.slider-edit .bk-input-group .bk-spin-wrapper .bk.bk-spin-btn-up {\\n top: -6px;\\n}\\n\\n.slider-edit .bk-input-group .bk-spin-wrapper .bk.bk-spin-btn-down {\\n bottom: 3px;\\n}\\n\\n/* JSON Pane */\\n.bk-root .json-formatter-row .json-formatter-string, .bk-root .json-formatter-row .json-formatter-stringifiable {\\n white-space: pre-wrap;\\n}\\n\\n.ql-bubble .ql-editor {\\n border: 1px solid #ccc;\\n}\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\".codehilite .hll { background-color: #ffffcc }\\n.codehilite { background: #f8f8f8; }\\n.codehilite .c { color: #408080; font-style: italic } /* Comment */\\n.codehilite .err { border: 1px solid #FF0000 } /* Error */\\n.codehilite .k { color: #008000; font-weight: bold } /* Keyword */\\n.codehilite .o { color: #666666 } /* Operator */\\n.codehilite .ch { color: #408080; font-style: italic } /* Comment.Hashbang */\\n.codehilite .cm { color: #408080; font-style: italic } /* Comment.Multiline */\\n.codehilite .cp { color: #BC7A00 } /* Comment.Preproc */\\n.codehilite .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */\\n.codehilite .c1 { color: #408080; font-style: italic } /* Comment.Single */\\n.codehilite .cs { color: #408080; font-style: italic } /* Comment.Special */\\n.codehilite .gd { color: #A00000 } /* Generic.Deleted */\\n.codehilite .ge { font-style: italic } /* Generic.Emph */\\n.codehilite .gr { color: #FF0000 } /* Generic.Error */\\n.codehilite .gh { color: #000080; font-weight: bold } /* Generic.Heading */\\n.codehilite .gi { color: #00A000 } /* Generic.Inserted */\\n.codehilite .go { color: #888888 } /* Generic.Output */\\n.codehilite .gp { color: #000080; font-weight: bold } /* Generic.Prompt */\\n.codehilite .gs { font-weight: bold } /* Generic.Strong */\\n.codehilite .gu { color: #800080; font-weight: bold } /* Generic.Subheading */\\n.codehilite .gt { color: #0044DD } /* Generic.Traceback */\\n.codehilite .kc { color: #008000; font-weight: bold } /* Keyword.Constant */\\n.codehilite .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */\\n.codehilite .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */\\n.codehilite .kp { color: #008000 } /* Keyword.Pseudo */\\n.codehilite .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */\\n.codehilite .kt { color: #B00040 } /* Keyword.Type */\\n.codehilite .m { color: #666666 } /* Literal.Number */\\n.codehilite .s { color: #BA2121 } /* Literal.String */\\n.codehilite .na { color: #7D9029 } /* Name.Attribute */\\n.codehilite .nb { color: #008000 } /* Name.Builtin */\\n.codehilite .nc { color: #0000FF; font-weight: bold } /* Name.Class */\\n.codehilite .no { color: #880000 } /* Name.Constant */\\n.codehilite .nd { color: #AA22FF } /* Name.Decorator */\\n.codehilite .ni { color: #999999; font-weight: bold } /* Name.Entity */\\n.codehilite .ne { color: #D2413A; font-weight: bold } /* Name.Exception */\\n.codehilite .nf { color: #0000FF } /* Name.Function */\\n.codehilite .nl { color: #A0A000 } /* Name.Label */\\n.codehilite .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */\\n.codehilite .nt { color: #008000; font-weight: bold } /* Name.Tag */\\n.codehilite .nv { color: #19177C } /* Name.Variable */\\n.codehilite .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */\\n.codehilite .w { color: #bbbbbb } /* Text.Whitespace */\\n.codehilite .mb { color: #666666 } /* Literal.Number.Bin */\\n.codehilite .mf { color: #666666 } /* Literal.Number.Float */\\n.codehilite .mh { color: #666666 } /* Literal.Number.Hex */\\n.codehilite .mi { color: #666666 } /* Literal.Number.Integer */\\n.codehilite .mo { color: #666666 } /* Literal.Number.Oct */\\n.codehilite .sa { color: #BA2121 } /* Literal.String.Affix */\\n.codehilite .sb { color: #BA2121 } /* Literal.String.Backtick */\\n.codehilite .sc { color: #BA2121 } /* Literal.String.Char */\\n.codehilite .dl { color: #BA2121 } /* Literal.String.Delimiter */\\n.codehilite .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */\\n.codehilite .s2 { color: #BA2121 } /* Literal.String.Double */\\n.codehilite .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */\\n.codehilite .sh { color: #BA2121 } /* Literal.String.Heredoc */\\n.codehilite .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */\\n.codehilite .sx { color: #008000 } /* Literal.String.Other */\\n.codehilite .sr { color: #BB6688 } /* Literal.String.Regex */\\n.codehilite .s1 { color: #BA2121 } /* Literal.String.Single */\\n.codehilite .ss { color: #19177C } /* Literal.String.Symbol */\\n.codehilite .bp { color: #008000 } /* Name.Builtin.Pseudo */\\n.codehilite .fm { color: #0000FF } /* Name.Function.Magic */\\n.codehilite .vc { color: #19177C } /* Name.Variable.Class */\\n.codehilite .vg { color: #19177C } /* Name.Variable.Global */\\n.codehilite .vi { color: #19177C } /* Name.Variable.Instance */\\n.codehilite .vm { color: #19177C } /* Name.Variable.Magic */\\n.codehilite .il { color: #666666 } /* Literal.Number.Integer.Long */\\n\\n.markdown h1 { margin-block-start: 0.34em }\\n.markdown h2 { margin-block-start: 0.42em }\\n.markdown h3 { margin-block-start: 0.5em }\\n.markdown h4 { margin-block-start: 0.67em }\\n.markdown h5 { margin-block-start: 0.84em }\\n.markdown h6 { margin-block-start: 1.17em }\\n.markdown ul { padding-inline-start: 2em }\\n.markdown ol { padding-inline-start: 2em }\\n.markdown strong { font-weight: 600 }\\n.markdown a { color: -webkit-link }\\n.markdown a { color: -moz-hyperlinkText }\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\".json-formatter-row {\\n font-family: monospace;\\n}\\n.json-formatter-row,\\n.json-formatter-row a,\\n.json-formatter-row a:hover {\\n color: black;\\n text-decoration: none;\\n}\\n.json-formatter-row .json-formatter-row {\\n margin-left: 1rem;\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty {\\n opacity: 0.5;\\n margin-left: 1rem;\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty:after {\\n display: none;\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-object:after {\\n content: \\\"No properties\\\";\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-array:after {\\n content: \\\"[]\\\";\\n}\\n.json-formatter-row .json-formatter-string,\\n.json-formatter-row .json-formatter-stringifiable {\\n color: green;\\n white-space: pre;\\n word-wrap: break-word;\\n}\\n.json-formatter-row .json-formatter-number {\\n color: blue;\\n}\\n.json-formatter-row .json-formatter-boolean {\\n color: red;\\n}\\n.json-formatter-row .json-formatter-null {\\n color: #855A00;\\n}\\n.json-formatter-row .json-formatter-undefined {\\n color: #ca0b69;\\n}\\n.json-formatter-row .json-formatter-function {\\n color: #FF20ED;\\n}\\n.json-formatter-row .json-formatter-date {\\n background-color: rgba(0, 0, 0, 0.05);\\n}\\n.json-formatter-row .json-formatter-url {\\n text-decoration: underline;\\n color: blue;\\n cursor: pointer;\\n}\\n.json-formatter-row .json-formatter-bracket {\\n color: blue;\\n}\\n.json-formatter-row .json-formatter-key {\\n color: #00008B;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-row .json-formatter-toggler-link {\\n cursor: pointer;\\n}\\n.json-formatter-row .json-formatter-toggler {\\n line-height: 1.2rem;\\n font-size: 0.7rem;\\n vertical-align: middle;\\n opacity: 0.6;\\n cursor: pointer;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-row .json-formatter-toggler:after {\\n display: inline-block;\\n transition: transform 100ms ease-in;\\n content: \\\"\\\\25BA\\\";\\n}\\n.json-formatter-row > a > .json-formatter-preview-text {\\n opacity: 0;\\n transition: opacity 0.15s ease-in;\\n font-style: italic;\\n}\\n.json-formatter-row:hover > a > .json-formatter-preview-text {\\n opacity: 0.6;\\n}\\n.json-formatter-row.json-formatter-open > .json-formatter-toggler-link .json-formatter-toggler:after {\\n transform: rotate(90deg);\\n}\\n.json-formatter-row.json-formatter-open > .json-formatter-children:after {\\n display: inline-block;\\n}\\n.json-formatter-row.json-formatter-open > a > .json-formatter-preview-text {\\n display: none;\\n}\\n.json-formatter-row.json-formatter-open.json-formatter-empty:after {\\n display: block;\\n}\\n.json-formatter-dark.json-formatter-row {\\n font-family: monospace;\\n}\\n.json-formatter-dark.json-formatter-row,\\n.json-formatter-dark.json-formatter-row a,\\n.json-formatter-dark.json-formatter-row a:hover {\\n color: white;\\n text-decoration: none;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-row {\\n margin-left: 1rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty {\\n opacity: 0.5;\\n margin-left: 1rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty:after {\\n display: none;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-object:after {\\n content: \\\"No properties\\\";\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-array:after {\\n content: \\\"[]\\\";\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-string,\\n.json-formatter-dark.json-formatter-row .json-formatter-stringifiable {\\n color: #31F031;\\n white-space: pre;\\n word-wrap: break-word;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-number {\\n color: #66C2FF;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-boolean {\\n color: #EC4242;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-null {\\n color: #EEC97D;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-undefined {\\n color: #ef8fbe;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-function {\\n color: #FD48CB;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-date {\\n background-color: rgba(255, 255, 255, 0.05);\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-url {\\n text-decoration: underline;\\n color: #027BFF;\\n cursor: pointer;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-bracket {\\n color: #9494FF;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-key {\\n color: #23A0DB;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-toggler-link {\\n cursor: pointer;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-toggler {\\n line-height: 1.2rem;\\n font-size: 0.7rem;\\n vertical-align: middle;\\n opacity: 0.6;\\n cursor: pointer;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-toggler:after {\\n display: inline-block;\\n transition: transform 100ms ease-in;\\n content: \\\"\\\\25BA\\\";\\n}\\n.json-formatter-dark.json-formatter-row > a > .json-formatter-preview-text {\\n opacity: 0;\\n transition: opacity 0.15s ease-in;\\n font-style: italic;\\n}\\n.json-formatter-dark.json-formatter-row:hover > a > .json-formatter-preview-text {\\n opacity: 0.6;\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open > .json-formatter-toggler-link .json-formatter-toggler:after {\\n transform: rotate(90deg);\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open > .json-formatter-children:after {\\n display: inline-block;\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open > a > .json-formatter-preview-text {\\n display: none;\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open.json-formatter-empty:after {\\n display: block;\\n}\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\"table.panel-df {\\n margin-left: auto;\\n margin-right: auto;\\n border: none;\\n border-collapse: collapse;\\n border-spacing: 0;\\n color: black;\\n font-size: 12px;\\n table-layout: fixed;\\n width: 100%;\\n}\\n\\n.panel-df tr, .panel-df th, .panel-df td {\\n text-align: right;\\n vertical-align: middle;\\n padding: 0.5em 0.5em !important;\\n line-height: normal;\\n white-space: normal;\\n max-width: none;\\n border: none;\\n}\\n\\n.panel-df tbody {\\n display: table-row-group;\\n vertical-align: middle;\\n border-color: inherit;\\n}\\n\\n.panel-df tbody tr:nth-child(odd) {\\n background: #f5f5f5;\\n}\\n\\n.panel-df thead {\\n border-bottom: 1px solid black;\\n vertical-align: bottom;\\n}\\n\\n.panel-df tr:hover {\\n background: lightblue !important;\\n cursor: pointer;\\n}\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\".bk.debugger-card {\\n border: 1px solid rgba(0,0,0,1);\\n color: rgba(255,255,255,1);\\n background-color: rgba(0,0,0,1);\\n border-radius: 0rem;\\n}\\n.bk.debugger-card-header {\\n align-items: center;\\n text-align: left;\\n background-color: rgba(0, 0, 0, 1)!important;\\n color: rgba(255, 255, 255, 1);\\n border-radius: 0rem;\\n display: inline-flex;\\n justify-content: start;\\n width: 100%;\\n}\\n.bk.debugger-card-button {\\n background-color: transparent;\\n color: rgba(255, 255, 255, 1);\\n margin-left: 0.5em;\\n}\\n.bk.debugger-card-title {\\n align-items: center;\\n text-align: left;\\n color: rgba(255, 255, 255, 1);\\n font-size: 1em;\\n overflow-wrap: break-word;\\n}\\n\\n/* Special debugger buttons for clearing and saving */\\n.bk button.special_btn {\\n width: 25px;\\n height: 25px;\\n background-color: black;\\n color: white;\\n display: inline-block;\\n}\\n\\n\\n.bk button.special_btn .tooltiptext {\\n visibility: hidden;\\n width: 100px;\\n background-color: darkgray;\\n color: #fff;\\n text-align: center;\\n border-radius: 6px;\\n padding: 5px 0;\\n\\n /* Position the tooltip */\\n position: relative;\\n z-index: 1;\\n top: 100%;\\n left: 100%;\\n margin-left: -100px;\\n display: block;\\n}\\n\\n.bk button.special_btn:hover .tooltiptext {\\n visibility: visible;\\n}\\n\\n\\n\\n.bk button.clear_btn:hover .shown { display: none;}\\n.bk button.clear_btn:hover:before { content: \\\"\\u2611\\\"; }\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\".bk.alert {\\n padding: 0.75rem 1.25rem;\\n border: 1px solid transparent;\\n border-radius: 0.25rem;\\n /* Don't set margin because that will not render correctly! */\\n /* margin-bottom: 1rem; */\\n margin-top: 15px;\\n margin-bottom: 15px;\\n}\\n.bk.alert a {\\n color: rgb(11, 46, 19); /* #002752; */\\n font-weight: 700;\\n text-decoration: rgb(11, 46, 19);\\n text-decoration-color: rgb(11, 46, 19);\\n text-decoration-line: none;\\n text-decoration-style: solid;\\n text-decoration-thickness: auto;\\n }\\n.bk.alert a:hover {\\n color: rgb(11, 46, 19);\\n font-weight: 700;\\n text-decoration: underline;\\n}\\n\\n.bk.alert-primary {\\n color: #004085;\\n background-color: #cce5ff;\\n border-color: #b8daff;\\n}\\n.bk.alert-primary hr {\\n border-top-color: #9fcdff;\\n}\\n\\n.bk.alert-secondary {\\n color: #383d41;\\n background-color: #e2e3e5;\\n border-color: #d6d8db;\\n }\\n.bk.alert-secondary hr {\\n border-top-color: #c8cbcf;\\n}\\n\\n.bk.alert-success {\\n color: #155724;\\n background-color: #d4edda;\\n border-color: #c3e6cb;\\n }\\n\\n.bk.alert-success hr {\\n border-top-color: #b1dfbb;\\n}\\n\\n.bk.alert-info {\\n color: #0c5460;\\n background-color: #d1ecf1;\\n border-color: #bee5eb;\\n }\\n.bk.alert-info hr {\\n border-top-color: #abdde5;\\n}\\n\\n.bk.alert-warning {\\n color: #856404;\\n background-color: #fff3cd;\\n border-color: #ffeeba;\\n }\\n\\n.bk.alert-warning hr {\\n border-top-color: #ffe8a1;\\n}\\n\\n.bk.alert-danger {\\n color: #721c24;\\n background-color: #f8d7da;\\n border-color: #f5c6cb;\\n}\\n.bk.alert-danger hr {\\n border-top-color: #f1b0b7;\\n}\\n\\n.bk.alert-light {\\n color: #818182;\\n background-color: #fefefe;\\n border-color: #fdfdfe;\\n }\\n.bk.alert-light hr {\\n border-top-color: #ececf6;\\n}\\n\\n.bk.alert-dark {\\n color: #1b1e21;\\n background-color: #d6d8d9;\\n border-color: #c6c8ca;\\n }\\n.bk.alert-dark hr {\\n border-top-color: #b9bbbe;\\n}\\n\\n\\n/* adjf\\u00e6l */\\n\\n.bk.alert-primary a {\\n color: #002752;\\n}\\n\\n.bk.alert-secondary a {\\n color: #202326;\\n}\\n\\n\\n.bk.alert-success a {\\n color: #0b2e13;\\n}\\n\\n\\n.bk.alert-info a {\\n color: #062c33;\\n}\\n\\n\\n.bk.alert-warning a {\\n color: #533f03;\\n}\\n\\n\\n.bk.alert-danger a {\\n color: #491217;\\n}\\n\\n.bk.alert-light a {\\n color: #686868;\\n}\\n\\n.bk.alert-dark a {\\n color: #040505;\\n}\\n\");\n", " }, function(Bokeh) {\n", " inject_raw_css(\"\\n .bk.pn-loading.arcs:before {\\n background-image: url(\\\"\\\");\\n background-size: auto calc(min(50%, 400px));\\n }\\n \");\n", " }, function(Bokeh) {\n", " /* BEGIN bokeh.min.js */\n", " /*!\n", " * Copyright (c) 2012 - 2021, Anaconda, Inc., and Bokeh Contributors\n", " * All rights reserved.\n", " * \n", " * Redistribution and use in source and binary forms, with or without modification,\n", " * are permitted provided that the following conditions are met:\n", " * \n", " * Redistributions of source code must retain the above copyright notice,\n", " * this list of conditions and the following disclaimer.\n", " * \n", " * Redistributions in binary form must reproduce the above copyright notice,\n", " * this list of conditions and the following disclaimer in the documentation\n", " * and/or other materials provided with the distribution.\n", " * \n", " * Neither the name of Anaconda nor the names of any contributors\n", " * may be used to endorse or promote products derived from this software\n", " * without specific prior written permission.\n", " * \n", " * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n", " * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n", " * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n", " * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE\n", " * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n", " * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n", " * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\n", " * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\n", " * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n", " * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\n", " * THE POSSIBILITY OF SUCH DAMAGE.\n", " */\n", " (function(root, factory) {\n", " const bokeh = factory();\n", " bokeh.__bokeh__ = true;\n", " if (typeof root.Bokeh === \"undefined\" || typeof root.Bokeh.__bokeh__ === \"undefined\") {\n", " root.Bokeh = bokeh;\n", " }\n", " const Bokeh = root.Bokeh;\n", " Bokeh[bokeh.version] = bokeh;\n", " })(this, function() {\n", " let define;\n", " const parent_require = typeof require === \"function\" && require\n", " return (function(modules, entry, aliases, externals) {\n", " if (aliases === undefined) aliases = {};\n", " if (externals === undefined) externals = {};\n", "\n", " const cache = {};\n", "\n", " const normalize = function(name) {\n", " if (typeof name === \"number\")\n", " return name;\n", "\n", " if (name === \"bokehjs\")\n", " return entry;\n", "\n", " if (!externals[name]) {\n", " const prefix = \"@bokehjs/\"\n", " if (name.slice(0, prefix.length) === prefix)\n", " name = name.slice(prefix.length)\n", " }\n", "\n", " const alias = aliases[name]\n", " if (alias != null)\n", " return alias;\n", "\n", " const trailing = name.length > 0 && name[name.lenght-1] === \"/\";\n", " const index = aliases[name + (trailing ? \"\" : \"/\") + \"index\"];\n", " if (index != null)\n", " return index;\n", "\n", " return name;\n", " }\n", "\n", " const require = function(name) {\n", " let mod = cache[name];\n", " if (!mod) {\n", " const id = normalize(name);\n", "\n", " mod = cache[id];\n", " if (!mod) {\n", " if (!modules[id]) {\n", " if (externals[id] === false || (externals[id] == true && parent_require)) {\n", " try {\n", " mod = {exports: externals[id] ? parent_require(id) : {}};\n", " cache[id] = cache[name] = mod;\n", " return mod.exports;\n", " } catch (e) {}\n", " }\n", "\n", " const err = new Error(\"Cannot find module '\" + name + \"'\");\n", " err.code = 'MODULE_NOT_FOUND';\n", " throw err;\n", " }\n", "\n", " mod = {exports: {}};\n", " cache[id] = cache[name] = mod;\n", "\n", " function __esModule() {\n", " Object.defineProperty(mod.exports, \"__esModule\", {value: true});\n", " }\n", "\n", " function __esExport(name, value) {\n", " Object.defineProperty(mod.exports, name, {\n", " enumerable: true, get: function () { return value; }\n", " });\n", " }\n", "\n", " modules[id].call(mod.exports, require, mod, mod.exports, __esModule, __esExport);\n", " } else {\n", " cache[name] = mod;\n", " }\n", " }\n", "\n", " return mod.exports;\n", " }\n", " require.resolve = function(name) {\n", " return \"\"\n", " }\n", "\n", " const main = require(entry);\n", " main.require = require;\n", "\n", " if (typeof Proxy !== \"undefined\") {\n", " // allow Bokeh.loader[\"@bokehjs/module/name\"] syntax\n", " main.loader = new Proxy({}, {\n", " get: function(_obj, module) {\n", " return require(module);\n", " }\n", " });\n", " }\n", "\n", " main.register_plugin = function(plugin_modules, plugin_entry, plugin_aliases, plugin_externals) {\n", " if (plugin_aliases === undefined) plugin_aliases = {};\n", " if (plugin_externals === undefined) plugin_externals = {};\n", "\n", " for (let name in plugin_modules) {\n", " modules[name] = plugin_modules[name];\n", " }\n", "\n", " for (let name in plugin_aliases) {\n", " aliases[name] = plugin_aliases[name];\n", " }\n", "\n", " for (let name in plugin_externals) {\n", " externals[name] = plugin_externals[name];\n", " }\n", "\n", " const plugin = require(plugin_entry);\n", "\n", " for (let name in plugin) {\n", " main[name] = plugin[name];\n", " }\n", "\n", " return plugin;\n", " }\n", "\n", " return main;\n", " })\n", " ([\n", " function _(t,_,n,o,r){o();(0,t(1).__exportStar)(t(2),n)},\n", " function _(t,e,r,n,o){n();var a=function(t,e){return a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&(t[r]=e[r])},a(t,e)};r.__extends=function(t,e){if(\"function\"!=typeof e&&null!==e)throw new TypeError(\"Class extends value \"+String(e)+\" is not a constructor or null\");function r(){this.constructor=t}a(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)};function i(t){var e=\"function\"==typeof Symbol&&Symbol.iterator,r=e&&t[e],n=0;if(r)return r.call(t);if(t&&\"number\"==typeof t.length)return{next:function(){return t&&n>=t.length&&(t=void 0),{value:t&&t[n++],done:!t}}};throw new TypeError(e?\"Object is not iterable.\":\"Symbol.iterator is not defined.\")}function c(t,e){var r=\"function\"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var n,o,a=r.call(t),i=[];try{for(;(void 0===e||e-- >0)&&!(n=a.next()).done;)i.push(n.value)}catch(t){o={error:t}}finally{try{n&&!n.done&&(r=a.return)&&r.call(a)}finally{if(o)throw o.error}}return i}function u(t){return this instanceof u?(this.v=t,this):new u(t)}r.__assign=function(){return r.__assign=Object.assign||function(t){for(var e,r=1,n=arguments.length;r=0;c--)(o=t[c])&&(i=(a<3?o(i):a>3?o(e,r,i):o(e,r))||i);return a>3&&i&&Object.defineProperty(e,r,i),i},r.__param=function(t,e){return function(r,n){e(r,n,t)}},r.__metadata=function(t,e){if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.metadata)return Reflect.metadata(t,e)},r.__awaiter=function(t,e,r,n){return new(r||(r=Promise))((function(o,a){function i(t){try{u(n.next(t))}catch(t){a(t)}}function c(t){try{u(n.throw(t))}catch(t){a(t)}}function u(t){var e;t.done?o(t.value):(e=t.value,e instanceof r?e:new r((function(t){t(e)}))).then(i,c)}u((n=n.apply(t,e||[])).next())}))},r.__generator=function(t,e){var r,n,o,a,i={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return a={next:c(0),throw:c(1),return:c(2)},\"function\"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function c(a){return function(c){return function(a){if(r)throw new TypeError(\"Generator is already executing.\");for(;i;)try{if(r=1,n&&(o=2&a[0]?n.return:a[0]?n.throw||((o=n.return)&&o.call(n),0):n.next)&&!(o=o.call(n,a[1])).done)return o;switch(n=0,o&&(a=[2&a[0],o.value]),a[0]){case 0:case 1:o=a;break;case 4:return i.label++,{value:a[1],done:!1};case 5:i.label++,n=a[1],a=[0];continue;case 7:a=i.ops.pop(),i.trys.pop();continue;default:if(!(o=i.trys,(o=o.length>0&&o[o.length-1])||6!==a[0]&&2!==a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]1||c(t,e)}))})}function c(t,e){try{(r=o[t](e)).value instanceof u?Promise.resolve(r.value.v).then(f,l):s(a[0][2],r)}catch(t){s(a[0][3],t)}var r}function f(t){c(\"next\",t)}function l(t){c(\"throw\",t)}function s(t,e){t(e),a.shift(),a.length&&c(a[0][0],a[0][1])}},r.__asyncDelegator=function(t){var e,r;return e={},n(\"next\"),n(\"throw\",(function(t){throw t})),n(\"return\"),e[Symbol.iterator]=function(){return this},e;function n(n,o){e[n]=t[n]?function(e){return(r=!r)?{value:u(t[n](e)),done:\"return\"===n}:o?o(e):e}:o}},r.__asyncValues=function(t){if(!Symbol.asyncIterator)throw new TypeError(\"Symbol.asyncIterator is not defined.\");var e,r=t[Symbol.asyncIterator];return r?r.call(t):(t=i(t),e={},n(\"next\"),n(\"throw\"),n(\"return\"),e[Symbol.asyncIterator]=function(){return this},e);function n(r){e[r]=t[r]&&function(e){return new Promise((function(n,o){(function(t,e,r,n){Promise.resolve(n).then((function(e){t({value:e,done:r})}),e)})(n,o,(e=t[r](e)).done,e.value)}))}}},r.__makeTemplateObject=function(t,e){return Object.defineProperty?Object.defineProperty(t,\"raw\",{value:e}):t.raw=e,t};var f=Object.create?function(t,e){Object.defineProperty(t,\"default\",{enumerable:!0,value:e})}:function(t,e){t.default=e};r.__importStar=function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var n in t)\"default\"!==n&&Object.prototype.hasOwnProperty.call(t,n)&&(0,r.__createBinding)(e,t,n);return f(e,t),e},r.__importDefault=function(t){return t&&t.__esModule?t:{default:t}},r.__classPrivateFieldGet=function(t,e,r,n){if(\"a\"===r&&!n)throw new TypeError(\"Private accessor was defined without a getter\");if(\"function\"==typeof e?t!==e||!n:!e.has(t))throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");return\"m\"===r?n:\"a\"===r?n.call(t):n?n.value:e.get(t)},r.__classPrivateFieldSet=function(t,e,r,n,o){if(\"m\"===n)throw new TypeError(\"Private method is not writable\");if(\"a\"===n&&!o)throw new TypeError(\"Private accessor was defined without a setter\");if(\"function\"==typeof e?t!==e||!o:!e.has(t))throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");return\"a\"===n?o.call(t,r):o?o.value=r:e.set(t,r),r}},\n", " function _(e,t,o,s,l){s();const n=e(1);l(\"version\",e(3).version),l(\"index\",e(4).index),o.embed=(0,n.__importStar)(e(4)),o.protocol=(0,n.__importStar)(e(406)),o._testing=(0,n.__importStar)(e(407));var r=e(19);l(\"logger\",r.logger),l(\"set_log_level\",r.set_log_level),l(\"settings\",e(28).settings),l(\"Models\",e(7).Models),l(\"documents\",e(5).documents),l(\"safely\",e(408).safely)},\n", " function _(n,i,o,c,e){c(),o.version=\"2.4.2\"},\n", " function _(e,o,t,n,s){n();const d=e(5),r=e(19),_=e(34),c=e(13),i=e(8),a=e(16),u=e(397),l=e(399),m=e(398);var f=e(397);s(\"add_document_standalone\",f.add_document_standalone),s(\"index\",f.index),s(\"add_document_from_session\",e(399).add_document_from_session);var g=e(404);async function w(e,o,t,n){(0,i.isString)(e)&&(e=JSON.parse((0,_.unescape)(e)));const s={};for(const[o,t]of(0,c.entries)(e))s[o]=d.Document.from_json(t);const a=[];for(const e of o){const o=(0,m._resolve_element)(e),d=(0,m._resolve_root_elements)(e);if(null!=e.docid)a.push(await(0,u.add_document_standalone)(s[e.docid],o,d,e.use_for_title));else{if(null==e.token)throw new Error(\"Error rendering Bokeh items: either 'docid' or 'token' was expected.\");{const s=(0,l._get_ws_url)(t,n);r.logger.debug(`embed: computed ws url: ${s}`);try{a.push(await(0,l.add_document_from_session)(s,e.token,o,d,e.use_for_title)),console.log(\"Bokeh items were rendered successfully\")}catch(e){console.log(\"Error rendering Bokeh items:\",e)}}}}return a}s(\"embed_items_notebook\",g.embed_items_notebook),s(\"kernels\",g.kernels),s(\"BOKEH_ROOT\",e(398).BOKEH_ROOT),t.embed_item=async function(e,o){const t={},n=(0,_.uuid4)();t[n]=e.doc,null==o&&(o=e.target_id);const s=document.getElementById(o);null!=s&&s.classList.add(m.BOKEH_ROOT);const d={roots:{[e.root_id]:o},root_ids:[e.root_id],docid:n};await(0,a.defer)();const[r]=await w(t,[d]);return r},t.embed_items=async function(e,o,t,n){return await(0,a.defer)(),w(e,o,t,n)}},\n", " function _(t,_,o,r,n){r();const a=t(1);(0,a.__exportStar)(t(6),o),(0,a.__exportStar)(t(35),o)},\n", " function _(e,t,s,o,n){o();const i=e(1),r=e(7),a=e(3),l=e(19),_=e(251),c=e(14),d=e(30),h=e(15),f=e(17),u=e(31),m=e(29),g=e(9),v=e(13),p=(0,i.__importStar)(e(77)),w=e(26),b=e(8),y=e(309),k=e(75),M=e(53),j=e(396),S=e(35);class z{constructor(e){this.document=e,this.session=null,this.subscribed_models=new Set}send_event(e){const t=new S.MessageSentEvent(this.document,\"bokeh_event\",e.to_json());this.document._trigger_on_change(t)}trigger(e){for(const t of this.subscribed_models)null!=e.origin&&e.origin!=t||t._process_event(e)}}s.EventManager=z,z.__name__=\"EventManager\",s.documents=[],s.DEFAULT_TITLE=\"Bokeh Application\";class E{constructor(e){var t;s.documents.push(this),this._init_timestamp=Date.now(),this._resolver=null!==(t=null==e?void 0:e.resolver)&&void 0!==t?t:new r.ModelResolver,this._title=s.DEFAULT_TITLE,this._roots=[],this._all_models=new Map,this._all_models_freeze_count=0,this._callbacks=new Map,this._message_callbacks=new Map,this.event_manager=new z(this),this.idle=new h.Signal0(this,\"idle\"),this._idle_roots=new WeakMap,this._interactive_timestamp=null,this._interactive_plot=null}get layoutables(){return this._roots.filter((e=>e instanceof y.LayoutDOM))}get is_idle(){for(const e of this.layoutables)if(!this._idle_roots.has(e))return!1;return!0}notify_idle(e){this._idle_roots.set(e,!0),this.is_idle&&(l.logger.info(`document idle at ${Date.now()-this._init_timestamp} ms`),this.event_manager.send_event(new _.DocumentReady),this.idle.emit())}clear(){this._push_all_models_freeze();try{for(;this._roots.length>0;)this.remove_root(this._roots[0])}finally{this._pop_all_models_freeze()}}interactive_start(e,t=null){null==this._interactive_plot&&(this._interactive_plot=e,this._interactive_plot.trigger_event(new _.LODStart)),this._interactive_finalize=t,this._interactive_timestamp=Date.now()}interactive_stop(){null!=this._interactive_plot&&(this._interactive_plot.trigger_event(new _.LODEnd),null!=this._interactive_finalize&&this._interactive_finalize()),this._interactive_plot=null,this._interactive_timestamp=null,this._interactive_finalize=null}interactive_duration(){return null==this._interactive_timestamp?-1:Date.now()-this._interactive_timestamp}destructively_move(e){if(e===this)throw new Error(\"Attempted to overwrite a document with itself\");e.clear();const t=(0,g.copy)(this._roots);this.clear();for(const e of t)if(null!=e.document)throw new Error(`Somehow we didn't detach ${e}`);if(0!=this._all_models.size)throw new Error(`this._all_models still had stuff in it: ${this._all_models}`);for(const s of t)e.add_root(s);e.set_title(this._title)}_push_all_models_freeze(){this._all_models_freeze_count+=1}_pop_all_models_freeze(){this._all_models_freeze_count-=1,0===this._all_models_freeze_count&&this._recompute_all_models()}_invalidate_all_models(){l.logger.debug(\"invalidating document models\"),0===this._all_models_freeze_count&&this._recompute_all_models()}_recompute_all_models(){let e=new Set;for(const t of this._roots)e=p.union(e,t.references());const t=new Set(this._all_models.values()),s=p.difference(t,e),o=p.difference(e,t),n=new Map;for(const t of e)n.set(t.id,t);for(const e of s)e.detach_document();for(const e of o)e.attach_document(this);this._all_models=n}roots(){return this._roots}add_root(e,t){if(l.logger.debug(`Adding root: ${e}`),!(0,g.includes)(this._roots,e)){this._push_all_models_freeze();try{this._roots.push(e)}finally{this._pop_all_models_freeze()}this._trigger_on_change(new S.RootAddedEvent(this,e,t))}}remove_root(e,t){const s=this._roots.indexOf(e);if(!(s<0)){this._push_all_models_freeze();try{this._roots.splice(s,1)}finally{this._pop_all_models_freeze()}this._trigger_on_change(new S.RootRemovedEvent(this,e,t))}}title(){return this._title}set_title(e,t){e!==this._title&&(this._title=e,this._trigger_on_change(new S.TitleChangedEvent(this,e,t)))}get_model_by_id(e){var t;return null!==(t=this._all_models.get(e))&&void 0!==t?t:null}get_model_by_name(e){const t=[];for(const s of this._all_models.values())s instanceof M.Model&&s.name==e&&t.push(s);switch(t.length){case 0:return null;case 1:return t[0];default:throw new Error(`Multiple models are named '${e}'`)}}on_message(e,t){const s=this._message_callbacks.get(e);null==s?this._message_callbacks.set(e,new Set([t])):s.add(t)}remove_on_message(e,t){var s;null===(s=this._message_callbacks.get(e))||void 0===s||s.delete(t)}_trigger_on_message(e,t){const s=this._message_callbacks.get(e);if(null!=s)for(const e of s)e(t)}on_change(e,t=!1){this._callbacks.has(e)||this._callbacks.set(e,t)}remove_on_change(e){this._callbacks.delete(e)}_trigger_on_change(e){for(const[t,s]of this._callbacks)if(!s&&e instanceof S.DocumentEventBatch)for(const s of e.events)t(s);else t(e)}_notify_change(e,t,s,o,n){this._trigger_on_change(new S.ModelChangedEvent(this,e,t,s,o,null==n?void 0:n.setter_id,null==n?void 0:n.hint))}static _instantiate_object(e,t,s,o){const n=Object.assign(Object.assign({},s),{id:e,__deferred__:!0});return new(o.get(t))(n)}static _instantiate_references_json(e,t,s){var o;const n=new Map;for(const i of e){const e=i.id,r=i.type,a=null!==(o=i.attributes)&&void 0!==o?o:{};let l=t.get(e);null==l&&(l=E._instantiate_object(e,r,a,s),null!=i.subtype&&l.set_subtype(i.subtype)),n.set(l.id,l)}return n}static _resolve_refs(e,t,s,o){function n(e){var i;if((0,f.is_ref)(e)){const o=null!==(i=t.get(e.id))&&void 0!==i?i:s.get(e.id);if(null!=o)return o;throw new Error(`reference ${JSON.stringify(e)} isn't known (not in Document?)`)}if((0,u.is_NDArray_ref)(e)){const{buffer:t,dtype:s,shape:n}=(0,u.decode_NDArray)(e,o);return(0,m.ndarray)(t,{dtype:s,shape:n})}return(0,b.isArray)(e)?function(e){const t=[];for(const s of e)t.push(n(s));return t}(e):(0,b.isPlainObject)(e)?function(e){const t={};for(const[s,o]of(0,v.entries)(e))t[s]=n(o);return t}(e):e}return n(e)}static _initialize_references_json(e,t,s,o){const n=new Map;for(const{id:i,attributes:r}of e){const e=!t.has(i),a=e?s.get(i):t.get(i),l=E._resolve_refs(r,t,s,o);a.setv(l,{silent:!0}),n.set(i,{instance:a,is_new:e})}const i=[],r=new Set;function a(e){if(e instanceof c.HasProps){if(n.has(e.id)&&!r.has(e.id)){r.add(e.id);const{instance:t,is_new:s}=n.get(e.id),{attributes:o}=t;for(const e of(0,v.values)(o))a(e);s&&(t.finalize(),i.push(t))}}else if((0,b.isArray)(e))for(const t of e)a(t);else if((0,b.isPlainObject)(e))for(const t of(0,v.values)(e))a(t)}for(const e of n.values())a(e.instance);for(const e of i)e.connect_signals()}static _event_for_attribute_change(e,t,s,o,n){if(o.get_model_by_id(e.id).property(t).syncable){const i={kind:\"ModelChanged\",model:{id:e.id},attr:t,new:s};return c.HasProps._json_record_references(o,s,n,{recursive:!0}),i}return null}static _events_to_sync_objects(e,t,s,o){const n=Object.keys(e.attributes),i=Object.keys(t.attributes),r=(0,g.difference)(n,i),a=(0,g.difference)(i,n),_=(0,g.intersection)(n,i),c=[];for(const e of r)l.logger.warn(`Server sent key ${e} but we don't seem to have it in our JSON`);for(const n of a){const i=t.attributes[n];c.push(E._event_for_attribute_change(e,n,i,s,o))}for(const n of _){const i=e.attributes[n],r=t.attributes[n];null==i&&null==r||(null==i||null==r?c.push(E._event_for_attribute_change(e,n,r,s,o)):\"data\"==n||(0,w.is_equal)(i,r)||c.push(E._event_for_attribute_change(e,n,r,s,o)))}return c.filter((e=>null!=e))}static _compute_patch_since_json(e,t){const s=t.to_json(!1);function o(e){const t=new Map;for(const s of e.roots.references)t.set(s.id,s);return t}const n=o(e),i=new Map,r=[];for(const t of e.roots.root_ids)i.set(t,n.get(t)),r.push(t);const a=o(s),l=new Map,_=[];for(const e of s.roots.root_ids)l.set(e,a.get(e)),_.push(e);if(r.sort(),_.sort(),(0,g.difference)(r,_).length>0||(0,g.difference)(_,r).length>0)throw new Error(\"Not implemented: computing add/remove of document roots\");const c=new Set;let h=[];for(const e of t._all_models.keys())if(n.has(e)){const s=E._events_to_sync_objects(n.get(e),a.get(e),t,c);h=h.concat(s)}const f=new d.Serializer({include_defaults:!1});return f.to_serializable([...c]),{references:[...f.definitions],events:h}}to_json_string(e=!0){return JSON.stringify(this.to_json(e))}to_json(e=!0){const t=new d.Serializer({include_defaults:e}),s=t.to_serializable(this._roots);return{version:a.version,title:this._title,roots:{root_ids:s.map((e=>e.id)),references:[...t.definitions]}}}static from_json_string(e){const t=JSON.parse(e);return E.from_json(t)}static from_json(e){l.logger.debug(\"Creating Document from JSON\");const t=e.version,s=-1!==t.indexOf(\"+\")||-1!==t.indexOf(\"-\"),o=`Library versions: JS (${a.version}) / Python (${t})`;s||a.version.replace(/-(dev|rc)\\./,\"$1\")==t?l.logger.debug(o):(l.logger.warn(\"JS/Python version mismatch\"),l.logger.warn(o));const n=new r.ModelResolver;null!=e.defs&&(0,j.resolve_defs)(e.defs,n);const i=e.roots,_=i.root_ids,c=i.references,d=E._instantiate_references_json(c,new Map,n);E._initialize_references_json(c,new Map,d,new Map);const h=new E({resolver:n});for(const e of _){const t=d.get(e);null!=t&&h.add_root(t)}return h.set_title(e.title),h}replace_with_json(e){E.from_json(e).destructively_move(this)}create_json_patch_string(e){return JSON.stringify(this.create_json_patch(e))}create_json_patch(e){for(const t of e)if(t.document!=this)throw new Error(\"Cannot create a patch using events from a different document\");const t=new d.Serializer,s=t.to_serializable(e);for(const e of this._all_models.values())t.remove_def(e);return{events:s,references:[...t.definitions]}}apply_json_patch(e,t=new Map,s){const o=e.references,n=e.events,i=E._instantiate_references_json(o,this._all_models,this._resolver);t instanceof Map||(t=new Map(t));for(const e of n)switch(e.kind){case\"RootAdded\":case\"RootRemoved\":case\"ModelChanged\":{const t=e.model.id,s=this._all_models.get(t);if(null!=s)i.set(t,s);else if(!i.has(t))throw l.logger.warn(`Got an event for unknown model ${e.model}\"`),new Error(\"event model wasn't known\");break}}const r=new Map(this._all_models),a=new Map;for(const[e,t]of i)r.has(e)||a.set(e,t);E._initialize_references_json(o,r,a,t);for(const e of n)switch(e.kind){case\"MessageSent\":{const{msg_type:s,msg_data:o}=e;let n;if(void 0===o){if(1!=t.size)throw new Error(\"expected exactly one buffer\");{const[[,e]]=t;n=e}}else n=E._resolve_refs(o,r,a,t);this._trigger_on_message(s,n);break}case\"ModelChanged\":{const o=e.model.id,n=this._all_models.get(o);if(null==n)throw new Error(`Cannot apply patch to ${o} which is not in the document`);const i=e.attr,l=E._resolve_refs(e.new,r,a,t);n.setv({[i]:l},{setter_id:s});break}case\"ColumnDataChanged\":{const o=e.column_source.id,n=this._all_models.get(o);if(null==n)throw new Error(`Cannot stream to ${o} which is not in the document`);const i=E._resolve_refs(e.new,new Map,new Map,t);if(null!=e.cols)for(const e in n.data)e in i||(i[e]=n.data[e]);n.setv({data:i},{setter_id:s,check_eq:!1});break}case\"ColumnsStreamed\":{const t=e.column_source.id,o=this._all_models.get(t);if(null==o)throw new Error(`Cannot stream to ${t} which is not in the document`);if(!(o instanceof k.ColumnDataSource))throw new Error(\"Cannot stream to non-ColumnDataSource\");const n=e.data,i=e.rollover;o.stream(n,i,s);break}case\"ColumnsPatched\":{const t=e.column_source.id,o=this._all_models.get(t);if(null==o)throw new Error(`Cannot patch ${t} which is not in the document`);if(!(o instanceof k.ColumnDataSource))throw new Error(\"Cannot patch non-ColumnDataSource\");const n=e.patches;o.patch(n,s);break}case\"RootAdded\":{const t=e.model.id,o=i.get(t);this.add_root(o,s);break}case\"RootRemoved\":{const t=e.model.id,o=i.get(t);this.remove_root(o,s);break}case\"TitleChanged\":this.set_title(e.title,s);break;default:throw new Error(`Unknown patch event ${JSON.stringify(e)}`)}}}s.Document=E,E.__name__=\"Document\"},\n", " function _(e,o,s,r,t){r();const l=e(1),i=e(8),d=e(13),n=e(14);s.overrides={};const a=new Map;s.Models=e=>{const o=s.Models.get(e);if(null!=o)return o;throw new Error(`Model '${e}' does not exist. This could be due to a widget or a custom model not being registered before first usage.`)},s.Models.get=e=>{var o;return null!==(o=s.overrides[e])&&void 0!==o?o:a.get(e)},s.Models.register=(e,o)=>{s.overrides[e]=o},s.Models.unregister=e=>{delete s.overrides[e]},s.Models.register_models=(e,o=!1,s)=>{var r;if(null!=e)for(const t of(0,i.isArray)(e)?e:(0,d.values)(e))if(r=t,(0,i.isObject)(r)&&r.prototype instanceof n.HasProps){const e=t.__qualified__;o||!a.has(e)?a.set(e,t):null!=s?s(e):console.warn(`Model '${e}' was already registered`)}},s.register_models=s.Models.register_models,s.Models.registered_names=()=>[...a.keys()];class _{constructor(){this._known_models=new Map}get(e,o){var r;const t=null!==(r=s.Models.get(e))&&void 0!==r?r:this._known_models.get(e);if(null!=t)return t;if(void 0!==o)return o;throw new Error(`Model '${e}' does not exist. This could be due to a widget or a custom model not being registered before first usage.`)}register(e){const o=e.__qualified__;null==this.get(o,null)?this._known_models.set(o,e):console.warn(`Model '${o}' was already registered with this resolver`)}}s.ModelResolver=_,_.__name__=\"ModelResolver\";const g=(0,l.__importStar)(e(38));(0,s.register_models)(g);const u=(0,l.__importStar)(e(392));(0,s.register_models)(u)},\n", " function _(n,t,r,e,i){e();\n", " // (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n", " // Underscore may be freely distributed under the MIT license.\n", " const o=n(9),u=Object.prototype.toString;function c(n){return!0===n||!1===n||\"[object Boolean]\"===u.call(n)}function f(n){return\"[object Number]\"===u.call(n)}function l(n){return\"[object String]\"===u.call(n)}function s(n){return\"symbol\"==typeof n}function a(n){const t=typeof n;return\"function\"===t||\"object\"===t&&!!n}function b(n){return a(n)&&void 0!==n[Symbol.iterator]}r.isBoolean=c,r.isNumber=f,r.isInteger=function(n){return f(n)&&Number.isInteger(n)},r.isString=l,r.isSymbol=s,r.isPrimitive=function(n){return null===n||c(n)||f(n)||l(n)||s(n)},r.isFunction=function(n){return\"[object Function]\"===u.call(n)},r.isArray=function(n){return Array.isArray(n)},r.isArrayOf=function(n,t){return(0,o.every)(n,t)},r.isArrayableOf=function(n,t){for(let r=0,e=n.length;r0,\"'step' must be a positive number\"),null==t&&(t=n,n=0);const{max:r,ceil:o,abs:i}=Math,c=n<=t?e:-e,f=r(o(i(t-n)/e),0),s=new Array(f);for(let t=0;t=0?t:n.length+t]},e.zip=function(...n){if(0==n.length)return[];const t=(0,c.min)(n.map((n=>n.length))),e=n.length,r=new Array(t);for(let o=0;on.length))),r=Array(e);for(let n=0;nn[t]))},e.argmax=function(n){return(0,c.max_by)(m(n.length),(t=>n[t]))},e.sort_by=function(n,t){const e=n.map(((n,e)=>({value:n,index:e,key:t(n)})));return e.sort(((n,t)=>{const e=n.key,r=t.key;if(e!==r){if(e>r||void 0===e)return 1;if(en.value))},e.uniq=function(n){const t=new Set;for(const e of n)t.add(e);return[...t]},e.uniq_by=function(n,t){const e=[],r=[];for(const o of n){const n=t(o);l(r,n)||(r.push(n),e.push(o))}return e},e.union=function(...n){const t=new Set;for(const e of n)for(const n of e)t.add(n);return[...t]},e.intersection=function(n,...t){const e=[];n:for(const r of n)if(!l(e,r)){for(const n of t)if(!l(n,r))continue n;e.push(r)}return e},e.difference=function(n,...t){const e=a(t);return n.filter((n=>!l(e,n)))},e.remove_at=function(n,t){const e=s(n);return e.splice(t,1),e},e.remove_by=function(n,t){for(let e=0;e2*a;)n-=2*a;return n}function c(n,t){return u(n-t)}function f(){return Math.random()}function i(n){switch(n){case\"deg\":return a/180;case\"rad\":return 1;case\"grad\":return a/200;case\"turn\":return 2*a}}r.angle_norm=u,r.angle_dist=c,r.angle_between=function(n,t,r,e=!1){const o=c(t,r);if(0==o)return!1;if(o==2*a)return!0;const f=u(n),i=c(t,f)<=o&&c(f,r)<=o;return e?!i:i},r.random=f,r.randomIn=function(n,t){return null==t&&(t=n,n=0),n+Math.floor(Math.random()*(t-n+1))},r.atan2=function(n,t){return Math.atan2(t[1]-n[1],t[0]-n[0])},r.radians=function(n){return n*(a/180)},r.degrees=function(n){return n/(a/180)},r.resolve_angle=function(n,t){return-i(t)*n},r.to_radians_coeff=i,r.rnorm=function(n,t){let r,e;for(;r=f(),e=f(),e=(2*e-1)*Math.sqrt(1/Math.E*2),!(-4*r*r*Math.log(r)>=e*e););let o=e/r;return o=n+t*o,o},r.clamp=function(n,t,r){return nr?r:n},r.log=function(n,t=Math.E){return Math.log(n)/Math.log(t)},r.float32_epsilon=1.1920928955078125e-7},\n", " function _(r,n,e,o,s){o();class t extends Error{}e.AssertionError=t,t.__name__=\"AssertionError\",e.assert=function(r,n){if(!(!0===r||!1!==r&&r()))throw new t(null!=n?n:\"Assertion failed\")},e.unreachable=function(){throw new Error(\"unreachable code\")}},\n", " function _(n,t,e,r,o){r();const i=n(10);function l(n,t,e,...r){const o=n.length;t<0&&(t+=o),t<0?t=0:t>o&&(t=o),null==e||e>o-t?e=o-t:e<0&&(e=0);const i=o-e+r.length,l=new n.constructor(i);let u=0;for(;u0?0:r-1;for(;o>=0&&ot[t.length-1])return t.length;let e=0,r=t.length-1;for(;r-e!=1;){const o=e+Math.floor((r-e)/2);n>=t[o]?e=o:r=o}return e}e.is_empty=function(n){return 0==n.length},e.copy=function(n){return Array.isArray(n)?n.slice():new n.constructor(n)},e.splice=l,e.head=u,e.insert=function(n,t,e){return l(n,e,0,t)},e.append=function(n,t){return l(n,n.length,0,t)},e.prepend=function(n,t){return l(n,0,0,t)},e.indexOf=function(n,t){for(let e=0,r=n.length;ee&&(e=t);return e},e.minmax=function(n){let t,e=1/0,r=-1/0;for(let o=0,i=n.length;or&&(r=t));return[e,r]},e.minmax2=function(n,t){let e,r,o=1/0,i=-1/0,l=1/0,u=-1/0;const c=Math.min(n.length,t.length);for(let f=0;fi&&(i=e),ru&&(u=r));return[o,i,l,u]},e.min_by=function(n,t){if(0==n.length)throw new Error(\"min_by() called with an empty array\");let e=n[0],r=t(e);for(let o=1,i=n.length;or&&(e=i,r=l)}return e},e.sum=function(n){let t=0;for(let e=0,r=n.length;et[r]=n+e),0),t},e.every=function(n,t){for(let e=0,r=n.length;e(n-t)/r))}},\n", " function _(t,e,n,c,o){c();const s=t(9),{hasOwnProperty:r}=Object.prototype;function i(t){return Object.keys(t).length}function u(t){return 0==i(t)}n.keys=Object.keys,n.values=Object.values,n.entries=Object.entries,n.extend=Object.assign,n.clone=function(t){return Object.assign({},t)},n.merge=function(t,e){const n=Object.create(Object.prototype),c=(0,s.concat)([Object.keys(t),Object.keys(e)]);for(const o of c){const c=r.call(t,o)?t[o]:[],i=r.call(e,o)?e[o]:[];n[o]=(0,s.union)(c,i)}return n},n.size=i,n.is_empty=u,n.isEmpty=u,n.to_object=function(t){const e={};for(const[n,c]of t)e[n]=c;return e}},\n", " function _(e,t,s,n,r){n();const i=e(1);var o;const c=e(15),a=e(17),_=(0,i.__importStar)(e(18)),h=(0,i.__importStar)(e(21)),u=e(34),l=e(13),f=e(8),p=e(26),d=e(30),g=e(35),y=e(26),v=e(36),m=e(37),b=(0,i.__importStar)(e(21));class w extends((0,c.Signalable)()){constructor(e={}){var t,s;super(),this._subtype=void 0,this.document=null,this.destroyed=new c.Signal0(this,\"destroyed\"),this.change=new c.Signal0(this,\"change\"),this.transformchange=new c.Signal0(this,\"transformchange\"),this.exprchange=new c.Signal0(this,\"exprchange\"),this.properties={},this._watchers=new WeakMap,this._pending=!1,this._changing=!1;const n=e instanceof Map?e.get.bind(e):t=>e[t];this.id=null!==(t=n(\"id\"))&&void 0!==t?t:(0,u.uniqueId)();for(const[e,{type:t,default_value:s,options:r}]of(0,l.entries)(this._props)){let i;t instanceof _.PropertyAlias?Object.defineProperty(this.properties,e,{get:()=>this.properties[t.attr],configurable:!1,enumerable:!1}):(i=t instanceof h.Kind?new _.PrimitiveProperty(this,e,t,s,n(e),r):new t(this,e,h.Any,s,n(e),r),this.properties[e]=i)}null!==(s=n(\"__deferred__\"))&&void 0!==s&&s||(this.finalize(),this.connect_signals())}get is_syncable(){return!0}set type(e){console.warn(\"prototype.type = 'ModelName' is deprecated, use static __name__ instead\"),this.constructor.__name__=e}get type(){return this.constructor.__qualified__}static get __qualified__(){const{__module__:e,__name__:t}=this;return null!=e?`${e}.${t}`:t}static get[Symbol.toStringTag](){return this.__name__}static _fix_default(e,t){if(void 0===e||(0,f.isFunction)(e))return e;if((0,f.isPrimitive)(e))return()=>e;{const t=new m.Cloner;return()=>t.clone(e)}}static define(e){for(const[t,s]of(0,l.entries)((0,f.isFunction)(e)?e(b):e)){if(null!=this.prototype._props[t])throw new Error(`attempted to redefine property '${this.prototype.type}.${t}'`);if(null!=this.prototype[t])throw new Error(`attempted to redefine attribute '${this.prototype.type}.${t}'`);Object.defineProperty(this.prototype,t,{get(){return this.properties[t].get_value()},set(e){return this.setv({[t]:e}),this},configurable:!1,enumerable:!0});const[e,n,r={}]=s,i={type:e,default_value:this._fix_default(n,t),options:r},o=Object.assign({},this.prototype._props);o[t]=i,this.prototype._props=o}}static internal(e){const t={};for(const[s,n]of(0,l.entries)((0,f.isFunction)(e)?e(b):e)){const[e,r,i={}]=n;t[s]=[e,r,Object.assign(Object.assign({},i),{internal:!0})]}this.define(t)}static mixins(e){function t(e,t){const s={};for(const[n,r]of(0,l.entries)(t))s[e+n]=r;return s}const s={},n=[];for(const r of(0,f.isArray)(e)?e:[e])if((0,f.isArray)(r)){const[e,i]=r;(0,l.extend)(s,t(e,i)),n.push([e,i])}else{const e=r;(0,l.extend)(s,e),n.push([\"\",e])}this.define(s),this.prototype._mixins=[...this.prototype._mixins,...n]}static override(e){for(const[t,s]of(0,l.entries)(e)){const e=this._fix_default(s,t),n=this.prototype._props[t];if(null==n)throw new Error(`attempted to override nonexistent '${this.prototype.type}.${t}'`);const r=Object.assign({},this.prototype._props);r[t]=Object.assign(Object.assign({},n),{default_value:e}),this.prototype._props=r}}toString(){return`${this.type}(${this.id})`}property(e){const t=this.properties[e];if(null!=t)return t;throw new Error(`unknown property ${this.type}.${e}`)}get attributes(){const e={};for(const t of this)e[t.attr]=t.get_value();return e}[m.clone](e){const t=new Map;for(const s of this)s.dirty&&t.set(s.attr,e.clone(s.get_value()));return new this.constructor(t)}[y.equals](e,t){for(const s of this){const n=e.property(s.attr);if(!t.eq(s.get_value(),n.get_value()))return!1}return!0}[v.pretty](e){const t=e.token,s=[];for(const n of this)if(n.dirty){const r=n.get_value();s.push(`${n.attr}${t(\":\")} ${e.to_string(r)}`)}return`${this.constructor.__qualified__}${t(\"(\")}${t(\"{\")}${s.join(`${t(\",\")} `)}${t(\"}\")}${t(\")\")}`}[d.serialize](e){const t=this.ref();e.add_ref(this,t);const s=this.struct();for(const t of this)t.syncable&&(e.include_defaults||t.dirty)&&(s.attributes[t.attr]=e.to_serializable(t.get_value()));return e.add_def(this,s),t}finalize(){for(const e of this){if(!(e instanceof _.VectorSpec||e instanceof _.ScalarSpec))continue;const t=e.get_value();if(null!=t){const{transform:e,expr:s}=t;null!=e&&this.connect(e.change,(()=>this.transformchange.emit())),null!=s&&this.connect(s.change,(()=>this.exprchange.emit()))}}this.initialize()}initialize(){}connect_signals(){}disconnect_signals(){c.Signal.disconnectReceiver(this)}destroy(){this.disconnect_signals(),this.destroyed.emit()}clone(){return(new m.Cloner).clone(this)}changed_for(e){const t=this._watchers.get(e);return this._watchers.set(e,!1),null==t||t}_setv(e,t){const s=t.check_eq,n=[],r=this._changing;this._changing=!0;for(const[t,r]of e)!1!==s&&(0,p.is_equal)(t.get_value(),r)||(t.set_value(r),n.push(t));n.length>0&&(this._watchers=new WeakMap,this._pending=!0);for(const e of n)e.change.emit();if(!r){if(!t.no_change)for(;this._pending;)this._pending=!1,this.change.emit();this._pending=!1,this._changing=!1}}setv(e,t={}){const s=(0,l.entries)(e);if(0==s.length)return;if(!0===t.silent){this._watchers=new WeakMap;for(const[e,t]of s)this.properties[e].set_value(t);return}const n=new Map,r=new Map;for(const[e,t]of s){const s=this.properties[e];n.set(s,t),r.set(s,s.get_value())}this._setv(n,t);const{document:i}=this;if(null!=i){const e=[];for(const[t,s]of r)e.push([t,s,t.get_value()]);for(const[,t,s]of e)if(this._needs_invalidate(t,s)){i._invalidate_all_models();break}this._push_changes(e,t)}}getv(e){return this.property(e).get_value()}ref(){return{id:this.id}}struct(){const e={type:this.type,id:this.id,attributes:{}};return null!=this._subtype&&(e.subtype=this._subtype),e}set_subtype(e){this._subtype=e}*[Symbol.iterator](){yield*(0,l.values)(this.properties)}*syncable_properties(){for(const e of this)e.syncable&&(yield e)}serializable_attributes(){const e={};for(const t of this.syncable_properties())e[t.attr]=t.get_value();return e}static _json_record_references(e,t,s,n){const{recursive:r}=n;if((0,a.is_ref)(t)){const n=e.get_model_by_id(t.id);null==n||s.has(n)||w._value_record_references(n,s,{recursive:r})}else if((0,f.isArray)(t))for(const n of t)w._json_record_references(e,n,s,{recursive:r});else if((0,f.isPlainObject)(t))for(const n of(0,l.values)(t))w._json_record_references(e,n,s,{recursive:r})}static _value_record_references(e,t,s){const{recursive:n}=s;if(e instanceof w){if(!t.has(e)&&(t.add(e),n))for(const s of e.syncable_properties()){const e=s.get_value();w._value_record_references(e,t,{recursive:n})}}else if((0,f.isArray)(e))for(const s of e)w._value_record_references(s,t,{recursive:n});else if((0,f.isPlainObject)(e))for(const s of(0,l.values)(e))w._value_record_references(s,t,{recursive:n})}references(){const e=new Set;return w._value_record_references(this,e,{recursive:!0}),e}_doc_attached(){}_doc_detached(){}attach_document(e){if(null!=this.document&&this.document!=e)throw new Error(\"models must be owned by only a single document\");this.document=e,this._doc_attached()}detach_document(){this._doc_detached(),this.document=null}_needs_invalidate(e,t){const s=new Set;w._value_record_references(t,s,{recursive:!1});const n=new Set;w._value_record_references(e,n,{recursive:!1});for(const e of s)if(!n.has(e))return!0;for(const e of n)if(!s.has(e))return!0;return!1}_push_changes(e,t={}){if(!this.is_syncable)return;const{document:s}=this;if(null==s)return;const{setter_id:n}=t,r=[];for(const[t,i,o]of e)t.syncable&&r.push(new g.ModelChangedEvent(s,this,t.attr,i,o,n));if(0!=r.length){let e;1==r.length?[e]=r:e=new g.DocumentEventBatch(s,r,n),s._trigger_on_change(e)}}on_change(e,t){for(const s of(0,f.isArray)(e)?e:[e])this.connect(s.change,t)}}s.HasProps=w,(o=w).prototype._props={},o.prototype._mixins=[]},\n", " function _(n,t,e,l,s){l();const i=n(16),o=n(9);class c{constructor(n,t){this.sender=n,this.name=t}connect(n,t=null){u.has(this.sender)||u.set(this.sender,[]);const e=u.get(this.sender);if(null!=g(e,this,n,t))return!1;const l=null!=t?t:n;a.has(l)||a.set(l,[]);const s=a.get(l),i={signal:this,slot:n,context:t};return e.push(i),s.push(i),!0}disconnect(n,t=null){const e=u.get(this.sender);if(null==e||0===e.length)return!1;const l=g(e,this,n,t);if(null==l)return!1;const s=null!=t?t:n,i=a.get(s);return l.signal=null,d(e),d(i),!0}emit(n){var t;const e=null!==(t=u.get(this.sender))&&void 0!==t?t:[];for(const{signal:t,slot:l,context:s}of e)t===this&&l.call(s,n,this.sender)}}e.Signal=c,c.__name__=\"Signal\";class r extends c{emit(){super.emit(void 0)}}e.Signal0=r,r.__name__=\"Signal0\",function(n){function t(n,t){const e=u.get(n);if(null==e||0===e.length)return;const l=a.get(t);if(null!=l&&0!==l.length){for(const t of l){if(null==t.signal)return;t.signal.sender===n&&(t.signal=null)}d(e),d(l)}}function e(n){var t;const e=u.get(n);if(null!=e&&0!==e.length){for(const n of e){if(null==n.signal)return;const e=null!==(t=n.context)&&void 0!==t?t:n.slot;n.signal=null,d(a.get(e))}d(e)}}function l(n,t,e){const l=a.get(n);if(null!=l&&0!==l.length){for(const n of l){if(null==n.signal)return;if(null!=t&&n.slot!=t)continue;const l=n.signal.sender;null!=e&&e.has(l)||(n.signal=null,d(u.get(l)))}d(l)}}function s(n){const t=u.get(n);if(null!=t&&0!==t.length){for(const n of t)n.signal=null;d(t)}const e=a.get(n);if(null!=e&&0!==e.length){for(const n of e)n.signal=null;d(e)}}n.disconnect_between=t,n.disconnect_sender=e,n.disconnect_receiver=l,n.disconnect_all=s,n.disconnectBetween=t,n.disconnectSender=e,n.disconnectReceiver=l,n.disconnectAll=s}(c||(e.Signal=c={})),e.Signalable=function(){return class{connect(n,t){return n.connect(t,this)}disconnect(n,t){return n.disconnect(t,this)}}};const u=new WeakMap,a=new WeakMap;function g(n,t,e,l){return(0,o.find)(n,(n=>n.signal===t&&n.slot===e&&n.context===l))}const f=new Set;function d(n){0===f.size&&(async()=>{await(0,i.defer)(),function(){for(const n of f)(0,o.remove_by)(n,(n=>null==n.signal));f.clear()}()})(),f.add(n)}},\n", " function _(e,n,t,s,o){s();const r=new MessageChannel,a=new Map;r.port1.onmessage=e=>{const n=e.data,t=a.get(n);if(null!=t)try{t()}finally{a.delete(n)}};let i=1;t.defer=function(){return new Promise((e=>{const n=i++;a.set(n,e),r.port2.postMessage(n)}))},t.wait=function(e){return new Promise((n=>setTimeout(n,e)))}},\n", " function _(n,t,i,e,c){e();const r=n(8),s=n(13);i.is_ref=function(n){if((0,r.isPlainObject)(n)){const t=(0,s.keys)(n);return 1==t.length&&\"id\"==t[0]}return!1}},\n", " function _(e,t,n,r,a){r(),n.YCoordinateSeqSeqSeqSpec=n.XCoordinateSeqSeqSeqSpec=n.YCoordinateSeqSpec=n.XCoordinateSeqSpec=n.YCoordinateSpec=n.XCoordinateSpec=n.CoordinateSeqSeqSeqSpec=n.CoordinateSeqSpec=n.CoordinateSpec=n.BaseCoordinateSpec=n.NumberUnitsSpec=n.UnitsSpec=n.DataSpec=n.VectorSpec=n.TextBaselineScalar=n.TextAlignScalar=n.FontStyleScalar=n.FontSizeScalar=n.FontScalar=n.LineDashScalar=n.LineCapScalar=n.LineJoinScalar=n.ArrayScalar=n.NullStringScalar=n.StringScalar=n.NumberScalar=n.ColorScalar=n.AnyScalar=n.ScalarSpec=n.VerticalAlign=n.UpdateMode=n.TooltipAttachment=n.TickLabelOrientation=n.TextureRepetition=n.TextBaseline=n.TextAlign=n.TapBehavior=n.StepMode=n.StartEnd=n.SpatialUnits=n.Sort=n.SizingMode=n.Side=n.RoundingFunction=n.ResetPolicy=n.RenderMode=n.RenderLevel=n.RadiusDimension=n.PointPolicy=n.Place=void 0,n.TextBaselineSpec=n.TextAlignSpec=n.FontStyleSpec=n.FontSizeSpec=n.FontSpec=n.LineDashSpec=n.LineCapSpec=n.LineJoinSpec=n.MarkerSpec=n.ArraySpec=n.NullStringSpec=n.StringSpec=n.AnySpec=n.NDArraySpec=n.ColorSpec=n.ScreenSizeSpec=n.NumberSpec=n.IntSpec=n.BooleanSpec=n.NullDistanceSpec=n.DistanceSpec=n.AngleSpec=void 0;const i=e(1),s=e(15),l=e(19),o=(0,i.__importStar)(e(20)),c=e(24),_=e(9),u=e(12),d=e(10),S=e(22),p=e(27),m=e(8),h=e(28),v=e(29),y=e(33);function x(e){try{return JSON.stringify(e)}catch(t){return e.toString()}}function g(e){return(0,m.isPlainObject)(e)&&(void 0===e.value?0:1)+(void 0===e.field?0:1)+(void 0===e.expr?0:1)==1}a(\"Uniform\",y.Uniform),a(\"UniformScalar\",y.UniformScalar),a(\"UniformVector\",y.UniformVector),n.isSpec=g;class f{constructor(e,t,n,r,a,i={}){var l;let o;if(this.obj=e,this.attr=t,this.kind=n,this.default_value=r,this._dirty=!1,this.change=new s.Signal0(this.obj,\"change\"),this.internal=null!==(l=i.internal)&&void 0!==l&&l,this.convert=i.convert,this.on_update=i.on_update,void 0!==a)o=a,this._dirty=!0;else{const t=this._default_override();if(void 0!==t)o=t;else{if(void 0===r)return void(this.spec={value:null});o=r(e)}}this._update(o)}get is_value(){return void 0!==this.spec.value}get syncable(){return!this.internal}get_value(){return this.spec.value}set_value(e){this._update(e),this._dirty=!0}_default_override(){}get dirty(){return this._dirty}_update(e){var t;if(this.validate(e),null!=this.convert){const t=this.convert(e);void 0!==t&&(e=t)}this.spec={value:e},null===(t=this.on_update)||void 0===t||t.call(this,e,this.obj)}toString(){return`Prop(${this.obj}.${this.attr}, spec: ${x(this.spec)})`}normalize(e){return e}validate(e){if(!this.valid(e))throw new Error(`${this.obj}.${this.attr} given invalid value: ${x(e)}`)}valid(e){return this.kind.valid(e)}_value(e=!0){if(!this.is_value)throw new Error(\"attempted to retrieve property value for property without value specification\");let t=this.normalize([this.spec.value])[0];return null!=this.spec.transform&&e&&(t=this.spec.transform.compute(t)),t}}n.Property=f,f.__name__=\"Property\";class A{constructor(e){this.attr=e}}n.PropertyAlias=A,A.__name__=\"PropertyAlias\",n.Alias=function(e){return new A(e)};class C extends f{}n.PrimitiveProperty=C,C.__name__=\"PrimitiveProperty\";class T extends f{}n.Any=T,T.__name__=\"Any\";class L extends f{valid(e){return(0,m.isArray)(e)||(0,m.isTypedArray)(e)}}n.Array=L,L.__name__=\"Array\";class w extends f{valid(e){return(0,m.isBoolean)(e)}}n.Boolean=w,w.__name__=\"Boolean\";class P extends f{valid(e){return(0,S.is_Color)(e)}}n.Color=P,P.__name__=\"Color\";class b extends f{}n.Instance=b,b.__name__=\"Instance\";class q extends f{valid(e){return(0,m.isNumber)(e)}}n.Number=q,q.__name__=\"Number\";class N extends q{valid(e){return(0,m.isNumber)(e)&&(0|e)==e}}n.Int=N,N.__name__=\"Int\";class z extends q{}n.Angle=z,z.__name__=\"Angle\";class B extends q{valid(e){return(0,m.isNumber)(e)&&0<=e&&e<=1}}n.Percent=B,B.__name__=\"Percent\";class F extends f{valid(e){return(0,m.isString)(e)}}n.String=F,F.__name__=\"String\";class D extends f{valid(e){return null===e||(0,m.isString)(e)}}n.NullString=D,D.__name__=\"NullString\";class U extends F{}n.FontSize=U,U.__name__=\"FontSize\";class M extends F{_default_override(){return h.settings.dev?\"Bokeh\":void 0}}n.Font=M,M.__name__=\"Font\";class R extends f{valid(e){return(0,m.isString)(e)&&(0,_.includes)(this.enum_values,e)}}function k(e){return class extends R{get enum_values(){return[...e]}}}n.EnumProperty=R,R.__name__=\"EnumProperty\",n.Enum=k;class O extends R{get enum_values(){return[...o.Direction]}normalize(e){const t=new Uint8Array(e.length);for(let n=0;n=0}}n.ScreenSizeSpec=fe,fe.__name__=\"ScreenSizeSpec\";class Ae extends ne{materialize(e){return(0,S.encode_rgba)((0,S.color2rgba)(e))}v_materialize(e){if(!(0,v.is_NDArray)(e)){const t=e.length,n=new c.RGBAArray(4*t);let r=0;for(const t of e){const[e,a,i,s]=(0,S.color2rgba)(t);n[r++]=e,n[r++]=a,n[r++]=i,n[r++]=s}return new c.ColorArray(n.buffer)}if(\"uint32\"==e.dtype&&1==e.dimension)return(0,p.to_big_endian)(e);if(\"uint8\"==e.dtype&&1==e.dimension){const[t]=e.shape,n=new c.RGBAArray(4*t);let r=0;for(const t of e)n[r++]=t,n[r++]=t,n[r++]=t,n[r++]=255;return new c.ColorArray(n.buffer)}if(\"uint8\"==e.dtype&&2==e.dimension){const[t,n]=e.shape;if(4==n)return new c.ColorArray(e.buffer);if(3==n){const r=new c.RGBAArray(4*t);for(let a=0,i=0;a0){let o=r[e];return null==o&&(r[e]=o=new v(e,l)),o}throw new TypeError(\"Logger.get() expects a non-empty string name and an optional log-level\")}get level(){return this.get_level()}get_level(){return this._log_level}set_level(e){if(e instanceof i)this._log_level=e;else{if(!(0,s.isString)(e)||null==v.log_levels[e])throw new Error(\"Logger.set_level() expects a log-level object or a string name of a log-level\");this._log_level=v.log_levels[e]}const l=`[${this._name}]`;for(const[e,o]of(0,g.entries)(v.log_levels))o.level\",\"*\"),t.HTTPMethod=(0,a.Enum)(\"POST\",\"GET\"),t.HexTileOrientation=(0,a.Enum)(\"pointytop\",\"flattop\"),t.HoverMode=(0,a.Enum)(\"mouse\",\"hline\",\"vline\"),t.LatLon=(0,a.Enum)(\"lat\",\"lon\"),t.LegendClickPolicy=(0,a.Enum)(\"none\",\"hide\",\"mute\"),t.LegendLocation=t.Anchor,t.LineCap=(0,a.Enum)(\"butt\",\"round\",\"square\"),t.LineJoin=(0,a.Enum)(\"miter\",\"round\",\"bevel\"),t.LineDash=(0,a.Enum)(\"solid\",\"dashed\",\"dotted\",\"dotdash\",\"dashdot\"),t.LinePolicy=(0,a.Enum)(\"prev\",\"next\",\"nearest\",\"interp\",\"none\"),t.Location=(0,a.Enum)(\"above\",\"below\",\"left\",\"right\"),t.Logo=(0,a.Enum)(\"normal\",\"grey\"),t.MarkerType=(0,a.Enum)(\"asterisk\",\"circle\",\"circle_cross\",\"circle_dot\",\"circle_x\",\"circle_y\",\"cross\",\"dash\",\"diamond\",\"diamond_cross\",\"diamond_dot\",\"dot\",\"hex\",\"hex_dot\",\"inverted_triangle\",\"plus\",\"square\",\"square_cross\",\"square_dot\",\"square_pin\",\"square_x\",\"star\",\"star_dot\",\"triangle\",\"triangle_dot\",\"triangle_pin\",\"x\",\"y\"),t.MutedPolicy=(0,a.Enum)(\"show\",\"ignore\"),t.Orientation=(0,a.Enum)(\"vertical\",\"horizontal\"),t.OutputBackend=(0,a.Enum)(\"canvas\",\"svg\",\"webgl\"),t.PaddingUnits=(0,a.Enum)(\"percent\",\"absolute\"),t.Place=(0,a.Enum)(\"above\",\"below\",\"left\",\"right\",\"center\"),t.PointPolicy=(0,a.Enum)(\"snap_to_data\",\"follow_mouse\",\"none\"),t.RadiusDimension=(0,a.Enum)(\"x\",\"y\",\"max\",\"min\"),t.RenderLevel=(0,a.Enum)(\"image\",\"underlay\",\"glyph\",\"guide\",\"annotation\",\"overlay\"),t.RenderMode=(0,a.Enum)(\"canvas\",\"css\"),t.ResetPolicy=(0,a.Enum)(\"standard\",\"event_only\"),t.RoundingFunction=(0,a.Enum)(\"round\",\"nearest\",\"floor\",\"rounddown\",\"ceil\",\"roundup\"),t.SelectionMode=(0,a.Enum)(\"replace\",\"append\",\"intersect\",\"subtract\"),t.Side=(0,a.Enum)(\"above\",\"below\",\"left\",\"right\"),t.SizingMode=(0,a.Enum)(\"stretch_width\",\"stretch_height\",\"stretch_both\",\"scale_width\",\"scale_height\",\"scale_both\",\"fixed\"),t.Sort=(0,a.Enum)(\"ascending\",\"descending\"),t.SpatialUnits=(0,a.Enum)(\"screen\",\"data\"),t.StartEnd=(0,a.Enum)(\"start\",\"end\"),t.StepMode=(0,a.Enum)(\"after\",\"before\",\"center\"),t.TapBehavior=(0,a.Enum)(\"select\",\"inspect\"),t.TextAlign=(0,a.Enum)(\"left\",\"right\",\"center\"),t.TextBaseline=(0,a.Enum)(\"top\",\"middle\",\"bottom\",\"alphabetic\",\"hanging\",\"ideographic\"),t.TextureRepetition=(0,a.Enum)(\"repeat\",\"repeat_x\",\"repeat_y\",\"no_repeat\"),t.TickLabelOrientation=(0,a.Enum)(\"vertical\",\"horizontal\",\"parallel\",\"normal\"),t.TooltipAttachment=(0,a.Enum)(\"horizontal\",\"vertical\",\"left\",\"right\",\"above\",\"below\"),t.UpdateMode=(0,a.Enum)(\"replace\",\"append\"),t.VerticalAlign=(0,a.Enum)(\"top\",\"middle\",\"bottom\")},\n", " function _(e,n,t,s,r){s();const i=(0,e(1).__importStar)(e(8)),a=e(22),l=e(13),_=window.Map,{hasOwnProperty:u}=Object.prototype;class d{}t.Kind=d,d.__name__=\"Kind\",function(e){class n extends d{valid(e){return!0}}n.__name__=\"Any\",e.Any=n;class t extends d{valid(e){return!0}}t.__name__=\"Unknown\",e.Unknown=t;class s extends d{valid(e){return i.isBoolean(e)}}s.__name__=\"Boolean\",e.Boolean=s;class r extends d{constructor(e){super(),this.obj_type=e}valid(e){return!0}}r.__name__=\"Ref\",e.Ref=r;class c extends d{valid(e){return!0}}c.__name__=\"AnyRef\",e.AnyRef=c;class o extends d{valid(e){return i.isNumber(e)}}o.__name__=\"Number\",e.Number=o;class p extends o{valid(e){return super.valid(e)&&i.isInteger(e)}}p.__name__=\"Int\",e.Int=p;class y extends o{valid(e){return super.valid(e)&&0<=e&&e<=1}}y.__name__=\"Percent\",e.Percent=y;class m extends d{constructor(e){super(),this.types=e,this.types=e}valid(e){return this.types.some((n=>n.valid(e)))}}m.__name__=\"Or\",e.Or=m;class v extends d{constructor(e){super(),this.types=e,this.types=e}valid(e){if(!i.isArray(e))return!1;for(let n=0;nthis.item_type.valid(e)))}}f.__name__=\"Array\",e.Array=f;class K extends d{valid(e){return null===e}}K.__name__=\"Null\",e.Null=K;class b extends d{constructor(e){super(),this.base_type=e}valid(e){return null===e||this.base_type.valid(e)}}b.__name__=\"Nullable\",e.Nullable=b;class A extends d{constructor(e){super(),this.base_type=e}valid(e){return void 0===e||this.base_type.valid(e)}}A.__name__=\"Opt\",e.Opt=A;class x extends d{valid(e){return i.isString(e)}}x.__name__=\"String\",e.String=x;class S extends d{constructor(e){super(),this.values=new Set(e)}valid(e){return this.values.has(e)}*[Symbol.iterator](){yield*this.values}}S.__name__=\"Enum\",e.Enum=S;class N extends d{constructor(e){super(),this.item_type=e}valid(e){if(!i.isPlainObject(e))return!1;for(const n in e)if(u.call(e,n)){const t=e[n];if(!this.item_type.valid(t))return!1}return!0}}N.__name__=\"Dict\",e.Dict=N;class O extends d{constructor(e,n){super(),this.key_type=e,this.item_type=n}valid(e){if(!(e instanceof _))return!1;for(const[n,t]of e.entries())if(!this.key_type.valid(n)||!this.item_type.valid(t))return!1;return!0}}O.__name__=\"Map\",e.Map=O;class g extends d{valid(e){return(0,a.is_Color)(e)}}g.__name__=\"Color\",e.Color=g;class P extends d{valid(e){return i.isFunction(e)}}P.__name__=\"Function\",e.Function=P}(t.Kinds||(t.Kinds={})),t.Any=new t.Kinds.Any,t.Unknown=new t.Kinds.Unknown,t.Boolean=new t.Kinds.Boolean,t.Number=new t.Kinds.Number,t.Int=new t.Kinds.Int,t.String=new t.Kinds.String,t.Null=new t.Kinds.Null;t.Nullable=e=>new t.Kinds.Nullable(e);t.Opt=e=>new t.Kinds.Opt(e);t.Or=(...e)=>new t.Kinds.Or(e);t.Tuple=(...e)=>new t.Kinds.Tuple(e);t.Struct=e=>new t.Kinds.Struct(e),t.Arrayable=new t.Kinds.Arrayable;t.Array=e=>new t.Kinds.Array(e);t.Dict=e=>new t.Kinds.Dict(e);t.Map=(e,n)=>new t.Kinds.Map(e,n);t.Enum=(...e)=>new t.Kinds.Enum(e);t.Ref=e=>new t.Kinds.Ref(e);t.AnyRef=()=>new t.Kinds.AnyRef;t.Function=()=>new t.Kinds.Function,t.Percent=new t.Kinds.Percent,t.Alpha=t.Percent,t.Color=new t.Kinds.Color,t.Auto=(0,t.Enum)(\"auto\"),t.FontSize=t.String,t.Font=t.String,t.Angle=t.Number},\n", " function _(n,t,r,e,s){e();const u=n(23),c=n(10),l=n(8),{round:i}=Math;function o(n){return(0,c.clamp)(i(n),0,255)}function a(){return[0,0,0,0]}function f(n){return[n>>24&255,n>>16&255,n>>8&255,255&n]}function d(n,t){var r;let e,s,u,c;return null==n?[e,s,u,c]=[0,0,0,0]:(0,l.isInteger)(n)?[e,s,u,c]=f(n):(0,l.isString)(n)?[e,s,u,c]=null!==(r=_(n))&&void 0!==r?r:[0,0,0,0]:([e,s,u,c=1]=n,c=o(255*c)),255==c&&null!=t&&(c=o(255*t)),[e,s,u,c]}r.transparent=a,r.encode_rgba=function([n,t,r,e]){return n<<24|t<<16|r<<8|e},r.decode_rgba=f,r.compose_alpha=function(n,t){return 255==(255&n)?4294967040&n|o(255*t):n},r.color2rgba=d;const h={0:\"0\",1:\"1\",2:\"2\",3:\"3\",4:\"4\",5:\"5\",6:\"6\",7:\"7\",8:\"8\",9:\"9\",10:\"a\",11:\"b\",12:\"c\",13:\"d\",14:\"e\",15:\"f\"};function g(n){return h[n>>4]+h[15&n]}r.color2css=function(n,t){const[r,e,s,u]=d(n,t);return`rgba(${r}, ${e}, ${s}, ${u/255})`},r.color2hex=function(n,t){const[r,e,s,u]=d(n,t),c=`#${g(r)}${g(e)}${g(s)}`;return 255==u?c:`${c}${g(u)}`},r.color2hexrgb=function(n){const[t,r,e]=d(n);return`#${g(t)}${g(r)}${g(e)}`};const b=/^rgba?\\(\\s*([^\\s,]+?)\\s+([^\\s,]+?)\\s+([^\\s,]+?)(?:\\s*\\/\\s*([^\\s,]+?))?\\s*\\)$/,$=/^rgba?\\(\\s*([^\\s,]+?)\\s*,\\s*([^\\s,]+?)\\s*,\\s*([^\\s,]+?)(?:\\s*,\\s*([^\\s,]+?))?\\s*\\)$/,m=(()=>{const n=document.createElement(\"canvas\");n.width=1,n.height=1;const t=n.getContext(\"2d\"),r=t.createLinearGradient(0,0,1,1);return n=>{t.fillStyle=r,t.fillStyle=n;const e=t.fillStyle;return e!=r?e:null}})();function _(n){var t;if(!(n=n.trim().toLowerCase()))return null;if(\"transparent\"==n)return[0,0,0,0];if((0,u.is_named_color)(n))return f(u.named_colors[n]);if(\"#\"==n[0]){const t=Number(`0x${n.substr(1)}`);if(isNaN(t))return null;switch(n.length-1){case 3:{const n=t>>8&15,r=t>>4&15,e=t>>0&15;return[n<<4|n,r<<4|r,e<<4|e,255]}case 4:{const n=t>>12&15,r=t>>8&15,e=t>>4&15,s=t>>0&15;return[n<<4|n,r<<4|r,e<<4|e,s<<4|s]}case 6:return[t>>16&255,t>>8&255,t>>0&255,255];case 8:return[t>>24&255,t>>16&255,t>>8&255,t>>0&255]}}else if(n.startsWith(\"rgb\")){const r=null!==(t=n.match(b))&&void 0!==t?t:n.match($);if(null!=r){let[,n,t,e,s=\"1\"]=r;const u=n.endsWith(\"%\"),c=t.endsWith(\"%\"),l=e.endsWith(\"%\"),i=s.endsWith(\"%\");if(!(u&&c&&l)&&(u||c||l))return null;u&&(n=n.slice(0,-1)),c&&(t=t.slice(0,-1)),l&&(e=e.slice(0,-1)),i&&(s=s.slice(0,-1));let a=Number(n),f=Number(t),d=Number(e),h=Number(s);return isNaN(a+f+d+h)?null:(u&&(a=a/100*255),c&&(f=f/100*255),l&&(d=d/100*255),h=255*(i?h/100:h),a=o(a),f=o(f),d=o(d),h=o(h),[a,f,d,h])}}else{const t=m(n);if(null!=t)return _(t)}return null}r.css4_parse=_,r.is_Color=function(n){return!!(0,l.isInteger)(n)||(!(!(0,l.isString)(n)||null==_(n))||!(!(0,l.isArray)(n)||3!=n.length&&4!=n.length))},r.is_dark=function([n,t,r]){return 1-(.299*n+.587*t+.114*r)/255>=.6}},\n", " function _(e,r,l,a,i){a();l.named_colors={aliceblue:4042850303,antiquewhite:4209760255,aqua:16777215,aquamarine:2147472639,azure:4043309055,beige:4126530815,bisque:4293182719,black:255,blanchedalmond:4293643775,blue:65535,blueviolet:2318131967,brown:2771004159,burlywood:3736635391,cadetblue:1604231423,chartreuse:2147418367,chocolate:3530104575,coral:4286533887,cornflowerblue:1687547391,cornsilk:4294499583,crimson:3692313855,cyan:16777215,darkblue:35839,darkcyan:9145343,darkgoldenrod:3095792639,darkgray:2846468607,darkgreen:6553855,darkgrey:2846468607,darkkhaki:3182914559,darkmagenta:2332068863,darkolivegreen:1433087999,darkorange:4287365375,darkorchid:2570243327,darkred:2332033279,darksalmon:3918953215,darkseagreen:2411499519,darkslateblue:1211993087,darkslategray:793726975,darkslategrey:793726975,darkturquoise:13554175,darkviolet:2483082239,deeppink:4279538687,deepskyblue:12582911,dimgray:1768516095,dimgrey:1768516095,dodgerblue:512819199,firebrick:2988581631,floralwhite:4294635775,forestgreen:579543807,fuchsia:4278255615,gainsboro:3705462015,ghostwhite:4177068031,gold:4292280575,goldenrod:3668254975,gray:2155905279,green:8388863,greenyellow:2919182335,grey:2155905279,honeydew:4043305215,hotpink:4285117695,indianred:3445382399,indigo:1258324735,ivory:4294963455,khaki:4041641215,lavender:3873897215,lavenderblush:4293981695,lawngreen:2096890111,lemonchiffon:4294626815,lightblue:2916673279,lightcoral:4034953471,lightcyan:3774873599,lightgoldenrodyellow:4210742015,lightgray:3553874943,lightgreen:2431553791,lightgrey:3553874943,lightpink:4290167295,lightsalmon:4288707327,lightseagreen:548580095,lightskyblue:2278488831,lightslategray:2005441023,lightslategrey:2005441023,lightsteelblue:2965692159,lightyellow:4294959359,lime:16711935,limegreen:852308735,linen:4210091775,magenta:4278255615,maroon:2147483903,mediumaquamarine:1724754687,mediumblue:52735,mediumorchid:3126187007,mediumpurple:2473647103,mediumseagreen:1018393087,mediumslateblue:2070474495,mediumspringgreen:16423679,mediumturquoise:1221709055,mediumvioletred:3340076543,midnightblue:421097727,mintcream:4127193855,mistyrose:4293190143,moccasin:4293178879,navajowhite:4292783615,navy:33023,oldlace:4260751103,olive:2155872511,olivedrab:1804477439,orange:4289003775,orangered:4282712319,orchid:3664828159,palegoldenrod:4008225535,palegreen:2566625535,paleturquoise:2951671551,palevioletred:3681588223,papayawhip:4293907967,peachpuff:4292524543,peru:3448061951,pink:4290825215,plum:3718307327,powderblue:2967529215,purple:2147516671,rebeccapurple:1714657791,red:4278190335,rosybrown:3163525119,royalblue:1097458175,saddlebrown:2336560127,salmon:4202722047,sandybrown:4104413439,seagreen:780883967,seashell:4294307583,sienna:2689740287,silver:3233857791,skyblue:2278484991,slateblue:1784335871,slategray:1887473919,slategrey:1887473919,snow:4294638335,springgreen:16744447,steelblue:1182971135,tan:3535047935,teal:8421631,thistle:3636451583,tomato:4284696575,turquoise:1088475391,violet:4001558271,wheat:4125012991,white:4294967295,whitesmoke:4126537215,yellow:4294902015,yellowgreen:2597139199},l.is_named_color=function(e){return e in l.named_colors}},\n", " function _(r,t,n,a,o){a(),n.GeneratorFunction=Object.getPrototypeOf((function*(){})).constructor,n.ColorArray=Uint32Array,n.RGBAArray=Uint8ClampedArray,n.infer_type=function(r,t){return r instanceof Float64Array||r instanceof Array||t instanceof Float64Array||t instanceof Array?Float64Array:Float32Array},n.ScreenArray=Float32Array,n.to_screen=function(r){return r instanceof Float32Array?r:Float32Array.from(r)},o(\"Indices\",r(25).BitSet)},\n", " function _(t,s,r,e,i){var n;e();const o=t(26),a=t(11);class _{constructor(t,s=0){this.size=t,this[n]=\"BitSet\",this._count=null,this._nwords=Math.ceil(t/32),0==s||1==s?(this._array=new Uint32Array(this._nwords),1==s&&this._array.fill(4294967295)):((0,a.assert)(s.length==this._nwords,\"Initializer size mismatch\"),this._array=s)}clone(){return new _(this.size,new Uint32Array(this._array))}[(n=Symbol.toStringTag,o.equals)](t,s){if(!s.eq(this.size,t.size))return!1;const{_nwords:r}=this,e=this.size%r,i=0==e?r:r-1;for(let s=0;s>>5,r=31&t;return!!(this._array[s]>>r&1)}set(t,s=!0){this._check_bounds(t),this._count=null;const r=t>>>5,e=31&t;s?this._array[r]|=1<>>t&1&&(e+=1)}return e}*ones(){const{_array:t,_nwords:s,size:r}=this;for(let e=0,i=0;i>>t&1&&(yield e);else e+=32}}*zeros(){const{_array:t,_nwords:s,size:r}=this;for(let e=0,i=0;i>>t&1||(yield e);else e+=32}}_check_size(t){(0,a.assert)(this.size==t.size,\"Size mismatch\")}add(t){this._check_size(t);for(let s=0;s{if(a(t)&&a(e))return t[r.equals](e,this);switch(n){case\"[object Array]\":case\"[object Uint8Array]\":case\"[object Int8Array]\":case\"[object Uint16Array]\":case\"[object Int16Array]\":case\"[object Uint32Array]\":case\"[object Int32Array]\":case\"[object Float32Array]\":case\"[object Float64Array]\":return this.arrays(t,e);case\"[object Map]\":return this.maps(t,e);case\"[object Set]\":return this.sets(t,e);case\"[object Object]\":if(t.constructor==e.constructor&&(null==t.constructor||t.constructor===Object))return this.objects(t,e);case\"[object Function]\":if(t.constructor==e.constructor&&t.constructor===Function)return this.eq(`${t}`,`${e}`)}if(t instanceof Node)return this.nodes(t,e);throw Error(`can't compare objects of type ${n}`)})();return s.pop(),o.pop(),u}numbers(t,e){return Object.is(t,e)}arrays(t,e){const{length:r}=t;if(r!=e.length)return!1;for(let n=0;n{const n=navigator.userAgent;return n.includes(\"MSIE\")||n.includes(\"Trident\")||n.includes(\"Edge\")})(),e.is_mobile=\"undefined\"!=typeof window&&(\"ontouchstart\"in window||navigator.maxTouchPoints>0),e.is_little_endian=(()=>{const n=new ArrayBuffer(4),i=new Uint8Array(n);new Uint32Array(n)[1]=168496141;let e=!0;return 10==i[4]&&11==i[5]&&12==i[6]&&13==i[7]&&(e=!1),e})(),e.BYTE_ORDER=e.is_little_endian?\"little\":\"big\",e.to_big_endian=function(n){if(e.is_little_endian){const i=new Uint32Array(n.length),e=new DataView(i.buffer);let t=0;for(const i of n)e.setUint32(t,i),t+=4;return i}return n}},\n", " function _(e,t,r,i,s){i();class _{constructor(){this._dev=!1,this._wireframe=!1}set dev(e){this._dev=e}get dev(){return this._dev}set wireframe(e){this._wireframe=e}get wireframe(){return this._wireframe}}r.Settings=_,_.__name__=\"Settings\",r.settings=new _},\n", " function _(e,s,t,i,r){var a,n,l,h,u,o,p,c;i();const y=e(8),_=e(11),A=e(26),q=e(30),d=e(31),z=Symbol(\"__ndarray__\");class D extends Uint8Array{constructor(e,s){super(e),this[a]=!0,this.dtype=\"uint8\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>D.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>D.prototype[q.serialize].call(this,e))}[(a=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}t.Uint8NDArray=D,D.__name__=\"Uint8NDArray\";class N extends Int8Array{constructor(e,s){super(e),this[n]=!0,this.dtype=\"int8\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>N.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>N.prototype[q.serialize].call(this,e))}[(n=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}t.Int8NDArray=N,N.__name__=\"Int8NDArray\";class f extends Uint16Array{constructor(e,s){super(e),this[l]=!0,this.dtype=\"uint16\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>f.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>f.prototype[q.serialize].call(this,e))}[(l=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}t.Uint16NDArray=f,f.__name__=\"Uint16NDArray\";class m extends Int16Array{constructor(e,s){super(e),this[h]=!0,this.dtype=\"int16\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>m.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>m.prototype[q.serialize].call(this,e))}[(h=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}t.Int16NDArray=m,m.__name__=\"Int16NDArray\";class g extends Uint32Array{constructor(e,s){super(e),this[u]=!0,this.dtype=\"uint32\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>g.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>g.prototype[q.serialize].call(this,e))}[(u=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}t.Uint32NDArray=g,g.__name__=\"Uint32NDArray\";class I extends Int32Array{constructor(e,s){super(e),this[o]=!0,this.dtype=\"int32\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>I.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>I.prototype[q.serialize].call(this,e))}[(o=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}t.Int32NDArray=I,I.__name__=\"Int32NDArray\";class U extends Float32Array{constructor(e,s){super(e),this[p]=!0,this.dtype=\"float32\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>U.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>U.prototype[q.serialize].call(this,e))}[(p=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}t.Float32NDArray=U,U.__name__=\"Float32NDArray\";class w extends Float64Array{constructor(e,s){super(e),this[c]=!0,this.dtype=\"float64\",this.shape=null!=s?s:x(e)?e.shape:[this.length],this.dimension=this.shape.length,null==this[A.equals]&&(this[A.equals]=(e,s)=>w.prototype[A.equals].call(this,e,s)),null==this[q.serialize]&&(this[q.serialize]=e=>w.prototype[q.serialize].call(this,e))}[(c=z,A.equals)](e,s){return s.eq(this.shape,e.shape)&&s.arrays(this,e)}[q.serialize](e){return(0,d.encode_NDArray)(this)}}function x(e){return(0,y.isObject)(e)&&void 0!==e[z]}t.Float64NDArray=w,w.__name__=\"Float64NDArray\",t.is_NDArray=x,t.ndarray=function(e,s={}){let{dtype:t}=s;null==t&&(t=e instanceof ArrayBuffer||(0,y.isArray)(e)?\"float64\":(()=>{switch(!0){case e instanceof Uint8Array:return\"uint8\";case e instanceof Int8Array:return\"int8\";case e instanceof Uint16Array:return\"uint16\";case e instanceof Int16Array:return\"int16\";case e instanceof Uint32Array:return\"uint32\";case e instanceof Int32Array:return\"int32\";case e instanceof Float32Array:return\"float32\";case e instanceof Float64Array:return\"float64\";default:(0,_.unreachable)()}})());const{shape:i}=s;switch(t){case\"uint8\":return new D(e,i);case\"int8\":return new N(e,i);case\"uint16\":return new f(e,i);case\"int16\":return new m(e,i);case\"uint32\":return new g(e,i);case\"int32\":return new I(e,i);case\"float32\":return new U(e,i);case\"float64\":return new w(e,i)}}},\n", " function _(e,r,t,i,s){i();const n=e(11),a=e(13),l=e(8);t.serialize=Symbol(\"serialize\");class o extends Error{}t.SerializationError=o,o.__name__=\"SerializationError\";class f{constructor(e){var r;this._references=new Map,this._definitions=new Map,this._refmap=new Map,this.include_defaults=null===(r=null==e?void 0:e.include_defaults)||void 0===r||r}get_ref(e){return this._references.get(e)}add_ref(e,r){(0,n.assert)(!this._references.has(e)),this._references.set(e,r)}add_def(e,r){const t=this.get_ref(e);(0,n.assert)(null!=t),this._definitions.set(e,r),this._refmap.set(t,r)}get objects(){return new Set(this._references.keys())}get references(){return new Set(this._references.values())}get definitions(){return new Set(this._definitions.values())}resolve_ref(e){return this._refmap.get(e)}remove_ref(e){return this._references.delete(e)}remove_def(e){return this._definitions.delete(e)}to_serializable(e){const r=this.get_ref(e);if(null!=r)return r;if(function(e){return(0,l.isObject)(e)&&void 0!==e[t.serialize]}(e))return e[t.serialize](this);if((0,l.isArray)(e)||(0,l.isTypedArray)(e)){const r=e.length,t=new Array(r);for(let i=0;i(0,s.buffer_to_base64)(_.buffer)};return Object.assign({__ndarray__:e},r)}}},\n", " function _(t,n,e,r,o){r(),e.buffer_to_base64=function(t){const n=new Uint8Array(t),e=Array.from(n).map((t=>String.fromCharCode(t)));return btoa(e.join(\"\"))},e.base64_to_buffer=function(t){const n=atob(t),e=n.length,r=new Uint8Array(e);for(let t=0,o=e;t\"'`])/g,(t=>{switch(t){case\"&\":return\"&\";case\"<\":return\"<\";case\">\":return\">\";case'\"':return\""\";case\"'\":return\"'\";case\"`\":return\"`\";default:return t}}))},r.unescape=function(t){return t.replace(/&(amp|lt|gt|quot|#x27|#x60);/g,((t,e)=>{switch(e){case\"amp\":return\"&\";case\"lt\":return\"<\";case\"gt\":return\">\";case\"quot\":return'\"';case\"#x27\":return\"'\";case\"#x60\":return\"`\";default:return e}}))},r.use_strict=function(t){return`'use strict';\\n${t}`},r.to_fixed=function(t,e){return t.toFixed(e).replace(/(\\.[0-9]*?)0+$/,\"$1\").replace(/\\.$/,\"\")}},\n", " function _(e,t,s,n,o){n();const i=e(30);class r{constructor(e){this.document=e}}s.DocumentEvent=r,r.__name__=\"DocumentEvent\";class a extends r{constructor(e,t,s){super(e),this.events=t,this.setter_id=s}}s.DocumentEventBatch=a,a.__name__=\"DocumentEventBatch\";class d extends r{}s.DocumentChangedEvent=d,d.__name__=\"DocumentChangedEvent\";class l extends d{constructor(e,t,s){super(e),this.msg_type=t,this.msg_data=s}[i.serialize](e){const t=this.msg_data,s=e.to_serializable(t);return{kind:\"MessageSent\",msg_type:this.msg_type,msg_data:s}}}s.MessageSentEvent=l,l.__name__=\"MessageSentEvent\";class _ extends d{constructor(e,t,s,n,o,i,r){super(e),this.model=t,this.attr=s,this.old=n,this.new_=o,this.setter_id=i,this.hint=r}[i.serialize](e){if(null!=this.hint)return e.to_serializable(this.hint);const t=this.new_,s=e.to_serializable(t);return this.model!=t&&e.remove_def(this.model),{kind:\"ModelChanged\",model:this.model.ref(),attr:this.attr,new:s}}}s.ModelChangedEvent=_,_.__name__=\"ModelChangedEvent\";class c extends d{constructor(e,t,s){super(e),this.column_source=t,this.patches=s}[i.serialize](e){return{kind:\"ColumnsPatched\",column_source:this.column_source,patches:this.patches}}}s.ColumnsPatchedEvent=c,c.__name__=\"ColumnsPatchedEvent\";class h extends d{constructor(e,t,s,n){super(e),this.column_source=t,this.data=s,this.rollover=n}[i.serialize](e){return{kind:\"ColumnsStreamed\",column_source:this.column_source,data:this.data,rollover:this.rollover}}}s.ColumnsStreamedEvent=h,h.__name__=\"ColumnsStreamedEvent\";class m extends d{constructor(e,t,s){super(e),this.title=t,this.setter_id=s}[i.serialize](e){return{kind:\"TitleChanged\",title:this.title}}}s.TitleChangedEvent=m,m.__name__=\"TitleChangedEvent\";class u extends d{constructor(e,t,s){super(e),this.model=t,this.setter_id=s}[i.serialize](e){return{kind:\"RootAdded\",model:e.to_serializable(this.model)}}}s.RootAddedEvent=u,u.__name__=\"RootAddedEvent\";class v extends d{constructor(e,t,s){super(e),this.model=t,this.setter_id=s}[i.serialize](e){return{kind:\"RootRemoved\",model:this.model.ref()}}}s.RootRemovedEvent=v,v.__name__=\"RootRemovedEvent\"},\n", " function _(t,i,r,n,s){n();const e=t(8),o=t(13);r.pretty=Symbol(\"pretty\");class c{constructor(t){this.visited=new Set,this.precision=null==t?void 0:t.precision}to_string(t){if((0,e.isObject)(t)){if(this.visited.has(t))return\"\";this.visited.add(t)}return function(t){return(0,e.isObject)(t)&&void 0!==t[r.pretty]}(t)?t[r.pretty](this):(0,e.isBoolean)(t)?this.boolean(t):(0,e.isNumber)(t)?this.number(t):(0,e.isString)(t)?this.string(t):(0,e.isArray)(t)?this.array(t):(0,e.isIterable)(t)?this.iterable(t):(0,e.isPlainObject)(t)?this.object(t):(0,e.isSymbol)(t)?this.symbol(t):`${t}`}token(t){return t}boolean(t){return`${t}`}number(t){return null!=this.precision?t.toFixed(this.precision):`${t}`}string(t){return`\"${t.replace(/'/g,\"\\\\'\")}\"`}symbol(t){return t.toString()}array(t){const i=this.token,r=[];for(const i of t)r.push(this.to_string(i));return`${i(\"[\")}${r.join(`${i(\",\")} `)}${i(\"]\")}`}iterable(t){var i;const r=this.token,n=null!==(i=Object(t)[Symbol.toStringTag])&&void 0!==i?i:\"Object\",s=this.array(t);return`${n}${r(\"(\")}${s}${r(\")\")}`}object(t){const i=this.token,r=[];for(const[n,s]of(0,o.entries)(t))r.push(`${n}${i(\":\")} ${this.to_string(s)}`);return`${i(\"{\")}${r.join(`${i(\",\")} `)}${i(\"}\")}`}}r.Printer=c,c.__name__=\"Printer\",r.to_string=function(t,i){return new c(i).to_string(t)}},\n", " function _(n,o,r,e,t){e();const l=n(13),i=n(8);function c(n){return(0,i.isObject)(n)&&void 0!==n[r.clone]}r.clone=Symbol(\"clone\"),r.is_Cloneable=c;class s extends Error{}r.CloningError=s,s.__name__=\"CloningError\";class a{constructor(){}clone(n){if(c(n))return n[r.clone](this);if((0,i.isArray)(n)){const o=n.length,r=new Array(o);for(let e=0;e{null!=this.layout&&(this.layout.visible=this.model.visible,this.plot_view.request_layout())}))}get needs_clip(){return null==this.layout}serializable_state(){const t=super.serializable_state();return null==this.layout?t:Object.assign(Object.assign({},t),{bbox:this.layout.bbox.box})}}i.AnnotationView=r,r.__name__=\"AnnotationView\";class a extends l.Renderer{constructor(t){super(t)}}i.Annotation=a,o=a,a.__name__=\"Annotation\",o.override({level:\"annotation\"})},\n", " function _(e,i,t,n,s){n();const r=e(1);var o,a;const _=e(42),l=(0,r.__importStar)(e(45)),d=e(20),h=e(53),u=e(54);class c extends h.Model{constructor(e){super(e)}}t.RendererGroup=c,o=c,c.__name__=\"RendererGroup\",o.define((({Boolean:e})=>({visible:[e,!0]})));class p extends _.View{get coordinates(){const{_coordinates:e}=this;return null!=e?e:this._coordinates=this._initialize_coordinates()}initialize(){super.initialize(),this.visuals=new l.Visuals(this),this.needs_webgl_blit=!1}connect_signals(){super.connect_signals();const{x_range_name:e,y_range_name:i}=this.model.properties;this.on_change([e,i],(()=>this._initialize_coordinates()));const{group:t}=this.model;null!=t&&this.on_change(t.properties.visible,(()=>{this.model.visible=t.visible}))}_initialize_coordinates(){const{coordinates:e}=this.model,{frame:i}=this.plot_view;if(null!=e)return e.get_transform(i);{const{x_range_name:e,y_range_name:t}=this.model,n=i.x_scales.get(e),s=i.y_scales.get(t);return new u.CoordinateTransform(n,s)}}get plot_view(){return this.parent}get plot_model(){return this.parent.model}get layer(){const{overlays:e,primary:i}=this.canvas;return\"overlay\"==this.model.level?e:i}get canvas(){return this.plot_view.canvas_view}request_render(){this.request_paint()}request_paint(){this.plot_view.request_paint(this)}request_layout(){this.plot_view.request_layout()}notify_finished(){this.plot_view.notify_finished()}notify_finished_after_paint(){this.plot_view.notify_finished_after_paint()}get needs_clip(){return!1}get has_webgl(){return!1}render(){this.model.visible&&this._render(),this._has_finished=!0}renderer_view(e){}}t.RendererView=p,p.__name__=\"RendererView\";class g extends h.Model{constructor(e){super(e)}}t.Renderer=g,a=g,g.__name__=\"Renderer\",a.define((({Boolean:e,String:i,Ref:t,Nullable:n})=>({group:[n(t(c)),null],level:[d.RenderLevel,\"image\"],visible:[e,!0],x_range_name:[i,\"default\"],y_range_name:[i,\"default\"],coordinates:[n(t(u.CoordinateMapping)),null]})))},\n", " function _(t,e,s,i,n){i();const o=t(1),h=t(15),r=t(43),l=t(8),_=(0,o.__importDefault)(t(44));class d{constructor(t){this.removed=new h.Signal0(this,\"removed\"),this._ready=Promise.resolve(void 0),this._slots=new WeakMap,this._idle_notified=!1;const{model:e,parent:s}=t;this.model=e,this.parent=s,this.root=null==s?this:s.root,this.removed.emit()}get ready(){return this._ready}connect(t,e){let s=this._slots.get(e);return null==s&&(s=(t,s)=>{const i=Promise.resolve(e.call(this,t,s));this._ready=this._ready.then((()=>i))},this._slots.set(e,s)),t.connect(s,this)}disconnect(t,e){return t.disconnect(e,this)}initialize(){this._has_finished=!1,this.is_root&&(this._stylesheet=r.stylesheet);for(const t of this.styles())this.stylesheet.append(t)}async lazy_initialize(){}remove(){this.disconnect_signals(),this.removed.emit()}toString(){return`${this.model.type}View(${this.model.id})`}serializable_state(){return{type:this.model.type}}get is_root(){return null==this.parent}has_finished(){return this._has_finished}get is_idle(){return this.has_finished()}connect_signals(){}disconnect_signals(){h.Signal.disconnect_receiver(this)}on_change(t,e){for(const s of(0,l.isArray)(t)?t:[t])this.connect(s.change,e)}cursor(t,e){return null}get stylesheet(){return this.is_root?this._stylesheet:this.root.stylesheet}styles(){return[_.default]}notify_finished(){this.is_root?!this._idle_notified&&this.has_finished()&&null!=this.model.document&&(this._idle_notified=!0,this.model.document.notify_idle(this.model)):this.root.notify_finished()}}s.View=d,d.__name__=\"View\"},\n", " function _(t,e,n,i,o){i();const s=t(8),l=t(13),r=t=>(e={},...n)=>{const i=document.createElement(t);i.classList.add(\"bk\"),(0,s.isPlainObject)(e)||(n=[e,...n],e={});for(let[t,n]of(0,l.entries)(e))if(null!=n&&(!(0,s.isBoolean)(n)||n))if(\"class\"===t&&((0,s.isString)(n)&&(n=n.split(/\\s+/)),(0,s.isArray)(n)))for(const t of n)null!=t&&i.classList.add(t);else if(\"style\"===t&&(0,s.isPlainObject)(n))for(const[t,e]of(0,l.entries)(n))i.style[t]=e;else if(\"data\"===t&&(0,s.isPlainObject)(n))for(const[t,e]of(0,l.entries)(n))i.dataset[t]=e;else i.setAttribute(t,n);function o(t){if((0,s.isString)(t))i.appendChild(document.createTextNode(t));else if(t instanceof Node)i.appendChild(t);else if(t instanceof NodeList||t instanceof HTMLCollection)for(const e of t)i.appendChild(e);else if(null!=t&&!1!==t)throw new Error(`expected a DOM element, string, false or null, got ${JSON.stringify(t)}`)}for(const t of n)if((0,s.isArray)(t))for(const e of t)o(e);else o(t);return i};function a(t){const e=t.parentNode;null!=e&&e.removeChild(t)}function c(t,...e){const n=t.firstChild;for(const i of e)t.insertBefore(i,n)}function d(t,e){var n,i,o;const s=Element.prototype;return(null!==(o=null!==(i=null!==(n=s.matches)&&void 0!==n?n:s.webkitMatchesSelector)&&void 0!==i?i:s.mozMatchesSelector)&&void 0!==o?o:s.msMatchesSelector).call(t,e)}function h(t){return parseFloat(t)||0}function f(t){const e=getComputedStyle(t);return{border:{top:h(e.borderTopWidth),bottom:h(e.borderBottomWidth),left:h(e.borderLeftWidth),right:h(e.borderRightWidth)},margin:{top:h(e.marginTop),bottom:h(e.marginBottom),left:h(e.marginLeft),right:h(e.marginRight)},padding:{top:h(e.paddingTop),bottom:h(e.paddingBottom),left:h(e.paddingLeft),right:h(e.paddingRight)}}}function u(t){const e=t.getBoundingClientRect();return{width:Math.ceil(e.width),height:Math.ceil(e.height)}}n.createElement=function(t,e,...n){return r(t)(e,...n)},n.div=r(\"div\"),n.span=r(\"span\"),n.canvas=r(\"canvas\"),n.link=r(\"link\"),n.style=r(\"style\"),n.a=r(\"a\"),n.p=r(\"p\"),n.i=r(\"i\"),n.pre=r(\"pre\"),n.button=r(\"button\"),n.label=r(\"label\"),n.input=r(\"input\"),n.select=r(\"select\"),n.option=r(\"option\"),n.optgroup=r(\"optgroup\"),n.textarea=r(\"textarea\"),n.createSVGElement=function(t,e,...n){const i=document.createElementNS(\"http://www.w3.org/2000/svg\",t);for(const[t,n]of(0,l.entries)(null!=e?e:{}))null==n||(0,s.isBoolean)(n)&&!n||i.setAttribute(t,n);function o(t){if((0,s.isString)(t))i.appendChild(document.createTextNode(t));else if(t instanceof Node)i.appendChild(t);else if(t instanceof NodeList||t instanceof HTMLCollection)for(const e of t)i.appendChild(e);else if(null!=t&&!1!==t)throw new Error(`expected a DOM element, string, false or null, got ${JSON.stringify(t)}`)}for(const t of n)if((0,s.isArray)(t))for(const e of t)o(e);else o(t);return i},n.nbsp=function(){return document.createTextNode(\"\\xa0\")},n.append=function(t,...e){for(const n of e)t.appendChild(n)},n.remove=a,n.removeElement=a,n.replaceWith=function(t,e){const n=t.parentNode;null!=n&&n.replaceChild(e,t)},n.prepend=c,n.empty=function(t,e=!1){let n;for(;n=t.firstChild;)t.removeChild(n);if(e&&t instanceof Element)for(const e of t.attributes)t.removeAttributeNode(e)},n.display=function(t){t.style.display=\"\"},n.undisplay=function(t){t.style.display=\"none\"},n.show=function(t){t.style.visibility=\"\"},n.hide=function(t){t.style.visibility=\"hidden\"},n.offset=function(t){const e=t.getBoundingClientRect();return{top:e.top+window.pageYOffset-document.documentElement.clientTop,left:e.left+window.pageXOffset-document.documentElement.clientLeft}},n.matches=d,n.parent=function(t,e){let n=t;for(;n=n.parentElement;)if(d(n,e))return n;return null},n.extents=f,n.size=u,n.scroll_size=function(t){return{width:Math.ceil(t.scrollWidth),height:Math.ceil(t.scrollHeight)}},n.outer_size=function(t){const{margin:{left:e,right:n,top:i,bottom:o}}=f(t),{width:s,height:l}=u(t);return{width:Math.ceil(s+e+n),height:Math.ceil(l+i+o)}},n.content_size=function(t){const{left:e,top:n}=t.getBoundingClientRect(),{padding:i}=f(t);let o=0,s=0;for(const l of t.children){const t=l.getBoundingClientRect();o=Math.max(o,Math.ceil(t.left-e-i.left+t.width)),s=Math.max(s,Math.ceil(t.top-n-i.top+t.height))}return{width:o,height:s}},n.position=function(t,e,n){const{style:i}=t;if(i.left=`${e.x}px`,i.top=`${e.y}px`,i.width=`${e.width}px`,i.height=`${e.height}px`,null==n)i.margin=\"\";else{const{top:t,right:e,bottom:o,left:s}=n;i.margin=`${t}px ${e}px ${o}px ${s}px`}},n.children=function(t){return Array.from(t.children)};class p{constructor(t){this.el=t,this.classList=t.classList}get values(){const t=[];for(let e=0;e{document.addEventListener(\"DOMContentLoaded\",(()=>t()),{once:!0})}))}},\n", " function _(o,i,t,e,r){e(),t.root=\"bk-root\",t.default=\".bk-root{position:relative;width:auto;height:auto;box-sizing:border-box;font-family:Helvetica, Arial, sans-serif;font-size:13px;}.bk-root .bk,.bk-root .bk:before,.bk-root .bk:after{box-sizing:inherit;margin:0;border:0;padding:0;background-image:none;font-family:inherit;font-size:100%;line-height:1.42857143;}.bk-root pre.bk{font-family:Courier, monospace;}\"},\n", " function _(e,t,r,a,c){a();const n=e(1),l=e(46);c(\"Line\",l.Line),c(\"LineScalar\",l.LineScalar),c(\"LineVector\",l.LineVector);const i=e(49);c(\"Fill\",i.Fill),c(\"FillScalar\",i.FillScalar),c(\"FillVector\",i.FillVector);const s=e(50);c(\"Text\",s.Text),c(\"TextScalar\",s.TextScalar),c(\"TextVector\",s.TextVector);const o=e(51);c(\"Hatch\",o.Hatch),c(\"HatchScalar\",o.HatchScalar),c(\"HatchVector\",o.HatchVector);const u=(0,n.__importStar)(e(48)),V=e(47);c(\"VisualProperties\",V.VisualProperties),c(\"VisualUniforms\",V.VisualUniforms);class h{constructor(e){this._visuals=[];for(const[t,r]of e.model._mixins){const a=(()=>{switch(r){case u.Line:return new l.Line(e,t);case u.LineScalar:return new l.LineScalar(e,t);case u.LineVector:return new l.LineVector(e,t);case u.Fill:return new i.Fill(e,t);case u.FillScalar:return new i.FillScalar(e,t);case u.FillVector:return new i.FillVector(e,t);case u.Text:return new s.Text(e,t);case u.TextScalar:return new s.TextScalar(e,t);case u.TextVector:return new s.TextVector(e,t);case u.Hatch:return new o.Hatch(e,t);case u.HatchScalar:return new o.HatchScalar(e,t);case u.HatchVector:return new o.HatchVector(e,t);default:throw new Error(\"unknown visual\")}})();a instanceof V.VisualProperties&&a.update(),this._visuals.push(a),Object.defineProperty(this,t+a.type,{get:()=>a,configurable:!1,enumerable:!0})}}*[Symbol.iterator](){yield*this._visuals}}r.Visuals=h,h.__name__=\"Visuals\"},\n", " function _(e,t,i,l,s){l();const a=e(1),n=e(47),h=(0,a.__importStar)(e(48)),o=e(22),_=e(8);function r(e){if((0,_.isArray)(e))return e;switch(e){case\"solid\":return[];case\"dashed\":return[6];case\"dotted\":return[2,4];case\"dotdash\":return[2,4,6,4];case\"dashdot\":return[6,4,2,4];default:return e.split(\" \").map(Number).filter(_.isInteger)}}i.resolve_line_dash=r;class u extends n.VisualProperties{get doit(){const e=this.line_color.get_value(),t=this.line_alpha.get_value(),i=this.line_width.get_value();return!(null==e||0==t||0==i)}apply(e){const{doit:t}=this;return t&&(this.set_value(e),e.stroke()),t}values(){return{color:this.line_color.get_value(),alpha:this.line_alpha.get_value(),width:this.line_width.get_value(),join:this.line_join.get_value(),cap:this.line_cap.get_value(),dash:this.line_dash.get_value(),offset:this.line_dash_offset.get_value()}}set_value(e){const t=this.line_color.get_value(),i=this.line_alpha.get_value();e.strokeStyle=(0,o.color2css)(t,i),e.lineWidth=this.line_width.get_value(),e.lineJoin=this.line_join.get_value(),e.lineCap=this.line_cap.get_value(),e.lineDash=r(this.line_dash.get_value()),e.lineDashOffset=this.line_dash_offset.get_value()}}i.Line=u,u.__name__=\"Line\";class c extends n.VisualUniforms{get doit(){const e=this.line_color.value,t=this.line_alpha.value,i=this.line_width.value;return!(0==e||0==t||0==i)}apply(e){const{doit:t}=this;return t&&(this.set_value(e),e.stroke()),t}values(){return{color:this.line_color.value,alpha:this.line_alpha.value,width:this.line_width.value,join:this.line_join.value,cap:this.line_cap.value,dash:this.line_dash.value,offset:this.line_dash_offset.value}}set_value(e){const t=this.line_color.value,i=this.line_alpha.value;e.strokeStyle=(0,o.color2css)(t,i),e.lineWidth=this.line_width.value,e.lineJoin=this.line_join.value,e.lineCap=this.line_cap.value,e.lineDash=r(this.line_dash.value),e.lineDashOffset=this.line_dash_offset.value}}i.LineScalar=c,c.__name__=\"LineScalar\";class d extends n.VisualUniforms{get doit(){const{line_color:e}=this;if(e.is_Scalar()&&0==e.value)return!1;const{line_alpha:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{line_width:i}=this;return!i.is_Scalar()||0!=i.value}apply(e,t){const{doit:i}=this;return i&&(this.set_vectorize(e,t),e.stroke()),i}values(e){return{color:this.line_color.get(e),alpha:this.line_alpha.get(e),width:this.line_width.get(e),join:this.line_join.get(e),cap:this.line_cap.get(e),dash:this.line_dash.get(e),offset:this.line_dash_offset.get(e)}}set_vectorize(e,t){const i=this.line_color.get(t),l=this.line_alpha.get(t),s=this.line_width.get(t),a=this.line_join.get(t),n=this.line_cap.get(t),h=this.line_dash.get(t),_=this.line_dash_offset.get(t);e.strokeStyle=(0,o.color2css)(i,l),e.lineWidth=s,e.lineJoin=a,e.lineCap=n,e.lineDash=r(h),e.lineDashOffset=_}}i.LineVector=d,d.__name__=\"LineVector\",u.prototype.type=\"line\",u.prototype.attrs=Object.keys(h.Line),c.prototype.type=\"line\",c.prototype.attrs=Object.keys(h.LineScalar),d.prototype.type=\"line\",d.prototype.attrs=Object.keys(h.LineVector)},\n", " function _(t,s,o,i,r){i();class e{constructor(t,s=\"\"){this.obj=t,this.prefix=s;const o=this;this._props=[];for(const i of this.attrs){const r=t.model.properties[s+i];r.change.connect((()=>this.update())),o[i]=r,this._props.push(r)}}*[Symbol.iterator](){yield*this._props}update(){}}o.VisualProperties=e,e.__name__=\"VisualProperties\";class p{constructor(t,s=\"\"){this.obj=t,this.prefix=s;for(const o of this.attrs)Object.defineProperty(this,o,{get:()=>t[s+o]})}*[Symbol.iterator](){for(const t of this.attrs)yield this.obj.model.properties[this.prefix+t]}update(){}}o.VisualUniforms=p,p.__name__=\"VisualUniforms\"},\n", " function _(e,l,t,a,c){a();const r=e(1),o=(0,r.__importStar)(e(18)),n=e(20),i=(0,r.__importStar)(e(21)),_=e(13);t.Line={line_color:[i.Nullable(i.Color),\"black\"],line_alpha:[i.Alpha,1],line_width:[i.Number,1],line_join:[n.LineJoin,\"bevel\"],line_cap:[n.LineCap,\"butt\"],line_dash:[i.Or(n.LineDash,i.Array(i.Number)),[]],line_dash_offset:[i.Number,0]},t.Fill={fill_color:[i.Nullable(i.Color),\"gray\"],fill_alpha:[i.Alpha,1]},t.Hatch={hatch_color:[i.Nullable(i.Color),\"black\"],hatch_alpha:[i.Alpha,1],hatch_scale:[i.Number,12],hatch_pattern:[i.Nullable(i.Or(n.HatchPatternType,i.String)),null],hatch_weight:[i.Number,1],hatch_extra:[i.Dict(i.AnyRef()),{}]},t.Text={text_color:[i.Nullable(i.Color),\"#444444\"],text_alpha:[i.Alpha,1],text_font:[o.Font,\"helvetica\"],text_font_size:[i.FontSize,\"16px\"],text_font_style:[n.FontStyle,\"normal\"],text_align:[n.TextAlign,\"left\"],text_baseline:[n.TextBaseline,\"bottom\"],text_line_height:[i.Number,1.2]},t.LineScalar={line_color:[o.ColorScalar,\"black\"],line_alpha:[o.NumberScalar,1],line_width:[o.NumberScalar,1],line_join:[o.LineJoinScalar,\"bevel\"],line_cap:[o.LineCapScalar,\"butt\"],line_dash:[o.LineDashScalar,[]],line_dash_offset:[o.NumberScalar,0]},t.FillScalar={fill_color:[o.ColorScalar,\"gray\"],fill_alpha:[o.NumberScalar,1]},t.HatchScalar={hatch_color:[o.ColorScalar,\"black\"],hatch_alpha:[o.NumberScalar,1],hatch_scale:[o.NumberScalar,12],hatch_pattern:[o.NullStringScalar,null],hatch_weight:[o.NumberScalar,1],hatch_extra:[o.AnyScalar,{}]},t.TextScalar={text_color:[o.ColorScalar,\"#444444\"],text_alpha:[o.NumberScalar,1],text_font:[o.FontScalar,\"helvetica\"],text_font_size:[o.FontSizeScalar,\"16px\"],text_font_style:[o.FontStyleScalar,\"normal\"],text_align:[o.TextAlignScalar,\"left\"],text_baseline:[o.TextBaselineScalar,\"bottom\"],text_line_height:[o.NumberScalar,1.2]},t.LineVector={line_color:[o.ColorSpec,\"black\"],line_alpha:[o.NumberSpec,1],line_width:[o.NumberSpec,1],line_join:[o.LineJoinSpec,\"bevel\"],line_cap:[o.LineCapSpec,\"butt\"],line_dash:[o.LineDashSpec,[]],line_dash_offset:[o.NumberSpec,0]},t.FillVector={fill_color:[o.ColorSpec,\"gray\"],fill_alpha:[o.NumberSpec,1]},t.HatchVector={hatch_color:[o.ColorSpec,\"black\"],hatch_alpha:[o.NumberSpec,1],hatch_scale:[o.NumberSpec,12],hatch_pattern:[o.NullStringSpec,null],hatch_weight:[o.NumberSpec,1],hatch_extra:[o.AnyScalar,{}]},t.TextVector={text_color:[o.ColorSpec,\"#444444\"],text_alpha:[o.NumberSpec,1],text_font:[o.FontSpec,\"helvetica\"],text_font_size:[o.FontSizeSpec,\"16px\"],text_font_style:[o.FontStyleSpec,\"normal\"],text_align:[o.TextAlignSpec,\"left\"],text_baseline:[o.TextBaselineSpec,\"bottom\"],text_line_height:[o.NumberSpec,1.2]},t.attrs_of=function(e,l,t,a=!1){const c={};for(const r of(0,_.keys)(t)){const t=`${l}${r}`,o=e[t];c[a?t:r]=o}return c}},\n", " function _(l,t,e,i,s){i();const a=l(1),o=l(47),r=(0,a.__importStar)(l(48)),_=l(22);class c extends o.VisualProperties{get doit(){const l=this.fill_color.get_value(),t=this.fill_alpha.get_value();return!(null==l||0==t)}apply(l,t){const{doit:e}=this;return e&&(this.set_value(l),l.fill(t)),e}values(){return{color:this.fill_color.get_value(),alpha:this.fill_alpha.get_value()}}set_value(l){const t=this.fill_color.get_value(),e=this.fill_alpha.get_value();l.fillStyle=(0,_.color2css)(t,e)}}e.Fill=c,c.__name__=\"Fill\";class h extends o.VisualUniforms{get doit(){const l=this.fill_color.value,t=this.fill_alpha.value;return!(0==l||0==t)}apply(l,t){const{doit:e}=this;return e&&(this.set_value(l),l.fill(t)),e}values(){return{color:this.fill_color.value,alpha:this.fill_alpha.value}}set_value(l){const t=this.fill_color.value,e=this.fill_alpha.value;l.fillStyle=(0,_.color2css)(t,e)}}e.FillScalar=h,h.__name__=\"FillScalar\";class u extends o.VisualUniforms{get doit(){const{fill_color:l}=this;if(l.is_Scalar()&&0==l.value)return!1;const{fill_alpha:t}=this;return!t.is_Scalar()||0!=t.value}apply(l,t,e){const{doit:i}=this;return i&&(this.set_vectorize(l,t),l.fill(e)),i}values(l){return{color:this.fill_color.get(l),alpha:this.fill_alpha.get(l)}}set_vectorize(l,t){const e=this.fill_color.get(t),i=this.fill_alpha.get(t);l.fillStyle=(0,_.color2css)(e,i)}}e.FillVector=u,u.__name__=\"FillVector\",c.prototype.type=\"fill\",c.prototype.attrs=Object.keys(r.Fill),h.prototype.type=\"fill\",h.prototype.attrs=Object.keys(r.FillScalar),u.prototype.type=\"fill\",u.prototype.attrs=Object.keys(r.FillVector)},\n", " function _(t,e,l,s,_){s();const i=t(1),a=t(47),o=(0,i.__importStar)(t(48)),n=t(22);class h extends a.VisualProperties{get doit(){const t=this.text_color.get_value(),e=this.text_alpha.get_value();return!(null==t||0==e)}values(){return{color:this.text_color.get_value(),alpha:this.text_alpha.get_value(),font:this.text_font.get_value(),font_size:this.text_font_size.get_value(),font_style:this.text_font_style.get_value(),align:this.text_align.get_value(),baseline:this.text_baseline.get_value(),line_height:this.text_line_height.get_value()}}set_value(t){const e=this.text_color.get_value(),l=this.text_alpha.get_value();t.fillStyle=(0,n.color2css)(e,l),t.font=this.font_value(),t.textAlign=this.text_align.get_value(),t.textBaseline=this.text_baseline.get_value()}font_value(){return`${this.text_font_style.get_value()} ${this.text_font_size.get_value()} ${this.text_font.get_value()}`}}l.Text=h,h.__name__=\"Text\";class x extends a.VisualUniforms{get doit(){const t=this.text_color.value,e=this.text_alpha.value;return!(0==t||0==e)}values(){return{color:this.text_color.value,alpha:this.text_alpha.value,font:this.text_font.value,font_size:this.text_font_size.value,font_style:this.text_font_style.value,align:this.text_align.value,baseline:this.text_baseline.value,line_height:this.text_line_height.value}}set_value(t){const e=this.text_color.value,l=this.text_alpha.value,s=this.font_value(),_=this.text_align.value,i=this.text_baseline.value;t.fillStyle=(0,n.color2css)(e,l),t.font=s,t.textAlign=_,t.textBaseline=i}font_value(){return`${this.text_font_style.value} ${this.text_font_size.value} ${this.text_font.value}`}}l.TextScalar=x,x.__name__=\"TextScalar\";class u extends a.VisualUniforms{values(t){return{color:this.text_color.get(t),alpha:this.text_alpha.get(t),font:this.text_font.get(t),font_size:this.text_font_size.get(t),font_style:this.text_font_style.get(t),align:this.text_align.get(t),baseline:this.text_baseline.get(t),line_height:this.text_line_height.get(t)}}get doit(){const{text_color:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{text_alpha:e}=this;return!e.is_Scalar()||0!=e.value}set_vectorize(t,e){const l=this.text_color.get(e),s=this.text_alpha.get(e),_=this.font_value(e),i=this.text_align.get(e),a=this.text_baseline.get(e);t.fillStyle=(0,n.color2css)(l,s),t.font=_,t.textAlign=i,t.textBaseline=a}font_value(t){return`${this.text_font_style.get(t)} ${this.text_font_size.get(t)} ${this.text_font.get(t)}`}}l.TextVector=u,u.__name__=\"TextVector\",h.prototype.type=\"text\",h.prototype.attrs=Object.keys(o.Text),x.prototype.type=\"text\",x.prototype.attrs=Object.keys(o.TextScalar),u.prototype.type=\"text\",u.prototype.attrs=Object.keys(o.TextVector)},\n", " function _(t,e,a,r,i){r();const h=t(1),s=t(47),n=t(52),c=(0,h.__importStar)(t(18)),_=(0,h.__importStar)(t(48));class l extends s.VisualProperties{constructor(){super(...arguments),this._update_iteration=0}update(){if(this._update_iteration++,this._hatch_image=null,!this.doit)return;const t=this.hatch_color.get_value(),e=this.hatch_alpha.get_value(),a=this.hatch_scale.get_value(),r=this.hatch_pattern.get_value(),i=this.hatch_weight.get_value(),h=t=>{this._hatch_image=t},s=this.hatch_extra.get_value()[r];if(null!=s){const r=s.get_pattern(t,e,a,i);if(r instanceof Promise){const{_update_iteration:t}=this;r.then((e=>{this._update_iteration==t&&(h(e),this.obj.request_render())}))}else h(r)}else{const s=this.obj.canvas.create_layer(),c=(0,n.get_pattern)(s,r,t,e,a,i);h(c)}}get doit(){const t=this.hatch_color.get_value(),e=this.hatch_alpha.get_value(),a=this.hatch_pattern.get_value();return!(null==t||0==e||\" \"==a||\"blank\"==a||null==a)}apply(t,e){const{doit:a}=this;return a&&(this.set_value(t),t.layer.undo_transform((()=>t.fill(e)))),a}set_value(t){const e=this.pattern(t);t.fillStyle=null!=e?e:\"transparent\"}pattern(t){const e=this._hatch_image;return null==e?null:t.createPattern(e,this.repetition())}repetition(){const t=this.hatch_pattern.get_value(),e=this.hatch_extra.get_value()[t];if(null==e)return\"repeat\";switch(e.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.Hatch=l,l.__name__=\"Hatch\";class o extends s.VisualUniforms{constructor(){super(...arguments),this._static_doit=!1,this._update_iteration=0}_compute_static_doit(){const t=this.hatch_color.value,e=this.hatch_alpha.value,a=this.hatch_pattern.value;return!(null==t||0==e||\" \"==a||\"blank\"==a||null==a)}update(){this._update_iteration++;const t=this.hatch_color.length;if(this._hatch_image=new c.UniformScalar(null,t),this._static_doit=this._compute_static_doit(),!this._static_doit)return;const e=this.hatch_color.value,a=this.hatch_alpha.value,r=this.hatch_scale.value,i=this.hatch_pattern.value,h=this.hatch_weight.value,s=e=>{this._hatch_image=new c.UniformScalar(e,t)},_=this.hatch_extra.value[i];if(null!=_){const t=_.get_pattern(e,a,r,h);if(t instanceof Promise){const{_update_iteration:e}=this;t.then((t=>{this._update_iteration==e&&(s(t),this.obj.request_render())}))}else s(t)}else{const t=this.obj.canvas.create_layer(),c=(0,n.get_pattern)(t,i,e,a,r,h);s(c)}}get doit(){return this._static_doit}apply(t,e){const{doit:a}=this;return a&&(this.set_value(t),t.layer.undo_transform((()=>t.fill(e)))),a}set_value(t){var e;t.fillStyle=null!==(e=this.pattern(t))&&void 0!==e?e:\"transparent\"}pattern(t){const e=this._hatch_image.value;return null==e?null:t.createPattern(e,this.repetition())}repetition(){const t=this.hatch_pattern.value,e=this.hatch_extra.value[t];if(null==e)return\"repeat\";switch(e.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.HatchScalar=o,o.__name__=\"HatchScalar\";class u extends s.VisualUniforms{constructor(){super(...arguments),this._static_doit=!1,this._update_iteration=0}_compute_static_doit(){const{hatch_color:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{hatch_alpha:e}=this;if(e.is_Scalar()&&0==e.value)return!1;const{hatch_pattern:a}=this;if(a.is_Scalar()){const t=a.value;if(\" \"==t||\"blank\"==t||null==t)return!1}return!0}update(){this._update_iteration++;const t=this.hatch_color.length;if(this._hatch_image=new c.UniformScalar(null,t),this._static_doit=this._compute_static_doit(),!this._static_doit)return;const e=(t,e,a,r,i,h)=>{const s=this.hatch_extra.value[t];if(null!=s){const t=s.get_pattern(e,a,r,i);if(t instanceof Promise){const{_update_iteration:e}=this;t.then((t=>{this._update_iteration==e&&(h(t),this.obj.request_render())}))}else h(t)}else{const s=this.obj.canvas.create_layer(),c=(0,n.get_pattern)(s,t,e,a,r,i);h(c)}};if(this.hatch_color.is_Scalar()&&this.hatch_alpha.is_Scalar()&&this.hatch_scale.is_Scalar()&&this.hatch_pattern.is_Scalar()&&this.hatch_weight.is_Scalar()){const a=this.hatch_color.value,r=this.hatch_alpha.value,i=this.hatch_scale.value;e(this.hatch_pattern.value,a,r,i,this.hatch_weight.value,(e=>{this._hatch_image=new c.UniformScalar(e,t)}))}else{const a=new Array(t);a.fill(null),this._hatch_image=new c.UniformVector(a);for(let r=0;r{a[r]=t}))}}}get doit(){return this._static_doit}apply(t,e,a){const{doit:r}=this;return r&&(this.set_vectorize(t,e),t.layer.undo_transform((()=>t.fill(a)))),r}set_vectorize(t,e){var a;t.fillStyle=null!==(a=this.pattern(t,e))&&void 0!==a?a:\"transparent\"}pattern(t,e){const a=this._hatch_image.get(e);return null==a?null:t.createPattern(a,this.repetition(e))}repetition(t){const e=this.hatch_pattern.get(t),a=this.hatch_extra.value[e];if(null==a)return\"repeat\";switch(a.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.HatchVector=u,u.__name__=\"HatchVector\",l.prototype.type=\"hatch\",l.prototype.attrs=Object.keys(_.Hatch),o.prototype.type=\"hatch\",o.prototype.attrs=Object.keys(_.HatchScalar),u.prototype.type=\"hatch\",u.prototype.attrs=Object.keys(_.HatchVector)},\n", " function _(e,o,a,s,r){s();const i=e(22);function l(e,o,a){e.moveTo(0,a+.5),e.lineTo(o,a+.5),e.stroke()}function n(e,o,a){e.moveTo(a+.5,0),e.lineTo(a+.5,o),e.stroke()}function t(e,o){e.moveTo(0,o),e.lineTo(o,0),e.stroke(),e.moveTo(0,0),e.lineTo(o,o),e.stroke()}a.hatch_aliases={\" \":\"blank\",\".\":\"dot\",o:\"ring\",\"-\":\"horizontal_line\",\"|\":\"vertical_line\",\"+\":\"cross\",'\"':\"horizontal_dash\",\":\":\"vertical_dash\",\"@\":\"spiral\",\"/\":\"right_diagonal_line\",\"\\\\\":\"left_diagonal_line\",x:\"diagonal_cross\",\",\":\"right_diagonal_dash\",\"`\":\"left_diagonal_dash\",v:\"horizontal_wave\",\">\":\"vertical_wave\",\"*\":\"criss_cross\"},a.get_pattern=function(e,o,s,r,c,k){return e.resize(c,c),e.prepare(),function(e,o,s,r,c,k){var _;const T=c,v=T/2,h=v/2,d=(0,i.color2css)(s,r);switch(e.strokeStyle=d,e.fillStyle=d,e.lineCap=\"square\",e.lineWidth=k,null!==(_=a.hatch_aliases[o])&&void 0!==_?_:o){case\"blank\":break;case\"dot\":e.arc(v,v,v/2,0,2*Math.PI,!0),e.fill();break;case\"ring\":e.arc(v,v,v/2,0,2*Math.PI,!0),e.stroke();break;case\"horizontal_line\":l(e,T,v);break;case\"vertical_line\":n(e,T,v);break;case\"cross\":l(e,T,v),n(e,T,v);break;case\"horizontal_dash\":l(e,v,v);break;case\"vertical_dash\":n(e,v,v);break;case\"spiral\":{const o=T/30;e.moveTo(v,v);for(let a=0;a<360;a++){const s=.1*a,r=v+o*s*Math.cos(s),i=v+o*s*Math.sin(s);e.lineTo(r,i)}e.stroke();break}case\"right_diagonal_line\":e.moveTo(.5-h,T),e.lineTo(h+.5,0),e.stroke(),e.moveTo(h+.5,T),e.lineTo(3*h+.5,0),e.stroke(),e.moveTo(3*h+.5,T),e.lineTo(5*h+.5,0),e.stroke(),e.stroke();break;case\"left_diagonal_line\":e.moveTo(h+.5,T),e.lineTo(.5-h,0),e.stroke(),e.moveTo(3*h+.5,T),e.lineTo(h+.5,0),e.stroke(),e.moveTo(5*h+.5,T),e.lineTo(3*h+.5,0),e.stroke(),e.stroke();break;case\"diagonal_cross\":t(e,T);break;case\"right_diagonal_dash\":e.moveTo(h+.5,3*h+.5),e.lineTo(3*h+.5,h+.5),e.stroke();break;case\"left_diagonal_dash\":e.moveTo(h+.5,h+.5),e.lineTo(3*h+.5,3*h+.5),e.stroke();break;case\"horizontal_wave\":e.moveTo(0,h),e.lineTo(v,3*h),e.lineTo(T,h),e.stroke();break;case\"vertical_wave\":e.moveTo(h,0),e.lineTo(3*h,v),e.lineTo(h,T),e.stroke();break;case\"criss_cross\":t(e,T),l(e,T,v),n(e,T,v)}}(e.ctx,o,s,r,c,k),e.canvas}},\n", " function _(e,t,s,n,c){var a;n();const i=e(14),r=e(8),l=e(13),o=e(26),_=e(19);class h extends i.HasProps{constructor(e){super(e)}get is_syncable(){return this.syncable}[o.equals](e,t){return t.eq(this.id,e.id)&&super[o.equals](e,t)}initialize(){super.initialize(),this._js_callbacks=new Map}connect_signals(){super.connect_signals(),this._update_property_callbacks(),this.connect(this.properties.js_property_callbacks.change,(()=>this._update_property_callbacks())),this.connect(this.properties.js_event_callbacks.change,(()=>this._update_event_callbacks())),this.connect(this.properties.subscribed_events.change,(()=>this._update_event_callbacks()))}_process_event(e){var t;for(const s of null!==(t=this.js_event_callbacks[e.event_name])&&void 0!==t?t:[])s.execute(e);null!=this.document&&this.subscribed_events.some((t=>t==e.event_name))&&this.document.event_manager.send_event(e)}trigger_event(e){null!=this.document&&(e.origin=this,this.document.event_manager.trigger(e))}_update_event_callbacks(){null!=this.document?this.document.event_manager.subscribed_models.add(this):_.logger.warn(\"WARNING: Document not defined for updating event callbacks\")}_update_property_callbacks(){const e=e=>{const[t,s=null]=e.split(\":\");return null!=s?this.properties[s][t]:this[t]};for(const[t,s]of this._js_callbacks){const n=e(t);for(const e of s)this.disconnect(n,e)}this._js_callbacks.clear();for(const[t,s]of(0,l.entries)(this.js_property_callbacks)){const n=s.map((e=>()=>e.execute(this)));this._js_callbacks.set(t,n);const c=e(t);for(const e of n)this.connect(c,e)}}_doc_attached(){(0,l.isEmpty)(this.js_event_callbacks)&&0==this.subscribed_events.length||this._update_event_callbacks()}_doc_detached(){this.document.event_manager.subscribed_models.delete(this)}select(e){if((0,r.isString)(e))return[...this.references()].filter((t=>t instanceof h&&t.name===e));if(e.prototype instanceof i.HasProps)return[...this.references()].filter((t=>t instanceof e));throw new Error(\"invalid selector\")}select_one(e){const t=this.select(e);switch(t.length){case 0:return null;case 1:return t[0];default:throw new Error(\"found more than one object matching given selector\")}}}s.Model=h,a=h,h.__name__=\"Model\",a.define((({Any:e,Unknown:t,Boolean:s,String:n,Array:c,Dict:a,Nullable:i})=>({tags:[c(t),[]],name:[i(n),null],js_property_callbacks:[a(c(e)),{}],js_event_callbacks:[a(c(e)),{}],subscribed_events:[c(n),[]],syncable:[s,!0]})))},\n", " function _(e,t,s,a,r){var c,n;a();const _=e(12),o=e(53),i=e(55),l=e(59),u=e(61),g=e(62),h=e(57),p=e(63),m=e(67);class x{constructor(e,t){this.x_scale=e,this.y_scale=t,this.x_source=this.x_scale.source_range,this.y_source=this.y_scale.source_range,this.ranges=[this.x_source,this.y_source],this.scales=[this.x_scale,this.y_scale]}map_to_screen(e,t){return[this.x_scale.v_compute(e),this.y_scale.v_compute(t)]}map_from_screen(e,t){return[this.x_scale.v_invert(e),this.y_scale.v_invert(t)]}}s.CoordinateTransform=x,x.__name__=\"CoordinateTransform\";class y extends o.Model{constructor(e){super(e)}get x_ranges(){return new Map([[\"default\",this.x_source]])}get y_ranges(){return new Map([[\"default\",this.y_source]])}_get_scale(e,t,s){if(e instanceof m.FactorRange!=t instanceof g.CategoricalScale)throw new Error(`Range ${e.type} is incompatible is Scale ${t.type}`);t instanceof u.LogScale&&e instanceof p.DataRange1d&&(e.scale_hint=\"log\");const a=t.clone();return a.setv({source_range:e,target_range:s}),a}get_transform(e){const{x_source:t,x_scale:s,x_target:a}=this,r=this._get_scale(t,s,a),{y_source:c,y_scale:n,y_target:_}=this,o=this._get_scale(c,n,_),i=new v({source_scale:r,source_range:r.source_range,target_scale:e.x_scale,target_range:e.x_target}),l=new v({source_scale:o,source_range:o.source_range,target_scale:e.y_scale,target_range:e.y_target});return new x(i,l)}}s.CoordinateMapping=y,c=y,y.__name__=\"CoordinateMapping\",c.define((({Ref:e})=>({x_source:[e(h.Range),()=>new p.DataRange1d],y_source:[e(h.Range),()=>new p.DataRange1d],x_scale:[e(i.Scale),()=>new l.LinearScale],y_scale:[e(i.Scale),()=>new l.LinearScale],x_target:[e(h.Range)],y_target:[e(h.Range)]})));class v extends i.Scale{constructor(e){super(e)}get s_compute(){const e=this.source_scale.s_compute,t=this.target_scale.s_compute;return s=>t(e(s))}get s_invert(){const e=this.source_scale.s_invert,t=this.target_scale.s_invert;return s=>e(t(s))}compute(e){return this.s_compute(e)}v_compute(e){const{s_compute:t}=this;return(0,_.map)(e,t)}invert(e){return this.s_invert(e)}v_invert(e){const{s_invert:t}=this;return(0,_.map)(e,t)}}s.CompositeScale=v,n=v,v.__name__=\"CompositeScale\",n.internal((({Ref:e})=>({source_scale:[e(i.Scale)],target_scale:[e(i.Scale)]})))},\n", " function _(e,t,r,n,s){var _;n();const a=e(56),c=e(57),o=e(58),i=e(24);class u extends a.Transform{constructor(e){super(e)}compute(e){return this.s_compute(e)}v_compute(e){const t=new i.ScreenArray(e.length),{s_compute:r}=this;for(let n=0;n({source_range:[e(c.Range)],target_range:[e(o.Range1d)]})))},\n", " function _(n,s,o,r,c){r();const e=n(53);class t extends e.Model{constructor(n){super(n)}}o.Transform=t,t.__name__=\"Transform\"},\n", " function _(e,t,n,i,s){var r;i();const a=e(53);class l extends a.Model{constructor(e){super(e),this.have_updated_interactively=!1}get is_reversed(){return this.start>this.end}get is_valid(){return isFinite(this.min)&&isFinite(this.max)}get span(){return Math.abs(this.end-this.start)}}n.Range=l,r=l,l.__name__=\"Range\",r.define((({Number:e,Tuple:t,Or:n,Auto:i,Nullable:s})=>({bounds:[s(n(t(s(e),s(e)),i)),null],min_interval:[s(e),null],max_interval:[s(e),null]}))),r.internal((({Array:e,AnyRef:t})=>({plots:[e(t()),[]]})))},\n", " function _(t,e,s,n,r){var a;n();const i=t(57);class _ extends i.Range{constructor(t){super(t)}_set_auto_bounds(){if(\"auto\"==this.bounds){const t=Math.min(this._reset_start,this._reset_end),e=Math.max(this._reset_start,this._reset_end);this.setv({bounds:[t,e]},{silent:!0})}}initialize(){super.initialize(),this._set_auto_bounds()}get min(){return Math.min(this.start,this.end)}get max(){return Math.max(this.start,this.end)}reset(){this._set_auto_bounds();const{_reset_start:t,_reset_end:e}=this;this.start!=t||this.end!=e?this.setv({start:t,end:e}):this.change.emit()}map(t){return new _({start:t(this.start),end:t(this.end)})}widen(t){let{start:e,end:s}=this;return this.is_reversed?(e+=t,s-=t):(e-=t,s+=t),new _({start:e,end:s})}}s.Range1d=_,a=_,_.__name__=\"Range1d\",a.define((({Number:t,Nullable:e})=>({start:[t,0],end:[t,1],reset_start:[e(t),null,{on_update(t,e){e._reset_start=null!=t?t:e.start}}],reset_end:[e(t),null,{on_update(t,e){e._reset_end=null!=t?t:e.end}}]})))},\n", " function _(t,e,n,r,s){r();const a=t(60);class _ extends a.ContinuousScale{constructor(t){super(t)}get s_compute(){const[t,e]=this._linear_compute_state();return n=>t*n+e}get s_invert(){const[t,e]=this._linear_compute_state();return n=>(n-e)/t}_linear_compute_state(){const t=this.source_range.start,e=this.source_range.end,n=this.target_range.start,r=(this.target_range.end-n)/(e-t);return[r,-r*t+n]}}n.LinearScale=_,_.__name__=\"LinearScale\"},\n", " function _(n,c,o,s,e){s();const t=n(55);class u extends t.Scale{constructor(n){super(n)}}o.ContinuousScale=u,u.__name__=\"ContinuousScale\"},\n", " function _(t,e,a,o,s){o();const r=t(60);class n extends r.ContinuousScale{constructor(t){super(t)}get s_compute(){const[t,e,a,o]=this._compute_state();return s=>{if(0==a)return 0;{const r=(Math.log(s)-o)/a;return isFinite(r)?r*t+e:NaN}}}get s_invert(){const[t,e,a,o]=this._compute_state();return s=>{const r=(s-e)/t;return Math.exp(a*r+o)}}_get_safe_factor(t,e){let a=t<0?0:t,o=e<0?0:e;if(a==o)if(0==a)[a,o]=[1,10];else{const t=Math.log(a)/Math.log(10);a=10**Math.floor(t),o=Math.ceil(t)!=Math.floor(t)?10**Math.ceil(t):10**(Math.ceil(t)+1)}return[a,o]}_compute_state(){const t=this.source_range.start,e=this.source_range.end,a=this.target_range.start,o=this.target_range.end-a,[s,r]=this._get_safe_factor(t,e);let n,c;0==s?(n=Math.log(r),c=0):(n=Math.log(r)-Math.log(s),c=Math.log(s));return[o,a,n,c]}}a.LogScale=n,n.__name__=\"LogScale\"},\n", " function _(t,e,c,a,s){a();const n=t(55),r=t(59),{_linear_compute_state:o}=r.LinearScale.prototype;class l extends n.Scale{constructor(t){super(t)}get s_compute(){const[t,e]=o.call(this),c=this.source_range;return a=>t*c.synthetic(a)+e}get s_invert(){const[t,e]=o.call(this);return c=>(c-e)/t}}c.CategoricalScale=l,l.__name__=\"CategoricalScale\"},\n", " function _(t,i,n,e,a){e();const s=t(1);var l;const _=t(64),o=t(20),r=t(9),h=t(19),d=(0,s.__importStar)(t(65)),u=t(66);class g extends _.DataRange{constructor(t){super(t),this.have_updated_interactively=!1}initialize(){super.initialize(),this._initial_start=this.start,this._initial_end=this.end,this._initial_range_padding=this.range_padding,this._initial_range_padding_units=this.range_padding_units,this._initial_follow=this.follow,this._initial_follow_interval=this.follow_interval,this._initial_default_span=this.default_span,this._plot_bounds=new Map}get min(){return Math.min(this.start,this.end)}get max(){return Math.max(this.start,this.end)}computed_renderers(){const{renderers:t,names:i}=this,n=(0,r.concat)(this.plots.map((t=>t.data_renderers)));return(0,u.compute_renderers)(0==t.length?\"auto\":t,n,i)}_compute_plot_bounds(t,i){let n=d.empty();for(const e of t){const t=i.get(e);null==t||!e.visible&&this.only_visible||(n=d.union(n,t))}return n}adjust_bounds_for_aspect(t,i){const n=d.empty();let e=t.x1-t.x0;e<=0&&(e=1);let a=t.y1-t.y0;a<=0&&(a=1);const s=.5*(t.x1+t.x0),l=.5*(t.y1+t.y0);return el&&(\"start\"==this.follow?a=e+s*l:\"end\"==this.follow&&(e=a-s*l)),[e,a]}update(t,i,n,e){if(this.have_updated_interactively)return;const a=this.computed_renderers();let s=this._compute_plot_bounds(a,t);null!=e&&(s=this.adjust_bounds_for_aspect(s,e)),this._plot_bounds.set(n,s);const[l,_]=this._compute_min_max(this._plot_bounds.entries(),i);let[o,r]=this._compute_range(l,_);null!=this._initial_start&&(\"log\"==this.scale_hint?this._initial_start>0&&(o=this._initial_start):o=this._initial_start),null!=this._initial_end&&(\"log\"==this.scale_hint?this._initial_end>0&&(r=this._initial_end):r=this._initial_end);let h=!1;\"auto\"==this.bounds&&(this.setv({bounds:[o,r]},{silent:!0}),h=!0);const[d,u]=[this.start,this.end];if(o!=d||r!=u){const t={};o!=d&&(t.start=o),r!=u&&(t.end=r),this.setv(t),h=!1}h&&this.change.emit()}reset(){this.have_updated_interactively=!1,this.setv({range_padding:this._initial_range_padding,range_padding_units:this._initial_range_padding_units,follow:this._initial_follow,follow_interval:this._initial_follow_interval,default_span:this._initial_default_span},{silent:!0}),this.change.emit()}}n.DataRange1d=g,l=g,g.__name__=\"DataRange1d\",l.define((({Boolean:t,Number:i,Nullable:n})=>({start:[i],end:[i],range_padding:[i,.1],range_padding_units:[o.PaddingUnits,\"percent\"],flipped:[t,!1],follow:[n(o.StartEnd),null],follow_interval:[n(i),null],default_span:[i,2],only_visible:[t,!1]}))),l.internal((({Enum:t})=>({scale_hint:[t(\"log\",\"auto\"),\"auto\"]})))},\n", " function _(e,n,a,r,s){var t;r();const c=e(57);class _ extends c.Range{constructor(e){super(e)}}a.DataRange=_,t=_,_.__name__=\"DataRange\",t.define((({String:e,Array:n,AnyRef:a})=>({names:[n(e),[]],renderers:[n(a()),[]]})))},\n", " function _(t,i,e,h,r){h();const s=t(24),n=t(26),{min:x,max:y}=Math;e.empty=function(){return{x0:1/0,y0:1/0,x1:-1/0,y1:-1/0}},e.positive_x=function(){return{x0:Number.MIN_VALUE,y0:-1/0,x1:1/0,y1:1/0}},e.positive_y=function(){return{x0:-1/0,y0:Number.MIN_VALUE,x1:1/0,y1:1/0}},e.union=function(t,i){return{x0:x(t.x0,i.x0),x1:y(t.x1,i.x1),y0:x(t.y0,i.y0),y1:y(t.y1,i.y1)}};class o{constructor(t){if(null==t)this.x0=0,this.y0=0,this.x1=0,this.y1=0;else if(\"x0\"in t){const{x0:i,y0:e,x1:h,y1:r}=t;if(!(i<=h&&e<=r))throw new Error(`invalid bbox {x0: ${i}, y0: ${e}, x1: ${h}, y1: ${r}}`);this.x0=i,this.y0=e,this.x1=h,this.y1=r}else if(\"x\"in t){const{x:i,y:e,width:h,height:r}=t;if(!(h>=0&&r>=0))throw new Error(`invalid bbox {x: ${i}, y: ${e}, width: ${h}, height: ${r}}`);this.x0=i,this.y0=e,this.x1=i+h,this.y1=e+r}else{let i,e,h,r;if(\"width\"in t)if(\"left\"in t)i=t.left,e=i+t.width;else if(\"right\"in t)e=t.right,i=e-t.width;else{const h=t.width/2;i=t.hcenter-h,e=t.hcenter+h}else i=t.left,e=t.right;if(\"height\"in t)if(\"top\"in t)h=t.top,r=h+t.height;else if(\"bottom\"in t)r=t.bottom,h=r-t.height;else{const i=t.height/2;h=t.vcenter-i,r=t.vcenter+i}else h=t.top,r=t.bottom;if(!(i<=e&&h<=r))throw new Error(`invalid bbox {left: ${i}, top: ${h}, right: ${e}, bottom: ${r}}`);this.x0=i,this.y0=h,this.x1=e,this.y1=r}}static from_rect({left:t,right:i,top:e,bottom:h}){return new o({x0:Math.min(t,i),y0:Math.min(e,h),x1:Math.max(t,i),y1:Math.max(e,h)})}equals(t){return this.x0==t.x0&&this.y0==t.y0&&this.x1==t.x1&&this.y1==t.y1}[n.equals](t,i){return i.eq(this.x0,t.x0)&&i.eq(this.y0,t.y0)&&i.eq(this.x1,t.x1)&&i.eq(this.y1,t.y1)}toString(){return`BBox({left: ${this.left}, top: ${this.top}, width: ${this.width}, height: ${this.height}})`}get left(){return this.x0}get top(){return this.y0}get right(){return this.x1}get bottom(){return this.y1}get p0(){return[this.x0,this.y0]}get p1(){return[this.x1,this.y1]}get x(){return this.x0}get y(){return this.y0}get width(){return this.x1-this.x0}get height(){return this.y1-this.y0}get size(){return{width:this.width,height:this.height}}get rect(){const{x0:t,y0:i,x1:e,y1:h}=this;return{p0:{x:t,y:i},p1:{x:e,y:i},p2:{x:e,y:h},p3:{x:t,y:h}}}get box(){const{x:t,y:i,width:e,height:h}=this;return{x:t,y:i,width:e,height:h}}get h_range(){return{start:this.x0,end:this.x1}}get v_range(){return{start:this.y0,end:this.y1}}get ranges(){return[this.h_range,this.v_range]}get aspect(){return this.width/this.height}get hcenter(){return(this.left+this.right)/2}get vcenter(){return(this.top+this.bottom)/2}get area(){return this.width*this.height}relative(){const{width:t,height:i}=this;return new o({x:0,y:0,width:t,height:i})}translate(t,i){const{x:e,y:h,width:r,height:s}=this;return new o({x:t+e,y:i+h,width:r,height:s})}relativize(t,i){return[t-this.x,i-this.y]}contains(t,i){return this.x0<=t&&t<=this.x1&&this.y0<=i&&i<=this.y1}clip(t,i){return tthis.x1&&(t=this.x1),ithis.y1&&(i=this.y1),[t,i]}grow_by(t){return new o({left:this.left-t,right:this.right+t,top:this.top-t,bottom:this.bottom+t})}shrink_by(t){return new o({left:this.left+t,right:this.right-t,top:this.top+t,bottom:this.bottom-t})}union(t){return new o({x0:x(this.x0,t.x0),y0:x(this.y0,t.y0),x1:y(this.x1,t.x1),y1:y(this.y1,t.y1)})}intersection(t){return this.intersects(t)?new o({x0:y(this.x0,t.x0),y0:y(this.y0,t.y0),x1:x(this.x1,t.x1),y1:x(this.y1,t.y1)}):null}intersects(t){return!(t.x1this.x1||t.y1this.y1)}get xview(){return{compute:t=>this.left+t,v_compute:t=>{const i=new s.ScreenArray(t.length),e=this.left;for(let h=0;hthis.bottom-t,v_compute:t=>{const i=new s.ScreenArray(t.length),e=this.bottom;for(let h=0;h0&&(r=r.filter((n=>(0,l.includes)(t,n.name)))),r}},\n", " function _(t,n,e,i,s){var r;i();const a=t(57),o=t(20),g=t(21),p=t(24),c=t(9),l=t(8),u=t(11);function h(t,n,e=0){const i=new Map;for(let s=0;sa.get(t).value)));r.set(t,{value:l/s,mapping:a}),o+=s+n+p}return[r,(a.size-1)*n+g]}function _(t,n,e,i,s=0){var r;const a=new Map,o=new Map;for(const[n,e,i]of t){const t=null!==(r=o.get(n))&&void 0!==r?r:[];o.set(n,[...t,[e,i]])}let g=s,p=0;for(const[t,s]of o){const r=s.length,[o,l]=d(s,e,i,g);p+=l;const u=(0,c.sum)(s.map((([t])=>o.get(t).value)));a.set(t,{value:u/r,mapping:o}),g+=r+n+l}return[a,(o.size-1)*n+p]}e.Factor=(0,g.Or)(g.String,(0,g.Tuple)(g.String,g.String),(0,g.Tuple)(g.String,g.String,g.String)),e.FactorSeq=(0,g.Or)((0,g.Array)(g.String),(0,g.Array)((0,g.Tuple)(g.String,g.String)),(0,g.Array)((0,g.Tuple)(g.String,g.String,g.String))),e.map_one_level=h,e.map_two_levels=d,e.map_three_levels=_;class f extends a.Range{constructor(t){super(t)}get min(){return this.start}get max(){return this.end}initialize(){super.initialize(),this._init(!0)}connect_signals(){super.connect_signals(),this.connect(this.properties.factors.change,(()=>this.reset())),this.connect(this.properties.factor_padding.change,(()=>this.reset())),this.connect(this.properties.group_padding.change,(()=>this.reset())),this.connect(this.properties.subgroup_padding.change,(()=>this.reset())),this.connect(this.properties.range_padding.change,(()=>this.reset())),this.connect(this.properties.range_padding_units.change,(()=>this.reset()))}reset(){this._init(!1),this.change.emit()}_lookup(t){switch(t.length){case 1:{const[n]=t,e=this._mapping.get(n);return null!=e?e.value:NaN}case 2:{const[n,e]=t,i=this._mapping.get(n);if(null!=i){const t=i.mapping.get(e);if(null!=t)return t.value}return NaN}case 3:{const[n,e,i]=t,s=this._mapping.get(n);if(null!=s){const t=s.mapping.get(e);if(null!=t){const n=t.mapping.get(i);if(null!=n)return n.value}}return NaN}default:(0,u.unreachable)()}}synthetic(t){if((0,l.isNumber)(t))return t;if((0,l.isString)(t))return this._lookup([t]);let n=0;const e=t[t.length-1];return(0,l.isNumber)(e)&&(n=e,t=t.slice(0,-1)),this._lookup(t)+n}v_synthetic(t){const n=t.length,e=new p.ScreenArray(n);for(let i=0;i{if((0,c.every)(this.factors,l.isString)){const t=this.factors,[n,e]=h(t,this.factor_padding);return{levels:1,mapping:n,tops:null,mids:null,inside_padding:e}}if((0,c.every)(this.factors,(t=>(0,l.isArray)(t)&&2==t.length&&(0,l.isString)(t[0])&&(0,l.isString)(t[1])))){const t=this.factors,[n,e]=d(t,this.group_padding,this.factor_padding),i=[...n.keys()];return{levels:2,mapping:n,tops:i,mids:null,inside_padding:e}}if((0,c.every)(this.factors,(t=>(0,l.isArray)(t)&&3==t.length&&(0,l.isString)(t[0])&&(0,l.isString)(t[1])&&(0,l.isString)(t[2])))){const t=this.factors,[n,e]=_(t,this.group_padding,this.subgroup_padding,this.factor_padding),i=[...n.keys()],s=[];for(const[t,e]of n)for(const n of e.mapping.keys())s.push([t,n]);return{levels:3,mapping:n,tops:i,mids:s,inside_padding:e}}(0,u.unreachable)()})();this._mapping=e,this.tops=i,this.mids=s;let a=0,o=this.factors.length+r;if(\"percent\"==this.range_padding_units){const t=(o-a)*this.range_padding/2;a-=t,o+=t}else a-=this.range_padding,o+=this.range_padding;this.setv({start:a,end:o,levels:n},{silent:t}),\"auto\"==this.bounds&&this.setv({bounds:[a,o]},{silent:!0})}}e.FactorRange=f,r=f,f.__name__=\"FactorRange\",r.define((({Number:t})=>({factors:[e.FactorSeq,[]],factor_padding:[t,0],subgroup_padding:[t,.8],group_padding:[t,1.4],range_padding:[t,0],range_padding_units:[o.PaddingUnits,\"percent\"],start:[t],end:[t]}))),r.internal((({Number:t,String:n,Array:e,Tuple:i,Nullable:s})=>({levels:[t],mids:[s(e(i(n,n))),null],tops:[s(e(n)),null]})))},\n", " function _(t,e,s,a,i){a();const n=t(1);var _;const r=t(69),o=t(112),l=t(48),d=t(20),h=t(24),c=t(113),u=(0,n.__importStar)(t(18)),v=t(10);class p extends r.DataAnnotationView{async lazy_initialize(){await super.lazy_initialize();const{start:t,end:e}=this.model;null!=t&&(this.start=await(0,c.build_view)(t,{parent:this})),null!=e&&(this.end=await(0,c.build_view)(e,{parent:this}))}set_data(t){var e,s;super.set_data(t),null===(e=this.start)||void 0===e||e.set_data(t),null===(s=this.end)||void 0===s||s.set_data(t)}remove(){var t,e;null===(t=this.start)||void 0===t||t.remove(),null===(e=this.end)||void 0===e||e.remove(),super.remove()}map_data(){const{frame:t}=this.plot_view;\"data\"==this.model.start_units?(this._sx_start=this.coordinates.x_scale.v_compute(this._x_start),this._sy_start=this.coordinates.y_scale.v_compute(this._y_start)):(this._sx_start=t.bbox.xview.v_compute(this._x_start),this._sy_start=t.bbox.yview.v_compute(this._y_start)),\"data\"==this.model.end_units?(this._sx_end=this.coordinates.x_scale.v_compute(this._x_end),this._sy_end=this.coordinates.y_scale.v_compute(this._y_end)):(this._sx_end=t.bbox.xview.v_compute(this._x_end),this._sy_end=t.bbox.yview.v_compute(this._y_end));const{_sx_start:e,_sy_start:s,_sx_end:a,_sy_end:i}=this,n=e.length,_=this._angles=new h.ScreenArray(n);for(let t=0;t({x_start:[u.XCoordinateSpec,{field:\"x_start\"}],y_start:[u.YCoordinateSpec,{field:\"y_start\"}],start_units:[d.SpatialUnits,\"data\"],start:[e(t(o.ArrowHead)),null],x_end:[u.XCoordinateSpec,{field:\"x_end\"}],y_end:[u.YCoordinateSpec,{field:\"y_end\"}],end_units:[d.SpatialUnits,\"data\"],end:[e(t(o.ArrowHead)),()=>new o.OpenHead]})))},\n", " function _(t,e,n,s,a){s();const o=t(1);var i;const c=t(40),r=t(70),_=t(75),l=t(78),h=(0,o.__importStar)(t(18));class d extends c.AnnotationView{constructor(){super(...arguments),this._initial_set_data=!1}connect_signals(){super.connect_signals();const t=()=>{this.set_data(this.model.source),this._rerender()};this.connect(this.model.change,t),this.connect(this.model.source.streaming,t),this.connect(this.model.source.patching,t),this.connect(this.model.source.change,t)}_rerender(){this.request_render()}set_data(t){const e=this;for(const n of this.model)if(n instanceof h.VectorSpec||n instanceof h.ScalarSpec)if(n instanceof h.BaseCoordinateSpec){const s=n.array(t);e[`_${n.attr}`]=s}else{const s=n.uniform(t);e[`${n.attr}`]=s}this.plot_model.use_map&&(null!=e._x&&l.inplace.project_xy(e._x,e._y),null!=e._xs&&l.inplace.project_xsys(e._xs,e._ys));for(const t of this.visuals)t.update()}_render(){this._initial_set_data||(this.set_data(this.model.source),this._initial_set_data=!0),this.map_data(),this.paint(this.layer.ctx)}}n.DataAnnotationView=d,d.__name__=\"DataAnnotationView\";class u extends c.Annotation{constructor(t){super(t)}}n.DataAnnotation=u,i=u,u.__name__=\"DataAnnotation\",i.define((({Ref:t})=>({source:[t(r.ColumnarDataSource),()=>new _.ColumnDataSource]})))},\n", " function _(t,e,n,s,a){var i;s();const r=t(71),l=t(15),c=t(19),o=t(73),h=t(8),u=t(9),g=t(13),d=t(72),_=t(74),m=t(29);class w extends r.DataSource{constructor(t){super(t),this.selection_manager=new o.SelectionManager(this)}get_array(t){let e=this.data[t];return null==e?this.data[t]=e=[]:(0,h.isArray)(e)||(this.data[t]=e=Array.from(e)),e}initialize(){super.initialize(),this._select=new l.Signal0(this,\"select\"),this.inspect=new l.Signal(this,\"inspect\"),this.streaming=new l.Signal0(this,\"streaming\"),this.patching=new l.Signal(this,\"patching\")}get_column(t){const e=this.data[t];return null!=e?e:null}columns(){return(0,g.keys)(this.data)}get_length(t=!0){const e=(0,u.uniq)((0,g.values)(this.data).map((t=>(0,m.is_NDArray)(t)?t.shape[0]:t.length)));switch(e.length){case 0:return null;case 1:return e[0];default:{const n=\"data source has columns of inconsistent lengths\";if(t)return c.logger.warn(n),e.sort()[0];throw new Error(n)}}}get length(){var t;return null!==(t=this.get_length())&&void 0!==t?t:0}clear(){const t={};for(const e of this.columns())t[e]=new this.data[e].constructor(0);this.data=t}}n.ColumnarDataSource=w,i=w,w.__name__=\"ColumnarDataSource\",i.define((({Ref:t})=>({selection_policy:[t(_.SelectionPolicy),()=>new _.UnionRenderers]}))),i.internal((({AnyRef:t})=>({inspected:[t(),()=>new d.Selection]})))},\n", " function _(e,c,n,t,o){var a;t();const s=e(53),r=e(72);class l extends s.Model{constructor(e){super(e)}}n.DataSource=l,a=l,l.__name__=\"DataSource\",a.define((({Ref:e})=>({selected:[e(r.Selection),()=>new r.Selection]})))},\n", " function _(i,e,s,t,n){var l;t();const c=i(53),d=i(9),h=i(13);class _ extends c.Model{constructor(i){super(i)}get_view(){return this.view}get selected_glyph(){return this.selected_glyphs.length>0?this.selected_glyphs[0]:null}add_to_selected_glyphs(i){this.selected_glyphs.push(i)}update(i,e=!0,s=\"replace\"){switch(s){case\"replace\":this.indices=i.indices,this.line_indices=i.line_indices,this.multiline_indices=i.multiline_indices,this.image_indices=i.image_indices,this.view=i.view,this.selected_glyphs=i.selected_glyphs;break;case\"append\":this.update_through_union(i);break;case\"intersect\":this.update_through_intersection(i);break;case\"subtract\":this.update_through_subtraction(i)}}clear(){this.indices=[],this.line_indices=[],this.multiline_indices={},this.image_indices=[],this.view=null,this.selected_glyphs=[]}map(i){return new _(Object.assign(Object.assign({},this.attributes),{indices:this.indices.map(i),multiline_indices:(0,h.to_object)((0,h.entries)(this.multiline_indices).map((([e,s])=>[i(Number(e)),s]))),image_indices:this.image_indices.map((e=>Object.assign(Object.assign({},e),{index:i(e.index)})))}))}is_empty(){return 0==this.indices.length&&0==this.line_indices.length&&0==this.image_indices.length}update_through_union(i){this.indices=(0,d.union)(this.indices,i.indices),this.selected_glyphs=(0,d.union)(i.selected_glyphs,this.selected_glyphs),this.line_indices=(0,d.union)(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=(0,h.merge)(i.multiline_indices,this.multiline_indices)}update_through_intersection(i){this.indices=(0,d.intersection)(this.indices,i.indices),this.selected_glyphs=(0,d.union)(i.selected_glyphs,this.selected_glyphs),this.line_indices=(0,d.union)(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=(0,h.merge)(i.multiline_indices,this.multiline_indices)}update_through_subtraction(i){this.indices=(0,d.difference)(this.indices,i.indices),this.selected_glyphs=(0,d.union)(i.selected_glyphs,this.selected_glyphs),this.line_indices=(0,d.union)(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=(0,h.merge)(i.multiline_indices,this.multiline_indices)}}s.Selection=_,l=_,_.__name__=\"Selection\",l.define((({Int:i,Array:e,Dict:s})=>({indices:[e(i),[]],line_indices:[e(i),[]],multiline_indices:[s(e(i)),{}]}))),l.internal((({Int:i,Array:e,AnyRef:s,Struct:t,Nullable:n})=>({selected_glyphs:[e(s()),[]],view:[n(s()),null],image_indices:[e(t({index:i,dim1:i,dim2:i,flat_index:i})),[]]})))},\n", " function _(e,t,o,s,c){s();const n=e(72);function i(e){return\"GlyphRenderer\"==e.model.type}function l(e){return\"GraphRenderer\"==e.model.type}class r{constructor(e){this.source=e,this.inspectors=new Map}select(e,t,o,s=\"replace\"){const c=[],n=[];for(const t of e)i(t)?c.push(t):l(t)&&n.push(t);let r=!1;for(const e of n){const c=e.model.selection_policy.hit_test(t,e);r=r||e.model.selection_policy.do_selection(c,e.model,o,s)}if(c.length>0){const e=this.source.selection_policy.hit_test(t,c);r=r||this.source.selection_policy.do_selection(e,this.source,o,s)}return r}inspect(e,t){let o=!1;if(i(e)){const s=e.hit_test(t);if(null!=s){o=!s.is_empty();const c=this.get_or_create_inspector(e.model);c.update(s,!0,\"replace\"),this.source.setv({inspected:c},{silent:!0}),this.source.inspect.emit([e.model,{geometry:t}])}}else if(l(e)){const s=e.model.inspection_policy.hit_test(t,e);o=o||e.model.inspection_policy.do_inspection(s,t,e,!1,\"replace\")}return o}clear(e){this.source.selected.clear(),null!=e&&this.get_or_create_inspector(e.model).clear()}get_or_create_inspector(e){let t=this.inspectors.get(e);return null==t&&(t=new n.Selection,this.inspectors.set(e,t)),t}}o.SelectionManager=r,r.__name__=\"SelectionManager\"},\n", " function _(e,t,n,s,o){s();const r=e(53);class c extends r.Model{do_selection(e,t,n,s){return null!=e&&(t.selected.update(e,n,s),t._select.emit(),!t.selected.is_empty())}}n.SelectionPolicy=c,c.__name__=\"SelectionPolicy\";class l extends c{hit_test(e,t){const n=[];for(const s of t){const t=s.hit_test(e);null!=t&&n.push(t)}if(n.length>0){const e=n[0];for(const t of n)e.update_through_intersection(t);return e}return null}}n.IntersectRenderers=l,l.__name__=\"IntersectRenderers\";class _ extends c{hit_test(e,t){const n=[];for(const s of t){const t=s.hit_test(e);null!=t&&n.push(t)}if(n.length>0){const e=n[0];for(const t of n)e.update_through_union(t);return e}return null}}n.UnionRenderers=_,_.__name__=\"UnionRenderers\"},\n", " function _(t,n,e,s,o){s();const r=t(1);var l;const c=t(70),i=t(8),a=t(13),u=(0,r.__importStar)(t(76)),h=t(77),d=t(35);function f(t,n,e){if((0,i.isArray)(t)){const s=t.concat(n);return null!=e&&s.length>e?s.slice(-e):s}if((0,i.isTypedArray)(t)){const s=t.length+n.length;if(null!=e&&s>e){const o=s-e,r=t.length;let l;t.length({data:[t(n),{}]})))},\n", " function _(t,n,o,e,c){e(),o.concat=function(t,...n){let o=t.length;for(const t of n)o+=t.length;const e=new t.constructor(o);e.set(t,0);let c=t.length;for(const t of n)e.set(t,c),c+=t.length;return e}},\n", " function _(n,o,t,e,f){function c(...n){const o=new Set;for(const t of n)for(const n of t)o.add(n);return o}e(),t.union=c,t.intersection=function(n,...o){const t=new Set;n:for(const e of n){for(const n of o)if(!n.has(e))continue n;t.add(e)}return t},t.difference=function(n,...o){const t=new Set(n);for(const n of c(...o))t.delete(n);return t}},\n", " function _(n,t,e,o,r){o();const c=n(1),l=(0,c.__importDefault)(n(79)),i=(0,c.__importDefault)(n(80)),u=n(24),a=new i.default(\"GOOGLE\"),s=new i.default(\"WGS84\"),f=(0,l.default)(s,a);e.wgs84_mercator={compute:(n,t)=>isFinite(n)&&isFinite(t)?f.forward([n,t]):[NaN,NaN],invert:(n,t)=>isFinite(n)&&isFinite(t)?f.inverse([n,t]):[NaN,NaN]};const _={lon:[-20026376.39,20026376.39],lat:[-20048966.1,20048966.1]},p={lon:[-180,180],lat:[-85.06,85.06]},{min:g,max:h}=Math;function m(n,t){const o=g(n.length,t.length),r=(0,u.infer_type)(n,t),c=new r(o),l=new r(o);return e.inplace.project_xy(n,t,c,l),[c,l]}e.clip_mercator=function(n,t,e){const[o,r]=_[e];return[h(n,o),g(t,r)]},e.in_bounds=function(n,t){const[e,o]=p[t];return e2?void 0!==e.name&&\"geocent\"===e.name||void 0!==n.name&&\"geocent\"===n.name?\"number\"==typeof o.z?[o.x,o.y,o.z].concat(t.splice(3)):[o.x,o.y,t[2]].concat(t.splice(3)):[o.x,o.y].concat(t.splice(2)):[o.x,o.y]):(a=(0,c.default)(e,n,t,r),2===(i=Object.keys(t)).length||i.forEach((function(r){if(void 0!==e.name&&\"geocent\"===e.name||void 0!==n.name&&\"geocent\"===n.name){if(\"x\"===r||\"y\"===r||\"z\"===r)return}else if(\"x\"===r||\"y\"===r)return;a[r]=t[r]})),a)}function l(e){return e instanceof i.default?e:e.oProj?e.oProj:(0,i.default)(e)}t.default=function(e,n,t){e=l(e);var r,o=!1;return void 0===n?(n=e,e=u,o=!0):(void 0!==n.x||Array.isArray(n))&&(t=n,n=e,e=u,o=!0),n=l(n),t?f(e,n,t):(r={forward:function(t,r){return f(e,n,t,r)},inverse:function(t,r){return f(n,e,t,r)}},o&&(r.oProj=n),r)}},\n", " function _(t,e,a,s,i){s();const l=t(1),u=(0,l.__importDefault)(t(81)),r=(0,l.__importDefault)(t(92)),d=(0,l.__importDefault)(t(93)),o=t(101),f=(0,l.__importDefault)(t(103)),p=(0,l.__importDefault)(t(104)),m=(0,l.__importDefault)(t(88)),n=t(105);function h(t,e){if(!(this instanceof h))return new h(t);e=e||function(t){if(t)throw t};var a=(0,u.default)(t);if(\"object\"==typeof a){var s=h.projections.get(a.projName);if(s){if(a.datumCode&&\"none\"!==a.datumCode){var i=(0,m.default)(f.default,a.datumCode);i&&(a.datum_params=a.datum_params||(i.towgs84?i.towgs84.split(\",\"):null),a.ellps=i.ellipse,a.datumName=i.datumName?i.datumName:a.datumCode)}a.k0=a.k0||1,a.axis=a.axis||\"enu\",a.ellps=a.ellps||\"wgs84\",a.lat1=a.lat1||a.lat0;var l=(0,o.sphere)(a.a,a.b,a.rf,a.ellps,a.sphere),d=(0,o.eccentricity)(l.a,l.b,l.rf,a.R_A),_=(0,n.getNadgrids)(a.nadgrids),c=a.datum||(0,p.default)(a.datumCode,a.datum_params,l.a,l.b,d.es,d.ep2,_);(0,r.default)(this,a),(0,r.default)(this,s),this.a=l.a,this.b=l.b,this.rf=l.rf,this.sphere=l.sphere,this.es=d.es,this.e=d.e,this.ep2=d.ep2,this.datum=c,this.init(),e(null,this)}else e(t)}else e(t)}h.projections=d.default,h.projections.start(),a.default=h},\n", " function _(t,r,n,u,e){u();const f=t(1),i=(0,f.__importDefault)(t(82)),a=(0,f.__importDefault)(t(89)),o=(0,f.__importDefault)(t(84)),l=(0,f.__importDefault)(t(88));var C=[\"PROJECTEDCRS\",\"PROJCRS\",\"GEOGCS\",\"GEOCCS\",\"PROJCS\",\"LOCAL_CS\",\"GEODCRS\",\"GEODETICCRS\",\"GEODETICDATUM\",\"ENGCRS\",\"ENGINEERINGCRS\"];var d=[\"3857\",\"900913\",\"3785\",\"102113\"];n.default=function(t){if(!function(t){return\"string\"==typeof t}(t))return t;if(function(t){return t in i.default}(t))return i.default[t];if(function(t){return C.some((function(r){return t.indexOf(r)>-1}))}(t)){var r=(0,a.default)(t);if(function(t){var r=(0,l.default)(t,\"authority\");if(r){var n=(0,l.default)(r,\"epsg\");return n&&d.indexOf(n)>-1}}(r))return i.default[\"EPSG:3857\"];var n=function(t){var r=(0,l.default)(t,\"extension\");if(r)return(0,l.default)(r,\"proj4\")}(r);return n?(0,o.default)(n):r}return function(t){return\"+\"===t[0]}(t)?(0,o.default)(t):void 0}},\n", " function _(t,r,i,e,n){e();const f=t(1),a=(0,f.__importDefault)(t(83)),l=(0,f.__importDefault)(t(84)),u=(0,f.__importDefault)(t(89));function o(t){var r=this;if(2===arguments.length){var i=arguments[1];\"string\"==typeof i?\"+\"===i.charAt(0)?o[t]=(0,l.default)(arguments[1]):o[t]=(0,u.default)(arguments[1]):o[t]=i}else if(1===arguments.length){if(Array.isArray(t))return t.map((function(t){Array.isArray(t)?o.apply(r,t):o(t)}));if(\"string\"==typeof t){if(t in o)return o[t]}else\"EPSG\"in t?o[\"EPSG:\"+t.EPSG]=t:\"ESRI\"in t?o[\"ESRI:\"+t.ESRI]=t:\"IAU2000\"in t?o[\"IAU2000:\"+t.IAU2000]=t:console.log(t);return}}(0,a.default)(o),i.default=o},\n", " function _(t,l,G,S,e){S(),G.default=function(t){t(\"EPSG:4326\",\"+title=WGS 84 (long/lat) +proj=longlat +ellps=WGS84 +datum=WGS84 +units=degrees\"),t(\"EPSG:4269\",\"+title=NAD83 (long/lat) +proj=longlat +a=6378137.0 +b=6356752.31414036 +ellps=GRS80 +datum=NAD83 +units=degrees\"),t(\"EPSG:3857\",\"+title=WGS 84 / Pseudo-Mercator +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs\"),t.WGS84=t[\"EPSG:4326\"],t[\"EPSG:3785\"]=t[\"EPSG:3857\"],t.GOOGLE=t[\"EPSG:3857\"],t[\"EPSG:900913\"]=t[\"EPSG:3857\"],t[\"EPSG:102113\"]=t[\"EPSG:3857\"]}},\n", " function _(t,n,o,a,u){a();const e=t(1),r=t(85),i=(0,e.__importDefault)(t(86)),f=(0,e.__importDefault)(t(87)),l=(0,e.__importDefault)(t(88));o.default=function(t){var n,o,a,u={},e=t.split(\"+\").map((function(t){return t.trim()})).filter((function(t){return t})).reduce((function(t,n){var o=n.split(\"=\");return o.push(!0),t[o[0].toLowerCase()]=o[1],t}),{}),c={proj:\"projName\",datum:\"datumCode\",rf:function(t){u.rf=parseFloat(t)},lat_0:function(t){u.lat0=t*r.D2R},lat_1:function(t){u.lat1=t*r.D2R},lat_2:function(t){u.lat2=t*r.D2R},lat_ts:function(t){u.lat_ts=t*r.D2R},lon_0:function(t){u.long0=t*r.D2R},lon_1:function(t){u.long1=t*r.D2R},lon_2:function(t){u.long2=t*r.D2R},alpha:function(t){u.alpha=parseFloat(t)*r.D2R},gamma:function(t){u.rectified_grid_angle=parseFloat(t)},lonc:function(t){u.longc=t*r.D2R},x_0:function(t){u.x0=parseFloat(t)},y_0:function(t){u.y0=parseFloat(t)},k_0:function(t){u.k0=parseFloat(t)},k:function(t){u.k0=parseFloat(t)},a:function(t){u.a=parseFloat(t)},b:function(t){u.b=parseFloat(t)},r_a:function(){u.R_A=!0},zone:function(t){u.zone=parseInt(t,10)},south:function(){u.utmSouth=!0},towgs84:function(t){u.datum_params=t.split(\",\").map((function(t){return parseFloat(t)}))},to_meter:function(t){u.to_meter=parseFloat(t)},units:function(t){u.units=t;var n=(0,l.default)(f.default,t);n&&(u.to_meter=n.to_meter)},from_greenwich:function(t){u.from_greenwich=t*r.D2R},pm:function(t){var n=(0,l.default)(i.default,t);u.from_greenwich=(n||parseFloat(t))*r.D2R},nadgrids:function(t){\"@null\"===t?u.datumCode=\"none\":u.nadgrids=t},axis:function(t){var n=\"ewnsud\";3===t.length&&-1!==n.indexOf(t.substr(0,1))&&-1!==n.indexOf(t.substr(1,1))&&-1!==n.indexOf(t.substr(2,1))&&(u.axis=t)},approx:function(){u.approx=!0}};for(n in e)o=e[n],n in c?\"function\"==typeof(a=c[n])?a(o):u[a]=o:u[n]=o;return\"string\"==typeof u.datumCode&&\"WGS84\"!==u.datumCode&&(u.datumCode=u.datumCode.toLowerCase()),u}},\n", " function _(S,_,P,R,I){R(),P.PJD_3PARAM=1,P.PJD_7PARAM=2,P.PJD_GRIDSHIFT=3,P.PJD_WGS84=4,P.PJD_NODATUM=5,P.SRS_WGS84_SEMIMAJOR=6378137,P.SRS_WGS84_SEMIMINOR=6356752.314,P.SRS_WGS84_ESQUARED=.0066943799901413165,P.SEC_TO_RAD=484813681109536e-20,P.HALF_PI=Math.PI/2,P.SIXTH=.16666666666666666,P.RA4=.04722222222222222,P.RA6=.022156084656084655,P.EPSLN=1e-10,P.D2R=.017453292519943295,P.R2D=57.29577951308232,P.FORTPI=Math.PI/4,P.TWO_PI=2*Math.PI,P.SPI=3.14159265359},\n", " function _(o,r,a,e,s){e();var n={};a.default=n,n.greenwich=0,n.lisbon=-9.131906111111,n.paris=2.337229166667,n.bogota=-74.080916666667,n.madrid=-3.687938888889,n.rome=12.452333333333,n.bern=7.439583333333,n.jakarta=106.807719444444,n.ferro=-17.666666666667,n.brussels=4.367975,n.stockholm=18.058277777778,n.athens=23.7163375,n.oslo=10.722916666667},\n", " function _(t,e,f,o,u){o(),f.default={ft:{to_meter:.3048},\"us-ft\":{to_meter:1200/3937}}},\n", " function _(e,r,t,a,n){a();var o=/[\\s_\\-\\/\\(\\)]/g;t.default=function(e,r){if(e[r])return e[r];for(var t,a=Object.keys(e),n=r.toLowerCase().replace(o,\"\"),f=-1;++f0?90:-90),e.lat_ts=e.lat1)}(n),n}},\n", " function _(t,e,r,i,s){i(),r.default=function(t){return new d(t).output()};var h=/\\s/,o=/[A-Za-z]/,n=/[A-Za-z84]/,a=/[,\\]]/,u=/[\\d\\.E\\-\\+]/;function d(t){if(\"string\"!=typeof t)throw new Error(\"not a string\");this.text=t.trim(),this.level=0,this.place=0,this.root=null,this.stack=[],this.currentObject=null,this.state=1}d.prototype.readCharicter=function(){var t=this.text[this.place++];if(4!==this.state)for(;h.test(t);){if(this.place>=this.text.length)return;t=this.text[this.place++]}switch(this.state){case 1:return this.neutral(t);case 2:return this.keyword(t);case 4:return this.quoted(t);case 5:return this.afterquote(t);case 3:return this.number(t);case-1:return}},d.prototype.afterquote=function(t){if('\"'===t)return this.word+='\"',void(this.state=4);if(a.test(t))return this.word=this.word.trim(),void this.afterItem(t);throw new Error(\"havn't handled \\\"\"+t+'\" in afterquote yet, index '+this.place)},d.prototype.afterItem=function(t){return\",\"===t?(null!==this.word&&this.currentObject.push(this.word),this.word=null,void(this.state=1)):\"]\"===t?(this.level--,null!==this.word&&(this.currentObject.push(this.word),this.word=null),this.state=1,this.currentObject=this.stack.pop(),void(this.currentObject||(this.state=-1))):void 0},d.prototype.number=function(t){if(!u.test(t)){if(a.test(t))return this.word=parseFloat(this.word),void this.afterItem(t);throw new Error(\"havn't handled \\\"\"+t+'\" in number yet, index '+this.place)}this.word+=t},d.prototype.quoted=function(t){'\"'!==t?this.word+=t:this.state=5},d.prototype.keyword=function(t){if(n.test(t))this.word+=t;else{if(\"[\"===t){var e=[];return e.push(this.word),this.level++,null===this.root?this.root=e:this.currentObject.push(e),this.stack.push(this.currentObject),this.currentObject=e,void(this.state=1)}if(!a.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in keyword yet, index '+this.place);this.afterItem(t)}},d.prototype.neutral=function(t){if(o.test(t))return this.word=t,void(this.state=2);if('\"'===t)return this.word=\"\",void(this.state=4);if(u.test(t))return this.word=t,void(this.state=3);if(!a.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in neutral yet, index '+this.place);this.afterItem(t)},d.prototype.output=function(){for(;this.place90&&a*o.R2D<-90&&h*o.R2D>180&&h*o.R2D<-180)return null;if(Math.abs(Math.abs(a)-o.HALF_PI)<=o.EPSLN)return null;if(this.sphere)i=this.x0+this.a*this.k0*(0,n.default)(h-this.long0),s=this.y0+this.a*this.k0*Math.log(Math.tan(o.FORTPI+.5*a));else{var e=Math.sin(a),r=(0,l.default)(this.e,a,e);i=this.x0+this.a*this.k0*(0,n.default)(h-this.long0),s=this.y0-this.a*this.k0*Math.log(r)}return t.x=i,t.y=s,t}function M(t){var i,s,h=t.x-this.x0,a=t.y-this.y0;if(this.sphere)s=o.HALF_PI-2*Math.atan(Math.exp(-a/(this.a*this.k0)));else{var e=Math.exp(-a/(this.a*this.k0));if(-9999===(s=(0,u.default)(this.e,e)))return null}return i=(0,n.default)(this.long0+h/(this.a*this.k0)),t.x=i,t.y=s,t}s.init=f,s.forward=_,s.inverse=M,s.names=[\"Mercator\",\"Popular Visualisation Pseudo Mercator\",\"Mercator_1SP\",\"Mercator_Auxiliary_Sphere\",\"merc\"],s.default={init:f,forward:_,inverse:M,names:s.names}},\n", " function _(t,n,r,u,a){u(),r.default=function(t,n,r){var u=t*n;return r/Math.sqrt(1-u*u)}},\n", " function _(t,n,u,a,f){a();const e=t(1),o=t(85),_=(0,e.__importDefault)(t(97));u.default=function(t){return Math.abs(t)<=o.SPI?t:t-(0,_.default)(t)*o.TWO_PI}},\n", " function _(n,t,u,f,c){f(),u.default=function(n){return n<0?-1:1}},\n", " function _(t,n,a,o,u){o();const c=t(85);a.default=function(t,n,a){var o=t*a,u=.5*t;return o=Math.pow((1-o)/(1+o),u),Math.tan(.5*(c.HALF_PI-n))/o}},\n", " function _(t,a,n,r,f){r();const h=t(85);n.default=function(t,a){for(var n,r,f=.5*t,o=h.HALF_PI-2*Math.atan(a),u=0;u<=15;u++)if(n=t*Math.sin(o),o+=r=h.HALF_PI-2*Math.atan(a*Math.pow((1-n)/(1+n),f))-o,Math.abs(r)<=1e-10)return o;return-9999}},\n", " function _(n,i,e,t,r){function a(){}function f(n){return n}t(),e.init=a,e.forward=f,e.inverse=f,e.names=[\"longlat\",\"identity\"],e.default={init:a,forward:f,inverse:f,names:e.names}},\n", " function _(t,r,e,a,n){a();const f=t(1),i=t(85),u=(0,f.__importStar)(t(102)),c=(0,f.__importDefault)(t(88));e.eccentricity=function(t,r,e,a){var n=t*t,f=r*r,u=(n-f)/n,c=0;return a?(n=(t*=1-u*(i.SIXTH+u*(i.RA4+u*i.RA6)))*t,u=0):c=Math.sqrt(u),{es:u,e:c,ep2:(n-f)/f}},e.sphere=function(t,r,e,a,n){if(!t){var f=(0,c.default)(u.default,a);f||(f=u.WGS84),t=f.a,r=f.b,e=f.rf}return e&&!r&&(r=(1-1/e)*t),(0===e||Math.abs(t-r)3&&(0===s.datum_params[3]&&0===s.datum_params[4]&&0===s.datum_params[5]&&0===s.datum_params[6]||(s.datum_type=d.PJD_7PARAM,s.datum_params[3]*=d.SEC_TO_RAD,s.datum_params[4]*=d.SEC_TO_RAD,s.datum_params[5]*=d.SEC_TO_RAD,s.datum_params[6]=s.datum_params[6]/1e6+1))),r&&(s.datum_type=d.PJD_GRIDSHIFT,s.grids=r),s.a=_,s.b=t,s.es=u,s.ep2=p,s}},\n", " function _(t,e,n,r,i){r();var u={};function l(t){if(0===t.length)return null;var e=\"@\"===t[0];return e&&(t=t.slice(1)),\"null\"===t?{name:\"null\",mandatory:!e,grid:null,isNull:!0}:{name:t,mandatory:!e,grid:u[t]||null,isNull:!1}}function o(t){return t/3600*Math.PI/180}function a(t,e,n){return String.fromCharCode.apply(null,new Uint8Array(t.buffer.slice(e,n)))}function d(t){return t.map((function(t){return[o(t.longitudeShift),o(t.latitudeShift)]}))}function g(t,e,n){return{name:a(t,e+8,e+16).trim(),parent:a(t,e+24,e+24+8).trim(),lowerLatitude:t.getFloat64(e+72,n),upperLatitude:t.getFloat64(e+88,n),lowerLongitude:t.getFloat64(e+104,n),upperLongitude:t.getFloat64(e+120,n),latitudeInterval:t.getFloat64(e+136,n),longitudeInterval:t.getFloat64(e+152,n),gridNodeCount:t.getInt32(e+168,n)}}function s(t,e,n,r){for(var i=e+176,u=[],l=0;l1&&console.log(\"Only single NTv2 subgrids are currently supported, subsequent sub grids are ignored\");var l=function(t,e,n){for(var r=176,i=[],u=0;ua.y||f>a.x||N1e-12&&Math.abs(n.y)>1e-12);if(d<0)return console.log(\"Inverse grid shift iterator failed to converge.\"),a;a.x=(0,u.default)(l.x+t.ll[0]),a.y=l.y+t.ll[1]}else isNaN(l.x)||(a.x=r.x+l.x,a.y=r.y+l.y);return a}function f(r,e){var t,a={x:r.x/e.del[0],y:r.y/e.del[1]},i=Math.floor(a.x),l=Math.floor(a.y),n=a.x-1*i,o=a.y-1*l,u={x:Number.NaN,y:Number.NaN};if(i<0||i>=e.lim[0])return u;if(l<0||l>=e.lim[1])return u;t=l*e.lim[0]+i;var d=e.cvs[t][0],s=e.cvs[t][1];t++;var y=e.cvs[t][0],f=e.cvs[t][1];t+=e.lim[0];var x=e.cvs[t][0],m=e.cvs[t][1];t--;var N=e.cvs[t][0],c=e.cvs[t][1],_=n*o,g=n*(1-o),v=(1-n)*(1-o),S=(1-n)*o;return u.x=v*d+g*y+S*N+_*x,u.y=v*s+g*f+S*c+_*m,u}t.default=function(r,e,t){if((0,o.compareDatums)(r,e))return t;if(r.datum_type===n.PJD_NODATUM||e.datum_type===n.PJD_NODATUM)return t;var a=r.a,i=r.es;if(r.datum_type===n.PJD_GRIDSHIFT){if(0!==s(r,!1,t))return;a=n.SRS_WGS84_SEMIMAJOR,i=n.SRS_WGS84_ESQUARED}var l=e.a,u=e.b,y=e.es;if(e.datum_type===n.PJD_GRIDSHIFT&&(l=n.SRS_WGS84_SEMIMAJOR,u=n.SRS_WGS84_SEMIMINOR,y=n.SRS_WGS84_ESQUARED),i===y&&a===l&&!d(r.datum_type)&&!d(e.datum_type))return t;if(t=(0,o.geodeticToGeocentric)(t,i,a),d(r.datum_type)&&(t=(0,o.geocentricToWgs84)(t,r.datum_type,r.datum_params)),d(e.datum_type)&&(t=(0,o.geocentricFromWgs84)(t,e.datum_type,e.datum_params)),t=(0,o.geocentricToGeodetic)(t,y,l,u),e.datum_type===n.PJD_GRIDSHIFT&&0!==s(e,!0,t))return;return t},t.applyGridShift=s},\n", " function _(a,t,r,m,s){m();const u=a(85);r.compareDatums=function(a,t){return a.datum_type===t.datum_type&&(!(a.a!==t.a||Math.abs(a.es-t.es)>5e-11)&&(a.datum_type===u.PJD_3PARAM?a.datum_params[0]===t.datum_params[0]&&a.datum_params[1]===t.datum_params[1]&&a.datum_params[2]===t.datum_params[2]:a.datum_type!==u.PJD_7PARAM||a.datum_params[0]===t.datum_params[0]&&a.datum_params[1]===t.datum_params[1]&&a.datum_params[2]===t.datum_params[2]&&a.datum_params[3]===t.datum_params[3]&&a.datum_params[4]===t.datum_params[4]&&a.datum_params[5]===t.datum_params[5]&&a.datum_params[6]===t.datum_params[6]))},r.geodeticToGeocentric=function(a,t,r){var m,s,_,e,n=a.x,d=a.y,i=a.z?a.z:0;if(d<-u.HALF_PI&&d>-1.001*u.HALF_PI)d=-u.HALF_PI;else if(d>u.HALF_PI&&d<1.001*u.HALF_PI)d=u.HALF_PI;else{if(d<-u.HALF_PI)return{x:-1/0,y:-1/0,z:a.z};if(d>u.HALF_PI)return{x:1/0,y:1/0,z:a.z}}return n>Math.PI&&(n-=2*Math.PI),s=Math.sin(d),e=Math.cos(d),_=s*s,{x:((m=r/Math.sqrt(1-t*_))+i)*e*Math.cos(n),y:(m+i)*e*Math.sin(n),z:(m*(1-t)+i)*s}},r.geocentricToGeodetic=function(a,t,r,m){var s,_,e,n,d,i,p,P,y,z,M,o,A,c,x,h=1e-12,f=a.x,I=a.y,F=a.z?a.z:0;if(s=Math.sqrt(f*f+I*I),_=Math.sqrt(f*f+I*I+F*F),s/r1e-24&&A<30);return{x:c,y:Math.atan(M/Math.abs(z)),z:x}},r.geocentricToWgs84=function(a,t,r){if(t===u.PJD_3PARAM)return{x:a.x+r[0],y:a.y+r[1],z:a.z+r[2]};if(t===u.PJD_7PARAM){var m=r[0],s=r[1],_=r[2],e=r[3],n=r[4],d=r[5],i=r[6];return{x:i*(a.x-d*a.y+n*a.z)+m,y:i*(d*a.x+a.y-e*a.z)+s,z:i*(-n*a.x+e*a.y+a.z)+_}}},r.geocentricFromWgs84=function(a,t,r){if(t===u.PJD_3PARAM)return{x:a.x-r[0],y:a.y-r[1],z:a.z-r[2]};if(t===u.PJD_7PARAM){var m=r[0],s=r[1],_=r[2],e=r[3],n=r[4],d=r[5],i=r[6],p=(a.x-m)/i,P=(a.y-s)/i,y=(a.z-_)/i;return{x:p+d*P-n*y,y:-d*p+P+e*y,z:n*p-e*P+y}}}},\n", " function _(e,a,i,r,s){r(),i.default=function(e,a,i){var r,s,n,c=i.x,d=i.y,f=i.z||0,u={};for(n=0;n<3;n++)if(!a||2!==n||void 0!==i.z)switch(0===n?(r=c,s=-1!==\"ew\".indexOf(e.axis[n])?\"x\":\"y\"):1===n?(r=d,s=-1!==\"ns\".indexOf(e.axis[n])?\"y\":\"x\"):(r=f,s=\"z\"),e.axis[n]){case\"e\":u[s]=r;break;case\"w\":u[s]=-r;break;case\"n\":u[s]=r;break;case\"s\":u[s]=-r;break;case\"u\":void 0!==i[s]&&(u.z=r);break;case\"d\":void 0!==i[s]&&(u.z=-r);break;default:return null}return u}},\n", " function _(n,t,e,u,f){u(),e.default=function(n){var t={x:n[0],y:n[1]};return n.length>2&&(t.z=n[2]),n.length>3&&(t.m=n[3]),t}},\n", " function _(e,i,n,t,r){function o(e){if(\"function\"==typeof Number.isFinite){if(Number.isFinite(e))return;throw new TypeError(\"coordinates must be finite numbers\")}if(\"number\"!=typeof e||e!=e||!isFinite(e))throw new TypeError(\"coordinates must be finite numbers\")}t(),n.default=function(e){o(e.x),o(e.y)}},\n", " function _(e,i,s,t,o){t();const n=e(1);var l,a,r,_,c;const d=e(53),v=e(42),u=(0,n.__importStar)(e(45)),h=e(48),m=(0,n.__importStar)(e(18));class T extends v.View{initialize(){super.initialize(),this.visuals=new u.Visuals(this)}request_render(){this.parent.request_render()}get canvas(){return this.parent.canvas}set_data(e){const i=this;for(const s of this.model){if(!(s instanceof m.VectorSpec||s instanceof m.ScalarSpec))continue;const t=s.uniform(e);i[`${s.attr}`]=t}}}s.ArrowHeadView=T,T.__name__=\"ArrowHeadView\";class p extends d.Model{constructor(e){super(e)}}s.ArrowHead=p,l=p,p.__name__=\"ArrowHead\",l.define((()=>({size:[m.NumberSpec,25]})));class V extends T{clip(e,i){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.moveTo(.5*s,s),e.lineTo(.5*s,-2),e.lineTo(-.5*s,-2),e.lineTo(-.5*s,s),e.lineTo(0,0),e.lineTo(.5*s,s)}render(e,i){if(this.visuals.line.doit){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,s),e.lineTo(0,0),e.lineTo(-.5*s,s),e.stroke()}}}s.OpenHeadView=V,V.__name__=\"OpenHeadView\";class f extends p{constructor(e){super(e)}}s.OpenHead=f,a=f,f.__name__=\"OpenHead\",a.prototype.default_view=V,a.mixins(h.LineVector);class w extends T{clip(e,i){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.moveTo(.5*s,s),e.lineTo(.5*s,-2),e.lineTo(-.5*s,-2),e.lineTo(-.5*s,s),e.lineTo(.5*s,s)}render(e,i){this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,i),this._normal(e,i),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,i),this._normal(e,i),e.stroke())}_normal(e,i){const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,s),e.lineTo(0,0),e.lineTo(-.5*s,s),e.closePath()}}s.NormalHeadView=w,w.__name__=\"NormalHeadView\";class H extends p{constructor(e){super(e)}}s.NormalHead=H,r=H,H.__name__=\"NormalHead\",r.prototype.default_view=w,r.mixins([h.LineVector,h.FillVector]),r.override({fill_color:\"black\"});class z extends T{clip(e,i){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.moveTo(.5*s,s),e.lineTo(.5*s,-2),e.lineTo(-.5*s,-2),e.lineTo(-.5*s,s),e.lineTo(0,.5*s),e.lineTo(.5*s,s)}render(e,i){this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,i),this._vee(e,i),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,i),this._vee(e,i),e.stroke())}_vee(e,i){const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,s),e.lineTo(0,0),e.lineTo(-.5*s,s),e.lineTo(0,.5*s),e.closePath()}}s.VeeHeadView=z,z.__name__=\"VeeHeadView\";class x extends p{constructor(e){super(e)}}s.VeeHead=x,_=x,x.__name__=\"VeeHead\",_.prototype.default_view=z,_.mixins([h.LineVector,h.FillVector]),_.override({fill_color:\"black\"});class g extends T{render(e,i){if(this.visuals.line.doit){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,0),e.lineTo(-.5*s,0),e.stroke()}}clip(e,i){}}s.TeeHeadView=g,g.__name__=\"TeeHeadView\";class b extends p{constructor(e){super(e)}}s.TeeHead=b,c=b,b.__name__=\"TeeHead\",c.prototype.default_view=g,c.mixins(h.LineVector)},\n", " function _(n,e,t,i,o){i();const s=n(9);async function c(n,e,t){const i=new n(Object.assign(Object.assign({},t),{model:e}));return i.initialize(),await i.lazy_initialize(),i}t.build_view=async function(n,e={parent:null},t=(n=>n.default_view)){const i=await c(t(n),n,e);return i.connect_signals(),i},t.build_views=async function(n,e,t={parent:null},i=(n=>n.default_view)){const o=(0,s.difference)([...n.keys()],e);for(const e of o)n.get(e).remove(),n.delete(e);const a=[],f=e.filter((e=>!n.has(e)));for(const e of f){const o=await c(i(e),e,t);n.set(e,o),a.push(o)}for(const n of a)n.connect_signals();return a},t.remove_views=function(n){for(const[e,t]of n)t.remove(),n.delete(e)}},\n", " function _(e,s,_,i,l){i();const t=e(1);var o;const r=e(115),p=(0,t.__importStar)(e(48));class h extends r.UpperLowerView{paint(e){e.beginPath(),e.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let s=0,_=this._lower_sx.length;s<_;s++)e.lineTo(this._lower_sx[s],this._lower_sy[s]);for(let s=this._upper_sx.length-1;s>=0;s--)e.lineTo(this._upper_sx[s],this._upper_sy[s]);e.closePath(),this.visuals.fill.apply(e),e.beginPath(),e.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let s=0,_=this._lower_sx.length;s<_;s++)e.lineTo(this._lower_sx[s],this._lower_sy[s]);this.visuals.line.apply(e),e.beginPath(),e.moveTo(this._upper_sx[0],this._upper_sy[0]);for(let s=0,_=this._upper_sx.length;s<_;s++)e.lineTo(this._upper_sx[s],this._upper_sy[s]);this.visuals.line.apply(e)}}_.BandView=h,h.__name__=\"BandView\";class n extends r.UpperLower{constructor(e){super(e)}}_.Band=n,o=n,n.__name__=\"Band\",o.prototype.default_view=h,o.mixins([p.Line,p.Fill]),o.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})},\n", " function _(e,t,i,s,o){s();const r=e(1);var n;const p=e(69),a=e(20),_=(0,r.__importStar)(e(18));class h extends p.DataAnnotationView{map_data(){const{frame:e}=this.plot_view,t=this.model.dimension,i=this.coordinates.x_scale,s=this.coordinates.y_scale,o=\"height\"==t?s:i,r=\"height\"==t?i:s,n=\"height\"==t?e.bbox.yview:e.bbox.xview,p=\"height\"==t?e.bbox.xview:e.bbox.yview;let a,_,h;a=\"data\"==this.model.properties.lower.units?o.v_compute(this._lower):n.v_compute(this._lower),_=\"data\"==this.model.properties.upper.units?o.v_compute(this._upper):n.v_compute(this._upper),h=\"data\"==this.model.properties.base.units?r.v_compute(this._base):p.v_compute(this._base);const[d,c]=\"height\"==t?[1,0]:[0,1],u=[a,h],l=[_,h];this._lower_sx=u[d],this._lower_sy=u[c],this._upper_sx=l[d],this._upper_sy=l[c]}}i.UpperLowerView=h,h.__name__=\"UpperLowerView\";class d extends _.CoordinateSpec{get dimension(){return\"width\"==this.obj.dimension?\"x\":\"y\"}get units(){var e;return null!==(e=this.spec.units)&&void 0!==e?e:\"data\"}}i.XOrYCoordinateSpec=d,d.__name__=\"XOrYCoordinateSpec\";class c extends p.DataAnnotation{constructor(e){super(e)}}i.UpperLower=c,n=c,c.__name__=\"UpperLower\",n.define((()=>({dimension:[a.Dimension,\"height\"],lower:[d,{field:\"lower\"}],upper:[d,{field:\"upper\"}],base:[d,{field:\"base\"}]})))},\n", " function _(t,o,i,n,e){n();const s=t(1);var l;const r=t(40),a=(0,s.__importStar)(t(48)),c=t(20),h=t(65);i.EDGE_TOLERANCE=2.5;class b extends r.AnnotationView{constructor(){super(...arguments),this.bbox=new h.BBox}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{left:t,right:o,top:i,bottom:n}=this.model;if(null==t&&null==o&&null==i&&null==n)return;const{frame:e}=this.plot_view,s=this.coordinates.x_scale,l=this.coordinates.y_scale,r=(t,o,i,n,e)=>{let s;return s=null!=t?this.model.screen?t:\"data\"==o?i.compute(t):n.compute(t):e,s};this.bbox=h.BBox.from_rect({left:r(t,this.model.left_units,s,e.bbox.xview,e.bbox.left),right:r(o,this.model.right_units,s,e.bbox.xview,e.bbox.right),top:r(i,this.model.top_units,l,e.bbox.yview,e.bbox.top),bottom:r(n,this.model.bottom_units,l,e.bbox.yview,e.bbox.bottom)}),this._paint_box()}_paint_box(){const{ctx:t}=this.layer;t.save();const{left:o,top:i,width:n,height:e}=this.bbox;t.beginPath(),t.rect(o,i,n,e),this.visuals.fill.apply(t),this.visuals.hatch.apply(t),this.visuals.line.apply(t),t.restore()}interactive_bbox(){const t=this.model.line_width+i.EDGE_TOLERANCE;return this.bbox.grow_by(t)}interactive_hit(t,o){if(null==this.model.in_cursor)return!1;return this.interactive_bbox().contains(t,o)}cursor(t,o){const{left:i,right:n,bottom:e,top:s}=this.bbox;return Math.abs(t-i)<3||Math.abs(t-n)<3?this.model.ew_cursor:Math.abs(o-e)<3||Math.abs(o-s)<3?this.model.ns_cursor:this.bbox.contains(t,o)?this.model.in_cursor:null}}i.BoxAnnotationView=b,b.__name__=\"BoxAnnotationView\";class u extends r.Annotation{constructor(t){super(t)}update({left:t,right:o,top:i,bottom:n}){this.setv({left:t,right:o,top:i,bottom:n,screen:!0})}}i.BoxAnnotation=u,l=u,u.__name__=\"BoxAnnotation\",l.prototype.default_view=b,l.mixins([a.Line,a.Fill,a.Hatch]),l.define((({Number:t,Nullable:o})=>({top:[o(t),null],top_units:[c.SpatialUnits,\"data\"],bottom:[o(t),null],bottom_units:[c.SpatialUnits,\"data\"],left:[o(t),null],left_units:[c.SpatialUnits,\"data\"],right:[o(t),null],right_units:[c.SpatialUnits,\"data\"],render_mode:[c.RenderMode,\"canvas\"]}))),l.internal((({Boolean:t,String:o,Nullable:i})=>({screen:[t,!1],ew_cursor:[i(o),null],ns_cursor:[i(o),null],in_cursor:[i(o),null]}))),l.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})},\n", " function _(t,e,i,o,n){o();const a=t(1);var r;const s=t(40),l=t(118),_=t(126),c=t(127),h=t(130),u=t(168),p=t(131),m=t(192),g=t(132),d=t(173),f=t(172),w=t(196),b=t(204),v=t(206),x=t(133),y=t(20),k=(0,a.__importStar)(t(48)),z=t(9),j=t(207),C=t(208),L=t(211),B=t(123),S=t(11),M=t(113),T=t(65),A=t(8);class O extends s.AnnotationView{get orientation(){return this._orientation}initialize(){super.initialize();const{ticker:t,formatter:e,color_mapper:i}=this.model;this._ticker=\"auto\"!=t?t:(()=>{switch(!0){case i instanceof w.LogColorMapper:return new u.LogTicker;case i instanceof w.ScanningColorMapper:return new u.BinnedTicker({mapper:i});case i instanceof w.CategoricalColorMapper:return new u.CategoricalTicker;default:return new u.BasicTicker}})(),this._formatter=\"auto\"!=e?e:(()=>{switch(!0){case this._ticker instanceof u.LogTicker:return new m.LogTickFormatter;case i instanceof w.CategoricalColorMapper:return new m.CategoricalTickFormatter;default:return new m.BasicTickFormatter}})(),this._major_range=(()=>{if(i instanceof w.CategoricalColorMapper){const{factors:t}=i;return new v.FactorRange({factors:t})}if(i instanceof f.ContinuousColorMapper){const{min:t,max:e}=i.metrics;return new v.Range1d({start:t,end:e})}(0,S.unreachable)()})(),this._major_scale=(()=>{if(i instanceof w.LinearColorMapper)return new b.LinearScale;if(i instanceof w.LogColorMapper)return new b.LogScale;if(i instanceof w.ScanningColorMapper){const{binning:t}=i.metrics;return new b.LinearInterpolationScale({binning:t})}if(i instanceof w.CategoricalColorMapper)return new b.CategoricalScale;(0,S.unreachable)()})(),this._minor_range=new v.Range1d({start:0,end:1}),this._minor_scale=new b.LinearScale;const o=k.attrs_of(this.model,\"major_label_\",k.Text,!0),n=k.attrs_of(this.model,\"major_tick_\",k.Line,!0),a=k.attrs_of(this.model,\"minor_tick_\",k.Line,!0),r=k.attrs_of(this.model,\"title_\",k.Text),s=i instanceof w.CategoricalColorMapper?c.CategoricalAxis:i instanceof w.LogColorMapper?c.LogAxis:c.LinearAxis;this._axis=new s(Object.assign(Object.assign(Object.assign({ticker:this._ticker,formatter:this._formatter,major_tick_in:this.model.major_tick_in,major_tick_out:this.model.major_tick_out,minor_tick_in:this.model.minor_tick_in,minor_tick_out:this.model.minor_tick_out,major_label_standoff:this.model.label_standoff,major_label_overrides:this.model.major_label_overrides,major_label_policy:this.model.major_label_policy,axis_line_color:null},o),n),a));const{title:_}=this.model;_&&(this._title=new l.Title(Object.assign({text:_,standoff:this.model.title_standoff},r)))}async lazy_initialize(){await super.lazy_initialize();const t=this,e={get parent(){return t.parent},get root(){return t.root},get frame(){return t._frame},get canvas_view(){return t.parent.canvas_view},request_layout(){t.parent.request_layout()}};this._axis_view=await(0,M.build_view)(this._axis,{parent:e}),null!=this._title&&(this._title_view=await(0,M.build_view)(this._title,{parent:e}))}remove(){var t;null===(t=this._title_view)||void 0===t||t.remove(),this._axis_view.remove(),super.remove()}connect_signals(){super.connect_signals(),this.connect(this._ticker.change,(()=>this.request_render())),this.connect(this._formatter.change,(()=>this.request_render())),this.connect(this.model.color_mapper.metrics_change,(()=>{const t=this._major_range,e=this._major_scale,{color_mapper:i}=this.model;if(i instanceof f.ContinuousColorMapper&&t instanceof v.Range1d){const{min:e,max:o}=i.metrics;t.setv({start:e,end:o})}if(i instanceof w.ScanningColorMapper&&e instanceof b.LinearInterpolationScale){const{binning:t}=i.metrics;e.binning=t}this._set_canvas_image(),this.plot_view.request_layout()}))}_set_canvas_image(){const{orientation:t}=this,e=(()=>{const{palette:e}=this.model.color_mapper;return\"vertical\"==t?(0,z.reversed)(e):e})(),[i,o]=\"vertical\"==t?[1,e.length]:[e.length,1],n=this._image=document.createElement(\"canvas\");n.width=i,n.height=o;const a=n.getContext(\"2d\"),r=a.getImageData(0,0,i,o),s=new w.LinearColorMapper({palette:e}).rgba_mapper.v_compute((0,z.range)(0,e.length));r.data.set(s),a.putImageData(r,0,0)}update_layout(){const{location:t,width:e,height:i,padding:o,margin:n}=this.model,[a,r]=(()=>{if(!(0,A.isString)(t))return[\"end\",\"start\"];switch(t){case\"top_left\":return[\"start\",\"start\"];case\"top\":case\"top_center\":return[\"start\",\"center\"];case\"top_right\":return[\"start\",\"end\"];case\"bottom_left\":return[\"end\",\"start\"];case\"bottom\":case\"bottom_center\":return[\"end\",\"center\"];case\"bottom_right\":return[\"end\",\"end\"];case\"left\":case\"center_left\":return[\"center\",\"start\"];case\"center\":case\"center_center\":return[\"center\",\"center\"];case\"right\":case\"center_right\":return[\"center\",\"end\"]}})(),s=this._orientation=(()=>{const{orientation:t}=this.model;return\"auto\"==t?null!=this.panel?this.panel.is_horizontal?\"horizontal\":\"vertical\":\"start\"==r||\"end\"==r||\"center\"==r&&\"center\"==a?\"vertical\":\"horizontal\":t})(),l=new C.NodeLayout,c=new C.VStack,h=new C.VStack,u=new C.HStack,p=new C.HStack;l.absolute=!0,c.absolute=!0,h.absolute=!0,u.absolute=!0,p.absolute=!0;const[m,g,d,f]=(()=>\"horizontal\"==s?[this._major_scale,this._minor_scale,this._major_range,this._minor_range]:[this._minor_scale,this._major_scale,this._minor_range,this._major_range])();this._frame=new _.CartesianFrame(m,g,d,f),l.on_resize((t=>this._frame.set_geometry(t)));const w=new L.BorderLayout;this._inner_layout=w,w.absolute=!0,w.center_panel=l,w.top_panel=c,w.bottom_panel=h,w.left_panel=u,w.right_panel=p;const b={left:o,right:o,top:o,bottom:o},v=(()=>{if(null==this.panel){if((0,A.isString)(t))return{left:n,right:n,top:n,bottom:n};{const[e,i]=t;return{left:e,right:n,top:n,bottom:i}}}if(!(0,A.isString)(t)){const[e,i]=t;return w.fixup_geometry=(t,o)=>{const n=t,a=this.layout.bbox,{width:r,height:s}=t;if(t=new T.BBox({left:a.left+e,bottom:a.bottom-i,width:r,height:s}),null!=o){const e=t.left-n.left,i=t.top-n.top,{left:a,top:r,width:s,height:l}=o;o=new T.BBox({left:a+e,top:r+i,width:s,height:l})}return[t,o]},{left:e,right:0,top:0,bottom:i}}w.fixup_geometry=(t,e)=>{const i=t;if(\"horizontal\"==s){const{top:e,width:i,height:o}=t;if(\"end\"==r){const{right:n}=this.layout.bbox;t=new T.BBox({right:n,top:e,width:i,height:o})}else if(\"center\"==r){const{hcenter:n}=this.layout.bbox;t=new T.BBox({hcenter:Math.round(n),top:e,width:i,height:o})}}else{const{left:e,width:i,height:o}=t;if(\"end\"==a){const{bottom:n}=this.layout.bbox;t=new T.BBox({left:e,bottom:n,width:i,height:o})}else if(\"center\"==a){const{vcenter:n}=this.layout.bbox;t=new T.BBox({left:e,vcenter:Math.round(n),width:i,height:o})}}if(null!=e){const o=t.left-i.left,n=t.top-i.top,{left:a,top:r,width:s,height:l}=e;e=new T.BBox({left:a+o,top:r+n,width:s,height:l})}return[t,e]}})();let x,y,k,z;if(w.padding=b,null!=this.panel?(x=\"max\",y=void 0,k=void 0,z=void 0):\"auto\"==(\"horizontal\"==s?e:i)?(x=\"fixed\",y=25*this.model.color_mapper.palette.length,k={percent:.3},z={percent:.8}):(x=\"fit\",y=void 0),\"horizontal\"==s){const t=\"auto\"==e?void 0:e,o=\"auto\"==i?25:i;w.set_sizing({width_policy:x,height_policy:\"min\",width:y,min_width:k,max_width:z,halign:r,valign:a,margin:v}),w.center_panel.set_sizing({width_policy:\"auto\"==e?\"fit\":\"fixed\",height_policy:\"fixed\",width:t,height:o})}else{const t=\"auto\"==e?25:e,o=\"auto\"==i?void 0:i;w.set_sizing({width_policy:\"min\",height_policy:x,height:y,min_height:k,max_height:z,halign:r,valign:a,margin:v}),w.center_panel.set_sizing({width_policy:\"fixed\",height_policy:\"auto\"==i?\"fit\":\"fixed\",width:t,height:o})}c.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),h.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),u.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),p.set_sizing({width_policy:\"min\",height_policy:\"fit\"});const{_title_view:S}=this;null!=S&&(\"horizontal\"==s?(S.panel=new B.Panel(\"above\"),S.update_layout(),c.children.push(S.layout)):(S.panel=new B.Panel(\"left\"),S.update_layout(),u.children.push(S.layout)));const{panel:M}=this,O=null!=M&&s==M.orientation?M.side:\"horizontal\"==s?\"below\":\"right\",R=(()=>{switch(O){case\"above\":return c;case\"below\":return h;case\"left\":return u;case\"right\":return p}})(),{_axis_view:F}=this;if(F.panel=new B.Panel(O),F.update_layout(),R.children.push(F.layout),null!=this.panel){const t=new j.Grid([{layout:w,row:0,col:0}]);t.absolute=!0,\"horizontal\"==s?t.set_sizing({width_policy:\"max\",height_policy:\"min\"}):t.set_sizing({width_policy:\"min\",height_policy:\"max\"}),this.layout=t}else this.layout=this._inner_layout;const{visible:I}=this.model;this.layout.sizing.visible=I,this._set_canvas_image()}_render(){var t;const{ctx:e}=this.layer;e.save(),this._paint_bbox(e,this._inner_layout.bbox),this._paint_image(e,this._inner_layout.center_panel.bbox),null===(t=this._title_view)||void 0===t||t.render(),this._axis_view.render(),e.restore()}_paint_bbox(t,e){const{x:i,y:o}=e;let{width:n,height:a}=e;i+n>=this.parent.canvas_view.bbox.width&&(n-=1),o+a>=this.parent.canvas_view.bbox.height&&(a-=1),t.save(),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(t),t.fillRect(i,o,n,a)),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(t),t.strokeRect(i,o,n,a)),t.restore()}_paint_image(t,e){const{x:i,y:o,width:n,height:a}=e;t.save(),t.setImageSmoothingEnabled(!1),t.globalAlpha=this.model.scale_alpha,t.drawImage(this._image,i,o,n,a),this.visuals.bar_line.doit&&(this.visuals.bar_line.set_value(t),t.strokeRect(i,o,n,a)),t.restore()}serializable_state(){const t=super.serializable_state(),{children:e=[]}=t,i=(0,a.__rest)(t,[\"children\"]);return null!=this._title_view&&e.push(this._title_view.serializable_state()),e.push(this._axis_view.serializable_state()),Object.assign(Object.assign({},i),{children:e})}}i.ColorBarView=O,O.__name__=\"ColorBarView\";class R extends s.Annotation{constructor(t){super(t)}}i.ColorBar=R,r=R,R.__name__=\"ColorBar\",r.prototype.default_view=O,r.mixins([[\"major_label_\",k.Text],[\"title_\",k.Text],[\"major_tick_\",k.Line],[\"minor_tick_\",k.Line],[\"border_\",k.Line],[\"bar_\",k.Line],[\"background_\",k.Fill]]),r.define((({Alpha:t,Number:e,String:i,Tuple:o,Dict:n,Or:a,Ref:r,Auto:s,Nullable:l})=>({location:[a(y.Anchor,o(e,e)),\"top_right\"],orientation:[a(y.Orientation,s),\"auto\"],title:[l(i),null],title_standoff:[e,2],width:[a(e,s),\"auto\"],height:[a(e,s),\"auto\"],scale_alpha:[t,1],ticker:[a(r(h.Ticker),s),\"auto\"],formatter:[a(r(p.TickFormatter),s),\"auto\"],major_label_overrides:[n(a(i,r(x.BaseText))),{}],major_label_policy:[r(g.LabelingPolicy),()=>new g.NoOverlap],color_mapper:[r(d.ColorMapper)],label_standoff:[e,5],margin:[e,30],padding:[e,10],major_tick_in:[e,5],major_tick_out:[e,0],minor_tick_in:[e,0],minor_tick_out:[e,0]}))),r.override({background_fill_color:\"#ffffff\",background_fill_alpha:.95,bar_line_color:null,border_line_color:null,major_label_text_font_size:\"11px\",major_tick_line_color:\"#ffffff\",minor_tick_line_color:null,title_text_font_size:\"13px\",title_text_font_style:\"italic\"})},\n", " function _(t,e,i,s,l){s();const o=t(1);var a;const n=t(119),r=t(20),c=t(120),h=(0,o.__importStar)(t(48));class _ extends n.TextAnnotationView{_get_location(){const t=this.model.offset,e=this.model.standoff/2;let i,s;const{bbox:l}=this.layout;switch(this.panel.side){case\"above\":case\"below\":switch(this.model.vertical_align){case\"top\":s=l.top+e;break;case\"middle\":s=l.vcenter;break;case\"bottom\":s=l.bottom-e}switch(this.model.align){case\"left\":i=l.left+t;break;case\"center\":i=l.hcenter;break;case\"right\":i=l.right-t}break;case\"left\":switch(this.model.vertical_align){case\"top\":i=l.left+e;break;case\"middle\":i=l.hcenter;break;case\"bottom\":i=l.right-e}switch(this.model.align){case\"left\":s=l.bottom-t;break;case\"center\":s=l.vcenter;break;case\"right\":s=l.top+t}break;case\"right\":switch(this.model.vertical_align){case\"top\":i=l.right-e;break;case\"middle\":i=l.hcenter;break;case\"bottom\":i=l.left+e}switch(this.model.align){case\"left\":s=l.top+t;break;case\"center\":s=l.vcenter;break;case\"right\":s=l.bottom-t}}return[i,s]}_render(){const{text:t}=this.model;if(null==t||0==t.length)return;this.model.text_baseline=this.model.vertical_align,this.model.text_align=this.model.align;const[e,i]=this._get_location(),s=this.panel.get_label_angle_heuristic(\"parallel\");(\"canvas\"==this.model.render_mode?this._canvas_text.bind(this):this._css_text.bind(this))(this.layer.ctx,t,e,i,s)}_get_size(){const{text:t}=this.model,e=new c.TextBox({text:t});e.visuals=this.visuals.text.values();const{width:i,height:s}=e.size();return{width:i,height:0==s?0:2+s+this.model.standoff}}}i.TitleView=_,_.__name__=\"TitleView\";class d extends n.TextAnnotation{constructor(t){super(t)}}i.Title=d,a=d,d.__name__=\"Title\",a.prototype.default_view=_,a.mixins([h.Text,[\"border_\",h.Line],[\"background_\",h.Fill]]),a.define((({Number:t,String:e})=>({text:[e,\"\"],vertical_align:[r.VerticalAlign,\"bottom\"],align:[r.TextAlign,\"left\"],offset:[t,0],standoff:[t,10]}))),a.prototype._props.text_align.options.internal=!0,a.prototype._props.text_baseline.options.internal=!0,a.override({text_font_size:\"13px\",text_font_style:\"bold\",text_line_height:1,background_fill_color:null,border_line_color:null})},\n", " function _(e,t,s,i,l){var n;i();const o=e(40),a=e(43),r=e(20),d=e(120),u=e(123),c=e(11);class h extends o.AnnotationView{update_layout(){const{panel:e}=this;this.layout=null!=e?new u.SideLayout(e,(()=>this.get_size()),!0):void 0}initialize(){super.initialize(),\"css\"==this.model.render_mode&&(this.el=(0,a.div)(),this.plot_view.canvas_view.add_overlay(this.el))}remove(){null!=this.el&&(0,a.remove)(this.el),super.remove()}connect_signals(){super.connect_signals(),\"css\"==this.model.render_mode?this.connect(this.model.change,(()=>this.render())):this.connect(this.model.change,(()=>this.request_render()))}render(){this.model.visible||\"css\"!=this.model.render_mode||(0,a.undisplay)(this.el),super.render()}_canvas_text(e,t,s,i,l){const n=new d.TextBox({text:t});n.angle=l,n.position={sx:s,sy:i},n.visuals=this.visuals.text.values();const{background_fill:o,border_line:a}=this.visuals;if(o.doit||a.doit){const{p0:t,p1:s,p2:i,p3:l}=n.rect();e.beginPath(),e.moveTo(t.x,t.y),e.lineTo(s.x,s.y),e.lineTo(i.x,i.y),e.lineTo(l.x,l.y),e.closePath(),this.visuals.background_fill.apply(e),this.visuals.border_line.apply(e)}this.visuals.text.doit&&n.paint(e)}_css_text(e,t,s,i,l){const{el:n}=this;(0,c.assert)(null!=n),(0,a.undisplay)(n),n.textContent=t,this.visuals.text.set_value(e),n.style.position=\"absolute\",n.style.left=`${s}px`,n.style.top=`${i}px`,n.style.color=e.fillStyle,n.style.font=e.font,n.style.lineHeight=\"normal\",n.style.whiteSpace=\"pre\";const[o,r]=(()=>{switch(this.visuals.text.text_align.get_value()){case\"left\":return[\"left\",\"0%\"];case\"center\":return[\"center\",\"-50%\"];case\"right\":return[\"right\",\"-100%\"]}})(),[d,u]=(()=>{switch(this.visuals.text.text_baseline.get_value()){case\"top\":return[\"top\",\"0%\"];case\"middle\":return[\"center\",\"-50%\"];case\"bottom\":return[\"bottom\",\"-100%\"];default:return[\"center\",\"-50%\"]}})();let h=`translate(${r}, ${u})`;l&&(h+=`rotate(${l}rad)`),n.style.transformOrigin=`${o} ${d}`,n.style.transform=h,this.layout,this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(e),n.style.backgroundColor=e.fillStyle),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(e),n.style.borderStyle=e.lineDash.length<2?\"solid\":\"dashed\",n.style.borderWidth=`${e.lineWidth}px`,n.style.borderColor=e.strokeStyle),(0,a.display)(n)}}s.TextAnnotationView=h,h.__name__=\"TextAnnotationView\";class _ extends o.Annotation{constructor(e){super(e)}}s.TextAnnotation=_,n=_,_.__name__=\"TextAnnotation\",n.define((()=>({render_mode:[r.RenderMode,\"canvas\"]})))},\n", " function _(t,e,s,i,n){i();const h=t(65),o=t(121),r=t(9),a=t(8),c=t(122),_=t(22);s.text_width=(()=>{const t=document.createElement(\"canvas\").getContext(\"2d\");let e=\"\";return(s,i)=>(i!=e&&(e=i,t.font=i),t.measureText(s).width)})();class l{constructor(){this._position={sx:0,sy:0},this.font_size_scale=1,this.align=\"left\",this._base_font_size=13,this._x_anchor=\"left\",this._y_anchor=\"center\"}set base_font_size(t){null!=t&&(this._base_font_size=t)}get base_font_size(){return this._base_font_size}set position(t){this._position=t}get position(){return this._position}infer_text_height(){return\"ascent_descent\"}bbox(){const{p0:t,p1:e,p2:s,p3:i}=this.rect(),n=Math.min(t.x,e.x,s.x,i.x),o=Math.min(t.y,e.y,s.y,i.y),r=Math.max(t.x,e.x,s.x,i.x),a=Math.max(t.y,e.y,s.y,i.y);return new h.BBox({left:n,right:r,top:o,bottom:a})}size(){const{width:t,height:e}=this._size(),{angle:s}=this;if(s){const i=Math.cos(Math.abs(s)),n=Math.sin(Math.abs(s));return{width:Math.abs(t*i+e*n),height:Math.abs(t*n+e*i)}}return{width:t,height:e}}rect(){const t=this._rect(),{angle:e}=this;if(e){const{sx:s,sy:i}=this.position,n=new c.AffineTransform;return n.translate(s,i),n.rotate(e),n.translate(-s,-i),n.apply_rect(t)}return t}paint_rect(t){const{p0:e,p1:s,p2:i,p3:n}=this.rect();t.save(),t.strokeStyle=\"red\",t.lineWidth=1,t.beginPath();const{round:h}=Math;t.moveTo(h(e.x),h(e.y)),t.lineTo(h(s.x),h(s.y)),t.lineTo(h(i.x),h(i.y)),t.lineTo(h(n.x),h(n.y)),t.closePath(),t.stroke(),t.restore()}paint_bbox(t){const{x:e,y:s,width:i,height:n}=this.bbox();t.save(),t.strokeStyle=\"blue\",t.lineWidth=1,t.beginPath();const{round:h}=Math;t.moveTo(h(e),h(s)),t.lineTo(h(e),h(s+n)),t.lineTo(h(e+i),h(s+n)),t.lineTo(h(e+i),h(s)),t.closePath(),t.stroke(),t.restore()}}s.GraphicsBox=l,l.__name__=\"GraphicsBox\";class x extends l{constructor({text:t}){super(),this.text=t}set visuals(t){const e=t.color,s=t.alpha,i=t.font_style;let n=t.font_size;const h=t.font,{font_size_scale:r,base_font_size:a}=this,c=(0,o.parse_css_font_size)(n);if(null!=c){let{value:t,unit:e}=c;t*=r,\"em\"==e&&a&&(t*=a,e=\"px\"),n=`${t}${e}`}const l=`${i} ${n} ${h}`;this.font=l,this.color=(0,_.color2css)(e,s),this.line_height=t.line_height;const x=t.align;this._x_anchor=x;const u=t.baseline;this._y_anchor=(()=>{switch(u){case\"top\":return\"top\";case\"middle\":return\"center\";case\"bottom\":return\"bottom\";default:return\"baseline\"}})()}infer_text_height(){if(this.text.includes(\"\\n\"))return\"ascent_descent\";{function t(t){for(const e of new Set(t))if(!(\"0\"<=e&&e<=\"9\"))switch(e){case\",\":case\".\":case\"+\":case\"-\":case\"\\u2212\":case\"e\":continue;default:return!1}return!0}return t(this.text)?\"cap\":\"ascent_descent\"}}_text_line(t){var e;const s=null!==(e=this.text_height_metric)&&void 0!==e?e:this.infer_text_height(),i=(()=>{switch(s){case\"x\":case\"x_descent\":return t.x_height;case\"cap\":case\"cap_descent\":return t.cap_height;case\"ascent\":case\"ascent_descent\":return t.ascent}})(),n=(()=>{switch(s){case\"x\":case\"cap\":case\"ascent\":return 0;case\"x_descent\":case\"cap_descent\":case\"ascent_descent\":return t.descent}})();return{height:i+n,ascent:i,descent:n}}get nlines(){return this.text.split(\"\\n\").length}_size(){var t,e;const{font:i}=this,n=(0,o.font_metrics)(i),h=(this.line_height-1)*n.height,a=\"\"==this.text,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>(0,s.text_width)(t,i))),x=this._text_line(n).height*_,u=\"%\"==(null===(t=this.width)||void 0===t?void 0:t.unit)?this.width.value:1,p=\"%\"==(null===(e=this.height)||void 0===e?void 0:e.unit)?this.height.value:1;return{width:(0,r.max)(l)*u,height:a?0:(x+h*(_-1))*p,metrics:n}}_computed_position(t,e,s){const{width:i,height:n}=t,{sx:h,sy:o,x_anchor:r=this._x_anchor,y_anchor:c=this._y_anchor}=this.position;return{x:h-(()=>{if((0,a.isNumber)(r))return r*i;switch(r){case\"left\":return 0;case\"center\":return.5*i;case\"right\":return i}})(),y:o-(()=>{var t;if((0,a.isNumber)(c))return c*n;switch(c){case\"top\":return 0;case\"center\":return.5*n;case\"bottom\":return n;case\"baseline\":if(1!=s)return.5*n;switch(null!==(t=this.text_height_metric)&&void 0!==t?t:this.infer_text_height()){case\"x\":case\"x_descent\":return e.x_height;case\"cap\":case\"cap_descent\":return e.cap_height;case\"ascent\":case\"ascent_descent\":return e.ascent}}})()}}_rect(){const{width:t,height:e,metrics:s}=this._size(),i=this.text.split(\"\\n\").length,{x:n,y:o}=this._computed_position({width:t,height:e},s,i);return new h.BBox({x:n,y:o,width:t,height:e}).rect}paint(t){var e,i;const{font:n}=this,h=(0,o.font_metrics)(n),a=(this.line_height-1)*h.height,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>(0,s.text_width)(t,n))),x=this._text_line(h),u=x.height*_,p=\"%\"==(null===(e=this.width)||void 0===e?void 0:e.unit)?this.width.value:1,f=\"%\"==(null===(i=this.height)||void 0===i?void 0:i.unit)?this.height.value:1,g=(0,r.max)(l)*p,d=(u+a*(_-1))*f;t.save(),t.fillStyle=this.color,t.font=this.font,t.textAlign=\"left\",t.textBaseline=\"alphabetic\";const{sx:b,sy:m}=this.position,{align:y}=this,{angle:w}=this;w&&(t.translate(b,m),t.rotate(w),t.translate(-b,-m));let{x:v,y:z}=this._computed_position({width:g,height:d},h,_);if(\"justify\"==y)for(let e=0;e<_;e++){let i=v;const h=c[e].split(\" \"),o=h.length,_=h.map((t=>(0,s.text_width)(t,n))),l=(g-(0,r.sum)(_))/(o-1);for(let e=0;e{switch(y){case\"left\":return 0;case\"center\":return.5*(g-l[e]);case\"right\":return g-l[e]}})();t.fillStyle=this.color,t.fillText(c[e],s,z+x.ascent),z+=x.height+a}t.restore()}}s.TextBox=x,x.__name__=\"TextBox\";class u extends l{constructor(t,e){super(),this.base=t,this.expo=e}get children(){return[this.base,this.expo]}set base_font_size(t){super.base_font_size=t,this.base.base_font_size=t,this.expo.base_font_size=t}set position(t){this._position=t;const e=this.base.size(),s=this.expo.size(),i=this._shift_scale()*e.height,n=Math.max(e.height,i+s.height);this.base.position={sx:0,x_anchor:\"left\",sy:n,y_anchor:\"bottom\"},this.expo.position={sx:e.width,x_anchor:\"left\",sy:i,y_anchor:\"bottom\"}}get position(){return this._position}set visuals(t){this.expo.font_size_scale=.7,this.base.visuals=t,this.expo.visuals=t}_shift_scale(){if(this.base instanceof x&&1==this.base.nlines){const{x_height:t,cap_height:e}=(0,o.font_metrics)(this.base.font);return t/e}return 2/3}infer_text_height(){return this.base.infer_text_height()}_rect(){const t=this.base.bbox(),e=this.expo.bbox(),s=t.union(e),{x:i,y:n}=this._computed_position();return s.translate(i,n).rect}_size(){const t=this.base.size(),e=this.expo.size();return{width:t.width+e.width,height:Math.max(t.height,this._shift_scale()*t.height+e.height)}}paint(t){t.save();const{angle:e}=this;if(e){const{sx:s,sy:i}=this.position;t.translate(s,i),t.rotate(e),t.translate(-s,-i)}const{x:s,y:i}=this._computed_position();t.translate(s,i),this.base.paint(t),this.expo.paint(t),t.restore()}paint_bbox(t){super.paint_bbox(t);const{x:e,y:s}=this._computed_position();t.save(),t.translate(e,s);for(const e of this.children)e.paint_bbox(t);t.restore()}_computed_position(){const{width:t,height:e}=this._size(),{sx:s,sy:i,x_anchor:n=this._x_anchor,y_anchor:h=this._y_anchor}=this.position;return{x:s-(()=>{if((0,a.isNumber)(n))return n*t;switch(n){case\"left\":return 0;case\"center\":return.5*t;case\"right\":return t}})(),y:i-(()=>{if((0,a.isNumber)(h))return h*e;switch(h){case\"top\":return 0;case\"center\":return.5*e;case\"bottom\":return e;case\"baseline\":return.5*e}})()}}}s.BaseExpo=u,u.__name__=\"BaseExpo\";class p{constructor(t){this.items=t}set base_font_size(t){for(const e of this.items)e.base_font_size=t}get length(){return this.items.length}set visuals(t){for(const e of this.items)e.visuals=t;const e={x:0,cap:1,ascent:2,x_descent:3,cap_descent:4,ascent_descent:5},s=(0,r.max_by)(this.items.map((t=>t.infer_text_height())),(t=>e[t]));for(const t of this.items)t.text_height_metric=s}set angle(t){for(const e of this.items)e.angle=t}max_size(){let t=0,e=0;for(const s of this.items){const i=s.size();t=Math.max(t,i.width),e=Math.max(e,i.height)}return{width:t,height:e}}}s.GraphicsBoxes=p,p.__name__=\"GraphicsBoxes\"},\n", " function _(t,e,n,r,l){r();const a=t(11),c=(()=>{try{return\"undefined\"!=typeof OffscreenCanvas&&null!=new OffscreenCanvas(0,0).getContext(\"2d\")}catch(t){return!1}})()?(t,e)=>new OffscreenCanvas(t,e):(t,e)=>{const n=document.createElement(\"canvas\");return n.width=t,n.height=e,n},o=(()=>{const t=c(0,0).getContext(\"2d\");return e=>{t.font=e;const n=t.measureText(\"M\"),r=t.measureText(\"x\"),l=t.measureText(\"\\xc5\\u015ag|\"),c=l.fontBoundingBoxAscent,o=l.fontBoundingBoxDescent;if(null!=c&&null!=o)return{height:c+o,ascent:c,descent:o,cap_height:n.actualBoundingBoxAscent,x_height:r.actualBoundingBoxAscent};const s=l.actualBoundingBoxAscent,u=l.actualBoundingBoxDescent;if(null!=s&&null!=u)return{height:s+u,ascent:s,descent:u,cap_height:n.actualBoundingBoxAscent,x_height:r.actualBoundingBoxAscent};(0,a.unreachable)()}})(),s=(()=>{const t=c(0,0).getContext(\"2d\");return(e,n)=>{t.font=n;const r=t.measureText(e),l=r.actualBoundingBoxAscent,c=r.actualBoundingBoxDescent;if(null!=l&&null!=c)return{width:r.width,height:l+c,ascent:l,descent:c};(0,a.unreachable)()}})(),u=(()=>{const t=document.createElement(\"canvas\"),e=t.getContext(\"2d\");let n=-1,r=-1;return(l,a=1)=>{e.font=l;const{width:c}=e.measureText(\"M\"),o=c*a,s=Math.ceil(o),u=Math.ceil(2*o),i=Math.ceil(1.5*o);n{let e=0;for(let n=0;n<=i;n++)for(let r=0;r{let e=t.length-4;for(let n=u;n>=i;n--)for(let r=0;r{const t=document.createElement(\"canvas\"),e=t.getContext(\"2d\");let n=-1,r=-1;return(l,a,c=1)=>{e.font=a;const{width:o}=e.measureText(\"M\"),s=o*c,u=Math.ceil(s),i=Math.ceil(2*s),f=Math.ceil(1.5*s);(n{let e=0;for(let n=0;n<=f;n++)for(let r=0;r{let e=t.length-4;for(let n=i;n>=f;n--)for(let r=0;r{try{return o(\"normal 10px sans-serif\"),o}catch(t){return u}})(),h=(()=>{try{return s(\"A\",\"normal 10px sans-serif\"),s}catch(t){return i}})(),g=new Map;function d(t){let e=g.get(t);return null==e&&(e={font:f(t),glyphs:new Map},g.set(t,e)),e.font}n.font_metrics=d,n.glyph_metrics=function(t,e){let n=g.get(e);null==n&&(d(e),n=g.get(e));let r=n.glyphs.get(t);return null==r&&(r=h(t,e),n.glyphs.set(t,r)),r},n.parse_css_font_size=function(t){const e=t.match(/^\\s*(\\d+(\\.\\d+)?)(\\w+)\\s*$/);if(null!=e){const[,t,,n]=e,r=Number(t);if(isFinite(r))return{value:r,unit:n}}return null}},\n", " function _(t,s,r,n,i){n();const{sin:e,cos:a}=Math;class h{constructor(t=1,s=0,r=0,n=1,i=0,e=0){this.a=t,this.b=s,this.c=r,this.d=n,this.e=i,this.f=e}toString(){const{a:t,b:s,c:r,d:n,e:i,f:e}=this;return`matrix(${t}, ${s}, ${r}, ${n}, ${i}, ${e})`}static from_DOMMatrix(t){const{a:s,b:r,c:n,d:i,e,f:a}=t;return new h(s,r,n,i,e,a)}to_DOMMatrix(){const{a:t,b:s,c:r,d:n,e:i,f:e}=this;return new DOMMatrix([t,s,r,n,i,e])}clone(){const{a:t,b:s,c:r,d:n,e:i,f:e}=this;return new h(t,s,r,n,i,e)}get is_identity(){const{a:t,b:s,c:r,d:n,e:i,f:e}=this;return 1==t&&0==s&&0==r&&1==n&&0==i&&0==e}apply_point(t){const[s,r]=this.apply(t.x,t.y);return{x:s,y:r}}apply_rect(t){return{p0:this.apply_point(t.p0),p1:this.apply_point(t.p1),p2:this.apply_point(t.p2),p3:this.apply_point(t.p3)}}apply(t,s){const{a:r,b:n,c:i,d:e,e:a,f:h}=this;return[r*t+i*s+a,n*t+e*s+h]}iv_apply(t,s){const{a:r,b:n,c:i,d:e,e:a,f:h}=this,c=t.length;for(let o=0;o{const h={max:4,fit:3,min:2,fixed:1};return h[i]>h[t]};if(\"fixed\"!=n&&\"fixed\"!=s)if(n==s){const n=t,s=_(t/e),r=_(h*e),g=h;Math.abs(i.width-n)+Math.abs(i.height-s)<=Math.abs(i.width-r)+Math.abs(i.height-g)?(t=n,h=s):(t=r,h=g)}else r(n,s)?h=_(t/e):t=_(h*e);else\"fixed\"==n?h=_(t/e):\"fixed\"==s&&(t=_(h*e))}return{width:t,height:h}}measure(i){if(!this.sizing.visible)return{width:0,height:0};const t=i=>\"fixed\"==this.sizing.width_policy&&null!=this.sizing.width?this.sizing.width:i,h=i=>\"fixed\"==this.sizing.height_policy&&null!=this.sizing.height?this.sizing.height:i,e=new s.Sizeable(i).shrink_by(this.sizing.margin).map(t,h),n=this._measure(e),r=this.clip_size(n,e),g=t(r.width),l=h(r.height),a=this.apply_aspect(e,{width:g,height:l});return Object.assign(Object.assign({},n),a)}compute(i={}){const t=this.measure({width:null!=i.width&&this.is_width_expanding()?i.width:1/0,height:null!=i.height&&this.is_height_expanding()?i.height:1/0}),{width:h,height:e}=t,n=new r.BBox({left:0,top:0,width:h,height:e});let s;if(null!=t.inner){const{left:i,top:n,right:g,bottom:l}=t.inner;s=new r.BBox({left:i,top:n,right:h-g,bottom:e-l})}this.set_geometry(n,s)}get xview(){return this.bbox.xview}get yview(){return this.bbox.yview}clip_size(i,t){function h(i,t,h,e){return null==h?h=0:(0,g.isNumber)(h)||(h=Math.round(h.percent*t)),null==e?e=1/0:(0,g.isNumber)(e)||(e=Math.round(e.percent*t)),a(h,l(i,e))}return{width:h(i.width,t.width,this.sizing.min_width,this.sizing.max_width),height:h(i.height,t.height,this.sizing.min_height,this.sizing.max_height)}}has_size_changed(){const{_dirty:i}=this;return this._dirty=!1,i}}h.Layoutable=o,o.__name__=\"Layoutable\";class d extends o{_measure(i){const{width_policy:t,height_policy:h}=this.sizing;return{width:(()=>{const{width:h}=this.sizing;if(i.width==1/0)return null!=h?h:0;switch(t){case\"fixed\":return null!=h?h:0;case\"min\":return null!=h?l(i.width,h):0;case\"fit\":return null!=h?l(i.width,h):i.width;case\"max\":return null!=h?a(i.width,h):i.width}})(),height:(()=>{const{height:t}=this.sizing;if(i.height==1/0)return null!=t?t:0;switch(h){case\"fixed\":return null!=t?t:0;case\"min\":return null!=t?l(i.height,t):0;case\"fit\":return null!=t?l(i.height,t):i.height;case\"max\":return null!=t?a(i.height,t):i.height}})()}}}h.LayoutItem=d,d.__name__=\"LayoutItem\";class u extends o{_measure(i){const t=this._content_size(),h=i.bounded_to(this.sizing.size).bounded_to(t);return{width:(()=>{switch(this.sizing.width_policy){case\"fixed\":return null!=this.sizing.width?this.sizing.width:t.width;case\"min\":return t.width;case\"fit\":return h.width;case\"max\":return Math.max(t.width,h.width)}})(),height:(()=>{switch(this.sizing.height_policy){case\"fixed\":return null!=this.sizing.height?this.sizing.height:t.height;case\"min\":return t.height;case\"fit\":return h.height;case\"max\":return Math.max(t.height,h.height)}})()}}}h.ContentLayoutable=u,u.__name__=\"ContentLayoutable\"},\n", " function _(e,t,s,a,_){a();const r=e(62),n=e(61),g=e(58),i=e(63),c=e(67),h=e(65),l=e(13),o=e(11);class x{constructor(e,t,s,a,_={},r={},n={},g={}){this.in_x_scale=e,this.in_y_scale=t,this.x_range=s,this.y_range=a,this.extra_x_ranges=_,this.extra_y_ranges=r,this.extra_x_scales=n,this.extra_y_scales=g,this._bbox=new h.BBox,(0,o.assert)(null==e.source_range&&null==e.target_range),(0,o.assert)(null==t.source_range&&null==t.target_range),this._configure_scales()}get bbox(){return this._bbox}_get_ranges(e,t){return new Map((0,l.entries)(Object.assign(Object.assign({},t),{default:e})))}_get_scales(e,t,s,a){var _;const g=new Map((0,l.entries)(Object.assign(Object.assign({},t),{default:e}))),h=new Map;for(const[t,l]of s){if(l instanceof c.FactorRange!=e instanceof r.CategoricalScale)throw new Error(`Range ${l.type} is incompatible is Scale ${e.type}`);e instanceof n.LogScale&&l instanceof i.DataRange1d&&(l.scale_hint=\"log\");const s=(null!==(_=g.get(t))&&void 0!==_?_:e).clone();s.setv({source_range:l,target_range:a}),h.set(t,s)}return h}_configure_frame_ranges(){const{bbox:e}=this;this._x_target=new g.Range1d({start:e.left,end:e.right}),this._y_target=new g.Range1d({start:e.bottom,end:e.top})}_configure_scales(){this._configure_frame_ranges(),this._x_ranges=this._get_ranges(this.x_range,this.extra_x_ranges),this._y_ranges=this._get_ranges(this.y_range,this.extra_y_ranges),this._x_scales=this._get_scales(this.in_x_scale,this.extra_x_scales,this._x_ranges,this._x_target),this._y_scales=this._get_scales(this.in_y_scale,this.extra_y_scales,this._y_ranges,this._y_target)}_update_scales(){this._configure_frame_ranges();for(const[,e]of this._x_scales)e.target_range=this._x_target;for(const[,e]of this._y_scales)e.target_range=this._y_target}set_geometry(e){this._bbox=e,this._update_scales()}get x_target(){return this._x_target}get y_target(){return this._y_target}get x_ranges(){return this._x_ranges}get y_ranges(){return this._y_ranges}get x_scales(){return this._x_scales}get y_scales(){return this._y_scales}get x_scale(){return this._x_scales.get(\"default\")}get y_scale(){return this._y_scales.get(\"default\")}get xscales(){return(0,l.to_object)(this.x_scales)}get yscales(){return(0,l.to_object)(this.y_scales)}}s.CartesianFrame=x,x.__name__=\"CartesianFrame\"},\n", " function _(i,s,x,A,o){A(),o(\"Axis\",i(128).Axis),o(\"CategoricalAxis\",i(140).CategoricalAxis),o(\"ContinuousAxis\",i(143).ContinuousAxis),o(\"DatetimeAxis\",i(144).DatetimeAxis),o(\"LinearAxis\",i(145).LinearAxis),o(\"LogAxis\",i(162).LogAxis),o(\"MercatorAxis\",i(165).MercatorAxis)},\n", " function _(t,e,i,s,a){s();const o=t(1);var l;const n=t(129),_=t(130),r=t(131),h=t(132),c=(0,o.__importStar)(t(48)),b=t(20),u=t(24),m=t(123),d=t(9),x=t(13),f=t(8),g=t(120),p=t(67),v=t(133),w=t(113),j=t(11),k=t(8),y=t(134),{abs:z}=Math;class M extends n.GuideRendererView{constructor(){super(...arguments),this._axis_label_view=null,this._major_label_views=new Map}async lazy_initialize(){await super.lazy_initialize(),await this._init_axis_label(),await this._init_major_labels()}async _init_axis_label(){const{axis_label:t}=this.model;if(null!=t){const e=(0,k.isString)(t)?(0,y.parse_delimited_string)(t):t;this._axis_label_view=await(0,w.build_view)(e,{parent:this})}else this._axis_label_view=null}async _init_major_labels(){const{major_label_overrides:t}=this.model;for(const[e,i]of(0,x.entries)(t)){const t=(0,k.isString)(i)?(0,y.parse_delimited_string)(i):i;this._major_label_views.set(e,await(0,w.build_view)(t,{parent:this}))}}update_layout(){this.layout=new m.SideLayout(this.panel,(()=>this.get_size()),!0),this.layout.on_resize((()=>this._coordinates=void 0))}get_size(){const{visible:t,fixed_location:e}=this.model;if(t&&null==e&&this.is_renderable){const{extents:t}=this;return{width:0,height:Math.round(t.tick+t.tick_label+t.axis_label)}}return{width:0,height:0}}get is_renderable(){const[t,e]=this.ranges;return t.is_valid&&e.is_valid}_render(){var t;if(!this.is_renderable)return;const{tick_coords:e,extents:i}=this,s=this.layer.ctx;s.save(),this._draw_rule(s,i),this._draw_major_ticks(s,i,e),this._draw_minor_ticks(s,i,e),this._draw_major_labels(s,i,e),this._draw_axis_label(s,i,e),null===(t=this._paint)||void 0===t||t.call(this,s,i,e),s.restore()}connect_signals(){super.connect_signals();const{axis_label:t,major_label_overrides:e}=this.model.properties;this.on_change(t,(async()=>{var t;null===(t=this._axis_label_view)||void 0===t||t.remove(),await this._init_axis_label()})),this.on_change(e,(async()=>{for(const t of this._major_label_views.values())t.remove();await this._init_major_labels()})),this.connect(this.model.change,(()=>this.plot_view.request_layout()))}get needs_clip(){return null!=this.model.fixed_location}_draw_rule(t,e){if(!this.visuals.axis_line.doit)return;const[i,s]=this.rule_coords,[a,o]=this.coordinates.map_to_screen(i,s),[l,n]=this.normals,[_,r]=this.offsets;this.visuals.axis_line.set_value(t),t.beginPath();for(let e=0;e0?s+i+3:0}_draw_axis_label(t,e,i){if(null==this._axis_label_view||null!=this.model.fixed_location)return;const[s,a]=(()=>{const{bbox:t}=this.layout;switch(this.panel.side){case\"above\":return[t.hcenter,t.bottom];case\"below\":return[t.hcenter,t.top];case\"left\":return[t.right,t.vcenter];case\"right\":return[t.left,t.vcenter]}})(),[o,l]=this.normals,n=e.tick+e.tick_label+this.model.axis_label_standoff,{vertical_align:_,align:r}=this.panel.get_label_text_heuristics(\"parallel\"),h={sx:s+o*n,sy:a+l*n,x_anchor:r,y_anchor:_},c=this._axis_label_view.graphics();c.visuals=this.visuals.axis_label_text.values(),c.angle=this.panel.get_label_angle_heuristic(\"parallel\"),this.plot_view.base_font_size&&(c.base_font_size=this.plot_view.base_font_size),c.position=h,c.align=r,c.paint(t)}_draw_ticks(t,e,i,s,a){if(!a.doit)return;const[o,l]=e,[n,_]=this.coordinates.map_to_screen(o,l),[r,h]=this.normals,[c,b]=this.offsets,[u,m]=[r*(c-i),h*(b-i)],[d,x]=[r*(c+s),h*(b+s)];a.set_value(t),t.beginPath();for(let e=0;et.bbox())),M=(()=>{const[t]=this.ranges;return t.is_reversed?0==this.dimension?(t,e)=>z[t].left-z[e].right:(t,e)=>z[e].top-z[t].bottom:0==this.dimension?(t,e)=>z[e].left-z[t].right:(t,e)=>z[t].top-z[e].bottom})(),{major_label_policy:O}=this.model,T=O.filter(k,z,M),A=[...T.ones()];if(0!=A.length){const t=this.parent.canvas_view.bbox,e=e=>{const i=z[e];if(i.left<0){const t=-i.left,{position:s}=y[e];y[e].position=Object.assign(Object.assign({},s),{sx:s.sx+t})}else if(i.right>t.width){const s=i.right-t.width,{position:a}=y[e];y[e].position=Object.assign(Object.assign({},a),{sx:a.sx-s})}},i=e=>{const i=z[e];if(i.top<0){const t=-i.top,{position:s}=y[e];y[e].position=Object.assign(Object.assign({},s),{sy:s.sy+t})}else if(i.bottom>t.height){const s=i.bottom-t.height,{position:a}=y[e];y[e].position=Object.assign(Object.assign({},a),{sy:a.sy-s})}},s=A[0],a=A[A.length-1];0==this.dimension?(e(s),e(a)):(i(s),i(a))}for(const e of T){y[e].paint(t)}}_tick_extent(){return this.model.major_tick_out}_tick_label_extents(){const t=this.tick_coords.major,e=this.compute_labels(t[this.dimension]),i=this.model.major_label_orientation,s=this.model.major_label_standoff,a=this.visuals.major_label_text;return[this._oriented_labels_extent(e,i,s,a)]}get extents(){const t=this._tick_label_extents();return{tick:this._tick_extent(),tick_labels:t,tick_label:(0,d.sum)(t),axis_label:this._axis_label_extent()}}_oriented_labels_extent(t,e,i,s){if(0==t.length||!s.doit)return 0;const a=this.panel.get_label_angle_heuristic(e);t.visuals=s.values(),t.angle=a,t.base_font_size=this.plot_view.base_font_size;const o=t.max_size(),l=0==this.dimension?o.height:o.width;return l>0?i+l+3:0}get normals(){return this.panel.normals}get dimension(){return this.panel.dimension}compute_labels(t){const e=this.model.formatter.format_graphics(t,this),{_major_label_views:i}=this,s=new Set;for(let a=0;az(l-n)?(t=r(_(a,o),l),s=_(r(a,o),n)):(t=_(a,o),s=r(a,o)),[t,s]}}get rule_coords(){const t=this.dimension,e=(t+1)%2,[i]=this.ranges,[s,a]=this.computed_bounds,o=[new Array(2),new Array(2)];return o[t][0]=Math.max(s,i.min),o[t][1]=Math.min(a,i.max),o[t][0]>o[t][1]&&(o[t][0]=o[t][1]=NaN),o[e][0]=this.loc,o[e][1]=this.loc,o}get tick_coords(){const t=this.dimension,e=(t+1)%2,[i]=this.ranges,[s,a]=this.computed_bounds,o=this.model.ticker.get_ticks(s,a,i,this.loc),l=o.major,n=o.minor,_=[[],[]],r=[[],[]],[h,c]=[i.min,i.max];for(let i=0;ic||(_[t].push(l[i]),_[e].push(this.loc));for(let i=0;ic||(r[t].push(n[i]),r[e].push(this.loc));return{major:_,minor:r}}get loc(){const{fixed_location:t}=this.model;if(null!=t){if((0,f.isNumber)(t))return t;const[,e]=this.ranges;if(e instanceof p.FactorRange)return e.synthetic(t);(0,j.unreachable)()}const[,e]=this.ranges;switch(this.panel.side){case\"left\":case\"below\":return e.start;case\"right\":case\"above\":return e.end}}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.layout.bbox.box})}remove(){var t;null===(t=this._axis_label_view)||void 0===t||t.remove();for(const t of this._major_label_views.values())t.remove();super.remove()}has_finished(){if(!super.has_finished())return!1;if(null!=this._axis_label_view&&!this._axis_label_view.has_finished())return!1;for(const t of this._major_label_views.values())if(!t.has_finished())return!1;return!0}}i.AxisView=M,M.__name__=\"AxisView\";class O extends n.GuideRenderer{constructor(t){super(t)}}i.Axis=O,l=O,O.__name__=\"Axis\",l.prototype.default_view=M,l.mixins([[\"axis_\",c.Line],[\"major_tick_\",c.Line],[\"minor_tick_\",c.Line],[\"major_label_\",c.Text],[\"axis_label_\",c.Text]]),l.define((({Any:t,Int:e,Number:i,String:s,Ref:a,Dict:o,Tuple:l,Or:n,Nullable:c,Auto:u})=>({bounds:[n(l(i,i),u),\"auto\"],ticker:[a(_.Ticker)],formatter:[a(r.TickFormatter)],axis_label:[c(n(s,a(v.BaseText))),null],axis_label_standoff:[e,5],major_label_standoff:[e,5],major_label_orientation:[n(b.TickLabelOrientation,i),\"horizontal\"],major_label_overrides:[o(n(s,a(v.BaseText))),{}],major_label_policy:[a(h.LabelingPolicy),()=>new h.AllLabels],major_tick_in:[i,2],major_tick_out:[i,6],minor_tick_in:[i,0],minor_tick_out:[i,4],fixed_location:[c(n(i,t)),null]}))),l.override({axis_line_color:\"black\",major_tick_line_color:\"black\",minor_tick_line_color:\"black\",major_label_text_font_size:\"11px\",major_label_text_align:\"center\",major_label_text_baseline:\"alphabetic\",axis_label_text_font_size:\"13px\",axis_label_text_font_style:\"italic\"})},\n", " function _(e,r,d,n,i){var s;n();const _=e(41);class u extends _.RendererView{}d.GuideRendererView=u,u.__name__=\"GuideRendererView\";class c extends _.Renderer{constructor(e){super(e)}}d.GuideRenderer=c,s=c,c.__name__=\"GuideRenderer\",s.override({level:\"guide\"})},\n", " function _(c,e,n,s,o){s();const r=c(53);class t extends r.Model{constructor(c){super(c)}}n.Ticker=t,t.__name__=\"Ticker\"},\n", " function _(t,o,r,e,c){e();const n=t(53),a=t(120);class m extends n.Model{constructor(t){super(t)}format_graphics(t,o){return this.doFormat(t,o).map((t=>new a.TextBox({text:t})))}compute(t,o){return this.doFormat([t],null!=o?o:{loc:0})[0]}v_compute(t,o){return this.doFormat(t,null!=o?o:{loc:0})}}r.TickFormatter=m,m.__name__=\"TickFormatter\"},\n", " function _(e,n,s,t,i){var c,r;t();const l=e(53),o=e(13),a=e(34),u=e(8),d=e(24);class _ extends l.Model{constructor(e){super(e)}}s.LabelingPolicy=_,_.__name__=\"LabelingPolicy\";class f extends _{constructor(e){super(e)}filter(e,n,s){return e}}s.AllLabels=f,f.__name__=\"AllLabels\";class m extends _{constructor(e){super(e)}filter(e,n,s){const{min_distance:t}=this;let i=null;for(const n of e)null!=i&&s(i,n)({min_distance:[e,5]})));class b extends _{constructor(e){super(e)}get names(){return(0,o.keys)(this.args)}get values(){return(0,o.values)(this.args)}get func(){const e=(0,a.use_strict)(this.code);return new d.GeneratorFunction(\"indices\",\"bboxes\",\"distance\",...this.names,e)}filter(e,n,s){const t=Object.create(null),i=this.func.call(t,e,n,s,...this.values);let c=i.next();if(c.done&&void 0!==c.value){const{value:n}=c;return n instanceof d.Indices?n:void 0===n?e:(0,u.isIterable)(n)?d.Indices.from_indices(e.size,n):d.Indices.all_unset(e.size)}{const n=[];do{n.push(c.value),c=i.next()}while(!c.done);return d.Indices.from_indices(e.size,n)}}}s.CustomLabelingPolicy=b,r=b,b.__name__=\"CustomLabelingPolicy\",r.define((({Unknown:e,String:n,Dict:s})=>({args:[s(e),{}],code:[n,\"\"]})))},\n", " function _(e,s,t,n,a){var _;n();const x=e(53),c=e(42);class i extends c.View{}t.BaseTextView=i,i.__name__=\"BaseTextView\";class o extends x.Model{constructor(e){super(e)}}t.BaseText=o,_=o,o.__name__=\"BaseText\",_.define((({String:e})=>({text:[e]})))},\n", " function _(n,e,t,i,r){i();const s=n(135),l=n(139),d=[{start:\"$$\",end:\"$$\",inline:!1},{start:\"\\\\[\",end:\"\\\\]\",inline:!1},{start:\"\\\\(\",end:\"\\\\)\",inline:!0}];t.parse_delimited_string=function(n){for(const e of d){const t=n.indexOf(e.start),i=t+e.start.length;if(0==t){const t=n.indexOf(e.end,i),r=t;if(t==n.length-e.end.length)return new s.TeX({text:n.slice(i,r),inline:e.inline});break}}return new l.PlainText({text:n})}},\n", " function _(t,e,s,i,n){var o,r,a;i();const h=t(8),_=t(136),l=t(22),c=t(120),d=t(121),u=t(122),g=t(65),p=t(133),x=t(137);class m extends p.BaseTextView{constructor(){super(...arguments),this._position={sx:0,sy:0},this.align=\"left\",this._x_anchor=\"left\",this._y_anchor=\"center\",this._base_font_size=13,this.font_size_scale=1,this.svg_image=null}graphics(){return this}infer_text_height(){return\"ascent_descent\"}set base_font_size(t){null!=t&&(this._base_font_size=t)}get base_font_size(){return this._base_font_size}get has_image_loaded(){return null!=this.svg_image}_rect(){const{width:t,height:e}=this._size(),{x:s,y:i}=this._computed_position();return new g.BBox({x:s,y:i,width:t,height:e}).rect}set position(t){this._position=t}get position(){return this._position}get text(){return this.model.text}get provider(){return x.default_provider}async lazy_initialize(){await super.lazy_initialize(),\"not_started\"==this.provider.status&&await this.provider.fetch(),\"not_started\"!=this.provider.status&&\"loading\"!=this.provider.status||this.provider.ready.connect((()=>this.load_image())),\"loaded\"==this.provider.status&&await this.load_image()}connect_signals(){super.connect_signals(),this.on_change(this.model.properties.text,(()=>this.load_image()))}set visuals(t){const e=t.color,s=t.alpha,i=t.font_style;let n=t.font_size;const o=t.font,{font_size_scale:r,_base_font_size:a}=this,h=(0,d.parse_css_font_size)(n);if(null!=h){let{value:t,unit:e}=h;t*=r,\"em\"==e&&a&&(t*=a,e=\"px\"),n=`${t}${e}`}const _=`${i} ${n} ${o}`;this.font=_,this.color=(0,l.color2css)(e,s)}_computed_position(){const{width:t,height:e}=this._size(),{sx:s,sy:i,x_anchor:n=this._x_anchor,y_anchor:o=this._y_anchor}=this.position;return{x:s-(()=>{if((0,h.isNumber)(n))return n*t;switch(n){case\"left\":return 0;case\"center\":return.5*t;case\"right\":return t}})(),y:i-(()=>{if((0,h.isNumber)(o))return o*e;switch(o){case\"top\":return 0;case\"center\":return.5*e;case\"bottom\":return e;case\"baseline\":return.5*e}})()}}size(){const{width:t,height:e}=this._size(),{angle:s}=this;if(s){const i=Math.cos(Math.abs(s)),n=Math.sin(Math.abs(s));return{width:Math.abs(t*i+e*n),height:Math.abs(t*n+e*i)}}return{width:t,height:e}}get_text_dimensions(){return{width:(0,c.text_width)(this.model.text,this.font),height:(0,d.font_metrics)(this.font).height}}get_image_dimensions(){var t,e,s,i;const n=parseFloat(null!==(e=null===(t=this.svg_element.getAttribute(\"height\"))||void 0===t?void 0:t.replace(/([A-z])/g,\"\"))&&void 0!==e?e:\"0\"),o=parseFloat(null!==(i=null===(s=this.svg_element.getAttribute(\"width\"))||void 0===s?void 0:s.replace(/([A-z])/g,\"\"))&&void 0!==i?i:\"0\");return{width:(0,d.font_metrics)(this.font).x_height*o,height:(0,d.font_metrics)(this.font).x_height*n}}_size(){return this.has_image_loaded?this.get_image_dimensions():this.get_text_dimensions()}bbox(){const{p0:t,p1:e,p2:s,p3:i}=this.rect(),n=Math.min(t.x,e.x,s.x,i.x),o=Math.min(t.y,e.y,s.y,i.y),r=Math.max(t.x,e.x,s.x,i.x),a=Math.max(t.y,e.y,s.y,i.y);return new g.BBox({left:n,right:r,top:o,bottom:a})}rect(){const t=this._rect(),{angle:e}=this;if(e){const{sx:s,sy:i}=this.position,n=new u.AffineTransform;return n.translate(s,i),n.rotate(e),n.translate(-s,-i),n.apply_rect(t)}return t}paint_rect(t){const{p0:e,p1:s,p2:i,p3:n}=this.rect();t.save(),t.strokeStyle=\"red\",t.lineWidth=1,t.beginPath();const{round:o}=Math;t.moveTo(o(e.x),o(e.y)),t.lineTo(o(s.x),o(s.y)),t.lineTo(o(i.x),o(i.y)),t.lineTo(o(n.x),o(n.y)),t.closePath(),t.stroke(),t.restore()}paint_bbox(t){const{x:e,y:s,width:i,height:n}=this.bbox();t.save(),t.strokeStyle=\"blue\",t.lineWidth=1,t.beginPath();const{round:o}=Math;t.moveTo(o(e),o(s)),t.lineTo(o(e),o(s+n)),t.lineTo(o(e+i),o(s+n)),t.lineTo(o(e+i),o(s)),t.closePath(),t.stroke(),t.restore()}async load_image(){if(null==this.provider.MathJax)return null;const t=this._process_text(this.model.text);if(null==t)return this._has_finished=!0,null;const e=t.children[0];this.svg_element=e,e.setAttribute(\"font\",this.font),e.setAttribute(\"stroke\",this.color);const s=e.outerHTML,i=new Blob([s],{type:\"image/svg+xml\"}),n=URL.createObjectURL(i);try{this.svg_image=await(0,_.load_image)(n)}finally{URL.revokeObjectURL(n)}return this.parent.request_layout(),this.svg_image}paint(t){t.save();const{sx:e,sy:s}=this.position;this.angle&&(t.translate(e,s),t.rotate(this.angle),t.translate(-e,-s));const{x:i,y:n}=this._computed_position();if(null!=this.svg_image){const{width:e,height:s}=this.get_image_dimensions();t.drawImage(this.svg_image,i,n,e,s)}else t.fillStyle=this.color,t.font=this.font,t.textAlign=\"left\",t.textBaseline=\"alphabetic\",t.fillText(this.model.text,i,n+(0,d.font_metrics)(this.font).ascent);t.restore(),this._has_finished||\"failed\"!=this.provider.status&&!this.has_image_loaded||(this._has_finished=!0,this.parent.notify_finished_after_paint())}}s.MathTextView=m,m.__name__=\"MathTextView\";class f extends p.BaseText{constructor(t){super(t)}}s.MathText=f,f.__name__=\"MathText\";class v extends m{_process_text(t){}}s.AsciiView=v,v.__name__=\"AsciiView\";class y extends f{constructor(t){super(t)}}s.Ascii=y,o=y,y.__name__=\"Ascii\",o.prototype.default_view=v;class w extends m{_process_text(t){var e;return null===(e=this.provider.MathJax)||void 0===e?void 0:e.mathml2svg(t.trim())}}s.MathMLView=w,w.__name__=\"MathMLView\";class b extends f{constructor(t){super(t)}}s.MathML=b,r=b,b.__name__=\"MathML\",r.prototype.default_view=w;class M extends m{_process_text(t){var e;return null===(e=this.provider.MathJax)||void 0===e?void 0:e.tex2svg(t,void 0,this.model.macros)}}s.TeXView=M,M.__name__=\"TeXView\";class T extends f{constructor(t){super(t)}}s.TeX=T,a=T,T.__name__=\"TeX\",a.prototype.default_view=M,a.define((({Boolean:t,Number:e,String:s,Dict:i,Tuple:n,Or:o})=>({macros:[i(o(s,n(s,e))),{}],inline:[t,!1]})))},\n", " function _(i,e,t,s,o){s();const a=i(19);t.load_image=async function(i,e){return new n(i,e).promise};class n{constructor(i,e={}){this._image=new Image,this._finished=!1;const{attempts:t=1,timeout:s=1}=e;this.promise=new Promise(((o,n)=>{this._image.crossOrigin=\"anonymous\";let r=0;this._image.onerror=()=>{if(++r==t){const s=`unable to load ${i} image after ${t} attempts`;if(a.logger.warn(s),null==this._image.crossOrigin)return void(null!=e.failed&&e.failed());a.logger.warn(`attempting to load ${i} without a cross origin policy`),this._image.crossOrigin=null,r=0}setTimeout((()=>this._image.src=i),s)},this._image.onload=()=>{this._finished=!0,null!=e.loaded&&e.loaded(this._image),o(this._image)},this._image.src=i}))}get finished(){return this._finished}get image(){if(this._finished)return this._image;throw new Error(\"not loaded yet\")}}t.ImageLoader=n,n.__name__=\"ImageLoader\"},\n", " function _(t,e,a,s,n){var r=this&&this.__createBinding||(Object.create?function(t,e,a,s){void 0===s&&(s=a),Object.defineProperty(t,s,{enumerable:!0,get:function(){return e[a]}})}:function(t,e,a,s){void 0===s&&(s=a),t[s]=e[a]}),i=this&&this.__setModuleDefault||(Object.create?function(t,e){Object.defineProperty(t,\"default\",{enumerable:!0,value:e})}:function(t,e){t.default=e}),d=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var a in t)\"default\"!==a&&Object.prototype.hasOwnProperty.call(t,a)&&r(e,t,a);return i(e,t),e};s();const o=t(15),u=t(138);class c{constructor(){this.ready=new o.Signal0(this,\"ready\"),this.status=\"not_started\"}}a.MathJaxProvider=c,c.__name__=\"MathJaxProvider\";class h extends c{get MathJax(){return null}async fetch(){this.status=\"failed\"}}a.NoProvider=h,h.__name__=\"NoProvider\";class l extends c{get MathJax(){return\"undefined\"!=typeof MathJax?MathJax:null}async fetch(){const t=document.createElement(\"script\");t.src=\"https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-svg.js\",t.onload=()=>{this.status=\"loaded\",this.ready.emit()},t.onerror=()=>{this.status=\"failed\"},this.status=\"loading\",document.head.appendChild(t)}}a.CDNProvider=l,l.__name__=\"CDNProvider\";class _ extends c{get MathJax(){return this._mathjax}async fetch(){this.status=\"loading\";try{const e=await(0,u.load_module)(Promise.resolve().then((()=>d(t(515)))));this._mathjax=e,this.status=\"loaded\",this.ready.emit()}catch(t){this.status=\"failed\"}}}a.BundleProvider=_,_.__name__=\"BundleProvider\",a.default_provider=new _},\n", " function _(n,r,o,t,c){t(),o.load_module=async function(n){try{return await n}catch(n){if((r=n)instanceof Error&&\"code\"in r&&\"MODULE_NOT_FOUND\"===n.code)return null;throw n}var r}},\n", " function _(e,t,i,n,s){var a;n();const x=e(133),_=e(120);class l extends x.BaseTextView{initialize(){super.initialize(),this._has_finished=!0}graphics(){return new _.TextBox({text:this.model.text})}}i.PlainTextView=l,l.__name__=\"PlainTextView\";class r extends x.BaseText{constructor(e){super(e)}}i.PlainText=r,a=r,r.__name__=\"PlainText\",a.prototype.default_view=l},\n", " function _(t,s,o,e,i){e();const r=t(1);var a;const l=t(128),_=t(141),n=t(142),p=(0,r.__importStar)(t(48)),c=t(20),h=t(120),m=t(8);class u extends l.AxisView{_paint(t,s,o){this._draw_group_separators(t,s,o)}_draw_group_separators(t,s,o){const[e]=this.ranges,[i,r]=this.computed_bounds;if(!e.tops||e.tops.length<2||!this.visuals.separator_line.doit)return;const a=this.dimension,l=(a+1)%2,_=[[],[]];let n=0;for(let t=0;ti&&pnew h.GraphicsBoxes(t.map((t=>(0,m.isString)(t)?new h.TextBox({text:t}):t))),_=t=>l(this.model.formatter.doFormat(t,this));if(1==t.levels){const t=_(i.major);a.push([t,r.major,this.model.major_label_orientation,this.visuals.major_label_text])}else if(2==t.levels){const t=_(i.major.map((t=>t[1])));a.push([t,r.major,this.model.major_label_orientation,this.visuals.major_label_text]),a.push([l(i.tops),r.tops,this.model.group_label_orientation,this.visuals.group_text])}else if(3==t.levels){const t=_(i.major.map((t=>t[2]))),s=i.mids.map((t=>t[1]));a.push([t,r.major,this.model.major_label_orientation,this.visuals.major_label_text]),a.push([l(s),r.mids,this.model.subgroup_label_orientation,this.visuals.subgroup_text]),a.push([l(i.tops),r.tops,this.model.group_label_orientation,this.visuals.group_text])}return a}get tick_coords(){const t=this.dimension,s=(t+1)%2,[o]=this.ranges,[e,i]=this.computed_bounds,r=this.model.ticker.get_ticks(e,i,o,this.loc),a={major:[[],[]],mids:[[],[]],tops:[[],[]],minor:[[],[]]};return a.major[t]=r.major,a.major[s]=r.major.map((()=>this.loc)),3==o.levels&&(a.mids[t]=r.mids,a.mids[s]=r.mids.map((()=>this.loc))),o.levels>1&&(a.tops[t]=r.tops,a.tops[s]=r.tops.map((()=>this.loc))),a}}o.CategoricalAxisView=u,u.__name__=\"CategoricalAxisView\";class d extends l.Axis{constructor(t){super(t)}}o.CategoricalAxis=d,a=d,d.__name__=\"CategoricalAxis\",a.prototype.default_view=u,a.mixins([[\"separator_\",p.Line],[\"group_\",p.Text],[\"subgroup_\",p.Text]]),a.define((({Number:t,Or:s})=>({group_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"],subgroup_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"]}))),a.override({ticker:()=>new _.CategoricalTicker,formatter:()=>new n.CategoricalTickFormatter,separator_line_color:\"lightgrey\",separator_line_width:2,group_text_font_style:\"bold\",group_text_font_size:\"11px\",group_text_color:\"grey\",subgroup_text_font_style:\"bold\",subgroup_text_font_size:\"11px\"})},\n", " function _(t,c,o,s,e){s();const r=t(130);class i extends r.Ticker{constructor(t){super(t)}get_ticks(t,c,o,s){var e,r;return{major:this._collect(o.factors,o,t,c),minor:[],tops:this._collect(null!==(e=o.tops)&&void 0!==e?e:[],o,t,c),mids:this._collect(null!==(r=o.mids)&&void 0!==r?r:[],o,t,c)}}_collect(t,c,o,s){const e=[];for(const r of t){const t=c.synthetic(r);t>o&&tnew _.DatetimeTicker,formatter:()=>new m.DatetimeTickFormatter})},\n", " function _(e,i,s,n,r){var t;n();const a=e(143),o=e(146),c=e(147);class _ extends a.ContinuousAxisView{}s.LinearAxisView=_,_.__name__=\"LinearAxisView\";class u extends a.ContinuousAxis{constructor(e){super(e)}}s.LinearAxis=u,t=u,u.__name__=\"LinearAxis\",t.prototype.default_view=_,t.override({ticker:()=>new c.BasicTicker,formatter:()=>new o.BasicTickFormatter})},\n", " function _(i,t,e,n,o){var r;n();const s=i(131),c=i(34);function _(i){let t=\"\";for(const e of i)t+=\"-\"==e?\"\\u2212\":e;return t}e.unicode_replace=_;class a extends s.TickFormatter{constructor(i){super(i),this.last_precision=3}get scientific_limit_low(){return 10**this.power_limit_low}get scientific_limit_high(){return 10**this.power_limit_high}_need_sci(i){if(!this.use_scientific)return!1;const{scientific_limit_high:t}=this,{scientific_limit_low:e}=this,n=i.length<2?0:Math.abs(i[1]-i[0])/1e4;for(const o of i){const i=Math.abs(o);if(!(i<=n)&&(i>=t||i<=e))return!0}return!1}_format_with_precision(i,t,e){return t?i.map((i=>_(i.toExponential(e)))):i.map((i=>_((0,c.to_fixed)(i,e))))}_auto_precision(i,t){const e=new Array(i.length),n=this.last_precision<=15;i:for(let o=this.last_precision;n?o<=15:o>=1;n?o++:o--){if(t){e[0]=i[0].toExponential(o);for(let t=1;t({precision:[n(t,e),\"auto\"],use_scientific:[i,!0],power_limit_high:[t,5],power_limit_low:[t,-3]})))},\n", " function _(c,e,s,i,n){i();const r=c(148);class t extends r.AdaptiveTicker{constructor(c){super(c)}}s.BasicTicker=t,t.__name__=\"BasicTicker\"},\n", " function _(t,i,a,s,e){var n;s();const r=t(149),_=t(9),l=t(10);class h extends r.ContinuousTicker{constructor(t){super(t)}get_min_interval(){return this.min_interval}get_max_interval(){var t;return null!==(t=this.max_interval)&&void 0!==t?t:1/0}initialize(){super.initialize();const t=(0,_.nth)(this.mantissas,-1)/this.base,i=(0,_.nth)(this.mantissas,0)*this.base;this.extended_mantissas=[t,...this.mantissas,i],this.base_factor=0===this.get_min_interval()?1:this.get_min_interval()}get_interval(t,i,a){const s=i-t,e=this.get_ideal_interval(t,i,a),n=Math.floor((0,l.log)(e/this.base_factor,this.base)),r=this.base**n*this.base_factor,h=this.extended_mantissas,m=h.map((t=>Math.abs(a-s/(t*r)))),v=h[(0,_.argmin)(m)]*r;return(0,l.clamp)(v,this.get_min_interval(),this.get_max_interval())}}a.AdaptiveTicker=h,n=h,h.__name__=\"AdaptiveTicker\",n.define((({Number:t,Array:i,Nullable:a})=>({base:[t,10],mantissas:[i(t),[1,2,5]],min_interval:[t,0],max_interval:[a(t),null]})))},\n", " function _(t,n,i,s,e){var o;s();const r=t(130),c=t(9);class _ extends r.Ticker{constructor(t){super(t)}get_ticks(t,n,i,s){return this.get_ticks_no_defaults(t,n,s,this.desired_num_ticks)}get_ticks_no_defaults(t,n,i,s){const e=this.get_interval(t,n,s),o=Math.floor(t/e),r=Math.ceil(n/e);let _;_=isFinite(o)&&isFinite(r)?(0,c.range)(o,r+1):[];const u=_.map((t=>t*e)).filter((i=>t<=i&&i<=n)),a=this.num_minor_ticks,f=[];if(a>0&&u.length>0){const i=e/a,s=(0,c.range)(0,a).map((t=>t*i));for(const i of s.slice(1)){const s=u[0]-i;t<=s&&s<=n&&f.push(s)}for(const i of u)for(const e of s){const s=i+e;t<=s&&s<=n&&f.push(s)}}return{major:u,minor:f}}get_ideal_interval(t,n,i){return(n-t)/i}}i.ContinuousTicker=_,o=_,_.__name__=\"ContinuousTicker\",o.define((({Int:t})=>({num_minor_ticks:[t,5],desired_num_ticks:[t,6]})))},\n", " function _(s,t,e,n,i){n();var r;const o=(0,s(1).__importDefault)(s(151)),a=s(131),c=s(19),u=s(152),m=s(9),h=s(8);function d(s){return(0,o.default)(s,\"%Y %m %d %H %M %S\").split(/\\s+/).map((s=>parseInt(s,10)))}function l(s,t){if((0,h.isFunction)(t))return t(s);{const e=(0,u.sprintf)(\"$1%06d\",function(s){return Math.round(s/1e3%1*1e6)}(s));return-1==(t=t.replace(/((^|[^%])(%%)*)%f/,e)).indexOf(\"%\")?t:(0,o.default)(s,t)}}const f=[\"microseconds\",\"milliseconds\",\"seconds\",\"minsec\",\"minutes\",\"hourmin\",\"hours\",\"days\",\"months\",\"years\"];class _ extends a.TickFormatter{constructor(s){super(s),this.strip_leading_zeros=!0}initialize(){super.initialize(),this._update_width_formats()}_update_width_formats(){const s=+(0,o.default)(new Date),t=function(t){const e=t.map((t=>l(s,t).length)),n=(0,m.sort_by)((0,m.zip)(e,t),(([s])=>s));return(0,m.unzip)(n)};this._width_formats={microseconds:t(this.microseconds),milliseconds:t(this.milliseconds),seconds:t(this.seconds),minsec:t(this.minsec),minutes:t(this.minutes),hourmin:t(this.hourmin),hours:t(this.hours),days:t(this.days),months:t(this.months),years:t(this.years)}}_get_resolution_str(s,t){const e=1.1*s;switch(!1){case!(e<.001):return\"microseconds\";case!(e<1):return\"milliseconds\";case!(e<60):return t>=60?\"minsec\":\"seconds\";case!(e<3600):return t>=3600?\"hourmin\":\"minutes\";case!(e<86400):return\"hours\";case!(e<2678400):return\"days\";case!(e<31536e3):return\"months\";default:return\"years\"}}doFormat(s,t){if(0==s.length)return[];const e=Math.abs(s[s.length-1]-s[0])/1e3,n=e/(s.length-1),i=this._get_resolution_str(n,e),[,[r]]=this._width_formats[i],o=[],a=f.indexOf(i),u={};for(const s of f)u[s]=0;u.seconds=5,u.minsec=4,u.minutes=4,u.hourmin=3,u.hours=3;for(const t of s){let s,e;try{e=d(t),s=l(t,r)}catch(s){c.logger.warn(`unable to format tick for timestamp value ${t}`),c.logger.warn(` - ${s}`),o.push(\"ERR\");continue}let n=!1,m=a;for(;0==e[u[f[m]]];){let r;if(m+=1,m==f.length)break;if((\"minsec\"==i||\"hourmin\"==i)&&!n){if(\"minsec\"==i&&0==e[4]&&0!=e[5]||\"hourmin\"==i&&0==e[3]&&0!=e[4]){r=this._width_formats[f[a-1]][1][0],s=l(t,r);break}n=!0}r=this._width_formats[f[m]][1][0],s=l(t,r)}if(this.strip_leading_zeros){let t=s.replace(/^0+/g,\"\");t!=s&&isNaN(parseInt(t))&&(t=`0${t}`),o.push(t)}else o.push(s)}return o}}e.DatetimeTickFormatter=_,r=_,_.__name__=\"DatetimeTickFormatter\",r.define((({String:s,Array:t})=>({microseconds:[t(s),[\"%fus\"]],milliseconds:[t(s),[\"%3Nms\",\"%S.%3Ns\"]],seconds:[t(s),[\"%Ss\"]],minsec:[t(s),[\":%M:%S\"]],minutes:[t(s),[\":%M\",\"%Mm\"]],hourmin:[t(s),[\"%H:%M\"]],hours:[t(s),[\"%Hh\",\"%H:%M\"]],days:[t(s),[\"%m/%d\",\"%a%d\"]],months:[t(s),[\"%m/%Y\",\"%b %Y\"]],years:[t(s),[\"%Y\"]]})))},\n", " function _(e,t,n,r,o){!function(e){\"object\"==typeof t&&t.exports?t.exports=e():\"function\"==typeof define?define(e):this.tz=e()}((function(){function e(e,t,n){var r,o=t.day[1];do{r=new Date(Date.UTC(n,t.month,Math.abs(o++)))}while(t.day[0]<7&&r.getUTCDay()!=t.day[0]);return(r={clock:t.clock,sort:r.getTime(),rule:t,save:6e4*t.save,offset:e.offset})[r.clock]=r.sort+6e4*t.time,r.posix?r.wallclock=r[r.clock]+(e.offset+t.saved):r.posix=r[r.clock]-(e.offset+t.saved),r}function t(t,n,r){var o,a,u,i,l,s,c,f=t[t.zone],h=[],T=new Date(r).getUTCFullYear(),g=1;for(o=1,a=f.length;o=T-g;--c)for(o=0,a=s.length;o=h[o][n]&&h[o][h[o].clock]>u[h[o].clock]&&(i=h[o])}return i&&((l=/^(.*)\\/(.*)$/.exec(u.format))?i.abbrev=l[i.save?2:1]:i.abbrev=u.format.replace(/%s/,i.rule.letter)),i||u}function n(e,n){return\"UTC\"==e.zone?n:(e.entry=t(e,\"posix\",n),n+e.entry.offset+e.entry.save)}function r(e,n){return\"UTC\"==e.zone?n:(e.entry=r=t(e,\"wallclock\",n),0<(o=n-r.wallclock)&&o9)t+=s*l[c-10];else{if(a=new Date(n(e,t)),c<7)for(;s;)a.setUTCDate(a.getUTCDate()+i),a.getUTCDay()==c&&(s-=i);else 7==c?a.setUTCFullYear(a.getUTCFullYear()+s):8==c?a.setUTCMonth(a.getUTCMonth()+s):a.setUTCDate(a.getUTCDate()+s);null==(t=r(e,a.getTime()))&&(t=r(e,a.getTime()+864e5*i)-864e5*i)}return t}var a={clock:function(){return+new Date},zone:\"UTC\",entry:{abbrev:\"UTC\",offset:0,save:0},UTC:1,z:function(e,t,n,r){var o,a,u=this.entry.offset+this.entry.save,i=Math.abs(u/1e3),l=[],s=3600;for(o=0;o<3;o++)l.push((\"0\"+Math.floor(i/s)).slice(-2)),i%=s,s/=60;return\"^\"!=n||u?(\"^\"==n&&(r=3),3==r?(a=(a=l.join(\":\")).replace(/:00$/,\"\"),\"^\"!=n&&(a=a.replace(/:00$/,\"\"))):r?(a=l.slice(0,r+1).join(\":\"),\"^\"==n&&(a=a.replace(/:00$/,\"\"))):a=l.slice(0,2).join(\"\"),a=(a=(u<0?\"-\":\"+\")+a).replace(/([-+])(0)/,{_:\" $1\",\"-\":\"$1\"}[n]||\"$1$2\")):\"Z\"},\"%\":function(e){return\"%\"},n:function(e){return\"\\n\"},t:function(e){return\"\\t\"},U:function(e){return s(e,0)},W:function(e){return s(e,1)},V:function(e){return c(e)[0]},G:function(e){return c(e)[1]},g:function(e){return c(e)[1]%100},j:function(e){return Math.floor((e.getTime()-Date.UTC(e.getUTCFullYear(),0))/864e5)+1},s:function(e){return Math.floor(e.getTime()/1e3)},C:function(e){return Math.floor(e.getUTCFullYear()/100)},N:function(e){return e.getTime()%1e3*1e6},m:function(e){return e.getUTCMonth()+1},Y:function(e){return e.getUTCFullYear()},y:function(e){return e.getUTCFullYear()%100},H:function(e){return e.getUTCHours()},M:function(e){return e.getUTCMinutes()},S:function(e){return e.getUTCSeconds()},e:function(e){return e.getUTCDate()},d:function(e){return e.getUTCDate()},u:function(e){return e.getUTCDay()||7},w:function(e){return e.getUTCDay()},l:function(e){return e.getUTCHours()%12||12},I:function(e){return e.getUTCHours()%12||12},k:function(e){return e.getUTCHours()},Z:function(e){return this.entry.abbrev},a:function(e){return this[this.locale].day.abbrev[e.getUTCDay()]},A:function(e){return this[this.locale].day.full[e.getUTCDay()]},h:function(e){return this[this.locale].month.abbrev[e.getUTCMonth()]},b:function(e){return this[this.locale].month.abbrev[e.getUTCMonth()]},B:function(e){return this[this.locale].month.full[e.getUTCMonth()]},P:function(e){return this[this.locale].meridiem[Math.floor(e.getUTCHours()/12)].toLowerCase()},p:function(e){return this[this.locale].meridiem[Math.floor(e.getUTCHours()/12)]},R:function(e,t){return this.convert([t,\"%H:%M\"])},T:function(e,t){return this.convert([t,\"%H:%M:%S\"])},D:function(e,t){return this.convert([t,\"%m/%d/%y\"])},F:function(e,t){return this.convert([t,\"%Y-%m-%d\"])},x:function(e,t){return this.convert([t,this[this.locale].date])},r:function(e,t){return this.convert([t,this[this.locale].time12||\"%I:%M:%S\"])},X:function(e,t){return this.convert([t,this[this.locale].time24])},c:function(e,t){return this.convert([t,this[this.locale].dateTime])},convert:function(e){if(!e.length)return\"1.0.23\";var t,a,u,l,s,c=Object.create(this),f=[];for(t=0;t=o?Math.floor((n-o)/7)+1:0}function c(e){var t,n,r;return n=e.getUTCFullYear(),t=new Date(Date.UTC(n,0)).getUTCDay(),(r=s(e,1)+(t>1&&t<=4?1:0))?53!=r||4==t||3==t&&29==new Date(n,1,29).getDate()?[r,e.getUTCFullYear()]:[1,e.getUTCFullYear()+1]:(n=e.getUTCFullYear()-1,[r=4==(t=new Date(Date.UTC(n,0)).getUTCDay())||3==t&&29==new Date(n,1,29).getDate()?53:52,e.getUTCFullYear()-1])}return u=u.toLowerCase().split(\"|\"),\"delmHMSUWVgCIky\".replace(/./g,(function(e){a[e].pad=2})),a.N.pad=9,a.j.pad=3,a.k.style=\"_\",a.l.style=\"_\",a.e.style=\"_\",function(){return a.convert(arguments)}}))},\n", " function _(r,t,n,e,i){e();const u=r(1),a=(0,u.__importStar)(r(153)),f=r(154),o=(0,u.__importDefault)(r(151)),l=r(21),s=r(8);function c(r,...t){return(0,f.sprintf)(r,...t)}function m(r,t,n){if((0,s.isNumber)(r)){return c((()=>{switch(!1){case Math.floor(r)!=r:return\"%d\";case!(Math.abs(r)>.1&&Math.abs(r)<1e3):return\"%0.3f\";default:return\"%0.3e\"}})(),r)}return`${r}`}function _(r,t,e){if(null==t)return m;if(null!=e&&r in e){const t=e[r];if((0,s.isString)(t)){if(t in n.DEFAULT_FORMATTERS)return n.DEFAULT_FORMATTERS[t];throw new Error(`Unknown tooltip field formatter type '${t}'`)}return function(r,n,e){return t.format(r,n,e)}}return n.DEFAULT_FORMATTERS.numeral}function p(r,t,n){const e=t.get_column(r);if(null==e)return null;if((0,s.isNumber)(n))return e[n];const i=e[n.index];if((0,s.isTypedArray)(i)||(0,s.isArray)(i)){if((0,s.isArray)(i[0])){return i[n.dim2][n.dim1]}return i[n.flat_index]}return i}function d(r,t,n,e){if(\"$\"==r[0]){return function(r,t){if(r in t)return t[r];throw new Error(`Unknown special variable '$${r}'`)}(r.substring(1),e)}return p(r.substring(1).replace(/[{}]/g,\"\"),t,n)}n.FormatterType=(0,l.Enum)(\"numeral\",\"printf\",\"datetime\"),n.DEFAULT_FORMATTERS={numeral:(r,t,n)=>a.format(r,t),datetime:(r,t,n)=>(0,o.default)(r,t),printf:(r,t,n)=>c(t,r)},n.sprintf=c,n.basic_formatter=m,n.get_formatter=_,n._get_column_value=p,n.get_value=d,n.replace_placeholders=function(r,t,n,e,i={},u){let a,f;if((0,s.isString)(r)?(a=r,f=!1):(a=r.html,f=!0),a=a.replace(/@\\$name/g,(r=>`@{${i.name}}`)),a=a.replace(/((?:\\$\\w+)|(?:@\\w+)|(?:@{(?:[^{}]+)}))(?:{([^{}]+)})?/g,((r,a,o)=>{const l=d(a,t,n,i);if(null==l)return u?u(\"???\"):\"???\";if(\"safe\"==o)return f=!0,`${l}`;const s=`${_(a,o,e)(l,o,i)}`;return u?u(s):s})),f){return[...(new DOMParser).parseFromString(a,\"text/html\").body.childNodes]}return a}},\n", " function _(e,n,t,r,i){\n", " /*!\n", " * numbro.js\n", " * version : 1.6.2\n", " * author : Företagsplatsen AB\n", " * license : MIT\n", " * http://www.foretagsplatsen.se\n", " */\n", " var a,o={},l=o,u=\"en-US\",c=null,s=\"0,0\";void 0!==n&&n.exports;function f(e){this._value=e}function d(e){var n,t=\"\";for(n=0;n-1?function(e,n){var t,r,i,a;return t=(a=e.toString()).split(\"e\")[0],i=a.split(\"e\")[1],a=t.split(\".\")[0]+(r=t.split(\".\")[1]||\"\")+d(i-r.length),n>0&&(a+=\".\"+d(n)),a}(e,n):(t(e*o)/o).toFixed(n),r&&(i=new RegExp(\"0{1,\"+r+\"}$\"),a=a.replace(i,\"\")),a}function p(e,n,t){var r;return r=n.indexOf(\"$\")>-1?function(e,n,t){var r,i,a=n,l=a.indexOf(\"$\"),c=a.indexOf(\"(\"),s=a.indexOf(\"+\"),f=a.indexOf(\"-\"),d=\"\",h=\"\";-1===a.indexOf(\"$\")?\"infix\"===o[u].currency.position?(h=o[u].currency.symbol,o[u].currency.spaceSeparated&&(h=\" \"+h+\" \")):o[u].currency.spaceSeparated&&(d=\" \"):a.indexOf(\" $\")>-1?(d=\" \",a=a.replace(\" $\",\"\")):a.indexOf(\"$ \")>-1?(d=\" \",a=a.replace(\"$ \",\"\")):a=a.replace(\"$\",\"\");if(i=m(e,a,t,h),-1===n.indexOf(\"$\"))switch(o[u].currency.position){case\"postfix\":i.indexOf(\")\")>-1?((i=i.split(\"\")).splice(-1,0,d+o[u].currency.symbol),i=i.join(\"\")):i=i+d+o[u].currency.symbol;break;case\"infix\":break;case\"prefix\":i.indexOf(\"(\")>-1||i.indexOf(\"-\")>-1?(i=i.split(\"\"),r=Math.max(c,f)+1,i.splice(r,0,o[u].currency.symbol+d),i=i.join(\"\")):i=o[u].currency.symbol+d+i;break;default:throw Error('Currency position should be among [\"prefix\", \"infix\", \"postfix\"]')}else l<=1?i.indexOf(\"(\")>-1||i.indexOf(\"+\")>-1||i.indexOf(\"-\")>-1?(r=1,(l-1?((i=i.split(\"\")).splice(-1,0,d+o[u].currency.symbol),i=i.join(\"\")):i=i+d+o[u].currency.symbol;return i}(e,n,t):n.indexOf(\"%\")>-1?function(e,n,t){var r,i=\"\";e*=100,n.indexOf(\" %\")>-1?(i=\" \",n=n.replace(\" %\",\"\")):n=n.replace(\"%\",\"\");(r=m(e,n,t)).indexOf(\")\")>-1?((r=r.split(\"\")).splice(-1,0,i+\"%\"),r=r.join(\"\")):r=r+i+\"%\";return r}(e,n,t):n.indexOf(\":\")>-1?function(e){var n=Math.floor(e/60/60),t=Math.floor((e-60*n*60)/60),r=Math.round(e-60*n*60-60*t);return n+\":\"+(t<10?\"0\"+t:t)+\":\"+(r<10?\"0\"+r:r)}(e):m(e,n,t),r}function m(e,n,t,r){var i,a,l,s,f,d,p,m,x,g,O,b,w,y,M,v,$,B=!1,E=!1,F=!1,k=\"\",U=!1,N=!1,S=!1,j=!1,D=!1,C=\"\",L=\"\",T=Math.abs(e),K=[\"B\",\"KiB\",\"MiB\",\"GiB\",\"TiB\",\"PiB\",\"EiB\",\"ZiB\",\"YiB\"],G=[\"B\",\"KB\",\"MB\",\"GB\",\"TB\",\"PB\",\"EB\",\"ZB\",\"YB\"],I=\"\",P=!1,R=!1;if(0===e&&null!==c)return c;if(!isFinite(e))return\"\"+e;if(0===n.indexOf(\"{\")){var W=n.indexOf(\"}\");if(-1===W)throw Error('Format should also contain a \"}\"');b=n.slice(1,W),n=n.slice(W+1)}else b=\"\";if(n.indexOf(\"}\")===n.length-1){var Y=n.indexOf(\"{\");if(-1===Y)throw Error('Format should also contain a \"{\"');w=n.slice(Y+1,-1),n=n.slice(0,Y+1)}else w=\"\";if(v=null===($=-1===n.indexOf(\".\")?n.match(/([0-9]+).*/):n.match(/([0-9]+)\\..*/))?-1:$[1].length,-1!==n.indexOf(\"-\")&&(P=!0),n.indexOf(\"(\")>-1?(B=!0,n=n.slice(1,-1)):n.indexOf(\"+\")>-1&&(E=!0,n=n.replace(/\\+/g,\"\")),n.indexOf(\"a\")>-1){if(g=n.split(\".\")[0].match(/[0-9]+/g)||[\"0\"],g=parseInt(g[0],10),U=n.indexOf(\"aK\")>=0,N=n.indexOf(\"aM\")>=0,S=n.indexOf(\"aB\")>=0,j=n.indexOf(\"aT\")>=0,D=U||N||S||j,n.indexOf(\" a\")>-1?(k=\" \",n=n.replace(\" a\",\"\")):n=n.replace(\"a\",\"\"),p=0===(p=(f=Math.floor(Math.log(T)/Math.LN10)+1)%3)?3:p,g&&0!==T&&(d=Math.floor(Math.log(T)/Math.LN10)+1-g,m=3*~~((Math.min(g,f)-p)/3),T/=Math.pow(10,m),-1===n.indexOf(\".\")&&g>3))for(n+=\"[.]\",M=(M=0===d?0:3*~~(d/3)-d)<0?M+3:M,i=0;i=Math.pow(10,12)&&!D||j?(k+=o[u].abbreviations.trillion,e/=Math.pow(10,12)):T=Math.pow(10,9)&&!D||S?(k+=o[u].abbreviations.billion,e/=Math.pow(10,9)):T=Math.pow(10,6)&&!D||N?(k+=o[u].abbreviations.million,e/=Math.pow(10,6)):(T=Math.pow(10,3)&&!D||U)&&(k+=o[u].abbreviations.thousand,e/=Math.pow(10,3)))}if(n.indexOf(\"b\")>-1)for(n.indexOf(\" b\")>-1?(C=\" \",n=n.replace(\" b\",\"\")):n=n.replace(\"b\",\"\"),s=0;s<=K.length;s++)if(a=Math.pow(1024,s),l=Math.pow(1024,s+1),e>=a&&e0&&(e/=a);break}if(n.indexOf(\"d\")>-1)for(n.indexOf(\" d\")>-1?(C=\" \",n=n.replace(\" d\",\"\")):n=n.replace(\"d\",\"\"),s=0;s<=G.length;s++)if(a=Math.pow(1e3,s),l=Math.pow(1e3,s+1),e>=a&&e0&&(e/=a);break}if(n.indexOf(\"o\")>-1&&(n.indexOf(\" o\")>-1?(L=\" \",n=n.replace(\" o\",\"\")):n=n.replace(\"o\",\"\"),o[u].ordinal&&(L+=o[u].ordinal(e))),n.indexOf(\"[.]\")>-1&&(F=!0,n=n.replace(\"[.]\",\".\")),x=e.toString().split(\".\")[0],O=n.split(\".\")[1],y=n.indexOf(\",\"),O){if(x=(I=-1!==O.indexOf(\"*\")?h(e,e.toString().split(\".\")[1].length,t):O.indexOf(\"[\")>-1?h(e,(O=(O=O.replace(\"]\",\"\")).split(\"[\"))[0].length+O[1].length,t,O[1].length):h(e,O.length,t)).split(\".\")[0],I.split(\".\")[1].length)I=(r?k+r:o[u].delimiters.decimal)+I.split(\".\")[1];else I=\"\";F&&0===Number(I.slice(1))&&(I=\"\")}else x=h(e,null,t);return x.indexOf(\"-\")>-1&&(x=x.slice(1),R=!0),x.length-1&&(x=x.toString().replace(/(\\d)(?=(\\d{3})+(?!\\d))/g,\"$1\"+o[u].delimiters.thousands)),0===n.indexOf(\".\")&&(x=\"\"),b+(n.indexOf(\"(\")2)&&(o.length<2?!!o[0].match(/^\\d+.*\\d$/)&&!o[0].match(u):1===o[0].length?!!o[0].match(/^\\d+$/)&&!o[0].match(u)&&!!o[1].match(/^\\d+$/):!!o[0].match(/^\\d+.*\\d$/)&&!o[0].match(u)&&!!o[1].match(/^\\d+$/)))))},n.exports={format:function(e,n,t,r){return null!=t&&t!==a.culture()&&a.setCulture(t),p(Number(e),null!=n?n:s,null==r?Math.round:r)}}},\n", " function _(e,n,t,r,i){!function(){\"use strict\";var e={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\\x25]+/,modulo:/^\\x25{2}/,placeholder:/^\\x25(?:([1-9]\\d*)\\$|\\(([^)]+)\\))?(\\+)?(0|'[^$])?(-)?(\\d+)?(?:\\.(\\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\\d]*)/i,key_access:/^\\.([a-z_][a-z_\\d]*)/i,index_access:/^\\[(\\d+)\\]/,sign:/^[+-]/};function n(e){return i(a(e),arguments)}function r(e,t){return n.apply(null,[e].concat(t||[]))}function i(t,r){var i,s,a,o,p,c,l,u,f,d=1,g=t.length,y=\"\";for(s=0;s=0),o.type){case\"b\":i=parseInt(i,10).toString(2);break;case\"c\":i=String.fromCharCode(parseInt(i,10));break;case\"d\":case\"i\":i=parseInt(i,10);break;case\"j\":i=JSON.stringify(i,null,o.width?parseInt(o.width):0);break;case\"e\":i=o.precision?parseFloat(i).toExponential(o.precision):parseFloat(i).toExponential();break;case\"f\":i=o.precision?parseFloat(i).toFixed(o.precision):parseFloat(i);break;case\"g\":i=o.precision?String(Number(i.toPrecision(o.precision))):parseFloat(i);break;case\"o\":i=(parseInt(i,10)>>>0).toString(8);break;case\"s\":i=String(i),i=o.precision?i.substring(0,o.precision):i;break;case\"t\":i=String(!!i),i=o.precision?i.substring(0,o.precision):i;break;case\"T\":i=Object.prototype.toString.call(i).slice(8,-1).toLowerCase(),i=o.precision?i.substring(0,o.precision):i;break;case\"u\":i=parseInt(i,10)>>>0;break;case\"v\":i=i.valueOf(),i=o.precision?i.substring(0,o.precision):i;break;case\"x\":i=(parseInt(i,10)>>>0).toString(16);break;case\"X\":i=(parseInt(i,10)>>>0).toString(16).toUpperCase()}e.json.test(o.type)?y+=i:(!e.number.test(o.type)||u&&!o.sign?f=\"\":(f=u?\"+\":\"-\",i=i.toString().replace(e.sign,\"\")),c=o.pad_char?\"0\"===o.pad_char?\"0\":o.pad_char.charAt(1):\" \",l=o.width-(f+i).length,p=o.width&&l>0?c.repeat(l):\"\",y+=o.align?f+i+p:\"0\"===c?f+p+i:p+f+i)}return y}var s=Object.create(null);function a(n){if(s[n])return s[n];for(var t,r=n,i=[],a=0;r;){if(null!==(t=e.text.exec(r)))i.push(t[0]);else if(null!==(t=e.modulo.exec(r)))i.push(\"%\");else{if(null===(t=e.placeholder.exec(r)))throw new SyntaxError(\"[sprintf] unexpected placeholder\");if(t[2]){a|=1;var o=[],p=t[2],c=[];if(null===(c=e.key.exec(p)))throw new SyntaxError(\"[sprintf] failed to parse named argument key\");for(o.push(c[1]);\"\"!==(p=p.substring(c[0].length));)if(null!==(c=e.key_access.exec(p)))o.push(c[1]);else{if(null===(c=e.index_access.exec(p)))throw new SyntaxError(\"[sprintf] failed to parse named argument key\");o.push(c[1])}t[2]=o}else a|=2;if(3===a)throw new Error(\"[sprintf] mixing positional and named placeholders is not (yet) supported\");i.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return s[n]=i}void 0!==t&&(t.sprintf=n,t.vsprintf=r),\"undefined\"!=typeof window&&(window.sprintf=n,window.vsprintf=r,\"function\"==typeof define&&define.amd&&define((function(){return{sprintf:n,vsprintf:r}})))}()},\n", " function _(e,n,i,a,s){var r;a();const t=e(9),c=e(148),m=e(156),_=e(157),k=e(160),o=e(161),T=e(159);class w extends m.CompositeTicker{constructor(e){super(e)}}i.DatetimeTicker=w,r=w,w.__name__=\"DatetimeTicker\",r.override({num_minor_ticks:0,tickers:()=>[new c.AdaptiveTicker({mantissas:[1,2,5],base:10,min_interval:0,max_interval:500*T.ONE_MILLI,num_minor_ticks:0}),new c.AdaptiveTicker({mantissas:[1,2,5,10,15,20,30],base:60,min_interval:T.ONE_SECOND,max_interval:30*T.ONE_MINUTE,num_minor_ticks:0}),new c.AdaptiveTicker({mantissas:[1,2,4,6,8,12],base:24,min_interval:T.ONE_HOUR,max_interval:12*T.ONE_HOUR,num_minor_ticks:0}),new _.DaysTicker({days:(0,t.range)(1,32)}),new _.DaysTicker({days:(0,t.range)(1,31,3)}),new _.DaysTicker({days:[1,8,15,22]}),new _.DaysTicker({days:[1,15]}),new k.MonthsTicker({months:(0,t.range)(0,12,1)}),new k.MonthsTicker({months:(0,t.range)(0,12,2)}),new k.MonthsTicker({months:(0,t.range)(0,12,4)}),new k.MonthsTicker({months:(0,t.range)(0,12,6)}),new o.YearsTicker({})]})},\n", " function _(t,e,i,r,s){var n;r();const _=t(149),a=t(9);class l extends _.ContinuousTicker{constructor(t){super(t)}get min_intervals(){return this.tickers.map((t=>t.get_min_interval()))}get max_intervals(){return this.tickers.map((t=>t.get_max_interval()))}get_min_interval(){return this.min_intervals[0]}get_max_interval(){return this.max_intervals[0]}get_best_ticker(t,e,i){const r=e-t,s=this.get_ideal_interval(t,e,i),n=[(0,a.sorted_index)(this.min_intervals,s)-1,(0,a.sorted_index)(this.max_intervals,s)],_=[this.min_intervals[n[0]],this.max_intervals[n[1]]].map((t=>Math.abs(i-r/t)));let l;if((0,a.is_empty)(_.filter((t=>!isNaN(t)))))l=this.tickers[0];else{const t=n[(0,a.argmin)(_)];l=this.tickers[t]}return l}get_interval(t,e,i){return this.get_best_ticker(t,e,i).get_interval(t,e,i)}get_ticks_no_defaults(t,e,i,r){return this.get_best_ticker(t,e,r).get_ticks_no_defaults(t,e,i,r)}}i.CompositeTicker=l,n=l,l.__name__=\"CompositeTicker\",n.define((({Array:t,Ref:e})=>({tickers:[t(e(_.ContinuousTicker)),[]]})))},\n", " function _(t,e,n,s,o){var a;s();const i=t(158),r=t(159),c=t(9);class _ extends i.SingleIntervalTicker{constructor(t){super(t)}initialize(){super.initialize();const t=this.days;t.length>1?this.interval=(t[1]-t[0])*r.ONE_DAY:this.interval=31*r.ONE_DAY}get_ticks_no_defaults(t,e,n,s){const o=function(t,e){const n=(0,r.last_month_no_later_than)(new Date(t)),s=(0,r.last_month_no_later_than)(new Date(e));s.setUTCMonth(s.getUTCMonth()+1);const o=[],a=n;for(;o.push((0,r.copy_date)(a)),a.setUTCMonth(a.getUTCMonth()+1),!(a>s););return o}(t,e),a=this.days,i=this.interval,_=(0,c.concat)(o.map((t=>((t,e)=>{const n=t.getUTCMonth(),s=[];for(const o of a){const a=(0,r.copy_date)(t);a.setUTCDate(o),new Date(a.getTime()+e/2).getUTCMonth()==n&&s.push(a)}return s})(t,i))));return{major:_.map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.DaysTicker=_,a=_,_.__name__=\"DaysTicker\",a.define((({Int:t,Array:e})=>({days:[e(t),[]]}))),a.override({num_minor_ticks:0})},\n", " function _(e,n,t,r,i){var a;r();const l=e(149);class s extends l.ContinuousTicker{constructor(e){super(e)}get_interval(e,n,t){return this.interval}get_min_interval(){return this.interval}get_max_interval(){return this.interval}}t.SingleIntervalTicker=s,a=s,s.__name__=\"SingleIntervalTicker\",a.define((({Number:e})=>({interval:[e]})))},\n", " function _(t,n,e,_,E){function N(t){return new Date(t.getTime())}function O(t){const n=N(t);return n.setUTCDate(1),n.setUTCHours(0),n.setUTCMinutes(0),n.setUTCSeconds(0),n.setUTCMilliseconds(0),n}_(),e.ONE_MILLI=1,e.ONE_SECOND=1e3,e.ONE_MINUTE=60*e.ONE_SECOND,e.ONE_HOUR=60*e.ONE_MINUTE,e.ONE_DAY=24*e.ONE_HOUR,e.ONE_MONTH=30*e.ONE_DAY,e.ONE_YEAR=365*e.ONE_DAY,e.copy_date=N,e.last_month_no_later_than=O,e.last_year_no_later_than=function(t){const n=O(t);return n.setUTCMonth(0),n}},\n", " function _(t,e,n,a,r){var s;a();const i=t(158),o=t(159),l=t(9);class _ extends i.SingleIntervalTicker{constructor(t){super(t)}initialize(){super.initialize();const t=this.months;t.length>1?this.interval=(t[1]-t[0])*o.ONE_MONTH:this.interval=12*o.ONE_MONTH}get_ticks_no_defaults(t,e,n,a){const r=function(t,e){const n=(0,o.last_year_no_later_than)(new Date(t)),a=(0,o.last_year_no_later_than)(new Date(e));a.setUTCFullYear(a.getUTCFullYear()+1);const r=[],s=n;for(;r.push((0,o.copy_date)(s)),s.setUTCFullYear(s.getUTCFullYear()+1),!(s>a););return r}(t,e),s=this.months;return{major:(0,l.concat)(r.map((t=>s.map((e=>{const n=(0,o.copy_date)(t);return n.setUTCMonth(e),n}))))).map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.MonthsTicker=_,s=_,_.__name__=\"MonthsTicker\",s.define((({Int:t,Array:e})=>({months:[e(t),[]]})))},\n", " function _(e,t,a,i,r){i();const n=e(147),_=e(158),s=e(159);class c extends _.SingleIntervalTicker{constructor(e){super(e)}initialize(){super.initialize(),this.interval=s.ONE_YEAR,this.basic_ticker=new n.BasicTicker({num_minor_ticks:0})}get_ticks_no_defaults(e,t,a,i){const r=(0,s.last_year_no_later_than)(new Date(e)).getUTCFullYear(),n=(0,s.last_year_no_later_than)(new Date(t)).getUTCFullYear();return{major:this.basic_ticker.get_ticks_no_defaults(r,n,a,i).major.map((e=>Date.UTC(e,0,1))).filter((a=>e<=a&&a<=t)),minor:[]}}}a.YearsTicker=c,c.__name__=\"YearsTicker\"},\n", " function _(e,o,i,s,t){var n;s();const r=e(143),_=e(163),c=e(164);class a extends r.ContinuousAxisView{}i.LogAxisView=a,a.__name__=\"LogAxisView\";class u extends r.ContinuousAxis{constructor(e){super(e)}}i.LogAxis=u,n=u,u.__name__=\"LogAxis\",n.prototype.default_view=a,n.override({ticker:()=>new c.LogTicker,formatter:()=>new _.LogTickFormatter})},\n", " function _(e,t,n,o,r){var i;o();const a=e(131),s=e(146),c=e(164),l=e(120),{abs:u,log:x,round:_}=Math;class p extends a.TickFormatter{constructor(e){super(e)}initialize(){super.initialize(),this.basic_formatter=new s.BasicTickFormatter}format_graphics(e,t){var n,o;if(0==e.length)return[];const r=null!==(o=null===(n=this.ticker)||void 0===n?void 0:n.base)&&void 0!==o?o:10,i=this._exponents(e,r);return null==i?this.basic_formatter.format_graphics(e,t):i.map((e=>{if(u(e)u(e)({ticker:[n(t(c.LogTicker)),null],min_exponent:[e,0]})))},\n", " function _(t,o,e,s,n){var r;s();const i=t(148),a=t(9);class c extends i.AdaptiveTicker{constructor(t){super(t)}get_ticks_no_defaults(t,o,e,s){const n=this.num_minor_ticks,r=[],i=this.base,c=Math.log(t)/Math.log(i),f=Math.log(o)/Math.log(i),l=f-c;let h;if(isFinite(l))if(l<2){const e=this.get_interval(t,o,s),i=Math.floor(t/e),c=Math.ceil(o/e);if(h=(0,a.range)(i,c+1).filter((t=>0!=t)).map((t=>t*e)).filter((e=>t<=e&&e<=o)),n>0&&h.length>0){const t=e/n,o=(0,a.range)(0,n).map((o=>o*t));for(const t of o.slice(1))r.push(h[0]-t);for(const t of h)for(const e of o)r.push(t+e)}}else{const t=Math.ceil(.999999*c),o=Math.floor(1.000001*f),e=Math.ceil((o-t)/9);if(h=(0,a.range)(t-1,o+1,e).map((t=>i**t)),n>0&&h.length>0){const t=i**e/n,o=(0,a.range)(1,n+1).map((o=>o*t));for(const t of o)r.push(h[0]/t);r.push(h[0]);for(const t of h)for(const e of o)r.push(t*e)}}else h=[];return{major:h.filter((e=>t<=e&&e<=o)),minor:r.filter((e=>t<=e&&e<=o))}}}e.LogTicker=c,r=c,c.__name__=\"LogTicker\",r.override({mantissas:[1,5]})},\n", " function _(e,r,t,i,a){var o;i();const s=e(128),c=e(145),n=e(166),_=e(167);class x extends s.AxisView{}t.MercatorAxisView=x,x.__name__=\"MercatorAxisView\";class d extends c.LinearAxis{constructor(e){super(e)}}t.MercatorAxis=d,o=d,d.__name__=\"MercatorAxis\",o.prototype.default_view=x,o.override({ticker:()=>new _.MercatorTicker({dimension:\"lat\"}),formatter:()=>new n.MercatorTickFormatter({dimension:\"lat\"})})},\n", " function _(r,t,e,o,n){var i;o();const c=r(146),s=r(20),a=r(78);class l extends c.BasicTickFormatter{constructor(r){super(r)}doFormat(r,t){if(null==this.dimension)throw new Error(\"MercatorTickFormatter.dimension not configured\");if(0==r.length)return[];const e=r.length,o=new Array(e);if(\"lon\"==this.dimension)for(let n=0;n({dimension:[r(s.LatLon),null]})))},\n", " function _(t,o,n,s,r){var e;s();const i=t(147),c=t(20),_=t(78);class a extends i.BasicTicker{constructor(t){super(t)}get_ticks_no_defaults(t,o,n,s){if(null==this.dimension)throw new Error(`${this}.dimension wasn't configured`);return[t,o]=(0,_.clip_mercator)(t,o,this.dimension),\"lon\"==this.dimension?this._get_ticks_lon(t,o,n,s):this._get_ticks_lat(t,o,n,s)}_get_ticks_lon(t,o,n,s){const[r]=_.wgs84_mercator.invert(t,n),[e,i]=_.wgs84_mercator.invert(o,n),c=super.get_ticks_no_defaults(r,e,n,s),a=[];for(const t of c.major)if((0,_.in_bounds)(t,\"lon\")){const[o]=_.wgs84_mercator.compute(t,i);a.push(o)}const m=[];for(const t of c.minor)if((0,_.in_bounds)(t,\"lon\")){const[o]=_.wgs84_mercator.compute(t,i);m.push(o)}return{major:a,minor:m}}_get_ticks_lat(t,o,n,s){const[,r]=_.wgs84_mercator.invert(n,t),[e,i]=_.wgs84_mercator.invert(n,o),c=super.get_ticks_no_defaults(r,i,n,s),a=[];for(const t of c.major)if((0,_.in_bounds)(t,\"lat\")){const[,o]=_.wgs84_mercator.compute(e,t);a.push(o)}const m=[];for(const t of c.minor)if((0,_.in_bounds)(t,\"lat\")){const[,o]=_.wgs84_mercator.compute(e,t);m.push(o)}return{major:a,minor:m}}}n.MercatorTicker=a,e=a,a.__name__=\"MercatorTicker\",e.define((({Nullable:t})=>({dimension:[t(c.LatLon),null]})))},\n", " function _(e,i,r,c,k){c(),k(\"AdaptiveTicker\",e(148).AdaptiveTicker),k(\"BasicTicker\",e(147).BasicTicker),k(\"CategoricalTicker\",e(141).CategoricalTicker),k(\"CompositeTicker\",e(156).CompositeTicker),k(\"ContinuousTicker\",e(149).ContinuousTicker),k(\"DatetimeTicker\",e(155).DatetimeTicker),k(\"DaysTicker\",e(157).DaysTicker),k(\"FixedTicker\",e(169).FixedTicker),k(\"LogTicker\",e(164).LogTicker),k(\"MercatorTicker\",e(167).MercatorTicker),k(\"MonthsTicker\",e(160).MonthsTicker),k(\"SingleIntervalTicker\",e(158).SingleIntervalTicker),k(\"Ticker\",e(130).Ticker),k(\"YearsTicker\",e(161).YearsTicker),k(\"BinnedTicker\",e(170).BinnedTicker)},\n", " function _(r,t,e,i,n){var s;i();const _=r(149);class c extends _.ContinuousTicker{constructor(r){super(r)}get_ticks_no_defaults(r,t,e,i){return{major:this.ticks,minor:this.minor_ticks}}get_interval(r,t,e){return 0}get_min_interval(){return 0}get_max_interval(){return 0}}e.FixedTicker=c,s=c,c.__name__=\"FixedTicker\",s.define((({Number:r,Array:t})=>({ticks:[t(r),[]],minor_ticks:[t(r),[]]})))},\n", " function _(e,n,t,r,i){var o;r();const a=e(130),s=e(171),c=e(12);class m extends a.Ticker{constructor(e){super(e)}get_ticks(e,n,t,r){const{binning:i}=this.mapper.metrics,o=Math.max(0,(0,c.left_edge_index)(e,i)),a=Math.min((0,c.left_edge_index)(n,i)+1,i.length-1),s=[];for(let e=o;e<=a;e++)s.push(i[e]);const{num_major_ticks:m}=this,_=[],h=\"auto\"==m?s.length:m,l=Math.max(1,Math.floor(s.length/h));for(let e=0;e({mapper:[n(s.ScanningColorMapper)],num_major_ticks:[t(e,r),8]})))},\n", " function _(n,e,i,r,o){r();const t=n(172),a=n(12);class c extends t.ContinuousColorMapper{constructor(n){super(n)}cmap(n,e,i,r,o){if(no.binning[o.binning.length-1])return r;return e[(0,a.left_edge_index)(n,o.binning)]}}i.ScanningColorMapper=c,c.__name__=\"ScanningColorMapper\"},\n", " function _(t,e,o,n,s){var l;n();const c=t(173),i=t(175),a=t(9),h=t(8);class r extends c.ColorMapper{constructor(t){super(t),this._scan_data=null}connect_signals(){super.connect_signals();const t=()=>{for(const[t]of this.domain)this.connect(t.view.change,(()=>this.update_data())),this.connect(t.data_source.selected.change,(()=>this.update_data()))};this.connect(this.properties.domain.change,(()=>t())),t()}update_data(){const{domain:t,palette:e}=this,o=[...this._collect(t)];this._scan_data=this.scan(o,e.length),this.metrics_change.emit(),this.change.emit()}get metrics(){return null==this._scan_data&&this.update_data(),this._scan_data}*_collect(t){for(const[e,o]of t)for(const t of(0,h.isArray)(o)?o:[o]){let o=e.data_source.get_column(t);o=e.view.indices.select(o);const n=e.view.masked,s=e.data_source.selected.indices;let l;if(null!=n&&s.length>0?l=(0,a.intersection)([...n],s):null!=n?l=[...n]:s.length>0&&(l=s),null!=l&&(o=(0,a.map)(l,(t=>o[t]))),o.length>0&&!(0,h.isNumber)(o[0]))for(const t of o)yield*t;else yield*o}}_v_compute(t,e,o,n){const{nan_color:s}=n;let{low_color:l,high_color:c}=n;null==l&&(l=o[0]),null==c&&(c=o[o.length-1]);const{domain:i}=this,h=(0,a.is_empty)(i)?t:[...this._collect(i)];this._scan_data=this.scan(h,o.length),this.metrics_change.emit();for(let n=0,i=t.length;n({high:[a(t),null],low:[a(t),null],high_color:[a(n),null],low_color:[a(n),null],domain:[c(l(o(i.GlyphRenderer),s(e,c(e)))),[]]})))},\n", " function _(e,r,t,n,o){var a;n();const c=e(174),i=e(15),_=e(24),l=e(22),s=e(27);function p(e){return(0,l.encode_rgba)((0,l.color2rgba)(e))}function u(e){const r=new Uint32Array(e.length);for(let t=0,n=e.length;te))),r}get rgba_mapper(){const e=this,r=u(this.palette),t=this._colors(p);return{v_compute(n){const o=new _.ColorArray(n.length);return e._v_compute(n,o,r,t),new Uint8ClampedArray((0,s.to_big_endian)(o).buffer)}}}_colors(e){return{nan_color:e(this.nan_color)}}}t.ColorMapper=h,a=h,h.__name__=\"ColorMapper\",a.define((({Color:e,Array:r})=>({palette:[r(e)],nan_color:[e,\"gray\"]})))},\n", " function _(r,e,n,s,o){s();const p=r(56);class t extends p.Transform{constructor(r){super(r)}compute(r){throw new Error(\"mapping single values is not supported\")}}n.Mapper=t,t.__name__=\"Mapper\"},\n", " function _(e,t,i,s,l){var h;s();const n=e(176),o=e(177),a=e(186),c=e(187),_=e(189),r=e(179),d=e(70),p=e(190),g=e(24),u=e(12),y=e(13),m=e(113),v=e(67),f={fill:{},line:{}},w={fill:{fill_alpha:.3,fill_color:\"grey\"},line:{line_alpha:.3,line_color:\"grey\"}},b={fill:{fill_alpha:.2},line:{}},V={fill:{fill_alpha:.2},line:{}};class x extends n.DataRendererView{get glyph_view(){return this.glyph}async lazy_initialize(){var e;await super.lazy_initialize();const t=this.model.glyph;this.glyph=await this.build_glyph_view(t);const i=\"fill\"in this.glyph.visuals,s=\"line\"in this.glyph.visuals,l=Object.assign({},t.attributes);function h(e){const h=(0,y.clone)(l);return i&&(0,y.extend)(h,e.fill),s&&(0,y.extend)(h,e.line),new t.constructor(h)}function n(e,t){return t instanceof r.Glyph?t:h(\"auto\"==t?e:{fill:{},line:{}})}delete l.id;let{selection_glyph:o,nonselection_glyph:a,hover_glyph:c,muted_glyph:_}=this.model;o=n(f,o),this.selection_glyph=await this.build_glyph_view(o),a=n(b,a),this.nonselection_glyph=await this.build_glyph_view(a),null!=c&&(this.hover_glyph=await this.build_glyph_view(c)),_=n(V,_),this.muted_glyph=await this.build_glyph_view(_);const d=n(w,\"auto\");this.decimated_glyph=await this.build_glyph_view(d),this.selection_glyph.set_base(this.glyph),this.nonselection_glyph.set_base(this.glyph),null===(e=this.hover_glyph)||void 0===e||e.set_base(this.glyph),this.muted_glyph.set_base(this.glyph),this.decimated_glyph.set_base(this.glyph),this.set_data()}async build_glyph_view(e){return(0,m.build_view)(e,{parent:this})}remove(){var e;this.glyph.remove(),this.selection_glyph.remove(),this.nonselection_glyph.remove(),null===(e=this.hover_glyph)||void 0===e||e.remove(),this.muted_glyph.remove(),this.decimated_glyph.remove(),super.remove()}connect_signals(){super.connect_signals();const e=()=>this.request_render(),t=()=>this.update_data();this.connect(this.model.change,e),this.connect(this.glyph.model.change,t),this.connect(this.selection_glyph.model.change,t),this.connect(this.nonselection_glyph.model.change,t),null!=this.hover_glyph&&this.connect(this.hover_glyph.model.change,t),this.connect(this.muted_glyph.model.change,t),this.connect(this.decimated_glyph.model.change,t),this.connect(this.model.data_source.change,t),this.connect(this.model.data_source.streaming,t),this.connect(this.model.data_source.patching,(e=>this.update_data(e))),this.connect(this.model.data_source.selected.change,e),this.connect(this.model.data_source._select,e),null!=this.hover_glyph&&this.connect(this.model.data_source.inspect,e),this.connect(this.model.properties.view.change,t),this.connect(this.model.view.properties.indices.change,t),this.connect(this.model.view.properties.masked.change,(()=>this.set_visuals())),this.connect(this.model.properties.visible.change,(()=>this.plot_view.invalidate_dataranges=!0));const{x_ranges:i,y_ranges:s}=this.plot_view.frame;for(const[,e]of i)e instanceof v.FactorRange&&this.connect(e.change,t);for(const[,e]of s)e instanceof v.FactorRange&&this.connect(e.change,t);const{transformchange:l,exprchange:h}=this.model.glyph;this.connect(l,t),this.connect(h,t)}_update_masked_indices(){const e=this.glyph.mask_data();return this.model.view.masked=e,e}update_data(e){this.set_data(e),this.request_render()}set_data(e){const t=this.model.data_source;this.all_indices=this.model.view.indices;const{all_indices:i}=this;this.glyph.set_data(t,i,e),this.set_visuals(),this._update_masked_indices();const{lod_factor:s}=this.plot_model,l=this.all_indices.count;this.decimated=new g.Indices(l);for(let e=0;e!n||n.is_empty()?[]:n.selected_glyph?this.model.view.convert_indices_from_subset(i):n.indices.length>0?n.indices:Object.keys(n.multiline_indices).map((e=>parseInt(e))))()),d=(0,u.filter)(i,(e=>r.has(t[e]))),{lod_threshold:p}=this.plot_model;let g,y,m;if(null!=this.model.document&&this.model.document.interactive_duration()>0&&!e&&null!=p&&t.length>p?(i=[...this.decimated],g=this.decimated_glyph,y=this.decimated_glyph,m=this.selection_glyph):(g=this.model.muted?this.muted_glyph:this.glyph,y=this.nonselection_glyph,m=this.selection_glyph),null!=this.hover_glyph&&d.length){const e=new Set(i);for(const t of d)e.delete(t);i=[...e]}if(h.length){const e={};for(const t of h)e[t]=!0;const l=new Array,n=new Array;if(this.glyph instanceof o.LineView)for(const i of t)null!=e[i]?l.push(i):n.push(i);else for(const s of i)null!=e[t[s]]?l.push(s):n.push(s);y.render(s,n),m.render(s,l),null!=this.hover_glyph&&(this.glyph instanceof o.LineView?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(d)):this.hover_glyph.render(s,d))}else if(this.glyph instanceof o.LineView)this.hover_glyph&&d.length?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(d)):g.render(s,t);else if(this.glyph instanceof a.PatchView||this.glyph instanceof c.HAreaView||this.glyph instanceof _.VAreaView)if(0==n.selected_glyphs.length||null==this.hover_glyph)g.render(s,t);else for(const e of n.selected_glyphs)e==this.glyph.model&&this.hover_glyph.render(s,t);else g.render(s,i),this.hover_glyph&&d.length&&this.hover_glyph.render(s,d);s.restore()}draw_legend(e,t,i,s,l,h,n,o){0!=this.glyph.data_size&&(null==o&&(o=this.model.get_reference_point(h,n)),this.glyph.draw_legend_for_index(e,{x0:t,x1:i,y0:s,y1:l},o))}hit_test(e){if(!this.model.visible)return null;const t=this.glyph.hit_test(e);return null==t?null:this.model.view.convert_selection_from_subset(t)}}i.GlyphRendererView=x,x.__name__=\"GlyphRendererView\";class G extends n.DataRenderer{constructor(e){super(e)}initialize(){super.initialize(),this.view.source!=this.data_source&&(this.view.source=this.data_source,this.view.compute_indices())}get_reference_point(e,t){if(null!=e){const i=this.data_source.get_column(e);if(null!=i)for(const[e,s]of Object.entries(this.view.indices_map))if(i[parseInt(e)]==t)return s}return 0}get_selection_manager(){return this.data_source.selection_manager}}i.GlyphRenderer=G,h=G,G.__name__=\"GlyphRenderer\",h.prototype.default_view=x,h.define((({Boolean:e,Auto:t,Or:i,Ref:s,Null:l,Nullable:h})=>({data_source:[s(d.ColumnarDataSource)],view:[s(p.CDSView),e=>new p.CDSView({source:e.data_source})],glyph:[s(r.Glyph)],hover_glyph:[h(s(r.Glyph)),null],nonselection_glyph:[i(s(r.Glyph),t,l),\"auto\"],selection_glyph:[i(s(r.Glyph),t,l),\"auto\"],muted_glyph:[i(s(r.Glyph),t,l),\"auto\"],muted:[e,!1]})))},\n", " function _(e,r,t,a,n){var s;a();const c=e(41);class _ extends c.RendererView{get xscale(){return this.coordinates.x_scale}get yscale(){return this.coordinates.y_scale}}t.DataRendererView=_,_.__name__=\"DataRendererView\";class i extends c.Renderer{constructor(e){super(e)}get selection_manager(){return this.get_selection_manager()}}t.DataRenderer=i,s=i,i.__name__=\"DataRenderer\",s.override({level:\"glyph\"})},\n", " function _(e,t,i,s,n){s();const l=e(1);var _;const r=e(178),o=e(184),a=(0,l.__importStar)(e(48)),h=(0,l.__importStar)(e(185)),c=e(72);class d extends r.XYGlyphView{async lazy_initialize(){await super.lazy_initialize();const{webgl:t}=this.renderer.plot_view.canvas_view;if(null==t?void 0:t.regl_wrapper.has_webgl){const{LineGL:i}=await Promise.resolve().then((()=>(0,l.__importStar)(e(421))));this.glglyph=new i(t.regl_wrapper,this)}}_render(e,t,i){const{sx:s,sy:n}=null!=i?i:this;let l=null;const _=e=>null!=l&&e-l!=1;let r=!0;e.beginPath();for(const i of t){const t=s[i],o=n[i];isFinite(t+o)?r||_(i)?(e.moveTo(t,o),r=!1):e.lineTo(t,o):r=!0,l=i}this.visuals.line.set_value(e),e.stroke()}_hit_point(e){const t=new c.Selection,i={x:e.sx,y:e.sy};let s=9999;const n=Math.max(2,this.line_width.value/2);for(let e=0,l=this.sx.length-1;e({x:[c.XCoordinateSpec,{field:\"x\"}],y:[c.YCoordinateSpec,{field:\"y\"}]})))},\n", " function _(e,t,s,i,n){i();const r=e(1),a=(0,r.__importStar)(e(18)),o=(0,r.__importStar)(e(65)),_=(0,r.__importStar)(e(45)),l=e(42),c=e(53),h=e(19),d=e(24),u=e(8),f=e(180),p=e(12),g=e(26),y=e(181),x=e(67),v=e(72),{abs:b,ceil:m}=Math;class w extends l.View{constructor(){super(...arguments),this._index=null,this._data_size=null,this._nohit_warned=new Set}get renderer(){return this.parent}get has_webgl(){return null!=this.glglyph}get index(){const{_index:e}=this;if(null!=e)return e;throw new Error(`${this}.index_data() wasn't called`)}get data_size(){const{_data_size:e}=this;if(null!=e)return e;throw new Error(`${this}.set_data() wasn't called`)}initialize(){super.initialize(),this.visuals=new _.Visuals(this)}request_render(){this.parent.request_render()}get canvas(){return this.renderer.parent.canvas_view}render(e,t,s){var i;null!=this.glglyph&&(this.renderer.needs_webgl_blit=this.glglyph.render(e,t,null!==(i=this.base)&&void 0!==i?i:this),this.renderer.needs_webgl_blit)||this._render(e,t,null!=s?s:this.base)}has_finished(){return!0}notify_finished(){this.renderer.notify_finished()}_bounds(e){return e}bounds(){return this._bounds(this.index.bbox)}log_bounds(){const{x0:e,x1:t}=this.index.bounds(o.positive_x()),{y0:s,y1:i}=this.index.bounds(o.positive_y());return this._bounds({x0:e,y0:s,x1:t,y1:i})}get_anchor_point(e,t,[s,i]){switch(e){case\"center\":case\"center_center\":{const[e,n]=this.scenterxy(t,s,i);return{x:e,y:n}}default:return null}}scenterx(e,t,s){return this.scenterxy(e,t,s)[0]}scentery(e,t,s){return this.scenterxy(e,t,s)[1]}sdist(e,t,s,i=\"edge\",n=!1){const r=t.length,a=new d.ScreenArray(r),o=e.s_compute;if(\"center\"==i)for(let e=0;em(e))),a}draw_legend_for_index(e,t,s){}hit_test(e){switch(e.type){case\"point\":if(null!=this._hit_point)return this._hit_point(e);break;case\"span\":if(null!=this._hit_span)return this._hit_span(e);break;case\"rect\":if(null!=this._hit_rect)return this._hit_rect(e);break;case\"poly\":if(null!=this._hit_poly)return this._hit_poly(e)}return this._nohit_warned.has(e.type)||(h.logger.debug(`'${e.type}' selection not available for ${this.model.type}`),this._nohit_warned.add(e.type)),null}_hit_rect_against_index(e){const{sx0:t,sx1:s,sy0:i,sy1:n}=e,[r,a]=this.renderer.coordinates.x_scale.r_invert(t,s),[o,_]=this.renderer.coordinates.y_scale.r_invert(i,n),l=[...this.index.indices({x0:r,x1:a,y0:o,y1:_})];return new v.Selection({indices:l})}_project_data(){}*_iter_visuals(){for(const e of this.visuals)for(const t of e)(t instanceof a.VectorSpec||t instanceof a.ScalarSpec)&&(yield t)}set_base(e){e!=this&&e instanceof this.constructor&&(this.base=e)}_configure(e,t){Object.defineProperty(this,(0,u.isString)(e)?e:e.attr,Object.assign({configurable:!0,enumerable:!0},t))}set_visuals(e,t){var s;for(const s of this._iter_visuals()){const{base:i}=this;if(null!=i){const e=i.model.properties[s.attr];if(null!=e&&(0,g.is_equal)(s.get_value(),e.get_value())){this._configure(s,{get:()=>i[`${s.attr}`]});continue}}const n=s.uniform(e).select(t);this._configure(s,{value:n})}for(const e of this.visuals)e.update();this._set_visuals(),null===(s=this.glglyph)||void 0===s||s.set_visuals_changed()}_set_visuals(){}set_data(e,t,s){var i;const{x_source:n,y_source:r}=this.renderer.coordinates,o=new Set(this._iter_visuals());this._data_size=t.count;for(const s of this.model)if((s instanceof a.VectorSpec||s instanceof a.ScalarSpec)&&!o.has(s))if(s instanceof a.BaseCoordinateSpec){const i=s.array(e);let o=t.select(i);const _=\"x\"==s.dimension?n:r;if(_ instanceof x.FactorRange)if(s instanceof a.CoordinateSpec)o=_.v_synthetic(o);else if(s instanceof a.CoordinateSeqSpec)for(let e=0;e{const s=new Uint32Array(r);for(let a=0;a>1;t[s]>i?e=s:n=s+1}return t[n]}class r extends d.default{get boxes(){return this._boxes}search_indices(i,t,n,e){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let s=this._boxes.length-4;const d=[],x=new o.Indices(this.numItems);for(;void 0!==s;){const o=Math.min(s+4*this.nodeSize,h(s,this._levelBounds));for(let h=s;h>2],r=this._boxes[h+0],l=this._boxes[h+1],a=this._boxes[h+2],_=this._boxes[h+3];na||t>_||(s<4*this.numItems?x.set(o):d.push(o)))}s=d.pop()}return x}}r.__name__=\"_FlatBush\";class l{constructor(i){this.index=null,i>0&&(this.index=new r(i))}add_rect(i,t,n,e){var s;isFinite(i+t+n+e)?null===(s=this.index)||void 0===s||s.add(i,t,n,e):this.add_empty()}add_point(i,t){var n;isFinite(i+t)?null===(n=this.index)||void 0===n||n.add(i,t,i,t):this.add_empty()}add_empty(){var i;null===(i=this.index)||void 0===i||i.add(1/0,1/0,-1/0,-1/0)}finish(){var i;null===(i=this.index)||void 0===i||i.finish()}_normalize(i){let{x0:t,y0:n,x1:e,y1:s}=i;return t>e&&([t,e]=[e,t]),n>s&&([n,s]=[s,n]),{x0:t,y0:n,x1:e,y1:s}}get bbox(){if(null==this.index)return(0,x.empty)();{const{minX:i,minY:t,maxX:n,maxY:e}=this.index;return{x0:i,y0:t,x1:n,y1:e}}}indices(i){if(null==this.index)return new o.Indices(0);{const{x0:t,y0:n,x1:e,y1:s}=this._normalize(i);return this.index.search_indices(t,n,e,s)}}bounds(i){const t=(0,x.empty)();if(null==this.index)return t;const{boxes:n}=this.index;for(const e of this.indices(i)){const s=n[4*e+0],d=n[4*e+1],o=n[4*e+2],x=n[4*e+3];s>=i.x0&&st.x1&&(t.x1=o),d>=i.y0&&dt.y1&&(t.y1=x)}return t}}n.SpatialIndex=l,l.__name__=\"SpatialIndex\"},\n", " function _(t,s,i,e,h){e();const n=(0,t(1).__importDefault)(t(183)),o=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array];class r{static from(t){if(!(t instanceof ArrayBuffer))throw new Error(\"Data must be an instance of ArrayBuffer.\");const[s,i]=new Uint8Array(t,0,2);if(251!==s)throw new Error(\"Data does not appear to be in a Flatbush format.\");if(i>>4!=3)throw new Error(`Got v${i>>4} data when expected v3.`);const[e]=new Uint16Array(t,2,1),[h]=new Uint32Array(t,4,1);return new r(h,e,o[15&i],t)}constructor(t,s=16,i=Float64Array,e){if(void 0===t)throw new Error(\"Missing required argument: numItems.\");if(isNaN(t)||t<=0)throw new Error(`Unpexpected numItems value: ${t}.`);this.numItems=+t,this.nodeSize=Math.min(Math.max(+s,2),65535);let h=t,r=h;this._levelBounds=[4*h];do{h=Math.ceil(h/this.nodeSize),r+=h,this._levelBounds.push(4*r)}while(1!==h);this.ArrayType=i||Float64Array,this.IndexArrayType=r<16384?Uint16Array:Uint32Array;const a=o.indexOf(this.ArrayType),_=4*r*this.ArrayType.BYTES_PER_ELEMENT;if(a<0)throw new Error(`Unexpected typed array class: ${i}.`);e&&e instanceof ArrayBuffer?(this.data=e,this._boxes=new this.ArrayType(this.data,8,4*r),this._indices=new this.IndexArrayType(this.data,8+_,r),this._pos=4*r,this.minX=this._boxes[this._pos-4],this.minY=this._boxes[this._pos-3],this.maxX=this._boxes[this._pos-2],this.maxY=this._boxes[this._pos-1]):(this.data=new ArrayBuffer(8+_+r*this.IndexArrayType.BYTES_PER_ELEMENT),this._boxes=new this.ArrayType(this.data,8,4*r),this._indices=new this.IndexArrayType(this.data,8+_,r),this._pos=0,this.minX=1/0,this.minY=1/0,this.maxX=-1/0,this.maxY=-1/0,new Uint8Array(this.data,0,2).set([251,48+a]),new Uint16Array(this.data,2,1)[0]=s,new Uint32Array(this.data,4,1)[0]=t),this._queue=new n.default}add(t,s,i,e){const h=this._pos>>2;return this._indices[h]=h,this._boxes[this._pos++]=t,this._boxes[this._pos++]=s,this._boxes[this._pos++]=i,this._boxes[this._pos++]=e,tthis.maxX&&(this.maxX=i),e>this.maxY&&(this.maxY=e),h}finish(){if(this._pos>>2!==this.numItems)throw new Error(`Added ${this._pos>>2} items when expected ${this.numItems}.`);if(this.numItems<=this.nodeSize)return this._boxes[this._pos++]=this.minX,this._boxes[this._pos++]=this.minY,this._boxes[this._pos++]=this.maxX,void(this._boxes[this._pos++]=this.maxY);const t=this.maxX-this.minX,s=this.maxY-this.minY,i=new Uint32Array(this.numItems);for(let e=0;e>2]=t,this._boxes[this._pos++]=e,this._boxes[this._pos++]=h,this._boxes[this._pos++]=n,this._boxes[this._pos++]=o}}}search(t,s,i,e,h){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let n=this._boxes.length-4;const o=[],r=[];for(;void 0!==n;){const a=Math.min(n+4*this.nodeSize,_(n,this._levelBounds));for(let _=n;_>2];ithis._boxes[_+2]||s>this._boxes[_+3]||(n<4*this.numItems?(void 0===h||h(a))&&r.push(a):o.push(a)))}n=o.pop()}return r}neighbors(t,s,i=1/0,e=1/0,h){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let n=this._boxes.length-4;const o=this._queue,r=[],x=e*e;for(;void 0!==n;){const e=Math.min(n+4*this.nodeSize,_(n,this._levelBounds));for(let i=n;i>2],r=a(t,this._boxes[i],this._boxes[i+2]),_=a(s,this._boxes[i+1],this._boxes[i+3]),x=r*r+_*_;n<4*this.numItems?(void 0===h||h(e))&&o.push(-e-1,x):o.push(e,x)}for(;o.length&&o.peek()<0;){if(o.peekValue()>x)return o.clear(),r;if(r.push(-o.pop()-1),r.length===i)return o.clear(),r}n=o.pop()}return o.clear(),r}}function a(t,s,i){return t>1;s[h]>t?e=h:i=h+1}return s[i]}function x(t,s,i,e,h,n){if(Math.floor(e/n)>=Math.floor(h/n))return;const o=t[e+h>>1];let r=e-1,a=h+1;for(;;){do{r++}while(t[r]o);if(r>=a)break;d(t,s,i,r,a)}x(t,s,i,e,a,n),x(t,s,i,a+1,h,n)}function d(t,s,i,e,h){const n=t[e];t[e]=t[h],t[h]=n;const o=4*e,r=4*h,a=s[o],_=s[o+1],x=s[o+2],d=s[o+3];s[o]=s[r],s[o+1]=s[r+1],s[o+2]=s[r+2],s[o+3]=s[r+3],s[r]=a,s[r+1]=_,s[r+2]=x,s[r+3]=d;const m=i[e];i[e]=i[h],i[h]=m}function m(t,s){let i=t^s,e=65535^i,h=65535^(t|s),n=t&(65535^s),o=i|e>>1,r=i>>1^i,a=h>>1^e&n>>1^h,_=i&h>>1^n>>1^n;i=o,e=r,h=a,n=_,o=i&i>>2^e&e>>2,r=i&e>>2^e&(i^e)>>2,a^=i&h>>2^e&n>>2,_^=e&h>>2^(i^e)&n>>2,i=o,e=r,h=a,n=_,o=i&i>>4^e&e>>4,r=i&e>>4^e&(i^e)>>4,a^=i&h>>4^e&n>>4,_^=e&h>>4^(i^e)&n>>4,i=o,e=r,h=a,n=_,a^=i&h>>8^e&n>>8,_^=e&h>>8^(i^e)&n>>8,i=a^a>>1,e=_^_>>1;let x=t^s,d=e|65535^(x|i);return x=16711935&(x|x<<8),x=252645135&(x|x<<4),x=858993459&(x|x<<2),x=1431655765&(x|x<<1),d=16711935&(d|d<<8),d=252645135&(d|d<<4),d=858993459&(d|d<<2),d=1431655765&(d|d<<1),(d<<1|x)>>>0}i.default=r},\n", " function _(s,t,i,h,e){h();i.default=class{constructor(){this.ids=[],this.values=[],this.length=0}clear(){this.length=0}push(s,t){let i=this.length++;for(this.ids[i]=s,this.values[i]=t;i>0;){const s=i-1>>1,h=this.values[s];if(t>=h)break;this.ids[i]=this.ids[s],this.values[i]=h,i=s}this.ids[i]=s,this.values[i]=t}pop(){if(0===this.length)return;const s=this.ids[0];if(this.length--,this.length>0){const s=this.ids[0]=this.ids[this.length],t=this.values[0]=this.values[this.length],i=this.length>>1;let h=0;for(;h=t)break;this.ids[h]=e,this.values[h]=l,h=s}this.ids[h]=s,this.values[h]=t}return s}peek(){if(0!==this.length)return this.ids[0]}peekValue(){if(0!==this.length)return this.values[0]}}},\n", " function _(e,n,a,t,i){t();const l=(0,e(1).__importStar)(e(185));function r(e,n,{x0:a,x1:t,y0:i,y1:l},r){n.save(),n.beginPath(),n.moveTo(a,(i+l)/2),n.lineTo(t,(i+l)/2),e.line.apply(n,r),n.restore()}function c(e,n,{x0:a,x1:t,y0:i,y1:l},r){var c,o;const _=.1*Math.abs(t-a),s=.1*Math.abs(l-i),y=a+_,p=t-_,g=i+s,h=l-s;n.beginPath(),n.rect(y,g,p-y,h-g),e.fill.apply(n,r),null===(c=e.hatch)||void 0===c||c.apply(n,r),null===(o=e.line)||void 0===o||o.apply(n,r)}a.generic_line_scalar_legend=function(e,n,{x0:a,x1:t,y0:i,y1:l}){n.save(),n.beginPath(),n.moveTo(a,(i+l)/2),n.lineTo(t,(i+l)/2),e.line.apply(n),n.restore()},a.generic_line_vector_legend=r,a.generic_line_legend=r,a.generic_area_scalar_legend=function(e,n,{x0:a,x1:t,y0:i,y1:l}){var r,c;const o=.1*Math.abs(t-a),_=.1*Math.abs(l-i),s=a+o,y=t-o,p=i+_,g=l-_;n.beginPath(),n.rect(s,p,y-s,g-p),e.fill.apply(n),null===(r=e.hatch)||void 0===r||r.apply(n),null===(c=e.line)||void 0===c||c.apply(n)},a.generic_area_vector_legend=c,a.generic_area_legend=c,a.line_interpolation=function(e,n,a,t,i,r){const{sx:c,sy:o}=n;let _,s,y,p;\"point\"==n.type?([y,p]=e.yscale.r_invert(o-1,o+1),[_,s]=e.xscale.r_invert(c-1,c+1)):\"v\"==n.direction?([y,p]=e.yscale.r_invert(o,o),[_,s]=[Math.min(a-1,i-1),Math.max(a+1,i+1)]):([_,s]=e.xscale.r_invert(c,c),[y,p]=[Math.min(t-1,r-1),Math.max(t+1,r+1)]);const{x:g,y:h}=l.check_2_segments_intersect(_,y,s,p,a,t,i,r);return[g,h]}},\n", " function _(t,n,e,i,r){function s(t,n){return(t.x-n.x)**2+(t.y-n.y)**2}function o(t,n,e){const i=s(n,e);if(0==i)return s(t,n);const r=((t.x-n.x)*(e.x-n.x)+(t.y-n.y)*(e.y-n.y))/i;if(r<0)return s(t,n);if(r>1)return s(t,e);return s(t,{x:n.x+r*(e.x-n.x),y:n.y+r*(e.y-n.y)})}i(),e.point_in_poly=function(t,n,e,i){let r=!1,s=e[e.length-1],o=i[i.length-1];for(let u=0;u0&&_<1&&h>0&&h<1,x:t+_*(e-t),y:n+_*(i-n)}}}},\n", " function _(t,s,e,i,a){i();const l=t(1);var n;const _=t(178),o=t(184),c=(0,l.__importStar)(t(185)),h=(0,l.__importStar)(t(48)),r=t(72);class p extends _.XYGlyphView{_render(t,s,e){const{sx:i,sy:a}=null!=e?e:this;let l=!0;t.beginPath();for(const e of s){const s=i[e],n=a[e];isFinite(s+n)?l?(t.moveTo(s,n),l=!1):t.lineTo(s,n):(t.closePath(),l=!0)}t.closePath(),this.visuals.fill.apply(t),this.visuals.hatch.apply(t),this.visuals.line.apply(t)}draw_legend_for_index(t,s,e){(0,o.generic_area_scalar_legend)(this.visuals,t,s)}_hit_point(t){const s=new r.Selection;return c.point_in_poly(t.sx,t.sy,this.sx,this.sy)&&(s.add_to_selected_glyphs(this.model),s.view=this),s}}e.PatchView=p,p.__name__=\"PatchView\";class d extends _.XYGlyph{constructor(t){super(t)}}e.Patch=d,n=d,d.__name__=\"Patch\",n.prototype.default_view=p,n.mixins([h.LineScalar,h.FillScalar,h.HatchScalar])},\n", " function _(e,t,s,i,r){i();const n=e(1);var a;const _=e(24),h=e(188),o=(0,n.__importStar)(e(185)),l=(0,n.__importStar)(e(18)),c=e(72);class d extends h.AreaView{_index_data(e){const{min:t,max:s}=Math,{data_size:i}=this;for(let r=0;r=0;t--)e.lineTo(r[t],n[t]);e.closePath(),this.visuals.fill.apply(e),this.visuals.hatch.apply(e)}_hit_point(e){const t=this.sy.length,s=new _.ScreenArray(2*t),i=new _.ScreenArray(2*t);for(let e=0,r=t;e({x1:[l.XCoordinateSpec,{field:\"x1\"}],x2:[l.XCoordinateSpec,{field:\"x2\"}],y:[l.YCoordinateSpec,{field:\"y\"}]})))},\n", " function _(e,a,r,_,s){_();const n=e(1);var c;const i=e(179),l=e(184),t=(0,n.__importStar)(e(48));class o extends i.GlyphView{draw_legend_for_index(e,a,r){(0,l.generic_area_scalar_legend)(this.visuals,e,a)}}r.AreaView=o,o.__name__=\"AreaView\";class d extends i.Glyph{constructor(e){super(e)}}r.Area=d,c=d,d.__name__=\"Area\",c.mixins([t.FillScalar,t.HatchScalar])},\n", " function _(e,t,s,i,r){i();const n=e(1);var a;const _=e(24),h=e(188),o=(0,n.__importStar)(e(185)),l=(0,n.__importStar)(e(18)),c=e(72);class y extends h.AreaView{_index_data(e){const{min:t,max:s}=Math,{data_size:i}=this;for(let r=0;r=0;t--)e.lineTo(i[t],n[t]);e.closePath(),this.visuals.fill.apply(e),this.visuals.hatch.apply(e)}scenterxy(e){return[this.sx[e],(this.sy1[e]+this.sy2[e])/2]}_hit_point(e){const t=this.sx.length,s=new _.ScreenArray(2*t),i=new _.ScreenArray(2*t);for(let e=0,r=t;e({x:[l.XCoordinateSpec,{field:\"x\"}],y1:[l.YCoordinateSpec,{field:\"y1\"}],y2:[l.YCoordinateSpec,{field:\"y2\"}]})))},\n", " function _(e,i,s,t,n){var c;t();const o=e(53),r=e(24),u=e(191),_=e(70);class a extends o.Model{constructor(e){super(e)}initialize(){super.initialize(),this.compute_indices()}connect_signals(){super.connect_signals(),this.connect(this.properties.filters.change,(()=>this.compute_indices()));const e=()=>{const e=()=>this.compute_indices();null!=this.source&&(this.connect(this.source.change,e),this.source instanceof _.ColumnarDataSource&&(this.connect(this.source.streaming,e),this.connect(this.source.patching,e)))};let i=null!=this.source;i?e():this.connect(this.properties.source.change,(()=>{i||(e(),i=!0)}))}compute_indices(){var e;const{source:i}=this;if(null==i)return;const s=null!==(e=i.get_length())&&void 0!==e?e:1,t=r.Indices.all_set(s);for(const e of this.filters)t.intersect(e.compute_indices(i));this.indices=t,this._indices=[...t],this.indices_map_to_subset()}indices_map_to_subset(){this.indices_map={};for(let e=0;ethis._indices[e]))}convert_selection_to_subset(e){return e.map((e=>this.indices_map[e]))}convert_indices_from_subset(e){return e.map((e=>this._indices[e]))}}s.CDSView=a,c=a,a.__name__=\"CDSView\",c.define((({Array:e,Ref:i})=>({filters:[e(i(u.Filter)),[]],source:[i(_.ColumnarDataSource)]}))),c.internal((({Int:e,Dict:i,Ref:s,Nullable:t})=>({indices:[s(r.Indices)],indices_map:[i(e),{}],masked:[t(s(r.Indices)),null]})))},\n", " function _(e,t,n,s,c){s();const o=e(53);class r extends o.Model{constructor(e){super(e)}}n.Filter=r,r.__name__=\"Filter\"},\n", " function _(t,r,a,e,c){e(),c(\"BasicTickFormatter\",t(146).BasicTickFormatter),c(\"CategoricalTickFormatter\",t(142).CategoricalTickFormatter),c(\"DatetimeTickFormatter\",t(150).DatetimeTickFormatter),c(\"FuncTickFormatter\",t(193).FuncTickFormatter),c(\"LogTickFormatter\",t(163).LogTickFormatter),c(\"MercatorTickFormatter\",t(166).MercatorTickFormatter),c(\"NumeralTickFormatter\",t(194).NumeralTickFormatter),c(\"PrintfTickFormatter\",t(195).PrintfTickFormatter),c(\"TickFormatter\",t(131).TickFormatter)},\n", " function _(t,e,n,s,r){var c;s();const i=t(131),a=t(13),u=t(34);class o extends i.TickFormatter{constructor(t){super(t)}get names(){return(0,a.keys)(this.args)}get values(){return(0,a.values)(this.args)}_make_func(){const t=(0,u.use_strict)(this.code);return new Function(\"tick\",\"index\",\"ticks\",...this.names,t)}doFormat(t,e){const n=this._make_func().bind({});return t.map(((t,e,s)=>`${n(t,e,s,...this.values)}`))}}n.FuncTickFormatter=o,c=o,o.__name__=\"FuncTickFormatter\",c.define((({Unknown:t,String:e,Dict:n})=>({args:[n(t),{}],code:[e,\"\"]})))},\n", " function _(r,n,t,o,e){o();var a;const u=(0,r(1).__importStar)(r(153)),c=r(131),i=r(20);class s extends c.TickFormatter{constructor(r){super(r)}get _rounding_fn(){switch(this.rounding){case\"round\":case\"nearest\":return Math.round;case\"floor\":case\"rounddown\":return Math.floor;case\"ceil\":case\"roundup\":return Math.ceil}}doFormat(r,n){const{format:t,language:o,_rounding_fn:e}=this;return r.map((r=>u.format(r,t,o,e)))}}t.NumeralTickFormatter=s,a=s,s.__name__=\"NumeralTickFormatter\",a.define((({String:r})=>({format:[r,\"0,0\"],language:[r,\"en\"],rounding:[i.RoundingFunction,\"round\"]})))},\n", " function _(t,r,n,o,a){var e;o();const i=t(131),s=t(152);class c extends i.TickFormatter{constructor(t){super(t)}doFormat(t,r){return t.map((t=>(0,s.sprintf)(this.format,t)))}}n.PrintfTickFormatter=c,e=c,c.__name__=\"PrintfTickFormatter\",e.define((({String:t})=>({format:[t,\"%s\"]})))},\n", " function _(r,o,a,p,e){p(),e(\"CategoricalColorMapper\",r(197).CategoricalColorMapper),e(\"CategoricalMarkerMapper\",r(199).CategoricalMarkerMapper),e(\"CategoricalPatternMapper\",r(200).CategoricalPatternMapper),e(\"ContinuousColorMapper\",r(172).ContinuousColorMapper),e(\"ColorMapper\",r(173).ColorMapper),e(\"LinearColorMapper\",r(201).LinearColorMapper),e(\"LogColorMapper\",r(202).LogColorMapper),e(\"ScanningColorMapper\",r(171).ScanningColorMapper),e(\"EqHistColorMapper\",r(203).EqHistColorMapper)},\n", " function _(t,o,r,a,e){var c;a();const s=t(198),l=t(173),n=t(67);class _ extends l.ColorMapper{constructor(t){super(t)}_v_compute(t,o,r,{nan_color:a}){(0,s.cat_v_compute)(t,this.factors,r,o,this.start,this.end,a)}}r.CategoricalColorMapper=_,c=_,_.__name__=\"CategoricalColorMapper\",c.define((({Number:t,Nullable:o})=>({factors:[n.FactorSeq],start:[t,0],end:[o(t),null]})))},\n", " function _(n,t,e,l,i){l();const c=n(12),u=n(8);function f(n,t){if(n.length!=t.length)return!1;for(let e=0,l=n.length;ef(n,h)))),s=_<0||_>=e.length?r:e[_],l[g]=s}}},\n", " function _(e,r,a,t,s){var c;t();const l=e(198),n=e(67),u=e(174),o=e(20);class p extends u.Mapper{constructor(e){super(e)}v_compute(e){const r=new Array(e.length);return(0,l.cat_v_compute)(e,this.factors,this.markers,r,this.start,this.end,this.default_value),r}}a.CategoricalMarkerMapper=p,c=p,p.__name__=\"CategoricalMarkerMapper\",c.define((({Number:e,Array:r,Nullable:a})=>({factors:[n.FactorSeq],markers:[r(o.MarkerType)],start:[e,0],end:[a(e),null],default_value:[o.MarkerType,\"circle\"]})))},\n", " function _(t,e,a,r,n){var s;r();const c=t(198),l=t(67),p=t(174),u=t(20);class o extends p.Mapper{constructor(t){super(t)}v_compute(t){const e=new Array(t.length);return(0,c.cat_v_compute)(t,this.factors,this.patterns,e,this.start,this.end,this.default_value),e}}a.CategoricalPatternMapper=o,s=o,o.__name__=\"CategoricalPatternMapper\",s.define((({Number:t,Array:e,Nullable:a})=>({factors:[l.FactorSeq],patterns:[e(u.HatchPatternType)],start:[t,0],end:[a(t),null],default_value:[u.HatchPatternType,\" \"]})))},\n", " function _(n,r,o,t,a){t();const e=n(172),i=n(12);class s extends e.ContinuousColorMapper{constructor(n){super(n)}scan(n,r){const o=null!=this.low?this.low:(0,i.min)(n),t=null!=this.high?this.high:(0,i.max)(n);return{max:t,min:o,norm_factor:1/(t-o),normed_interval:1/r}}cmap(n,r,o,t,a){const e=r.length-1;if(n==a.max)return r[e];const i=(n-a.min)*a.norm_factor,s=Math.floor(i/a.normed_interval);return s<0?o:s>e?t:r[s]}}o.LinearColorMapper=s,s.__name__=\"LinearColorMapper\"},\n", " function _(o,t,n,r,l){r();const a=o(172),s=o(12);class e extends a.ContinuousColorMapper{constructor(o){super(o)}scan(o,t){const n=null!=this.low?this.low:(0,s.min)(o),r=null!=this.high?this.high:(0,s.max)(o);return{max:r,min:n,scale:t/(Math.log(r)-Math.log(n))}}cmap(o,t,n,r,l){const a=t.length-1;if(o>l.max)return r;if(o==l.max)return t[a];if(oa&&(e=a),t[e]}}n.LogColorMapper=e,e.__name__=\"LogColorMapper\"},\n", " function _(n,t,e,i,o){var s;i();const r=n(171),a=n(12),l=n(9),c=n(19);class h extends r.ScanningColorMapper{constructor(n){super(n)}scan(n,t){const e=null!=this.low?this.low:(0,a.min)(n),i=null!=this.high?this.high:(0,a.max)(n),o=this.bins,s=(0,l.linspace)(e,i,o+1),r=(0,a.bin_counts)(n,s),h=new Array(o);for(let n=0,t=s.length;nn/p));let m=t-1,f=[],M=0,_=2*t;for(;m!=t&&M<4&&0!=m;){const n=_/m;if(n>1e3)break;_=Math.round(Math.max(t*n,t));const e=(0,l.range)(0,_),i=(0,a.map)(u,(n=>n*(_-1)));f=(0,a.interpolate)(e,i,h);m=(0,l.uniq)(f).length-1,M++}if(0==m){f=[e,i];for(let n=0;n({bins:[n,65536]})))},\n", " function _(a,e,l,c,n){c(),n(\"CategoricalScale\",a(62).CategoricalScale),n(\"ContinuousScale\",a(60).ContinuousScale),n(\"LinearScale\",a(59).LinearScale),n(\"LinearInterpolationScale\",a(205).LinearInterpolationScale),n(\"LogScale\",a(61).LogScale),n(\"Scale\",a(55).Scale)},\n", " function _(e,r,n,t,a){var i;t();const s=e(55),o=e(59),c=e(12);class _ extends s.Scale{constructor(e){super(e)}connect_signals(){super.connect_signals();const{source_range:e,target_range:r}=this.properties;this.on_change([e,r],(()=>{this.linear_scale=new o.LinearScale({source_range:this.source_range,target_range:this.target_range})}))}get s_compute(){throw new Error(\"not implemented\")}get s_invert(){throw new Error(\"not implemented\")}compute(e){return e}v_compute(e){const{binning:r}=this,{start:n,end:t}=this.source_range,a=n,i=t,s=r.length,o=(t-n)/(s-1),_=new Float64Array(s);for(let e=0;e{if(ei)return i;const n=(0,c.left_edge_index)(e,r);if(-1==n)return a;if(n>=s-1)return i;const t=r[n],o=(e-t)/(r[n+1]-t),l=_[n];return l+o*(_[n+1]-l)}));return this.linear_scale.v_compute(l)}invert(e){return e}v_invert(e){return new Float64Array(e)}}n.LinearInterpolationScale=_,i=_,_.__name__=\"LinearInterpolationScale\",i.internal((({Arrayable:e,Ref:r})=>({binning:[e],linear_scale:[r(o.LinearScale),e=>new o.LinearScale({source_range:e.source_range,target_range:e.target_range})]})))},\n", " function _(a,n,e,g,R){g(),R(\"DataRange\",a(64).DataRange),R(\"DataRange1d\",a(63).DataRange1d),R(\"FactorRange\",a(67).FactorRange),R(\"Range\",a(57).Range),R(\"Range1d\",a(58).Range1d)},\n", " function _(a,o,i,t,e){t();var n=a(124);e(\"Sizeable\",n.Sizeable),e(\"SizingPolicy\",n.SizingPolicy);var c=a(125);e(\"Layoutable\",c.Layoutable),e(\"LayoutItem\",c.LayoutItem);var r=a(208);e(\"HStack\",r.HStack),e(\"VStack\",r.VStack);var l=a(209);e(\"Grid\",l.Grid),e(\"Row\",l.Row),e(\"Column\",l.Column);var S=a(210);e(\"ContentBox\",S.ContentBox),e(\"VariadicBox\",S.VariadicBox)},\n", " function _(t,e,h,i,r){i();const n=t(125),o=t(65);class s extends n.Layoutable{constructor(){super(...arguments),this.children=[]}*[Symbol.iterator](){yield*this.children}}h.Stack=s,s.__name__=\"Stack\";class c extends s{_measure(t){let e=0,h=0;for(const t of this.children){const i=t.measure({width:0,height:0});e+=i.width,h=Math.max(h,i.height)}return{width:e,height:h}}_set_geometry(t,e){super._set_geometry(t,e);const h=this.absolute?t.top:0;let i=this.absolute?t.left:0;const{height:r}=t;for(const t of this.children){const{width:e}=t.measure({width:0,height:0});t.set_geometry(new o.BBox({left:i,width:e,top:h,height:r})),i+=e}}}h.HStack=c,c.__name__=\"HStack\";class a extends s{_measure(t){let e=0,h=0;for(const t of this.children){const i=t.measure({width:0,height:0});e=Math.max(e,i.width),h+=i.height}return{width:e,height:h}}_set_geometry(t,e){super._set_geometry(t,e);const h=this.absolute?t.left:0;let i=this.absolute?t.top:0;const{width:r}=t;for(const t of this.children){const{height:e}=t.measure({width:0,height:0});t.set_geometry(new o.BBox({top:i,height:e,left:h,width:r})),i+=e}}}h.VStack=a,a.__name__=\"VStack\";class l extends n.Layoutable{constructor(){super(...arguments),this.children=[]}*[Symbol.iterator](){yield*this.children}_measure(t){const{width_policy:e,height_policy:h}=this.sizing,{min:i,max:r}=Math;let n=0,o=0;for(const e of this.children){const{width:h,height:i}=e.measure(t);n=r(n,h),o=r(o,i)}return{width:(()=>{const{width:h}=this.sizing;if(t.width==1/0)return\"fixed\"==e&&null!=h?h:n;switch(e){case\"fixed\":return null!=h?h:n;case\"min\":return n;case\"fit\":return null!=h?i(t.width,h):t.width;case\"max\":return null!=h?r(t.width,h):t.width}})(),height:(()=>{const{height:e}=this.sizing;if(t.height==1/0)return\"fixed\"==h&&null!=e?e:o;switch(h){case\"fixed\":return null!=e?e:o;case\"min\":return o;case\"fit\":return null!=e?i(t.height,e):t.height;case\"max\":return null!=e?r(t.height,e):t.height}})()}}_set_geometry(t,e){super._set_geometry(t,e);const h=this.absolute?t:t.relative(),{left:i,right:r,top:n,bottom:s}=h,c=Math.round(h.vcenter),a=Math.round(h.hcenter);for(const e of this.children){const{margin:h,halign:l,valign:d}=e.sizing,{width:u,height:g,inner:_}=e.measure(t),w=(()=>{switch(`${d}_${l}`){case\"start_start\":return new o.BBox({left:i+h.left,top:n+h.top,width:u,height:g});case\"start_center\":return new o.BBox({hcenter:a,top:n+h.top,width:u,height:g});case\"start_end\":return new o.BBox({right:r-h.right,top:n+h.top,width:u,height:g});case\"center_start\":return new o.BBox({left:i+h.left,vcenter:c,width:u,height:g});case\"center_center\":return new o.BBox({hcenter:a,vcenter:c,width:u,height:g});case\"center_end\":return new o.BBox({right:r-h.right,vcenter:c,width:u,height:g});case\"end_start\":return new o.BBox({left:i+h.left,bottom:s-h.bottom,width:u,height:g});case\"end_center\":return new o.BBox({hcenter:a,bottom:s-h.bottom,width:u,height:g});case\"end_end\":return new o.BBox({right:r-h.right,bottom:s-h.bottom,width:u,height:g})}})(),m=null==_?w:new o.BBox({left:w.left+_.left,top:w.top+_.top,right:w.right-_.right,bottom:w.bottom-_.bottom});e.set_geometry(w,m)}}}h.NodeLayout=l,l.__name__=\"NodeLayout\"},\n", " function _(t,i,s,e,o){e();const n=t(124),l=t(125),r=t(8),h=t(65),c=t(9),{max:a,round:g}=Math;class p{constructor(t){this.def=t,this._map=new Map}get(t){let i=this._map.get(t);return void 0===i&&(i=this.def(),this._map.set(t,i)),i}apply(t,i){const s=this.get(t);this._map.set(t,i(s))}}p.__name__=\"DefaultMap\";class f{constructor(){this._items=[],this._nrows=0,this._ncols=0}get nrows(){return this._nrows}get ncols(){return this._ncols}add(t,i){const{r1:s,c1:e}=t;this._nrows=a(this._nrows,s+1),this._ncols=a(this._ncols,e+1),this._items.push({span:t,data:i})}at(t,i){return this._items.filter((({span:s})=>s.r0<=t&&t<=s.r1&&s.c0<=i&&i<=s.c1)).map((({data:t})=>t))}row(t){return this._items.filter((({span:i})=>i.r0<=t&&t<=i.r1)).map((({data:t})=>t))}col(t){return this._items.filter((({span:i})=>i.c0<=t&&t<=i.c1)).map((({data:t})=>t))}foreach(t){for(const{span:i,data:s}of this._items)t(i,s)}map(t){const i=new f;for(const{span:s,data:e}of this._items)i.add(s,t(s,e));return i}}f.__name__=\"Container\";class _ extends l.Layoutable{constructor(t=[]){super(),this.items=t,this.rows=\"auto\",this.cols=\"auto\",this.spacing=0}*[Symbol.iterator](){for(const{layout:t}of this.items)yield t}is_width_expanding(){if(super.is_width_expanding())return!0;if(\"fixed\"==this.sizing.width_policy)return!1;const{cols:t}=this._state;return(0,c.some)(t,(t=>\"max\"==t.policy))}is_height_expanding(){if(super.is_height_expanding())return!0;if(\"fixed\"==this.sizing.height_policy)return!1;const{rows:t}=this._state;return(0,c.some)(t,(t=>\"max\"==t.policy))}_init(){var t,i,s,e;super._init();const o=new f;for(const{layout:t,row:i,col:s,row_span:e,col_span:n}of this.items)if(t.sizing.visible){const l=i,r=s,h=i+(null!=e?e:1)-1,c=s+(null!=n?n:1)-1;o.add({r0:l,c0:r,r1:h,c1:c},t)}const{nrows:n,ncols:l}=o,h=new Array(n);for(let s=0;s{var t;const i=(0,r.isPlainObject)(this.rows)?null!==(t=this.rows[s])&&void 0!==t?t:this.rows[\"*\"]:this.rows;return null==i?{policy:\"auto\"}:(0,r.isNumber)(i)?{policy:\"fixed\",height:i}:(0,r.isString)(i)?{policy:i}:i})(),n=null!==(t=e.align)&&void 0!==t?t:\"auto\";if(\"fixed\"==e.policy)h[s]={policy:\"fixed\",height:e.height,align:n};else if(\"min\"==e.policy)h[s]={policy:\"min\",align:n};else if(\"fit\"==e.policy||\"max\"==e.policy)h[s]={policy:e.policy,flex:null!==(i=e.flex)&&void 0!==i?i:1,align:n};else{if(\"auto\"!=e.policy)throw new Error(\"unrechable\");(0,c.some)(o.row(s),(t=>t.is_height_expanding()))?h[s]={policy:\"max\",flex:1,align:n}:h[s]={policy:\"min\",align:n}}}const a=new Array(l);for(let t=0;t{var i;const s=(0,r.isPlainObject)(this.cols)?null!==(i=this.cols[t])&&void 0!==i?i:this.cols[\"*\"]:this.cols;return null==s?{policy:\"auto\"}:(0,r.isNumber)(s)?{policy:\"fixed\",width:s}:(0,r.isString)(s)?{policy:s}:s})(),n=null!==(s=i.align)&&void 0!==s?s:\"auto\";if(\"fixed\"==i.policy)a[t]={policy:\"fixed\",width:i.width,align:n};else if(\"min\"==i.policy)a[t]={policy:\"min\",align:n};else if(\"fit\"==i.policy||\"max\"==i.policy)a[t]={policy:i.policy,flex:null!==(e=i.flex)&&void 0!==e?e:1,align:n};else{if(\"auto\"!=i.policy)throw new Error(\"unrechable\");(0,c.some)(o.col(t),(t=>t.is_width_expanding()))?a[t]={policy:\"max\",flex:1,align:n}:a[t]={policy:\"min\",align:n}}}const[g,p]=(0,r.isNumber)(this.spacing)?[this.spacing,this.spacing]:this.spacing;this._state={items:o,nrows:n,ncols:l,rows:h,cols:a,rspacing:g,cspacing:p}}_measure_totals(t,i){const{nrows:s,ncols:e,rspacing:o,cspacing:n}=this._state;return{height:(0,c.sum)(t)+(s-1)*o,width:(0,c.sum)(i)+(e-1)*n}}_measure_cells(t){const{items:i,nrows:s,ncols:e,rows:o,cols:l,rspacing:r,cspacing:h}=this._state,c=new Array(s);for(let t=0;t{const{r0:e,c0:f,r1:d,c1:u}=i,w=(d-e)*r,m=(u-f)*h;let y=0;for(let i=e;i<=d;i++)y+=t(i,f).height;y+=w;let x=0;for(let i=f;i<=u;i++)x+=t(e,i).width;x+=m;const b=s.measure({width:x,height:y});_.add(i,{layout:s,size_hint:b});const z=new n.Sizeable(b).grow_by(s.sizing.margin);z.height-=w,z.width-=m;const v=[];for(let t=e;t<=d;t++){const i=o[t];\"fixed\"==i.policy?z.height-=i.height:v.push(t)}if(z.height>0){const t=g(z.height/v.length);for(const i of v)c[i]=a(c[i],t)}const j=[];for(let t=f;t<=u;t++){const i=l[t];\"fixed\"==i.policy?z.width-=i.width:j.push(t)}if(z.width>0){const t=g(z.width/j.length);for(const i of j)p[i]=a(p[i],t)}}));return{size:this._measure_totals(c,p),row_heights:c,col_widths:p,size_hints:_}}_measure_grid(t){const{nrows:i,ncols:s,rows:e,cols:o,rspacing:n,cspacing:l}=this._state,r=this._measure_cells(((t,i)=>{const s=e[t],n=o[i];return{width:\"fixed\"==n.policy?n.width:1/0,height:\"fixed\"==s.policy?s.height:1/0}}));let h;h=\"fixed\"==this.sizing.height_policy&&null!=this.sizing.height?this.sizing.height:t.height!=1/0&&this.is_height_expanding()?t.height:r.size.height;let c,p=0;for(let t=0;t0)for(let t=0;ti?i:e,t--}}}c=\"fixed\"==this.sizing.width_policy&&null!=this.sizing.width?this.sizing.width:t.width!=1/0&&this.is_width_expanding()?t.width:r.size.width;let f=0;for(let t=0;t0)for(let t=0;ts?s:o,t--}}}const{row_heights:_,col_widths:d,size_hints:u}=this._measure_cells(((t,i)=>({width:r.col_widths[i],height:r.row_heights[t]})));return{size:this._measure_totals(_,d),row_heights:_,col_widths:d,size_hints:u}}_measure(t){const{size:i}=this._measure_grid(t);return i}_set_geometry(t,i){super._set_geometry(t,i);const{nrows:s,ncols:e,rspacing:o,cspacing:n}=this._state,{row_heights:l,col_widths:r,size_hints:c}=this._measure_grid(t),f=this._state.rows.map(((t,i)=>Object.assign(Object.assign({},t),{top:0,height:l[i],get bottom(){return this.top+this.height}}))),_=this._state.cols.map(((t,i)=>Object.assign(Object.assign({},t),{left:0,width:r[i],get right(){return this.left+this.width}}))),d=c.map(((t,i)=>Object.assign(Object.assign({},i),{outer:new h.BBox,inner:new h.BBox})));for(let i=0,e=this.absolute?t.top:0;i{const{layout:r,size_hint:c}=l,{sizing:a}=r,{width:p,height:d}=c,u=function(t,i){let s=(i-t)*n;for(let e=t;e<=i;e++)s+=_[e].width;return s}(i,e),w=function(t,i){let s=(i-t)*o;for(let e=t;e<=i;e++)s+=f[e].height;return s}(t,s),m=i==e&&\"auto\"!=_[i].align?_[i].align:a.halign,y=t==s&&\"auto\"!=f[t].align?f[t].align:a.valign;let x=_[i].left;\"start\"==m?x+=a.margin.left:\"center\"==m?x+=g((u-p)/2):\"end\"==m&&(x+=u-a.margin.right-p);let b=f[t].top;\"start\"==y?b+=a.margin.top:\"center\"==y?b+=g((w-d)/2):\"end\"==y&&(b+=w-a.margin.bottom-d),l.outer=new h.BBox({left:x,top:b,width:p,height:d})}));const u=f.map((()=>({start:new p((()=>0)),end:new p((()=>0))}))),w=_.map((()=>({start:new p((()=>0)),end:new p((()=>0))})));d.foreach((({r0:t,c0:i,r1:s,c1:e},{size_hint:o,outer:n})=>{const{inner:l}=o;null!=l&&(u[t].start.apply(n.top,(t=>a(t,l.top))),u[s].end.apply(f[s].bottom-n.bottom,(t=>a(t,l.bottom))),w[i].start.apply(n.left,(t=>a(t,l.left))),w[e].end.apply(_[e].right-n.right,(t=>a(t,l.right))))})),d.foreach((({r0:t,c0:i,r1:s,c1:e},o)=>{const{size_hint:n,outer:l}=o,r=t=>{const i=this.absolute?l:l.relative(),s=i.left+t.left,e=i.top+t.top,o=i.right-t.right,n=i.bottom-t.bottom;return new h.BBox({left:s,top:e,right:o,bottom:n})};if(null!=n.inner){let h=r(n.inner);if(!1!==n.align){const o=u[t].start.get(l.top),n=u[s].end.get(f[s].bottom-l.bottom),c=w[i].start.get(l.left),a=w[e].end.get(_[e].right-l.right);try{h=r({top:o,bottom:n,left:c,right:a})}catch(t){}}o.inner=h}else o.inner=l})),d.foreach(((t,{layout:i,outer:s,inner:e})=>{i.set_geometry(s,e)}))}}s.Grid=_,_.__name__=\"Grid\";class d extends _{constructor(t){super(),this.items=t.map(((t,i)=>({layout:t,row:0,col:i}))),this.rows=\"fit\"}}s.Row=d,d.__name__=\"Row\";class u extends _{constructor(t){super(),this.items=t.map(((t,i)=>({layout:t,row:i,col:0}))),this.cols=\"fit\"}}s.Column=u,u.__name__=\"Column\"},\n", " function _(e,t,s,n,i){n();const a=e(125),c=e(124),o=e(43);class r extends a.ContentLayoutable{constructor(e){super(),this.content_size=(0,o.unsized)(e,(()=>new c.Sizeable((0,o.size)(e))))}_content_size(){return this.content_size}}s.ContentBox=r,r.__name__=\"ContentBox\";class _ extends a.Layoutable{constructor(e){super(),this.el=e}_measure(e){const t=new c.Sizeable(e).bounded_to(this.sizing.size);return(0,o.sized)(this.el,t,(()=>{const e=new c.Sizeable((0,o.content_size)(this.el)),{border:t,padding:s}=(0,o.extents)(this.el);return e.grow_by(t).grow_by(s).map(Math.ceil)}))}}s.VariadicBox=_,_.__name__=\"VariadicBox\";class h extends _{constructor(e){super(e),this._cache=new Map}_measure(e){const{width:t,height:s}=e,n=`${t},${s}`;let i=this._cache.get(n);return null==i&&(i=super._measure(e),this._cache.set(n,i)),i}invalidate_cache(){this._cache.clear()}}s.CachedVariadicBox=h,h.__name__=\"CachedVariadicBox\"},\n", " function _(t,e,i,h,o){h();const s=t(124),r=t(125),n=t(65);class g extends r.Layoutable{constructor(){super(...arguments),this.min_border={left:0,top:0,right:0,bottom:0},this.padding={left:0,top:0,right:0,bottom:0}}*[Symbol.iterator](){yield this.top_panel,yield this.bottom_panel,yield this.left_panel,yield this.right_panel,yield this.center_panel}_measure(t){t=new s.Sizeable({width:\"fixed\"==this.sizing.width_policy||t.width==1/0?this.sizing.width:t.width,height:\"fixed\"==this.sizing.height_policy||t.height==1/0?this.sizing.height:t.height});const e=this.left_panel.measure({width:0,height:t.height}),i=Math.max(e.width,this.min_border.left)+this.padding.left,h=this.right_panel.measure({width:0,height:t.height}),o=Math.max(h.width,this.min_border.right)+this.padding.right,r=this.top_panel.measure({width:t.width,height:0}),n=Math.max(r.height,this.min_border.top)+this.padding.top,g=this.bottom_panel.measure({width:t.width,height:0}),a=Math.max(g.height,this.min_border.bottom)+this.padding.bottom,d=new s.Sizeable(t).shrink_by({left:i,right:o,top:n,bottom:a}),l=this.center_panel.measure(d);return{width:i+l.width+o,height:n+l.height+a,inner:{left:i,right:o,top:n,bottom:a},align:(()=>{const{width_policy:t,height_policy:e}=this.center_panel.sizing;return\"fixed\"!=t&&\"fixed\"!=e})()}}_set_geometry(t,e){super._set_geometry(t,e),this.center_panel.set_geometry(e);const i=this.left_panel.measure({width:0,height:t.height}),h=this.right_panel.measure({width:0,height:t.height}),o=this.top_panel.measure({width:t.width,height:0}),s=this.bottom_panel.measure({width:t.width,height:0}),{left:r,top:g,right:a,bottom:d}=e;this.top_panel.set_geometry(new n.BBox({left:r,right:a,bottom:g,height:o.height})),this.bottom_panel.set_geometry(new n.BBox({left:r,right:a,top:d,height:s.height})),this.left_panel.set_geometry(new n.BBox({top:g,bottom:d,right:r,width:i.width})),this.right_panel.set_geometry(new n.BBox({top:g,bottom:d,left:a,width:h.width}))}}i.BorderLayout=g,g.__name__=\"BorderLayout\"},\n", " function _(t,e,i,s,l){s();const n=t(1);var o;const a=t(119),_=t(10),d=t(20),h=t(120),r=t(123),u=(0,n.__importStar)(t(48));class c extends a.TextAnnotationView{update_layout(){const{panel:t}=this;this.layout=null!=t?new r.SideLayout(t,(()=>this.get_size()),!1):void 0}_get_size(){const{text:t}=this.model,e=new h.TextBox({text:t}),{angle:i,angle_units:s}=this.model;e.angle=(0,_.resolve_angle)(i,s),e.visuals=this.visuals.text.values();const{width:l,height:n}=e.size();return{width:l,height:n}}_render(){const{angle:t,angle_units:e}=this.model,i=(0,_.resolve_angle)(t,e),s=null!=this.layout?this.layout:this.plot_view.frame,l=this.coordinates.x_scale,n=this.coordinates.y_scale;let o=\"data\"==this.model.x_units?l.compute(this.model.x):s.bbox.xview.compute(this.model.x),a=\"data\"==this.model.y_units?n.compute(this.model.y):s.bbox.yview.compute(this.model.y);o+=this.model.x_offset,a-=this.model.y_offset;(\"canvas\"==this.model.render_mode?this._canvas_text.bind(this):this._css_text.bind(this))(this.layer.ctx,this.model.text,o,a,i)}}i.LabelView=c,c.__name__=\"LabelView\";class x extends a.TextAnnotation{constructor(t){super(t)}}i.Label=x,o=x,x.__name__=\"Label\",o.prototype.default_view=c,o.mixins([u.Text,[\"border_\",u.Line],[\"background_\",u.Fill]]),o.define((({Number:t,String:e,Angle:i})=>({x:[t],x_units:[d.SpatialUnits,\"data\"],y:[t],y_units:[d.SpatialUnits,\"data\"],text:[e,\"\"],angle:[i,0],angle_units:[d.AngleUnits,\"rad\"],x_offset:[t,0],y_offset:[t,0]}))),o.override({background_fill_color:null,border_line_color:null})},\n", " function _(t,e,s,i,l){i();const o=t(1);var a;const r=t(69),n=(0,o.__importStar)(t(48)),d=t(20),_=t(43),c=t(120),h=(0,o.__importStar)(t(18)),u=t(11);class v extends r.DataAnnotationView{set_data(t){var e;if(super.set_data(t),null===(e=this.els)||void 0===e||e.forEach((t=>(0,_.remove)(t))),\"css\"==this.model.render_mode){const t=this.els=[...this.text].map((()=>(0,_.div)({style:{display:\"none\"}})));for(const e of t)this.plot_view.canvas_view.add_overlay(e)}else delete this.els}remove(){var t;null===(t=this.els)||void 0===t||t.forEach((t=>(0,_.remove)(t))),super.remove()}_rerender(){\"css\"==this.model.render_mode?this.render():this.request_render()}map_data(){const{x_scale:t,y_scale:e}=this.coordinates,s=null!=this.layout?this.layout:this.plot_view.frame;this.sx=\"data\"==this.model.x_units?t.v_compute(this._x):s.bbox.xview.v_compute(this._x),this.sy=\"data\"==this.model.y_units?e.v_compute(this._y):s.bbox.yview.v_compute(this._y)}paint(){const t=\"canvas\"==this.model.render_mode?this._v_canvas_text.bind(this):this._v_css_text.bind(this),{ctx:e}=this.layer;for(let s=0,i=this.text.length;s{switch(this.visuals.text.text_align.get(e)){case\"left\":return[\"left\",\"0%\"];case\"center\":return[\"center\",\"-50%\"];case\"right\":return[\"right\",\"-100%\"]}})(),[d,c]=(()=>{switch(this.visuals.text.text_baseline.get(e)){case\"top\":return[\"top\",\"0%\"];case\"middle\":return[\"center\",\"-50%\"];case\"bottom\":return[\"bottom\",\"-100%\"];default:return[\"center\",\"-50%\"]}})();let h=`translate(${n}, ${c})`;o&&(h+=`rotate(${o}rad)`),a.style.transformOrigin=`${r} ${d}`,a.style.transform=h,this.layout,this.visuals.background_fill.doit&&(this.visuals.background_fill.set_vectorize(t,e),a.style.backgroundColor=t.fillStyle),this.visuals.border_line.doit&&(this.visuals.border_line.set_vectorize(t,e),a.style.borderStyle=t.lineDash.length<2?\"solid\":\"dashed\",a.style.borderWidth=`${t.lineWidth}px`,a.style.borderColor=t.strokeStyle),(0,_.display)(a)}}s.LabelSetView=v,v.__name__=\"LabelSetView\";class x extends r.DataAnnotation{constructor(t){super(t)}}s.LabelSet=x,a=x,x.__name__=\"LabelSet\",a.prototype.default_view=v,a.mixins([n.TextVector,[\"border_\",n.LineVector],[\"background_\",n.FillVector]]),a.define((()=>({x:[h.XCoordinateSpec,{field:\"x\"}],y:[h.YCoordinateSpec,{field:\"y\"}],x_units:[d.SpatialUnits,\"data\"],y_units:[d.SpatialUnits,\"data\"],text:[h.StringSpec,{field:\"text\"}],angle:[h.AngleSpec,0],x_offset:[h.NumberSpec,{value:0}],y_offset:[h.NumberSpec,{value:0}],render_mode:[d.RenderMode,\"canvas\"]}))),a.override({background_fill_color:null,border_line_color:null})},\n", " function _(t,e,i,l,s){l();const n=t(1);var o;const h=t(40),a=t(215),_=t(20),r=(0,n.__importStar)(t(48)),d=t(15),c=t(123),g=t(121),m=t(65),b=t(9),f=t(8),u=t(11);class x extends h.AnnotationView{update_layout(){const{panel:t}=this;this.layout=null!=t?new c.SideLayout(t,(()=>this.get_size())):void 0}cursor(t,e){return\"none\"==this.model.click_policy?null:\"pointer\"}get legend_padding(){return null!=this.model.border_line_color?this.model.padding:0}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render())),this.connect(this.model.item_change,(()=>this.request_render()))}compute_legend_bbox(){const t=this.model.get_legend_names(),{glyph_height:e,glyph_width:i}=this.model,{label_height:l,label_width:s}=this.model;this.max_label_height=(0,b.max)([(0,g.font_metrics)(this.visuals.label_text.font_value()).height,l,e]);const{ctx:n}=this.layer;n.save(),this.visuals.label_text.set_value(n),this.text_widths=new Map;for(const e of t)this.text_widths.set(e,(0,b.max)([n.measureText(e).width,s]));this.visuals.title_text.set_value(n),this.title_height=this.model.title?(0,g.font_metrics)(this.visuals.title_text.font_value()).height+this.model.title_standoff:0,this.title_width=this.model.title?n.measureText(this.model.title).width:0,n.restore();const o=Math.max((0,b.max)([...this.text_widths.values()]),0),h=this.model.margin,{legend_padding:a}=this,_=this.model.spacing,{label_standoff:r}=this.model;let d,c;if(\"vertical\"==this.model.orientation)d=t.length*this.max_label_height+Math.max(t.length-1,0)*_+2*a+this.title_height,c=(0,b.max)([o+i+r+2*a,this.title_width+2*a]);else{let e=2*a+Math.max(t.length-1,0)*_;for(const[,t]of this.text_widths)e+=(0,b.max)([t,s])+i+r;c=(0,b.max)([this.title_width+2*a,e]),d=this.max_label_height+this.title_height+2*a}const x=null!=this.layout?this.layout:this.plot_view.frame,[p,w]=x.bbox.ranges,{location:v}=this.model;let y,k;if((0,f.isString)(v))switch(v){case\"top_left\":y=p.start+h,k=w.start+h;break;case\"top\":case\"top_center\":y=(p.end+p.start)/2-c/2,k=w.start+h;break;case\"top_right\":y=p.end-h-c,k=w.start+h;break;case\"bottom_right\":y=p.end-h-c,k=w.end-h-d;break;case\"bottom\":case\"bottom_center\":y=(p.end+p.start)/2-c/2,k=w.end-h-d;break;case\"bottom_left\":y=p.start+h,k=w.end-h-d;break;case\"left\":case\"center_left\":y=p.start+h,k=(w.end+w.start)/2-d/2;break;case\"center\":case\"center_center\":y=(p.end+p.start)/2-c/2,k=(w.end+w.start)/2-d/2;break;case\"right\":case\"center_right\":y=p.end-h-c,k=(w.end+w.start)/2-d/2}else if((0,f.isArray)(v)&&2==v.length){const[t,e]=v;y=x.bbox.xview.compute(t),k=x.bbox.yview.compute(e)-d}else(0,u.unreachable)();return new m.BBox({left:y,top:k,width:c,height:d})}interactive_bbox(){return this.compute_legend_bbox()}interactive_hit(t,e){return this.interactive_bbox().contains(t,e)}on_hit(t,e){let i;const{glyph_width:l}=this.model,{legend_padding:s}=this,n=this.model.spacing,{label_standoff:o}=this.model;let h=i=s;const a=this.compute_legend_bbox(),_=\"vertical\"==this.model.orientation;for(const r of this.model.items){const d=r.get_labels_list_from_label_prop();for(const c of d){const d=a.x+h,g=a.y+i+this.title_height;let b,f;[b,f]=_?[a.width-2*s,this.max_label_height]:[this.text_widths.get(c)+l+o,this.max_label_height];if(new m.BBox({left:d,top:g,width:b,height:f}).contains(t,e)){switch(this.model.click_policy){case\"hide\":for(const t of r.renderers)t.visible=!t.visible;break;case\"mute\":for(const t of r.renderers)t.muted=!t.muted}return!0}_?i+=this.max_label_height+n:h+=this.text_widths.get(c)+l+o+n}}return!1}_render(){if(0==this.model.items.length)return;if(!(0,b.some)(this.model.items,(t=>t.visible)))return;for(const t of this.model.items)t.legend=this.model;const{ctx:t}=this.layer,e=this.compute_legend_bbox();t.save(),this._draw_legend_box(t,e),this._draw_legend_items(t,e),this._draw_title(t,e),t.restore()}_draw_legend_box(t,e){t.beginPath(),t.rect(e.x,e.y,e.width,e.height),this.visuals.background_fill.apply(t),this.visuals.border_line.apply(t)}_draw_legend_items(t,e){const{glyph_width:i,glyph_height:l}=this.model,{legend_padding:s}=this,n=this.model.spacing,{label_standoff:o}=this.model;let h=s,a=s;const _=\"vertical\"==this.model.orientation;for(const r of this.model.items){if(!r.visible)continue;const d=r.get_labels_list_from_label_prop(),c=r.get_field_from_label_prop();if(0==d.length)continue;const g=(()=>{switch(this.model.click_policy){case\"none\":return!0;case\"hide\":return(0,b.every)(r.renderers,(t=>t.visible));case\"mute\":return(0,b.every)(r.renderers,(t=>!t.muted))}})();for(const m of d){const d=e.x+h,b=e.y+a+this.title_height,f=d+i,u=b+l;_?a+=this.max_label_height+n:h+=this.text_widths.get(m)+i+o+n,this.visuals.label_text.set_value(t),t.fillText(m,f+o,b+this.max_label_height/2);for(const e of r.renderers){const i=this.plot_view.renderer_view(e);null==i||i.draw_legend(t,d,f,b,u,c,m,r.index)}if(!g){let l,n;[l,n]=_?[e.width-2*s,this.max_label_height]:[this.text_widths.get(m)+i+o,this.max_label_height],t.beginPath(),t.rect(d,b,l,n),this.visuals.inactive_fill.set_value(t),t.fill()}}}}_draw_title(t,e){const{title:i}=this.model;i&&this.visuals.title_text.doit&&(t.save(),t.translate(e.x0,e.y0+this.title_height),this.visuals.title_text.set_value(t),t.fillText(i,this.legend_padding,this.legend_padding-this.model.title_standoff),t.restore())}_get_size(){const{width:t,height:e}=this.compute_legend_bbox();return{width:t+2*this.model.margin,height:e+2*this.model.margin}}}i.LegendView=x,x.__name__=\"LegendView\";class p extends h.Annotation{constructor(t){super(t)}initialize(){super.initialize(),this.item_change=new d.Signal0(this,\"item_change\")}get_legend_names(){const t=[];for(const e of this.items){const i=e.get_labels_list_from_label_prop();t.push(...i)}return t}}i.Legend=p,o=p,p.__name__=\"Legend\",o.prototype.default_view=x,o.mixins([[\"label_\",r.Text],[\"title_\",r.Text],[\"inactive_\",r.Fill],[\"border_\",r.Line],[\"background_\",r.Fill]]),o.define((({Number:t,String:e,Array:i,Tuple:l,Or:s,Ref:n,Nullable:o})=>({orientation:[_.Orientation,\"vertical\"],location:[s(_.LegendLocation,l(t,t)),\"top_right\"],title:[o(e),null],title_standoff:[t,5],label_standoff:[t,5],glyph_height:[t,20],glyph_width:[t,20],label_height:[t,20],label_width:[t,20],margin:[t,10],padding:[t,10],spacing:[t,3],items:[i(n(a.LegendItem)),[]],click_policy:[_.LegendClickPolicy,\"none\"]}))),o.override({border_line_color:\"#e5e5e5\",border_line_alpha:.5,border_line_width:1,background_fill_color:\"#ffffff\",background_fill_alpha:.95,inactive_fill_color:\"white\",inactive_fill_alpha:.7,label_text_font_size:\"13px\",label_text_baseline:\"middle\",title_text_font_size:\"13px\",title_text_font_style:\"italic\"})},\n", " function _(e,r,l,n,t){n();const i=e(1);var s;const o=e(53),a=e(175),_=e(70),u=e(216),d=(0,i.__importStar)(e(18)),c=e(19),f=e(9);class h extends o.Model{constructor(e){super(e)}_check_data_sources_on_renderers(){if(null!=this.get_field_from_label_prop()){if(this.renderers.length<1)return!1;const e=this.renderers[0].data_source;if(null!=e)for(const r of this.renderers)if(r.data_source!=e)return!1}return!0}_check_field_label_on_data_source(){const e=this.get_field_from_label_prop();if(null!=e){if(this.renderers.length<1)return!1;const r=this.renderers[0].data_source;if(null!=r&&!(0,f.includes)(r.columns(),e))return!1}return!0}initialize(){super.initialize(),this.legend=null,this.connect(this.change,(()=>{var e;return null===(e=this.legend)||void 0===e?void 0:e.item_change.emit()}));this._check_data_sources_on_renderers()||c.logger.error(\"Non matching data sources on legend item renderers\");this._check_field_label_on_data_source()||c.logger.error(`Bad column name on label: ${this.label}`)}get_field_from_label_prop(){const{label:e}=this;return(0,u.isField)(e)?e.field:null}get_labels_list_from_label_prop(){if(!this.visible)return[];if((0,u.isValue)(this.label)){const{value:e}=this.label;return null!=e?[e]:[]}const e=this.get_field_from_label_prop();if(null!=e){let r;if(!this.renderers[0]||null==this.renderers[0].data_source)return[\"No source found\"];if(r=this.renderers[0].data_source,r instanceof _.ColumnarDataSource){const l=r.get_column(e);return null!=l?(0,f.uniq)(Array.from(l)):[\"Invalid field\"]}}return[]}}l.LegendItem=h,s=h,h.__name__=\"LegendItem\",s.define((({Boolean:e,Int:r,Array:l,Ref:n,Nullable:t})=>({label:[d.NullStringSpec,null],renderers:[l(n(a.GlyphRenderer)),[]],index:[t(r),null],visible:[e,!0]})))},\n", " function _(i,n,e,t,u){t();const c=i(8);e.isValue=function(i){return(0,c.isPlainObject)(i)&&\"value\"in i},e.isField=function(i){return(0,c.isPlainObject)(i)&&\"field\"in i},e.isExpr=function(i){return(0,c.isPlainObject)(i)&&\"expr\"in i}},\n", " function _(t,n,e,s,i){s();const o=t(1);var a;const l=t(40),c=(0,o.__importStar)(t(48)),r=t(20);class _ extends l.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{xs:t,ys:n}=this.model;if(t.length!=n.length)return;const e=t.length;if(e<3)return;const{frame:s}=this.plot_view,{ctx:i}=this.layer,o=this.coordinates.x_scale,a=this.coordinates.y_scale,{screen:l}=this.model;function c(t,n,e,s){return l?t:\"data\"==n?e.v_compute(t):s.v_compute(t)}const r=c(t,this.model.xs_units,o,s.bbox.xview),_=c(n,this.model.ys_units,a,s.bbox.yview);i.beginPath();for(let t=0;t({xs:[n(t),[]],xs_units:[r.SpatialUnits,\"data\"],ys:[n(t),[]],ys_units:[r.SpatialUnits,\"data\"]}))),a.internal((({Boolean:t})=>({screen:[t,!1]}))),a.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})},\n", " function _(e,t,n,o,i){o();const s=e(1);var l;const r=e(40),c=(0,s.__importStar)(e(48));class a extends r.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{gradient:e,y_intercept:t}=this.model;if(null==e||null==t)return;const{frame:n}=this.plot_view,o=this.coordinates.x_scale,i=this.coordinates.y_scale;let s,l,r,c;if(0==e)s=i.compute(t),l=s,r=n.bbox.left,c=r+n.bbox.width;else{s=n.bbox.top,l=s+n.bbox.height;const a=(i.invert(s)-t)/e,_=(i.invert(l)-t)/e;r=o.compute(a),c=o.compute(_)}const{ctx:a}=this.layer;a.save(),a.beginPath(),this.visuals.line.set_value(a),a.moveTo(r,s),a.lineTo(c,l),a.stroke(),a.restore()}}n.SlopeView=a,a.__name__=\"SlopeView\";class _ extends r.Annotation{constructor(e){super(e)}}n.Slope=_,l=_,_.__name__=\"Slope\",l.prototype.default_view=a,l.mixins(c.Line),l.define((({Number:e,Nullable:t})=>({gradient:[t(e),null],y_intercept:[t(e),null]}))),l.override({line_color:\"black\"})},\n", " function _(e,t,i,o,n){o();const s=e(1);var l;const a=e(40),r=(0,s.__importStar)(e(48)),c=e(20);class d extends a.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.plot_view.request_paint(this)))}_render(){const{location:e}=this.model;if(null==e)return;const{frame:t}=this.plot_view,i=this.coordinates.x_scale,o=this.coordinates.y_scale,n=(t,i)=>\"data\"==this.model.location_units?t.compute(e):this.model.for_hover?e:i.compute(e);let s,l,a,r;\"width\"==this.model.dimension?(a=n(o,t.bbox.yview),l=t.bbox.left,r=t.bbox.width,s=this.model.line_width):(a=t.bbox.top,l=n(i,t.bbox.xview),r=this.model.line_width,s=t.bbox.height);const{ctx:c}=this.layer;c.save(),c.beginPath(),this.visuals.line.set_value(c),c.moveTo(l,a),\"width\"==this.model.dimension?c.lineTo(l+r,a):c.lineTo(l,a+s),c.stroke(),c.restore()}}i.SpanView=d,d.__name__=\"SpanView\";class _ extends a.Annotation{constructor(e){super(e)}}i.Span=_,l=_,_.__name__=\"Span\",l.prototype.default_view=d,l.mixins(r.Line),l.define((({Number:e,Nullable:t})=>({render_mode:[c.RenderMode,\"canvas\"],location:[t(e),null],location_units:[c.SpatialUnits,\"data\"],dimension:[c.Dimension,\"width\"]}))),l.internal((({Boolean:e})=>({for_hover:[e,!1]}))),l.override({line_color:\"black\"})},\n", " function _(i,e,t,o,l){var s;o();const a=i(40),_=i(221),n=i(113),r=i(43),h=i(123),b=i(65);class v extends a.AnnotationView{constructor(){super(...arguments),this._invalidate_toolbar=!0,this._previous_bbox=new b.BBox}update_layout(){this.layout=new h.SideLayout(this.panel,(()=>this.get_size()),!0)}initialize(){super.initialize(),this.el=(0,r.div)(),this.plot_view.canvas_view.add_event(this.el)}async lazy_initialize(){await super.lazy_initialize(),this._toolbar_view=await(0,n.build_view)(this.model.toolbar,{parent:this}),this.plot_view.visibility_callbacks.push((i=>this._toolbar_view.set_visibility(i)))}remove(){this._toolbar_view.remove(),(0,r.remove)(this.el),super.remove()}render(){this.model.visible||(0,r.undisplay)(this.el),super.render()}_render(){const{bbox:i}=this.layout;this._previous_bbox.equals(i)||((0,r.position)(this.el,i),this._previous_bbox=i,this._invalidate_toolbar=!0),this._invalidate_toolbar&&(this.el.style.position=\"absolute\",this.el.style.overflow=\"hidden\",(0,r.empty)(this.el),this.el.appendChild(this._toolbar_view.el),this._toolbar_view.layout.bbox=i,this._toolbar_view.render(),this._invalidate_toolbar=!1),(0,r.display)(this.el)}_get_size(){const{tools:i,logo:e}=this.model.toolbar;return{width:30*i.length+(null!=e?25:0)+15,height:30}}}t.ToolbarPanelView=v,v.__name__=\"ToolbarPanelView\";class d extends a.Annotation{constructor(i){super(i)}}t.ToolbarPanel=d,s=d,d.__name__=\"ToolbarPanel\",s.prototype.default_view=v,s.define((({Ref:i})=>({toolbar:[i(_.Toolbar)]})))},\n", " function _(t,e,s,i,o){var c;i();const n=t(8),a=t(9),l=t(13),r=t(222),_=t(223),u=t(232),p=t(233);function v(t){switch(t){case\"tap\":return\"active_tap\";case\"pan\":return\"active_drag\";case\"pinch\":case\"scroll\":return\"active_scroll\";case\"multi\":return\"active_multi\"}return null}function h(t){return\"tap\"==t||\"pan\"==t}s.Drag=r.Tool,s.Inspection=r.Tool,s.Scroll=r.Tool,s.Tap=r.Tool;class f extends p.ToolbarBase{constructor(t){super(t)}connect_signals(){super.connect_signals();const{tools:t,active_drag:e,active_inspect:s,active_scroll:i,active_tap:o,active_multi:c}=this.properties;this.on_change([t,e,s,i,o,c],(()=>this._init_tools()))}_init_tools(){if(super._init_tools(),\"auto\"==this.active_inspect);else if(this.active_inspect instanceof u.InspectTool){let t=!1;for(const e of this.inspectors)e!=this.active_inspect?e.active=!1:t=!0;t||(this.active_inspect=null)}else if((0,n.isArray)(this.active_inspect)){const t=(0,a.intersection)(this.active_inspect,this.inspectors);t.length!=this.active_inspect.length&&(this.active_inspect=t);for(const t of this.inspectors)(0,a.includes)(this.active_inspect,t)||(t.active=!1)}else if(null==this.active_inspect)for(const t of this.inspectors)t.active=!1;const t=t=>{t.active?this._active_change(t):t.active=!0};for(const t of(0,l.values)(this.gestures)){t.tools=(0,a.sort_by)(t.tools,(t=>t.default_order));for(const e of t.tools)this.connect(e.properties.active.change,(()=>this._active_change(e)))}for(const[e,s]of(0,l.entries)(this.gestures)){const i=v(e);if(i){const o=this[i];\"auto\"==o?0!=s.tools.length&&h(e)&&t(s.tools[0]):null!=o&&((0,a.includes)(this.tools,o)?t(o):this[i]=null)}}}}s.Toolbar=f,c=f,f.__name__=\"Toolbar\",c.prototype.default_view=p.ToolbarBaseView,c.define((({Or:t,Ref:e,Auto:i,Null:o})=>({active_drag:[t(e(s.Drag),i,o),\"auto\"],active_inspect:[t(e(s.Inspection),i,o),\"auto\"],active_scroll:[t(e(s.Scroll),i,o),\"auto\"],active_tap:[t(e(s.Tap),i,o),\"auto\"],active_multi:[t(e(_.GestureTool),i,o),\"auto\"]})))},\n", " function _(t,e,n,o,s){var i;o();const a=t(42),r=t(9),l=t(53);class c extends a.View{get plot_view(){return this.parent}get plot_model(){return this.parent.model}connect_signals(){super.connect_signals(),this.connect(this.model.properties.active.change,(()=>{this.model.active?this.activate():this.deactivate()}))}activate(){}deactivate(){}}n.ToolView=c,c.__name__=\"ToolView\";class _ extends l.Model{constructor(t){super(t)}get synthetic_renderers(){return[]}_get_dim_limits([t,e],[n,o],s,i){const a=s.bbox.h_range;let l;\"width\"==i||\"both\"==i?(l=[(0,r.min)([t,n]),(0,r.max)([t,n])],l=[(0,r.max)([l[0],a.start]),(0,r.min)([l[1],a.end])]):l=[a.start,a.end];const c=s.bbox.v_range;let _;return\"height\"==i||\"both\"==i?(_=[(0,r.min)([e,o]),(0,r.max)([e,o])],_=[(0,r.max)([_[0],c.start]),(0,r.min)([_[1],c.end])]):_=[c.start,c.end],[l,_]}static register_alias(t,e){this.prototype._known_aliases.set(t,e)}static from_string(t){const e=this.prototype._known_aliases.get(t);if(null!=e)return e();{const e=[...this.prototype._known_aliases.keys()];throw new Error(`unexpected tool name '${t}', possible tools are ${e.join(\", \")}`)}}}n.Tool=_,i=_,_.__name__=\"Tool\",i.prototype._known_aliases=new Map,i.define((({String:t,Nullable:e})=>({description:[e(t),null]}))),i.internal((({Boolean:t})=>({active:[t,!1]})))},\n", " function _(e,o,t,s,n){s();const u=e(224),_=e(231);class l extends u.ButtonToolView{}t.GestureToolView=l,l.__name__=\"GestureToolView\";class i extends u.ButtonTool{constructor(e){super(e),this.button_view=_.OnOffButtonView}}t.GestureTool=i,i.__name__=\"GestureTool\"},\n", " function _(t,e,o,s,i){s();const n=t(1);var l;const r=(0,n.__importDefault)(t(225)),a=t(226),u=t(222),h=t(43),_=t(34),d=t(8),c=t(9),m=(0,n.__importStar)(t(227)),p=m,v=(0,n.__importDefault)(t(228)),f=(0,n.__importDefault)(t(229)),g=t(230);class b extends a.DOMView{initialize(){super.initialize();const t=this.model.menu;if(null!=t){const e=this.parent.model.toolbar_location,o=\"left\"==e||\"above\"==e,s=this.parent.model.horizontal?\"vertical\":\"horizontal\";this._menu=new g.ContextMenu(o?(0,c.reversed)(t):t,{orientation:s,prevent_hide:t=>t.target==this.el})}this._hammer=new r.default(this.el,{touchAction:\"auto\",inputClass:r.default.TouchMouseInput}),this.connect(this.model.change,(()=>this.render())),this._hammer.on(\"tap\",(t=>{var e;(null===(e=this._menu)||void 0===e?void 0:e.is_open)?this._menu.hide():t.target==this.el&&this._clicked()})),this._hammer.on(\"press\",(()=>this._pressed())),this.el.addEventListener(\"keydown\",(t=>{t.keyCode==h.Keys.Enter&&this._clicked()}))}remove(){var t;this._hammer.destroy(),null===(t=this._menu)||void 0===t||t.remove(),super.remove()}styles(){return[...super.styles(),m.default,v.default,f.default]}css_classes(){return super.css_classes().concat(p.toolbar_button)}render(){(0,h.empty)(this.el);const t=this.model.computed_icon;(0,d.isString)(t)&&((0,_.startsWith)(t,\"data:image\")?this.el.style.backgroundImage=`url(\"${t}\")`:this.el.classList.add(t)),this.el.title=this.model.tooltip,this.el.tabIndex=0,null!=this._menu&&this.root.el.appendChild(this._menu.el)}_pressed(){var t;const e=(()=>{switch(this.parent.model.toolbar_location){case\"right\":return{left_of:this.el};case\"left\":return{right_of:this.el};case\"above\":return{below:this.el};case\"below\":return{above:this.el}}})();null===(t=this._menu)||void 0===t||t.toggle(e)}}o.ButtonToolButtonView=b,b.__name__=\"ButtonToolButtonView\";class w extends u.ToolView{}o.ButtonToolView=w,w.__name__=\"ButtonToolView\";class y extends u.Tool{constructor(t){super(t)}_get_dim_tooltip(t){const{description:e,tool_name:o}=this;return null!=e?e:\"both\"==t?o:`${o} (${\"width\"==t?\"x\":\"y\"}-axis)`}get tooltip(){var t;return null!==(t=this.description)&&void 0!==t?t:this.tool_name}get computed_icon(){return this.icon}get menu(){return null}}o.ButtonTool=y,l=y,y.__name__=\"ButtonTool\",l.internal((({Boolean:t})=>({disabled:[t,!1]})))},\n", " function _(t,e,i,n,r){\n", " /*! Hammer.JS - v2.0.7 - 2016-04-22\n", " * http://hammerjs.github.io/\n", " *\n", " * Copyright (c) 2016 Jorik Tangelder;\n", " * Licensed under the MIT license */\n", " !function(t,i,n,r){\"use strict\";var s,o=[\"\",\"webkit\",\"Moz\",\"MS\",\"ms\",\"o\"],a=i.createElement(\"div\"),h=Math.round,u=Math.abs,c=Date.now;function l(t,e,i){return setTimeout(T(t,i),e)}function p(t,e,i){return!!Array.isArray(t)&&(f(t,i[e],i),!0)}function f(t,e,i){var n;if(t)if(t.forEach)t.forEach(e,i);else if(t.length!==r)for(n=0;n\\s*\\(/gm,\"{anonymous}()@\"):\"Unknown Stack Trace\",s=t.console&&(t.console.warn||t.console.log);return s&&s.call(t.console,r,n),e.apply(this,arguments)}}s=\"function\"!=typeof Object.assign?function(t){if(t===r||null===t)throw new TypeError(\"Cannot convert undefined or null to object\");for(var e=Object(t),i=1;i-1}function S(t){return t.trim().split(/\\s+/g)}function b(t,e,i){if(t.indexOf&&!i)return t.indexOf(e);for(var n=0;ni[e]})):n.sort()),n}function x(t,e){for(var i,n,s=e[0].toUpperCase()+e.slice(1),a=0;a1&&!i.firstMultiple?i.firstMultiple=H(e):1===s&&(i.firstMultiple=!1);var o=i.firstInput,a=i.firstMultiple,h=a?a.center:o.center,l=e.center=L(n);e.timeStamp=c(),e.deltaTime=e.timeStamp-o.timeStamp,e.angle=G(h,l),e.distance=j(h,l),function(t,e){var i=e.center,n=t.offsetDelta||{},r=t.prevDelta||{},s=t.prevInput||{};1!==e.eventType&&4!==s.eventType||(r=t.prevDelta={x:s.deltaX||0,y:s.deltaY||0},n=t.offsetDelta={x:i.x,y:i.y});e.deltaX=r.x+(i.x-n.x),e.deltaY=r.y+(i.y-n.y)}(i,e),e.offsetDirection=V(e.deltaX,e.deltaY);var p=U(e.deltaTime,e.deltaX,e.deltaY);e.overallVelocityX=p.x,e.overallVelocityY=p.y,e.overallVelocity=u(p.x)>u(p.y)?p.x:p.y,e.scale=a?(f=a.pointers,v=n,j(v[0],v[1],W)/j(f[0],f[1],W)):1,e.rotation=a?function(t,e){return G(e[1],e[0],W)+G(t[1],t[0],W)}(a.pointers,n):0,e.maxPointers=i.prevInput?e.pointers.length>i.prevInput.maxPointers?e.pointers.length:i.prevInput.maxPointers:e.pointers.length,function(t,e){var i,n,s,o,a=t.lastInterval||e,h=e.timeStamp-a.timeStamp;if(8!=e.eventType&&(h>25||a.velocity===r)){var c=e.deltaX-a.deltaX,l=e.deltaY-a.deltaY,p=U(h,c,l);n=p.x,s=p.y,i=u(p.x)>u(p.y)?p.x:p.y,o=V(c,l),t.lastInterval=e}else i=a.velocity,n=a.velocityX,s=a.velocityY,o=a.direction;e.velocity=i,e.velocityX=n,e.velocityY=s,e.direction=o}(i,e);var f,v;var d=t.element;_(e.srcEvent.target,d)&&(d=e.srcEvent.target);e.target=d}(t,i),t.emit(\"hammer.input\",i),t.recognize(i),t.session.prevInput=i}function H(t){for(var e=[],i=0;i=u(e)?t<0?2:4:e<0?8:16}function j(t,e,i){i||(i=F);var n=e[i[0]]-t[i[0]],r=e[i[1]]-t[i[1]];return Math.sqrt(n*n+r*r)}function G(t,e,i){i||(i=F);var n=e[i[0]]-t[i[0]],r=e[i[1]]-t[i[1]];return 180*Math.atan2(r,n)/Math.PI}q.prototype={handler:function(){},init:function(){this.evEl&&I(this.element,this.evEl,this.domHandler),this.evTarget&&I(this.target,this.evTarget,this.domHandler),this.evWin&&I(O(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&A(this.element,this.evEl,this.domHandler),this.evTarget&&A(this.target,this.evTarget,this.domHandler),this.evWin&&A(O(this.element),this.evWin,this.domHandler)}};var Z={mousedown:1,mousemove:2,mouseup:4},B=\"mousedown\",$=\"mousemove mouseup\";function J(){this.evEl=B,this.evWin=$,this.pressed=!1,q.apply(this,arguments)}g(J,q,{handler:function(t){var e=Z[t.type];1&e&&0===t.button&&(this.pressed=!0),2&e&&1!==t.which&&(e=4),this.pressed&&(4&e&&(this.pressed=!1),this.callback(this.manager,e,{pointers:[t],changedPointers:[t],pointerType:X,srcEvent:t}))}});var K={pointerdown:1,pointermove:2,pointerup:4,pointercancel:8,pointerout:8},Q={2:N,3:\"pen\",4:X,5:\"kinect\"},tt=\"pointerdown\",et=\"pointermove pointerup pointercancel\";function it(){this.evEl=tt,this.evWin=et,q.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}t.MSPointerEvent&&!t.PointerEvent&&(tt=\"MSPointerDown\",et=\"MSPointerMove MSPointerUp MSPointerCancel\"),g(it,q,{handler:function(t){var e=this.store,i=!1,n=t.type.toLowerCase().replace(\"ms\",\"\"),r=K[n],s=Q[t.pointerType]||t.pointerType,o=s==N,a=b(e,t.pointerId,\"pointerId\");1&r&&(0===t.button||o)?a<0&&(e.push(t),a=e.length-1):12&r&&(i=!0),a<0||(e[a]=t,this.callback(this.manager,r,{pointers:e,changedPointers:[t],pointerType:s,srcEvent:t}),i&&e.splice(a,1))}});var nt={touchstart:1,touchmove:2,touchend:4,touchcancel:8},rt=\"touchstart\",st=\"touchstart touchmove touchend touchcancel\";function ot(){this.evTarget=rt,this.evWin=st,this.started=!1,q.apply(this,arguments)}function at(t,e){var i=P(t.touches),n=P(t.changedTouches);return 12&e&&(i=D(i.concat(n),\"identifier\",!0)),[i,n]}g(ot,q,{handler:function(t){var e=nt[t.type];if(1===e&&(this.started=!0),this.started){var i=at.call(this,t,e);12&e&&i[0].length-i[1].length==0&&(this.started=!1),this.callback(this.manager,e,{pointers:i[0],changedPointers:i[1],pointerType:N,srcEvent:t})}}});var ht={touchstart:1,touchmove:2,touchend:4,touchcancel:8},ut=\"touchstart touchmove touchend touchcancel\";function ct(){this.evTarget=ut,this.targetIds={},q.apply(this,arguments)}function lt(t,e){var i=P(t.touches),n=this.targetIds;if(3&e&&1===i.length)return n[i[0].identifier]=!0,[i,i];var r,s,o=P(t.changedTouches),a=[],h=this.target;if(s=i.filter((function(t){return _(t.target,h)})),1===e)for(r=0;r-1&&n.splice(t,1)}),2500)}}function dt(t){for(var e=t.srcEvent.clientX,i=t.srcEvent.clientY,n=0;n-1&&this.requireFail.splice(e,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(t){return!!this.simultaneous[t.id]},emit:function(t){var e=this,i=this.state;function n(i){e.manager.emit(i,t)}i<8&&n(e.options.event+Dt(i)),n(e.options.event),t.additionalEvent&&n(t.additionalEvent),i>=8&&n(e.options.event+Dt(i))},tryEmit:function(t){if(this.canEmit())return this.emit(t);this.state=bt},canEmit:function(){for(var t=0;te.threshold&&r&e.direction},attrTest:function(t){return Ot.prototype.attrTest.call(this,t)&&(2&this.state||!(2&this.state)&&this.directionTest(t))},emit:function(t){this.pX=t.deltaX,this.pY=t.deltaY;var e=xt(t.direction);e&&(t.additionalEvent=this.options.event+e),this._super.emit.call(this,t)}}),g(Mt,Ot,{defaults:{event:\"pinch\",threshold:0,pointers:2},getTouchAction:function(){return[It]},attrTest:function(t){return this._super.attrTest.call(this,t)&&(Math.abs(t.scale-1)>this.options.threshold||2&this.state)},emit:function(t){if(1!==t.scale){var e=t.scale<1?\"in\":\"out\";t.additionalEvent=this.options.event+e}this._super.emit.call(this,t)}}),g(zt,Pt,{defaults:{event:\"press\",pointers:1,time:251,threshold:9},getTouchAction:function(){return[yt]},process:function(t){var e=this.options,i=t.pointers.length===e.pointers,n=t.distancee.time;if(this._input=t,!n||!i||12&t.eventType&&!r)this.reset();else if(1&t.eventType)this.reset(),this._timer=l((function(){this.state=8,this.tryEmit()}),e.time,this);else if(4&t.eventType)return 8;return bt},reset:function(){clearTimeout(this._timer)},emit:function(t){8===this.state&&(t&&4&t.eventType?this.manager.emit(this.options.event+\"up\",t):(this._input.timeStamp=c(),this.manager.emit(this.options.event,this._input)))}}),g(Nt,Ot,{defaults:{event:\"rotate\",threshold:0,pointers:2},getTouchAction:function(){return[It]},attrTest:function(t){return this._super.attrTest.call(this,t)&&(Math.abs(t.rotation)>this.options.threshold||2&this.state)}}),g(Xt,Ot,{defaults:{event:\"swipe\",threshold:10,velocity:.3,direction:30,pointers:1},getTouchAction:function(){return Rt.prototype.getTouchAction.call(this)},attrTest:function(t){var e,i=this.options.direction;return 30&i?e=t.overallVelocity:6&i?e=t.overallVelocityX:i&Y&&(e=t.overallVelocityY),this._super.attrTest.call(this,t)&&i&t.offsetDirection&&t.distance>this.options.threshold&&t.maxPointers==this.options.pointers&&u(e)>this.options.velocity&&4&t.eventType},emit:function(t){var e=xt(t.offsetDirection);e&&this.manager.emit(this.options.event+e,t),this.manager.emit(this.options.event,t)}}),g(Yt,Pt,{defaults:{event:\"tap\",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[Et]},process:function(t){var e=this.options,i=t.pointers.length===e.pointers,n=t.distance .bk-divider{cursor:default;overflow:hidden;background-color:#e5e5e5;}.bk-root .bk-context-menu.bk-horizontal > .bk-divider{width:1px;margin:5px 0;}.bk-root .bk-context-menu.bk-vertical > .bk-divider{height:1px;margin:0 5px;}.bk-root .bk-context-menu > :not(.bk-divider){border:1px solid transparent;}.bk-root .bk-context-menu > :not(.bk-divider).bk-active{border-color:#26aae1;}.bk-root .bk-context-menu > :not(.bk-divider):hover{background-color:#f9f9f9;}.bk-root .bk-context-menu > :not(.bk-divider):focus,.bk-root .bk-context-menu > :not(.bk-divider):focus-visible{outline:1px dotted #26aae1;outline-offset:-1px;}.bk-root .bk-context-menu > :not(.bk-divider)::-moz-focus-inner{border:0;}.bk-root .bk-context-menu.bk-horizontal > :not(.bk-divider):first-child{border-top-left-radius:4px;border-bottom-left-radius:4px;}.bk-root .bk-context-menu.bk-horizontal > :not(.bk-divider):last-child{border-top-right-radius:4px;border-bottom-right-radius:4px;}.bk-root .bk-context-menu.bk-vertical > :not(.bk-divider):first-child{border-top-left-radius:4px;border-top-right-radius:4px;}.bk-root .bk-context-menu.bk-vertical > :not(.bk-divider):last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;}.bk-root .bk-menu{position:absolute;left:0;width:100%;z-index:100;cursor:pointer;font-size:12px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 6px 12px rgba(0, 0, 0, 0.175);}.bk-root .bk-menu.bk-above{bottom:100%;}.bk-root .bk-menu.bk-below{top:100%;}.bk-root .bk-menu > .bk-divider{height:1px;margin:7.5px 0;overflow:hidden;background-color:#e5e5e5;}.bk-root .bk-menu > :not(.bk-divider){padding:6px 12px;}.bk-root .bk-menu > :not(.bk-divider):hover,.bk-root .bk-menu > :not(.bk-divider).bk-active{background-color:#e6e6e6;}.bk-root .bk-caret{display:inline-block;vertical-align:middle;width:0;height:0;margin:0 5px;}.bk-root .bk-caret.bk-down{border-top:4px solid;}.bk-root .bk-caret.bk-up{border-bottom:4px solid;}.bk-root .bk-caret.bk-down,.bk-root .bk-caret.bk-up{border-right:4px solid transparent;border-left:4px solid transparent;}.bk-root .bk-caret.bk-left{border-right:4px solid;}.bk-root .bk-caret.bk-right{border-left:4px solid;}.bk-root .bk-caret.bk-left,.bk-root .bk-caret.bk-right{border-top:4px solid transparent;border-bottom:4px solid transparent;}\"},\n", " function _(t,e,i,n,o){n();const s=t(1),l=t(43),h=t(9),r=(0,s.__importStar)(t(229));class d{constructor(t,e={}){var i,n;this.items=t,this.el=(0,l.div)(),this._open=!1,this._item_click=t=>{var e;null===(e=t.handler)||void 0===e||e.call(t),this.hide()},this._on_mousedown=t=>{var e;const{target:i}=t;i instanceof Node&&this.el.contains(i)||(null===(e=this.prevent_hide)||void 0===e?void 0:e.call(this,t))||this.hide()},this._on_keydown=t=>{t.keyCode==l.Keys.Esc&&this.hide()},this._on_blur=()=>{this.hide()},this.orientation=null!==(i=e.orientation)&&void 0!==i?i:\"vertical\",this.reversed=null!==(n=e.reversed)&&void 0!==n&&n,this.prevent_hide=e.prevent_hide,(0,l.undisplay)(this.el)}get is_open(){return this._open}get can_open(){return 0!=this.items.length}remove(){(0,l.remove)(this.el),this._unlisten()}_listen(){document.addEventListener(\"mousedown\",this._on_mousedown),document.addEventListener(\"keydown\",this._on_keydown),window.addEventListener(\"blur\",this._on_blur)}_unlisten(){document.removeEventListener(\"mousedown\",this._on_mousedown),document.removeEventListener(\"keydown\",this._on_keydown),window.removeEventListener(\"blur\",this._on_blur)}_position(t){const e=this.el.parentElement;if(null!=e){const i=(()=>{if(\"left_of\"in t){const{left:e,top:i}=t.left_of.getBoundingClientRect();return{right:e,top:i}}if(\"right_of\"in t){const{top:e,right:i}=t.right_of.getBoundingClientRect();return{left:i,top:e}}if(\"below\"in t){const{left:e,bottom:i}=t.below.getBoundingClientRect();return{left:e,top:i}}if(\"above\"in t){const{left:e,top:i}=t.above.getBoundingClientRect();return{left:e,bottom:i}}return t})(),n=e.getBoundingClientRect();this.el.style.left=null!=i.left?i.left-n.left+\"px\":\"\",this.el.style.top=null!=i.top?i.top-n.top+\"px\":\"\",this.el.style.right=null!=i.right?n.right-i.right+\"px\":\"\",this.el.style.bottom=null!=i.bottom?n.bottom-i.bottom+\"px\":\"\"}}render(){var t;(0,l.empty)(this.el,!0),(0,l.classes)(this.el).add(\"bk-context-menu\",`bk-${this.orientation}`);const e=this.reversed?(0,h.reversed)(this.items):this.items;for(const i of e){let e;if(null==i)e=(0,l.div)({class:r.divider});else{if(null!=i.if&&!i.if())continue;if(null!=i.content)e=i.content;else{const n=null!=i.icon?(0,l.div)({class:[\"bk-menu-icon\",i.icon]}):null,o=[(null===(t=i.active)||void 0===t?void 0:t.call(i))?\"bk-active\":null,i.class];e=(0,l.div)({class:o,title:i.tooltip,tabIndex:0},n,i.label,i.content),e.addEventListener(\"click\",(()=>{this._item_click(i)})),e.addEventListener(\"keydown\",(t=>{t.keyCode==l.Keys.Enter&&this._item_click(i)}))}}this.el.appendChild(e)}}show(t){if(0!=this.items.length&&!this._open){if(this.render(),0==this.el.children.length)return;this._position(null!=t?t:{left:0,top:0}),(0,l.display)(this.el),this._listen(),this._open=!0}}hide(){this._open&&(this._open=!1,this._unlisten(),(0,l.undisplay)(this.el))}toggle(t){this._open?this.hide():this.show(t)}}i.ContextMenu=d,d.__name__=\"ContextMenu\"},\n", " function _(t,e,i,n,o){n();const s=t(1),c=t(224),l=(0,s.__importStar)(t(227)),a=t(43);class _ extends c.ButtonToolButtonView{render(){super.render(),(0,a.classes)(this.el).toggle(l.active,this.model.active)}_clicked(){const{active:t}=this.model;this.model.active=!t}}i.OnOffButtonView=_,_.__name__=\"OnOffButtonView\"},\n", " function _(e,o,t,n,s){var c;n();const l=e(224),_=e(231);class i extends l.ButtonToolView{}t.InspectToolView=i,i.__name__=\"InspectToolView\";class a extends l.ButtonTool{constructor(e){super(e),this.event_type=\"move\"}}t.InspectTool=a,c=a,a.__name__=\"InspectTool\",c.prototype.button_view=_.OnOffButtonView,c.define((({Boolean:e})=>({toggleable:[e,!0]}))),c.override({active:!0})},\n", " function _(t,o,e,l,i){l();const s=t(1);var n,a;const r=t(19),c=t(43),h=t(113),_=t(226),u=t(20),v=t(9),d=t(234),p=t(13),b=t(8),g=t(235),f=t(65),m=t(53),w=t(222),y=t(223),T=t(238),z=t(239),x=t(232),B=t(230),C=(0,s.__importStar)(t(227)),k=C,L=(0,s.__importStar)(t(240)),M=L;class S extends m.Model{constructor(t){super(t)}get visible(){var t;return!this.autohide||null!==(t=this._visible)&&void 0!==t&&t}}e.ToolbarViewModel=S,n=S,S.__name__=\"ToolbarViewModel\",n.define((({Boolean:t})=>({autohide:[t,!1]}))),n.internal((({Boolean:t,Nullable:o})=>({_visible:[o(t),null]})));class $ extends _.DOMView{constructor(){super(...arguments),this.layout={bbox:new f.BBox}}initialize(){super.initialize(),this._tool_button_views=new Map,this._toolbar_view_model=new S({autohide:this.model.autohide});const{toolbar_location:t}=this.model,o=\"left\"==t||\"above\"==t,e=this.model.horizontal?\"vertical\":\"horizontal\";this._overflow_menu=new B.ContextMenu([],{orientation:e,reversed:o})}async lazy_initialize(){await super.lazy_initialize(),await this._build_tool_button_views()}connect_signals(){super.connect_signals(),this.connect(this.model.properties.tools.change,(async()=>{await this._build_tool_button_views(),this.render()})),this.connect(this.model.properties.autohide.change,(()=>{this._toolbar_view_model.autohide=this.model.autohide,this._on_visible_change()})),this.connect(this._toolbar_view_model.properties._visible.change,(()=>this._on_visible_change()))}styles(){return[...super.styles(),C.default,L.default]}remove(){(0,h.remove_views)(this._tool_button_views),super.remove()}async _build_tool_button_views(){const t=null!=this.model._proxied_tools?this.model._proxied_tools:this.model.tools;await(0,h.build_views)(this._tool_button_views,t,{parent:this},(t=>t.button_view))}set_visibility(t){t!=this._toolbar_view_model._visible&&(this._toolbar_view_model._visible=t)}_on_visible_change(){const{visible:t}=this._toolbar_view_model;(0,c.classes)(this.el).toggle(k.toolbar_hidden,!t)}render(){(0,c.empty)(this.el),this.el.classList.add(k.toolbar),this.el.classList.add(k[this.model.toolbar_location]),this._toolbar_view_model.autohide=this.model.autohide,this._on_visible_change();const{horizontal:t}=this.model;let o=0;if(null!=this.model.logo){const e=\"grey\"===this.model.logo?M.grey:null,l=(0,c.a)({href:\"https://bokeh.org/\",target:\"_blank\",class:[M.logo,M.logo_small,e]});this.el.appendChild(l);const{width:i,height:s}=l.getBoundingClientRect();o+=t?i:s}for(const[,t]of this._tool_button_views)t.render();const e=[],l=t=>this._tool_button_views.get(t).el,{gestures:i}=this.model;for(const t of(0,p.values)(i))e.push(t.tools.map(l));e.push(this.model.actions.map(l)),e.push(this.model.inspectors.filter((t=>t.toggleable)).map(l));const s=e.filter((t=>0!=t.length)),n=()=>(0,c.div)({class:k.divider}),{bbox:a}=this.layout;let r=!1;this.root.el.appendChild(this._overflow_menu.el);const h=(0,c.div)({class:k.tool_overflow,tabIndex:0},t?\"\\u22ee\":\"\\u22ef\"),_=()=>{const t=(()=>{switch(this.model.toolbar_location){case\"right\":return{left_of:h};case\"left\":return{right_of:h};case\"above\":return{below:h};case\"below\":return{above:h}}})();this._overflow_menu.toggle(t)};h.addEventListener(\"click\",(()=>{_()})),h.addEventListener(\"keydown\",(t=>{t.keyCode==c.Keys.Enter&&_()}));for(const e of(0,d.join)(s,n))if(r)this._overflow_menu.items.push({content:e,class:t?k.right:k.above});else{this.el.appendChild(e);const{width:l,height:i}=e.getBoundingClientRect();if(o+=t?l:i,r=t?o>a.width-15:o>a.height-15,r){this.el.removeChild(e),this.el.appendChild(h);const{items:t}=this._overflow_menu;t.splice(0,t.length),t.push({content:e})}}}update_layout(){}update_position(){}after_layout(){this._has_finished=!0}export(t,o=!0){const e=\"png\"==t?\"canvas\":\"svg\",l=new g.CanvasLayer(e,o);return l.resize(0,0),l}}function V(){return{pan:{tools:[],active:null},scroll:{tools:[],active:null},pinch:{tools:[],active:null},tap:{tools:[],active:null},doubletap:{tools:[],active:null},press:{tools:[],active:null},pressup:{tools:[],active:null},rotate:{tools:[],active:null},move:{tools:[],active:null},multi:{tools:[],active:null}}}e.ToolbarBaseView=$,$.__name__=\"ToolbarBaseView\";class A extends m.Model{constructor(t){super(t)}initialize(){super.initialize(),this._init_tools()}_init_tools(){const t=function(t,o){if(t.length!=o.length)return!0;const e=new Set(o.map((t=>t.id)));return(0,v.some)(t,(t=>!e.has(t.id)))},o=this.tools.filter((t=>t instanceof x.InspectTool));t(this.inspectors,o)&&(this.inspectors=o);const e=this.tools.filter((t=>t instanceof z.HelpTool));t(this.help,e)&&(this.help=e);const l=this.tools.filter((t=>t instanceof T.ActionTool));t(this.actions,l)&&(this.actions=l);const i=(t,o)=>{t in this.gestures||r.logger.warn(`Toolbar: unknown event type '${t}' for tool: ${o}`)},s={pan:{tools:[],active:null},scroll:{tools:[],active:null},pinch:{tools:[],active:null},tap:{tools:[],active:null},doubletap:{tools:[],active:null},press:{tools:[],active:null},pressup:{tools:[],active:null},rotate:{tools:[],active:null},move:{tools:[],active:null},multi:{tools:[],active:null}};for(const t of this.tools)if(t instanceof y.GestureTool&&t.event_type)if((0,b.isString)(t.event_type))s[t.event_type].tools.push(t),i(t.event_type,t);else{s.multi.tools.push(t);for(const o of t.event_type)i(o,t)}for(const o of Object.keys(s)){const e=this.gestures[o];t(e.tools,s[o].tools)&&(e.tools=s[o].tools),e.active&&(0,v.every)(e.tools,(t=>t.id!=e.active.id))&&(e.active=null)}}get horizontal(){return\"above\"===this.toolbar_location||\"below\"===this.toolbar_location}get vertical(){return\"left\"===this.toolbar_location||\"right\"===this.toolbar_location}_active_change(t){const{event_type:o}=t;if(null==o)return;const e=(0,b.isString)(o)?[o]:o;for(const o of e)if(t.active){const e=this.gestures[o].active;null!=e&&t!=e&&(r.logger.debug(`Toolbar: deactivating tool: ${e} for event type '${o}'`),e.active=!1),this.gestures[o].active=t,r.logger.debug(`Toolbar: activating tool: ${t} for event type '${o}'`)}else this.gestures[o].active=null}}e.ToolbarBase=A,a=A,A.__name__=\"ToolbarBase\",a.prototype.default_view=$,a.define((({Boolean:t,Array:o,Ref:e,Nullable:l})=>({tools:[o(e(w.Tool)),[]],logo:[l(u.Logo),\"normal\"],autohide:[t,!1]}))),a.internal((({Array:t,Struct:o,Ref:e,Nullable:l})=>{const i=o({tools:t(e(y.GestureTool)),active:l(e(w.Tool))});return{gestures:[o({pan:i,scroll:i,pinch:i,tap:i,doubletap:i,press:i,pressup:i,rotate:i,move:i,multi:i}),V],actions:[t(e(T.ActionTool)),[]],inspectors:[t(e(x.InspectTool)),[]],help:[t(e(z.HelpTool)),[]],toolbar_location:[u.Location,\"right\"]}}))},\n", " function _(n,o,e,t,f){t();const r=n(9);function*i(n,o){const e=n.length;if(o>e)return;const t=(0,r.range)(o);for(yield t.map((o=>n[o]));;){let f;for(const n of(0,r.reversed)((0,r.range)(o)))if(t[n]!=n+e-o){f=n;break}if(null==f)return;t[f]+=1;for(const n of(0,r.range)(f+1,o))t[n]=t[n-1]+1;yield t.map((o=>n[o]))}}e.enumerate=function*(n){let o=0;for(const e of n)yield[e,o++]},e.join=function*(n,o){let e=!0;for(const t of n)e?e=!1:null!=o&&(yield o()),yield*t},e.combinations=i,e.subsets=function*(n){for(const o of(0,r.range)(n.length+1))yield*i(n,o)}},\n", " function _(t,e,s,i,n){i();const o=t(236),a=t(65),r=t(43);function h(t){!function(t){void 0===t.lineDash&&Object.defineProperty(t,\"lineDash\",{get:()=>t.getLineDash(),set:e=>t.setLineDash(e)})}(t),function(t){t.setImageSmoothingEnabled=e=>{t.imageSmoothingEnabled=e,t.mozImageSmoothingEnabled=e,t.oImageSmoothingEnabled=e,t.webkitImageSmoothingEnabled=e,t.msImageSmoothingEnabled=e},t.getImageSmoothingEnabled=()=>{const e=t.imageSmoothingEnabled;return null==e||e}}(t),function(t){t.ellipse||(t.ellipse=function(e,s,i,n,o,a,r,h=!1){const l=.551784;t.translate(e,s),t.rotate(o);let c=i,g=n;h&&(c=-i,g=-n),t.moveTo(-c,0),t.bezierCurveTo(-c,g*l,-c*l,g,0,g),t.bezierCurveTo(c*l,g,c,g*l,c,0),t.bezierCurveTo(c,-g*l,c*l,-g,0,-g),t.bezierCurveTo(-c*l,-g,-c,-g*l,-c,0),t.rotate(-o),t.translate(-e,-s)})}(t)}const l={position:\"absolute\",top:\"0\",left:\"0\",width:\"100%\",height:\"100%\"};class c{constructor(t,e){switch(this.backend=t,this.hidpi=e,this.pixel_ratio=1,this.bbox=new a.BBox,t){case\"webgl\":case\"canvas\":{this._el=this._canvas=(0,r.canvas)({style:l});const t=this.canvas.getContext(\"2d\");if(null==t)throw new Error(\"unable to obtain 2D rendering context\");this._ctx=t,e&&(this.pixel_ratio=devicePixelRatio);break}case\"svg\":{const t=new o.SVGRenderingContext2D;this._ctx=t,this._canvas=t.get_svg(),this._el=(0,r.div)({style:l},this._canvas);break}}this._ctx.layer=this,h(this._ctx)}get canvas(){return this._canvas}get ctx(){return this._ctx}get el(){return this._el}resize(t,e){this.bbox=new a.BBox({left:0,top:0,width:t,height:e});const s=this._ctx instanceof o.SVGRenderingContext2D?this._ctx:this.canvas;s.width=t*this.pixel_ratio,s.height=e*this.pixel_ratio}undo_transform(t){const{ctx:e}=this;if(void 0===e.getTransform)t(e);else{const s=e.getTransform();e.setTransform(this._base_transform);try{t(e)}finally{e.setTransform(s)}}}prepare(){const{ctx:t,hidpi:e,pixel_ratio:s}=this;t.save(),e&&(t.scale(s,s),t.translate(.5,.5)),void 0!==t.getTransform&&(this._base_transform=t.getTransform()),this.clear()}clear(){const{x:t,y:e,width:s,height:i}=this.bbox;this.ctx.clearRect(t,e,s,i)}finish(){this.ctx.restore()}to_blob(){const{_canvas:t}=this;if(t instanceof HTMLCanvasElement)return null!=t.msToBlob?Promise.resolve(t.msToBlob()):new Promise(((e,s)=>{t.toBlob((t=>null!=t?e(t):s()),\"image/png\")}));{const t=this._ctx.get_serialized_svg(!0),e=new Blob([t],{type:\"image/svg+xml\"});return Promise.resolve(e)}}}s.CanvasLayer=c,c.__name__=\"CanvasLayer\"},\n", " function _(t,e,i,s,r){s();const n=t(122),a=t(8),o=t(237),l=t(10),h=t(43);function _(t){var e;const i={left:\"start\",right:\"end\",center:\"middle\",start:\"start\",end:\"end\"};return null!==(e=i[t])&&void 0!==e?e:i.start}function c(t){var e;const i={alphabetic:\"alphabetic\",hanging:\"hanging\",top:\"text-before-edge\",bottom:\"text-after-edge\",middle:\"central\"};return null!==(e=i[t])&&void 0!==e?e:i.alphabetic}const p=function(t,e){const i=new Map,s=t.split(\",\");e=null!=e?e:10;for(let t=0;t=0?Math.acos(e):-Math.acos(e)}const v=b(f),A=b(g);this.lineTo(d+f[0]*r,m+f[1]*r),this.arc(d,m,r,v,A)}stroke(){\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"fill\"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"stroke\"),null!=this._clip_path&&this.__currentElement.setAttribute(\"clip-path\",this._clip_path)}fill(t,e){let i=null;if(t instanceof Path2D)i=t;else{if(\"evenodd\"!=t&&\"nonzero\"!=t&&null!=t||null!=e)throw new Error(\"invalid arguments\");e=t}if(null!=i)throw new Error(\"not implemented\");\"none\"!=this.__currentElement.getAttribute(\"fill\")&&this.__init_element(),\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"stroke\"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"fill\"),null!=e&&this.__currentElement.setAttribute(\"fill-rule\",e),null!=this._clip_path&&this.__currentElement.setAttribute(\"clip-path\",this._clip_path)}rect(t,e,i,s){isFinite(t+e+i+s)&&(this.moveTo(t,e),this.lineTo(t+i,e),this.lineTo(t+i,e+s),this.lineTo(t,e+s),this.lineTo(t,e))}fillRect(t,e,i,s){isFinite(t+e+i+s)&&(this.beginPath(),this.rect(t,e,i,s),this.fill())}strokeRect(t,e,i,s){isFinite(t+e+i+s)&&(this.beginPath(),this.rect(t,e,i,s),this.stroke())}__clearCanvas(){(0,h.empty)(this.__defs),(0,h.empty)(this.__root),this.__root.appendChild(this.__defs),this.__currentElement=this.__root}clearRect(t,e,i,s){if(!isFinite(t+e+i+s))return;if(0===t&&0===e&&i===this.width&&s===this.height)return void this.__clearCanvas();const r=this.__createElement(\"rect\",{x:t,y:e,width:i,height:s,fill:\"#FFFFFF\"},!0);this._apply_transform(r),this.__root.appendChild(r)}createLinearGradient(t,e,i,s){if(!isFinite(t+e+i+s))throw new Error(\"The provided double value is non-finite\");const[r,n]=this._transform.apply(t,e),[a,o]=this._transform.apply(i,s),l=this.__createElement(\"linearGradient\",{id:this._random_string(),x1:`${r}px`,x2:`${a}px`,y1:`${n}px`,y2:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(l),new d(l,this)}createRadialGradient(t,e,i,s,r,n){if(!isFinite(t+e+i+s+r+n))throw new Error(\"The provided double value is non-finite\");const[a,o]=this._transform.apply(t,e),[l,h]=this._transform.apply(s,r),_=this.__createElement(\"radialGradient\",{id:this._random_string(),cx:`${l}px`,cy:`${h}px`,r:`${n}px`,r0:`${i}px`,fx:`${a}px`,fy:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(_),new d(_,this)}__parseFont(){var t,e,i,s,r;const n=/^\\s*(?=(?:(?:[-a-z]+\\s*){0,2}(italic|oblique))?)(?=(?:(?:[-a-z]+\\s*){0,2}(small-caps))?)(?=(?:(?:[-a-z]+\\s*){0,2}(bold(?:er)?|lighter|[1-9]00))?)(?:(?:normal|\\1|\\2|\\3)\\s*){0,3}((?:xx?-)?(?:small|large)|medium|smaller|larger|[.\\d]+(?:\\%|in|[cem]m|ex|p[ctx]))(?:\\s*\\/\\s*(normal|[.\\d]+(?:\\%|in|[cem]m|ex|p[ctx])))?\\s*([-,\\'\\\"\\sa-z0-9]+?)\\s*$/i.exec(this.font);return{style:null!==(t=n[1])&&void 0!==t?t:\"normal\",size:null!==(e=n[4])&&void 0!==e?e:\"10px\",family:null!==(i=n[6])&&void 0!==i?i:\"sans-serif\",weight:null!==(s=n[3])&&void 0!==s?s:\"normal\",decoration:null!==(r=n[2])&&void 0!==r?r:\"normal\"}}__applyText(t,e,i,s){const r=this.__parseFont(),n=this.__createElement(\"text\",{\"font-family\":r.family,\"font-size\":r.size,\"font-style\":r.style,\"font-weight\":r.weight,\"text-decoration\":r.decoration,x:e,y:i,\"text-anchor\":_(this.textAlign),\"dominant-baseline\":c(this.textBaseline)},!0);n.appendChild(this.__document.createTextNode(t)),this._apply_transform(n),this.__currentElement=n,this.__applyStyleToCurrentElement(s);const a=(()=>{if(null!=this._clip_path){const t=this.__createElement(\"g\");return t.setAttribute(\"clip-path\",this._clip_path),t.appendChild(n),t}return n})();this.__root.appendChild(a)}fillText(t,e,i){null!=t&&isFinite(e+i)&&this.__applyText(t,e,i,\"fill\")}strokeText(t,e,i){null!=t&&isFinite(e+i)&&this.__applyText(t,e,i,\"stroke\")}measureText(t){return this.__ctx.font=this.font,this.__ctx.measureText(t)}arc(t,e,i,s,r,n=!1){this.ellipse(t,e,i,i,0,s,r,n)}ellipse(t,e,i,s,r,n,a,o=!1){if(!isFinite(t+e+i+s+r+n+a))return;if(i<0||s<0)throw new DOMException(\"IndexSizeError, radius can't be negative\");const h=o?a-n:n-a;n%=2*Math.PI,a%=2*Math.PI;const _=t+i*Math.cos(n),c=e+s*Math.sin(n);this.lineTo(_,c);const p=180*r/Math.PI,u=o?0:1;if(Math.abs(n-a)<2*l.float32_epsilon&&!(Math.abs(h)<2*l.float32_epsilon&&h<0)){const r=t+i*Math.cos(n+Math.PI),a=e+s*Math.sin(n+Math.PI),[o,l]=this._transform.apply(_,c),[h,d]=this._transform.apply(r,a);this.__addPathCommand(o,l,`A ${i} ${s} ${p} 0 ${u} ${h} ${d} A ${i} ${s} ${p} 0 ${u} ${o} ${l}`)}else{const r=t+i*Math.cos(a),l=e+s*Math.sin(a);let h=a-n;h<0&&(h+=2*Math.PI);const _=o!==h>Math.PI?1:0,[c,d]=this._transform.apply(r,l);this.__addPathCommand(c,d,`A ${i} ${s} ${p} ${_} ${u} ${c} ${d}`)}}clip(){const t=this.__createElement(\"clipPath\"),e=this._random_string();this.__applyCurrentDefaultPath(),t.setAttribute(\"id\",e),t.appendChild(this.__currentElement),this.__defs.appendChild(t),this._clip_path=`url(#${e})`}drawImage(t,...e){let i,s,r,n,a,o,l,h;if(2==e.length){if([i,s]=e,!isFinite(i+s))return;a=0,o=0,l=t.width,h=t.height,r=l,n=h}else if(4==e.length){if([i,s,r,n]=e,!isFinite(i+s+r+n))return;a=0,o=0,l=t.width,h=t.height}else{if(8!==e.length)throw new Error(`Inavlid number of arguments passed to drawImage: ${arguments.length}`);if([a,o,l,h,i,s,r,n]=e,!isFinite(a+o+l+h+i+s+r+n))return}const _=this.__root,c=this._transform.clone().translate(i,s);if(t instanceof f||t instanceof SVGSVGElement){const e=(t instanceof SVGSVGElement?t:t.get_svg()).cloneNode(!0);let i;c.is_identity&&1==this.globalAlpha&&null==this._clip_path?i=_:(i=this.__createElement(\"g\"),c.is_identity||this._apply_transform(i,c),1!=this.globalAlpha&&i.setAttribute(\"opacity\",`${this.globalAlpha}`),null!=this._clip_path&&i.setAttribute(\"clip-path\",this._clip_path),_.appendChild(i));for(const t of[...e.childNodes])if(t instanceof SVGDefsElement){for(const e of[...t.childNodes])if(e instanceof Element){const t=e.getAttribute(\"id\");this.__ids.add(t),this.__defs.appendChild(e.cloneNode(!0))}}else i.appendChild(t.cloneNode(!0))}else if(t instanceof HTMLImageElement||t instanceof SVGImageElement){const e=this.__createElement(\"image\");if(e.setAttribute(\"width\",`${r}`),e.setAttribute(\"height\",`${n}`),e.setAttribute(\"preserveAspectRatio\",\"none\"),1!=this.globalAlpha&&e.setAttribute(\"opacity\",`${this.globalAlpha}`),a||o||l!==t.width||h!==t.height){const e=this.__document.createElement(\"canvas\");e.width=r,e.height=n;e.getContext(\"2d\").drawImage(t,a,o,l,h,0,0,r,n),t=e}this._apply_transform(e,c);const i=t instanceof HTMLCanvasElement?t.toDataURL():t.getAttribute(\"src\");if(e.setAttribute(\"href\",i),null!=this._clip_path){const t=this.__createElement(\"g\");t.setAttribute(\"clip-path\",this._clip_path),t.appendChild(e),_.appendChild(t)}else _.appendChild(e)}else if(t instanceof HTMLCanvasElement){const e=this.__createElement(\"image\");e.setAttribute(\"width\",`${r}`),e.setAttribute(\"height\",`${n}`),e.setAttribute(\"preserveAspectRatio\",\"none\"),1!=this.globalAlpha&&e.setAttribute(\"opacity\",`${this.globalAlpha}`);const i=this.__document.createElement(\"canvas\");i.width=r,i.height=n;const s=i.getContext(\"2d\");if(s.imageSmoothingEnabled=!1,s.drawImage(t,a,o,l,h,0,0,r,n),t=i,this._apply_transform(e,c),e.setAttribute(\"href\",t.toDataURL()),null!=this._clip_path){const t=this.__createElement(\"g\");t.setAttribute(\"clip-path\",this._clip_path),t.appendChild(e),_.appendChild(t)}else _.appendChild(e)}}createPattern(t,e){const i=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"pattern\"),s=this._random_string();if(i.setAttribute(\"id\",s),i.setAttribute(\"width\",`${this._to_number(t.width)}`),i.setAttribute(\"height\",`${this._to_number(t.height)}`),i.setAttribute(\"patternUnits\",\"userSpaceOnUse\"),t instanceof HTMLCanvasElement||t instanceof HTMLImageElement||t instanceof SVGImageElement){const e=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"image\"),s=t instanceof HTMLCanvasElement?t.toDataURL():t.getAttribute(\"src\");e.setAttribute(\"href\",s),i.appendChild(e),this.__defs.appendChild(i)}else if(t instanceof f){for(const e of[...t.__root.childNodes])e instanceof SVGDefsElement||i.appendChild(e.cloneNode(!0));this.__defs.appendChild(i)}else{if(!(t instanceof SVGSVGElement))throw new Error(\"unsupported\");for(const e of[...t.childNodes])e instanceof SVGDefsElement||i.appendChild(e.cloneNode(!0));this.__defs.appendChild(i)}return new m(i,this)}getLineDash(){const{lineDash:t}=this;return(0,a.isString)(t)?t.split(\",\").map((t=>parseInt(t))):null==t?[]:t}setLineDash(t){t&&t.length>0?this.lineDash=t.join(\",\"):this.lineDash=null}_to_number(t){return(0,a.isNumber)(t)?t:t.baseVal.value}getTransform(){return this._transform.to_DOMMatrix()}setTransform(...t){let e;e=(0,a.isNumber)(t[0])?new DOMMatrix(t):t[0]instanceof DOMMatrix?t[0]:new DOMMatrix(Object.values(!t[0])),this._transform=n.AffineTransform.from_DOMMatrix(e)}resetTransform(){this._transform=new n.AffineTransform}isPointInPath(...t){throw new Error(\"not implemented\")}isPointInStroke(...t){throw new Error(\"not implemented\")}createImageData(...t){throw new Error(\"not implemented\")}getImageData(t,e,i,s){throw new Error(\"not implemented\")}putImageData(...t){throw new Error(\"not implemented\")}drawFocusIfNeeded(...t){throw new Error(\"not implemented\")}scrollPathIntoView(...t){throw new Error(\"not implemented\")}}i.SVGRenderingContext2D=f,f.__name__=\"SVGRenderingContext2D\",f.__random=o.random},\n", " function _(e,t,s,n,r){n();const o=2147483647;class i{constructor(e){this.seed=e%o,this.seed<=0&&(this.seed+=2147483646)}integer(){return this.seed=48271*this.seed%o,this.seed}float(){return(this.integer()-1)/2147483646}floats(e,t=0,s=1){const n=new Array(e);for(let r=0;rthis.doit(o)))}}n.ActionToolView=_,_.__name__=\"ActionToolView\";class d extends s.ButtonTool{constructor(o){super(o),this.button_view=l,this.do=new c.Signal(this,\"do\")}}n.ActionTool=d,d.__name__=\"ActionTool\"},\n", " function _(o,e,t,l,i){var s;l();const n=o(238),r=o(228);class c extends n.ActionToolView{doit(){window.open(this.model.redirect)}}t.HelpToolView=c,c.__name__=\"HelpToolView\";class _ extends n.ActionTool{constructor(o){super(o),this.tool_name=\"Help\",this.icon=r.tool_icon_help}}t.HelpTool=_,s=_,_.__name__=\"HelpTool\",s.prototype.default_view=c,s.define((({String:o})=>({redirect:[o,\"https://docs.bokeh.org/en/latest/docs/user_guide/tools.html\"]}))),s.override({description:\"Click the question mark to learn more about Bokeh plot tools.\"}),s.register_alias(\"help\",(()=>new _))},\n", " function _(o,l,g,A,r){A(),g.root=\"bk-root\",g.logo=\"bk-logo\",g.grey=\"bk-grey\",g.logo_small=\"bk-logo-small\",g.logo_notebook=\"bk-logo-notebook\",g.default=\".bk-root .bk-logo{margin:5px;position:relative;display:block;background-repeat:no-repeat;}.bk-root .bk-logo.bk-grey{filter:url(\\\"data:image/svg+xml;utf8,#grayscale\\\");filter:gray;-webkit-filter:grayscale(100%);}.bk-root .bk-logo-small{width:20px;height:20px;background-image:url();}.bk-root .bk-logo-notebook{display:inline-block;vertical-align:middle;margin-right:5px;}\"},\n", " function _(e,t,s,i,l){i();const o=e(1);var n;const a=e(40),h=e(20),r=e(43),c=(0,o.__importStar)(e(242)),d=c;class p extends a.AnnotationView{initialize(){super.initialize(),this.el=(0,r.div)({class:d.tooltip}),(0,r.undisplay)(this.el),this.plot_view.canvas_view.add_overlay(this.el)}remove(){(0,r.remove)(this.el),super.remove()}connect_signals(){super.connect_signals(),this.connect(this.model.properties.content.change,(()=>this.render())),this.connect(this.model.properties.position.change,(()=>this._reposition()))}styles(){return[...super.styles(),c.default]}render(){this.model.visible||(0,r.undisplay)(this.el),super.render()}_render(){const{content:e}=this.model;null!=e?((0,r.empty)(this.el),(0,r.classes)(this.el).toggle(\"bk-tooltip-custom\",this.model.custom),this.el.appendChild(e),this.model.show_arrow&&this.el.classList.add(d.tooltip_arrow)):(0,r.undisplay)(this.el)}_reposition(){const{position:e}=this.model;if(null==e)return void(0,r.undisplay)(this.el);const[t,s]=e,i=(()=>{const e=this.parent.layout.bbox.relative(),{attachment:i}=this.model;switch(i){case\"horizontal\":return t({attachment:[h.TooltipAttachment,\"horizontal\"],inner_only:[e,!0],show_arrow:[e,!0]}))),n.internal((({Boolean:e,Number:t,Tuple:s,Ref:i,Nullable:l})=>({position:[l(s(t,t)),null],content:[i(HTMLElement),()=>(0,r.div)()],custom:[e]}))),n.override({level:\"overlay\"})},\n", " function _(o,t,r,e,l){e(),r.root=\"bk-root\",r.tooltip=\"bk-tooltip\",r.left=\"bk-left\",r.tooltip_arrow=\"bk-tooltip-arrow\",r.right=\"bk-right\",r.above=\"bk-above\",r.below=\"bk-below\",r.tooltip_row_label=\"bk-tooltip-row-label\",r.tooltip_row_value=\"bk-tooltip-row-value\",r.tooltip_color_block=\"bk-tooltip-color-block\",r.default='.bk-root{}.bk-root .bk-tooltip{font-weight:300;font-size:12px;position:absolute;padding:5px;border:1px solid #e5e5e5;color:#2f2f2f;background-color:white;pointer-events:none;opacity:0.95;z-index:100;}.bk-root .bk-tooltip > div:not(:first-child){margin-top:5px;border-top:#e5e5e5 1px dashed;}.bk-root .bk-tooltip.bk-left.bk-tooltip-arrow::before{position:absolute;margin:-7px 0 0 0;top:50%;width:0;height:0;border-style:solid;border-width:7px 0 7px 0;border-color:transparent;content:\" \";display:block;left:-10px;border-right-width:10px;border-right-color:#909599;}.bk-root .bk-tooltip.bk-left::before{left:-10px;border-right-width:10px;border-right-color:#909599;}.bk-root .bk-tooltip.bk-right.bk-tooltip-arrow::after{position:absolute;margin:-7px 0 0 0;top:50%;width:0;height:0;border-style:solid;border-width:7px 0 7px 0;border-color:transparent;content:\" \";display:block;right:-10px;border-left-width:10px;border-left-color:#909599;}.bk-root .bk-tooltip.bk-right::after{right:-10px;border-left-width:10px;border-left-color:#909599;}.bk-root .bk-tooltip.bk-above::before{position:absolute;margin:0 0 0 -7px;left:50%;width:0;height:0;border-style:solid;border-width:0 7px 0 7px;border-color:transparent;content:\" \";display:block;top:-10px;border-bottom-width:10px;border-bottom-color:#909599;}.bk-root .bk-tooltip.bk-below::after{position:absolute;margin:0 0 0 -7px;left:50%;width:0;height:0;border-style:solid;border-width:0 7px 0 7px;border-color:transparent;content:\" \";display:block;bottom:-10px;border-top-width:10px;border-top-color:#909599;}.bk-root .bk-tooltip-row-label{text-align:right;color:#26aae1;}.bk-root .bk-tooltip-row-value{color:default;}.bk-root .bk-tooltip-color-block{width:12px;height:12px;margin-left:5px;margin-right:5px;outline:#dddddd solid 1px;display:inline-block;}'},\n", " function _(e,t,s,i,r){var a;i();const l=e(115),_=e(112),h=e(113),o=e(48);class n extends l.UpperLowerView{async lazy_initialize(){await super.lazy_initialize();const{lower_head:e,upper_head:t}=this.model;null!=e&&(this.lower_head=await(0,h.build_view)(e,{parent:this})),null!=t&&(this.upper_head=await(0,h.build_view)(t,{parent:this}))}set_data(e){var t,s;super.set_data(e),null===(t=this.lower_head)||void 0===t||t.set_data(e),null===(s=this.upper_head)||void 0===s||s.set_data(e)}paint(e){if(this.visuals.line.doit)for(let t=0,s=this._lower_sx.length;t({lower_head:[t(e(_.ArrowHead)),()=>new _.TeeHead({size:10})],upper_head:[t(e(_.ArrowHead)),()=>new _.TeeHead({size:10})]}))),a.override({level:\"underlay\"})},\n", " function _(n,o,t,u,e){u(),e(\"CustomJS\",n(245).CustomJS),e(\"OpenURL\",n(247).OpenURL)},\n", " function _(t,e,s,n,c){var a;n();const r=t(246),u=t(13),o=t(34);class i extends r.Callback{constructor(t){super(t)}get names(){return(0,u.keys)(this.args)}get values(){return(0,u.values)(this.args)}get func(){const t=(0,o.use_strict)(this.code);return new Function(...this.names,\"cb_obj\",\"cb_data\",t)}execute(t,e={}){return this.func.apply(t,this.values.concat(t,e))}}s.CustomJS=i,a=i,i.__name__=\"CustomJS\",a.define((({Unknown:t,String:e,Dict:s})=>({args:[s(t),{}],code:[e,\"\"]})))},\n", " function _(c,a,l,n,s){n();const e=c(53);class o extends e.Model{constructor(c){super(c)}}l.Callback=o,o.__name__=\"Callback\"},\n", " function _(e,t,n,o,i){var s;o();const c=e(246),r=e(152),a=e(8);class d extends c.Callback{constructor(e){super(e)}navigate(e){this.same_tab?window.location.href=e:window.open(e)}execute(e,{source:t}){const n=e=>{const n=(0,r.replace_placeholders)(this.url,t,e,void 0,void 0,encodeURI);if(!(0,a.isString)(n))throw new Error(\"HTML output is not supported in this context\");this.navigate(n)},{selected:o}=t;for(const e of o.indices)n(e);for(const e of o.line_indices)n(e)}}n.OpenURL=d,s=d,d.__name__=\"OpenURL\",s.define((({Boolean:e,String:t})=>({url:[t,\"http://\"],same_tab:[e,!1]})))},\n", " function _(a,n,i,e,r){e(),r(\"Canvas\",a(249).Canvas),r(\"CartesianFrame\",a(126).CartesianFrame),r(\"CoordinateMapping\",a(54).CoordinateMapping)},\n", " function _(e,t,i,s,a){var r,l=this&&this.__createBinding||(Object.create?function(e,t,i,s){void 0===s&&(s=i),Object.defineProperty(e,s,{enumerable:!0,get:function(){return t[i]}})}:function(e,t,i,s){void 0===s&&(s=i),e[s]=t[i]}),n=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,\"default\",{enumerable:!0,value:t})}:function(e,t){e.default=t}),o=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var i in e)\"default\"!==i&&Object.prototype.hasOwnProperty.call(e,i)&&l(t,e,i);return n(t,e),t};s();const h=e(14),c=e(226),u=e(19),_=e(43),d=e(20),p=e(13),b=e(250),v=e(65),g=e(138),w=e(235);const y=(()=>{let t;return async()=>void 0!==t?t:t=await async function(){const t=document.createElement(\"canvas\"),i=t.getContext(\"webgl\",{premultipliedAlpha:!0});if(null!=i){const s=await(0,g.load_module)(Promise.resolve().then((()=>o(e(410)))));if(null!=s){const e=s.get_regl(i);if(e.has_webgl)return{canvas:t,regl_wrapper:e};u.logger.trace(\"WebGL is supported, but not the required extensions\")}else u.logger.trace(\"WebGL is supported, but bokehjs(.min).js bundle is not available\")}else u.logger.trace(\"WebGL is not supported\");return null}()})(),m={position:\"absolute\",top:\"0\",left:\"0\",width:\"100%\",height:\"100%\"};class f extends c.DOMView{constructor(){super(...arguments),this.bbox=new v.BBox,this.webgl=null}initialize(){super.initialize(),this.underlays_el=(0,_.div)({style:m}),this.primary=this.create_layer(),this.overlays=this.create_layer(),this.overlays_el=(0,_.div)({style:m}),this.events_el=(0,_.div)({class:\"bk-canvas-events\",style:m});const e=[this.underlays_el,this.primary.el,this.overlays.el,this.overlays_el,this.events_el];(0,p.extend)(this.el.style,m),(0,_.append)(this.el,...e),this.ui_event_bus=new b.UIEventBus(this)}async lazy_initialize(){await super.lazy_initialize(),\"webgl\"==this.model.output_backend&&(this.webgl=await y())}remove(){this.ui_event_bus.destroy(),super.remove()}add_underlay(e){this.underlays_el.appendChild(e)}add_overlay(e){this.overlays_el.appendChild(e)}add_event(e){this.events_el.appendChild(e)}get pixel_ratio(){return this.primary.pixel_ratio}resize(e,t){this.bbox=new v.BBox({left:0,top:0,width:e,height:t}),this.primary.resize(e,t),this.overlays.resize(e,t)}prepare_webgl(e){const{webgl:t}=this;if(null!=t){const{width:i,height:s}=this.bbox;t.canvas.width=this.pixel_ratio*i,t.canvas.height=this.pixel_ratio*s;const[a,r,l,n]=e,{xview:o,yview:h}=this.bbox,c=o.compute(a),u=h.compute(r+n),_=this.pixel_ratio;t.regl_wrapper.set_scissor(_*c,_*u,_*l,_*n),this._clear_webgl()}}blit_webgl(e){const{webgl:t}=this;if(null!=t){if(u.logger.debug(\"Blitting WebGL canvas\"),e.restore(),e.drawImage(t.canvas,0,0),e.save(),this.model.hidpi){const t=this.pixel_ratio;e.scale(t,t),e.translate(.5,.5)}this._clear_webgl()}}_clear_webgl(){const{webgl:e}=this;if(null!=e){const{regl_wrapper:t,canvas:i}=e;t.clear(i.width,i.height)}}compose(){const e=this.create_layer(),{width:t,height:i}=this.bbox;return e.resize(t,i),e.ctx.drawImage(this.primary.canvas,0,0),e.ctx.drawImage(this.overlays.canvas,0,0),e}create_layer(){const{output_backend:e,hidpi:t}=this.model;return new w.CanvasLayer(e,t)}to_blob(){return this.compose().to_blob()}}i.CanvasView=f,f.__name__=\"CanvasView\";class x extends h.HasProps{constructor(e){super(e)}}i.Canvas=x,r=x,x.__name__=\"Canvas\",r.prototype.default_view=f,r.internal((({Boolean:e})=>({hidpi:[e,!0],output_backend:[d.OutputBackend,\"canvas\"]})))},\n", " function _(t,e,s,n,i){n();const r=t(1),a=(0,r.__importDefault)(t(225)),_=t(15),h=t(19),o=t(43),l=(0,r.__importStar)(t(251)),c=t(252),p=t(9),u=t(8),v=t(27),d=t(230);class g{constructor(t){this.canvas_view=t,this.pan_start=new _.Signal(this,\"pan:start\"),this.pan=new _.Signal(this,\"pan\"),this.pan_end=new _.Signal(this,\"pan:end\"),this.pinch_start=new _.Signal(this,\"pinch:start\"),this.pinch=new _.Signal(this,\"pinch\"),this.pinch_end=new _.Signal(this,\"pinch:end\"),this.rotate_start=new _.Signal(this,\"rotate:start\"),this.rotate=new _.Signal(this,\"rotate\"),this.rotate_end=new _.Signal(this,\"rotate:end\"),this.tap=new _.Signal(this,\"tap\"),this.doubletap=new _.Signal(this,\"doubletap\"),this.press=new _.Signal(this,\"press\"),this.pressup=new _.Signal(this,\"pressup\"),this.move_enter=new _.Signal(this,\"move:enter\"),this.move=new _.Signal(this,\"move\"),this.move_exit=new _.Signal(this,\"move:exit\"),this.scroll=new _.Signal(this,\"scroll\"),this.keydown=new _.Signal(this,\"keydown\"),this.keyup=new _.Signal(this,\"keyup\"),this.hammer=new a.default(this.hit_area,{touchAction:\"auto\",inputClass:a.default.TouchMouseInput}),this._prev_move=null,this._curr_pan=null,this._curr_pinch=null,this._curr_rotate=null,this._configure_hammerjs(),this.hit_area.addEventListener(\"mousemove\",(t=>this._mouse_move(t))),this.hit_area.addEventListener(\"mouseenter\",(t=>this._mouse_enter(t))),this.hit_area.addEventListener(\"mouseleave\",(t=>this._mouse_exit(t))),this.hit_area.addEventListener(\"contextmenu\",(t=>this._context_menu(t))),this.hit_area.addEventListener(\"wheel\",(t=>this._mouse_wheel(t))),document.addEventListener(\"keydown\",this),document.addEventListener(\"keyup\",this),this.menu=new d.ContextMenu([],{prevent_hide:t=>2==t.button&&t.target==this.hit_area}),this.hit_area.appendChild(this.menu.el)}get hit_area(){return this.canvas_view.events_el}destroy(){this.menu.remove(),this.hammer.destroy(),document.removeEventListener(\"keydown\",this),document.removeEventListener(\"keyup\",this)}handleEvent(t){\"keydown\"==t.type?this._key_down(t):\"keyup\"==t.type&&this._key_up(t)}_configure_hammerjs(){this.hammer.get(\"doubletap\").recognizeWith(\"tap\"),this.hammer.get(\"tap\").requireFailure(\"doubletap\"),this.hammer.get(\"doubletap\").dropRequireFailure(\"tap\"),this.hammer.on(\"doubletap\",(t=>this._doubletap(t))),this.hammer.on(\"tap\",(t=>this._tap(t))),this.hammer.on(\"press\",(t=>this._press(t))),this.hammer.on(\"pressup\",(t=>this._pressup(t))),this.hammer.get(\"pan\").set({direction:a.default.DIRECTION_ALL}),this.hammer.on(\"panstart\",(t=>this._pan_start(t))),this.hammer.on(\"pan\",(t=>this._pan(t))),this.hammer.on(\"panend\",(t=>this._pan_end(t))),this.hammer.get(\"pinch\").set({enable:!0}),this.hammer.on(\"pinchstart\",(t=>this._pinch_start(t))),this.hammer.on(\"pinch\",(t=>this._pinch(t))),this.hammer.on(\"pinchend\",(t=>this._pinch_end(t))),this.hammer.get(\"rotate\").set({enable:!0}),this.hammer.on(\"rotatestart\",(t=>this._rotate_start(t))),this.hammer.on(\"rotate\",(t=>this._rotate(t))),this.hammer.on(\"rotateend\",(t=>this._rotate_end(t)))}register_tool(t){const e=t.model.event_type;null!=e&&((0,u.isString)(e)?this._register_tool(t,e):e.forEach(((e,s)=>this._register_tool(t,e,s<1))))}_register_tool(t,e,s=!0){const n=t,{id:i}=n.model,r=t=>e=>{e.id==i&&t(e.e)},a=t=>e=>{t(e.e)};switch(e){case\"pan\":null!=n._pan_start&&n.connect(this.pan_start,r(n._pan_start.bind(n))),null!=n._pan&&n.connect(this.pan,r(n._pan.bind(n))),null!=n._pan_end&&n.connect(this.pan_end,r(n._pan_end.bind(n)));break;case\"pinch\":null!=n._pinch_start&&n.connect(this.pinch_start,r(n._pinch_start.bind(n))),null!=n._pinch&&n.connect(this.pinch,r(n._pinch.bind(n))),null!=n._pinch_end&&n.connect(this.pinch_end,r(n._pinch_end.bind(n)));break;case\"rotate\":null!=n._rotate_start&&n.connect(this.rotate_start,r(n._rotate_start.bind(n))),null!=n._rotate&&n.connect(this.rotate,r(n._rotate.bind(n))),null!=n._rotate_end&&n.connect(this.rotate_end,r(n._rotate_end.bind(n)));break;case\"move\":null!=n._move_enter&&n.connect(this.move_enter,r(n._move_enter.bind(n))),null!=n._move&&n.connect(this.move,r(n._move.bind(n))),null!=n._move_exit&&n.connect(this.move_exit,r(n._move_exit.bind(n)));break;case\"tap\":null!=n._tap&&n.connect(this.tap,r(n._tap.bind(n))),null!=n._doubletap&&n.connect(this.doubletap,r(n._doubletap.bind(n)));break;case\"press\":null!=n._press&&n.connect(this.press,r(n._press.bind(n))),null!=n._pressup&&n.connect(this.pressup,r(n._pressup.bind(n)));break;case\"scroll\":null!=n._scroll&&n.connect(this.scroll,r(n._scroll.bind(n)));break;default:throw new Error(`unsupported event_type: ${e}`)}s&&(null!=n._keydown&&n.connect(this.keydown,a(n._keydown.bind(n))),null!=n._keyup&&n.connect(this.keyup,a(n._keyup.bind(n))),v.is_mobile&&null!=n._scroll&&\"pinch\"==e&&(h.logger.debug(\"Registering scroll on touch screen\"),n.connect(this.scroll,r(n._scroll.bind(n)))))}_hit_test_renderers(t,e,s){var n;const i=t.get_renderer_views();for(const t of(0,p.reversed)(i))if(null===(n=t.interactive_hit)||void 0===n?void 0:n.call(t,e,s))return t;return null}set_cursor(t=\"default\"){this.hit_area.style.cursor=t}_hit_test_frame(t,e,s){return t.frame.bbox.contains(e,s)}_hit_test_canvas(t,e,s){return t.layout.bbox.contains(e,s)}_hit_test_plot(t,e){for(const s of this.canvas_view.plot_views)if(s.layout.bbox.relative().contains(t,e))return s;return null}_trigger(t,e,s){var n;const{sx:i,sy:r}=e,a=this._hit_test_plot(i,r),_=t=>{const[s,n]=[i,r];return Object.assign(Object.assign({},e),{sx:s,sy:n})};if(\"panstart\"==e.type||\"pan\"==e.type||\"panend\"==e.type){let n;if(\"panstart\"==e.type&&null!=a?(this._curr_pan={plot_view:a},n=a):\"pan\"==e.type&&null!=this._curr_pan?n=this._curr_pan.plot_view:\"panend\"==e.type&&null!=this._curr_pan?(n=this._curr_pan.plot_view,this._curr_pan=null):n=null,null!=n){const e=_();this.__trigger(n,t,e,s)}}else if(\"pinchstart\"==e.type||\"pinch\"==e.type||\"pinchend\"==e.type){let n;if(\"pinchstart\"==e.type&&null!=a?(this._curr_pinch={plot_view:a},n=a):\"pinch\"==e.type&&null!=this._curr_pinch?n=this._curr_pinch.plot_view:\"pinchend\"==e.type&&null!=this._curr_pinch?(n=this._curr_pinch.plot_view,this._curr_pinch=null):n=null,null!=n){const e=_();this.__trigger(n,t,e,s)}}else if(\"rotatestart\"==e.type||\"rotate\"==e.type||\"rotateend\"==e.type){let n;if(\"rotatestart\"==e.type&&null!=a?(this._curr_rotate={plot_view:a},n=a):\"rotate\"==e.type&&null!=this._curr_rotate?n=this._curr_rotate.plot_view:\"rotateend\"==e.type&&null!=this._curr_rotate?(n=this._curr_rotate.plot_view,this._curr_rotate=null):n=null,null!=n){const e=_();this.__trigger(n,t,e,s)}}else if(\"mouseenter\"==e.type||\"mousemove\"==e.type||\"mouseleave\"==e.type){const h=null===(n=this._prev_move)||void 0===n?void 0:n.plot_view;if(null!=h&&(\"mouseleave\"==e.type||h!=a)){const{sx:t,sy:e}=_();this.__trigger(h,this.move_exit,{type:\"mouseleave\",sx:t,sy:e,shiftKey:!1,ctrlKey:!1},s)}if(null!=a&&(\"mouseenter\"==e.type||h!=a)){const{sx:t,sy:e}=_();this.__trigger(a,this.move_enter,{type:\"mouseenter\",sx:t,sy:e,shiftKey:!1,ctrlKey:!1},s)}if(null!=a&&\"mousemove\"==e.type){const e=_();this.__trigger(a,t,e,s)}this._prev_move={sx:i,sy:r,plot_view:a}}else if(null!=a){const e=_();this.__trigger(a,t,e,s)}}__trigger(t,e,s,n){var i,r;const a=t.model.toolbar.gestures,_=e.name.split(\":\")[0],h=this._hit_test_renderers(t,s.sx,s.sy),o=this._hit_test_canvas(t,s.sx,s.sy);switch(_){case\"move\":{const n=a[_].active;null!=n&&this.trigger(e,s,n.id);const r=t.model.toolbar.inspectors.filter((t=>t.active));let l=\"default\";null!=h?(l=null!==(i=h.cursor(s.sx,s.sy))&&void 0!==i?i:l,(0,p.is_empty)(r)||(e=this.move_exit)):this._hit_test_frame(t,s.sx,s.sy)&&((0,p.is_empty)(r)||(l=\"crosshair\")),this.set_cursor(l),t.set_toolbar_visibility(o),r.map((t=>this.trigger(e,s,t.id)));break}case\"tap\":{const{target:t}=n;if(null!=t&&t!=this.hit_area)return;null!=h&&null!=h.on_hit&&h.on_hit(s.sx,s.sy);const i=a[_].active;null!=i&&this.trigger(e,s,i.id);break}case\"doubletap\":{const t=null!==(r=a.doubletap.active)&&void 0!==r?r:a.tap.active;null!=t&&this.trigger(e,s,t.id);break}case\"scroll\":{const t=a[v.is_mobile?\"pinch\":\"scroll\"].active;null!=t&&(n.preventDefault(),n.stopPropagation(),this.trigger(e,s,t.id));break}case\"pan\":{const t=a[_].active;null!=t&&(n.preventDefault(),this.trigger(e,s,t.id));break}default:{const t=a[_].active;null!=t&&this.trigger(e,s,t.id)}}this._trigger_bokeh_event(t,s)}trigger(t,e,s=null){t.emit({id:s,e})}_trigger_bokeh_event(t,e){const s=(()=>{const{sx:s,sy:n}=e,i=t.frame.x_scale.invert(s),r=t.frame.y_scale.invert(n);switch(e.type){case\"wheel\":return new l.MouseWheel(s,n,i,r,e.delta);case\"mousemove\":return new l.MouseMove(s,n,i,r);case\"mouseenter\":return new l.MouseEnter(s,n,i,r);case\"mouseleave\":return new l.MouseLeave(s,n,i,r);case\"tap\":return new l.Tap(s,n,i,r);case\"doubletap\":return new l.DoubleTap(s,n,i,r);case\"press\":return new l.Press(s,n,i,r);case\"pressup\":return new l.PressUp(s,n,i,r);case\"pan\":return new l.Pan(s,n,i,r,e.deltaX,e.deltaY);case\"panstart\":return new l.PanStart(s,n,i,r);case\"panend\":return new l.PanEnd(s,n,i,r);case\"pinch\":return new l.Pinch(s,n,i,r,e.scale);case\"pinchstart\":return new l.PinchStart(s,n,i,r);case\"pinchend\":return new l.PinchEnd(s,n,i,r);case\"rotate\":return new l.Rotate(s,n,i,r,e.rotation);case\"rotatestart\":return new l.RotateStart(s,n,i,r);case\"rotateend\":return new l.RotateEnd(s,n,i,r);default:return}})();null!=s&&t.model.trigger_event(s)}_get_sxy(t){const{pageX:e,pageY:s}=function(t){return\"undefined\"!=typeof TouchEvent&&t instanceof TouchEvent}(t)?(0!=t.touches.length?t.touches:t.changedTouches)[0]:t,{left:n,top:i}=(0,o.offset)(this.hit_area);return{sx:e-n,sy:s-i}}_pan_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{deltaX:t.deltaX,deltaY:t.deltaY,shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_pinch_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{scale:t.scale,shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_rotate_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{rotation:t.rotation,shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_tap_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_move_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t)),{shiftKey:t.shiftKey,ctrlKey:t.ctrlKey})}_scroll_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t)),{delta:(0,c.getDeltaY)(t),shiftKey:t.shiftKey,ctrlKey:t.ctrlKey})}_key_event(t){return{type:t.type,keyCode:t.keyCode}}_pan_start(t){const e=this._pan_event(t);e.sx-=t.deltaX,e.sy-=t.deltaY,this._trigger(this.pan_start,e,t.srcEvent)}_pan(t){this._trigger(this.pan,this._pan_event(t),t.srcEvent)}_pan_end(t){this._trigger(this.pan_end,this._pan_event(t),t.srcEvent)}_pinch_start(t){this._trigger(this.pinch_start,this._pinch_event(t),t.srcEvent)}_pinch(t){this._trigger(this.pinch,this._pinch_event(t),t.srcEvent)}_pinch_end(t){this._trigger(this.pinch_end,this._pinch_event(t),t.srcEvent)}_rotate_start(t){this._trigger(this.rotate_start,this._rotate_event(t),t.srcEvent)}_rotate(t){this._trigger(this.rotate,this._rotate_event(t),t.srcEvent)}_rotate_end(t){this._trigger(this.rotate_end,this._rotate_event(t),t.srcEvent)}_tap(t){this._trigger(this.tap,this._tap_event(t),t.srcEvent)}_doubletap(t){this._trigger(this.doubletap,this._tap_event(t),t.srcEvent)}_press(t){this._trigger(this.press,this._tap_event(t),t.srcEvent)}_pressup(t){this._trigger(this.pressup,this._tap_event(t),t.srcEvent)}_mouse_enter(t){this._trigger(this.move_enter,this._move_event(t),t)}_mouse_move(t){this._trigger(this.move,this._move_event(t),t)}_mouse_exit(t){this._trigger(this.move_exit,this._move_event(t),t)}_mouse_wheel(t){this._trigger(this.scroll,this._scroll_event(t),t)}_context_menu(t){!this.menu.is_open&&this.menu.can_open&&t.preventDefault();const{sx:e,sy:s}=this._get_sxy(t);this.menu.toggle({left:e,top:s})}_key_down(t){this.trigger(this.keydown,this._key_event(t))}_key_up(t){this.trigger(this.keyup,this._key_event(t))}}s.UIEventBus=g,g.__name__=\"UIEventBus\"},\n", " function _(e,t,s,n,_){n();var a=this&&this.__decorate||function(e,t,s,n){var _,a=arguments.length,o=a<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,s):n;if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.decorate)o=Reflect.decorate(e,t,s,n);else for(var r=e.length-1;r>=0;r--)(_=e[r])&&(o=(a<3?_(o):a>3?_(t,s,o):_(t,s))||o);return a>3&&o&&Object.defineProperty(t,s,o),o};function o(e){return function(t){t.prototype.event_name=e}}class r{to_json(){const{event_name:e}=this;return{event_name:e,event_values:this._to_json()}}}s.BokehEvent=r,r.__name__=\"BokehEvent\";class c extends r{constructor(){super(...arguments),this.origin=null}_to_json(){return{model:this.origin}}}s.ModelEvent=c,c.__name__=\"ModelEvent\";let l=class extends r{_to_json(){return{}}};s.DocumentReady=l,l.__name__=\"DocumentReady\",s.DocumentReady=l=a([o(\"document_ready\")],l);let i=class extends c{};s.ButtonClick=i,i.__name__=\"ButtonClick\",s.ButtonClick=i=a([o(\"button_click\")],i);let u=class extends c{constructor(e){super(),this.item=e}_to_json(){const{item:e}=this;return Object.assign(Object.assign({},super._to_json()),{item:e})}};s.MenuItemClick=u,u.__name__=\"MenuItemClick\",s.MenuItemClick=u=a([o(\"menu_item_click\")],u);class d extends c{}s.UIEvent=d,d.__name__=\"UIEvent\";let m=class extends d{};s.LODStart=m,m.__name__=\"LODStart\",s.LODStart=m=a([o(\"lodstart\")],m);let h=class extends d{};s.LODEnd=h,h.__name__=\"LODEnd\",s.LODEnd=h=a([o(\"lodend\")],h);let p=class extends d{constructor(e,t,s,n){super(),this.x0=e,this.x1=t,this.y0=s,this.y1=n}_to_json(){const{x0:e,x1:t,y0:s,y1:n}=this;return Object.assign(Object.assign({},super._to_json()),{x0:e,x1:t,y0:s,y1:n})}};s.RangesUpdate=p,p.__name__=\"RangesUpdate\",s.RangesUpdate=p=a([o(\"rangesupdate\")],p);let x=class extends d{constructor(e,t){super(),this.geometry=e,this.final=t}_to_json(){const{geometry:e,final:t}=this;return Object.assign(Object.assign({},super._to_json()),{geometry:e,final:t})}};s.SelectionGeometry=x,x.__name__=\"SelectionGeometry\",s.SelectionGeometry=x=a([o(\"selectiongeometry\")],x);let j=class extends d{};s.Reset=j,j.__name__=\"Reset\",s.Reset=j=a([o(\"reset\")],j);class y extends d{constructor(e,t,s,n){super(),this.sx=e,this.sy=t,this.x=s,this.y=n}_to_json(){const{sx:e,sy:t,x:s,y:n}=this;return Object.assign(Object.assign({},super._to_json()),{sx:e,sy:t,x:s,y:n})}}s.PointEvent=y,y.__name__=\"PointEvent\";let g=class extends y{constructor(e,t,s,n,_,a){super(e,t,s,n),this.delta_x=_,this.delta_y=a}_to_json(){const{delta_x:e,delta_y:t}=this;return Object.assign(Object.assign({},super._to_json()),{delta_x:e,delta_y:t})}};s.Pan=g,g.__name__=\"Pan\",s.Pan=g=a([o(\"pan\")],g);let P=class extends y{constructor(e,t,s,n,_){super(e,t,s,n),this.scale=_}_to_json(){const{scale:e}=this;return Object.assign(Object.assign({},super._to_json()),{scale:e})}};s.Pinch=P,P.__name__=\"Pinch\",s.Pinch=P=a([o(\"pinch\")],P);let O=class extends y{constructor(e,t,s,n,_){super(e,t,s,n),this.rotation=_}_to_json(){const{rotation:e}=this;return Object.assign(Object.assign({},super._to_json()),{rotation:e})}};s.Rotate=O,O.__name__=\"Rotate\",s.Rotate=O=a([o(\"rotate\")],O);let b=class extends y{constructor(e,t,s,n,_){super(e,t,s,n),this.delta=_}_to_json(){const{delta:e}=this;return Object.assign(Object.assign({},super._to_json()),{delta:e})}};s.MouseWheel=b,b.__name__=\"MouseWheel\",s.MouseWheel=b=a([o(\"wheel\")],b);let v=class extends y{};s.MouseMove=v,v.__name__=\"MouseMove\",s.MouseMove=v=a([o(\"mousemove\")],v);let E=class extends y{};s.MouseEnter=E,E.__name__=\"MouseEnter\",s.MouseEnter=E=a([o(\"mouseenter\")],E);let R=class extends y{};s.MouseLeave=R,R.__name__=\"MouseLeave\",s.MouseLeave=R=a([o(\"mouseleave\")],R);let M=class extends y{};s.Tap=M,M.__name__=\"Tap\",s.Tap=M=a([o(\"tap\")],M);let f=class extends y{};s.DoubleTap=f,f.__name__=\"DoubleTap\",s.DoubleTap=f=a([o(\"doubletap\")],f);let S=class extends y{};s.Press=S,S.__name__=\"Press\",s.Press=S=a([o(\"press\")],S);let D=class extends y{};s.PressUp=D,D.__name__=\"PressUp\",s.PressUp=D=a([o(\"pressup\")],D);let k=class extends y{};s.PanStart=k,k.__name__=\"PanStart\",s.PanStart=k=a([o(\"panstart\")],k);let L=class extends y{};s.PanEnd=L,L.__name__=\"PanEnd\",s.PanEnd=L=a([o(\"panend\")],L);let U=class extends y{};s.PinchStart=U,U.__name__=\"PinchStart\",s.PinchStart=U=a([o(\"pinchstart\")],U);let C=class extends y{};s.PinchEnd=C,C.__name__=\"PinchEnd\",s.PinchEnd=C=a([o(\"pinchend\")],C);let T=class extends y{};s.RotateStart=T,T.__name__=\"RotateStart\",s.RotateStart=T=a([o(\"rotatestart\")],T);let B=class extends y{};s.RotateEnd=B,B.__name__=\"RotateEnd\",s.RotateEnd=B=a([o(\"rotateend\")],B)},\n", " function _(t,e,n,l,o){\n", " /*!\n", " * jQuery Mousewheel 3.1.13\n", " *\n", " * Copyright jQuery Foundation and other contributors\n", " * Released under the MIT license\n", " * http://jquery.org/license\n", " */\n", " function u(t){const e=getComputedStyle(t).fontSize;return null!=e?parseInt(e,10):null}l(),n.getDeltaY=function(t){let e=-t.deltaY;if(t.target instanceof HTMLElement)switch(t.deltaMode){case t.DOM_DELTA_LINE:e*=(n=t.target,null!==(a=null!==(o=u(null!==(l=n.offsetParent)&&void 0!==l?l:document.body))&&void 0!==o?o:u(n))&&void 0!==a?a:16);break;case t.DOM_DELTA_PAGE:e*=function(t){return t.clientHeight}(t.target)}var n,l,o,a;return e}},\n", " function _(m,o,n,r,a){r(),a(\"Expression\",m(254).Expression),a(\"CustomJSExpr\",m(255).CustomJSExpr),a(\"Stack\",m(256).Stack),a(\"CumSum\",m(257).CumSum),a(\"ScalarExpression\",m(254).ScalarExpression),a(\"Minimum\",m(258).Minimum),a(\"Maximum\",m(259).Maximum);var s=m(260);a(\"XComponent\",s.XComponent),a(\"YComponent\",s.YComponent),a(\"PolarTransform\",m(261).PolarTransform)},\n", " function _(e,t,s,i,r){i();const n=e(53);class _ extends n.Model{constructor(e){super(e)}initialize(){super.initialize(),this._result=new Map}v_compute(e){let t=this._result.get(e);return(void 0===t||e.changed_for(this))&&(t=this._v_compute(e),this._result.set(e,t)),t}}s.Expression=_,_.__name__=\"Expression\";class o extends n.Model{constructor(e){super(e)}initialize(){super.initialize(),this._result=new Map}compute(e){let t=this._result.get(e);return(void 0===t||e.changed_for(this))&&(t=this._compute(e),this._result.set(e,t)),t}}s.ScalarExpression=o,o.__name__=\"ScalarExpression\"},\n", " function _(e,s,t,n,r){var a;n();const o=e(14),c=e(254),i=e(24),u=e(9),l=e(13),h=e(34),g=e(8);class p extends c.Expression{constructor(e){super(e)}connect_signals(){super.connect_signals();for(const e of(0,l.values)(this.args))e instanceof o.HasProps&&e.change.connect((()=>{this._result.clear(),this.change.emit()}))}get names(){return(0,l.keys)(this.args)}get values(){return(0,l.values)(this.args)}get func(){const e=(0,h.use_strict)(this.code);return new i.GeneratorFunction(...this.names,e)}_v_compute(e){const s=this.func.apply(e,this.values);let t=s.next();if(t.done&&void 0!==t.value){const{value:s}=t;return(0,g.isArray)(s)||(0,g.isTypedArray)(s)?s:(0,g.isIterable)(s)?[...s]:(0,u.repeat)(s,e.length)}{const e=[];do{e.push(t.value),t=s.next()}while(!t.done);return e}}}t.CustomJSExpr=p,a=p,p.__name__=\"CustomJSExpr\",a.define((({Unknown:e,String:s,Dict:t})=>({args:[t(e),{}],code:[s,\"\"]})))},\n", " function _(t,n,e,o,r){var s;o();const a=t(254);class c extends a.Expression{constructor(t){super(t)}_v_compute(t){var n;const e=null!==(n=t.get_length())&&void 0!==n?n:0,o=new Float64Array(e);for(const n of this.fields){const r=t.data[n];if(null!=r){const t=Math.min(e,r.length);for(let n=0;n({fields:[n(t),[]]})))},\n", " function _(e,n,t,o,r){var i;o();const l=e(254);class u extends l.Expression{constructor(e){super(e)}_v_compute(e){var n;const t=new Float64Array(null!==(n=e.get_length())&&void 0!==n?n:0),o=e.data[this.field],r=this.include_zero?1:0;t[0]=this.include_zero?0:o[0];for(let e=1;e({field:[n],include_zero:[e,!1]})))},\n", " function _(i,n,l,t,e){var a;t();const u=i(254),r=i(9);class s extends u.ScalarExpression{constructor(i){super(i)}_compute(i){var n,l;const t=null!==(n=i.data[this.field])&&void 0!==n?n:[];return Math.min(null!==(l=this.initial)&&void 0!==l?l:1/0,(0,r.min)(t))}}l.Minimum=s,a=s,s.__name__=\"Minimum\",a.define((({Number:i,String:n,Nullable:l})=>({field:[n],initial:[l(i),null]})))},\n", " function _(i,a,n,l,t){var e;l();const u=i(254),r=i(9);class s extends u.ScalarExpression{constructor(i){super(i)}_compute(i){var a,n;const l=null!==(a=i.data[this.field])&&void 0!==a?a:[];return Math.max(null!==(n=this.initial)&&void 0!==n?n:-1/0,(0,r.max)(l))}}n.Maximum=s,e=s,s.__name__=\"Maximum\",e.define((({Number:i,String:a,Nullable:n})=>({field:[a],initial:[n(i),null]})))},\n", " function _(n,e,t,o,r){var s;o();const _=n(254);class m extends _.Expression{constructor(n){super(n)}get x(){return new c({transform:this})}get y(){return new u({transform:this})}}t.CoordinateTransform=m,m.__name__=\"CoordinateTransform\";class a extends _.Expression{constructor(n){super(n)}}t.XYComponent=a,s=a,a.__name__=\"XYComponent\",s.define((({Ref:n})=>({transform:[n(m)]})));class c extends a{constructor(n){super(n)}_v_compute(n){return this.transform.v_compute(n).x}}t.XComponent=c,c.__name__=\"XComponent\";class u extends a{constructor(n){super(n)}_v_compute(n){return this.transform.v_compute(n).y}}t.YComponent=u,u.__name__=\"YComponent\"},\n", " function _(r,t,n,e,o){e();const i=r(1);var a;const s=r(260),c=r(20),l=(0,i.__importStar)(r(18));class d extends s.CoordinateTransform{constructor(r){super(r)}_v_compute(r){const t=this.properties.radius.uniform(r),n=this.properties.angle.uniform(r),e=\"anticlock\"==this.direction?-1:1,o=Math.min(t.length,n.length),i=new Float64Array(o),a=new Float64Array(o);for(let r=0;r({radius:[l.DistanceSpec,{field:\"radius\"}],angle:[l.AngleSpec,{field:\"angle\"}],direction:[c.Direction,\"anticlock\"]})))},\n", " function _(e,t,l,r,i){r(),i(\"BooleanFilter\",e(263).BooleanFilter),i(\"CustomJSFilter\",e(264).CustomJSFilter),i(\"Filter\",e(191).Filter),i(\"GroupFilter\",e(265).GroupFilter),i(\"IndexFilter\",e(266).IndexFilter)},\n", " function _(e,n,l,o,s){var t;o();const a=e(191),r=e(24);class c extends a.Filter{constructor(e){super(e)}compute_indices(e){const n=e.length,{booleans:l}=this;return null==l?r.Indices.all_set(n):r.Indices.from_booleans(n,l)}}l.BooleanFilter=c,t=c,c.__name__=\"BooleanFilter\",t.define((({Boolean:e,Array:n,Nullable:l})=>({booleans:[l(n(e)),null]})))},\n", " function _(e,n,r,s,t){var i;s();const o=e(191),c=e(24),u=e(13),a=e(8),l=e(34);class f extends o.Filter{constructor(e){super(e)}get names(){return(0,u.keys)(this.args)}get values(){return(0,u.values)(this.args)}get func(){const e=(0,l.use_strict)(this.code);return new Function(...this.names,\"source\",e)}compute_indices(e){const n=e.length,r=this.func(...this.values,e);if(null==r)return c.Indices.all_set(n);if((0,a.isArrayOf)(r,a.isInteger))return c.Indices.from_indices(n,r);if((0,a.isArrayOf)(r,a.isBoolean))return c.Indices.from_booleans(n,r);throw new Error(`expect an array of integers or booleans, or null, got ${r}`)}}r.CustomJSFilter=f,i=f,f.__name__=\"CustomJSFilter\",i.define((({Unknown:e,String:n,Dict:r})=>({args:[r(e),{}],code:[n,\"\"]})))},\n", " function _(n,e,t,o,r){var u;o();const s=n(191),c=n(24),i=n(19);class l extends s.Filter{constructor(n){super(n)}compute_indices(n){const e=n.get_column(this.column_name);if(null==e)return i.logger.warn(`${this}: groupby column '${this.column_name}' not found in the data source`),new c.Indices(n.length,1);{const t=new c.Indices(n.length);for(let n=0;n({column_name:[n],group:[n]})))},\n", " function _(e,n,i,s,t){var l;s();const c=e(191),r=e(24);class d extends c.Filter{constructor(e){super(e)}compute_indices(e){const n=e.length,{indices:i}=this;return null==i?r.Indices.all_set(n):r.Indices.from_indices(n,i)}}i.IndexFilter=d,l=d,d.__name__=\"IndexFilter\",l.define((({Int:e,Array:n,Nullable:i})=>({indices:[i(n(e)),null]})))},\n", " function _(e,a,l,i,t){i(),t(\"AnnularWedge\",e(268).AnnularWedge),t(\"Annulus\",e(269).Annulus),t(\"Arc\",e(270).Arc),t(\"Bezier\",e(271).Bezier),t(\"Circle\",e(272).Circle),t(\"Ellipse\",e(273).Ellipse),t(\"EllipseOval\",e(274).EllipseOval),t(\"Glyph\",e(179).Glyph),t(\"HArea\",e(187).HArea),t(\"HBar\",e(276).HBar),t(\"HexTile\",e(278).HexTile),t(\"Image\",e(279).Image),t(\"ImageRGBA\",e(281).ImageRGBA),t(\"ImageURL\",e(282).ImageURL),t(\"Line\",e(177).Line),t(\"MultiLine\",e(283).MultiLine),t(\"MultiPolygons\",e(284).MultiPolygons),t(\"Oval\",e(285).Oval),t(\"Patch\",e(186).Patch),t(\"Patches\",e(286).Patches),t(\"Quad\",e(287).Quad),t(\"Quadratic\",e(288).Quadratic),t(\"Ray\",e(289).Ray),t(\"Rect\",e(290).Rect),t(\"Scatter\",e(291).Scatter),t(\"Segment\",e(294).Segment),t(\"Spline\",e(295).Spline),t(\"Step\",e(297).Step),t(\"Text\",e(298).Text),t(\"VArea\",e(189).VArea),t(\"VBar\",e(299).VBar),t(\"Wedge\",e(300).Wedge)},\n", " function _(e,t,s,i,r){i();const n=e(1);var a;const o=e(178),_=e(184),d=e(48),u=e(24),h=e(20),c=(0,n.__importStar)(e(18)),l=e(10),p=e(72);class x extends o.XYGlyphView{_map_data(){\"data\"==this.model.properties.inner_radius.units?this.sinner_radius=this.sdist(this.renderer.xscale,this._x,this.inner_radius):this.sinner_radius=(0,u.to_screen)(this.inner_radius),\"data\"==this.model.properties.outer_radius.units?this.souter_radius=this.sdist(this.renderer.xscale,this._x,this.outer_radius):this.souter_radius=(0,u.to_screen)(this.outer_radius)}_render(e,t,s){const{sx:i,sy:r,start_angle:n,end_angle:a,sinner_radius:o,souter_radius:_}=null!=s?s:this,d=\"anticlock\"==this.model.direction;for(const s of t){const t=i[s],u=r[s],h=o[s],c=_[s],l=n.get(s),p=a.get(s);if(!isFinite(t+u+h+c+l+p))continue;const x=p-l;e.translate(t,u),e.rotate(l),e.beginPath(),e.moveTo(c,0),e.arc(0,0,c,0,x,d),e.rotate(x),e.lineTo(h,0),e.arc(0,0,h,0,-x,!d),e.closePath(),e.rotate(-x-l),e.translate(-t,-u),this.visuals.fill.apply(e,s),this.visuals.hatch.apply(e,s),this.visuals.line.apply(e,s)}}_hit_point(e){const{sx:t,sy:s}=e,i=this.renderer.xscale.invert(t),r=this.renderer.yscale.invert(s);let n,a,o,_;if(\"data\"==this.model.properties.outer_radius.units)n=i-this.max_outer_radius,o=i+this.max_outer_radius,a=r-this.max_outer_radius,_=r+this.max_outer_radius;else{const e=t-this.max_outer_radius,i=t+this.max_outer_radius;[n,o]=this.renderer.xscale.r_invert(e,i);const r=s-this.max_outer_radius,d=s+this.max_outer_radius;[a,_]=this.renderer.yscale.r_invert(r,d)}const d=[];for(const e of this.index.indices({x0:n,x1:o,y0:a,y1:_})){const t=this.souter_radius[e]**2,s=this.sinner_radius[e]**2,[n,a]=this.renderer.xscale.r_compute(i,this._x[e]),[o,_]=this.renderer.yscale.r_compute(r,this._y[e]),u=(n-a)**2+(o-_)**2;u<=t&&u>=s&&d.push(e)}const u=\"anticlock\"==this.model.direction,h=[];for(const e of d){const i=Math.atan2(s-this.sy[e],t-this.sx[e]);(0,l.angle_between)(-i,-this.start_angle.get(e),-this.end_angle.get(e),u)&&h.push(e)}return new p.Selection({indices:h})}draw_legend_for_index(e,t,s){(0,_.generic_area_vector_legend)(this.visuals,e,t,s)}scenterxy(e){const t=(this.sinner_radius[e]+this.souter_radius[e])/2,s=(this.start_angle.get(e)+this.end_angle.get(e))/2;return[this.sx[e]+t*Math.cos(s),this.sy[e]+t*Math.sin(s)]}}s.AnnularWedgeView=x,x.__name__=\"AnnularWedgeView\";class g extends o.XYGlyph{constructor(e){super(e)}}s.AnnularWedge=g,a=g,g.__name__=\"AnnularWedge\",a.prototype.default_view=x,a.mixins([d.LineVector,d.FillVector,d.HatchVector]),a.define((({})=>({direction:[h.Direction,\"anticlock\"],inner_radius:[c.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[c.DistanceSpec,{field:\"outer_radius\"}],start_angle:[c.AngleSpec,{field:\"start_angle\"}],end_angle:[c.AngleSpec,{field:\"end_angle\"}]})))},\n", " function _(s,e,i,r,t){r();const n=s(1);var a;const u=s(178),o=s(24),_=s(48),d=(0,n.__importStar)(s(18)),h=s(27),c=s(72);class l extends u.XYGlyphView{_map_data(){\"data\"==this.model.properties.inner_radius.units?this.sinner_radius=this.sdist(this.renderer.xscale,this._x,this.inner_radius):this.sinner_radius=(0,o.to_screen)(this.inner_radius),\"data\"==this.model.properties.outer_radius.units?this.souter_radius=this.sdist(this.renderer.xscale,this._x,this.outer_radius):this.souter_radius=(0,o.to_screen)(this.outer_radius)}_render(s,e,i){const{sx:r,sy:t,sinner_radius:n,souter_radius:a}=null!=i?i:this;for(const i of e){const e=r[i],u=t[i],o=n[i],_=a[i];if(isFinite(e+u+o+_)){if(s.beginPath(),h.is_ie)for(const i of[!1,!0])s.moveTo(e,u),s.arc(e,u,o,0,Math.PI,i),s.moveTo(e+_,u),s.arc(e,u,_,Math.PI,0,!i);else s.arc(e,u,o,0,2*Math.PI,!0),s.moveTo(e+_,u),s.arc(e,u,_,2*Math.PI,0,!1);this.visuals.fill.apply(s,i),this.visuals.hatch.apply(s,i),this.visuals.line.apply(s,i)}}}_hit_point(s){const{sx:e,sy:i}=s,r=this.renderer.xscale.invert(e),t=this.renderer.yscale.invert(i);let n,a,u,o;if(\"data\"==this.model.properties.outer_radius.units)n=r-this.max_outer_radius,u=r+this.max_outer_radius,a=t-this.max_outer_radius,o=t+this.max_outer_radius;else{const s=e-this.max_outer_radius,r=e+this.max_outer_radius;[n,u]=this.renderer.xscale.r_invert(s,r);const t=i-this.max_outer_radius,_=i+this.max_outer_radius;[a,o]=this.renderer.yscale.r_invert(t,_)}const _=[];for(const s of this.index.indices({x0:n,x1:u,y0:a,y1:o})){const e=this.souter_radius[s]**2,i=this.sinner_radius[s]**2,[n,a]=this.renderer.xscale.r_compute(r,this._x[s]),[u,o]=this.renderer.yscale.r_compute(t,this._y[s]),d=(n-a)**2+(u-o)**2;d<=e&&d>=i&&_.push(s)}return new c.Selection({indices:_})}draw_legend_for_index(s,{x0:e,y0:i,x1:r,y1:t},n){const a=n+1,u=new Array(a);u[n]=(e+r)/2;const o=new Array(a);o[n]=(i+t)/2;const _=.5*Math.min(Math.abs(r-e),Math.abs(t-i)),d=new Array(a);d[n]=.4*_;const h=new Array(a);h[n]=.8*_,this._render(s,[n],{sx:u,sy:o,sinner_radius:d,souter_radius:h})}}i.AnnulusView=l,l.__name__=\"AnnulusView\";class x extends u.XYGlyph{constructor(s){super(s)}}i.Annulus=x,a=x,x.__name__=\"Annulus\",a.prototype.default_view=l,a.mixins([_.LineVector,_.FillVector,_.HatchVector]),a.define((({})=>({inner_radius:[d.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[d.DistanceSpec,{field:\"outer_radius\"}]})))},\n", " function _(e,i,s,t,n){t();const r=e(1);var a;const c=e(178),d=e(184),l=e(48),_=e(24),o=e(20),u=(0,r.__importStar)(e(18));class h extends c.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius):this.sradius=(0,_.to_screen)(this.radius)}_render(e,i,s){if(this.visuals.line.doit){const{sx:t,sy:n,sradius:r,start_angle:a,end_angle:c}=null!=s?s:this,d=\"anticlock\"==this.model.direction;for(const s of i){const i=t[s],l=n[s],_=r[s],o=a.get(s),u=c.get(s);isFinite(i+l+_+o+u)&&(e.beginPath(),e.arc(i,l,_,o,u,d),this.visuals.line.set_vectorize(e,s),e.stroke())}}}draw_legend_for_index(e,i,s){(0,d.generic_line_vector_legend)(this.visuals,e,i,s)}}s.ArcView=h,h.__name__=\"ArcView\";class g extends c.XYGlyph{constructor(e){super(e)}}s.Arc=g,a=g,g.__name__=\"Arc\",a.prototype.default_view=h,a.mixins(l.LineVector),a.define((({})=>({direction:[o.Direction,\"anticlock\"],radius:[u.DistanceSpec,{field:\"radius\"}],start_angle:[u.AngleSpec,{field:\"start_angle\"}],end_angle:[u.AngleSpec,{field:\"end_angle\"}]})))},\n", " function _(e,t,i,n,s){n();const o=e(1);var c;const r=e(48),a=e(179),_=e(184),d=e(78),l=(0,o.__importStar)(e(18));function x(e,t,i,n,s,o,c,r){const a=[],_=[[],[]];for(let _=0;_<=2;_++){let d,l,x;if(0===_?(l=6*e-12*i+6*s,d=-3*e+9*i-9*s+3*c,x=3*i-3*e):(l=6*t-12*n+6*o,d=-3*t+9*n-9*o+3*r,x=3*n-3*t),Math.abs(d)<1e-12){if(Math.abs(l)<1e-12)continue;const e=-x/l;0({x0:[l.XCoordinateSpec,{field:\"x0\"}],y0:[l.YCoordinateSpec,{field:\"y0\"}],x1:[l.XCoordinateSpec,{field:\"x1\"}],y1:[l.YCoordinateSpec,{field:\"y1\"}],cx0:[l.XCoordinateSpec,{field:\"cx0\"}],cy0:[l.YCoordinateSpec,{field:\"cy0\"}],cx1:[l.XCoordinateSpec,{field:\"cx1\"}],cy1:[l.YCoordinateSpec,{field:\"cy1\"}]}))),c.mixins(r.LineVector)},\n", " function _(s,i,e,t,r){t();const a=s(1);var n;const h=s(178),d=s(48),l=s(24),c=s(20),_=(0,a.__importStar)(s(185)),u=(0,a.__importStar)(s(18)),o=s(9),x=s(12),m=s(72);class p extends h.XYGlyphView{async lazy_initialize(){await super.lazy_initialize();const{webgl:i}=this.renderer.plot_view.canvas_view;if(null==i?void 0:i.regl_wrapper.has_webgl){const{MarkerGL:e}=await Promise.resolve().then((()=>(0,a.__importStar)(s(426))));this.glglyph=new e(i.regl_wrapper,this,\"circle\")}}get use_radius(){return!(this.radius.is_Scalar()&&isNaN(this.radius.value))}_set_data(s){super._set_data(s);const i=(()=>{if(this.use_radius)return 2*this.max_radius;{const{size:s}=this;return s.is_Scalar()?s.value:(0,x.max)(s.array)}})();this._configure(\"max_size\",{value:i})}_map_data(){if(this.use_radius)if(\"data\"==this.model.properties.radius.units)switch(this.model.radius_dimension){case\"x\":this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius);break;case\"y\":this.sradius=this.sdist(this.renderer.yscale,this._y,this.radius);break;case\"max\":{const s=this.sdist(this.renderer.xscale,this._x,this.radius),i=this.sdist(this.renderer.yscale,this._y,this.radius);this.sradius=(0,x.map)(s,((s,e)=>Math.max(s,i[e])));break}case\"min\":{const s=this.sdist(this.renderer.xscale,this._x,this.radius),i=this.sdist(this.renderer.yscale,this._y,this.radius);this.sradius=(0,x.map)(s,((s,e)=>Math.min(s,i[e])));break}}else this.sradius=(0,l.to_screen)(this.radius);else{const s=l.ScreenArray.from(this.size);this.sradius=(0,x.map)(s,(s=>s/2))}}_mask_data(){const{frame:s}=this.renderer.plot_view,i=s.x_target,e=s.y_target;let t,r;return this.use_radius&&\"data\"==this.model.properties.radius.units?(t=i.map((s=>this.renderer.xscale.invert(s))).widen(this.max_radius),r=e.map((s=>this.renderer.yscale.invert(s))).widen(this.max_radius)):(t=i.widen(this.max_size).map((s=>this.renderer.xscale.invert(s))),r=e.widen(this.max_size).map((s=>this.renderer.yscale.invert(s)))),this.index.indices({x0:t.start,x1:t.end,y0:r.start,y1:r.end})}_render(s,i,e){const{sx:t,sy:r,sradius:a}=null!=e?e:this;for(const e of i){const i=t[e],n=r[e],h=a[e];isFinite(i+n+h)&&(s.beginPath(),s.arc(i,n,h,0,2*Math.PI,!1),this.visuals.fill.apply(s,e),this.visuals.hatch.apply(s,e),this.visuals.line.apply(s,e))}}_hit_point(s){const{sx:i,sy:e}=s,t=this.renderer.xscale.invert(i),r=this.renderer.yscale.invert(e),{hit_dilation:a}=this.model;let n,h,d,l;if(this.use_radius&&\"data\"==this.model.properties.radius.units)n=t-this.max_radius*a,h=t+this.max_radius*a,d=r-this.max_radius*a,l=r+this.max_radius*a;else{const s=i-this.max_size*a,t=i+this.max_size*a;[n,h]=this.renderer.xscale.r_invert(s,t);const r=e-this.max_size*a,c=e+this.max_size*a;[d,l]=this.renderer.yscale.r_invert(r,c)}const c=this.index.indices({x0:n,x1:h,y0:d,y1:l}),_=[];if(this.use_radius&&\"data\"==this.model.properties.radius.units)for(const s of c){const i=(this.sradius[s]*a)**2,[e,n]=this.renderer.xscale.r_compute(t,this._x[s]),[h,d]=this.renderer.yscale.r_compute(r,this._y[s]);(e-n)**2+(h-d)**2<=i&&_.push(s)}else for(const s of c){const t=(this.sradius[s]*a)**2;(this.sx[s]-i)**2+(this.sy[s]-e)**2<=t&&_.push(s)}return new m.Selection({indices:_})}_hit_span(s){const{sx:i,sy:e}=s,t=this.bounds();let r,a,n,h;if(\"h\"==s.direction){let s,e;if(n=t.y0,h=t.y1,this.use_radius&&\"data\"==this.model.properties.radius.units)s=i-this.max_radius,e=i+this.max_radius,[r,a]=this.renderer.xscale.r_invert(s,e);else{const t=this.max_size/2;s=i-t,e=i+t,[r,a]=this.renderer.xscale.r_invert(s,e)}}else{let s,i;if(r=t.x0,a=t.x1,this.use_radius&&\"data\"==this.model.properties.radius.units)s=e-this.max_radius,i=e+this.max_radius,[n,h]=this.renderer.yscale.r_invert(s,i);else{const t=this.max_size/2;s=e-t,i=e+t,[n,h]=this.renderer.yscale.r_invert(s,i)}}const d=[...this.index.indices({x0:r,x1:a,y0:n,y1:h})];return new m.Selection({indices:d})}_hit_rect(s){const{sx0:i,sx1:e,sy0:t,sy1:r}=s,[a,n]=this.renderer.xscale.r_invert(i,e),[h,d]=this.renderer.yscale.r_invert(t,r),l=[...this.index.indices({x0:a,x1:n,y0:h,y1:d})];return new m.Selection({indices:l})}_hit_poly(s){const{sx:i,sy:e}=s,t=(0,o.range)(0,this.sx.length),r=[];for(let s=0,a=t.length;s({angle:[u.AngleSpec,0],size:[u.ScreenSizeSpec,{value:4}],radius:[u.NullDistanceSpec,null],radius_dimension:[c.RadiusDimension,\"x\"],hit_dilation:[s,1]})))},\n", " function _(e,l,s,i,_){var p;i();const t=e(274);class a extends t.EllipseOvalView{}s.EllipseView=a,a.__name__=\"EllipseView\";class n extends t.EllipseOval{constructor(e){super(e)}}s.Ellipse=n,p=n,n.__name__=\"Ellipse\",p.prototype.default_view=a},\n", " function _(t,s,e,i,h){i();const n=t(1),r=t(275),a=(0,n.__importStar)(t(185)),l=t(24),_=t(72),o=(0,n.__importStar)(t(18));class d extends r.CenterRotatableView{_map_data(){\"data\"==this.model.properties.width.units?this.sw=this.sdist(this.renderer.xscale,this._x,this.width,\"center\"):this.sw=(0,l.to_screen)(this.width),\"data\"==this.model.properties.height.units?this.sh=this.sdist(this.renderer.yscale,this._y,this.height,\"center\"):this.sh=(0,l.to_screen)(this.height)}_render(t,s,e){const{sx:i,sy:h,sw:n,sh:r,angle:a}=null!=e?e:this;for(const e of s){const s=i[e],l=h[e],_=n[e],o=r[e],d=a.get(e);isFinite(s+l+_+o+d)&&(t.beginPath(),t.ellipse(s,l,_/2,o/2,d,0,2*Math.PI),this.visuals.fill.apply(t,e),this.visuals.hatch.apply(t,e),this.visuals.line.apply(t,e))}}_hit_point(t){let s,e,i,h,n,r,l,o,d;const{sx:c,sy:p}=t,w=this.renderer.xscale.invert(c),x=this.renderer.yscale.invert(p);\"data\"==this.model.properties.width.units?(s=w-this.max_width,e=w+this.max_width):(r=c-this.max_width,l=c+this.max_width,[s,e]=this.renderer.xscale.r_invert(r,l)),\"data\"==this.model.properties.height.units?(i=x-this.max_height,h=x+this.max_height):(o=p-this.max_height,d=p+this.max_height,[i,h]=this.renderer.yscale.r_invert(o,d));const m=this.index.indices({x0:s,x1:e,y0:i,y1:h}),y=[];for(const t of m)n=a.point_in_ellipse(c,p,this.angle.get(t),this.sh[t]/2,this.sw[t]/2,this.sx[t],this.sy[t]),n&&y.push(t);return new _.Selection({indices:y})}draw_legend_for_index(t,{x0:s,y0:e,x1:i,y1:h},n){const r=n+1,a=new Array(r);a[n]=(s+i)/2;const l=new Array(r);l[n]=(e+h)/2;const _=this.sw[n]/this.sh[n],d=.8*Math.min(Math.abs(i-s),Math.abs(h-e)),c=new Array(r),p=new Array(r);_>1?(c[n]=d,p[n]=d/_):(c[n]=d*_,p[n]=d);const w=new o.UniformScalar(0,r);this._render(t,[n],{sx:a,sy:l,sw:c,sh:p,angle:w})}}e.EllipseOvalView=d,d.__name__=\"EllipseOvalView\";class c extends r.CenterRotatable{constructor(t){super(t)}}e.EllipseOval=c,c.__name__=\"EllipseOval\"},\n", " function _(e,t,i,a,n){a();const s=e(1);var r;const h=e(178),o=e(48),_=(0,s.__importStar)(e(18));class c extends h.XYGlyphView{get max_w2(){return\"data\"==this.model.properties.width.units?this.max_width/2:0}get max_h2(){return\"data\"==this.model.properties.height.units?this.max_height/2:0}_bounds({x0:e,x1:t,y0:i,y1:a}){const{max_w2:n,max_h2:s}=this;return{x0:e-n,x1:t+n,y0:i-s,y1:a+s}}}i.CenterRotatableView=c,c.__name__=\"CenterRotatableView\";class l extends h.XYGlyph{constructor(e){super(e)}}i.CenterRotatable=l,r=l,l.__name__=\"CenterRotatable\",r.mixins([o.LineVector,o.FillVector,o.HatchVector]),r.define((({})=>({angle:[_.AngleSpec,0],width:[_.DistanceSpec,{field:\"width\"}],height:[_.DistanceSpec,{field:\"height\"}]})))},\n", " function _(t,e,s,i,h){i();const r=t(1);var a;const n=t(277),o=t(24),_=(0,r.__importStar)(t(18));class c extends n.BoxView{scenterxy(t){return[(this.sleft[t]+this.sright[t])/2,this.sy[t]]}_lrtb(t){const e=this._left[t],s=this._right[t],i=this._y[t],h=this.height.get(t)/2;return[Math.min(e,s),Math.max(e,s),i+h,i-h]}_map_data(){this.sy=this.renderer.yscale.v_compute(this._y),this.sh=this.sdist(this.renderer.yscale,this._y,this.height,\"center\"),this.sleft=this.renderer.xscale.v_compute(this._left),this.sright=this.renderer.xscale.v_compute(this._right);const t=this.sy.length;this.stop=new o.ScreenArray(t),this.sbottom=new o.ScreenArray(t);for(let e=0;e({left:[_.XCoordinateSpec,{value:0}],y:[_.YCoordinateSpec,{field:\"y\"}],height:[_.NumberSpec,{value:1}],right:[_.XCoordinateSpec,{field:\"right\"}]})))},\n", " function _(t,e,s,r,i){var n;r();const a=t(48),h=t(179),o=t(184),c=t(72);class _ extends h.GlyphView{get_anchor_point(t,e,s){const r=Math.min(this.sleft[e],this.sright[e]),i=Math.max(this.sright[e],this.sleft[e]),n=Math.min(this.stop[e],this.sbottom[e]),a=Math.max(this.sbottom[e],this.stop[e]);switch(t){case\"top_left\":return{x:r,y:n};case\"top\":case\"top_center\":return{x:(r+i)/2,y:n};case\"top_right\":return{x:i,y:n};case\"bottom_left\":return{x:r,y:a};case\"bottom\":case\"bottom_center\":return{x:(r+i)/2,y:a};case\"bottom_right\":return{x:i,y:a};case\"left\":case\"center_left\":return{x:r,y:(n+a)/2};case\"center\":case\"center_center\":return{x:(r+i)/2,y:(n+a)/2};case\"right\":case\"center_right\":return{x:i,y:(n+a)/2}}}_index_data(t){const{min:e,max:s}=Math,{data_size:r}=this;for(let i=0;i({r:[l.NumberSpec,{field:\"r\"}],q:[l.NumberSpec,{field:\"q\"}],scale:[l.NumberSpec,1],size:[e,1],aspect_scale:[e,1],orientation:[_.HexTileOrientation,\"pointytop\"]}))),a.override({line_color:null})},\n", " function _(e,a,t,_,r){var n;_();const s=e(280),o=e(173),i=e(201);class p extends s.ImageBaseView{connect_signals(){super.connect_signals(),this.connect(this.model.color_mapper.change,(()=>this._update_image()))}_update_image(){null!=this.image_data&&(this._set_data(null),this.renderer.request_render())}_flat_img_to_buf8(e){return this.model.color_mapper.rgba_mapper.v_compute(e)}}t.ImageView=p,p.__name__=\"ImageView\";class m extends s.ImageBase{constructor(e){super(e)}}t.Image=m,n=m,m.__name__=\"Image\",n.prototype.default_view=p,n.define((({Ref:e})=>({color_mapper:[e(o.ColorMapper),()=>new i.LinearColorMapper({palette:[\"#000000\",\"#252525\",\"#525252\",\"#737373\",\"#969696\",\"#bdbdbd\",\"#d9d9d9\",\"#f0f0f0\",\"#ffffff\"]})]})))},\n", " function _(e,t,i,s,a){s();const h=e(1);var n;const r=e(178),_=e(24),d=(0,h.__importStar)(e(18)),l=e(72),g=e(9),o=e(29),c=e(11);class m extends r.XYGlyphView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.global_alpha.change,(()=>this.renderer.request_render()))}_render(e,t,i){const{image_data:s,sx:a,sy:h,sw:n,sh:r,global_alpha:_}=null!=i?i:this,d=e.getImageSmoothingEnabled();e.setImageSmoothingEnabled(!1);const l=_.is_Scalar();l&&(e.globalAlpha=_.value);for(const i of t){const t=s[i],_=a[i],d=h[i],g=n[i],o=r[i],c=this.global_alpha.get(i);if(null==t||!isFinite(_+d+g+o+c))continue;l||(e.globalAlpha=c);const m=d;e.translate(0,m),e.scale(1,-1),e.translate(0,-m),e.drawImage(t,0|_,0|d,g,o),e.translate(0,m),e.scale(1,-1),e.translate(0,-m)}e.setImageSmoothingEnabled(d)}_set_data(e){this._set_width_heigh_data();for(let t=0,i=this.image.length;t({image:[d.NDArraySpec,{field:\"image\"}],dw:[d.DistanceSpec,{field:\"dw\"}],dh:[d.DistanceSpec,{field:\"dh\"}],global_alpha:[d.NumberSpec,{value:1}],dilate:[e,!1]})))},\n", " function _(e,a,t,r,_){var n;r();const s=e(280),m=e(8);class i extends s.ImageBaseView{_flat_img_to_buf8(e){let a;return a=(0,m.isArray)(e)?new Uint32Array(e):e,new Uint8ClampedArray(a.buffer)}}t.ImageRGBAView=i,i.__name__=\"ImageRGBAView\";class g extends s.ImageBase{constructor(e){super(e)}}t.ImageRGBA=g,n=g,g.__name__=\"ImageRGBA\",n.prototype.default_view=i},\n", " function _(e,t,s,r,a){r();const i=e(1);var n;const o=e(178),c=e(24),_=e(20),h=(0,i.__importStar)(e(18)),l=e(12),d=e(136);class m extends o.XYGlyphView{constructor(){super(...arguments),this._images_rendered=!1,this._set_data_iteration=0}connect_signals(){super.connect_signals(),this.connect(this.model.properties.global_alpha.change,(()=>this.renderer.request_render()))}_index_data(e){const{data_size:t}=this;for(let s=0;s{this._set_data_iteration==r&&(this.image[a]=e,this.renderer.request_render())},attempts:t+1,timeout:s})}const a=\"data\"==this.model.properties.w.units,i=\"data\"==this.model.properties.h.units,n=this._x.length,o=new c.ScreenArray(a?2*n:n),_=new c.ScreenArray(i?2*n:n),{anchor:h}=this.model;function m(e,t){switch(h){case\"top_left\":case\"bottom_left\":case\"left\":case\"center_left\":return[e,e+t];case\"top\":case\"top_center\":case\"bottom\":case\"bottom_center\":case\"center\":case\"center_center\":return[e-t/2,e+t/2];case\"top_right\":case\"bottom_right\":case\"right\":case\"center_right\":return[e-t,e]}}function g(e,t){switch(h){case\"top_left\":case\"top\":case\"top_center\":case\"top_right\":return[e,e-t];case\"bottom_left\":case\"bottom\":case\"bottom_center\":case\"bottom_right\":return[e+t,e];case\"left\":case\"center_left\":case\"center\":case\"center_center\":case\"right\":case\"center_right\":return[e+t/2,e-t/2]}}if(a)for(let e=0;e({url:[h.StringSpec,{field:\"url\"}],anchor:[_.Anchor,\"top_left\"],global_alpha:[h.NumberSpec,{value:1}],angle:[h.AngleSpec,0],w:[h.NullDistanceSpec,null],h:[h.NullDistanceSpec,null],dilate:[e,!1],retry_attempts:[t,0],retry_timeout:[t,0]})))},\n", " function _(e,t,s,i,n){i();const o=e(1);var r;const l=e(78),_=e(48),c=(0,o.__importStar)(e(185)),h=(0,o.__importStar)(e(18)),a=e(12),d=e(13),x=e(179),y=e(184),g=e(72);class p extends x.GlyphView{_project_data(){l.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(e){const{data_size:t}=this;for(let s=0;s0&&o.set(e,s)}return new g.Selection({indices:[...o.keys()],multiline_indices:(0,d.to_object)(o)})}get_interpolation_hit(e,t,s){const i=this._xs.get(e),n=this._ys.get(e),o=i[t],r=n[t],l=i[t+1],_=n[t+1];return(0,y.line_interpolation)(this.renderer,s,o,r,l,_)}draw_legend_for_index(e,t,s){(0,y.generic_line_vector_legend)(this.visuals,e,t,s)}scenterxy(){throw new Error(`${this}.scenterxy() is not implemented`)}}s.MultiLineView=p,p.__name__=\"MultiLineView\";class u extends x.Glyph{constructor(e){super(e)}}s.MultiLine=u,r=u,u.__name__=\"MultiLine\",r.prototype.default_view=p,r.define((({})=>({xs:[h.XCoordinateSeqSpec,{field:\"xs\"}],ys:[h.YCoordinateSeqSpec,{field:\"ys\"}]}))),r.mixins(_.LineVector)},\n", " function _(t,e,s,n,i){n();const o=t(1);var r;const l=t(181),h=t(179),a=t(184),_=t(12),c=t(12),d=t(48),x=(0,o.__importStar)(t(185)),y=(0,o.__importStar)(t(18)),f=t(72),g=t(11);class p extends h.GlyphView{_project_data(){}_index_data(t){const{min:e,max:s}=Math,{data_size:n}=this;for(let i=0;i1&&c.length>1)for(let s=1,n=i.length;s1){let r=!1;for(let t=1;t({xs:[y.XCoordinateSeqSeqSeqSpec,{field:\"xs\"}],ys:[y.YCoordinateSeqSeqSeqSpec,{field:\"ys\"}]}))),r.mixins([d.LineVector,d.FillVector,d.HatchVector])},\n", " function _(a,e,l,s,_){var t;s();const i=a(274),n=a(12);class p extends i.EllipseOvalView{_map_data(){super._map_data(),(0,n.mul)(this.sw,.75)}}l.OvalView=p,p.__name__=\"OvalView\";class v extends i.EllipseOval{constructor(a){super(a)}}l.Oval=v,t=v,v.__name__=\"Oval\",t.prototype.default_view=p},\n", " function _(e,t,s,i,n){i();const r=e(1);var a;const o=e(179),c=e(184),_=e(12),h=e(48),l=(0,r.__importStar)(e(185)),d=(0,r.__importStar)(e(18)),y=e(72),p=e(11),x=e(78);class f extends o.GlyphView{_project_data(){x.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(e){const{data_size:t}=this;for(let s=0;s({xs:[d.XCoordinateSeqSpec,{field:\"xs\"}],ys:[d.YCoordinateSeqSpec,{field:\"ys\"}]}))),a.mixins([h.LineVector,h.FillVector,h.HatchVector])},\n", " function _(t,e,o,i,s){i();const r=t(1);var n;const _=t(277),d=(0,r.__importStar)(t(18));class a extends _.BoxView{scenterxy(t){return[this.sleft[t]/2+this.sright[t]/2,this.stop[t]/2+this.sbottom[t]/2]}_lrtb(t){return[this._left[t],this._right[t],this._top[t],this._bottom[t]]}}o.QuadView=a,a.__name__=\"QuadView\";class c extends _.Box{constructor(t){super(t)}}o.Quad=c,n=c,c.__name__=\"Quad\",n.prototype.default_view=a,n.define((({})=>({right:[d.XCoordinateSpec,{field:\"right\"}],bottom:[d.YCoordinateSpec,{field:\"bottom\"}],left:[d.XCoordinateSpec,{field:\"left\"}],top:[d.YCoordinateSpec,{field:\"top\"}]})))},\n", " function _(e,t,i,n,s){n();const c=e(1);var o;const r=e(48),a=e(78),_=e(179),d=e(184),l=(0,c.__importStar)(e(18));function x(e,t,i){if(t==(e+i)/2)return[e,i];{const n=(e-t)/(e-2*t+i),s=e*(1-n)**2+2*t*(1-n)*n+i*n**2;return[Math.min(e,i,s),Math.max(e,i,s)]}}class y extends _.GlyphView{_project_data(){a.inplace.project_xy(this._x0,this._y0),a.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{_x0:t,_x1:i,_y0:n,_y1:s,_cx:c,_cy:o,data_size:r}=this;for(let a=0;a({x0:[l.XCoordinateSpec,{field:\"x0\"}],y0:[l.YCoordinateSpec,{field:\"y0\"}],x1:[l.XCoordinateSpec,{field:\"x1\"}],y1:[l.YCoordinateSpec,{field:\"y1\"}],cx:[l.XCoordinateSpec,{field:\"cx\"}],cy:[l.YCoordinateSpec,{field:\"cy\"}]}))),o.mixins(r.LineVector)},\n", " function _(e,t,s,i,n){i();const l=e(1);var a;const r=e(178),o=e(184),h=e(48),_=e(24),c=(0,l.__importStar)(e(18));class g extends r.XYGlyphView{_map_data(){\"data\"==this.model.properties.length.units?this.slength=this.sdist(this.renderer.xscale,this._x,this.length):this.slength=(0,_.to_screen)(this.length);const{width:e,height:t}=this.renderer.plot_view.frame.bbox,s=2*(e+t),{slength:i}=this;for(let e=0,t=i.length;e({length:[c.DistanceSpec,0],angle:[c.AngleSpec,0]})))},\n", " function _(t,e,s,i,r){var n,h=this&&this.__createBinding||(Object.create?function(t,e,s,i){void 0===i&&(i=s),Object.defineProperty(t,i,{enumerable:!0,get:function(){return e[s]}})}:function(t,e,s,i){void 0===i&&(i=s),t[i]=e[s]}),a=this&&this.__setModuleDefault||(Object.create?function(t,e){Object.defineProperty(t,\"default\",{enumerable:!0,value:e})}:function(t,e){t.default=e}),l=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var s in t)\"default\"!==s&&Object.prototype.hasOwnProperty.call(t,s)&&h(e,t,s);return a(e,t),e};i();const o=t(275),c=t(184),_=t(24),d=t(12),f=t(72);class y extends o.CenterRotatableView{async lazy_initialize(){await super.lazy_initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;if(null==e?void 0:e.regl_wrapper.has_webgl){const{RectGL:s}=await Promise.resolve().then((()=>l(t(425))));this.glglyph=new s(e.regl_wrapper,this)}}_map_data(){if(\"data\"==this.model.properties.width.units)[this.sw,this.sx0]=this._map_dist_corner_for_data_side_length(this._x,this.width,this.renderer.xscale);else{this.sw=(0,_.to_screen)(this.width);const t=this.sx.length;this.sx0=new _.ScreenArray(t);for(let e=0;e({dilate:[t,!1]})))},\n", " function _(e,t,s,r,i){r();const a=e(1);var n;const l=e(292),_=e(293),c=(0,a.__importStar)(e(18));class o extends l.MarkerView{async lazy_initialize(){await super.lazy_initialize();const{webgl:t}=this.renderer.plot_view.canvas_view;if(null==t?void 0:t.regl_wrapper.has_webgl){const{MarkerGL:t}=await Promise.resolve().then((()=>(0,a.__importStar)(e(426))));this.glcls=t}}_init_webgl(){const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e){const{regl_wrapper:t}=e;if(t.has_webgl){const e=new Set(null!=this.base?this.base.marker:this.marker);if(1==e.size){const[s]=[...e],r=this.glcls;if(null==r?void 0:r.is_supported(s)){const{glglyph:e}=this;if(null==e||e.marker_type!=s)return void(this.glglyph=new r(t,this,s))}}}}delete this.glglyph}_set_visuals(){this._init_webgl()}_render(e,t,s){const{sx:r,sy:i,size:a,angle:n,marker:l}=null!=s?s:this;for(const s of t){const t=r[s],c=i[s],o=a.get(s),g=n.get(s),h=l.get(s);if(!isFinite(t+c+o+g)||null==h)continue;const w=o/2;e.beginPath(),e.translate(t,c),g&&e.rotate(g),_.marker_funcs[h](e,s,w,this.visuals),g&&e.rotate(-g),e.translate(-t,-c)}}draw_legend_for_index(e,{x0:t,x1:s,y0:r,y1:i},a){const n=a+1,l=this.marker.get(a),_=Object.assign(Object.assign({},this._get_legend_args({x0:t,x1:s,y0:r,y1:i},a)),{marker:new c.UniformScalar(l,n)});this._render(e,[a],_)}}s.ScatterView=o,o.__name__=\"ScatterView\";class g extends l.Marker{constructor(e){super(e)}}s.Scatter=g,n=g,g.__name__=\"Scatter\",n.prototype.default_view=o,n.define((()=>({marker:[c.MarkerSpec,{value:\"circle\"}]})))},\n", " function _(e,t,s,n,i){n();const r=e(1);var a;const c=e(178),o=e(48),_=(0,r.__importStar)(e(185)),h=(0,r.__importStar)(e(18)),l=e(9),x=e(72);class d extends c.XYGlyphView{_render(e,t,s){const{sx:n,sy:i,size:r,angle:a}=null!=s?s:this;for(const s of t){const t=n[s],c=i[s],o=r.get(s),_=a.get(s);if(!isFinite(t+c+o+_))continue;const h=o/2;e.beginPath(),e.translate(t,c),_&&e.rotate(_),this._render_one(e,s,h,this.visuals),_&&e.rotate(-_),e.translate(-t,-c)}}_mask_data(){const{x_target:e,y_target:t}=this.renderer.plot_view.frame,s=e.widen(this.max_size).map((e=>this.renderer.xscale.invert(e))),n=t.widen(this.max_size).map((e=>this.renderer.yscale.invert(e)));return this.index.indices({x0:s.start,x1:s.end,y0:n.start,y1:n.end})}_hit_point(e){const{sx:t,sy:s}=e,{max_size:n}=this,{hit_dilation:i}=this.model,r=t-n*i,a=t+n*i,[c,o]=this.renderer.xscale.r_invert(r,a),_=s-n*i,h=s+n*i,[l,d]=this.renderer.yscale.r_invert(_,h),y=this.index.indices({x0:c,x1:o,y0:l,y1:d}),g=[];for(const e of y){const n=this.size.get(e)/2*i;Math.abs(this.sx[e]-t)<=n&&Math.abs(this.sy[e]-s)<=n&&g.push(e)}return new x.Selection({indices:g})}_hit_span(e){const{sx:t,sy:s}=e,n=this.bounds(),i=this.max_size/2;let r,a,c,o;if(\"h\"==e.direction){c=n.y0,o=n.y1;const e=t-i,s=t+i;[r,a]=this.renderer.xscale.r_invert(e,s)}else{r=n.x0,a=n.x1;const e=s-i,t=s+i;[c,o]=this.renderer.yscale.r_invert(e,t)}const _=[...this.index.indices({x0:r,x1:a,y0:c,y1:o})];return new x.Selection({indices:_})}_hit_rect(e){const{sx0:t,sx1:s,sy0:n,sy1:i}=e,[r,a]=this.renderer.xscale.r_invert(t,s),[c,o]=this.renderer.yscale.r_invert(n,i),_=[...this.index.indices({x0:r,x1:a,y0:c,y1:o})];return new x.Selection({indices:_})}_hit_poly(e){const{sx:t,sy:s}=e,n=(0,l.range)(0,this.sx.length),i=[];for(let e=0,r=n.length;e({size:[h.ScreenSizeSpec,{value:4}],angle:[h.AngleSpec,0],hit_dilation:[e,1]})))},\n", " function _(l,o,n,t,i){t();const e=Math.sqrt(3),a=Math.sqrt(5),c=(a+1)/4,p=Math.sqrt((5-a)/8),r=(a-1)/4,h=Math.sqrt((5+a)/8);function u(l,o){l.rotate(Math.PI/4),s(l,o),l.rotate(-Math.PI/4)}function f(l,o){const n=o*e,t=n/3;l.moveTo(-n/2,-t),l.lineTo(0,0),l.lineTo(n/2,-t),l.lineTo(0,0),l.lineTo(0,o)}function s(l,o){l.moveTo(0,o),l.lineTo(0,-o),l.moveTo(-o,0),l.lineTo(o,0)}function T(l,o){l.moveTo(0,o),l.lineTo(o/1.5,0),l.lineTo(0,-o),l.lineTo(-o/1.5,0),l.closePath()}function y(l,o){const n=o*e,t=n/3;l.moveTo(-o,t),l.lineTo(o,t),l.lineTo(0,t-n),l.closePath()}function v(l,o,n,t){l.arc(0,0,n,0,2*Math.PI,!1),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)}function d(l,o,n,t){T(l,n),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)}function _(l,o,n,t){!function(l,o){l.beginPath(),l.arc(0,0,o/4,0,2*Math.PI,!1),l.closePath()}(l,n),t.line.set_vectorize(l,o),l.fillStyle=l.strokeStyle,l.fill()}function P(l,o,n,t){!function(l,o){const n=o/2,t=e*n;l.moveTo(o,0),l.lineTo(n,-t),l.lineTo(-n,-t),l.lineTo(-o,0),l.lineTo(-n,t),l.lineTo(n,t),l.closePath()}(l,n),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)}function m(l,o,n,t){const i=2*n;l.rect(-n,-n,i,i),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)}function q(l,o,n,t){!function(l,o){const n=Math.sqrt(5-2*a)*o;l.moveTo(0,-o),l.lineTo(n*r,n*h-o),l.lineTo(n*(1+r),n*h-o),l.lineTo(n*(1+r-c),n*(h+p)-o),l.lineTo(n*(1+2*r-c),n*(2*h+p)-o),l.lineTo(0,2*n*h-o),l.lineTo(-n*(1+2*r-c),n*(2*h+p)-o),l.lineTo(-n*(1+r-c),n*(h+p)-o),l.lineTo(-n*(1+r),n*h-o),l.lineTo(-n*r,n*h-o),l.closePath()}(l,n),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)}function M(l,o,n,t){y(l,n),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)}n.marker_funcs={asterisk:function(l,o,n,t){s(l,n),u(l,n),t.line.apply(l,o)},circle:v,circle_cross:function(l,o,n,t){l.arc(0,0,n,0,2*Math.PI,!1),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.doit&&(t.line.set_vectorize(l,o),s(l,n),l.stroke())},circle_dot:function(l,o,n,t){v(l,o,n,t),_(l,o,n,t)},circle_y:function(l,o,n,t){l.arc(0,0,n,0,2*Math.PI,!1),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.doit&&(t.line.set_vectorize(l,o),f(l,n),l.stroke())},circle_x:function(l,o,n,t){l.arc(0,0,n,0,2*Math.PI,!1),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.doit&&(t.line.set_vectorize(l,o),u(l,n),l.stroke())},cross:function(l,o,n,t){s(l,n),t.line.apply(l,o)},diamond:d,diamond_dot:function(l,o,n,t){d(l,o,n,t),_(l,o,n,t)},diamond_cross:function(l,o,n,t){T(l,n),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.doit&&(t.line.set_vectorize(l,o),l.moveTo(0,n),l.lineTo(0,-n),l.moveTo(-n/1.5,0),l.lineTo(n/1.5,0),l.stroke())},dot:_,hex:P,hex_dot:function(l,o,n,t){P(l,o,n,t),_(l,o,n,t)},inverted_triangle:function(l,o,n,t){l.rotate(Math.PI),y(l,n),l.rotate(-Math.PI),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)},plus:function(l,o,n,t){const i=3*n/8,e=[i,i,n,n,i,i,-i,-i,-n,-n,-i,-i],a=[n,i,i,-i,-i,-n,-n,-i,-i,i,i,n];l.beginPath();for(let o=0;o<12;o++)l.lineTo(e[o],a[o]);l.closePath(),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)},square:m,square_cross:function(l,o,n,t){const i=2*n;l.rect(-n,-n,i,i),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.doit&&(t.line.set_vectorize(l,o),s(l,n),l.stroke())},square_dot:function(l,o,n,t){m(l,o,n,t),_(l,o,n,t)},square_pin:function(l,o,n,t){const i=3*n/8;l.moveTo(-n,-n),l.quadraticCurveTo(0,-i,n,-n),l.quadraticCurveTo(i,0,n,n),l.quadraticCurveTo(0,i,-n,n),l.quadraticCurveTo(-i,0,-n,-n),l.closePath(),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)},square_x:function(l,o,n,t){const i=2*n;l.rect(-n,-n,i,i),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.doit&&(t.line.set_vectorize(l,o),l.moveTo(-n,n),l.lineTo(n,-n),l.moveTo(-n,-n),l.lineTo(n,n),l.stroke())},star:q,star_dot:function(l,o,n,t){q(l,o,n,t),_(l,o,n,t)},triangle:M,triangle_dot:function(l,o,n,t){M(l,o,n,t),_(l,o,n,t)},triangle_pin:function(l,o,n,t){const i=n*e,a=i/3,c=3*a/8;l.moveTo(-n,a),l.quadraticCurveTo(0,c,n,a),l.quadraticCurveTo(e*c/2,c/2,0,a-i),l.quadraticCurveTo(-e*c/2,c/2,-n,a),l.closePath(),t.fill.apply(l,o),t.hatch.apply(l,o),t.line.apply(l,o)},dash:function(l,o,n,t){!function(l,o){l.moveTo(-o,0),l.lineTo(o,0)}(l,n),t.line.apply(l,o)},x:function(l,o,n,t){u(l,n),t.line.apply(l,o)},y:function(l,o,n,t){f(l,n),t.line.apply(l,o)}}},\n", " function _(e,t,s,i,n){i();const r=e(1);var o;const _=(0,r.__importStar)(e(185)),h=(0,r.__importStar)(e(18)),c=e(48),a=e(78),d=e(179),x=e(184),l=e(72);class y extends d.GlyphView{_project_data(){a.inplace.project_xy(this._x0,this._y0),a.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{min:t,max:s}=Math,{_x0:i,_x1:n,_y0:r,_y1:o,data_size:_}=this;for(let h=0;h<_;h++){const _=i[h],c=n[h],a=r[h],d=o[h];e.add_rect(t(_,c),t(a,d),s(_,c),s(a,d))}}_render(e,t,s){if(this.visuals.line.doit){const{sx0:i,sy0:n,sx1:r,sy1:o}=null!=s?s:this;for(const s of t){const t=i[s],_=n[s],h=r[s],c=o[s];isFinite(t+_+h+c)&&(e.beginPath(),e.moveTo(t,_),e.lineTo(h,c),this.visuals.line.set_vectorize(e,s),e.stroke())}}}_hit_point(e){const{sx:t,sy:s}=e,i={x:t,y:s},[n,r]=this.renderer.xscale.r_invert(t-2,t+2),[o,h]=this.renderer.yscale.r_invert(s-2,s+2),c=this.index.indices({x0:n,y0:o,x1:r,y1:h}),a=[];for(const e of c){const t=Math.max(2,this.line_width.get(e)/2)**2,s={x:this.sx0[e],y:this.sy0[e]},n={x:this.sx1[e],y:this.sy1[e]};_.dist_to_segment_squared(i,s,n)({x0:[h.XCoordinateSpec,{field:\"x0\"}],y0:[h.YCoordinateSpec,{field:\"y0\"}],x1:[h.XCoordinateSpec,{field:\"x1\"}],y1:[h.YCoordinateSpec,{field:\"y1\"}]}))),o.mixins(c.LineVector)},\n", " function _(t,e,s,i,n){i();const o=t(1);var _;const l=t(178),a=(0,o.__importStar)(t(48)),c=t(296);class r extends l.XYGlyphView{_set_data(){const{tension:t,closed:e}=this.model;[this._xt,this._yt]=(0,c.catmullrom_spline)(this._x,this._y,20,t,e)}_map_data(){const{x_scale:t,y_scale:e}=this.renderer.coordinates;this.sxt=t.v_compute(this._xt),this.syt=e.v_compute(this._yt)}_render(t,e,s){const{sxt:i,syt:n}=null!=s?s:this;let o=!0;t.beginPath();const _=i.length;for(let e=0;e<_;e++){const s=i[e],_=n[e];isFinite(s+_)?o?(t.moveTo(s,_),o=!1):t.lineTo(s,_):o=!0}this.visuals.line.set_value(t),t.stroke()}}s.SplineView=r,r.__name__=\"SplineView\";class h extends l.XYGlyph{constructor(t){super(t)}}s.Spline=h,_=h,h.__name__=\"Spline\",_.prototype.default_view=r,_.mixins(a.LineScalar),_.define((({Boolean:t,Number:e})=>({tension:[e,.5],closed:[t,!1]})))},\n", " function _(n,t,e,o,s){o();const c=n(24),l=n(11);e.catmullrom_spline=function(n,t,e=10,o=.5,s=!1){(0,l.assert)(n.length==t.length);const r=n.length,f=s?r+1:r,w=(0,c.infer_type)(n,t),i=new w(f+2),u=new w(f+2);i.set(n,1),u.set(t,1),s?(i[0]=n[r-1],u[0]=t[r-1],i[f]=n[0],u[f]=t[0],i[f+1]=n[1],u[f+1]=t[1]):(i[0]=n[0],u[0]=t[0],i[f+1]=n[r-1],u[f+1]=t[r-1]);const g=new w(4*(e+1));for(let n=0,t=0;n<=e;n++){const o=n/e,s=o**2,c=o*s;g[t++]=2*c-3*s+1,g[t++]=-2*c+3*s,g[t++]=c-2*s+o,g[t++]=c-s}const h=new w((f-1)*(e+1)),_=new w((f-1)*(e+1));for(let n=1,t=0;n1&&(e.stroke(),o=!1)}o?(e.lineTo(t,r),e.lineTo(a,c)):(e.beginPath(),e.moveTo(s[n],i[n]),o=!0),l=n}e.lineTo(s[a-1],i[a-1]),e.stroke()}}draw_legend_for_index(e,t,n){(0,r.generic_line_scalar_legend)(this.visuals,e,t)}}n.StepView=f,f.__name__=\"StepView\";class u extends a.XYGlyph{constructor(e){super(e)}}n.Step=u,l=u,u.__name__=\"Step\",l.prototype.default_view=f,l.mixins(c.LineScalar),l.define((()=>({mode:[_.StepMode,\"before\"]})))},\n", " function _(t,e,s,i,n){i();const o=t(1);var _;const h=t(178),l=t(48),r=(0,o.__importStar)(t(185)),a=(0,o.__importStar)(t(18)),c=t(121),x=t(11),u=t(72);class f extends h.XYGlyphView{_rotate_point(t,e,s,i,n){return[(t-s)*Math.cos(n)-(e-i)*Math.sin(n)+s,(t-s)*Math.sin(n)+(e-i)*Math.cos(n)+i]}_text_bounds(t,e,s,i){return[[t,t+s,t+s,t,t],[e,e,e-i,e-i,e]]}_render(t,e,s){const{sx:i,sy:n,x_offset:o,y_offset:_,angle:h,text:l}=null!=s?s:this;this._sys=[],this._sxs=[];for(const s of e){const e=this._sxs[s]=[],r=this._sys[s]=[],a=i[s],x=n[s],u=o.get(s),f=_.get(s),p=h.get(s),g=l.get(s);if(isFinite(a+x+u+f+p)&&null!=g&&this.visuals.text.doit){const i=`${g}`;t.save(),t.translate(a+u,x+f),t.rotate(p),this.visuals.text.set_vectorize(t,s);const n=this.visuals.text.font_value(s),{height:o}=(0,c.font_metrics)(n),_=this.text_line_height.get(s)*o;if(-1==i.indexOf(\"\\n\")){t.fillText(i,0,0);const s=a+u,n=x+f,o=t.measureText(i).width,[h,l]=this._text_bounds(s,n,o,_);e.push(h),r.push(l)}else{const n=i.split(\"\\n\"),o=_*n.length,h=this.text_baseline.get(s);let l;switch(h){case\"top\":l=0;break;case\"middle\":l=-o/2+_/2;break;case\"bottom\":l=-o+_;break;default:l=0,console.warn(`'${h}' baseline not supported with multi line text`)}for(const s of n){t.fillText(s,0,l);const i=a+u,n=l+x+f,o=t.measureText(s).width,[h,c]=this._text_bounds(i,n,o,_);e.push(h),r.push(c),l+=_}}t.restore()}}}_hit_point(t){const{sx:e,sy:s}=t,i=[];for(let t=0;t({text:[a.NullStringSpec,{field:\"text\"}],angle:[a.AngleSpec,0],x_offset:[a.NumberSpec,0],y_offset:[a.NumberSpec,0]})))},\n", " function _(t,s,e,i,r){i();const h=t(1);var o;const a=t(277),n=t(24),_=(0,h.__importStar)(t(18));class c extends a.BoxView{scenterxy(t){return[this.sx[t],(this.stop[t]+this.sbottom[t])/2]}_lrtb(t){const s=this.width.get(t)/2,e=this._x[t],i=this._top[t],r=this._bottom[t];return[e-s,e+s,Math.max(i,r),Math.min(i,r)]}_map_data(){this.sx=this.renderer.xscale.v_compute(this._x),this.sw=this.sdist(this.renderer.xscale,this._x,this.width,\"center\"),this.stop=this.renderer.yscale.v_compute(this._top),this.sbottom=this.renderer.yscale.v_compute(this._bottom);const t=this.sx.length;this.sleft=new n.ScreenArray(t),this.sright=new n.ScreenArray(t);for(let s=0;s({x:[_.XCoordinateSpec,{field:\"x\"}],bottom:[_.YCoordinateSpec,{value:0}],width:[_.NumberSpec,{value:1}],top:[_.YCoordinateSpec,{field:\"top\"}]})))},\n", " function _(e,s,t,i,n){i();const r=e(1);var a;const c=e(178),l=e(184),d=e(48),o=e(24),h=e(20),_=(0,r.__importStar)(e(18)),u=e(10),g=e(72);class p extends c.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius):this.sradius=(0,o.to_screen)(this.radius)}_render(e,s,t){const{sx:i,sy:n,sradius:r,start_angle:a,end_angle:c}=null!=t?t:this,l=\"anticlock\"==this.model.direction;for(const t of s){const s=i[t],d=n[t],o=r[t],h=a.get(t),_=c.get(t);isFinite(s+d+o+h+_)&&(e.beginPath(),e.arc(s,d,o,h,_,l),e.lineTo(s,d),e.closePath(),this.visuals.fill.apply(e,t),this.visuals.hatch.apply(e,t),this.visuals.line.apply(e,t))}}_hit_point(e){let s,t,i,n,r,a,c,l,d;const{sx:o,sy:h}=e,_=this.renderer.xscale.invert(o),p=this.renderer.yscale.invert(h),x=2*this.max_radius;\"data\"===this.model.properties.radius.units?(a=_-x,c=_+x,l=p-x,d=p+x):(t=o-x,i=o+x,[a,c]=this.renderer.xscale.r_invert(t,i),n=h-x,r=h+x,[l,d]=this.renderer.yscale.r_invert(n,r));const y=[];for(const e of this.index.indices({x0:a,x1:c,y0:l,y1:d})){const a=this.sradius[e]**2;[t,i]=this.renderer.xscale.r_compute(_,this._x[e]),[n,r]=this.renderer.yscale.r_compute(p,this._y[e]),s=(t-i)**2+(n-r)**2,s<=a&&y.push(e)}const f=\"anticlock\"==this.model.direction,m=[];for(const e of y){const s=Math.atan2(h-this.sy[e],o-this.sx[e]);(0,u.angle_between)(-s,-this.start_angle.get(e),-this.end_angle.get(e),f)&&m.push(e)}return new g.Selection({indices:m})}draw_legend_for_index(e,s,t){(0,l.generic_area_vector_legend)(this.visuals,e,s,t)}scenterxy(e){const s=this.sradius[e]/2,t=(this.start_angle.get(e)+this.end_angle.get(e))/2;return[this.sx[e]+s*Math.cos(t),this.sy[e]+s*Math.sin(t)]}}t.WedgeView=p,p.__name__=\"WedgeView\";class x extends c.XYGlyph{constructor(e){super(e)}}t.Wedge=x,a=x,x.__name__=\"Wedge\",a.prototype.default_view=p,a.mixins([d.LineVector,d.FillVector,d.HatchVector]),a.define((({})=>({direction:[h.Direction,\"anticlock\"],radius:[_.DistanceSpec,{field:\"radius\"}],start_angle:[_.AngleSpec,{field:\"start_angle\"}],end_angle:[_.AngleSpec,{field:\"end_angle\"}]})))},\n", " function _(t,_,r,o,a){o();const e=t(1);(0,e.__exportStar)(t(302),r),(0,e.__exportStar)(t(303),r),(0,e.__exportStar)(t(304),r)},\n", " function _(e,t,d,n,s){n();const o=e(53),r=e(12),_=e(9),i=e(72);class c extends o.Model{constructor(e){super(e)}_hit_test(e,t,d){if(!t.model.visible)return null;const n=d.glyph.hit_test(e);return null==n?null:d.model.view.convert_selection_from_subset(n)}}d.GraphHitTestPolicy=c,c.__name__=\"GraphHitTestPolicy\";class a extends c{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.edge_view)}do_selection(e,t,d,n){if(null==e)return!1;const s=t.edge_renderer.data_source.selected;return s.update(e,d,n),t.edge_renderer.data_source._select.emit(),!s.is_empty()}do_inspection(e,t,d,n,s){if(null==e)return!1;const{edge_renderer:o}=d.model,r=o.get_selection_manager().get_or_create_inspector(d.edge_view.model);return r.update(e,n,s),d.edge_view.model.data_source.setv({inspected:r},{silent:!0}),d.edge_view.model.data_source.inspect.emit([d.edge_view.model,{geometry:t}]),!r.is_empty()}}d.EdgesOnly=a,a.__name__=\"EdgesOnly\";class l extends c{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.node_view)}do_selection(e,t,d,n){if(null==e)return!1;const s=t.node_renderer.data_source.selected;return s.update(e,d,n),t.node_renderer.data_source._select.emit(),!s.is_empty()}do_inspection(e,t,d,n,s){if(null==e)return!1;const{node_renderer:o}=d.model,r=o.get_selection_manager().get_or_create_inspector(d.node_view.model);return r.update(e,n,s),d.node_view.model.data_source.setv({inspected:r},{silent:!0}),d.node_view.model.data_source.inspect.emit([d.node_view.model,{geometry:t}]),!r.is_empty()}}d.NodesOnly=l,l.__name__=\"NodesOnly\";class u extends c{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.node_view)}get_linked_edges(e,t,d){let n=[];\"selection\"==d?n=e.selected.indices.map((t=>e.data.index[t])):\"inspection\"==d&&(n=e.inspected.indices.map((t=>e.data.index[t])));const s=[];for(let e=0;e(0,r.indexOf)(e.data.index,t)));return new i.Selection({indices:o})}do_selection(e,t,d,n){if(null==e)return!1;const s=t.edge_renderer.data_source.selected;s.update(e,d,n);const o=t.node_renderer.data_source.selected,r=this.get_linked_nodes(t.node_renderer.data_source,t.edge_renderer.data_source,\"selection\");return o.update(r,d,n),t.edge_renderer.data_source._select.emit(),!s.is_empty()}do_inspection(e,t,d,n,s){if(null==e)return!1;const o=d.edge_view.model.data_source.selection_manager.get_or_create_inspector(d.edge_view.model);o.update(e,n,s),d.edge_view.model.data_source.setv({inspected:o},{silent:!0});const r=d.node_view.model.data_source.selection_manager.get_or_create_inspector(d.node_view.model),_=this.get_linked_nodes(d.node_view.model.data_source,d.edge_view.model.data_source,\"inspection\");return r.update(_,n,s),d.node_view.model.data_source.setv({inspected:r},{silent:!0}),d.edge_view.model.data_source.inspect.emit([d.edge_view.model,{geometry:t}]),!o.is_empty()}}d.EdgesAndLinkedNodes=m,m.__name__=\"EdgesAndLinkedNodes\"},\n", " function _(e,o,t,r,n){var s;r();const a=e(53),d=e(260);class _ extends a.Model{constructor(e){super(e)}get node_coordinates(){return new u({layout:this})}get edge_coordinates(){return new i({layout:this})}}t.LayoutProvider=_,_.__name__=\"LayoutProvider\";class c extends d.CoordinateTransform{constructor(e){super(e)}}t.GraphCoordinates=c,s=c,c.__name__=\"GraphCoordinates\",s.define((({Ref:e})=>({layout:[e(_)]})));class u extends c{constructor(e){super(e)}_v_compute(e){const[o,t]=this.layout.get_node_coordinates(e);return{x:o,y:t}}}t.NodeCoordinates=u,u.__name__=\"NodeCoordinates\";class i extends c{constructor(e){super(e)}_v_compute(e){const[o,t]=this.layout.get_edge_coordinates(e);return{x:o,y:t}}}t.EdgeCoordinates=i,i.__name__=\"EdgeCoordinates\"},\n", " function _(t,a,l,e,n){var o;e();const r=t(303);class u extends r.LayoutProvider{constructor(t){super(t)}get_node_coordinates(t){var a;const l=null!==(a=t.data.index)&&void 0!==a?a:[],e=l.length,n=new Float64Array(e),o=new Float64Array(e);for(let t=0;t({graph_layout:[l(a(t,t)),{}]})))},\n", " function _(i,d,n,r,G){r(),G(\"Grid\",i(306).Grid)},\n", " function _(i,e,n,s,t){s();const r=i(1);var o;const d=i(127),_=i(129),a=i(130),l=(0,r.__importStar)(i(48)),h=i(8);class c extends _.GuideRendererView{_render(){const i=this.layer.ctx;i.save(),this._draw_regions(i),this._draw_minor_grids(i),this._draw_grids(i),i.restore()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_draw_regions(i){if(!this.visuals.band_fill.doit&&!this.visuals.band_hatch.doit)return;const[e,n]=this.grid_coords(\"major\",!1);for(let s=0;sn[1]&&(t=n[1]);else{[s,t]=n;for(const i of this.plot_view.axis_views)i.dimension==this.model.dimension&&i.model.x_range_name==this.model.x_range_name&&i.model.y_range_name==this.model.y_range_name&&([s,t]=i.computed_bounds)}return[s,t]}grid_coords(i,e=!0){const n=this.model.dimension,s=(n+1)%2,[t,r]=this.ranges();let[o,d]=this.computed_bounds();[o,d]=[Math.min(o,d),Math.max(o,d)];const _=[[],[]],a=this.model.get_ticker();if(null==a)return _;const l=a.get_ticks(o,d,t,r.min)[i],h=t.min,c=t.max,u=r.min,m=r.max;e||(l[0]!=h&&l.splice(0,0,h),l[l.length-1]!=c&&l.push(c));for(let i=0;i({bounds:[r(t(i,i),e),\"auto\"],dimension:[n(0,1),0],axis:[o(s(d.Axis)),null],ticker:[o(s(a.Ticker)),null]}))),o.override({level:\"underlay\",band_fill_color:null,band_fill_alpha:0,grid_line_color:\"#e5e5e5\",minor_grid_line_color:null})},\n", " function _(o,a,x,B,e){B(),e(\"Box\",o(308).Box),e(\"Column\",o(310).Column),e(\"GridBox\",o(311).GridBox),e(\"HTMLBox\",o(312).HTMLBox),e(\"LayoutDOM\",o(309).LayoutDOM),e(\"Panel\",o(313).Panel),e(\"Row\",o(314).Row),e(\"Spacer\",o(315).Spacer),e(\"Tabs\",o(316).Tabs),e(\"WidgetBox\",o(319).WidgetBox)},\n", " function _(e,n,s,t,c){var i;t();const o=e(309);class r extends o.LayoutDOMView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.children.change,(()=>this.rebuild()))}get child_models(){return this.model.children}}s.BoxView=r,r.__name__=\"BoxView\";class a extends o.LayoutDOM{constructor(e){super(e)}}s.Box=a,i=a,a.__name__=\"Box\",i.define((({Number:e,Array:n,Ref:s})=>({children:[n(s(o.LayoutDOM)),[]],spacing:[e,0]})))},\n", " function _(t,i,e,s,o){var l;s();const n=t(53),h=t(20),a=t(43),r=t(19),_=t(8),c=t(22),u=t(121),d=t(113),p=t(226),m=t(207),g=t(44),w=t(235);class f extends p.DOMView{constructor(){super(...arguments),this._offset_parent=null,this._viewport={}}get is_layout_root(){return this.is_root||!(this.parent instanceof f)}get base_font_size(){const t=getComputedStyle(this.el).fontSize,i=(0,u.parse_css_font_size)(t);if(null!=i){const{value:t,unit:e}=i;if(\"px\"==e)return t}return null}initialize(){super.initialize(),this.el.style.position=this.is_layout_root?\"relative\":\"absolute\",this._child_views=new Map}async lazy_initialize(){await super.lazy_initialize(),await this.build_child_views()}remove(){for(const t of this.child_views)t.remove();this._child_views.clear(),super.remove()}connect_signals(){super.connect_signals(),this.is_layout_root&&(this._on_resize=()=>this.resize_layout(),window.addEventListener(\"resize\",this._on_resize),this._parent_observer=setInterval((()=>{const t=this.el.offsetParent;this._offset_parent!=t&&(this._offset_parent=t,null!=t&&(this.compute_viewport(),this.invalidate_layout()))}),250));const t=this.model.properties;this.on_change([t.width,t.height,t.min_width,t.min_height,t.max_width,t.max_height,t.margin,t.width_policy,t.height_policy,t.sizing_mode,t.aspect_ratio,t.visible],(()=>this.invalidate_layout())),this.on_change([t.background,t.css_classes],(()=>this.invalidate_render()))}disconnect_signals(){null!=this._parent_observer&&clearTimeout(this._parent_observer),null!=this._on_resize&&window.removeEventListener(\"resize\",this._on_resize),super.disconnect_signals()}css_classes(){return super.css_classes().concat(this.model.css_classes)}get child_views(){return this.child_models.map((t=>this._child_views.get(t)))}async build_child_views(){await(0,d.build_views)(this._child_views,this.child_models,{parent:this})}render(){super.render(),(0,a.empty)(this.el);const{background:t}=this.model;this.el.style.backgroundColor=null!=t?(0,c.color2css)(t):\"\",(0,a.classes)(this.el).clear().add(...this.css_classes());for(const t of this.child_views)this.el.appendChild(t.el),t.render()}update_layout(){for(const t of this.child_views)t.update_layout();this._update_layout()}update_position(){this.el.style.display=this.model.visible?\"block\":\"none\";const t=this.is_layout_root?this.layout.sizing.margin:void 0;(0,a.position)(this.el,this.layout.bbox,t);for(const t of this.child_views)t.update_position()}after_layout(){for(const t of this.child_views)t.after_layout();this._has_finished=!0}compute_viewport(){this._viewport=this._viewport_size()}renderTo(t){t.appendChild(this.el),this._offset_parent=this.el.offsetParent,this.compute_viewport(),this.build(),this.notify_finished()}build(){if(!this.is_layout_root)throw new Error(`${this.toString()} is not a root layout`);return this.render(),this.update_layout(),this.compute_layout(),this}async rebuild(){await this.build_child_views(),this.invalidate_render()}compute_layout(){const t=Date.now();this.layout.compute(this._viewport),this.update_position(),this.after_layout(),r.logger.debug(`layout computed in ${Date.now()-t} ms`)}resize_layout(){this.root.compute_viewport(),this.root.compute_layout()}invalidate_layout(){this.root.update_layout(),this.root.compute_layout()}invalidate_render(){this.render(),this.invalidate_layout()}has_finished(){if(!super.has_finished())return!1;for(const t of this.child_views)if(!t.has_finished())return!1;return!0}_width_policy(){return null!=this.model.width?\"fixed\":\"fit\"}_height_policy(){return null!=this.model.height?\"fixed\":\"fit\"}box_sizing(){let{width_policy:t,height_policy:i,aspect_ratio:e}=this.model;\"auto\"==t&&(t=this._width_policy()),\"auto\"==i&&(i=this._height_policy());const{sizing_mode:s}=this.model;if(null!=s)if(\"fixed\"==s)t=i=\"fixed\";else if(\"stretch_both\"==s)t=i=\"max\";else if(\"stretch_width\"==s)t=\"max\";else if(\"stretch_height\"==s)i=\"max\";else switch(null==e&&(e=\"auto\"),s){case\"scale_width\":t=\"max\",i=\"min\";break;case\"scale_height\":t=\"min\",i=\"max\";break;case\"scale_both\":t=\"max\",i=\"max\"}const o={width_policy:t,height_policy:i},{min_width:l,min_height:n}=this.model;null!=l&&(o.min_width=l),null!=n&&(o.min_height=n);const{width:h,height:a}=this.model;null!=h&&(o.width=h),null!=a&&(o.height=a);const{max_width:r,max_height:c}=this.model;null!=r&&(o.max_width=r),null!=c&&(o.max_height=c),\"auto\"==e&&null!=h&&null!=a?o.aspect=h/a:(0,_.isNumber)(e)&&(o.aspect=e);const{margin:u}=this.model;if(null!=u)if((0,_.isNumber)(u))o.margin={top:u,right:u,bottom:u,left:u};else if(2==u.length){const[t,i]=u;o.margin={top:t,right:i,bottom:t,left:i}}else{const[t,i,e,s]=u;o.margin={top:t,right:i,bottom:e,left:s}}o.visible=this.model.visible;const{align:d}=this.model;return(0,_.isArray)(d)?[o.halign,o.valign]=d:o.halign=o.valign=d,o}_viewport_size(){return(0,a.undisplayed)(this.el,(()=>{let t=this.el;for(;t=t.parentElement;){if(t.classList.contains(g.root))continue;if(t==document.body){const{margin:{left:t,right:i,top:e,bottom:s}}=(0,a.extents)(document.body);return{width:Math.ceil(document.documentElement.clientWidth-t-i),height:Math.ceil(document.documentElement.clientHeight-e-s)}}const{padding:{left:i,right:e,top:s,bottom:o}}=(0,a.extents)(t),{width:l,height:n}=t.getBoundingClientRect(),h=Math.ceil(l-i-e),r=Math.ceil(n-s-o);if(h>0||r>0)return{width:h>0?h:void 0,height:r>0?r:void 0}}return{}}))}export(t,i=!0){const e=\"png\"==t?\"canvas\":\"svg\",s=new w.CanvasLayer(e,i),{width:o,height:l}=this.layout.bbox;s.resize(o,l);for(const e of this.child_views){const o=e.export(t,i),{x:l,y:n}=e.layout.bbox;s.ctx.drawImage(o.canvas,l,n)}return s}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.layout.bbox.box,children:this.child_views.map((t=>t.serializable_state()))})}}e.LayoutDOMView=f,f.__name__=\"LayoutDOMView\";class y extends n.Model{constructor(t){super(t)}}e.LayoutDOM=y,l=y,y.__name__=\"LayoutDOM\",l.define((t=>{const{Boolean:i,Number:e,String:s,Auto:o,Color:l,Array:n,Tuple:a,Or:r,Null:_,Nullable:c}=t,u=a(e,e),d=a(e,e,e,e);return{width:[c(e),null],height:[c(e),null],min_width:[c(e),null],min_height:[c(e),null],max_width:[c(e),null],max_height:[c(e),null],margin:[c(r(e,u,d)),[0,0,0,0]],width_policy:[r(m.SizingPolicy,o),\"auto\"],height_policy:[r(m.SizingPolicy,o),\"auto\"],aspect_ratio:[r(e,o,_),null],sizing_mode:[c(h.SizingMode),null],visible:[i,!0],disabled:[i,!1],align:[r(h.Align,a(h.Align,h.Align)),\"start\"],background:[c(l),null],css_classes:[n(s),[]]}}))},\n", " function _(o,s,t,i,e){var n;i();const a=o(308),l=o(209);class u extends a.BoxView{_update_layout(){const o=this.child_views.map((o=>o.layout));this.layout=new l.Column(o),this.layout.rows=this.model.rows,this.layout.spacing=[this.model.spacing,0],this.layout.set_sizing(this.box_sizing())}}t.ColumnView=u,u.__name__=\"ColumnView\";class _ extends a.Box{constructor(o){super(o)}}t.Column=_,n=_,_.__name__=\"Column\",n.prototype.default_view=u,n.define((({Any:o})=>({rows:[o,\"auto\"]})))},\n", " function _(s,o,t,i,e){var n;i();const l=s(309),a=s(209);class r extends l.LayoutDOMView{connect_signals(){super.connect_signals();const{children:s,rows:o,cols:t,spacing:i}=this.model.properties;this.on_change([s,o,t,i],(()=>this.rebuild()))}get child_models(){return this.model.children.map((([s])=>s))}_update_layout(){this.layout=new a.Grid,this.layout.rows=this.model.rows,this.layout.cols=this.model.cols,this.layout.spacing=this.model.spacing;for(const[s,o,t,i,e]of this.model.children){const n=this._child_views.get(s);this.layout.items.push({layout:n.layout,row:o,col:t,row_span:i,col_span:e})}this.layout.set_sizing(this.box_sizing())}}t.GridBoxView=r,r.__name__=\"GridBoxView\";class c extends l.LayoutDOM{constructor(s){super(s)}}t.GridBox=c,n=c,c.__name__=\"GridBox\",n.prototype.default_view=r,n.define((({Any:s,Int:o,Number:t,Tuple:i,Array:e,Ref:n,Or:a,Opt:r})=>({children:[e(i(n(l.LayoutDOM),o,o,r(o),r(o))),[]],rows:[s,\"auto\"],cols:[s,\"auto\"],spacing:[a(t,i(t,t)),0]})))},\n", " function _(t,e,o,s,n){s();const _=t(309),i=t(207);class a extends _.LayoutDOMView{get child_models(){return[]}_update_layout(){this.layout=new i.ContentBox(this.el),this.layout.set_sizing(this.box_sizing())}}o.HTMLBoxView=a,a.__name__=\"HTMLBoxView\";class u extends _.LayoutDOM{constructor(t){super(t)}}o.HTMLBox=u,u.__name__=\"HTMLBox\"},\n", " function _(e,n,l,a,o){var t;a();const s=e(53),c=e(309);class d extends s.Model{constructor(e){super(e)}}l.Panel=d,t=d,d.__name__=\"Panel\",t.define((({Boolean:e,String:n,Ref:l})=>({title:[n,\"\"],child:[l(c.LayoutDOM)],closable:[e,!1],disabled:[e,!1]})))},\n", " function _(o,s,t,i,e){var a;i();const n=o(308),l=o(209);class _ extends n.BoxView{_update_layout(){const o=this.child_views.map((o=>o.layout));this.layout=new l.Row(o),this.layout.cols=this.model.cols,this.layout.spacing=[0,this.model.spacing],this.layout.set_sizing(this.box_sizing())}}t.RowView=_,_.__name__=\"RowView\";class c extends n.Box{constructor(o){super(o)}}t.Row=c,a=c,c.__name__=\"Row\",a.prototype.default_view=_,a.define((({Any:o})=>({cols:[o,\"auto\"]})))},\n", " function _(e,t,a,s,_){var o;s();const i=e(309),n=e(207);class u extends i.LayoutDOMView{get child_models(){return[]}_update_layout(){this.layout=new n.LayoutItem,this.layout.set_sizing(this.box_sizing())}}a.SpacerView=u,u.__name__=\"SpacerView\";class c extends i.LayoutDOM{constructor(e){super(e)}}a.Spacer=c,o=c,c.__name__=\"Spacer\",o.prototype.default_view=u},\n", " function _(e,t,s,i,l){i();const h=e(1);var a;const o=e(207),d=e(43),r=e(9),c=e(10),n=e(20),_=e(309),p=e(313),b=(0,h.__importStar)(e(317)),m=b,u=(0,h.__importStar)(e(318)),g=u,v=(0,h.__importStar)(e(229)),w=v;class f extends _.LayoutDOMView{constructor(){super(...arguments),this._scroll_index=0}connect_signals(){super.connect_signals(),this.connect(this.model.properties.tabs.change,(()=>this.rebuild())),this.connect(this.model.properties.active.change,(()=>this.on_active_change()))}styles(){return[...super.styles(),u.default,v.default,b.default]}get child_models(){return this.model.tabs.map((e=>e.child))}_update_layout(){const e=this.model.tabs_location,t=\"above\"==e||\"below\"==e,{scroll_el:s,headers_el:i}=this;this.header=new class extends o.ContentBox{_measure(e){const l=(0,d.size)(s),h=(0,d.children)(i).slice(0,3).map((e=>(0,d.size)(e))),{width:a,height:o}=super._measure(e);if(t){const t=l.width+(0,r.sum)(h.map((e=>e.width)));return{width:e.width!=1/0?e.width:t,height:o}}{const t=l.height+(0,r.sum)(h.map((e=>e.height)));return{width:a,height:e.height!=1/0?e.height:t}}}}(this.header_el),t?this.header.set_sizing({width_policy:\"fit\",height_policy:\"fixed\"}):this.header.set_sizing({width_policy:\"fixed\",height_policy:\"fit\"});let l=1,h=1;switch(e){case\"above\":l-=1;break;case\"below\":l+=1;break;case\"left\":h-=1;break;case\"right\":h+=1}const a={layout:this.header,row:l,col:h},c=this.child_views.map((e=>({layout:e.layout,row:1,col:1})));this.layout=new o.Grid([a,...c]),this.layout.set_sizing(this.box_sizing())}update_position(){super.update_position(),this.header_el.style.position=\"absolute\",(0,d.position)(this.header_el,this.header.bbox);const e=this.model.tabs_location,t=\"above\"==e||\"below\"==e,s=(0,d.size)(this.scroll_el),i=(0,d.scroll_size)(this.headers_el);if(t){const{width:e}=this.header.bbox;i.width>e?(this.wrapper_el.style.maxWidth=e-s.width+\"px\",(0,d.display)(this.scroll_el),this.do_scroll(this.model.active)):(this.wrapper_el.style.maxWidth=\"\",(0,d.undisplay)(this.scroll_el))}else{const{height:e}=this.header.bbox;i.height>e?(this.wrapper_el.style.maxHeight=e-s.height+\"px\",(0,d.display)(this.scroll_el),this.do_scroll(this.model.active)):(this.wrapper_el.style.maxHeight=\"\",(0,d.undisplay)(this.scroll_el))}const{child_views:l}=this;for(const e of l)(0,d.hide)(e.el);const h=l[this.model.active];null!=h&&(0,d.show)(h.el)}render(){super.render();const{active:e}=this.model,t=this.model.tabs.map(((t,s)=>{const i=(0,d.div)({class:[m.tab,s==e?m.active:null]},t.title);if(i.addEventListener(\"click\",(e=>{this.model.disabled||e.target==e.currentTarget&&this.change_active(s)})),t.closable){const e=(0,d.div)({class:m.close});e.addEventListener(\"click\",(e=>{if(e.target==e.currentTarget){this.model.tabs=(0,r.remove_at)(this.model.tabs,s);const e=this.model.tabs.length;this.model.active>e-1&&(this.model.active=e-1)}})),i.appendChild(e)}return(this.model.disabled||t.disabled)&&i.classList.add(m.disabled),i}));this.headers_el=(0,d.div)({class:[m.headers]},t),this.wrapper_el=(0,d.div)({class:m.headers_wrapper},this.headers_el),this.left_el=(0,d.div)({class:[g.btn,g.btn_default],disabled:\"\"},(0,d.div)({class:[w.caret,m.left]})),this.right_el=(0,d.div)({class:[g.btn,g.btn_default]},(0,d.div)({class:[w.caret,m.right]})),this.left_el.addEventListener(\"click\",(()=>this.do_scroll(\"left\"))),this.right_el.addEventListener(\"click\",(()=>this.do_scroll(\"right\"))),this.scroll_el=(0,d.div)({class:g.btn_group},this.left_el,this.right_el);const s=this.model.tabs_location;this.header_el=(0,d.div)({class:[m.tabs_header,m[s]]},this.scroll_el,this.wrapper_el),this.el.appendChild(this.header_el)}do_scroll(e){const t=this.model.tabs.length;\"left\"==e?this._scroll_index-=1:\"right\"==e?this._scroll_index+=1:this._scroll_index=e,this._scroll_index=(0,c.clamp)(this._scroll_index,0,t-1),0==this._scroll_index?this.left_el.setAttribute(\"disabled\",\"\"):this.left_el.removeAttribute(\"disabled\"),this._scroll_index==t-1?this.right_el.setAttribute(\"disabled\",\"\"):this.right_el.removeAttribute(\"disabled\");const s=(0,d.children)(this.headers_el).slice(0,this._scroll_index).map((e=>e.getBoundingClientRect())),i=this.model.tabs_location;if(\"above\"==i||\"below\"==i){const e=-(0,r.sum)(s.map((e=>e.width)));this.headers_el.style.left=`${e}px`}else{const e=-(0,r.sum)(s.map((e=>e.height)));this.headers_el.style.top=`${e}px`}}change_active(e){e!=this.model.active&&(this.model.active=e)}on_active_change(){const e=this.model.active,t=(0,d.children)(this.headers_el);for(const e of t)e.classList.remove(m.active);t[e].classList.add(m.active);const{child_views:s}=this;for(const e of s)(0,d.hide)(e.el);(0,d.show)(s[e].el)}}s.TabsView=f,f.__name__=\"TabsView\";class x extends _.LayoutDOM{constructor(e){super(e)}}s.Tabs=x,a=x,x.__name__=\"Tabs\",a.prototype.default_view=f,a.define((({Int:e,Array:t,Ref:s})=>({tabs:[t(s(p.Panel)),[]],tabs_location:[n.Location,\"above\"],active:[e,0]})))},\n", " function _(e,r,b,o,t){o(),b.root=\"bk-root\",b.tabs_header=\"bk-tabs-header\",b.btn_group=\"bk-btn-group\",b.btn=\"bk-btn\",b.headers_wrapper=\"bk-headers-wrapper\",b.above=\"bk-above\",b.right=\"bk-right\",b.below=\"bk-below\",b.left=\"bk-left\",b.headers=\"bk-headers\",b.tab=\"bk-tab\",b.active=\"bk-active\",b.close=\"bk-close\",b.disabled=\"bk-disabled\",b.default='.bk-root .bk-tabs-header{display:flex;flex-wrap:nowrap;align-items:center;overflow:hidden;user-select:none;-ms-user-select:none;-moz-user-select:none;-webkit-user-select:none;}.bk-root .bk-tabs-header .bk-btn-group{height:auto;margin-right:5px;}.bk-root .bk-tabs-header .bk-btn-group > .bk-btn{flex-grow:0;height:auto;padding:4px 4px;}.bk-root .bk-tabs-header .bk-headers-wrapper{flex-grow:1;overflow:hidden;color:#666666;}.bk-root .bk-tabs-header.bk-above .bk-headers-wrapper{border-bottom:1px solid #e6e6e6;}.bk-root .bk-tabs-header.bk-right .bk-headers-wrapper{border-left:1px solid #e6e6e6;}.bk-root .bk-tabs-header.bk-below .bk-headers-wrapper{border-top:1px solid #e6e6e6;}.bk-root .bk-tabs-header.bk-left .bk-headers-wrapper{border-right:1px solid #e6e6e6;}.bk-root .bk-tabs-header.bk-above,.bk-root .bk-tabs-header.bk-below{flex-direction:row;}.bk-root .bk-tabs-header.bk-above .bk-headers,.bk-root .bk-tabs-header.bk-below .bk-headers{flex-direction:row;}.bk-root .bk-tabs-header.bk-left,.bk-root .bk-tabs-header.bk-right{flex-direction:column;}.bk-root .bk-tabs-header.bk-left .bk-headers,.bk-root .bk-tabs-header.bk-right .bk-headers{flex-direction:column;}.bk-root .bk-tabs-header .bk-headers{position:relative;display:flex;flex-wrap:nowrap;align-items:center;}.bk-root .bk-tabs-header .bk-tab{padding:4px 8px;border:solid transparent;white-space:nowrap;cursor:pointer;}.bk-root .bk-tabs-header .bk-tab:hover{background-color:#f2f2f2;}.bk-root .bk-tabs-header .bk-tab.bk-active{color:#4d4d4d;background-color:white;border-color:#e6e6e6;}.bk-root .bk-tabs-header .bk-tab .bk-close{margin-left:10px;}.bk-root .bk-tabs-header .bk-tab.bk-disabled{cursor:not-allowed;pointer-events:none;opacity:0.65;}.bk-root .bk-tabs-header.bk-above .bk-tab{border-width:3px 1px 0px 1px;border-radius:4px 4px 0 0;}.bk-root .bk-tabs-header.bk-right .bk-tab{border-width:1px 3px 1px 0px;border-radius:0 4px 4px 0;}.bk-root .bk-tabs-header.bk-below .bk-tab{border-width:0px 1px 3px 1px;border-radius:0 0 4px 4px;}.bk-root .bk-tabs-header.bk-left .bk-tab{border-width:1px 0px 1px 3px;border-radius:4px 0 0 4px;}.bk-root .bk-close{display:inline-block;width:10px;height:10px;vertical-align:middle;background-image:url(\\'data:image/svg+xml;utf8, \\');}.bk-root .bk-close:hover{background-image:url(\\'data:image/svg+xml;utf8, \\');}'},\n", " function _(o,b,r,t,e){t(),r.root=\"bk-root\",r.btn=\"bk-btn\",r.active=\"bk-active\",r.btn_default=\"bk-btn-default\",r.btn_primary=\"bk-btn-primary\",r.btn_success=\"bk-btn-success\",r.btn_warning=\"bk-btn-warning\",r.btn_danger=\"bk-btn-danger\",r.btn_light=\"bk-btn-light\",r.btn_group=\"bk-btn-group\",r.vertical=\"bk-vertical\",r.horizontal=\"bk-horizontal\",r.dropdown_toggle=\"bk-dropdown-toggle\",r.default=\".bk-root .bk-btn{height:100%;display:inline-block;text-align:center;vertical-align:middle;white-space:nowrap;cursor:pointer;padding:6px 12px;font-size:12px;border:1px solid transparent;border-radius:4px;outline:0;user-select:none;-ms-user-select:none;-moz-user-select:none;-webkit-user-select:none;}.bk-root .bk-btn:hover,.bk-root .bk-btn:focus{text-decoration:none;}.bk-root .bk-btn:active,.bk-root .bk-btn.bk-active{background-image:none;box-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);}.bk-root .bk-btn[disabled]{cursor:not-allowed;pointer-events:none;opacity:0.65;box-shadow:none;}.bk-root .bk-btn-default{color:#333;background-color:#fff;border-color:#ccc;}.bk-root .bk-btn-default:hover{background-color:#f5f5f5;border-color:#b8b8b8;}.bk-root .bk-btn-default.bk-active{background-color:#ebebeb;border-color:#adadad;}.bk-root .bk-btn-default[disabled],.bk-root .bk-btn-default[disabled]:hover,.bk-root .bk-btn-default[disabled]:focus,.bk-root .bk-btn-default[disabled]:active,.bk-root .bk-btn-default[disabled].bk-active{background-color:#e6e6e6;border-color:#ccc;}.bk-root .bk-btn-primary{color:#fff;background-color:#428bca;border-color:#357ebd;}.bk-root .bk-btn-primary:hover{background-color:#3681c1;border-color:#2c699e;}.bk-root .bk-btn-primary.bk-active{background-color:#3276b1;border-color:#285e8e;}.bk-root .bk-btn-primary[disabled],.bk-root .bk-btn-primary[disabled]:hover,.bk-root .bk-btn-primary[disabled]:focus,.bk-root .bk-btn-primary[disabled]:active,.bk-root .bk-btn-primary[disabled].bk-active{background-color:#506f89;border-color:#357ebd;}.bk-root .bk-btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c;}.bk-root .bk-btn-success:hover{background-color:#4eb24e;border-color:#409240;}.bk-root .bk-btn-success.bk-active{background-color:#47a447;border-color:#398439;}.bk-root .bk-btn-success[disabled],.bk-root .bk-btn-success[disabled]:hover,.bk-root .bk-btn-success[disabled]:focus,.bk-root .bk-btn-success[disabled]:active,.bk-root .bk-btn-success[disabled].bk-active{background-color:#667b66;border-color:#4cae4c;}.bk-root .bk-btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236;}.bk-root .bk-btn-warning:hover{background-color:#eea43b;border-color:#e89014;}.bk-root .bk-btn-warning.bk-active{background-color:#ed9c28;border-color:#d58512;}.bk-root .bk-btn-warning[disabled],.bk-root .bk-btn-warning[disabled]:hover,.bk-root .bk-btn-warning[disabled]:focus,.bk-root .bk-btn-warning[disabled]:active,.bk-root .bk-btn-warning[disabled].bk-active{background-color:#c89143;border-color:#eea236;}.bk-root .bk-btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a;}.bk-root .bk-btn-danger:hover{background-color:#d5433e;border-color:#bd2d29;}.bk-root .bk-btn-danger.bk-active{background-color:#d2322d;border-color:#ac2925;}.bk-root .bk-btn-danger[disabled],.bk-root .bk-btn-danger[disabled]:hover,.bk-root .bk-btn-danger[disabled]:focus,.bk-root .bk-btn-danger[disabled]:active,.bk-root .bk-btn-danger[disabled].bk-active{background-color:#a55350;border-color:#d43f3a;}.bk-root .bk-btn-light{color:#333;background-color:#fff;border-color:#ccc;border-color:transparent;}.bk-root .bk-btn-light:hover{background-color:#f5f5f5;border-color:#b8b8b8;}.bk-root .bk-btn-light.bk-active{background-color:#ebebeb;border-color:#adadad;}.bk-root .bk-btn-light[disabled],.bk-root .bk-btn-light[disabled]:hover,.bk-root .bk-btn-light[disabled]:focus,.bk-root .bk-btn-light[disabled]:active,.bk-root .bk-btn-light[disabled].bk-active{background-color:#e6e6e6;border-color:#ccc;}.bk-root .bk-btn-group{height:100%;display:flex;flex-wrap:nowrap;align-items:center;}.bk-root .bk-btn-group:not(.bk-vertical),.bk-root .bk-btn-group.bk-horizontal{flex-direction:row;}.bk-root .bk-btn-group.bk-vertical{flex-direction:column;}.bk-root .bk-btn-group > .bk-btn{flex-grow:1;}.bk-root .bk-btn-group:not(.bk-vertical) > .bk-btn + .bk-btn{margin-left:-1px;}.bk-root .bk-btn-group.bk-vertical > .bk-btn + .bk-btn{margin-top:-1px;}.bk-root .bk-btn-group:not(.bk-vertical) > .bk-btn:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0;}.bk-root .bk-btn-group.bk-vertical > .bk-btn:first-child:not(:last-child){border-bottom-left-radius:0;border-bottom-right-radius:0;}.bk-root .bk-btn-group:not(.bk-vertical) > .bk-btn:not(:first-child):last-child{border-bottom-left-radius:0;border-top-left-radius:0;}.bk-root .bk-btn-group.bk-vertical > .bk-btn:not(:first-child):last-child{border-top-left-radius:0;border-top-right-radius:0;}.bk-root .bk-btn-group > .bk-btn:not(:first-child):not(:last-child){border-radius:0;}.bk-root .bk-btn-group.bk-vertical > .bk-btn{width:100%;}.bk-root .bk-btn-group .bk-dropdown-toggle{flex:0 0 0;padding:6px 6px;}\"},\n", " function _(e,t,o,n,_){var i;n();const s=e(310);class d extends s.ColumnView{}o.WidgetBoxView=d,d.__name__=\"WidgetBoxView\";class a extends s.Column{constructor(e){super(e)}}o.WidgetBox=a,i=a,a.__name__=\"WidgetBox\",i.prototype.default_view=d},\n", " function _(t,a,i,e,M){e();var T=t(135);M(\"MathText\",T.MathText),M(\"Ascii\",T.Ascii),M(\"MathML\",T.MathML),M(\"TeX\",T.TeX),M(\"PlainText\",t(139).PlainText)},\n", " function _(r,o,t,e,n){e(),n(\"CustomJSTransform\",r(322).CustomJSTransform),n(\"Dodge\",r(323).Dodge),n(\"Interpolator\",r(325).Interpolator),n(\"Jitter\",r(326).Jitter),n(\"LinearInterpolator\",r(327).LinearInterpolator),n(\"StepInterpolator\",r(328).StepInterpolator),n(\"Transform\",r(56).Transform)},\n", " function _(r,t,s,n,e){var a;n();const u=r(56),o=r(13),m=r(34);class _ extends u.Transform{constructor(r){super(r)}get names(){return(0,o.keys)(this.args)}get values(){return(0,o.values)(this.args)}_make_transform(r,t){return new Function(...this.names,r,(0,m.use_strict)(t))}get scalar_transform(){return this._make_transform(\"x\",this.func)}get vector_transform(){return this._make_transform(\"xs\",this.v_func)}compute(r){return this.scalar_transform(...this.values,r)}v_compute(r){return this.vector_transform(...this.values,r)}}s.CustomJSTransform=_,a=_,_.__name__=\"CustomJSTransform\",a.define((({Unknown:r,String:t,Dict:s})=>({args:[s(r),{}],func:[t,\"\"],v_func:[t,\"\"]})))},\n", " function _(e,n,r,o,s){var t;o();const u=e(324);class a extends u.RangeTransform{constructor(e){super(e)}_compute(e){return e+this.value}}r.Dodge=a,t=a,a.__name__=\"Dodge\",t.define((({Number:e})=>({value:[e,0]})))},\n", " function _(e,n,t,r,a){var s;r();const c=e(56),o=e(57),i=e(67),u=e(24),h=e(8),l=e(11);class g extends c.Transform{constructor(e){super(e)}v_compute(e){let n;this.range instanceof i.FactorRange?n=this.range.v_synthetic(e):(0,h.isArrayableOf)(e,h.isNumber)?n=e:(0,l.unreachable)();const t=new((0,u.infer_type)(n))(n.length);for(let e=0;e({range:[n(e(o.Range)),null]})))},\n", " function _(t,e,r,n,s){var o;n();const i=t(56),a=t(70),h=t(24),l=t(9),d=t(8);class c extends i.Transform{constructor(t){super(t),this._sorted_dirty=!0}connect_signals(){super.connect_signals(),this.connect(this.change,(()=>this._sorted_dirty=!0))}v_compute(t){const e=new((0,h.infer_type)(t))(t.length);for(let r=0;ro*(e[t]-e[r]))),this._x_sorted=new((0,h.infer_type)(e))(n),this._y_sorted=new((0,h.infer_type)(r))(n);for(let t=0;t({x:[o(r,s(e))],y:[o(r,s(e))],data:[i(n(a.ColumnarDataSource)),null],clip:[t,!0]})))},\n", " function _(t,s,e,i,r){i();const n=t(1);var o;const a=t(324),u=t(67),h=t(20),c=t(8),m=t(12),f=(0,n.__importStar)(t(10)),_=t(11);class p extends a.RangeTransform{constructor(t){super(t)}v_compute(t){var s;let e;this.range instanceof u.FactorRange?e=this.range.v_synthetic(t):(0,c.isArrayableOf)(t,c.isNumber)?e=t:(0,_.unreachable)();const i=e.length;(null===(s=this.previous_offsets)||void 0===s?void 0:s.length)!=i&&(this.previous_offsets=new Array(i),this.previous_offsets=(0,m.map)(this.previous_offsets,(()=>this._compute())));const r=this.previous_offsets;return(0,m.map)(e,((t,s)=>r[s]+t))}_compute(){switch(this.distribution){case\"uniform\":return this.mean+(f.random()-.5)*this.width;case\"normal\":return f.rnorm(this.mean,this.width)}}}e.Jitter=p,o=p,p.__name__=\"Jitter\",o.define((({Number:t})=>({mean:[t,0],width:[t,1],distribution:[h.Distribution,\"uniform\"]})))},\n", " function _(t,s,_,r,e){r();const i=t(9),o=t(325);class n extends o.Interpolator{constructor(t){super(t)}compute(t){if(this.sort(!1),this.clip){if(tthis._x_sorted[this._x_sorted.length-1])return NaN}else{if(tthis._x_sorted[this._x_sorted.length-1])return this._y_sorted[this._y_sorted.length-1]}if(t==this._x_sorted[0])return this._y_sorted[0];const s=(0,i.find_last_index)(this._x_sorted,(s=>sthis._x_sorted[this._x_sorted.length-1])return NaN}else{if(tthis._x_sorted[this._x_sorted.length-1])return this._y_sorted[this._y_sorted.length-1]}let e;switch(this.mode){case\"after\":e=(0,d.find_last_index)(this._x_sorted,(e=>t>=e));break;case\"before\":e=(0,d.find_index)(this._x_sorted,(e=>t<=e));break;case\"center\":{const s=(0,d.map)(this._x_sorted,(e=>Math.abs(e-t))),r=(0,d.min)(s);e=(0,d.find_index)(s,(t=>r===t));break}default:throw new Error(`unknown mode: ${this.mode}`)}return-1!=e?this._y_sorted[e]:NaN}}s.StepInterpolator=h,_=h,h.__name__=\"StepInterpolator\",_.define((()=>({mode:[n.StepMode,\"after\"]})))},\n", " function _(p,o,t,a,n){a(),n(\"MapOptions\",p(330).MapOptions),n(\"GMapOptions\",p(330).GMapOptions),n(\"GMapPlot\",p(330).GMapPlot),n(\"Plot\",p(331).Plot)},\n", " function _(e,t,n,o,a){var s,p,_;o();const i=e(331),r=e(53),l=e(58),c=e(336);a(\"GMapPlotView\",c.GMapPlotView);class d extends r.Model{constructor(e){super(e)}}n.MapOptions=d,s=d,d.__name__=\"MapOptions\",s.define((({Int:e,Number:t})=>({lat:[t],lng:[t],zoom:[e,12]})));class u extends d{constructor(e){super(e)}}n.GMapOptions=u,p=u,u.__name__=\"GMapOptions\",p.define((({Boolean:e,Int:t,String:n})=>({map_type:[n,\"roadmap\"],scale_control:[e,!1],styles:[n],tilt:[t,45]})));class M extends i.Plot{constructor(e){super(e),this.use_map=!0}}n.GMapPlot=M,_=M,M.__name__=\"GMapPlot\",_.prototype.default_view=c.GMapPlotView,_.define((({String:e,Ref:t})=>({map_options:[t(u)],api_key:[e],api_version:[e,\"3.43\"]}))),_.override({x_range:()=>new l.Range1d,y_range:()=>new l.Range1d})},\n", " function _(e,t,r,n,i){n();const o=e(1);var a;const s=(0,o.__importStar)(e(48)),l=(0,o.__importStar)(e(18)),_=e(15),c=e(20),h=e(9),d=e(13),u=e(8),g=e(309),p=e(128),f=e(306),b=e(40),w=e(118),y=e(59),m=e(221),x=e(57),v=e(55),A=e(75),S=e(41),R=e(176),D=e(175),L=e(63),P=e(332);i(\"PlotView\",P.PlotView);class k extends g.LayoutDOM{constructor(e){super(e),this.use_map=!1}_doc_attached(){super._doc_attached(),this._push_changes([[this.properties.inner_height,null,this.inner_height],[this.properties.inner_width,null,this.inner_width]])}initialize(){super.initialize(),this.reset=new _.Signal0(this,\"reset\");for(const e of(0,d.values)(this.extra_x_ranges).concat(this.x_range)){let t=e.plots;(0,u.isArray)(t)&&(t=t.concat(this),e.setv({plots:t},{silent:!0}))}for(const e of(0,d.values)(this.extra_y_ranges).concat(this.y_range)){let t=e.plots;(0,u.isArray)(t)&&(t=t.concat(this),e.setv({plots:t},{silent:!0}))}}add_layout(e,t=\"center\"){const r=this.properties[t].get_value();this.setv({[t]:[...r,e]})}remove_layout(e){const t=t=>{(0,h.remove_by)(t,(t=>t==e))};t(this.left),t(this.right),t(this.above),t(this.below),t(this.center)}get data_renderers(){return this.renderers.filter((e=>e instanceof R.DataRenderer))}add_renderers(...e){this.renderers=this.renderers.concat(e)}add_glyph(e,t=new A.ColumnDataSource,r={}){const n=new D.GlyphRenderer(Object.assign(Object.assign({},r),{data_source:t,glyph:e}));return this.add_renderers(n),n}add_tools(...e){this.toolbar.tools=this.toolbar.tools.concat(e)}get panels(){return[...this.side_panels,...this.center]}get side_panels(){const{above:e,below:t,left:r,right:n}=this;return(0,h.concat)([e,t,r,n])}}r.Plot=k,a=k,k.__name__=\"Plot\",a.prototype.default_view=P.PlotView,a.mixins([[\"outline_\",s.Line],[\"background_\",s.Fill],[\"border_\",s.Fill]]),a.define((({Boolean:e,Number:t,String:r,Array:n,Dict:i,Or:o,Ref:a,Null:s,Nullable:_})=>({toolbar:[a(m.Toolbar),()=>new m.Toolbar],toolbar_location:[_(c.Location),\"right\"],toolbar_sticky:[e,!0],plot_width:[l.Alias(\"width\")],plot_height:[l.Alias(\"height\")],frame_width:[_(t),null],frame_height:[_(t),null],title:[o(a(w.Title),r,s),\"\",{convert:e=>(0,u.isString)(e)?new w.Title({text:e}):e}],title_location:[_(c.Location),\"above\"],above:[n(o(a(b.Annotation),a(p.Axis))),[]],below:[n(o(a(b.Annotation),a(p.Axis))),[]],left:[n(o(a(b.Annotation),a(p.Axis))),[]],right:[n(o(a(b.Annotation),a(p.Axis))),[]],center:[n(o(a(b.Annotation),a(f.Grid))),[]],renderers:[n(a(S.Renderer)),[]],x_range:[a(x.Range),()=>new L.DataRange1d],y_range:[a(x.Range),()=>new L.DataRange1d],x_scale:[a(v.Scale),()=>new y.LinearScale],y_scale:[a(v.Scale),()=>new y.LinearScale],extra_x_ranges:[i(a(x.Range)),{}],extra_y_ranges:[i(a(x.Range)),{}],extra_x_scales:[i(a(v.Scale)),{}],extra_y_scales:[i(a(v.Scale)),{}],lod_factor:[t,10],lod_interval:[t,300],lod_threshold:[_(t),2e3],lod_timeout:[t,500],hidpi:[e,!0],output_backend:[c.OutputBackend,\"canvas\"],min_border:[_(t),5],min_border_top:[_(t),null],min_border_left:[_(t),null],min_border_bottom:[_(t),null],min_border_right:[_(t),null],inner_width:[t,0],inner_height:[t,0],outer_width:[t,0],outer_height:[t,0],match_aspect:[e,!1],aspect_scale:[t,1],reset_policy:[c.ResetPolicy,\"standard\"]}))),a.override({width:600,height:600,outline_line_color:\"#e5e5e5\",border_fill_color:\"#ffffff\",background_fill_color:\"#ffffff\"})},\n", " function _(e,t,i,s,a){s();const n=e(1),o=e(126),l=e(249),r=e(309),_=e(40),h=e(118),d=e(128),u=e(220),c=e(251),p=e(113),v=e(45),g=e(19),b=e(251),m=e(333),y=e(8),w=e(9),f=e(235),x=e(208),z=e(211),k=e(209),q=e(123),M=e(65),R=e(334),V=e(335),S=e(28);class O extends r.LayoutDOMView{constructor(){super(...arguments),this._outer_bbox=new M.BBox,this._inner_bbox=new M.BBox,this._needs_paint=!0,this._needs_layout=!1,this._invalidated_painters=new Set,this._invalidate_all=!0,this._needs_notify=!1}get canvas(){return this.canvas_view}get state(){return this._state_manager}set invalidate_dataranges(e){this._range_manager.invalidate_dataranges=e}renderer_view(e){const t=this.renderer_views.get(e);if(null==t)for(const[,t]of this.renderer_views){const i=t.renderer_view(e);if(null!=i)return i}return t}get is_paused(){return null!=this._is_paused&&0!==this._is_paused}get child_models(){return[]}pause(){null==this._is_paused?this._is_paused=1:this._is_paused+=1}unpause(e=!1){if(null==this._is_paused)throw new Error(\"wasn't paused\");this._is_paused-=1,0!=this._is_paused||e||this.request_paint(\"everything\")}notify_finished_after_paint(){this._needs_notify=!0}request_render(){this.request_paint(\"everything\")}request_paint(e){this.invalidate_painters(e),this.schedule_paint()}invalidate_painters(e){if(\"everything\"==e)this._invalidate_all=!0;else if((0,y.isArray)(e))for(const t of e)this._invalidated_painters.add(t);else this._invalidated_painters.add(e)}schedule_paint(){if(!this.is_paused){const e=this.throttled_paint();this._ready=this._ready.then((()=>e))}}request_layout(){this._needs_layout=!0,this.request_paint(\"everything\")}reset(){\"standard\"==this.model.reset_policy&&(this.state.clear(),this.reset_range(),this.reset_selection()),this.model.trigger_event(new c.Reset)}remove(){(0,p.remove_views)(this.renderer_views),(0,p.remove_views)(this.tool_views),this.canvas_view.remove(),super.remove()}render(){super.render(),this.el.appendChild(this.canvas_view.el),this.canvas_view.render()}initialize(){this.pause(),super.initialize(),this.lod_started=!1,this.visuals=new v.Visuals(this),this._initial_state={selection:new Map,dimensions:{width:0,height:0}},this.visibility_callbacks=[],this.renderer_views=new Map,this.tool_views=new Map,this.frame=new o.CartesianFrame(this.model.x_scale,this.model.y_scale,this.model.x_range,this.model.y_range,this.model.extra_x_ranges,this.model.extra_y_ranges,this.model.extra_x_scales,this.model.extra_y_scales),this._range_manager=new R.RangeManager(this),this._state_manager=new V.StateManager(this,this._initial_state),this.throttled_paint=(0,m.throttle)((()=>this.repaint()),1e3/60);const{title_location:e,title:t}=this.model;null!=e&&null!=t&&(this._title=t instanceof h.Title?t:new h.Title({text:t}));const{toolbar_location:i,toolbar:s}=this.model;null!=i&&null!=s&&(this._toolbar=new u.ToolbarPanel({toolbar:s}),s.toolbar_location=i)}async lazy_initialize(){await super.lazy_initialize();const{hidpi:e,output_backend:t}=this.model,i=new l.Canvas({hidpi:e,output_backend:t});this.canvas_view=await(0,p.build_view)(i,{parent:this}),this.canvas_view.plot_views=[this],await this.build_renderer_views(),await this.build_tool_views(),this._range_manager.update_dataranges(),this.unpause(!0),g.logger.debug(\"PlotView initialized\")}_width_policy(){return null==this.model.frame_width?super._width_policy():\"min\"}_height_policy(){return null==this.model.frame_height?super._height_policy():\"min\"}_update_layout(){var e,t,i,s,a;this.layout=new z.BorderLayout,this.layout.set_sizing(this.box_sizing());const n=(0,w.copy)(this.model.above),o=(0,w.copy)(this.model.below),l=(0,w.copy)(this.model.left),r=(0,w.copy)(this.model.right),d=e=>{switch(e){case\"above\":return n;case\"below\":return o;case\"left\":return l;case\"right\":return r}},{title_location:c,title:p}=this.model;null!=c&&null!=p&&d(c).push(this._title);const{toolbar_location:v,toolbar:g}=this.model;if(null!=v&&null!=g){const e=d(v);let t=!0;if(this.model.toolbar_sticky)for(let i=0;i{var i;const s=this.renderer_view(t);return s.panel=new q.Panel(e),null===(i=s.update_layout)||void 0===i||i.call(s),s.layout},m=(e,t)=>{const i=\"above\"==e||\"below\"==e,s=[];for(const a of t)if((0,y.isArray)(a)){const t=a.map((t=>{const s=b(e,t);if(t instanceof u.ToolbarPanel){const e=i?\"width_policy\":\"height_policy\";s.set_sizing(Object.assign(Object.assign({},s.sizing),{[e]:\"min\"}))}return s}));let n;i?(n=new k.Row(t),n.set_sizing({width_policy:\"max\",height_policy:\"min\"})):(n=new k.Column(t),n.set_sizing({width_policy:\"min\",height_policy:\"max\"})),n.absolute=!0,s.push(n)}else s.push(b(e,a));return s},f=null!==(e=this.model.min_border)&&void 0!==e?e:0;this.layout.min_border={left:null!==(t=this.model.min_border_left)&&void 0!==t?t:f,top:null!==(i=this.model.min_border_top)&&void 0!==i?i:f,right:null!==(s=this.model.min_border_right)&&void 0!==s?s:f,bottom:null!==(a=this.model.min_border_bottom)&&void 0!==a?a:f};const M=new x.NodeLayout,R=new x.VStack,V=new x.VStack,S=new x.HStack,O=new x.HStack;M.absolute=!0,R.absolute=!0,V.absolute=!0,S.absolute=!0,O.absolute=!0,M.children=this.model.center.filter((e=>e instanceof _.Annotation)).map((e=>{var t;const i=this.renderer_view(e);return null===(t=i.update_layout)||void 0===t||t.call(i),i.layout})).filter((e=>null!=e));const{frame_width:P,frame_height:j}=this.model;M.set_sizing(Object.assign(Object.assign({},null!=P?{width_policy:\"fixed\",width:P}:{width_policy:\"fit\"}),null!=j?{height_policy:\"fixed\",height:j}:{height_policy:\"fit\"})),M.on_resize((e=>this.frame.set_geometry(e))),R.children=(0,w.reversed)(m(\"above\",n)),V.children=m(\"below\",o),S.children=(0,w.reversed)(m(\"left\",l)),O.children=m(\"right\",r),R.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),V.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),S.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),O.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),this.layout.center_panel=M,this.layout.top_panel=R,this.layout.bottom_panel=V,this.layout.left_panel=S,this.layout.right_panel=O}get axis_views(){const e=[];for(const[,t]of this.renderer_views)t instanceof d.AxisView&&e.push(t);return e}set_toolbar_visibility(e){for(const t of this.visibility_callbacks)t(e)}update_range(e,t){this.pause(),this._range_manager.update(e,t),this.unpause()}reset_range(){this.update_range(null),this.trigger_ranges_update_event()}trigger_ranges_update_event(){const{x_range:e,y_range:t}=this.model;this.model.trigger_event(new b.RangesUpdate(e.start,e.end,t.start,t.end))}get_selection(){const e=new Map;for(const t of this.model.data_renderers){const{selected:i}=t.selection_manager.source;e.set(t,i)}return e}update_selection(e){for(const t of this.model.data_renderers){const i=t.selection_manager.source;if(null!=e){const s=e.get(t);null!=s&&i.selected.update(s,!0)}else i.selection_manager.clear()}}reset_selection(){this.update_selection(null)}_invalidate_layout(){(()=>{var e;for(const t of this.model.side_panels){const i=this.renderer_views.get(t);if(null===(e=i.layout)||void 0===e?void 0:e.has_size_changed())return this.invalidate_painters(i),!0}return!1})()&&this.root.compute_layout()}get_renderer_views(){return this.computed_renderers.map((e=>this.renderer_views.get(e)))}*_compute_renderers(){const{above:e,below:t,left:i,right:s,center:a,renderers:n}=this.model;yield*n,yield*e,yield*t,yield*i,yield*s,yield*a,null!=this._title&&(yield this._title),null!=this._toolbar&&(yield this._toolbar);for(const e of this.model.toolbar.tools)null!=e.overlay&&(yield e.overlay),yield*e.synthetic_renderers}async build_renderer_views(){this.computed_renderers=[...this._compute_renderers()],await(0,p.build_views)(this.renderer_views,this.computed_renderers,{parent:this})}async build_tool_views(){const e=this.model.toolbar.tools;(await(0,p.build_views)(this.tool_views,e,{parent:this})).map((e=>this.canvas_view.ui_event_bus.register_tool(e)))}connect_signals(){super.connect_signals();const{x_ranges:e,y_ranges:t}=this.frame;for(const[,t]of e)this.connect(t.change,(()=>{this._needs_layout=!0,this.request_paint(\"everything\")}));for(const[,e]of t)this.connect(e.change,(()=>{this._needs_layout=!0,this.request_paint(\"everything\")}));const{above:i,below:s,left:a,right:n,center:o,renderers:l}=this.model.properties;this.on_change([i,s,a,n,o,l],(async()=>await this.build_renderer_views())),this.connect(this.model.toolbar.properties.tools.change,(async()=>{await this.build_renderer_views(),await this.build_tool_views()})),this.connect(this.model.change,(()=>this.request_paint(\"everything\"))),this.connect(this.model.reset,(()=>this.reset()))}has_finished(){if(!super.has_finished())return!1;if(this.model.visible)for(const[,e]of this.renderer_views)if(!e.has_finished())return!1;return!0}after_layout(){var e;super.after_layout();for(const[,t]of this.renderer_views)t instanceof _.AnnotationView&&(null===(e=t.after_layout)||void 0===e||e.call(t));if(this._needs_layout=!1,this.model.setv({inner_width:Math.round(this.frame.bbox.width),inner_height:Math.round(this.frame.bbox.height),outer_width:Math.round(this.layout.bbox.width),outer_height:Math.round(this.layout.bbox.height)},{no_change:!0}),!1!==this.model.match_aspect&&(this.pause(),this._range_manager.update_dataranges(),this.unpause(!0)),!this._outer_bbox.equals(this.layout.bbox)){const{width:e,height:t}=this.layout.bbox;this.canvas_view.resize(e,t),this._outer_bbox=this.layout.bbox,this._invalidate_all=!0,this._needs_paint=!0}const{inner_bbox:t}=this.layout;this._inner_bbox.equals(t)||(this._inner_bbox=t,this._needs_paint=!0),this._needs_paint&&this.paint()}repaint(){this._needs_layout&&this._invalidate_layout(),this.paint()}paint(){this.is_paused||(this.model.visible&&(g.logger.trace(`${this.toString()}.paint()`),this._actual_paint()),this._needs_notify&&(this._needs_notify=!1,this.notify_finished()))}_actual_paint(){var e;const{document:t}=this.model;if(null!=t){const e=t.interactive_duration();e>=0&&e{t.interactive_duration()>this.model.lod_timeout&&t.interactive_stop(),this.request_paint(\"everything\")}),this.model.lod_timeout):t.interactive_stop()}this._range_manager.invalidate_dataranges&&(this._range_manager.update_dataranges(),this._invalidate_layout());let i=!1,s=!1;if(this._invalidate_all)i=!0,s=!0;else for(const e of this._invalidated_painters){const{level:t}=e.model;if(\"overlay\"!=t?i=!0:s=!0,i&&s)break}this._invalidated_painters.clear(),this._invalidate_all=!1;const a=[this.frame.bbox.left,this.frame.bbox.top,this.frame.bbox.width,this.frame.bbox.height],{primary:n,overlays:o}=this.canvas_view;i&&(n.prepare(),this.canvas_view.prepare_webgl(a),this._map_hook(n.ctx,a),this._paint_empty(n.ctx,a),this._paint_outline(n.ctx,a),this._paint_levels(n.ctx,\"image\",a,!0),this._paint_levels(n.ctx,\"underlay\",a,!0),this._paint_levels(n.ctx,\"glyph\",a,!0),this._paint_levels(n.ctx,\"guide\",a,!1),this._paint_levels(n.ctx,\"annotation\",a,!1),n.finish()),(s||S.settings.wireframe)&&(o.prepare(),this._paint_levels(o.ctx,\"overlay\",a,!1),S.settings.wireframe&&this._paint_layout(o.ctx,this.layout),o.finish()),null==this._initial_state.range&&(this._initial_state.range=null!==(e=this._range_manager.compute_initial())&&void 0!==e?e:void 0),this._needs_paint=!1}_paint_levels(e,t,i,s){for(const a of this.computed_renderers){if(a.level!=t)continue;const n=this.renderer_views.get(a);e.save(),(s||n.needs_clip)&&(e.beginPath(),e.rect(...i),e.clip()),n.render(),e.restore(),n.has_webgl&&n.needs_webgl_blit&&this.canvas_view.blit_webgl(e)}}_paint_layout(e,t){const{x:i,y:s,width:a,height:n}=t.bbox;e.strokeStyle=\"blue\",e.strokeRect(i,s,a,n);for(const a of t)e.save(),t.absolute||e.translate(i,s),this._paint_layout(e,a),e.restore()}_map_hook(e,t){}_paint_empty(e,t){const[i,s,a,n]=[0,0,this.layout.bbox.width,this.layout.bbox.height],[o,l,r,_]=t;this.visuals.border_fill.doit&&(this.visuals.border_fill.set_value(e),e.fillRect(i,s,a,n),e.clearRect(o,l,r,_)),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(e),e.fillRect(o,l,r,_))}_paint_outline(e,t){if(this.visuals.outline_line.doit){e.save(),this.visuals.outline_line.set_value(e);let[i,s,a,n]=t;i+a==this.layout.bbox.width&&(a-=1),s+n==this.layout.bbox.height&&(n-=1),e.strokeRect(i,s,a,n),e.restore()}}to_blob(){return this.canvas_view.to_blob()}export(e,t=!0){const i=\"png\"==e?\"canvas\":\"svg\",s=new f.CanvasLayer(i,t),{width:a,height:n}=this.layout.bbox;s.resize(a,n);const{canvas:o}=this.canvas_view.compose();return s.ctx.drawImage(o,0,0),s}serializable_state(){const e=super.serializable_state(),{children:t}=e,i=(0,n.__rest)(e,[\"children\"]),s=this.get_renderer_views().map((e=>e.serializable_state())).filter((e=>null!=e.bbox));return Object.assign(Object.assign({},i),{children:[...null!=t?t:[],...s]})}}i.PlotView=O,O.__name__=\"PlotView\"},\n", " function _(t,n,e,o,u){o(),e.throttle=function(t,n){let e=null,o=0,u=!1;return function(){return new Promise(((r,i)=>{const l=function(){o=Date.now(),e=null,u=!1;try{t(),r()}catch(t){i(t)}},a=Date.now(),c=n-(a-o);c<=0&&!u?(null!=e&&clearTimeout(e),u=!0,requestAnimationFrame(l)):e||u?r():e=setTimeout((()=>requestAnimationFrame(l)),c)}))}}},\n", " function _(t,n,e,a,s){a();const o=t(63),r=t(19);class l{constructor(t){this.parent=t,this.invalidate_dataranges=!0}get frame(){return this.parent.frame}update(t,n){const{x_ranges:e,y_ranges:a}=this.frame;if(null==t){for(const[,t]of e)t.reset();for(const[,t]of a)t.reset();this.update_dataranges()}else{const s=[];for(const[n,a]of e)s.push([a,t.xrs.get(n)]);for(const[n,e]of a)s.push([e,t.yrs.get(n)]);(null==n?void 0:n.scrolling)&&this._update_ranges_together(s),this._update_ranges_individually(s,n)}}reset(){this.update(null)}_update_dataranges(t){const n=new Map,e=new Map;let a=!1;for(const[,n]of t.x_ranges)n instanceof o.DataRange1d&&\"log\"==n.scale_hint&&(a=!0);for(const[,n]of t.y_ranges)n instanceof o.DataRange1d&&\"log\"==n.scale_hint&&(a=!0);for(const t of this.parent.model.data_renderers){const s=this.parent.renderer_view(t);if(null==s)continue;const o=s.glyph_view.bounds();if(null!=o&&n.set(t,o),a){const n=s.glyph_view.log_bounds();null!=n&&e.set(t,n)}}let s=!1,l=!1;const i=t.x_target.span,d=t.y_target.span;let u;!1!==this.parent.model.match_aspect&&0!=i&&0!=d&&(u=1/this.parent.model.aspect_scale*(i/d));for(const[,a]of t.x_ranges){if(a instanceof o.DataRange1d){const t=\"log\"==a.scale_hint?e:n;a.update(t,0,this.parent.model,u),a.follow&&(s=!0)}null!=a.bounds&&(l=!0)}for(const[,a]of t.y_ranges){if(a instanceof o.DataRange1d){const t=\"log\"==a.scale_hint?e:n;a.update(t,1,this.parent.model,u),a.follow&&(s=!0)}null!=a.bounds&&(l=!0)}if(s&&l){r.logger.warn(\"Follow enabled so bounds are unset.\");for(const[,n]of t.x_ranges)n.bounds=null;for(const[,n]of t.y_ranges)n.bounds=null}}update_dataranges(){this._update_dataranges(this.frame);for(const t of this.parent.model.renderers){const{coordinates:n}=t;null!=n&&this._update_dataranges(n)}null!=this.compute_initial()&&(this.invalidate_dataranges=!1)}compute_initial(){let t=!0;const{x_ranges:n,y_ranges:e}=this.frame,a=new Map,s=new Map;for(const[e,s]of n){const{start:n,end:o}=s;if(null==n||null==o||isNaN(n+o)){t=!1;break}a.set(e,{start:n,end:o})}if(t)for(const[n,a]of e){const{start:e,end:o}=a;if(null==e||null==o||isNaN(e+o)){t=!1;break}s.set(n,{start:e,end:o})}return t?{xrs:a,yrs:s}:(r.logger.warn(\"could not set initial ranges\"),null)}_update_ranges_together(t){let n=1;for(const[e,a]of t)n=Math.min(n,this._get_weight_to_constrain_interval(e,a));if(n<1)for(const[e,a]of t)a.start=n*a.start+(1-n)*e.start,a.end=n*a.end+(1-n)*e.end}_update_ranges_individually(t,n){const e=!!(null==n?void 0:n.panning),a=!!(null==n?void 0:n.scrolling);let s=!1;for(const[n,o]of t){if(!a){const t=this._get_weight_to_constrain_interval(n,o);t<1&&(o.start=t*o.start+(1-t)*n.start,o.end=t*o.end+(1-t)*n.end)}if(null!=n.bounds&&\"auto\"!=n.bounds){const[t,r]=n.bounds,l=Math.abs(o.end-o.start);n.is_reversed?(null!=t&&t>=o.end&&(s=!0,o.end=t,(e||a)&&(o.start=t+l)),null!=r&&r<=o.start&&(s=!0,o.start=r,(e||a)&&(o.end=r-l))):(null!=t&&t>=o.start&&(s=!0,o.start=t,(e||a)&&(o.end=t+l)),null!=r&&r<=o.end&&(s=!0,o.end=r,(e||a)&&(o.start=r-l)))}}if(!(a&&s&&(null==n?void 0:n.maintain_focus)))for(const[n,e]of t)n.have_updated_interactively=!0,n.start==e.start&&n.end==e.end||n.setv(e)}_get_weight_to_constrain_interval(t,n){const{min_interval:e}=t;let{max_interval:a}=t;if(null!=t.bounds&&\"auto\"!=t.bounds){const[n,e]=t.bounds;if(null!=n&&null!=e){const t=Math.abs(e-n);a=null!=a?Math.min(a,t):t}}let s=1;if(null!=e||null!=a){const o=Math.abs(t.end-t.start),r=Math.abs(n.end-n.start);null!=e&&e>0&&r0&&r>a&&(s=(a-o)/(r-o)),s=Math.max(0,Math.min(1,s))}return s}}e.RangeManager=l,l.__name__=\"RangeManager\"},\n", " function _(t,i,s,e,n){e();const h=t(15);class a{constructor(t,i){this.parent=t,this.initial_state=i,this.changed=new h.Signal0(this.parent,\"state_changed\"),this.history=[],this.index=-1}_do_state_change(t){const i=null!=this.history[t]?this.history[t].state:this.initial_state;return null!=i.range&&this.parent.update_range(i.range),null!=i.selection&&this.parent.update_selection(i.selection),i}push(t,i){const{history:s,index:e}=this,n=null!=s[e]?s[e].state:{},h=Object.assign(Object.assign(Object.assign({},this.initial_state),n),i);this.history=this.history.slice(0,this.index+1),this.history.push({type:t,state:h}),this.index=this.history.length-1,this.changed.emit()}clear(){this.history=[],this.index=-1,this.changed.emit()}undo(){if(this.can_undo){this.index-=1;const t=this._do_state_change(this.index);return this.changed.emit(),t}return null}redo(){if(this.can_redo){this.index+=1;const t=this._do_state_change(this.index);return this.changed.emit(),t}return null}get can_undo(){return this.index>=0}get can_redo(){return this.indexm.emit();const s=encodeURIComponent,o=document.createElement(\"script\");o.type=\"text/javascript\",o.src=`https://maps.googleapis.com/maps/api/js?v=${s(e)}&key=${s(t)}&callback=_bokeh_gmaps_callback`,document.body.appendChild(o)}(t,e)}m.connect((()=>this.request_paint(\"everything\")))}this.unpause()}remove(){(0,p.remove)(this.map_el),super.remove()}update_range(t,e){var s,o;if(null==t)this.map.setCenter({lat:this.initial_lat,lng:this.initial_lng}),this.map.setOptions({zoom:this.initial_zoom}),super.update_range(null,e);else if(null!=t.sdx||null!=t.sdy)this.map.panBy(null!==(s=t.sdx)&&void 0!==s?s:0,null!==(o=t.sdy)&&void 0!==o?o:0),super.update_range(t,e);else if(null!=t.factor){if(10!==this.zoom_count)return void(this.zoom_count+=1);this.zoom_count=0,this.pause(),super.update_range(t,e);const s=t.factor<0?-1:1,o=this.map.getZoom();if(null!=o){const t=o+s;if(t>=2){this.map.setZoom(t);const[e,s]=this._get_projected_bounds();s-e<0&&this.map.setZoom(o)}}this.unpause()}this._set_bokeh_ranges()}_build_map(){const{maps:t}=google;this.map_types={satellite:t.MapTypeId.SATELLITE,terrain:t.MapTypeId.TERRAIN,roadmap:t.MapTypeId.ROADMAP,hybrid:t.MapTypeId.HYBRID};const e=this.model.map_options,s={center:new t.LatLng(e.lat,e.lng),zoom:e.zoom,disableDefaultUI:!0,mapTypeId:this.map_types[e.map_type],scaleControl:e.scale_control,tilt:e.tilt};null!=e.styles&&(s.styles=JSON.parse(e.styles)),this.map_el=(0,p.div)({style:{position:\"absolute\"}}),this.canvas_view.add_underlay(this.map_el),this.map=new t.Map(this.map_el,s),t.event.addListener(this.map,\"idle\",(()=>this._set_bokeh_ranges())),t.event.addListener(this.map,\"bounds_changed\",(()=>this._set_bokeh_ranges())),t.event.addListenerOnce(this.map,\"tilesloaded\",(()=>this._render_finished())),this.connect(this.model.properties.map_options.change,(()=>this._update_options())),this.connect(this.model.map_options.properties.styles.change,(()=>this._update_styles())),this.connect(this.model.map_options.properties.lat.change,(()=>this._update_center(\"lat\"))),this.connect(this.model.map_options.properties.lng.change,(()=>this._update_center(\"lng\"))),this.connect(this.model.map_options.properties.zoom.change,(()=>this._update_zoom())),this.connect(this.model.map_options.properties.map_type.change,(()=>this._update_map_type())),this.connect(this.model.map_options.properties.scale_control.change,(()=>this._update_scale_control())),this.connect(this.model.map_options.properties.tilt.change,(()=>this._update_tilt()))}_render_finished(){this._tiles_loaded=!0,this.notify_finished()}has_finished(){return super.has_finished()&&!0===this._tiles_loaded}_get_latlon_bounds(){const t=this.map.getBounds(),e=t.getNorthEast(),s=t.getSouthWest();return[s.lng(),e.lng(),s.lat(),e.lat()]}_get_projected_bounds(){const[t,e,s,o]=this._get_latlon_bounds(),[i,a]=l.wgs84_mercator.compute(t,s),[n,p]=l.wgs84_mercator.compute(e,o);return[i,n,a,p]}_set_bokeh_ranges(){const[t,e,s,o]=this._get_projected_bounds();this.frame.x_range.setv({start:t,end:e}),this.frame.y_range.setv({start:s,end:o})}_update_center(t){var e;const s=null===(e=this.map.getCenter())||void 0===e?void 0:e.toJSON();null!=s&&(s[t]=this.model.map_options[t],this.map.setCenter(s),this._set_bokeh_ranges())}_update_map_type(){this.map.setOptions({mapTypeId:this.map_types[this.model.map_options.map_type]})}_update_scale_control(){this.map.setOptions({scaleControl:this.model.map_options.scale_control})}_update_tilt(){this.map.setOptions({tilt:this.model.map_options.tilt})}_update_options(){this._update_styles(),this._update_center(\"lat\"),this._update_center(\"lng\"),this._update_zoom(),this._update_map_type()}_update_styles(){this.map.setOptions({styles:JSON.parse(this.model.map_options.styles)})}_update_zoom(){this.map.setOptions({zoom:this.model.map_options.zoom}),this._set_bokeh_ranges()}_map_hook(t,e){if(null==this.map&&\"undefined\"!=typeof google&&null!=google.maps&&this._build_map(),null!=this.map_el){const[t,s,o,i]=e;this.map_el.style.top=`${s}px`,this.map_el.style.left=`${t}px`,this.map_el.style.width=`${o}px`,this.map_el.style.height=`${i}px`}}_paint_empty(t,e){const s=this.layout.bbox.width,o=this.layout.bbox.height,[i,a,n,p]=e;t.clearRect(0,0,s,o),t.beginPath(),t.moveTo(0,0),t.lineTo(0,o),t.lineTo(s,o),t.lineTo(s,0),t.lineTo(0,0),t.moveTo(i,a),t.lineTo(i+n,a),t.lineTo(i+n,a+p),t.lineTo(i,a+p),t.lineTo(i,a),t.closePath(),null!=this.model.border_fill_color&&(t.fillStyle=(0,_.color2css)(this.model.border_fill_color),t.fill())}}s.GMapPlotView=d,d.__name__=\"GMapPlotView\"},\n", " function _(t,_,n,o,r){o();(0,t(1).__exportStar)(t(132),n)},\n", " function _(e,r,d,n,R){n(),R(\"GlyphRenderer\",e(175).GlyphRenderer),R(\"GraphRenderer\",e(339).GraphRenderer),R(\"GuideRenderer\",e(129).GuideRenderer);var G=e(41);R(\"Renderer\",G.Renderer),R(\"RendererGroup\",G.RendererGroup)},\n", " function _(e,r,i,n,t){var o;n();const s=e(176),d=e(175),a=e(303),p=e(302),l=e(113),_=e(178),h=e(283),y=e(286);class c extends s.DataRendererView{get glyph_view(){return this.node_view.glyph}async lazy_initialize(){await super.lazy_initialize(),this.apply_coordinates();const{parent:e}=this,{edge_renderer:r,node_renderer:i}=this.model;this.edge_view=await(0,l.build_view)(r,{parent:e}),this.node_view=await(0,l.build_view)(i,{parent:e})}connect_signals(){super.connect_signals(),this.connect(this.model.layout_provider.change,(()=>{this.apply_coordinates(),this.edge_view.set_data(),this.node_view.set_data(),this.request_render()}))}apply_coordinates(){const{edge_renderer:e,node_renderer:r}=this.model;if(!(e.glyph instanceof h.MultiLine||e.glyph instanceof y.Patches))throw new Error(`${this}.edge_renderer.glyph must be a MultiLine glyph`);if(!(r.glyph instanceof _.XYGlyph))throw new Error(`${this}.node_renderer.glyph must be a XYGlyph glyph`);const i=this.model.layout_provider.edge_coordinates,n=this.model.layout_provider.node_coordinates;e.glyph.properties.xs.internal=!0,e.glyph.properties.ys.internal=!0,r.glyph.properties.x.internal=!0,r.glyph.properties.y.internal=!0,e.glyph.xs={expr:i.x},e.glyph.ys={expr:i.y},r.glyph.x={expr:n.x},r.glyph.y={expr:n.y}}remove(){this.edge_view.remove(),this.node_view.remove(),super.remove()}_render(){this.edge_view.render(),this.node_view.render()}renderer_view(e){if(e instanceof d.GlyphRenderer){if(e==this.edge_view.model)return this.edge_view;if(e==this.node_view.model)return this.node_view}return super.renderer_view(e)}}i.GraphRendererView=c,c.__name__=\"GraphRendererView\";class g extends s.DataRenderer{constructor(e){super(e)}get_selection_manager(){return this.node_renderer.data_source.selection_manager}}i.GraphRenderer=g,o=g,g.__name__=\"GraphRenderer\",o.prototype.default_view=c,o.define((({Ref:e})=>({layout_provider:[e(a.LayoutProvider)],node_renderer:[e(d.GlyphRenderer)],edge_renderer:[e(d.GlyphRenderer)],selection_policy:[e(p.GraphHitTestPolicy),()=>new p.NodesOnly],inspection_policy:[e(p.GraphHitTestPolicy),()=>new p.NodesOnly]})))},\n", " function _(e,t,n,o,c){o();(0,e(1).__exportStar)(e(74),n),c(\"Selection\",e(72).Selection)},\n", " function _(a,e,S,o,r){o(),r(\"ServerSentDataSource\",a(342).ServerSentDataSource),r(\"AjaxDataSource\",a(344).AjaxDataSource),r(\"ColumnDataSource\",a(75).ColumnDataSource),r(\"ColumnarDataSource\",a(70).ColumnarDataSource),r(\"CDSView\",a(190).CDSView),r(\"DataSource\",a(71).DataSource),r(\"GeoJSONDataSource\",a(345).GeoJSONDataSource),r(\"WebDataSource\",a(343).WebDataSource)},\n", " function _(e,t,i,a,s){a();const n=e(343);class r extends n.WebDataSource{constructor(e){super(e),this.initialized=!1}setup(){if(!this.initialized){this.initialized=!0;new EventSource(this.data_url).onmessage=e=>{var t;this.load_data(JSON.parse(e.data),this.mode,null!==(t=this.max_size)&&void 0!==t?t:void 0)}}}}i.ServerSentDataSource=r,r.__name__=\"ServerSentDataSource\"},\n", " function _(e,t,a,n,r){var s;n();const l=e(75),o=e(20);class c extends l.ColumnDataSource{constructor(e){super(e)}get_column(e){const t=this.data[e];return null!=t?t:[]}get_length(){var e;return null!==(e=super.get_length())&&void 0!==e?e:0}initialize(){super.initialize(),this.setup()}load_data(e,t,a){const{adapter:n}=this;let r;switch(r=null!=n?n.execute(this,{response:e}):e,t){case\"replace\":this.data=r;break;case\"append\":{const e=this.data;for(const t of this.columns()){const n=Array.from(e[t]),s=Array.from(r[t]),l=n.concat(s);r[t]=null!=a?l.slice(-a):l}this.data=r;break}}}}a.WebDataSource=c,s=c,c.__name__=\"WebDataSource\",s.define((({Any:e,Int:t,String:a,Nullable:n})=>({max_size:[n(t),null],mode:[o.UpdateMode,\"replace\"],adapter:[n(e),null],data_url:[a]})))},\n", " function _(t,e,i,s,a){var n;s();const r=t(343),o=t(20),l=t(19),d=t(13);class h extends r.WebDataSource{constructor(t){super(t),this.interval=null,this.initialized=!1}destroy(){null!=this.interval&&clearInterval(this.interval),super.destroy()}setup(){if(!this.initialized&&(this.initialized=!0,this.get_data(this.mode),null!=this.polling_interval)){const t=()=>this.get_data(this.mode,this.max_size,this.if_modified);this.interval=setInterval(t,this.polling_interval)}}get_data(t,e=null,i=!1){const s=this.prepare_request();s.addEventListener(\"load\",(()=>this.do_load(s,t,null!=e?e:void 0))),s.addEventListener(\"error\",(()=>this.do_error(s))),s.send()}prepare_request(){const t=new XMLHttpRequest;t.open(this.method,this.data_url,!0),t.withCredentials=!1,t.setRequestHeader(\"Content-Type\",this.content_type);const e=this.http_headers;for(const[i,s]of(0,d.entries)(e))t.setRequestHeader(i,s);return t}do_load(t,e,i){if(200===t.status){const s=JSON.parse(t.responseText);this.load_data(s,e,i)}}do_error(t){l.logger.error(`Failed to fetch JSON from ${this.data_url} with code ${t.status}`)}}i.AjaxDataSource=h,n=h,h.__name__=\"AjaxDataSource\",n.define((({Boolean:t,Int:e,String:i,Dict:s,Nullable:a})=>({polling_interval:[a(e),null],content_type:[i,\"application/json\"],http_headers:[s(i),{}],method:[o.HTTPMethod,\"POST\"],if_modified:[t,!1]})))},\n", " function _(e,t,o,r,n){var s;r();const a=e(70),i=e(19),l=e(9),c=e(13);function _(e){return null!=e?e:NaN}const{hasOwnProperty:g}=Object.prototype;class u extends a.ColumnarDataSource{constructor(e){super(e)}initialize(){super.initialize(),this._update_data()}connect_signals(){super.connect_signals(),this.connect(this.properties.geojson.change,(()=>this._update_data()))}_update_data(){this.data=this.geojson_to_column_data()}_get_new_list_array(e){return(0,l.range)(0,e).map((e=>[]))}_get_new_nan_array(e){return(0,l.range)(0,e).map((e=>NaN))}_add_properties(e,t,o,r){var n;const s=null!==(n=e.properties)&&void 0!==n?n:{};for(const[e,n]of(0,c.entries)(s))g.call(t,e)||(t[e]=this._get_new_nan_array(r)),t[e][o]=_(n)}_add_geometry(e,t,o){function r(e,t){return e.concat([[NaN,NaN,NaN]]).concat(t)}switch(e.type){case\"Point\":{const[r,n,s]=e.coordinates;t.x[o]=r,t.y[o]=n,t.z[o]=_(s);break}case\"LineString\":{const{coordinates:r}=e;for(let e=0;e1&&i.logger.warn(\"Bokeh does not support Polygons with holes in, only exterior ring used.\");const r=e.coordinates[0];for(let e=0;e1&&i.logger.warn(\"Bokeh does not support Polygons with holes in, only exterior ring used.\"),n.push(t[0]);const s=n.reduce(r);for(let e=0;e({geojson:[e]}))),s.internal((({Dict:e,Arrayable:t})=>({data:[e(t),{}]})))},\n", " function _(e,r,T,o,S){o(),S(\"BBoxTileSource\",e(347).BBoxTileSource),S(\"MercatorTileSource\",e(348).MercatorTileSource),S(\"QUADKEYTileSource\",e(351).QUADKEYTileSource),S(\"TileRenderer\",e(352).TileRenderer),S(\"TileSource\",e(349).TileSource),S(\"TMSTileSource\",e(355).TMSTileSource),S(\"WMTSTileSource\",e(353).WMTSTileSource)},\n", " function _(e,t,r,o,l){var i;o();const n=e(348);class s extends n.MercatorTileSource{constructor(e){super(e)}get_image_url(e,t,r){const o=this.string_lookup_replace(this.url,this.extra_url_vars);let l,i,n,s;return this.use_latlon?[i,s,l,n]=this.get_tile_geographic_bounds(e,t,r):[i,s,l,n]=this.get_tile_meter_bounds(e,t,r),o.replace(\"{XMIN}\",i.toString()).replace(\"{YMIN}\",s.toString()).replace(\"{XMAX}\",l.toString()).replace(\"{YMAX}\",n.toString())}}r.BBoxTileSource=s,i=s,s.__name__=\"BBoxTileSource\",i.define((({Boolean:e})=>({use_latlon:[e,!1]})))},\n", " function _(t,e,i,_,s){var r;_();const o=t(349),n=t(9),l=t(350);class u extends o.TileSource{constructor(t){super(t)}initialize(){super.initialize(),this._resolutions=(0,n.range)(this.min_zoom,this.max_zoom+1).map((t=>this.get_resolution(t)))}_computed_initial_resolution(){return null!=this.initial_resolution?this.initial_resolution:2*Math.PI*6378137/this.tile_size}is_valid_tile(t,e,i){return!(!this.wrap_around&&(t<0||t>=2**i))&&!(e<0||e>=2**i)}parent_by_tile_xyz(t,e,i){const _=this.tile_xyz_to_quadkey(t,e,i),s=_.substring(0,_.length-1);return this.quadkey_to_tile_xyz(s)}get_resolution(t){return this._computed_initial_resolution()/2**t}get_resolution_by_extent(t,e,i){return[(t[2]-t[0])/i,(t[3]-t[1])/e]}get_level_by_extent(t,e,i){const _=(t[2]-t[0])/i,s=(t[3]-t[1])/e,r=Math.max(_,s);let o=0;for(const t of this._resolutions){if(r>t){if(0==o)return 0;if(o>0)return o-1}o+=1}return o-1}get_closest_level_by_extent(t,e,i){const _=(t[2]-t[0])/i,s=(t[3]-t[1])/e,r=Math.max(_,s),o=this._resolutions.reduce((function(t,e){return Math.abs(e-r)e?(u=o-s,a*=t):(u*=e,a=n-r)}const h=(u-(o-s))/2,c=(a-(n-r))/2;return[s-h,r-c,o+h,n+c]}tms_to_wmts(t,e,i){return[t,2**i-1-e,i]}wmts_to_tms(t,e,i){return[t,2**i-1-e,i]}pixels_to_meters(t,e,i){const _=this.get_resolution(i);return[t*_-this.x_origin_offset,e*_-this.y_origin_offset]}meters_to_pixels(t,e,i){const _=this.get_resolution(i);return[(t+this.x_origin_offset)/_,(e+this.y_origin_offset)/_]}pixels_to_tile(t,e){let i=Math.ceil(t/this.tile_size);i=0===i?i:i-1;return[i,Math.max(Math.ceil(e/this.tile_size)-1,0)]}pixels_to_raster(t,e,i){return[t,(this.tile_size<=l;t--)for(let i=n;i<=u;i++)this.is_valid_tile(i,t,e)&&h.push([i,t,e,this.get_tile_meter_bounds(i,t,e)]);return this.sort_tiles_from_center(h,[n,l,u,a]),h}quadkey_to_tile_xyz(t){let e=0,i=0;const _=t.length;for(let s=_;s>0;s--){const r=1<0;s--){const i=1<0;)if(s=s.substring(0,s.length-1),[t,e,i]=this.quadkey_to_tile_xyz(s),[t,e,i]=this.denormalize_xyz(t,e,i,_),this.tiles.has(this.tile_xyz_to_key(t,e,i)))return[t,e,i];return[0,0,0]}normalize_xyz(t,e,i){if(this.wrap_around){const _=2**i;return[(t%_+_)%_,e,i]}return[t,e,i]}denormalize_xyz(t,e,i,_){return[t+_*2**i,e,i]}denormalize_meters(t,e,i,_){return[t+2*_*Math.PI*6378137,e]}calculate_world_x_by_tile_xyz(t,e,i){return Math.floor(t/2**i)}}i.MercatorTileSource=u,r=u,u.__name__=\"MercatorTileSource\",r.define((({Boolean:t})=>({snap_to_zoom:[t,!1],wrap_around:[t,!0]}))),r.override({x_origin_offset:20037508.34,y_origin_offset:20037508.34,initial_resolution:156543.03392804097})},\n", " function _(e,t,r,i,n){var l;i();const a=e(53),s=e(13);class c extends a.Model{constructor(e){super(e)}initialize(){super.initialize(),this.tiles=new Map,this._normalize_case()}connect_signals(){super.connect_signals(),this.connect(this.change,(()=>this._clear_cache()))}string_lookup_replace(e,t){let r=e;for(const[e,i]of(0,s.entries)(t))r=r.replace(`{${e}}`,i);return r}_normalize_case(){const e=this.url.replace(\"{x}\",\"{X}\").replace(\"{y}\",\"{Y}\").replace(\"{z}\",\"{Z}\").replace(\"{q}\",\"{Q}\").replace(\"{xmin}\",\"{XMIN}\").replace(\"{ymin}\",\"{YMIN}\").replace(\"{xmax}\",\"{XMAX}\").replace(\"{ymax}\",\"{YMAX}\");this.url=e}_clear_cache(){this.tiles=new Map}tile_xyz_to_key(e,t,r){return`${e}:${t}:${r}`}key_to_tile_xyz(e){const[t,r,i]=e.split(\":\").map((e=>parseInt(e)));return[t,r,i]}sort_tiles_from_center(e,t){const[r,i,n,l]=t,a=(n-r)/2+r,s=(l-i)/2+i;e.sort((function(e,t){return Math.sqrt((a-e[0])**2+(s-e[1])**2)-Math.sqrt((a-t[0])**2+(s-t[1])**2)}))}get_image_url(e,t,r){return this.string_lookup_replace(this.url,this.extra_url_vars).replace(\"{X}\",e.toString()).replace(\"{Y}\",t.toString()).replace(\"{Z}\",r.toString())}}r.TileSource=c,l=c,c.__name__=\"TileSource\",l.define((({Number:e,String:t,Dict:r,Nullable:i})=>({url:[t,\"\"],tile_size:[e,256],max_zoom:[e,30],min_zoom:[e,0],extra_url_vars:[r(t),{}],attribution:[t,\"\"],x_origin_offset:[e],y_origin_offset:[e],initial_resolution:[i(e),null]})))},\n", " function _(t,e,r,n,o){n();const c=t(78);function _(t,e){return c.wgs84_mercator.compute(t,e)}function g(t,e){return c.wgs84_mercator.invert(t,e)}r.geographic_to_meters=_,r.meters_to_geographic=g,r.geographic_extent_to_meters=function(t){const[e,r,n,o]=t,[c,g]=_(e,r),[i,u]=_(n,o);return[c,g,i,u]},r.meters_extent_to_geographic=function(t){const[e,r,n,o]=t,[c,_]=g(e,r),[i,u]=g(n,o);return[c,_,i,u]}},\n", " function _(e,t,r,s,_){s();const o=e(348);class c extends o.MercatorTileSource{constructor(e){super(e)}get_image_url(e,t,r){const s=this.string_lookup_replace(this.url,this.extra_url_vars),[_,o,c]=this.tms_to_wmts(e,t,r),i=this.tile_xyz_to_quadkey(_,o,c);return s.replace(\"{Q}\",i)}}r.QUADKEYTileSource=c,c.__name__=\"QUADKEYTileSource\"},\n", " function _(t,e,i,s,_){s();const n=t(1);var a;const o=t(349),r=t(353),h=t(41),l=t(58),d=t(43),m=t(136),c=t(9),u=t(8),p=(0,n.__importStar)(t(354));class g extends h.RendererView{initialize(){this._tiles=[],super.initialize()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render())),this.connect(this.model.tile_source.change,(()=>this.request_render()))}remove(){null!=this.attribution_el&&(0,d.removeElement)(this.attribution_el),super.remove()}styles(){return[...super.styles(),p.default]}get_extent(){return[this.x_range.start,this.y_range.start,this.x_range.end,this.y_range.end]}get map_plot(){return this.plot_model}get map_canvas(){return this.layer.ctx}get map_frame(){return this.plot_view.frame}get x_range(){return this.map_plot.x_range}get y_range(){return this.map_plot.y_range}_set_data(){this.extent=this.get_extent(),this._last_height=void 0,this._last_width=void 0}_update_attribution(){null!=this.attribution_el&&(0,d.removeElement)(this.attribution_el);const{attribution:t}=this.model.tile_source;if((0,u.isString)(t)&&t.length>0){const{layout:e,frame:i}=this.plot_view,s=e.bbox.width-i.bbox.right,_=e.bbox.height-i.bbox.bottom,n=i.bbox.width;this.attribution_el=(0,d.div)({class:p.tile_attribution,style:{position:\"absolute\",right:`${s}px`,bottom:`${_}px`,\"max-width\":n-4+\"px\",padding:\"2px\",\"background-color\":\"rgba(255,255,255,0.5)\",\"font-size\":\"9px\",\"line-height\":\"1.05\",\"white-space\":\"nowrap\",overflow:\"hidden\",\"text-overflow\":\"ellipsis\"}}),this.plot_view.canvas_view.add_event(this.attribution_el),this.attribution_el.innerHTML=t,this.attribution_el.title=this.attribution_el.textContent.replace(/\\s*\\n\\s*/g,\" \")}}_map_data(){this.initial_extent=this.get_extent();const t=this.model.tile_source.get_level_by_extent(this.initial_extent,this.map_frame.bbox.height,this.map_frame.bbox.width),e=this.model.tile_source.snap_to_zoom_level(this.initial_extent,this.map_frame.bbox.height,this.map_frame.bbox.width,t);this.x_range.start=e[0],this.y_range.start=e[1],this.x_range.end=e[2],this.y_range.end=e[3],this.x_range instanceof l.Range1d&&(this.x_range.reset_start=e[0],this.x_range.reset_end=e[2]),this.y_range instanceof l.Range1d&&(this.y_range.reset_start=e[1],this.y_range.reset_end=e[3]),this._update_attribution()}_create_tile(t,e,i,s,_=!1){const n=this.model.tile_source.tile_xyz_to_quadkey(t,e,i),a=this.model.tile_source.tile_xyz_to_key(t,e,i);if(this.model.tile_source.tiles.has(a))return;const[o,r,h]=this.model.tile_source.normalize_xyz(t,e,i),l=this.model.tile_source.get_image_url(o,r,h),d={img:void 0,tile_coords:[t,e,i],normalized_coords:[o,r,h],quadkey:n,cache_key:a,bounds:s,loaded:!1,finished:!1,x_coord:s[0],y_coord:s[3]};this.model.tile_source.tiles.set(a,d),this._tiles.push(d),new m.ImageLoader(l,{loaded:t=>{Object.assign(d,{img:t,loaded:!0}),_?(d.finished=!0,this.notify_finished()):this.request_render()},failed(){d.finished=!0}})}_enforce_aspect_ratio(){if(this._last_height!==this.map_frame.bbox.height||this._last_width!==this.map_frame.bbox.width){const t=this.get_extent(),e=this.model.tile_source.get_level_by_extent(t,this.map_frame.bbox.height,this.map_frame.bbox.width),i=this.model.tile_source.snap_to_zoom_level(t,this.map_frame.bbox.height,this.map_frame.bbox.width,e);this.x_range.setv({start:i[0],end:i[2]}),this.y_range.setv({start:i[1],end:i[3]}),this.extent=i,this._last_height=this.map_frame.bbox.height,this._last_width=this.map_frame.bbox.width}}has_finished(){if(!super.has_finished())return!1;if(0==this._tiles.length)return!1;for(const t of this._tiles)if(!t.finished)return!1;return!0}_render(){null==this.map_initialized&&(this._set_data(),this._map_data(),this.map_initialized=!0),this._enforce_aspect_ratio(),this._update(),null!=this.prefetch_timer&&clearTimeout(this.prefetch_timer),this.prefetch_timer=setTimeout(this._prefetch_tiles.bind(this),500),this.has_finished()&&this.notify_finished()}_draw_tile(t){const e=this.model.tile_source.tiles.get(t);if(null!=e&&e.loaded){const[[t],[i]]=this.coordinates.map_to_screen([e.bounds[0]],[e.bounds[3]]),[[s],[_]]=this.coordinates.map_to_screen([e.bounds[2]],[e.bounds[1]]),n=s-t,a=_-i,o=t,r=i,h=this.map_canvas.getImageSmoothingEnabled();this.map_canvas.setImageSmoothingEnabled(this.model.smoothing),this.map_canvas.drawImage(e.img,o,r,n,a),this.map_canvas.setImageSmoothingEnabled(h),e.finished=!0}}_set_rect(){const t=this.plot_model.outline_line_width,e=this.map_frame.bbox.left+t/2,i=this.map_frame.bbox.top+t/2,s=this.map_frame.bbox.width-t,_=this.map_frame.bbox.height-t;this.map_canvas.rect(e,i,s,_),this.map_canvas.clip()}_render_tiles(t){this.map_canvas.save(),this._set_rect(),this.map_canvas.globalAlpha=this.model.alpha;for(const e of t)this._draw_tile(e);this.map_canvas.restore()}_prefetch_tiles(){const{tile_source:t}=this.model,e=this.get_extent(),i=this.map_frame.bbox.height,s=this.map_frame.bbox.width,_=this.model.tile_source.get_level_by_extent(e,i,s),n=this.model.tile_source.get_tiles_by_extent(e,_);for(let e=0,i=Math.min(10,n.length);ei&&(s=this.extent,o=i,r=!0),r&&(this.x_range.setv({start:s[0],end:s[2]}),this.y_range.setv({start:s[1],end:s[3]})),this.extent=s;const h=t.get_tiles_by_extent(s,o),l=[],d=[],m=[],u=[];for(const e of h){const[i,s,n]=e,a=t.tile_xyz_to_key(i,s,n),o=t.tiles.get(a);if(null!=o&&o.loaded)d.push(a);else if(this.model.render_parents){const[e,a,o]=t.get_closest_parent_by_tile_xyz(i,s,n),r=t.tile_xyz_to_key(e,a,o),h=t.tiles.get(r);if(null!=h&&h.loaded&&!(0,c.includes)(m,r)&&m.push(r),_){const e=t.children_by_tile_xyz(i,s,n);for(const[i,s,_]of e){const e=t.tile_xyz_to_key(i,s,_);t.tiles.has(e)&&u.push(e)}}}null==o&&l.push(e)}this._render_tiles(m),this._render_tiles(u),this._render_tiles(d),null!=this.render_timer&&clearTimeout(this.render_timer),this.render_timer=setTimeout((()=>this._fetch_tiles(l)),65)}}i.TileRendererView=g,g.__name__=\"TileRendererView\";class b extends h.Renderer{constructor(t){super(t)}}i.TileRenderer=b,a=b,b.__name__=\"TileRenderer\",a.prototype.default_view=g,a.define((({Boolean:t,Number:e,Ref:i})=>({alpha:[e,1],smoothing:[t,!0],tile_source:[i(o.TileSource),()=>new r.WMTSTileSource],render_parents:[t,!0]}))),a.override({level:\"image\"})},\n", " function _(t,e,r,o,s){o();const c=t(348);class i extends c.MercatorTileSource{constructor(t){super(t)}get_image_url(t,e,r){const o=this.string_lookup_replace(this.url,this.extra_url_vars),[s,c,i]=this.tms_to_wmts(t,e,r);return o.replace(\"{X}\",s.toString()).replace(\"{Y}\",c.toString()).replace(\"{Z}\",i.toString())}}r.WMTSTileSource=i,i.__name__=\"WMTSTileSource\"},\n", " function _(t,o,i,b,r){b(),i.root=\"bk-root\",i.tile_attribution=\"bk-tile-attribution\",i.default=\".bk-root .bk-tile-attribution a{color:black;}\"},\n", " function _(e,r,t,c,o){c();const i=e(348);class l extends i.MercatorTileSource{constructor(e){super(e)}get_image_url(e,r,t){return this.string_lookup_replace(this.url,this.extra_url_vars).replace(\"{X}\",e.toString()).replace(\"{Y}\",r.toString()).replace(\"{Z}\",t.toString())}}t.TMSTileSource=l,l.__name__=\"TMSTileSource\"},\n", " function _(e,t,u,a,r){a(),r(\"CanvasTexture\",e(357).CanvasTexture),r(\"ImageURLTexture\",e(359).ImageURLTexture),r(\"Texture\",e(358).Texture)},\n", " function _(t,e,n,c,s){var r;c();const o=t(358),a=t(34);class u extends o.Texture{constructor(t){super(t)}get func(){const t=(0,a.use_strict)(this.code);return new Function(\"ctx\",\"color\",\"scale\",\"weight\",t)}get_pattern(t,e,n){const c=document.createElement(\"canvas\");c.width=e,c.height=e;const s=c.getContext(\"2d\");return this.func.call(this,s,t,e,n),c}}n.CanvasTexture=u,r=u,u.__name__=\"CanvasTexture\",r.define((({String:t})=>({code:[t]})))},\n", " function _(e,t,n,r,o){var i;r();const s=e(53),u=e(20);class c extends s.Model{constructor(e){super(e)}}n.Texture=c,i=c,c.__name__=\"Texture\",i.define((()=>({repetition:[u.TextureRepetition,\"repeat\"]})))},\n", " function _(e,t,i,r,n){var a;r();const s=e(358),o=e(136);class u extends s.Texture{constructor(e){super(e)}initialize(){super.initialize(),this._loader=new o.ImageLoader(this.url)}get_pattern(e,t,i){const{_loader:r}=this;return this._loader.finished?r.image:r.promise}}i.ImageURLTexture=u,a=u,u.__name__=\"ImageURLTexture\",a.define((({String:e})=>({url:[e]})))},\n", " function _(o,l,T,e,t){e(),t(\"ActionTool\",o(238).ActionTool),t(\"CustomAction\",o(361).CustomAction),t(\"HelpTool\",o(239).HelpTool),t(\"RedoTool\",o(362).RedoTool),t(\"ResetTool\",o(363).ResetTool),t(\"SaveTool\",o(364).SaveTool),t(\"UndoTool\",o(365).UndoTool),t(\"ZoomInTool\",o(366).ZoomInTool),t(\"ZoomOutTool\",o(369).ZoomOutTool),t(\"ButtonTool\",o(224).ButtonTool),t(\"EditTool\",o(370).EditTool),t(\"BoxEditTool\",o(371).BoxEditTool),t(\"FreehandDrawTool\",o(372).FreehandDrawTool),t(\"PointDrawTool\",o(373).PointDrawTool),t(\"PolyDrawTool\",o(374).PolyDrawTool),t(\"PolyTool\",o(375).PolyTool),t(\"PolyEditTool\",o(376).PolyEditTool),t(\"BoxSelectTool\",o(377).BoxSelectTool),t(\"BoxZoomTool\",o(379).BoxZoomTool),t(\"GestureTool\",o(223).GestureTool),t(\"LassoSelectTool\",o(380).LassoSelectTool),t(\"LineEditTool\",o(382).LineEditTool),t(\"PanTool\",o(384).PanTool),t(\"PolySelectTool\",o(381).PolySelectTool),t(\"RangeTool\",o(385).RangeTool),t(\"SelectTool\",o(378).SelectTool),t(\"TapTool\",o(386).TapTool),t(\"WheelPanTool\",o(387).WheelPanTool),t(\"WheelZoomTool\",o(388).WheelZoomTool),t(\"CrosshairTool\",o(389).CrosshairTool),t(\"CustomJSHover\",o(390).CustomJSHover),t(\"HoverTool\",o(391).HoverTool),t(\"InspectTool\",o(232).InspectTool),t(\"Tool\",o(222).Tool),t(\"ToolProxy\",o(394).ToolProxy),t(\"Toolbar\",o(221).Toolbar),t(\"ToolbarBase\",o(233).ToolbarBase),t(\"ProxyToolbar\",o(395).ProxyToolbar),t(\"ToolbarBox\",o(395).ToolbarBox)},\n", " function _(t,o,e,s,n){var c;s();const i=t(238);class u extends i.ActionToolButtonView{css_classes(){return super.css_classes().concat(\"bk-toolbar-button-custom-action\")}}e.CustomActionButtonView=u,u.__name__=\"CustomActionButtonView\";class l extends i.ActionToolView{doit(){var t;null===(t=this.model.callback)||void 0===t||t.execute(this.model)}}e.CustomActionView=l,l.__name__=\"CustomActionView\";class a extends i.ActionTool{constructor(t){super(t),this.tool_name=\"Custom Action\",this.button_view=u}}e.CustomAction=a,c=a,a.__name__=\"CustomAction\",c.prototype.default_view=l,c.define((({Any:t,String:o,Nullable:e})=>({callback:[e(t)],icon:[o]}))),c.override({description:\"Perform a Custom Action\"})},\n", " function _(e,o,t,i,s){var n;i();const l=e(238),_=e(228);class d extends l.ActionToolView{connect_signals(){super.connect_signals(),this.connect(this.plot_view.state.changed,(()=>this.model.disabled=!this.plot_view.state.can_redo))}doit(){const e=this.plot_view.state.redo();null!=(null==e?void 0:e.range)&&this.plot_view.trigger_ranges_update_event()}}t.RedoToolView=d,d.__name__=\"RedoToolView\";class a extends l.ActionTool{constructor(e){super(e),this.tool_name=\"Redo\",this.icon=_.tool_icon_redo}}t.RedoTool=a,n=a,a.__name__=\"RedoTool\",n.prototype.default_view=d,n.override({disabled:!0}),n.register_alias(\"redo\",(()=>new a))},\n", " function _(e,o,t,s,i){var _;s();const n=e(238),l=e(228);class c extends n.ActionToolView{doit(){this.plot_view.reset()}}t.ResetToolView=c,c.__name__=\"ResetToolView\";class r extends n.ActionTool{constructor(e){super(e),this.tool_name=\"Reset\",this.icon=l.tool_icon_reset}}t.ResetTool=r,_=r,r.__name__=\"ResetTool\",_.prototype.default_view=c,_.register_alias(\"reset\",(()=>new r))},\n", " function _(e,o,t,a,i){var s;a();const c=e(238),n=e(228);class l extends c.ActionToolView{async copy(){const e=await this.plot_view.to_blob(),o=new ClipboardItem({[e.type]:Promise.resolve(e)});await navigator.clipboard.write([o])}async save(e){const o=await this.plot_view.to_blob(),t=document.createElement(\"a\");t.href=URL.createObjectURL(o),t.download=e,t.target=\"_blank\",t.dispatchEvent(new MouseEvent(\"click\"))}doit(e=\"save\"){switch(e){case\"save\":this.save(\"bokeh_plot\");break;case\"copy\":this.copy()}}}t.SaveToolView=l,l.__name__=\"SaveToolView\";class r extends c.ActionTool{constructor(e){super(e),this.tool_name=\"Save\",this.icon=n.tool_icon_save}get menu(){return[{icon:\"bk-tool-icon-copy-to-clipboard\",tooltip:\"Copy image to clipboard\",if:()=>\"undefined\"!=typeof ClipboardItem,handler:()=>{this.do.emit(\"copy\")}}]}}t.SaveTool=r,s=r,r.__name__=\"SaveTool\",s.prototype.default_view=l,s.register_alias(\"save\",(()=>new r))},\n", " function _(o,e,t,n,i){var s;n();const l=o(238),_=o(228);class d extends l.ActionToolView{connect_signals(){super.connect_signals(),this.connect(this.plot_view.state.changed,(()=>this.model.disabled=!this.plot_view.state.can_undo))}doit(){const o=this.plot_view.state.undo();null!=(null==o?void 0:o.range)&&this.plot_view.trigger_ranges_update_event()}}t.UndoToolView=d,d.__name__=\"UndoToolView\";class a extends l.ActionTool{constructor(o){super(o),this.tool_name=\"Undo\",this.icon=_.tool_icon_undo}}t.UndoTool=a,s=a,a.__name__=\"UndoTool\",s.prototype.default_view=d,s.override({disabled:!0}),s.register_alias(\"undo\",(()=>new a))},\n", " function _(o,n,e,i,s){var t;i();const _=o(367),m=o(228);class a extends _.ZoomBaseToolView{}e.ZoomInToolView=a,a.__name__=\"ZoomInToolView\";class l extends _.ZoomBaseTool{constructor(o){super(o),this.sign=1,this.tool_name=\"Zoom In\",this.icon=m.tool_icon_zoom_in}}e.ZoomInTool=l,t=l,l.__name__=\"ZoomInTool\",t.prototype.default_view=a,t.register_alias(\"zoom_in\",(()=>new l({dimensions:\"both\"}))),t.register_alias(\"xzoom_in\",(()=>new l({dimensions:\"width\"}))),t.register_alias(\"yzoom_in\",(()=>new l({dimensions:\"height\"})))},\n", " function _(o,t,e,i,s){var n;i();const a=o(238),_=o(20),l=o(368);class m extends a.ActionToolView{doit(){var o;const t=this.plot_view.frame,e=this.model.dimensions,i=\"width\"==e||\"both\"==e,s=\"height\"==e||\"both\"==e,n=(0,l.scale_range)(t,this.model.sign*this.model.factor,i,s);this.plot_view.state.push(\"zoom_out\",{range:n}),this.plot_view.update_range(n,{scrolling:!0,maintain_focus:this.model.maintain_focus}),null===(o=this.model.document)||void 0===o||o.interactive_start(this.plot_model),this.plot_view.trigger_ranges_update_event()}}e.ZoomBaseToolView=m,m.__name__=\"ZoomBaseToolView\";class h extends a.ActionTool{constructor(o){super(o),this.maintain_focus=!0}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}e.ZoomBaseTool=h,n=h,h.__name__=\"ZoomBaseTool\",n.define((({Percent:o})=>({factor:[o,.1],dimensions:[_.Dimensions,\"both\"]})))},\n", " function _(n,t,o,r,s){r();const c=n(10);function e(n,t,o){const[r,s]=[n.start,n.end],c=null!=o?o:(s+r)/2;return[r-(r-c)*t,s-(s-c)*t]}function a(n,[t,o]){const r=new Map;for(const[s,c]of n){const[n,e]=c.r_invert(t,o);r.set(s,{start:n,end:e})}return r}o.scale_highlow=e,o.get_info=a,o.scale_range=function(n,t,o=!0,r=!0,s){t=(0,c.clamp)(t,-.9,.9);const l=o?t:0,[u,i]=e(n.bbox.h_range,l,null!=s?s.x:void 0),_=a(n.x_scales,[u,i]),f=r?t:0,[g,x]=e(n.bbox.v_range,f,null!=s?s.y:void 0);return{xrs:_,yrs:a(n.y_scales,[g,x]),factor:t}}},\n", " function _(o,e,t,i,s){var n;i();const _=o(367),a=o(228);class m extends _.ZoomBaseToolView{}t.ZoomOutToolView=m,m.__name__=\"ZoomOutToolView\";class l extends _.ZoomBaseTool{constructor(o){super(o),this.sign=-1,this.tool_name=\"Zoom Out\",this.icon=a.tool_icon_zoom_out}}t.ZoomOutTool=l,n=l,l.__name__=\"ZoomOutTool\",n.prototype.default_view=m,n.define((({Boolean:o})=>({maintain_focus:[o,!0]}))),n.register_alias(\"zoom_out\",(()=>new l({dimensions:\"both\"}))),n.register_alias(\"xzoom_out\",(()=>new l({dimensions:\"width\"}))),n.register_alias(\"yzoom_out\",(()=>new l({dimensions:\"height\"})))},\n", " function _(e,t,s,o,n){var r;o();const i=e(9),c=e(8),a=e(11),_=e(175),l=e(223);class d extends l.GestureToolView{constructor(){super(...arguments),this._mouse_in_frame=!0}_select_mode(e){const{shiftKey:t,ctrlKey:s}=e;return t||s?t&&!s?\"append\":!t&&s?\"intersect\":t&&s?\"subtract\":void(0,a.unreachable)():\"replace\"}_move_enter(e){this._mouse_in_frame=!0}_move_exit(e){this._mouse_in_frame=!1}_map_drag(e,t,s){if(!this.plot_view.frame.bbox.contains(e,t))return null;const o=this.plot_view.renderer_view(s);if(null==o)return null;return[o.coordinates.x_scale.invert(e),o.coordinates.y_scale.invert(t)]}_delete_selected(e){const t=e.data_source,s=t.selected.indices;s.sort();for(const e of t.columns()){const o=t.get_array(e);for(let e=0;e({custom_icon:[n(t),null],empty_value:[e],renderers:[s(o(_.GlyphRenderer)),[]]})))},\n", " function _(e,t,s,i,_){var o;i();const n=e(43),a=e(20),d=e(370),l=e(228);class r extends d.EditToolView{_tap(e){null==this._draw_basepoint&&null==this._basepoint&&this._select_event(e,this._select_mode(e),this.model.renderers)}_keyup(e){if(this.model.active&&this._mouse_in_frame)for(const t of this.model.renderers)if(e.keyCode===n.Keys.Backspace)this._delete_selected(t);else if(e.keyCode==n.Keys.Esc){t.data_source.selection_manager.clear()}}_set_extent([e,t],[s,i],_,o=!1){const n=this.model.renderers[0],a=this.plot_view.renderer_view(n);if(null==a)return;const d=n.glyph,l=n.data_source,[r,h]=a.coordinates.x_scale.r_invert(e,t),[p,u]=a.coordinates.y_scale.r_invert(s,i),[c,m]=[(r+h)/2,(p+u)/2],[f,b]=[h-r,u-p],[y,x]=[d.x.field,d.y.field],[w,v]=[d.width.field,d.height.field];if(_)this._pop_glyphs(l,this.model.num_objects),y&&l.get_array(y).push(c),x&&l.get_array(x).push(m),w&&l.get_array(w).push(f),v&&l.get_array(v).push(b),this._pad_empty_columns(l,[y,x,w,v]);else{const e=l.data[y].length-1;y&&(l.data[y][e]=c),x&&(l.data[x][e]=m),w&&(l.data[w][e]=f),v&&(l.data[v][e]=b)}this._emit_cds_changes(l,!0,!1,o)}_update_box(e,t=!1,s=!1){if(null==this._draw_basepoint)return;const i=[e.sx,e.sy],_=this.plot_view.frame,o=this.model.dimensions,n=this.model._get_dim_limits(this._draw_basepoint,i,_,o);if(null!=n){const[e,i]=n;this._set_extent(e,i,t,s)}}_doubletap(e){this.model.active&&(null!=this._draw_basepoint?(this._update_box(e,!1,!0),this._draw_basepoint=null):(this._draw_basepoint=[e.sx,e.sy],this._select_event(e,\"append\",this.model.renderers),this._update_box(e,!0,!1)))}_move(e){this._update_box(e,!1,!1)}_pan_start(e){if(e.shiftKey){if(null!=this._draw_basepoint)return;this._draw_basepoint=[e.sx,e.sy],this._update_box(e,!0,!1)}else{if(null!=this._basepoint)return;this._select_event(e,\"append\",this.model.renderers),this._basepoint=[e.sx,e.sy]}}_pan(e,t=!1,s=!1){if(e.shiftKey){if(null==this._draw_basepoint)return;this._update_box(e,t,s)}else{if(null==this._basepoint)return;this._drag_points(e,this.model.renderers)}}_pan_end(e){if(this._pan(e,!1,!0),e.shiftKey)this._draw_basepoint=null;else{this._basepoint=null;for(const e of this.model.renderers)this._emit_cds_changes(e.data_source,!1,!0,!0)}}}s.BoxEditToolView=r,r.__name__=\"BoxEditToolView\";class h extends d.EditTool{constructor(e){super(e),this.tool_name=\"Box Edit Tool\",this.icon=l.tool_icon_box_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=1}}s.BoxEditTool=h,o=h,h.__name__=\"BoxEditTool\",o.prototype.default_view=r,o.define((({Int:e})=>({dimensions:[a.Dimensions,\"both\"],num_objects:[e,0]})))},\n", " function _(e,t,a,s,r){var _;s();const d=e(43),o=e(8),n=e(370),i=e(228);class l extends n.EditToolView{_draw(e,t,a=!1){if(!this.model.active)return;const s=this.model.renderers[0],r=this._map_drag(e.sx,e.sy,s);if(null==r)return;const[_,d]=r,n=s.data_source,i=s.glyph,[l,h]=[i.xs.field,i.ys.field];if(\"new\"==t)this._pop_glyphs(n,this.model.num_objects),l&&n.get_array(l).push([_]),h&&n.get_array(h).push([d]),this._pad_empty_columns(n,[l,h]);else if(\"add\"==t){if(l){const e=n.data[l].length-1;let t=n.get_array(l)[e];(0,o.isArray)(t)||(t=Array.from(t),n.data[l][e]=t),t.push(_)}if(h){const e=n.data[h].length-1;let t=n.get_array(h)[e];(0,o.isArray)(t)||(t=Array.from(t),n.data[h][e]=t),t.push(d)}}this._emit_cds_changes(n,!0,!0,a)}_pan_start(e){this._draw(e,\"new\")}_pan(e){this._draw(e,\"add\")}_pan_end(e){this._draw(e,\"add\",!0)}_tap(e){this._select_event(e,this._select_mode(e),this.model.renderers)}_keyup(e){if(this.model.active&&this._mouse_in_frame)for(const t of this.model.renderers)e.keyCode===d.Keys.Esc?t.data_source.selection_manager.clear():e.keyCode===d.Keys.Backspace&&this._delete_selected(t)}}a.FreehandDrawToolView=l,l.__name__=\"FreehandDrawToolView\";class h extends n.EditTool{constructor(e){super(e),this.tool_name=\"Freehand Draw Tool\",this.icon=i.tool_icon_freehand_draw,this.event_type=[\"pan\",\"tap\"],this.default_order=3}}a.FreehandDrawTool=h,_=h,h.__name__=\"FreehandDrawTool\",_.prototype.default_view=l,_.define((({Int:e})=>({num_objects:[e,0]}))),_.register_alias(\"freehand_draw\",(()=>new h))},\n", " function _(e,t,s,o,a){var i;o();const n=e(43),_=e(370),r=e(228);class d extends _.EditToolView{_tap(e){if(this._select_event(e,this._select_mode(e),this.model.renderers).length||!this.model.add)return;const t=this.model.renderers[0],s=this._map_drag(e.sx,e.sy,t);if(null==s)return;const o=t.glyph,a=t.data_source,[i,n]=[o.x.field,o.y.field],[_,r]=s;this._pop_glyphs(a,this.model.num_objects),i&&a.get_array(i).push(_),n&&a.get_array(n).push(r),this._pad_empty_columns(a,[i,n]),a.change.emit(),a.data=a.data,a.properties.data.change.emit()}_keyup(e){if(this.model.active&&this._mouse_in_frame)for(const t of this.model.renderers)e.keyCode===n.Keys.Backspace?this._delete_selected(t):e.keyCode==n.Keys.Esc&&t.data_source.selection_manager.clear()}_pan_start(e){this.model.drag&&(this._select_event(e,\"append\",this.model.renderers),this._basepoint=[e.sx,e.sy])}_pan(e){this.model.drag&&null!=this._basepoint&&this._drag_points(e,this.model.renderers)}_pan_end(e){if(this.model.drag){this._pan(e);for(const e of this.model.renderers)this._emit_cds_changes(e.data_source,!1,!0,!0);this._basepoint=null}}}s.PointDrawToolView=d,d.__name__=\"PointDrawToolView\";class l extends _.EditTool{constructor(e){super(e),this.tool_name=\"Point Draw Tool\",this.icon=r.tool_icon_point_draw,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=2}}s.PointDrawTool=l,i=l,l.__name__=\"PointDrawTool\",i.prototype.default_view=d,i.define((({Boolean:e,Int:t})=>({add:[e,!0],drag:[e,!0],num_objects:[t,0]})))},\n", " function _(e,t,s,i,a){var r;i();const o=e(43),n=e(8),d=e(375),_=e(228);class h extends d.PolyToolView{constructor(){super(...arguments),this._drawing=!1,this._initialized=!1}_tap(e){this._drawing?this._draw(e,\"add\",!0):this._select_event(e,this._select_mode(e),this.model.renderers)}_draw(e,t,s=!1){const i=this.model.renderers[0],a=this._map_drag(e.sx,e.sy,i);if(this._initialized||this.activate(),null==a)return;const[r,o]=this._snap_to_vertex(e,...a),d=i.data_source,_=i.glyph,[h,l]=[_.xs.field,_.ys.field];if(\"new\"==t)this._pop_glyphs(d,this.model.num_objects),h&&d.get_array(h).push([r,r]),l&&d.get_array(l).push([o,o]),this._pad_empty_columns(d,[h,l]);else if(\"edit\"==t){if(h){const e=d.data[h][d.data[h].length-1];e[e.length-1]=r}if(l){const e=d.data[l][d.data[l].length-1];e[e.length-1]=o}}else if(\"add\"==t){if(h){const e=d.data[h].length-1;let t=d.get_array(h)[e];const s=t[t.length-1];t[t.length-1]=r,(0,n.isArray)(t)||(t=Array.from(t),d.data[h][e]=t),t.push(s)}if(l){const e=d.data[l].length-1;let t=d.get_array(l)[e];const s=t[t.length-1];t[t.length-1]=o,(0,n.isArray)(t)||(t=Array.from(t),d.data[l][e]=t),t.push(s)}}this._emit_cds_changes(d,!0,!1,s)}_show_vertices(){if(!this.model.active)return;const e=[],t=[];for(let s=0;sthis._show_vertices()))}this._initialized=!0}}deactivate(){this._drawing&&(this._remove(),this._drawing=!1),this.model.vertex_renderer&&this._hide_vertices()}}s.PolyDrawToolView=h,h.__name__=\"PolyDrawToolView\";class l extends d.PolyTool{constructor(e){super(e),this.tool_name=\"Polygon Draw Tool\",this.icon=_.tool_icon_poly_draw,this.event_type=[\"pan\",\"tap\",\"move\"],this.default_order=3}}s.PolyDrawTool=l,r=l,l.__name__=\"PolyDrawTool\",r.prototype.default_view=h,r.define((({Boolean:e,Int:t})=>({drag:[e,!0],num_objects:[t,0]})))},\n", " function _(e,r,t,s,o){var _;s();const d=e(8),i=e(370);class l extends i.EditToolView{_set_vertices(e,r){const t=this.model.vertex_renderer.glyph,s=this.model.vertex_renderer.data_source,[o,_]=[t.x.field,t.y.field];o&&((0,d.isArray)(e)?s.data[o]=e:t.x={value:e}),_&&((0,d.isArray)(r)?s.data[_]=r:t.y={value:r}),this._emit_cds_changes(s,!0,!0,!1)}_hide_vertices(){this._set_vertices([],[])}_snap_to_vertex(e,r,t){if(this.model.vertex_renderer){const s=this._select_event(e,\"replace\",[this.model.vertex_renderer]),o=this.model.vertex_renderer.data_source,_=this.model.vertex_renderer.glyph,[d,i]=[_.x.field,_.y.field];if(s.length){const e=o.selected.indices[0];d&&(r=o.data[d][e]),i&&(t=o.data[i][e]),o.selection_manager.clear()}}return[r,t]}}t.PolyToolView=l,l.__name__=\"PolyToolView\";class n extends i.EditTool{constructor(e){super(e)}}t.PolyTool=n,_=n,n.__name__=\"PolyTool\",_.define((({AnyRef:e})=>({vertex_renderer:[e()]})))},\n", " function _(e,t,s,r,i){var _;r();const d=e(43),n=e(8),l=e(375),a=e(228);class c extends l.PolyToolView{constructor(){super(...arguments),this._drawing=!1,this._cur_index=null}_doubletap(e){if(!this.model.active)return;const t=this._map_drag(e.sx,e.sy,this.model.vertex_renderer);if(null==t)return;const[s,r]=t,i=this._select_event(e,\"replace\",[this.model.vertex_renderer]),_=this.model.vertex_renderer.data_source,d=this.model.vertex_renderer.glyph,[n,l]=[d.x.field,d.y.field];if(i.length&&null!=this._selected_renderer){const e=_.selected.indices[0];this._drawing?(this._drawing=!1,_.selection_manager.clear()):(_.selected.indices=[e+1],n&&_.get_array(n).splice(e+1,0,s),l&&_.get_array(l).splice(e+1,0,r),this._drawing=!0),_.change.emit(),this._emit_cds_changes(this._selected_renderer.data_source)}else this._show_vertices(e)}_show_vertices(e){if(!this.model.active)return;const t=this.model.renderers[0],s=()=>this._update_vertices(t),r=null==t?void 0:t.data_source,i=this._select_event(e,\"replace\",this.model.renderers);if(!i.length)return this._set_vertices([],[]),this._selected_renderer=null,this._drawing=!1,this._cur_index=null,void(null!=r&&r.disconnect(r.properties.data.change,s));null!=r&&r.connect(r.properties.data.change,s),this._cur_index=i[0].data_source.selected.indices[0],this._update_vertices(i[0])}_update_vertices(e){const t=e.glyph,s=e.data_source,r=this._cur_index,[i,_]=[t.xs.field,t.ys.field];if(this._drawing)return;if(null==r&&(i||_))return;let d,l;i&&null!=r?(d=s.data[i][r],(0,n.isArray)(d)||(s.data[i][r]=d=Array.from(d))):d=t.xs.value,_&&null!=r?(l=s.data[_][r],(0,n.isArray)(l)||(s.data[_][r]=l=Array.from(l))):l=t.ys.value,this._selected_renderer=e,this._set_vertices(d,l)}_move(e){if(this._drawing&&null!=this._selected_renderer){const t=this.model.vertex_renderer,s=t.data_source,r=t.glyph,i=this._map_drag(e.sx,e.sy,t);if(null==i)return;let[_,d]=i;const n=s.selected.indices;[_,d]=this._snap_to_vertex(e,_,d),s.selected.indices=n;const[l,a]=[r.x.field,r.y.field],c=n[0];l&&(s.data[l][c]=_),a&&(s.data[a][c]=d),s.change.emit(),this._selected_renderer.data_source.change.emit()}}_tap(e){const t=this.model.vertex_renderer,s=this._map_drag(e.sx,e.sy,t);if(null==s)return;if(this._drawing&&this._selected_renderer){let[r,i]=s;const _=t.data_source,d=t.glyph,[n,l]=[d.x.field,d.y.field],a=_.selected.indices;[r,i]=this._snap_to_vertex(e,r,i);const c=a[0];if(_.selected.indices=[c+1],n){const e=_.get_array(n),t=e[c];e[c]=r,e.splice(c+1,0,t)}if(l){const e=_.get_array(l),t=e[c];e[c]=i,e.splice(c+1,0,t)}return _.change.emit(),void this._emit_cds_changes(this._selected_renderer.data_source,!0,!1,!0)}const r=this._select_mode(e);this._select_event(e,r,[t]),this._select_event(e,r,this.model.renderers)}_remove_vertex(){if(!this._drawing||!this._selected_renderer)return;const e=this.model.vertex_renderer,t=e.data_source,s=e.glyph,r=t.selected.indices[0],[i,_]=[s.x.field,s.y.field];i&&t.get_array(i).splice(r,1),_&&t.get_array(_).splice(r,1),t.change.emit(),this._emit_cds_changes(this._selected_renderer.data_source)}_pan_start(e){this._select_event(e,\"append\",[this.model.vertex_renderer]),this._basepoint=[e.sx,e.sy]}_pan(e){null!=this._basepoint&&(this._drag_points(e,[this.model.vertex_renderer]),this._selected_renderer&&this._selected_renderer.data_source.change.emit())}_pan_end(e){null!=this._basepoint&&(this._drag_points(e,[this.model.vertex_renderer]),this._emit_cds_changes(this.model.vertex_renderer.data_source,!1,!0,!0),this._selected_renderer&&this._emit_cds_changes(this._selected_renderer.data_source),this._basepoint=null)}_keyup(e){if(!this.model.active||!this._mouse_in_frame)return;let t;t=this._selected_renderer?[this.model.vertex_renderer]:this.model.renderers;for(const s of t)e.keyCode===d.Keys.Backspace?(this._delete_selected(s),this._selected_renderer&&this._emit_cds_changes(this._selected_renderer.data_source)):e.keyCode==d.Keys.Esc&&(this._drawing?(this._remove_vertex(),this._drawing=!1):this._selected_renderer&&this._hide_vertices(),s.data_source.selection_manager.clear())}deactivate(){this._selected_renderer&&(this._drawing&&(this._remove_vertex(),this._drawing=!1),this._hide_vertices())}}s.PolyEditToolView=c,c.__name__=\"PolyEditToolView\";class o extends l.PolyTool{constructor(e){super(e),this.tool_name=\"Poly Edit Tool\",this.icon=a.tool_icon_poly_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=4}}s.PolyEditTool=o,_=o,o.__name__=\"PolyEditTool\",_.prototype.default_view=c},\n", " function _(e,t,o,s,i){var l;s();const n=e(378),_=e(116),c=e(20),r=e(228);class a extends n.SelectToolView{_compute_limits(e){const t=this.plot_view.frame,o=this.model.dimensions;let s=this._base_point;if(\"center\"==this.model.origin){const[t,o]=s,[i,l]=e;s=[t-(i-t),o-(l-o)]}return this.model._get_dim_limits(s,e,t,o)}_pan_start(e){const{sx:t,sy:o}=e;this._base_point=[t,o]}_pan(e){const{sx:t,sy:o}=e,s=[t,o],[i,l]=this._compute_limits(s);this.model.overlay.update({left:i[0],right:i[1],top:l[0],bottom:l[1]}),this.model.select_every_mousemove&&this._do_select(i,l,!1,this._select_mode(e))}_pan_end(e){const{sx:t,sy:o}=e,s=[t,o],[i,l]=this._compute_limits(s);this._do_select(i,l,!0,this._select_mode(e)),this.model.overlay.update({left:null,right:null,top:null,bottom:null}),this._base_point=null,this.plot_view.state.push(\"box_select\",{selection:this.plot_view.get_selection()})}_do_select([e,t],[o,s],i,l=\"replace\"){const n={type:\"rect\",sx0:e,sx1:t,sy0:o,sy1:s};this._select(n,i,l)}}o.BoxSelectToolView=a,a.__name__=\"BoxSelectToolView\";const h=()=>new _.BoxAnnotation({level:\"overlay\",top_units:\"screen\",left_units:\"screen\",bottom_units:\"screen\",right_units:\"screen\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:2,line_dash:[4,4]});class m extends n.SelectTool{constructor(e){super(e),this.tool_name=\"Box Select\",this.icon=r.tool_icon_box_select,this.event_type=\"pan\",this.default_order=30}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}o.BoxSelectTool=m,l=m,m.__name__=\"BoxSelectTool\",l.prototype.default_view=a,l.define((({Boolean:e,Ref:t})=>({dimensions:[c.Dimensions,\"both\"],select_every_mousemove:[e,!1],overlay:[t(_.BoxAnnotation),h],origin:[c.BoxOrigin,\"corner\"]}))),l.register_alias(\"box_select\",(()=>new m)),l.register_alias(\"xbox_select\",(()=>new m({dimensions:\"width\"}))),l.register_alias(\"ybox_select\",(()=>new m({dimensions:\"height\"})))},\n", " function _(e,t,s,n,r){var o;n();const c=e(223),i=e(175),a=e(339),l=e(176),d=e(66),_=e(20),h=e(43),p=e(251),u=e(15),m=e(11);class v extends c.GestureToolView{connect_signals(){super.connect_signals(),this.model.clear.connect((()=>this._clear()))}get computed_renderers(){const{renderers:e,names:t}=this.model,s=this.plot_model.data_renderers;return(0,d.compute_renderers)(e,s,t)}_computed_renderers_by_data_source(){var e;const t=new Map;for(const s of this.computed_renderers){let n;if(s instanceof i.GlyphRenderer)n=s.data_source;else{if(!(s instanceof a.GraphRenderer))continue;n=s.node_renderer.data_source}const r=null!==(e=t.get(n))&&void 0!==e?e:[];t.set(n,[...r,s])}return t}_select_mode(e){const{shiftKey:t,ctrlKey:s}=e;return t||s?t&&!s?\"append\":!t&&s?\"intersect\":t&&s?\"subtract\":void(0,m.unreachable)():this.model.mode}_keyup(e){e.keyCode==h.Keys.Esc&&this._clear()}_clear(){for(const e of this.computed_renderers)e.get_selection_manager().clear();const e=this.computed_renderers.map((e=>this.plot_view.renderer_view(e)));this.plot_view.request_paint(e)}_select(e,t,s){const n=this._computed_renderers_by_data_source();for(const[,r]of n){const n=r[0].get_selection_manager(),o=[];for(const e of r){const t=this.plot_view.renderer_view(e);null!=t&&o.push(t)}n.select(o,e,t,s)}null!=this.model.callback&&this._emit_callback(e),this._emit_selection_event(e,t)}_emit_selection_event(e,t=!0){const{x_scale:s,y_scale:n}=this.plot_view.frame;let r;switch(e.type){case\"point\":{const{sx:t,sy:o}=e,c=s.invert(t),i=n.invert(o);r=Object.assign(Object.assign({},e),{x:c,y:i});break}case\"span\":{const{sx:t,sy:o}=e,c=s.invert(t),i=n.invert(o);r=Object.assign(Object.assign({},e),{x:c,y:i});break}case\"rect\":{const{sx0:t,sx1:o,sy0:c,sy1:i}=e,[a,l]=s.r_invert(t,o),[d,_]=n.r_invert(c,i);r=Object.assign(Object.assign({},e),{x0:a,y0:d,x1:l,y1:_});break}case\"poly\":{const{sx:t,sy:o}=e,c=s.v_invert(t),i=n.v_invert(o);r=Object.assign(Object.assign({},e),{x:c,y:i});break}}this.plot_model.trigger_event(new p.SelectionGeometry(r,t))}}s.SelectToolView=v,v.__name__=\"SelectToolView\";class b extends c.GestureTool{constructor(e){super(e)}initialize(){super.initialize(),this.clear=new u.Signal0(this,\"clear\")}get menu(){return[{icon:\"bk-tool-icon-replace-mode\",tooltip:\"Replace the current selection\",active:()=>\"replace\"==this.mode,handler:()=>{this.mode=\"replace\",this.active=!0}},{icon:\"bk-tool-icon-append-mode\",tooltip:\"Append to the current selection (Shift)\",active:()=>\"append\"==this.mode,handler:()=>{this.mode=\"append\",this.active=!0}},{icon:\"bk-tool-icon-intersect-mode\",tooltip:\"Intersect with the current selection (Ctrl)\",active:()=>\"intersect\"==this.mode,handler:()=>{this.mode=\"intersect\",this.active=!0}},{icon:\"bk-tool-icon-subtract-mode\",tooltip:\"Subtract from the current selection (Shift+Ctrl)\",active:()=>\"subtract\"==this.mode,handler:()=>{this.mode=\"subtract\",this.active=!0}},null,{icon:\"bk-tool-icon-clear-selection\",tooltip:\"Clear the current selection (Esc)\",handler:()=>{this.clear.emit()}}]}}s.SelectTool=b,o=b,b.__name__=\"SelectTool\",o.define((({String:e,Array:t,Ref:s,Or:n,Auto:r})=>({renderers:[n(t(s(l.DataRenderer)),r),\"auto\"],names:[t(e),[]],mode:[_.SelectionMode,\"replace\"]})))},\n", " function _(t,o,e,s,i){var n;s();const _=t(223),a=t(116),l=t(20),r=t(228);class h extends _.GestureToolView{_match_aspect(t,o,e){const s=e.bbox.aspect,i=e.bbox.h_range.end,n=e.bbox.h_range.start,_=e.bbox.v_range.end,a=e.bbox.v_range.start;let l=Math.abs(t[0]-o[0]),r=Math.abs(t[1]-o[1]);const h=0==r?0:l/r,[c]=h>=s?[1,h/s]:[s/h,1];let m,p,d,b;return t[0]<=o[0]?(m=t[0],p=t[0]+l*c,p>i&&(p=i)):(p=t[0],m=t[0]-l*c,m_&&(d=_)):(d=t[1],b=t[1]-l/s,bnew a.BoxAnnotation({level:\"overlay\",top_units:\"screen\",left_units:\"screen\",bottom_units:\"screen\",right_units:\"screen\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:2,line_dash:[4,4]});class m extends _.GestureTool{constructor(t){super(t),this.tool_name=\"Box Zoom\",this.icon=r.tool_icon_box_zoom,this.event_type=\"pan\",this.default_order=20}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}e.BoxZoomTool=m,n=m,m.__name__=\"BoxZoomTool\",n.prototype.default_view=h,n.define((({Boolean:t,Ref:o})=>({dimensions:[l.Dimensions,\"both\"],overlay:[o(a.BoxAnnotation),c],match_aspect:[t,!1],origin:[l.BoxOrigin,\"corner\"]}))),n.register_alias(\"box_zoom\",(()=>new m({dimensions:\"both\"}))),n.register_alias(\"xbox_zoom\",(()=>new m({dimensions:\"width\"}))),n.register_alias(\"ybox_zoom\",(()=>new m({dimensions:\"height\"})))},\n", " function _(s,e,t,o,_){var l;o();const i=s(378),a=s(217),c=s(381),n=s(43),h=s(228);class r extends i.SelectToolView{constructor(){super(...arguments),this.sxs=[],this.sys=[]}connect_signals(){super.connect_signals(),this.connect(this.model.properties.active.change,(()=>this._active_change()))}_active_change(){this.model.active||this._clear_overlay()}_keyup(s){s.keyCode==n.Keys.Enter&&this._clear_overlay()}_pan_start(s){this.sxs=[],this.sys=[];const{sx:e,sy:t}=s;this._append_overlay(e,t)}_pan(s){const[e,t]=this.plot_view.frame.bbox.clip(s.sx,s.sy);this._append_overlay(e,t),this.model.select_every_mousemove&&this._do_select(this.sxs,this.sys,!1,this._select_mode(s))}_pan_end(s){const{sxs:e,sys:t}=this;this._clear_overlay(),this._do_select(e,t,!0,this._select_mode(s)),this.plot_view.state.push(\"lasso_select\",{selection:this.plot_view.get_selection()})}_append_overlay(s,e){const{sxs:t,sys:o}=this;t.push(s),o.push(e),this.model.overlay.update({xs:t,ys:o})}_clear_overlay(){this.sxs=[],this.sys=[],this.model.overlay.update({xs:this.sxs,ys:this.sys})}_do_select(s,e,t,o){const _={type:\"poly\",sx:s,sy:e};this._select(_,t,o)}}t.LassoSelectToolView=r,r.__name__=\"LassoSelectToolView\";class y extends i.SelectTool{constructor(s){super(s),this.tool_name=\"Lasso Select\",this.icon=h.tool_icon_lasso_select,this.event_type=\"pan\",this.default_order=12}}t.LassoSelectTool=y,l=y,y.__name__=\"LassoSelectTool\",l.prototype.default_view=r,l.define((({Boolean:s,Ref:e})=>({select_every_mousemove:[s,!0],overlay:[e(a.PolyAnnotation),c.DEFAULT_POLY_OVERLAY]}))),l.register_alias(\"lasso_select\",(()=>new y))},\n", " function _(e,t,s,l,o){var i;l();const a=e(378),_=e(217),c=e(43),n=e(9),h=e(228);class y extends a.SelectToolView{initialize(){super.initialize(),this.data={sx:[],sy:[]}}connect_signals(){super.connect_signals(),this.connect(this.model.properties.active.change,(()=>this._active_change()))}_active_change(){this.model.active||this._clear_data()}_keyup(e){e.keyCode==c.Keys.Enter&&this._clear_data()}_doubletap(e){this._do_select(this.data.sx,this.data.sy,!0,this._select_mode(e)),this.plot_view.state.push(\"poly_select\",{selection:this.plot_view.get_selection()}),this._clear_data()}_clear_data(){this.data={sx:[],sy:[]},this.model.overlay.update({xs:[],ys:[]})}_tap(e){const{sx:t,sy:s}=e;this.plot_view.frame.bbox.contains(t,s)&&(this.data.sx.push(t),this.data.sy.push(s),this.model.overlay.update({xs:(0,n.copy)(this.data.sx),ys:(0,n.copy)(this.data.sy)}))}_do_select(e,t,s,l){const o={type:\"poly\",sx:e,sy:t};this._select(o,s,l)}}s.PolySelectToolView=y,y.__name__=\"PolySelectToolView\";s.DEFAULT_POLY_OVERLAY=()=>new _.PolyAnnotation({level:\"overlay\",xs_units:\"screen\",ys_units:\"screen\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:2,line_dash:[4,4]});class d extends a.SelectTool{constructor(e){super(e),this.tool_name=\"Poly Select\",this.icon=h.tool_icon_polygon_select,this.event_type=\"tap\",this.default_order=11}}s.PolySelectTool=d,i=d,d.__name__=\"PolySelectTool\",i.prototype.default_view=y,i.define((({Ref:e})=>({overlay:[e(_.PolyAnnotation),s.DEFAULT_POLY_OVERLAY]}))),i.register_alias(\"poly_select\",(()=>new d))},\n", " function _(e,t,s,i,r){var n;i();const _=e(20),d=e(383),o=e(228);class l extends d.LineToolView{constructor(){super(...arguments),this._drawing=!1}_doubletap(e){if(!this.model.active)return;const t=this.model.renderers;for(const s of t){1==this._select_event(e,\"replace\",[s]).length&&(this._selected_renderer=s)}this._show_intersections(),this._update_line_cds()}_show_intersections(){if(!this.model.active)return;if(null==this._selected_renderer)return;if(!this.model.renderers.length)return this._set_intersection([],[]),this._selected_renderer=null,void(this._drawing=!1);const e=this._selected_renderer.data_source,t=this._selected_renderer.glyph,[s,i]=[t.x.field,t.y.field],r=e.get_array(s),n=e.get_array(i);this._set_intersection(r,n)}_tap(e){const t=this.model.intersection_renderer;if(null==this._map_drag(e.sx,e.sy,t))return;if(this._drawing&&this._selected_renderer){const s=this._select_mode(e);if(0==this._select_event(e,s,[t]).length)return}const s=this._select_mode(e);this._select_event(e,s,[t]),this._select_event(e,s,this.model.renderers)}_update_line_cds(){if(null==this._selected_renderer)return;const e=this.model.intersection_renderer.glyph,t=this.model.intersection_renderer.data_source,[s,i]=[e.x.field,e.y.field];if(s&&i){const e=t.data[s],r=t.data[i];this._selected_renderer.data_source.data[s]=e,this._selected_renderer.data_source.data[i]=r}this._emit_cds_changes(this._selected_renderer.data_source,!0,!0,!1)}_pan_start(e){this._select_event(e,\"append\",[this.model.intersection_renderer]),this._basepoint=[e.sx,e.sy]}_pan(e){null!=this._basepoint&&(this._drag_points(e,[this.model.intersection_renderer],this.model.dimensions),this._selected_renderer&&this._selected_renderer.data_source.change.emit())}_pan_end(e){null!=this._basepoint&&(this._drag_points(e,[this.model.intersection_renderer]),this._emit_cds_changes(this.model.intersection_renderer.data_source,!1,!0,!0),this._selected_renderer&&this._emit_cds_changes(this._selected_renderer.data_source),this._basepoint=null)}activate(){this._drawing=!0}deactivate(){this._selected_renderer&&(this._drawing&&(this._drawing=!1),this._hide_intersections())}}s.LineEditToolView=l,l.__name__=\"LineEditToolView\";class h extends d.LineTool{constructor(e){super(e),this.tool_name=\"Line Edit Tool\",this.icon=o.tool_icon_line_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=4}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}s.LineEditTool=h,n=h,h.__name__=\"LineEditTool\",n.prototype.default_view=l,n.define((()=>({dimensions:[_.Dimensions,\"both\"]})))},\n", " function _(e,i,n,t,s){var o;t();const r=e(8),_=e(370);class d extends _.EditToolView{_set_intersection(e,i){const n=this.model.intersection_renderer.glyph,t=this.model.intersection_renderer.data_source,[s,o]=[n.x.field,n.y.field];s&&((0,r.isArray)(e)?t.data[s]=e:n.x={value:e}),o&&((0,r.isArray)(i)?t.data[o]=i:n.y={value:i}),this._emit_cds_changes(t,!0,!0,!1)}_hide_intersections(){this._set_intersection([],[])}}n.LineToolView=d,d.__name__=\"LineToolView\";class a extends _.EditTool{constructor(e){super(e)}}n.LineTool=a,o=a,a.__name__=\"LineTool\",o.define((({AnyRef:e})=>({intersection_renderer:[e()]})))},\n", " function _(t,s,n,e,i){e();const o=t(1);var a;const _=t(223),l=t(20),r=(0,o.__importStar)(t(228));function h(t,s,n){const e=new Map;for(const[i,o]of t){const[t,a]=o.r_invert(s,n);e.set(i,{start:t,end:a})}return e}n.update_ranges=h;class d extends _.GestureToolView{_pan_start(t){var s;this.last_dx=0,this.last_dy=0;const{sx:n,sy:e}=t,i=this.plot_view.frame.bbox;if(!i.contains(n,e)){const t=i.h_range,s=i.v_range;(nt.end)&&(this.v_axis_only=!0),(es.end)&&(this.h_axis_only=!0)}null===(s=this.model.document)||void 0===s||s.interactive_start(this.plot_model)}_pan(t){var s;this._update(t.deltaX,t.deltaY),null===(s=this.model.document)||void 0===s||s.interactive_start(this.plot_model)}_pan_end(t){this.h_axis_only=!1,this.v_axis_only=!1,null!=this.pan_info&&this.plot_view.state.push(\"pan\",{range:this.pan_info}),this.plot_view.trigger_ranges_update_event()}_update(t,s){const n=this.plot_view.frame,e=t-this.last_dx,i=s-this.last_dy,o=n.bbox.h_range,a=o.start-e,_=o.end-e,l=n.bbox.v_range,r=l.start-i,d=l.end-i,p=this.model.dimensions;let c,u,m,v,x,g;\"width\"!=p&&\"both\"!=p||this.v_axis_only?(c=o.start,u=o.end,m=0):(c=a,u=_,m=-e),\"height\"!=p&&\"both\"!=p||this.h_axis_only?(v=l.start,x=l.end,g=0):(v=r,x=d,g=-i),this.last_dx=t,this.last_dy=s;const{x_scales:w,y_scales:y}=n,f=h(w,c,u),b=h(y,v,x);this.pan_info={xrs:f,yrs:b,sdx:m,sdy:g},this.plot_view.update_range(this.pan_info,{panning:!0})}}n.PanToolView=d,d.__name__=\"PanToolView\";class p extends _.GestureTool{constructor(t){super(t),this.tool_name=\"Pan\",this.event_type=\"pan\",this.default_order=10}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}n.PanTool=p,a=p,p.__name__=\"PanTool\",a.prototype.default_view=d,a.define((()=>({dimensions:[l.Dimensions,\"both\",{on_update(t,s){switch(t){case\"both\":s.icon=r.tool_icon_pan;break;case\"width\":s.icon=r.tool_icon_xpan;break;case\"height\":s.icon=r.tool_icon_ypan}}}]}))),a.register_alias(\"pan\",(()=>new p({dimensions:\"both\"}))),a.register_alias(\"xpan\",(()=>new p({dimensions:\"width\"}))),a.register_alias(\"ypan\",(()=>new p({dimensions:\"height\"})))},\n", " function _(e,t,i,s,n){var l;s();const a=e(116),r=e(58),o=e(19),_=e(223),h=e(228);function d(e){switch(e){case 1:return 2;case 2:return 1;case 4:return 5;case 5:return 4;default:return e}}function u(e,t,i,s){if(null==t)return!1;const n=i.compute(t);return Math.abs(e-n)n.right)&&(l=!1)}if(null!=n.bottom&&null!=n.top){const e=s.invert(t);(en.top)&&(l=!1)}return l}function g(e,t,i){let s=0;return e>=i.start&&e<=i.end&&(s+=1),t>=i.start&&t<=i.end&&(s+=1),s}function y(e,t,i,s){const n=t.compute(e),l=t.invert(n+i);return l>=s.start&&l<=s.end?l:e}function f(e,t,i){return e>t.start?(t.end=e,i):(t.end=t.start,t.start=e,d(i))}function v(e,t,i){return e=o&&(e.start=a,e.end=r)}i.flip_side=d,i.is_near=u,i.is_inside=c,i.sides_inside=g,i.compute_value=y,i.update_range_end_side=f,i.update_range_start_side=v,i.update_range=m;class p extends _.GestureToolView{initialize(){super.initialize(),this.side=0,this.model.update_overlay_from_ranges()}connect_signals(){super.connect_signals(),null!=this.model.x_range&&this.connect(this.model.x_range.change,(()=>this.model.update_overlay_from_ranges())),null!=this.model.y_range&&this.connect(this.model.y_range.change,(()=>this.model.update_overlay_from_ranges()))}_pan_start(e){this.last_dx=0,this.last_dy=0;const t=this.model.x_range,i=this.model.y_range,{frame:s}=this.plot_view,n=s.x_scale,l=s.y_scale,r=this.model.overlay,{left:o,right:_,top:h,bottom:d}=r,g=this.model.overlay.line_width+a.EDGE_TOLERANCE;null!=t&&this.model.x_interaction&&(u(e.sx,o,n,g)?this.side=1:u(e.sx,_,n,g)?this.side=2:c(e.sx,e.sy,n,l,r)&&(this.side=3)),null!=i&&this.model.y_interaction&&(0==this.side&&u(e.sy,d,l,g)&&(this.side=4),0==this.side&&u(e.sy,h,l,g)?this.side=5:c(e.sx,e.sy,n,l,this.model.overlay)&&(3==this.side?this.side=7:this.side=6))}_pan(e){const t=this.plot_view.frame,i=e.deltaX-this.last_dx,s=e.deltaY-this.last_dy,n=this.model.x_range,l=this.model.y_range,a=t.x_scale,r=t.y_scale;if(null!=n)if(3==this.side||7==this.side)m(n,a,i,t.x_range);else if(1==this.side){const e=y(n.start,a,i,t.x_range);this.side=v(e,n,this.side)}else if(2==this.side){const e=y(n.end,a,i,t.x_range);this.side=f(e,n,this.side)}if(null!=l)if(6==this.side||7==this.side)m(l,r,s,t.y_range);else if(4==this.side){const e=y(l.start,r,s,t.y_range);this.side=v(e,l,this.side)}else if(5==this.side){const e=y(l.end,r,s,t.y_range);this.side=f(e,l,this.side)}this.last_dx=e.deltaX,this.last_dy=e.deltaY}_pan_end(e){this.side=0,this.plot_view.trigger_ranges_update_event()}}i.RangeToolView=p,p.__name__=\"RangeToolView\";const x=()=>new a.BoxAnnotation({level:\"overlay\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:.5,line_dash:[2,2]});class w extends _.GestureTool{constructor(e){super(e),this.tool_name=\"Range Tool\",this.icon=h.tool_icon_range,this.event_type=\"pan\",this.default_order=1}initialize(){super.initialize(),this.overlay.in_cursor=\"grab\",this.overlay.ew_cursor=null!=this.x_range&&this.x_interaction?\"ew-resize\":null,this.overlay.ns_cursor=null!=this.y_range&&this.y_interaction?\"ns-resize\":null}update_overlay_from_ranges(){null==this.x_range&&null==this.y_range&&(this.overlay.left=null,this.overlay.right=null,this.overlay.bottom=null,this.overlay.top=null,o.logger.warn(\"RangeTool not configured with any Ranges.\")),null==this.x_range?(this.overlay.left=null,this.overlay.right=null):(this.overlay.left=this.x_range.start,this.overlay.right=this.x_range.end),null==this.y_range?(this.overlay.bottom=null,this.overlay.top=null):(this.overlay.bottom=this.y_range.start,this.overlay.top=this.y_range.end)}}i.RangeTool=w,l=w,w.__name__=\"RangeTool\",l.prototype.default_view=p,l.define((({Boolean:e,Ref:t,Nullable:i})=>({x_range:[i(t(r.Range1d)),null],x_interaction:[e,!0],y_range:[i(t(r.Range1d)),null],y_interaction:[e,!0],overlay:[t(a.BoxAnnotation),x]})))},\n", " function _(e,t,s,o,i){var l;o();const a=e(378),n=e(20),c=e(228);class _ extends a.SelectToolView{_tap(e){\"tap\"==this.model.gesture&&this._handle_tap(e)}_doubletap(e){\"doubletap\"==this.model.gesture&&this._handle_tap(e)}_handle_tap(e){const{sx:t,sy:s}=e,o={type:\"point\",sx:t,sy:s};this._select(o,!0,this._select_mode(e))}_select(e,t,s){const{callback:o}=this.model;if(\"select\"==this.model.behavior){const i=this._computed_renderers_by_data_source();for(const[,l]of i){const i=l[0].get_selection_manager(),a=l.map((e=>this.plot_view.renderer_view(e))).filter((e=>null!=e));if(i.select(a,e,t,s)&&null!=o){const t=a[0].coordinates.x_scale.invert(e.sx),s=a[0].coordinates.y_scale.invert(e.sy),l={geometries:Object.assign(Object.assign({},e),{x:t,y:s}),source:i.source};o.execute(this.model,l)}}this._emit_selection_event(e),this.plot_view.state.push(\"tap\",{selection:this.plot_view.get_selection()})}else for(const t of this.computed_renderers){const s=this.plot_view.renderer_view(t);if(null==s)continue;const i=t.get_selection_manager();if(i.inspect(s,e)&&null!=o){const t=s.coordinates.x_scale.invert(e.sx),l=s.coordinates.y_scale.invert(e.sy),a={geometries:Object.assign(Object.assign({},e),{x:t,y:l}),source:i.source};o.execute(this.model,a)}}}}s.TapToolView=_,_.__name__=\"TapToolView\";class r extends a.SelectTool{constructor(e){super(e),this.tool_name=\"Tap\",this.icon=c.tool_icon_tap_select,this.event_type=\"tap\",this.default_order=10}}s.TapTool=r,l=r,r.__name__=\"TapTool\",l.prototype.default_view=_,l.define((({Any:e,Enum:t,Nullable:s})=>({behavior:[n.TapBehavior,\"select\"],gesture:[t(\"tap\",\"doubletap\"),\"tap\"],callback:[s(e)]}))),l.register_alias(\"click\",(()=>new r({behavior:\"inspect\"}))),l.register_alias(\"tap\",(()=>new r)),l.register_alias(\"doubletap\",(()=>new r({gesture:\"doubletap\"})))},\n", " function _(e,t,s,n,i){var a;n();const o=e(223),l=e(20),_=e(228),r=e(384);class h extends o.GestureToolView{_scroll(e){let t=this.model.speed*e.delta;t>.9?t=.9:t<-.9&&(t=-.9),this._update_ranges(t)}_update_ranges(e){var t;const{frame:s}=this.plot_view,n=s.bbox.h_range,i=s.bbox.v_range,[a,o]=[n.start,n.end],[l,_]=[i.start,i.end];let h,d,p,c;switch(this.model.dimension){case\"height\":{const t=Math.abs(_-l);h=a,d=o,p=l-t*e,c=_-t*e;break}case\"width\":{const t=Math.abs(o-a);h=a-t*e,d=o-t*e,p=l,c=_;break}}const{x_scales:g,y_scales:u}=s,w={xrs:(0,r.update_ranges)(g,h,d),yrs:(0,r.update_ranges)(u,p,c),factor:e};this.plot_view.state.push(\"wheel_pan\",{range:w}),this.plot_view.update_range(w,{scrolling:!0}),null===(t=this.model.document)||void 0===t||t.interactive_start(this.plot_model,(()=>this.plot_view.trigger_ranges_update_event()))}}s.WheelPanToolView=h,h.__name__=\"WheelPanToolView\";class d extends o.GestureTool{constructor(e){super(e),this.tool_name=\"Wheel Pan\",this.icon=_.tool_icon_wheel_pan,this.event_type=\"scroll\",this.default_order=12}get tooltip(){return this._get_dim_tooltip(this.dimension)}}s.WheelPanTool=d,a=d,d.__name__=\"WheelPanTool\",a.prototype.default_view=h,a.define((()=>({dimension:[l.Dimension,\"width\"]}))),a.internal((({Number:e})=>({speed:[e,.001]}))),a.register_alias(\"xwheel_pan\",(()=>new d({dimension:\"width\"}))),a.register_alias(\"ywheel_pan\",(()=>new d({dimension:\"height\"})))},\n", " function _(e,o,t,s,i){var n;s();const l=e(223),_=e(368),h=e(20),a=e(27),r=e(228);class m extends l.GestureToolView{_pinch(e){const{sx:o,sy:t,scale:s,ctrlKey:i,shiftKey:n}=e;let l;l=s>=1?20*(s-1):-20/s,this._scroll({type:\"wheel\",sx:o,sy:t,delta:l,ctrlKey:i,shiftKey:n})}_scroll(e){var o;const{frame:t}=this.plot_view,s=t.bbox.h_range,i=t.bbox.v_range,{sx:n,sy:l}=e,h=this.model.dimensions,a=(\"width\"==h||\"both\"==h)&&s.startthis.plot_view.trigger_ranges_update_event()))}}t.WheelZoomToolView=m,m.__name__=\"WheelZoomToolView\";class d extends l.GestureTool{constructor(e){super(e),this.tool_name=\"Wheel Zoom\",this.icon=r.tool_icon_wheel_zoom,this.event_type=a.is_mobile?\"pinch\":\"scroll\",this.default_order=10}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}t.WheelZoomTool=d,n=d,d.__name__=\"WheelZoomTool\",n.prototype.default_view=m,n.define((({Boolean:e,Number:o})=>({dimensions:[h.Dimensions,\"both\"],maintain_focus:[e,!0],zoom_on_axis:[e,!0],speed:[o,1/600]}))),n.register_alias(\"wheel_zoom\",(()=>new d({dimensions:\"both\"}))),n.register_alias(\"xwheel_zoom\",(()=>new d({dimensions:\"width\"}))),n.register_alias(\"ywheel_zoom\",(()=>new d({dimensions:\"height\"})))},\n", " function _(i,e,s,t,o){var n;t();const l=i(232),a=i(219),h=i(20),r=i(13),_=i(228);class c extends l.InspectToolView{_move(i){if(!this.model.active)return;const{sx:e,sy:s}=i;this.plot_view.frame.bbox.contains(e,s)?this._update_spans(e,s):this._update_spans(null,null)}_move_exit(i){this._update_spans(null,null)}_update_spans(i,e){const s=this.model.dimensions;\"width\"!=s&&\"both\"!=s||(this.model.spans.width.location=e),\"height\"!=s&&\"both\"!=s||(this.model.spans.height.location=i)}}s.CrosshairToolView=c,c.__name__=\"CrosshairToolView\";class p extends l.InspectTool{constructor(i){super(i),this.tool_name=\"Crosshair\",this.icon=_.tool_icon_crosshair}get tooltip(){return this._get_dim_tooltip(this.dimensions)}get synthetic_renderers(){return(0,r.values)(this.spans)}}s.CrosshairTool=p,n=p,p.__name__=\"CrosshairTool\",(()=>{function i(i,e){return new a.Span({for_hover:!0,dimension:e,location_units:\"screen\",level:\"overlay\",line_color:i.line_color,line_width:i.line_width,line_alpha:i.line_alpha})}n.prototype.default_view=c,n.define((({Alpha:i,Number:e,Color:s})=>({dimensions:[h.Dimensions,\"both\"],line_color:[s,\"black\"],line_width:[e,1],line_alpha:[i,1]}))),n.internal((({Struct:e,Ref:s})=>({spans:[e({width:s(a.Span),height:s(a.Span)}),e=>({width:i(e,\"width\"),height:i(e,\"height\")})]}))),n.register_alias(\"crosshair\",(()=>new p))})()},\n", " function _(e,s,t,r,n){var o;r();const a=e(53),u=e(13),c=e(34);class i extends a.Model{constructor(e){super(e)}get values(){return(0,u.values)(this.args)}_make_code(e,s,t,r){return new Function(...(0,u.keys)(this.args),e,s,t,(0,c.use_strict)(r))}format(e,s,t){return this._make_code(\"value\",\"format\",\"special_vars\",this.code)(...this.values,e,s,t)}}t.CustomJSHover=i,o=i,i.__name__=\"CustomJSHover\",o.define((({Unknown:e,String:s,Dict:t})=>({args:[t(e),{}],code:[s,\"\"]})))},\n", " function _(e,t,n,s,o){s();const i=e(1);var r;const l=e(232),a=e(390),c=e(241),_=e(175),d=e(339),p=e(176),h=e(177),u=e(283),m=(0,i.__importStar)(e(185)),y=e(152),f=e(43),v=e(22),x=e(13),w=e(234),g=e(8),b=e(113),k=e(20),C=e(228),S=e(15),T=e(66),$=(0,i.__importStar)(e(242)),R=e(392);function M(e,t,n,s,o,i){const r={x:o[e],y:i[e]},l={x:o[e+1],y:i[e+1]};let a,c;if(\"span\"==t.type)\"h\"==t.direction?(a=Math.abs(r.x-n),c=Math.abs(l.x-n)):(a=Math.abs(r.y-s),c=Math.abs(l.y-s));else{const e={x:n,y:s};a=m.dist_2_pts(r,e),c=m.dist_2_pts(l,e)}return adelete this._template_el)),this.on_change([e,t,n],(async()=>await this._update_ttmodels()))}async _update_ttmodels(){const{_ttmodels:e,computed_renderers:t}=this;e.clear();const{tooltips:n}=this.model;if(null!=n)for(const t of this.computed_renderers){const s=new c.Tooltip({custom:(0,g.isString)(n)||(0,g.isFunction)(n),attachment:this.model.attachment,show_arrow:this.model.show_arrow});t instanceof _.GlyphRenderer?e.set(t,s):t instanceof d.GraphRenderer&&(e.set(t.node_renderer,s),e.set(t.edge_renderer,s))}const s=await(0,b.build_views)(this._ttviews,[...e.values()],{parent:this.plot_view});for(const e of s)e.render();const o=[...function*(){for(const e of t)e instanceof _.GlyphRenderer?yield e:e instanceof d.GraphRenderer&&(yield e.node_renderer,yield e.edge_renderer)}()],i=this._slots.get(this._update);if(null!=i){const e=new Set(o.map((e=>e.data_source)));S.Signal.disconnect_receiver(this,i,e)}for(const e of o)this.connect(e.data_source.inspect,this._update)}get computed_renderers(){const{renderers:e,names:t}=this.model,n=this.plot_model.data_renderers;return(0,T.compute_renderers)(e,n,t)}get ttmodels(){return this._ttmodels}_clear(){this._inspect(1/0,1/0);for(const[,e]of this.ttmodels)e.clear()}_move(e){if(!this.model.active)return;const{sx:t,sy:n}=e;this.plot_view.frame.bbox.contains(t,n)?this._inspect(t,n):this._clear()}_move_exit(){this._clear()}_inspect(e,t){let n;if(\"mouse\"==this.model.mode)n={type:\"point\",sx:e,sy:t};else{n={type:\"span\",direction:\"vline\"==this.model.mode?\"h\":\"v\",sx:e,sy:t}}for(const e of this.computed_renderers){const t=e.get_selection_manager(),s=this.plot_view.renderer_view(e);null!=s&&t.inspect(s,n)}this._emit_callback(n)}_update([e,{geometry:t}]){var n,s;if(!this.model.active)return;if(\"point\"!=t.type&&\"span\"!=t.type)return;if(!(e instanceof _.GlyphRenderer))return;if(\"ignore\"==this.model.muted_policy&&e.muted)return;const o=this.ttmodels.get(e);if(null==o)return;const i=e.get_selection_manager(),r=i.inspectors.get(e),l=e.view.convert_selection_to_subset(r);if(r.is_empty())return void o.clear();const a=i.source,c=this.plot_view.renderer_view(e);if(null==c)return;const{sx:d,sy:p}=t,m=c.coordinates.x_scale,y=c.coordinates.y_scale,v=m.invert(d),w=y.invert(p),{glyph:g}=c,b=[];if(g instanceof h.LineView)for(const n of l.line_indices){let s,o,i=g._x[n+1],r=g._y[n+1],c=n;switch(this.model.line_policy){case\"interp\":[i,r]=g.get_interpolation_hit(n,t),s=m.compute(i),o=y.compute(r);break;case\"prev\":[[s,o],c]=G(g.sx,g.sy,n);break;case\"next\":[[s,o],c]=G(g.sx,g.sy,n+1);break;case\"nearest\":[[s,o],c]=M(n,t,d,p,g.sx,g.sy),i=g._x[c],r=g._y[c];break;default:[s,o]=[d,p]}const _={index:c,x:v,y:w,sx:d,sy:p,data_x:i,data_y:r,rx:s,ry:o,indices:l.line_indices,name:e.name};b.push([s,o,this._render_tooltips(a,c,_)])}for(const t of r.image_indices){const n={index:t.index,x:v,y:w,sx:d,sy:p,name:e.name},s=this._render_tooltips(a,t,n);b.push([d,p,s])}for(const o of l.indices)if(g instanceof u.MultiLineView&&!(0,x.isEmpty)(l.multiline_indices))for(const n of l.multiline_indices[o.toString()]){let s,i,r,c=g._xs.get(o)[n],h=g._ys.get(o)[n],u=n;switch(this.model.line_policy){case\"interp\":[c,h]=g.get_interpolation_hit(o,n,t),s=m.compute(c),i=y.compute(h);break;case\"prev\":[[s,i],u]=G(g.sxs.get(o),g.sys.get(o),n);break;case\"next\":[[s,i],u]=G(g.sxs.get(o),g.sys.get(o),n+1);break;case\"nearest\":[[s,i],u]=M(n,t,d,p,g.sxs.get(o),g.sys.get(o)),c=g._xs.get(o)[u],h=g._ys.get(o)[u];break;default:throw new Error(\"shouldn't have happened\")}r=e instanceof _.GlyphRenderer?e.view.convert_indices_from_subset([o])[0]:o;const f={index:r,x:v,y:w,sx:d,sy:p,data_x:c,data_y:h,segment_index:u,indices:l.multiline_indices,name:e.name};b.push([s,i,this._render_tooltips(a,r,f)])}else{const t=null===(n=g._x)||void 0===n?void 0:n[o],i=null===(s=g._y)||void 0===s?void 0:s[o];let r,c,h;if(\"snap_to_data\"==this.model.point_policy){let e=g.get_anchor_point(this.model.anchor,o,[d,p]);if(null==e&&(e=g.get_anchor_point(\"center\",o,[d,p]),null==e))continue;r=e.x,c=e.y}else[r,c]=[d,p];h=e instanceof _.GlyphRenderer?e.view.convert_indices_from_subset([o])[0]:o;const u={index:h,x:v,y:w,sx:d,sy:p,data_x:t,data_y:i,indices:l.indices,name:e.name};b.push([r,c,this._render_tooltips(a,h,u)])}if(0==b.length)o.clear();else{const{content:e}=o;(0,f.empty)(o.content);for(const[,,t]of b)null!=t&&e.appendChild(t);const[t,n]=b[b.length-1];o.setv({position:[t,n]},{check_eq:!1})}}_emit_callback(e){const{callback:t}=this.model;if(null!=t)for(const n of this.computed_renderers){if(!(n instanceof _.GlyphRenderer))continue;const s=this.plot_view.renderer_view(n);if(null==s)continue;const{x_scale:o,y_scale:i}=s.coordinates,r=o.invert(e.sx),l=i.invert(e.sy),a=n.data_source.inspected;t.execute(this.model,{geometry:Object.assign({x:r,y:l},e),renderer:n,index:a})}}_create_template(e){const t=(0,f.div)({style:{display:\"table\",borderSpacing:\"2px\"}});for(const[n]of e){const e=(0,f.div)({style:{display:\"table-row\"}});t.appendChild(e);const s=(0,f.div)({style:{display:\"table-cell\"},class:$.tooltip_row_label},0!=n.length?`${n}: `:\"\");e.appendChild(s);const o=(0,f.span)();o.dataset.value=\"\";const i=(0,f.span)({class:$.tooltip_color_block},\" \");i.dataset.swatch=\"\",(0,f.undisplay)(i);const r=(0,f.div)({style:{display:\"table-cell\"},class:$.tooltip_row_value},o,i);e.appendChild(r)}return t}_render_template(e,t,n,s,o){const i=e.cloneNode(!0),r=i.querySelectorAll(\"[data-value]\"),l=i.querySelectorAll(\"[data-swatch]\"),a=/\\$color(\\[.*\\])?:(\\w*)/,c=/\\$swatch:(\\w*)/;for(const[[,e],i]of(0,w.enumerate)(t)){const t=e.match(c),_=e.match(a);if(null!=t||null!=_){if(null!=t){const[,e]=t,o=n.get_column(e);if(null==o)r[i].textContent=`${e} unknown`;else{const e=(0,g.isNumber)(s)?o[s]:null;null!=e&&(l[i].style.backgroundColor=(0,v.color2css)(e),(0,f.display)(l[i]))}}if(null!=_){const[,e=\"\",t]=_,o=n.get_column(t);if(null==o){r[i].textContent=`${t} unknown`;continue}const a=e.indexOf(\"hex\")>=0,c=e.indexOf(\"swatch\")>=0,d=(0,g.isNumber)(s)?o[s]:null;if(null==d){r[i].textContent=\"(null)\";continue}r[i].textContent=a?(0,v.color2hex)(d):(0,v.color2css)(d),c&&(l[i].style.backgroundColor=(0,v.color2css)(d),(0,f.display)(l[i]))}}else{const t=(0,y.replace_placeholders)(e.replace(\"$~\",\"$data_\"),n,s,this.model.formatters,o);if((0,g.isString)(t))r[i].textContent=t;else for(const e of t)r[i].appendChild(e)}}return i}_render_tooltips(e,t,n){var s;const{tooltips:o}=this.model;if((0,g.isString)(o)){const s=(0,y.replace_placeholders)({html:o},e,t,this.model.formatters,n);return(0,f.div)(s)}if((0,g.isFunction)(o))return o(e,n);if(o instanceof R.Template)return this._template_view.update(e,t,n),this._template_view.el;if(null!=o){const i=null!==(s=this._template_el)&&void 0!==s?s:this._template_el=this._create_template(o);return this._render_template(i,o,e,t,n)}return null}}n.HoverToolView=z,z.__name__=\"HoverToolView\";class A extends l.InspectTool{constructor(e){super(e),this.tool_name=\"Hover\",this.icon=C.tool_icon_hover}}n.HoverTool=A,r=A,A.__name__=\"HoverTool\",r.prototype.default_view=z,r.define((({Any:e,Boolean:t,String:n,Array:s,Tuple:o,Dict:i,Or:r,Ref:l,Function:c,Auto:_,Nullable:d})=>({tooltips:[d(r(l(R.Template),n,s(o(n,n)),c())),[[\"index\",\"$index\"],[\"data (x, y)\",\"($x, $y)\"],[\"screen (x, y)\",\"($sx, $sy)\"]]],formatters:[i(r(l(a.CustomJSHover),y.FormatterType)),{}],renderers:[r(s(l(p.DataRenderer)),_),\"auto\"],names:[s(n),[]],mode:[k.HoverMode,\"mouse\"],muted_policy:[k.MutedPolicy,\"show\"],point_policy:[k.PointPolicy,\"snap_to_data\"],line_policy:[k.LinePolicy,\"nearest\"],show_arrow:[t,!0],anchor:[k.Anchor,\"center\"],attachment:[k.TooltipAttachment,\"horizontal\"],callback:[d(e)]}))),r.register_alias(\"hover\",(()=>new A))},\n", " function _(e,t,s,n,a){n();const l=e(1);var i,_,o,r,c,d,p,u,m,w,f,h,x;const v=e(53),y=e(309),V=e(393);a(\"Styles\",V.Styles);const g=e(43),T=e(42),b=e(226),R=e(113),D=e(8),M=e(13),S=(0,l.__importStar)(e(242)),O=e(152);class C extends b.DOMView{}s.DOMNodeView=C,C.__name__=\"DOMNodeView\";class z extends v.Model{constructor(e){super(e)}}s.DOMNode=z,z.__name__=\"DOMNode\",z.__module__=\"bokeh.models.dom\";class P extends C{render(){super.render(),this.el.textContent=this.model.content}_createElement(){return document.createTextNode(\"\")}}s.TextView=P,P.__name__=\"TextView\";class A extends z{constructor(e){super(e)}}s.Text=A,i=A,A.__name__=\"Text\",i.prototype.default_view=P,i.define((({String:e})=>({content:[e,\"\"]})));class N extends C{}s.PlaceholderView=N,N.__name__=\"PlaceholderView\",N.tag_name=\"span\";class E extends z{constructor(e){super(e)}}s.Placeholder=E,_=E,E.__name__=\"Placeholder\",_.define((({})=>({})));class G extends N{update(e,t,s){this.el.textContent=t.toString()}}s.IndexView=G,G.__name__=\"IndexView\";class I extends E{constructor(e){super(e)}}s.Index=I,o=I,I.__name__=\"Index\",o.prototype.default_view=G,o.define((({})=>({})));class k extends N{update(e,t,s){const n=(0,O._get_column_value)(this.model.field,e,t),a=null==n?\"???\":`${n}`;this.el.textContent=a}}s.ValueRefView=k,k.__name__=\"ValueRefView\";class $ extends E{constructor(e){super(e)}}s.ValueRef=$,r=$,$.__name__=\"ValueRef\",r.prototype.default_view=k,r.define((({String:e})=>({field:[e]})));class B extends k{render(){super.render(),this.value_el=(0,g.span)(),this.swatch_el=(0,g.span)({class:S.tooltip_color_block},\" \"),this.el.appendChild(this.value_el),this.el.appendChild(this.swatch_el)}update(e,t,s){const n=(0,O._get_column_value)(this.model.field,e,t),a=null==n?\"???\":`${n}`;this.el.textContent=a}}s.ColorRefView=B,B.__name__=\"ColorRefView\";class L extends ${constructor(e){super(e)}}s.ColorRef=L,c=L,L.__name__=\"ColorRef\",c.prototype.default_view=B,c.define((({Boolean:e})=>({hex:[e,!0],swatch:[e,!0]})));class j extends C{constructor(){super(...arguments),this.child_views=new Map}async lazy_initialize(){await super.lazy_initialize();const e=this.model.children.filter((e=>e instanceof v.Model));await(0,R.build_views)(this.child_views,e,{parent:this})}render(){super.render();const{style:e}=this.model;if(null!=e)if(e instanceof V.Styles)for(const t of e){const e=t.get_value();if((0,D.isString)(e)){const s=t.attr.replace(/_/g,\"-\");this.el.style.hasOwnProperty(s)&&this.el.style.setProperty(s,e)}}else for(const[t,s]of(0,M.entries)(e)){const e=t.replace(/_/g,\"-\");this.el.style.hasOwnProperty(e)&&this.el.style.setProperty(e,s)}for(const e of this.model.children)if((0,D.isString)(e)){const t=document.createTextNode(e);this.el.appendChild(t)}else{this.child_views.get(e).renderTo(this.el)}}}s.DOMElementView=j,j.__name__=\"DOMElementView\";class q extends z{constructor(e){super(e)}}s.DOMElement=q,d=q,q.__name__=\"DOMElement\",d.define((({String:e,Array:t,Dict:s,Or:n,Nullable:a,Ref:l})=>({style:[a(n(l(V.Styles),s(e))),null],children:[t(n(e,l(z),l(y.LayoutDOM))),[]]})));class F extends T.View{}s.ActionView=F,F.__name__=\"ActionView\";class H extends v.Model{constructor(e){super(e)}}s.Action=H,p=H,H.__name__=\"Action\",H.__module__=\"bokeh.models.dom\",p.define((({})=>({})));class J extends j{constructor(){super(...arguments),this.action_views=new Map}async lazy_initialize(){await super.lazy_initialize(),await(0,R.build_views)(this.action_views,this.model.actions,{parent:this})}remove(){(0,R.remove_views)(this.action_views),super.remove()}update(e,t,s={}){!function n(a){for(const l of a.child_views.values())l instanceof N?l.update(e,t,s):l instanceof j&&n(l)}(this);for(const n of this.action_views.values())n.update(e,t,s)}}s.TemplateView=J,J.__name__=\"TemplateView\",J.tag_name=\"div\";class K extends q{}s.Template=K,u=K,K.__name__=\"Template\",u.prototype.default_view=J,u.define((({Array:e,Ref:t})=>({actions:[e(t(H)),[]]})));class Q extends j{}s.SpanView=Q,Q.__name__=\"SpanView\",Q.tag_name=\"span\";class U extends q{}s.Span=U,m=U,U.__name__=\"Span\",m.prototype.default_view=Q;class W extends j{}s.DivView=W,W.__name__=\"DivView\",W.tag_name=\"div\";class X extends q{}s.Div=X,w=X,X.__name__=\"Div\",w.prototype.default_view=W;class Y extends j{}s.TableView=Y,Y.__name__=\"TableView\",Y.tag_name=\"table\";class Z extends q{}s.Table=Z,f=Z,Z.__name__=\"Table\",f.prototype.default_view=Y;class ee extends j{}s.TableRowView=ee,ee.__name__=\"TableRowView\",ee.tag_name=\"tr\";class te extends q{}s.TableRow=te,h=te,te.__name__=\"TableRow\",h.prototype.default_view=ee;const se=e(41),ne=e(234);class ae extends F{update(e,t,s){for(const[e,s]of(0,ne.enumerate)(this.model.groups))e.visible=t==s}}s.ToggleGroupView=ae,ae.__name__=\"ToggleGroupView\";class le extends H{constructor(e){super(e)}}s.ToggleGroup=le,x=le,le.__name__=\"ToggleGroup\",x.prototype.default_view=ae,x.define((({Array:e,Ref:t})=>({groups:[e(t(se.RendererGroup)),[]]})))},\n", " function _(l,n,u,_,e){var t;_();const o=l(53);class r extends o.Model{constructor(l){super(l)}}u.Styles=r,t=r,r.__name__=\"Styles\",r.__module__=\"bokeh.models.css\",t.define((({String:l,Nullable:n})=>({align_content:[n(l),null],align_items:[n(l),null],align_self:[n(l),null],alignment_baseline:[n(l),null],all:[n(l),null],animation:[n(l),null],animation_delay:[n(l),null],animation_direction:[n(l),null],animation_duration:[n(l),null],animation_fill_mode:[n(l),null],animation_iteration_count:[n(l),null],animation_name:[n(l),null],animation_play_state:[n(l),null],animation_timing_function:[n(l),null],backface_visibility:[n(l),null],background:[n(l),null],background_attachment:[n(l),null],background_clip:[n(l),null],background_color:[n(l),null],background_image:[n(l),null],background_origin:[n(l),null],background_position:[n(l),null],background_position_x:[n(l),null],background_position_y:[n(l),null],background_repeat:[n(l),null],background_size:[n(l),null],baseline_shift:[n(l),null],block_size:[n(l),null],border:[n(l),null],border_block_end:[n(l),null],border_block_end_color:[n(l),null],border_block_end_style:[n(l),null],border_block_end_width:[n(l),null],border_block_start:[n(l),null],border_block_start_color:[n(l),null],border_block_start_style:[n(l),null],border_block_start_width:[n(l),null],border_bottom:[n(l),null],border_bottom_color:[n(l),null],border_bottom_left_radius:[n(l),null],border_bottom_right_radius:[n(l),null],border_bottom_style:[n(l),null],border_bottom_width:[n(l),null],border_collapse:[n(l),null],border_color:[n(l),null],border_image:[n(l),null],border_image_outset:[n(l),null],border_image_repeat:[n(l),null],border_image_slice:[n(l),null],border_image_source:[n(l),null],border_image_width:[n(l),null],border_inline_end:[n(l),null],border_inline_end_color:[n(l),null],border_inline_end_style:[n(l),null],border_inline_end_width:[n(l),null],border_inline_start:[n(l),null],border_inline_start_color:[n(l),null],border_inline_start_style:[n(l),null],border_inline_start_width:[n(l),null],border_left:[n(l),null],border_left_color:[n(l),null],border_left_style:[n(l),null],border_left_width:[n(l),null],border_radius:[n(l),null],border_right:[n(l),null],border_right_color:[n(l),null],border_right_style:[n(l),null],border_right_width:[n(l),null],border_spacing:[n(l),null],border_style:[n(l),null],border_top:[n(l),null],border_top_color:[n(l),null],border_top_left_radius:[n(l),null],border_top_right_radius:[n(l),null],border_top_style:[n(l),null],border_top_width:[n(l),null],border_width:[n(l),null],bottom:[n(l),null],box_shadow:[n(l),null],box_sizing:[n(l),null],break_after:[n(l),null],break_before:[n(l),null],break_inside:[n(l),null],caption_side:[n(l),null],caret_color:[n(l),null],clear:[n(l),null],clip:[n(l),null],clip_path:[n(l),null],clip_rule:[n(l),null],color:[n(l),null],color_interpolation:[n(l),null],color_interpolation_filters:[n(l),null],column_count:[n(l),null],column_fill:[n(l),null],column_gap:[n(l),null],column_rule:[n(l),null],column_rule_color:[n(l),null],column_rule_style:[n(l),null],column_rule_width:[n(l),null],column_span:[n(l),null],column_width:[n(l),null],columns:[n(l),null],content:[n(l),null],counter_increment:[n(l),null],counter_reset:[n(l),null],css_float:[n(l),null],css_text:[n(l),null],cursor:[n(l),null],direction:[n(l),null],display:[n(l),null],dominant_baseline:[n(l),null],empty_cells:[n(l),null],fill:[n(l),null],fill_opacity:[n(l),null],fill_rule:[n(l),null],filter:[n(l),null],flex:[n(l),null],flex_basis:[n(l),null],flex_direction:[n(l),null],flex_flow:[n(l),null],flex_grow:[n(l),null],flex_shrink:[n(l),null],flex_wrap:[n(l),null],float:[n(l),null],flood_color:[n(l),null],flood_opacity:[n(l),null],font:[n(l),null],font_family:[n(l),null],font_feature_settings:[n(l),null],font_kerning:[n(l),null],font_size:[n(l),null],font_size_adjust:[n(l),null],font_stretch:[n(l),null],font_style:[n(l),null],font_synthesis:[n(l),null],font_variant:[n(l),null],font_variant_caps:[n(l),null],font_variant_east_asian:[n(l),null],font_variant_ligatures:[n(l),null],font_variant_numeric:[n(l),null],font_variant_position:[n(l),null],font_weight:[n(l),null],gap:[n(l),null],glyph_orientation_vertical:[n(l),null],grid:[n(l),null],grid_area:[n(l),null],grid_auto_columns:[n(l),null],grid_auto_flow:[n(l),null],grid_auto_rows:[n(l),null],grid_column:[n(l),null],grid_column_end:[n(l),null],grid_column_gap:[n(l),null],grid_column_start:[n(l),null],grid_gap:[n(l),null],grid_row:[n(l),null],grid_row_end:[n(l),null],grid_row_gap:[n(l),null],grid_row_start:[n(l),null],grid_template:[n(l),null],grid_template_areas:[n(l),null],grid_template_columns:[n(l),null],grid_template_rows:[n(l),null],height:[n(l),null],hyphens:[n(l),null],image_orientation:[n(l),null],image_rendering:[n(l),null],inline_size:[n(l),null],justify_content:[n(l),null],justify_items:[n(l),null],justify_self:[n(l),null],left:[n(l),null],letter_spacing:[n(l),null],lighting_color:[n(l),null],line_break:[n(l),null],line_height:[n(l),null],list_style:[n(l),null],list_style_image:[n(l),null],list_style_position:[n(l),null],list_style_type:[n(l),null],margin:[n(l),null],margin_block_end:[n(l),null],margin_block_start:[n(l),null],margin_bottom:[n(l),null],margin_inline_end:[n(l),null],margin_inline_start:[n(l),null],margin_left:[n(l),null],margin_right:[n(l),null],margin_top:[n(l),null],marker:[n(l),null],marker_end:[n(l),null],marker_mid:[n(l),null],marker_start:[n(l),null],mask:[n(l),null],mask_composite:[n(l),null],mask_image:[n(l),null],mask_position:[n(l),null],mask_repeat:[n(l),null],mask_size:[n(l),null],mask_type:[n(l),null],max_block_size:[n(l),null],max_height:[n(l),null],max_inline_size:[n(l),null],max_width:[n(l),null],min_block_size:[n(l),null],min_height:[n(l),null],min_inline_size:[n(l),null],min_width:[n(l),null],object_fit:[n(l),null],object_position:[n(l),null],opacity:[n(l),null],order:[n(l),null],orphans:[n(l),null],outline:[n(l),null],outline_color:[n(l),null],outline_offset:[n(l),null],outline_style:[n(l),null],outline_width:[n(l),null],overflow:[n(l),null],overflow_anchor:[n(l),null],overflow_wrap:[n(l),null],overflow_x:[n(l),null],overflow_y:[n(l),null],overscroll_behavior:[n(l),null],overscroll_behavior_block:[n(l),null],overscroll_behavior_inline:[n(l),null],overscroll_behavior_x:[n(l),null],overscroll_behavior_y:[n(l),null],padding:[n(l),null],padding_block_end:[n(l),null],padding_block_start:[n(l),null],padding_bottom:[n(l),null],padding_inline_end:[n(l),null],padding_inline_start:[n(l),null],padding_left:[n(l),null],padding_right:[n(l),null],padding_top:[n(l),null],page_break_after:[n(l),null],page_break_before:[n(l),null],page_break_inside:[n(l),null],paint_order:[n(l),null],perspective:[n(l),null],perspective_origin:[n(l),null],place_content:[n(l),null],place_items:[n(l),null],place_self:[n(l),null],pointer_events:[n(l),null],position:[n(l),null],quotes:[n(l),null],resize:[n(l),null],right:[n(l),null],rotate:[n(l),null],row_gap:[n(l),null],ruby_align:[n(l),null],ruby_position:[n(l),null],scale:[n(l),null],scroll_behavior:[n(l),null],shape_rendering:[n(l),null],stop_color:[n(l),null],stop_opacity:[n(l),null],stroke:[n(l),null],stroke_dasharray:[n(l),null],stroke_dashoffset:[n(l),null],stroke_linecap:[n(l),null],stroke_linejoin:[n(l),null],stroke_miterlimit:[n(l),null],stroke_opacity:[n(l),null],stroke_width:[n(l),null],tab_size:[n(l),null],table_layout:[n(l),null],text_align:[n(l),null],text_align_last:[n(l),null],text_anchor:[n(l),null],text_combine_upright:[n(l),null],text_decoration:[n(l),null],text_decoration_color:[n(l),null],text_decoration_line:[n(l),null],text_decoration_style:[n(l),null],text_emphasis:[n(l),null],text_emphasis_color:[n(l),null],text_emphasis_position:[n(l),null],text_emphasis_style:[n(l),null],text_indent:[n(l),null],text_justify:[n(l),null],text_orientation:[n(l),null],text_overflow:[n(l),null],text_rendering:[n(l),null],text_shadow:[n(l),null],text_transform:[n(l),null],text_underline_position:[n(l),null],top:[n(l),null],touch_action:[n(l),null],transform:[n(l),null],transform_box:[n(l),null],transform_origin:[n(l),null],transform_style:[n(l),null],transition:[n(l),null],transition_delay:[n(l),null],transition_duration:[n(l),null],transition_property:[n(l),null],transition_timing_function:[n(l),null],translate:[n(l),null],unicode_bidi:[n(l),null],user_select:[n(l),null],vertical_align:[n(l),null],visibility:[n(l),null],white_space:[n(l),null],widows:[n(l),null],width:[n(l),null],will_change:[n(l),null],word_break:[n(l),null],word_spacing:[n(l),null],word_wrap:[n(l),null],writing_mode:[n(l),null],z_index:[n(l),null]})))},\n", " function _(t,o,e,n,s){var i;n();const l=t(15),c=t(53),r=t(224),a=t(232),u=t(234);class h extends c.Model{constructor(t){super(t)}get button_view(){return this.tools[0].button_view}get event_type(){return this.tools[0].event_type}get tooltip(){return this.tools[0].tooltip}get tool_name(){return this.tools[0].tool_name}get icon(){return this.tools[0].computed_icon}get computed_icon(){return this.icon}get toggleable(){const t=this.tools[0];return t instanceof a.InspectTool&&t.toggleable}initialize(){super.initialize(),this.do=new l.Signal0(this,\"do\")}connect_signals(){super.connect_signals(),this.connect(this.do,(()=>this.doit())),this.connect(this.properties.active.change,(()=>this.set_active()));for(const t of this.tools)this.connect(t.properties.active.change,(()=>{this.active=t.active}))}doit(){for(const t of this.tools)t.do.emit()}set_active(){for(const t of this.tools)t.active=this.active}get menu(){const{menu:t}=this.tools[0];if(null==t)return null;const o=[];for(const[e,n]of(0,u.enumerate)(t))if(null==e)o.push(null);else{const t=()=>{var t,o,e;for(const s of this.tools)null===(e=null===(o=null===(t=s.menu)||void 0===t?void 0:t[n])||void 0===o?void 0:o.handler)||void 0===e||e.call(o)};o.push(Object.assign(Object.assign({},e),{handler:t}))}return o}}e.ToolProxy=h,i=h,h.__name__=\"ToolProxy\",i.define((({Boolean:t,Array:o,Ref:e})=>({tools:[o(e(r.ButtonTool)),[]],active:[t,!1],disabled:[t,!1]})))},\n", " function _(o,t,s,e,i){var n,r;e();const l=o(20),c=o(9),h=o(13),a=o(233),_=o(221),p=o(394),u=o(309),f=o(207);class y extends a.ToolbarBase{constructor(o){super(o)}initialize(){super.initialize(),this._merge_tools()}_merge_tools(){this._proxied_tools=[];const o={},t={},s={},e=[],i=[];for(const o of this.help)(0,c.includes)(i,o.redirect)||(e.push(o),i.push(o.redirect));this._proxied_tools.push(...e),this.help=e;for(const[o,t]of(0,h.entries)(this.gestures)){o in s||(s[o]={});for(const e of t.tools)e.type in s[o]||(s[o][e.type]=[]),s[o][e.type].push(e)}for(const t of this.inspectors)t.type in o||(o[t.type]=[]),o[t.type].push(t);for(const o of this.actions)o.type in t||(t[o.type]=[]),t[o.type].push(o);const n=(o,t=!1)=>{const s=new p.ToolProxy({tools:o,active:t});return this._proxied_tools.push(s),s};for(const o of(0,h.keys)(s)){const t=this.gestures[o];t.tools=[];for(const e of(0,h.keys)(s[o])){const i=s[o][e];if(i.length>0)if(\"multi\"==o)for(const o of i){const s=n([o]);t.tools.push(s),this.connect(s.properties.active.change,(()=>this._active_change(s)))}else{const o=n(i);t.tools.push(o),this.connect(o.properties.active.change,(()=>this._active_change(o)))}}}this.actions=[];for(const[o,s]of(0,h.entries)(t))if(\"CustomAction\"==o)for(const o of s)this.actions.push(n([o]));else s.length>0&&this.actions.push(n(s));this.inspectors=[];for(const t of(0,h.values)(o))t.length>0&&this.inspectors.push(n(t,!0));for(const[o,t]of(0,h.entries)(this.gestures))0!=t.tools.length&&(t.tools=(0,c.sort_by)(t.tools,(o=>o.default_order)),\"pinch\"!=o&&\"scroll\"!=o&&\"multi\"!=o&&(t.tools[0].active=!0))}}s.ProxyToolbar=y,n=y,y.__name__=\"ProxyToolbar\",n.define((({Array:o,Ref:t})=>({toolbars:[o(t(_.Toolbar)),[]]})));class d extends u.LayoutDOMView{initialize(){this.model.toolbar.toolbar_location=this.model.toolbar_location,super.initialize()}get child_models(){return[this.model.toolbar]}_update_layout(){this.layout=new f.ContentBox(this.child_views[0].el);const{toolbar:o}=this.model;o.horizontal?this.layout.set_sizing({width_policy:\"fit\",min_width:100,height_policy:\"fixed\"}):this.layout.set_sizing({width_policy:\"fixed\",height_policy:\"fit\",min_height:100})}after_layout(){super.after_layout();const o=this.child_views[0];o.layout.bbox=this.layout.bbox,o.render()}}s.ToolbarBoxView=d,d.__name__=\"ToolbarBoxView\";class b extends u.LayoutDOM{constructor(o){super(o)}}s.ToolbarBox=b,r=b,b.__name__=\"ToolbarBox\",r.prototype.default_view=d,r.define((({Ref:o})=>({toolbar:[o(a.ToolbarBase)],toolbar_location:[l.Location,\"right\"]})))},\n", " function _(e,n,r,t,o){t();const s=e(1),u=e(53),c=(0,s.__importStar)(e(21)),a=e(8),l=e(13);r.resolve_defs=function(e,n){var r,t,o,s;function i(e){return null!=e.module?`${e.module}.${e.name}`:e.name}function f(e){if((0,a.isString)(e))switch(e){case\"Any\":return c.Any;case\"Unknown\":return c.Unknown;case\"Boolean\":return c.Boolean;case\"Number\":return c.Number;case\"Int\":return c.Int;case\"String\":return c.String;case\"Null\":return c.Null}else switch(e[0]){case\"Nullable\":{const[,n]=e;return c.Nullable(f(n))}case\"Or\":{const[,...n]=e;return c.Or(...n.map(f))}case\"Tuple\":{const[,n,...r]=e;return c.Tuple(f(n),...r.map(f))}case\"Array\":{const[,n]=e;return c.Array(f(n))}case\"Struct\":{const[,...n]=e,r=n.map((([e,n])=>[e,f(n)]));return c.Struct((0,l.to_object)(r))}case\"Dict\":{const[,n]=e;return c.Dict(f(n))}case\"Map\":{const[,n,r]=e;return c.Map(f(n),f(r))}case\"Enum\":{const[,...n]=e;return c.Enum(...n)}case\"Ref\":{const[,r]=e,t=n.get(i(r));if(null!=t)return c.Ref(t);throw new Error(`${i(r)} wasn't defined before referencing it`)}case\"AnyRef\":return c.AnyRef()}}for(const c of e){const e=(()=>{if(null==c.extends)return u.Model;{const e=n.get(i(c.extends));if(null!=e)return e;throw new Error(`base model ${i(c.extends)} of ${i(c)} is not defined`)}})(),a=((s=class extends e{}).__name__=c.name,s.__module__=c.module,s);for(const e of null!==(r=c.properties)&&void 0!==r?r:[]){const n=f(null!==(t=e.kind)&&void 0!==t?t:\"Unknown\");a.define({[e.name]:[n,e.default]})}for(const e of null!==(o=c.overrides)&&void 0!==o?o:[])a.override({[e.name]:e.default});n.register(a)}}},\n", " function _(n,e,t,o,i){o();const d=n(5),c=n(226),s=n(113),a=n(43),l=n(398);t.index={},t.add_document_standalone=async function(n,e,o=[],i=!1){const u=new Map;async function f(i){let d;const f=n.roots().indexOf(i),r=o[f];null!=r?d=r:e.classList.contains(l.BOKEH_ROOT)?d=e:(d=(0,a.div)({class:l.BOKEH_ROOT}),e.appendChild(d));const w=await(0,s.build_view)(i,{parent:null});return w instanceof c.DOMView&&w.renderTo(d),u.set(i,w),t.index[i.id]=w,w}for(const e of n.roots())await f(e);return i&&(window.document.title=n.title()),n.on_change((n=>{n instanceof d.RootAddedEvent?f(n.model):n instanceof d.RootRemovedEvent?function(n){const e=u.get(n);null!=e&&(e.remove(),u.delete(n),delete t.index[n.id])}(n.model):i&&n instanceof d.TitleChangedEvent&&(window.document.title=n.title)})),[...u.values()]}},\n", " function _(o,e,n,t,r){t();const l=o(43),d=o(44);function u(o){let e=document.getElementById(o);if(null==e)throw new Error(`Error rendering Bokeh model: could not find #${o} HTML tag`);if(!document.body.contains(e))throw new Error(`Error rendering Bokeh model: element #${o} must be under `);if(\"SCRIPT\"==e.tagName){const o=(0,l.div)({class:n.BOKEH_ROOT});(0,l.replaceWith)(e,o),e=o}return e}n.BOKEH_ROOT=d.root,n._resolve_element=function(o){const{elementid:e}=o;return null!=e?u(e):document.body},n._resolve_root_elements=function(o){const e=[];if(null!=o.root_ids&&null!=o.roots)for(const n of o.root_ids)e.push(u(o.roots[n]));return e}},\n", " function _(n,o,t,s,e){s();const c=n(400),r=n(19),a=n(397);t._get_ws_url=function(n,o){let t,s=\"ws:\";return\"https:\"==window.location.protocol&&(s=\"wss:\"),null!=o?(t=document.createElement(\"a\"),t.href=o):t=window.location,null!=n?\"/\"==n&&(n=\"\"):n=t.pathname.replace(/\\/+$/,\"\"),`${s}//${t.host}${n}/ws`};const i={};t.add_document_from_session=async function(n,o,t,s=[],e=!1){const l=window.location.search.substr(1);let d;try{d=await function(n,o,t){const s=(0,c.parse_token)(o).session_id;n in i||(i[n]={});const e=i[n];return s in e||(e[s]=(0,c.pull_session)(n,o,t)),e[s]}(n,o,l)}catch(n){const t=(0,c.parse_token)(o).session_id;throw r.logger.error(`Failed to load Bokeh session ${t}: ${n}`),n}return(0,a.add_document_standalone)(d.document,t,s,e)}},\n", " function _(e,s,n,t,o){t();const r=e(19),i=e(5),c=e(401),l=e(402),_=e(403);n.DEFAULT_SERVER_WEBSOCKET_URL=\"ws://localhost:5006/ws\",n.DEFAULT_TOKEN=\"eyJzZXNzaW9uX2lkIjogImRlZmF1bHQifQ\";let h=0;function a(e){let s=e.split(\".\")[0];const n=s.length%4;return 0!=n&&(s+=\"=\".repeat(4-n)),JSON.parse(atob(s.replace(/_/g,\"/\").replace(/-/g,\"+\")))}n.parse_token=a;class d{constructor(e=n.DEFAULT_SERVER_WEBSOCKET_URL,s=n.DEFAULT_TOKEN,t=null){this.url=e,this.token=s,this.args_string=t,this._number=h++,this.socket=null,this.session=null,this.closed_permanently=!1,this._current_handler=null,this._pending_replies=new Map,this._pending_messages=[],this._receiver=new l.Receiver,this.id=a(s).session_id.split(\".\")[0],r.logger.debug(`Creating websocket ${this._number} to '${this.url}' session '${this.id}'`)}async connect(){if(this.closed_permanently)throw new Error(\"Cannot connect() a closed ClientConnection\");if(null!=this.socket)throw new Error(\"Already connected\");this._current_handler=null,this._pending_replies.clear(),this._pending_messages=[];try{let e=`${this.url}`;return null!=this.args_string&&this.args_string.length>0&&(e+=`?${this.args_string}`),this.socket=new WebSocket(e,[\"bokeh\",this.token]),new Promise(((e,s)=>{this.socket.binaryType=\"arraybuffer\",this.socket.onopen=()=>this._on_open(e,s),this.socket.onmessage=e=>this._on_message(e),this.socket.onclose=e=>this._on_close(e,s),this.socket.onerror=()=>this._on_error(s)}))}catch(e){throw r.logger.error(`websocket creation failed to url: ${this.url}`),r.logger.error(` - ${e}`),e}}close(){this.closed_permanently||(r.logger.debug(`Permanently closing websocket connection ${this._number}`),this.closed_permanently=!0,null!=this.socket&&this.socket.close(1e3,`close method called on ClientConnection ${this._number}`),this.session._connection_closed())}_schedule_reconnect(e){setTimeout((()=>{this.closed_permanently||r.logger.info(`Websocket connection ${this._number} disconnected, will not attempt to reconnect`)}),e)}send(e){if(null==this.socket)throw new Error(`not connected so cannot send ${e}`);e.send(this.socket)}async send_with_reply(e){const s=await new Promise(((s,n)=>{this._pending_replies.set(e.msgid(),{resolve:s,reject:n}),this.send(e)}));if(\"ERROR\"===s.msgtype())throw new Error(`Error reply ${s.content.text}`);return s}async _pull_doc_json(){const e=c.Message.create(\"PULL-DOC-REQ\",{}),s=await this.send_with_reply(e);if(!(\"doc\"in s.content))throw new Error(\"No 'doc' field in PULL-DOC-REPLY\");return s.content.doc}async _repull_session_doc(e,s){var n;r.logger.debug(this.session?\"Repulling session\":\"Pulling session for first time\");try{const n=await this._pull_doc_json();if(null==this.session)if(this.closed_permanently)r.logger.debug(\"Got new document after connection was already closed\"),s(new Error(\"The connection has been closed\"));else{const s=i.Document.from_json(n),t=i.Document._compute_patch_since_json(n,s);if(t.events.length>0){r.logger.debug(`Sending ${t.events.length} changes from model construction back to server`);const e=c.Message.create(\"PATCH-DOC\",{},t);this.send(e)}this.session=new _.ClientSession(this,s,this.id);for(const e of this._pending_messages)this.session.handle(e);this._pending_messages=[],r.logger.debug(\"Created a new session from new pulled doc\"),e(this.session)}else this.session.document.replace_with_json(n),r.logger.debug(\"Updated existing session with new pulled doc\")}catch(e){null===(n=console.trace)||void 0===n||n.call(console,e),r.logger.error(`Failed to repull session ${e}`),s(e instanceof Error?e:`${e}`)}}_on_open(e,s){r.logger.info(`Websocket connection ${this._number} is now open`),this._current_handler=n=>{this._awaiting_ack_handler(n,e,s)}}_on_message(e){null==this._current_handler&&r.logger.error(\"Got a message with no current handler set\");try{this._receiver.consume(e.data)}catch(e){this._close_bad_protocol(`${e}`)}const s=this._receiver.message;if(null!=s){const e=s.problem();null!=e&&this._close_bad_protocol(e),this._current_handler(s)}}_on_close(e,s){r.logger.info(`Lost websocket ${this._number} connection, ${e.code} (${e.reason})`),this.socket=null,this._pending_replies.forEach((e=>e.reject(\"Disconnected\"))),this._pending_replies.clear(),this.closed_permanently||this._schedule_reconnect(2e3),s(new Error(`Lost websocket connection, ${e.code} (${e.reason})`))}_on_error(e){r.logger.debug(`Websocket error on socket ${this._number}`);const s=\"Could not open websocket\";r.logger.error(`Failed to connect to Bokeh server: ${s}`),e(new Error(s))}_close_bad_protocol(e){r.logger.error(`Closing connection: ${e}`),null!=this.socket&&this.socket.close(1002,e)}_awaiting_ack_handler(e,s,n){\"ACK\"===e.msgtype()?(this._current_handler=e=>this._steady_state_handler(e),this._repull_session_doc(s,n)):this._close_bad_protocol(\"First message was not an ACK\")}_steady_state_handler(e){const s=e.reqid(),n=this._pending_replies.get(s);n?(this._pending_replies.delete(s),n.resolve(e)):this.session?this.session.handle(e):\"PATCH-DOC\"!=e.msgtype()&&this._pending_messages.push(e)}}n.ClientConnection=d,d.__name__=\"ClientConnection\",n.pull_session=function(e,s,n){return new d(e,s,n).connect()}},\n", " function _(e,s,t,r,n){r();const i=e(34);class a{constructor(e,s,t){this.header=e,this.metadata=s,this.content=t,this.buffers=new Map}static assemble(e,s,t){const r=JSON.parse(e),n=JSON.parse(s),i=JSON.parse(t);return new a(r,n,i)}assemble_buffer(e,s){const t=null!=this.header.num_buffers?this.header.num_buffers:0;if(t<=this.buffers.size)throw new Error(`too many buffers received, expecting ${t}`);const{id:r}=JSON.parse(e);this.buffers.set(r,s)}static create(e,s,t={}){const r=a.create_header(e);return new a(r,s,t)}static create_header(e){return{msgid:(0,i.uniqueId)(),msgtype:e}}complete(){return null!=this.header&&null!=this.metadata&&null!=this.content&&(null==this.header.num_buffers||this.buffers.size==this.header.num_buffers)}send(e){if((null!=this.header.num_buffers?this.header.num_buffers:0)>0)throw new Error(\"BokehJS only supports receiving buffers, not sending\");const s=JSON.stringify(this.header),t=JSON.stringify(this.metadata),r=JSON.stringify(this.content);e.send(s),e.send(t),e.send(r)}msgid(){return this.header.msgid}msgtype(){return this.header.msgtype}reqid(){return this.header.reqid}problem(){return\"msgid\"in this.header?\"msgtype\"in this.header?null:\"No msgtype in header\":\"No msgid in header\"}}t.Message=a,a.__name__=\"Message\"},\n", " function _(e,t,s,_,r){_();const i=e(401),h=e(8);class a{constructor(){this.message=null,this._partial=null,this._fragments=[],this._buf_header=null,this._current_consumer=this._HEADER}consume(e){this._current_consumer(e)}_HEADER(e){this._assume_text(e),this.message=null,this._partial=null,this._fragments=[e],this._buf_header=null,this._current_consumer=this._METADATA}_METADATA(e){this._assume_text(e),this._fragments.push(e),this._current_consumer=this._CONTENT}_CONTENT(e){this._assume_text(e),this._fragments.push(e);const[t,s,_]=this._fragments.slice(0,3);this._partial=i.Message.assemble(t,s,_),this._check_complete()}_BUFFER_HEADER(e){this._assume_text(e),this._buf_header=e,this._current_consumer=this._BUFFER_PAYLOAD}_BUFFER_PAYLOAD(e){this._assume_binary(e),this._partial.assemble_buffer(this._buf_header,e),this._check_complete()}_assume_text(e){if(!(0,h.isString)(e))throw new Error(\"Expected text fragment but received binary fragment\")}_assume_binary(e){if(!(e instanceof ArrayBuffer))throw new Error(\"Expected binary fragment but received text fragment\")}_check_complete(){this._partial.complete()?(this.message=this._partial,this._current_consumer=this._HEADER):this._current_consumer=this._BUFFER_HEADER}}s.Receiver=a,a.__name__=\"Receiver\"},\n", " function _(e,t,n,s,o){s();const c=e(5),i=e(401),_=e(19);class r{constructor(e,t,n){this._connection=e,this.document=t,this.id=n,this._document_listener=e=>{this._document_changed(e)},this.document.on_change(this._document_listener,!0)}handle(e){const t=e.msgtype();\"PATCH-DOC\"===t?this._handle_patch(e):\"OK\"===t?this._handle_ok(e):\"ERROR\"===t?this._handle_error(e):_.logger.debug(`Doing nothing with message ${e.msgtype()}`)}close(){this._connection.close()}_connection_closed(){this.document.remove_on_change(this._document_listener)}async request_server_info(){const e=i.Message.create(\"SERVER-INFO-REQ\",{});return(await this._connection.send_with_reply(e)).content}async force_roundtrip(){await this.request_server_info()}_document_changed(e){if(e.setter_id===this.id)return;const t=e instanceof c.DocumentEventBatch?e.events:[e],n=this.document.create_json_patch(t),s=i.Message.create(\"PATCH-DOC\",{},n);this._connection.send(s)}_handle_patch(e){this.document.apply_json_patch(e.content,e.buffers,this.id)}_handle_ok(e){_.logger.trace(`Unhandled OK reply to ${e.reqid()}`)}_handle_error(e){_.logger.error(`Unhandled ERROR reply to ${e.reqid()}: ${e.content.text}`)}}n.ClientSession=r,r.__name__=\"ClientSession\"},\n", " function _(e,o,t,n,r){n();const s=e(1),l=e(5),i=e(402),a=e(19),c=e(43),g=e(13),f=e(397),u=e(398),m=(0,s.__importDefault)(e(44)),p=(0,s.__importDefault)(e(240)),d=(0,s.__importDefault)(e(405));function _(e,o){o.buffers.length>0?e.consume(o.buffers[0].buffer):e.consume(o.content.data);const t=e.message;null!=t&&this.apply_json_patch(t.content,t.buffers)}function b(e,o){if(\"undefined\"!=typeof Jupyter&&null!=Jupyter.notebook.kernel){a.logger.info(`Registering Jupyter comms for target ${e}`);const t=Jupyter.notebook.kernel.comm_manager;try{t.register_target(e,(t=>{a.logger.info(`Registering Jupyter comms for target ${e}`);const n=new i.Receiver;t.on_msg(_.bind(o,n))}))}catch(e){a.logger.warn(`Jupyter comms failed to register. push_notebook() will not function. (exception reported: ${e})`)}}else if(o.roots()[0].id in t.kernels){a.logger.info(`Registering JupyterLab comms for target ${e}`);const n=t.kernels[o.roots()[0].id];try{n.registerCommTarget(e,(t=>{a.logger.info(`Registering JupyterLab comms for target ${e}`);const n=new i.Receiver;t.onMsg=_.bind(o,n)}))}catch(e){a.logger.warn(`Jupyter comms failed to register. push_notebook() will not function. (exception reported: ${e})`)}}else if(\"undefined\"!=typeof google&&null!=google.colab.kernel){a.logger.info(`Registering Google Colab comms for target ${e}`);const t=google.colab.kernel.comms;try{t.registerTarget(e,(async t=>{var n,r,l;a.logger.info(`Registering Google Colab comms for target ${e}`);const c=new i.Receiver;try{for(var g,f=(0,s.__asyncValues)(t.messages);!(g=await f.next()).done;){const e=g.value,t={data:e.data},n=[];for(const o of null!==(l=e.buffers)&&void 0!==l?l:[])n.push(new DataView(o));const r={content:t,buffers:n};_.bind(o)(c,r)}}catch(e){n={error:e}}finally{try{g&&!g.done&&(r=f.return)&&await r.call(f)}finally{if(n)throw n.error}}}))}catch(e){a.logger.warn(`Google Colab comms failed to register. push_notebook() will not function. (exception reported: ${e})`)}}else console.warn(\"Jupyter notebooks comms not available. push_notebook() will not function. If running JupyterLab ensure the latest @bokeh/jupyter_bokeh extension is installed. In an exported notebook this warning is expected.\")}c.stylesheet.append(m.default),c.stylesheet.append(p.default),c.stylesheet.append(d.default),t.kernels={},t.embed_items_notebook=function(e,o){if(1!=(0,g.size)(e))throw new Error(\"embed_items_notebook expects exactly one document in docs_json\");const t=l.Document.from_json((0,g.values)(e)[0]);for(const e of o){null!=e.notebook_comms_target&&b(e.notebook_comms_target,t);const o=(0,u._resolve_element)(e),n=(0,u._resolve_root_elements)(e);(0,f.add_document_standalone)(t,o,n)}}},\n", " function _(t,o,r,e,d){e(),r.root=\"bk-root\",r.tooltip=\"bk-tooltip\",r.default=\".rendered_html .bk-root .bk-tooltip table,.rendered_html .bk-root .bk-tooltip tr,.rendered_html .bk-root .bk-tooltip th,.rendered_html .bk-root .bk-tooltip td{border:none;padding:1px;}\"},\n", " function _(t,_,o,r,n){r();const a=t(1);(0,a.__exportStar)(t(401),o),(0,a.__exportStar)(t(402),o)},\n", " function _(e,t,n,s,o){function l(){const e=document.getElementsByTagName(\"body\")[0],t=document.getElementsByClassName(\"bokeh-test-div\");1==t.length&&(e.removeChild(t[0]),delete t[0]);const n=document.createElement(\"div\");n.classList.add(\"bokeh-test-div\"),n.style.display=\"none\",e.insertBefore(n,e.firstChild)}s(),n.results={},n.init=function(){l()},n.record0=function(e,t){n.results[e]=t},n.record=function(e,t){n.results[e]=t,l()},n.count=function(e){null==n.results[e]&&(n.results[e]=0),n.results[e]+=1,l()}},\n", " function _(e,t,o,n,l){n(),o.safely=function(e,t=!1){try{return e()}catch(e){if(function(e){const t=document.createElement(\"div\");t.style.backgroundColor=\"#f2dede\",t.style.border=\"1px solid #a94442\",t.style.borderRadius=\"4px\",t.style.display=\"inline-block\",t.style.fontFamily=\"sans-serif\",t.style.marginTop=\"5px\",t.style.minWidth=\"200px\",t.style.padding=\"5px 5px 5px 10px\",t.classList.add(\"bokeh-error-box-into-flames\");const o=document.createElement(\"span\");o.style.backgroundColor=\"#a94442\",o.style.borderRadius=\"0px 4px 0px 0px\",o.style.color=\"white\",o.style.cursor=\"pointer\",o.style.cssFloat=\"right\",o.style.fontSize=\"0.8em\",o.style.margin=\"-6px -6px 0px 0px\",o.style.padding=\"2px 5px 4px 5px\",o.title=\"close\",o.setAttribute(\"aria-label\",\"close\"),o.appendChild(document.createTextNode(\"x\")),o.addEventListener(\"click\",(()=>s.removeChild(t)));const n=document.createElement(\"h3\");n.style.color=\"#a94442\",n.style.margin=\"8px 0px 0px 0px\",n.style.padding=\"0px\",n.appendChild(document.createTextNode(\"Bokeh Error\"));const l=document.createElement(\"pre\");l.style.whiteSpace=\"unset\",l.style.overflowX=\"auto\",l.appendChild(document.createTextNode(e)),t.appendChild(o),t.appendChild(n),t.appendChild(l);const s=document.getElementsByTagName(\"body\")[0];s.insertBefore(t,s.firstChild)}(e instanceof Error&&e.stack?e.stack:`${e}`),t)return;throw e}}},\n", " ], 0, {\"main\":0,\"tslib\":1,\"index\":2,\"version\":3,\"embed/index\":4,\"document/index\":5,\"document/document\":6,\"base\":7,\"core/util/types\":8,\"core/util/array\":9,\"core/util/math\":10,\"core/util/assert\":11,\"core/util/arrayable\":12,\"core/util/object\":13,\"core/has_props\":14,\"core/signaling\":15,\"core/util/defer\":16,\"core/util/refs\":17,\"core/properties\":18,\"core/logging\":19,\"core/enums\":20,\"core/kinds\":21,\"core/util/color\":22,\"core/util/svg_colors\":23,\"core/types\":24,\"core/util/bitset\":25,\"core/util/eq\":26,\"core/util/platform\":27,\"core/settings\":28,\"core/util/ndarray\":29,\"core/serializer\":30,\"core/util/serialization\":31,\"core/util/buffer\":32,\"core/uniforms\":33,\"core/util/string\":34,\"document/events\":35,\"core/util/pretty\":36,\"core/util/cloneable\":37,\"models/index\":38,\"models/annotations/index\":39,\"models/annotations/annotation\":40,\"models/renderers/renderer\":41,\"core/view\":42,\"core/dom\":43,\"styles/root.css\":44,\"core/visuals/index\":45,\"core/visuals/line\":46,\"core/visuals/visual\":47,\"core/property_mixins\":48,\"core/visuals/fill\":49,\"core/visuals/text\":50,\"core/visuals/hatch\":51,\"core/visuals/patterns\":52,\"model\":53,\"models/canvas/coordinates\":54,\"models/scales/scale\":55,\"models/transforms/transform\":56,\"models/ranges/range\":57,\"models/ranges/range1d\":58,\"models/scales/linear_scale\":59,\"models/scales/continuous_scale\":60,\"models/scales/log_scale\":61,\"models/scales/categorical_scale\":62,\"models/ranges/data_range1d\":63,\"models/ranges/data_range\":64,\"core/util/bbox\":65,\"models/util\":66,\"models/ranges/factor_range\":67,\"models/annotations/arrow\":68,\"models/annotations/data_annotation\":69,\"models/sources/columnar_data_source\":70,\"models/sources/data_source\":71,\"models/selections/selection\":72,\"core/selection_manager\":73,\"models/selections/interaction_policy\":74,\"models/sources/column_data_source\":75,\"core/util/typed_array\":76,\"core/util/set\":77,\"core/util/projections\":78,\"models/annotations/arrow_head\":112,\"core/build_views\":113,\"models/annotations/band\":114,\"models/annotations/upper_lower\":115,\"models/annotations/box_annotation\":116,\"models/annotations/color_bar\":117,\"models/annotations/title\":118,\"models/annotations/text_annotation\":119,\"core/graphics\":120,\"core/util/text\":121,\"core/util/affine\":122,\"core/layout/side_panel\":123,\"core/layout/types\":124,\"core/layout/layoutable\":125,\"models/canvas/cartesian_frame\":126,\"models/axes/index\":127,\"models/axes/axis\":128,\"models/renderers/guide_renderer\":129,\"models/tickers/ticker\":130,\"models/formatters/tick_formatter\":131,\"models/policies/labeling\":132,\"models/text/base_text\":133,\"models/text/utils\":134,\"models/text/math_text\":135,\"core/util/image\":136,\"models/text/providers\":137,\"core/util/modules\":138,\"models/text/plain_text\":139,\"models/axes/categorical_axis\":140,\"models/tickers/categorical_ticker\":141,\"models/formatters/categorical_tick_formatter\":142,\"models/axes/continuous_axis\":143,\"models/axes/datetime_axis\":144,\"models/axes/linear_axis\":145,\"models/formatters/basic_tick_formatter\":146,\"models/tickers/basic_ticker\":147,\"models/tickers/adaptive_ticker\":148,\"models/tickers/continuous_ticker\":149,\"models/formatters/datetime_tick_formatter\":150,\"core/util/templating\":152,\"models/tickers/datetime_ticker\":155,\"models/tickers/composite_ticker\":156,\"models/tickers/days_ticker\":157,\"models/tickers/single_interval_ticker\":158,\"models/tickers/util\":159,\"models/tickers/months_ticker\":160,\"models/tickers/years_ticker\":161,\"models/axes/log_axis\":162,\"models/formatters/log_tick_formatter\":163,\"models/tickers/log_ticker\":164,\"models/axes/mercator_axis\":165,\"models/formatters/mercator_tick_formatter\":166,\"models/tickers/mercator_ticker\":167,\"models/tickers/index\":168,\"models/tickers/fixed_ticker\":169,\"models/tickers/binned_ticker\":170,\"models/mappers/scanning_color_mapper\":171,\"models/mappers/continuous_color_mapper\":172,\"models/mappers/color_mapper\":173,\"models/mappers/mapper\":174,\"models/renderers/glyph_renderer\":175,\"models/renderers/data_renderer\":176,\"models/glyphs/line\":177,\"models/glyphs/xy_glyph\":178,\"models/glyphs/glyph\":179,\"core/util/ragged_array\":180,\"core/util/spatial\":181,\"models/glyphs/utils\":184,\"core/hittest\":185,\"models/glyphs/patch\":186,\"models/glyphs/harea\":187,\"models/glyphs/area\":188,\"models/glyphs/varea\":189,\"models/sources/cds_view\":190,\"models/filters/filter\":191,\"models/formatters/index\":192,\"models/formatters/func_tick_formatter\":193,\"models/formatters/numeral_tick_formatter\":194,\"models/formatters/printf_tick_formatter\":195,\"models/mappers/index\":196,\"models/mappers/categorical_color_mapper\":197,\"models/mappers/categorical_mapper\":198,\"models/mappers/categorical_marker_mapper\":199,\"models/mappers/categorical_pattern_mapper\":200,\"models/mappers/linear_color_mapper\":201,\"models/mappers/log_color_mapper\":202,\"models/mappers/eqhist_color_mapper\":203,\"models/scales/index\":204,\"models/scales/linear_interpolation_scale\":205,\"models/ranges/index\":206,\"core/layout/index\":207,\"core/layout/alignments\":208,\"core/layout/grid\":209,\"core/layout/html\":210,\"core/layout/border\":211,\"models/annotations/label\":212,\"models/annotations/label_set\":213,\"models/annotations/legend\":214,\"models/annotations/legend_item\":215,\"core/vectorization\":216,\"models/annotations/poly_annotation\":217,\"models/annotations/slope\":218,\"models/annotations/span\":219,\"models/annotations/toolbar_panel\":220,\"models/tools/toolbar\":221,\"models/tools/tool\":222,\"models/tools/gestures/gesture_tool\":223,\"models/tools/button_tool\":224,\"core/dom_view\":226,\"styles/toolbar.css\":227,\"styles/icons.css\":228,\"styles/menus.css\":229,\"core/util/menus\":230,\"models/tools/on_off_button\":231,\"models/tools/inspectors/inspect_tool\":232,\"models/tools/toolbar_base\":233,\"core/util/iterator\":234,\"core/util/canvas\":235,\"core/util/svg\":236,\"core/util/random\":237,\"models/tools/actions/action_tool\":238,\"models/tools/actions/help_tool\":239,\"styles/logo.css\":240,\"models/annotations/tooltip\":241,\"styles/tooltips.css\":242,\"models/annotations/whisker\":243,\"models/callbacks/index\":244,\"models/callbacks/customjs\":245,\"models/callbacks/callback\":246,\"models/callbacks/open_url\":247,\"models/canvas/index\":248,\"models/canvas/canvas\":249,\"core/ui_events\":250,\"core/bokeh_events\":251,\"core/util/wheel\":252,\"models/expressions/index\":253,\"models/expressions/expression\":254,\"models/expressions/customjs_expr\":255,\"models/expressions/stack\":256,\"models/expressions/cumsum\":257,\"models/expressions/minimum\":258,\"models/expressions/maximum\":259,\"models/expressions/coordinate_transform\":260,\"models/expressions/polar\":261,\"models/filters/index\":262,\"models/filters/boolean_filter\":263,\"models/filters/customjs_filter\":264,\"models/filters/group_filter\":265,\"models/filters/index_filter\":266,\"models/glyphs/index\":267,\"models/glyphs/annular_wedge\":268,\"models/glyphs/annulus\":269,\"models/glyphs/arc\":270,\"models/glyphs/bezier\":271,\"models/glyphs/circle\":272,\"models/glyphs/ellipse\":273,\"models/glyphs/ellipse_oval\":274,\"models/glyphs/center_rotatable\":275,\"models/glyphs/hbar\":276,\"models/glyphs/box\":277,\"models/glyphs/hex_tile\":278,\"models/glyphs/image\":279,\"models/glyphs/image_base\":280,\"models/glyphs/image_rgba\":281,\"models/glyphs/image_url\":282,\"models/glyphs/multi_line\":283,\"models/glyphs/multi_polygons\":284,\"models/glyphs/oval\":285,\"models/glyphs/patches\":286,\"models/glyphs/quad\":287,\"models/glyphs/quadratic\":288,\"models/glyphs/ray\":289,\"models/glyphs/rect\":290,\"models/glyphs/scatter\":291,\"models/glyphs/marker\":292,\"models/glyphs/defs\":293,\"models/glyphs/segment\":294,\"models/glyphs/spline\":295,\"core/util/interpolation\":296,\"models/glyphs/step\":297,\"models/glyphs/text\":298,\"models/glyphs/vbar\":299,\"models/glyphs/wedge\":300,\"models/graphs/index\":301,\"models/graphs/graph_hit_test_policy\":302,\"models/graphs/layout_provider\":303,\"models/graphs/static_layout_provider\":304,\"models/grids/index\":305,\"models/grids/grid\":306,\"models/layouts/index\":307,\"models/layouts/box\":308,\"models/layouts/layout_dom\":309,\"models/layouts/column\":310,\"models/layouts/grid_box\":311,\"models/layouts/html_box\":312,\"models/layouts/panel\":313,\"models/layouts/row\":314,\"models/layouts/spacer\":315,\"models/layouts/tabs\":316,\"styles/tabs.css\":317,\"styles/buttons.css\":318,\"models/layouts/widget_box\":319,\"models/text/index\":320,\"models/transforms/index\":321,\"models/transforms/customjs_transform\":322,\"models/transforms/dodge\":323,\"models/transforms/range_transform\":324,\"models/transforms/interpolator\":325,\"models/transforms/jitter\":326,\"models/transforms/linear_interpolator\":327,\"models/transforms/step_interpolator\":328,\"models/plots/index\":329,\"models/plots/gmap_plot\":330,\"models/plots/plot\":331,\"models/plots/plot_canvas\":332,\"core/util/throttle\":333,\"models/plots/range_manager\":334,\"models/plots/state_manager\":335,\"models/plots/gmap_plot_canvas\":336,\"models/policies/index\":337,\"models/renderers/index\":338,\"models/renderers/graph_renderer\":339,\"models/selections/index\":340,\"models/sources/index\":341,\"models/sources/server_sent_data_source\":342,\"models/sources/web_data_source\":343,\"models/sources/ajax_data_source\":344,\"models/sources/geojson_data_source\":345,\"models/tiles/index\":346,\"models/tiles/bbox_tile_source\":347,\"models/tiles/mercator_tile_source\":348,\"models/tiles/tile_source\":349,\"models/tiles/tile_utils\":350,\"models/tiles/quadkey_tile_source\":351,\"models/tiles/tile_renderer\":352,\"models/tiles/wmts_tile_source\":353,\"styles/tiles.css\":354,\"models/tiles/tms_tile_source\":355,\"models/textures/index\":356,\"models/textures/canvas_texture\":357,\"models/textures/texture\":358,\"models/textures/image_url_texture\":359,\"models/tools/index\":360,\"models/tools/actions/custom_action\":361,\"models/tools/actions/redo_tool\":362,\"models/tools/actions/reset_tool\":363,\"models/tools/actions/save_tool\":364,\"models/tools/actions/undo_tool\":365,\"models/tools/actions/zoom_in_tool\":366,\"models/tools/actions/zoom_base_tool\":367,\"core/util/zoom\":368,\"models/tools/actions/zoom_out_tool\":369,\"models/tools/edit/edit_tool\":370,\"models/tools/edit/box_edit_tool\":371,\"models/tools/edit/freehand_draw_tool\":372,\"models/tools/edit/point_draw_tool\":373,\"models/tools/edit/poly_draw_tool\":374,\"models/tools/edit/poly_tool\":375,\"models/tools/edit/poly_edit_tool\":376,\"models/tools/gestures/box_select_tool\":377,\"models/tools/gestures/select_tool\":378,\"models/tools/gestures/box_zoom_tool\":379,\"models/tools/gestures/lasso_select_tool\":380,\"models/tools/gestures/poly_select_tool\":381,\"models/tools/edit/line_edit_tool\":382,\"models/tools/edit/line_tool\":383,\"models/tools/gestures/pan_tool\":384,\"models/tools/gestures/range_tool\":385,\"models/tools/gestures/tap_tool\":386,\"models/tools/gestures/wheel_pan_tool\":387,\"models/tools/gestures/wheel_zoom_tool\":388,\"models/tools/inspectors/crosshair_tool\":389,\"models/tools/inspectors/customjs_hover\":390,\"models/tools/inspectors/hover_tool\":391,\"models/dom/index\":392,\"models/dom/styles\":393,\"models/tools/tool_proxy\":394,\"models/tools/toolbar_box\":395,\"document/defs\":396,\"embed/standalone\":397,\"embed/dom\":398,\"embed/server\":399,\"client/connection\":400,\"protocol/message\":401,\"protocol/receiver\":402,\"client/session\":403,\"embed/notebook\":404,\"styles/notebook.css\":405,\"protocol/index\":406,\"testing\":407,\"safely\":408}, {});});\n", "\n", " /* END bokeh.min.js */\n", " },\n", " function(Bokeh) {\n", " /* BEGIN bokeh-gl.min.js */\n", " /*!\n", " * Copyright (c) 2012 - 2021, Anaconda, Inc., and Bokeh Contributors\n", " * All rights reserved.\n", " * \n", " * Redistribution and use in source and binary forms, with or without modification,\n", " * are permitted provided that the following conditions are met:\n", " * \n", " * Redistributions of source code must retain the above copyright notice,\n", " * this list of conditions and the following disclaimer.\n", " * \n", " * Redistributions in binary form must reproduce the above copyright notice,\n", " * this list of conditions and the following disclaimer in the documentation\n", " * and/or other materials provided with the distribution.\n", " * \n", " * Neither the name of Anaconda nor the names of any contributors\n", " * may be used to endorse or promote products derived from this software\n", " * without specific prior written permission.\n", " * \n", " * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n", " * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n", " * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n", " * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE\n", " * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n", " * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n", " * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\n", " * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\n", " * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n", " * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\n", " * THE POSSIBILITY OF SUCH DAMAGE.\n", " */\n", " (function(root, factory) {\n", " factory(root[\"Bokeh\"], \"2.4.2\");\n", " })(this, function(Bokeh, version) {\n", " let define;\n", " return (function(modules, entry, aliases, externals) {\n", " const bokeh = typeof Bokeh !== \"undefined\" && (version != null ? Bokeh[version] : Bokeh);\n", " if (bokeh != null) {\n", " return bokeh.register_plugin(modules, entry, aliases);\n", " } else {\n", " throw new Error(\"Cannot find Bokeh \" + version + \". You have to load it prior to loading plugins.\");\n", " }\n", " })\n", " ({\n", " 409: function _(n,c,f,i,o){i(),n(410)},\n", " 410: function _(t,_,r,e,o){e();const g=t(1);\n", " /*\n", " Copyright notice: many of the awesome techniques and GLSL code contained in\n", " this module are based on work by Nicolas Rougier as part of the Glumpy and\n", " Vispy projects. The algorithms are published in\n", " http://jcgt.org/published/0003/04/01/ and http://jcgt.org/published/0002/02/08/\n", " \n", " Other locations where we work with GL, or prepare for GL-rendering:\n", " - canvas.ts\n", " - plot.ts\n", " - glyph.ts\n", " - glyph_renderer.ts\n", " */o(\"get_regl\",t(411).get_regl),(0,g.__exportStar)(t(421),r),(0,g.__exportStar)(t(425),r),(0,g.__exportStar)(t(426),r)},\n", " 411: function _(t,i,e,_,a){_();const r=t(1),o=(0,r.__importDefault)(t(412)),n=t(413),s=(0,r.__importDefault)(t(415)),l=(0,r.__importDefault)(t(416)),p=(0,r.__importDefault)(t(417)),c=(0,r.__importDefault)(t(418)),h=(0,r.__importDefault)(t(419)),u=(0,r.__importDefault)(t(420));let f;e.get_regl=function(t){return null==f&&(f=new g(t)),f};class g{constructor(t){try{this._regl=(0,o.default)({gl:t,extensions:[\"ANGLE_instanced_arrays\",\"EXT_blend_minmax\"]}),this._regl_available=!0,this._line_geometry=this._regl.buffer({usage:\"static\",type:\"float\",data:[[-2,0],[-1,-1],[1,-1],[2,0],[1,1],[-1,1]]}),this._line_triangles=this._regl.elements({usage:\"static\",primitive:\"triangles\",data:[[0,1,5],[1,2,5],[5,2,4],[2,3,4]]})}catch(t){this._regl_available=!1}}buffer(t){return this._regl.buffer(t)}clear(t,i){this._viewport={x:0,y:0,width:t,height:i},this._regl.clear({color:[0,0,0,0]})}get has_webgl(){return this._regl_available}get scissor(){return this._scissor}set_scissor(t,i,e,_){this._scissor={x:t,y:i,width:e,height:_}}get viewport(){return this._viewport}dashed_line(){return null==this._dashed_line&&(this._dashed_line=function(t,i,e){const _={vert:`#define DASHED\\n\\n${s.default}`,frag:`#define DASHED\\n\\n${l.default}`,attributes:{a_position:{buffer:i,divisor:0},a_point_prev:(t,i)=>i.points.to_attribute_config(),a_point_start:(t,i)=>i.points.to_attribute_config(2*Float32Array.BYTES_PER_ELEMENT),a_point_end:(t,i)=>i.points.to_attribute_config(4*Float32Array.BYTES_PER_ELEMENT),a_point_next:(t,i)=>i.points.to_attribute_config(6*Float32Array.BYTES_PER_ELEMENT),a_length_so_far:(t,i)=>i.length_so_far.to_attribute_config()},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\"),u_line_color:t.prop(\"line_color\"),u_linewidth:t.prop(\"linewidth\"),u_miter_limit:t.prop(\"miter_limit\"),u_line_join:t.prop(\"line_join\"),u_line_cap:t.prop(\"line_cap\"),u_dash_tex:t.prop(\"dash_tex\"),u_dash_tex_info:t.prop(\"dash_tex_info\"),u_dash_scale:t.prop(\"dash_scale\"),u_dash_offset:t.prop(\"dash_offset\")},elements:e,instances:t.prop(\"nsegments\"),blend:{enable:!0,equation:\"max\",func:{srcRGB:1,srcAlpha:1,dstRGB:1,dstAlpha:1}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(_)}(this._regl,this._line_geometry,this._line_triangles)),this._dashed_line}get_dash(t){return null==this._dash_cache&&(this._dash_cache=new n.DashCache(this._regl)),this._dash_cache.get(t)}marker(t){null==this._marker_map&&(this._marker_map=new Map);let i=this._marker_map.get(t);return null==i&&(i=function(t,i){const e={vert:p.default,frag:`#define USE_${i.toUpperCase()}\\n\\n${c.default}`,attributes:{a_position:{buffer:t.buffer([[-.5,-.5],[-.5,.5],[.5,.5],[.5,-.5]]),divisor:0},a_center:(t,i)=>i.center.to_attribute_config(),a_size:(t,i)=>i.size.to_attribute_config(),a_angle:(t,i)=>i.angle.to_attribute_config(),a_linewidth:(t,i)=>i.linewidth.to_attribute_config(),a_line_color:(t,i)=>i.line_color.to_attribute_config(),a_fill_color:(t,i)=>i.fill_color.to_attribute_config(),a_show:(t,i)=>i.show.to_attribute_config()},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\")},count:4,primitive:\"triangle fan\",instances:t.prop(\"nmarkers\"),blend:{enable:!0,func:{srcRGB:\"one\",srcAlpha:\"one\",dstRGB:\"one minus src alpha\",dstAlpha:\"one minus src alpha\"}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(e)}(this._regl,t),this._marker_map.set(t,i)),i}rect_no_hatch(){return null==this._rect_no_hatch&&(this._rect_no_hatch=function(t){const i={vert:h.default,frag:u.default,attributes:{a_position:{buffer:t.buffer([[-.5,-.5],[-.5,.5],[.5,.5],[.5,-.5]]),divisor:0},a_center:(t,i)=>i.center.to_attribute_config(),a_width:(t,i)=>i.width.to_attribute_config(),a_height:(t,i)=>i.height.to_attribute_config(),a_angle:(t,i)=>i.angle.to_attribute_config(),a_linewidth:(t,i)=>i.linewidth.to_attribute_config(),a_line_color:(t,i)=>i.line_color.to_attribute_config(),a_fill_color:(t,i)=>i.fill_color.to_attribute_config(),a_line_join:(t,i)=>i.line_join.to_attribute_config(),a_show:(t,i)=>i.show.to_attribute_config()},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\")},count:4,primitive:\"triangle fan\",instances:t.prop(\"nmarkers\"),blend:{enable:!0,func:{srcRGB:\"one\",srcAlpha:\"one\",dstRGB:\"one minus src alpha\",dstAlpha:\"one minus src alpha\"}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(i)}(this._regl)),this._rect_no_hatch}rect_hatch(){return null==this._rect_hatch&&(this._rect_hatch=function(t){const i={vert:`#define HATCH\\n\\n${h.default}`,frag:`#define HATCH\\n\\n${u.default}`,attributes:{a_position:{buffer:t.buffer([[-.5,-.5],[-.5,.5],[.5,.5],[.5,-.5]]),divisor:0},a_center:(t,i)=>i.center.to_attribute_config(),a_width:(t,i)=>i.width.to_attribute_config(),a_height:(t,i)=>i.height.to_attribute_config(),a_angle:(t,i)=>i.angle.to_attribute_config(),a_linewidth:(t,i)=>i.linewidth.to_attribute_config(),a_line_color:(t,i)=>i.line_color.to_attribute_config(),a_fill_color:(t,i)=>i.fill_color.to_attribute_config(),a_line_join:(t,i)=>i.line_join.to_attribute_config(),a_show:(t,i)=>i.show.to_attribute_config(),a_hatch_pattern:(t,i)=>i.hatch_pattern.to_attribute_config(),a_hatch_scale:(t,i)=>i.hatch_scale.to_attribute_config(),a_hatch_weight:(t,i)=>i.hatch_weight.to_attribute_config(),a_hatch_color:(t,i)=>i.hatch_color.to_attribute_config()},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\")},count:4,primitive:\"triangle fan\",instances:t.prop(\"nmarkers\"),blend:{enable:!0,func:{srcRGB:\"one\",srcAlpha:\"one\",dstRGB:\"one minus src alpha\",dstAlpha:\"one minus src alpha\"}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(i)}(this._regl)),this._rect_hatch}solid_line(){return null==this._solid_line&&(this._solid_line=function(t,i,e){const _={vert:s.default,frag:l.default,attributes:{a_position:{buffer:i,divisor:0},a_point_prev:(t,i)=>i.points.to_attribute_config(),a_point_start:(t,i)=>i.points.to_attribute_config(2*Float32Array.BYTES_PER_ELEMENT),a_point_end:(t,i)=>i.points.to_attribute_config(4*Float32Array.BYTES_PER_ELEMENT),a_point_next:(t,i)=>i.points.to_attribute_config(6*Float32Array.BYTES_PER_ELEMENT)},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\"),u_line_color:t.prop(\"line_color\"),u_linewidth:t.prop(\"linewidth\"),u_miter_limit:t.prop(\"miter_limit\"),u_line_join:t.prop(\"line_join\"),u_line_cap:t.prop(\"line_cap\")},elements:e,instances:t.prop(\"nsegments\"),blend:{enable:!0,equation:\"max\",func:{srcRGB:1,srcAlpha:1,dstRGB:1,dstAlpha:1}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(_)}(this._regl,this._line_geometry,this._line_triangles)),this._solid_line}}e.ReglWrapper=g,g.__name__=\"ReglWrapper\"},\n", " 412: function _(e,t,r,n,a){var i,o;i=this,o=function(){\"use strict\";var e=function(e){return e instanceof Uint8Array||e instanceof Uint16Array||e instanceof Uint32Array||e instanceof Int8Array||e instanceof Int16Array||e instanceof Int32Array||e instanceof Float32Array||e instanceof Float64Array||e instanceof Uint8ClampedArray},t=function(e,t){for(var r=Object.keys(t),n=0;n=0&&(0|e)===e||n(\"invalid parameter type, (\"+e+\")\"+i(t)+\". must be a nonnegative integer\")},oneOf:f,shaderError:function(e,t,n,i,o){if(!e.getShaderParameter(t,e.COMPILE_STATUS)){var f=e.getShaderInfoLog(t),u=i===e.FRAGMENT_SHADER?\"fragment\":\"vertex\";g(n,\"string\",u+\" shader source must be a string\",o);var c=h(n,o),l=function(e){var t=[];return e.split(\"\\n\").forEach((function(e){if(!(e.length<5)){var r=/^ERROR:\\s+(\\d+):(\\d+):\\s*(.*)$/.exec(e);r?t.push(new d(0|r[1],0|r[2],r[3].trim())):e.length>0&&t.push(new d(\"unknown\",0,e))}})),t}(f);!function(e,t){t.forEach((function(t){var r=e[t.file];if(r){var n=r.index[t.line];if(n)return n.errors.push(t),void(r.hasErrors=!0)}e.unknown.hasErrors=!0,e.unknown.lines[0].errors.push(t)}))}(c,l),Object.keys(c).forEach((function(e){var t=c[e];if(t.hasErrors){var n=[\"\"],a=[\"\"];i(\"file number \"+e+\": \"+t.name+\"\\n\",\"color:red;text-decoration:underline;font-weight:bold\"),t.lines.forEach((function(e){if(e.errors.length>0){i(s(e.number,4)+\"| \",\"background-color:yellow; font-weight:bold\"),i(e.line+r,\"color:red; background-color:yellow; font-weight:bold\");var t=0;e.errors.forEach((function(n){var a=n.message,o=/^\\s*'(.*)'\\s*:\\s*(.*)$/.exec(a);if(o){var f=o[1];a=o[2],\"assign\"===f&&(f=\"=\"),t=Math.max(e.line.indexOf(f,t),0)}else t=0;i(s(\"| \",6)),i(s(\"^^^\",t+3)+r,\"font-weight:bold\"),i(s(\"| \",6)),i(a+r,\"font-weight:bold\")})),i(s(\"| \",6)+r)}else i(s(e.number,4)+\"| \"),i(e.line+r,\"color:red\")})),\"undefined\"==typeof document||window.chrome?console.log(n.join(\"\")):(a[0]=n.join(\"%c\"),console.log.apply(console,a))}function i(e,t){n.push(e),a.push(t||\"\")}})),a.raise(\"Error compiling \"+u+\" shader, \"+c[0].name)}},linkError:function(e,t,n,i,o){if(!e.getProgramParameter(t,e.LINK_STATUS)){var f=e.getProgramInfoLog(t),u=h(n,o),s='Error linking program with vertex shader, \"'+h(i,o)[0].name+'\", and fragment shader \"'+u[0].name+'\"';\"undefined\"!=typeof document?console.log(\"%c\"+s+\"\\n%c\"+f,\"color:red;text-decoration:underline;font-weight:bold\",\"color:red\"):console.log(s+r+f),a.raise(s)}},callSite:p,saveCommandRef:b,saveDrawInfo:function(e,t,r,n){function a(e){return e?n.id(e):0}function i(e,t){Object.keys(t).forEach((function(t){e[n.id(t)]=!0}))}b(e),e._fragId=a(e.static.frag),e._vertId=a(e.static.vert);var o=e._uniformSet={};i(o,t.static),i(o,t.dynamic);var f=e._attributeSet={};i(f,r.static),i(f,r.dynamic),e._hasCount=\"count\"in e.static||\"count\"in e.dynamic||\"elements\"in e.static||\"elements\"in e.dynamic},framebufferFormat:function(e,t,r){e.texture?f(e.texture._texture.internalformat,t,\"unsupported texture format for attachment\"):f(e.renderbuffer._renderbuffer.format,r,\"unsupported renderbuffer format for attachment\")},guessCommand:m,texture2D:function(e,t,r){var n,i=t.width,o=t.height,f=t.channels;a(i>0&&i<=r.maxTextureSize&&o>0&&o<=r.maxTextureSize,\"invalid texture shape\"),e.wrapS===y&&e.wrapT===y||a(A(i)&&A(o),\"incompatible wrap mode for texture, both width and height must be power of 2\"),1===t.mipmask?1!==i&&1!==o&&a(9984!==e.minFilter&&9986!==e.minFilter&&9985!==e.minFilter&&9987!==e.minFilter,\"min filter requires mipmap\"):(a(A(i)&&A(o),\"texture must be a square power of 2 to support mipmapping\"),a(t.mipmask===(i<<1)-1,\"missing or incomplete mipmap data\")),5126===t.type&&(r.extensions.indexOf(\"oes_texture_float_linear\")<0&&a(9728===e.minFilter&&9728===e.magFilter,\"filter not supported, must enable oes_texture_float_linear\"),a(!e.genMipmaps,\"mipmap generation not supported with float textures\"));var u=t.images;for(n=0;n<16;++n)if(u[n]){var s=i>>n,c=o>>n;a(t.mipmask&1<0&&i<=n.maxTextureSize&&o>0&&o<=n.maxTextureSize,\"invalid texture shape\"),a(i===o,\"cube map must be square\"),a(t.wrapS===y&&t.wrapT===y,\"wrap mode not supported by cube map\");for(var u=0;u>l,p=o>>l;a(s.mipmask&1<1&&t===r&&('\"'===t||\"'\"===t))return['\"'+O(e.substr(1,e.length-2))+'\"'];var n=/\\[(false|true|null|\\d+|'[^']*'|\"[^\"]*\")\\]/.exec(e);if(n)return E(e.substr(0,n.index)).concat(E(n[1])).concat(E(e.substr(n.index+n[0].length)));var a=e.split(\".\");if(1===a.length)return['\"'+O(e)+'\"'];for(var i=[],o=0;o0,\"invalid pixel ratio\"))):_.raise(\"invalid arguments to regl\"),r&&(\"canvas\"===r.nodeName.toLowerCase()?a=r:n=r),!i){if(!a){_(\"undefined\"!=typeof document,\"must manually specify webgl context outside of DOM environments\");var h=function(e,r,n){var a,i=document.createElement(\"canvas\");function o(){var t=window.innerWidth,r=window.innerHeight;if(e!==document.body){var a=i.getBoundingClientRect();t=a.right-a.left,r=a.bottom-a.top}i.width=n*t,i.height=n*r}return t(i.style,{border:0,margin:0,padding:0,top:0,left:0,width:\"100%\",height:\"100%\"}),e.appendChild(i),e===document.body&&(i.style.position=\"absolute\",t(e.style,{margin:0,padding:0})),e!==document.body&&\"function\"==typeof ResizeObserver?(a=new ResizeObserver((function(){setTimeout(o)}))).observe(e):window.addEventListener(\"resize\",o,!1),o(),{canvas:i,onDestroy:function(){a?a.disconnect():window.removeEventListener(\"resize\",o),e.removeChild(i)}}}(n||document.body,0,l);if(!h)return null;a=h.canvas,p=h.onDestroy}void 0===u.premultipliedAlpha&&(u.premultipliedAlpha=!0),i=function(e,t){function r(r){try{return e.getContext(r,t)}catch(e){return null}}return r(\"webgl\")||r(\"experimental-webgl\")||r(\"webgl-experimental\")}(a,u)}return i?{gl:i,canvas:a,container:n,extensions:s,optionalExtensions:c,pixelRatio:l,profile:d,onDone:m,onDestroy:p}:(p(),m(\"webgl not supported, try upgrading your browser or graphics drivers http://get.webgl.org\"),null)}function V(e,t){for(var r=Array(e),n=0;n65535)<<4,t|=r=((e>>>=t)>255)<<3,t|=r=((e>>>=r)>15)<<2,(t|=r=((e>>>=r)>3)<<1)|(e>>>=r)>>1}function P(){var e=V(8,(function(){return[]}));function t(t){var r=function(e){for(var t=16;t<=1<<28;t*=16)if(e<=t)return t;return 0}(t),n=e[I(r)>>2];return n.length>0?n.pop():new ArrayBuffer(r)}function r(t){e[I(t.byteLength)>>2].push(t)}return{alloc:t,free:r,allocType:function(e,r){var n=null;switch(e){case 5120:n=new Int8Array(t(r),0,r);break;case 5121:n=new Uint8Array(t(r),0,r);break;case 5122:n=new Int16Array(t(2*r),0,r);break;case 5123:n=new Uint16Array(t(2*r),0,r);break;case 5124:n=new Int32Array(t(4*r),0,r);break;case 5125:n=new Uint32Array(t(4*r),0,r);break;case 5126:n=new Float32Array(t(4*r),0,r);break;default:return null}return n.length!==r?n.subarray(0,r):n},freeType:function(e){r(e.buffer)}}}var L=P();L.zero=P();var R=3553,M=6408,W=5126,U=36160;function G(t){return!!t&&\"object\"==typeof t&&Array.isArray(t.shape)&&Array.isArray(t.stride)&&\"number\"==typeof t.offset&&t.shape.length===t.stride.length&&(Array.isArray(t.data)||e(t.data))}var H=function(e){return Object.keys(e).map((function(t){return e[t]}))},N={shape:function(e){for(var t=[],r=e;r.length;r=r[0])t.push(r.length);return t},flatten:function(e,t,r,n){var a=1;if(t.length)for(var i=0;i>>31<<15,i=(n<<1>>>24)-127,o=n>>13&1023;if(i<-24)t[r]=a;else if(i<-14){var f=-14-i;t[r]=a+(o+1024>>f)}else t[r]=i>15?a+31744:a+(i+15<<10)+o}return t}function me(t){return Array.isArray(t)||e(t)}var pe=function(e){return!(e&e-1||!e)},he=3553,be=34067,ve=34069,ge=6408,ye=6406,xe=6407,we=6409,Ae=6410,_e=32855,ke=6402,Se=34041,Oe=35904,Ee=35906,Te=36193,De=33776,je=33777,Ce=33778,ze=33779,Fe=5121,Be=5123,Ve=5125,Ie=5126,Pe=33071,Le=9728,Re=9984,Me=9987,We=4352,Ue=33984,Ge=[Re,9986,9985,Me],He=[0,we,Ae,xe,ge],Ne={};function qe(e){return\"[object \"+e+\"]\"}Ne[6409]=Ne[6406]=Ne[6402]=1,Ne[34041]=Ne[6410]=2,Ne[6407]=Ne[35904]=3,Ne[6408]=Ne[35906]=4;var Qe=qe(\"HTMLCanvasElement\"),Ye=qe(\"OffscreenCanvas\"),Xe=qe(\"CanvasRenderingContext2D\"),$e=qe(\"ImageBitmap\"),Ke=qe(\"HTMLImageElement\"),Je=qe(\"HTMLVideoElement\"),Ze=Object.keys(Y).concat([Qe,Ye,Xe,$e,Ke,Je]),et=[];et[5121]=1,et[5126]=4,et[36193]=2,et[5123]=2,et[5125]=4;var tt=[];function rt(e){return Array.isArray(e)&&(0===e.length||\"number\"==typeof e[0])}function nt(e){return!!Array.isArray(e)&&!(0===e.length||!me(e[0]))}function at(e){return Object.prototype.toString.call(e)}function it(e){return at(e)===Qe}function ot(e){return at(e)===Ye}function ft(e){if(!e)return!1;var t=at(e);return Ze.indexOf(t)>=0||rt(e)||nt(e)||G(e)}function ut(e){return 0|Y[Object.prototype.toString.call(e)]}function st(e,t){return L.allocType(e.type===Te?Ie:e.type,t)}function ct(e,t){e.type===Te?(e.data=de(t),L.freeType(t)):e.data=t}function lt(e,t,r,n,a,i){var o;if(o=void 0!==tt[e]?tt[e]:Ne[e]*et[t],i&&(o*=6),a){for(var f=0,u=r;u>=1;)f+=o*u*u,u/=2;return f}return o*r*n}function dt(r,n,a,i,o,f,u){var s={\"don't care\":We,\"dont care\":We,nice:4354,fast:4353},c={repeat:10497,clamp:Pe,mirror:33648},l={nearest:Le,linear:9729},d=t({mipmap:Me,\"nearest mipmap nearest\":Re,\"linear mipmap nearest\":9985,\"nearest mipmap linear\":9986,\"linear mipmap linear\":Me},l),m={none:0,browser:37444},p={uint8:Fe,rgba4:32819,rgb565:33635,\"rgb5 a1\":32820},h={alpha:ye,luminance:we,\"luminance alpha\":Ae,rgb:xe,rgba:ge,rgba4:32854,\"rgb5 a1\":_e,rgb565:36194},b={};n.ext_srgb&&(h.srgb=Oe,h.srgba=Ee),n.oes_texture_float&&(p.float32=p.float=Ie),n.oes_texture_half_float&&(p.float16=p[\"half float\"]=Te),n.webgl_depth_texture&&(t(h,{depth:ke,\"depth stencil\":Se}),t(p,{uint16:Be,uint32:Ve,\"depth stencil\":34042})),n.webgl_compressed_texture_s3tc&&t(b,{\"rgb s3tc dxt1\":De,\"rgba s3tc dxt1\":je,\"rgba s3tc dxt3\":Ce,\"rgba s3tc dxt5\":ze}),n.webgl_compressed_texture_atc&&t(b,{\"rgb atc\":35986,\"rgba atc explicit alpha\":35987,\"rgba atc interpolated alpha\":34798}),n.webgl_compressed_texture_pvrtc&&t(b,{\"rgb pvrtc 4bppv1\":35840,\"rgb pvrtc 2bppv1\":35841,\"rgba pvrtc 4bppv1\":35842,\"rgba pvrtc 2bppv1\":35843}),n.webgl_compressed_texture_etc1&&(b[\"rgb etc1\"]=36196);var v=Array.prototype.slice.call(r.getParameter(34467));Object.keys(b).forEach((function(e){var t=b[e];v.indexOf(t)>=0&&(h[e]=t)}));var g=Object.keys(h);a.textureFormats=g;var y=[];Object.keys(h).forEach((function(e){var t=h[e];y[t]=e}));var x=[];Object.keys(p).forEach((function(e){var t=p[e];x[t]=e}));var w=[];Object.keys(l).forEach((function(e){w[l[e]]=e}));var A=[];Object.keys(d).forEach((function(e){var t=d[e];A[t]=e}));var k=[];Object.keys(c).forEach((function(e){k[c[e]]=e}));var S=g.reduce((function(e,t){var r=h[t];return r===we||r===ye||r===we||r===Ae||r===ke||r===Se||n.ext_srgb&&(r===Oe||r===Ee)?e[r]=r:r===_e||t.indexOf(\"rgba\")>=0?e[r]=ge:e[r]=xe,e}),{});function O(){this.internalformat=ge,this.format=ge,this.type=Fe,this.compressed=!1,this.premultiplyAlpha=!1,this.flipY=!1,this.unpackAlignment=1,this.colorSpace=37444,this.width=0,this.height=0,this.channels=0}function E(e,t){e.internalformat=t.internalformat,e.format=t.format,e.type=t.type,e.compressed=t.compressed,e.premultiplyAlpha=t.premultiplyAlpha,e.flipY=t.flipY,e.unpackAlignment=t.unpackAlignment,e.colorSpace=t.colorSpace,e.width=t.width,e.height=t.height,e.channels=t.channels}function T(e,t){if(\"object\"==typeof t&&t){if(\"premultiplyAlpha\"in t&&(_.type(t.premultiplyAlpha,\"boolean\",\"invalid premultiplyAlpha\"),e.premultiplyAlpha=t.premultiplyAlpha),\"flipY\"in t&&(_.type(t.flipY,\"boolean\",\"invalid texture flip\"),e.flipY=t.flipY),\"alignment\"in t&&(_.oneOf(t.alignment,[1,2,4,8],\"invalid texture unpack alignment\"),e.unpackAlignment=t.alignment),\"colorSpace\"in t&&(_.parameter(t.colorSpace,m,\"invalid colorSpace\"),e.colorSpace=m[t.colorSpace]),\"type\"in t){var r=t.type;_(n.oes_texture_float||!(\"float\"===r||\"float32\"===r),\"you must enable the OES_texture_float extension in order to use floating point textures.\"),_(n.oes_texture_half_float||!(\"half float\"===r||\"float16\"===r),\"you must enable the OES_texture_half_float extension in order to use 16-bit floating point textures.\"),_(n.webgl_depth_texture||!(\"uint16\"===r||\"uint32\"===r||\"depth stencil\"===r),\"you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures.\"),_.parameter(r,p,\"invalid texture type\"),e.type=p[r]}var i=e.width,o=e.height,f=e.channels,u=!1;\"shape\"in t?(_(Array.isArray(t.shape)&&t.shape.length>=2,\"shape must be an array\"),i=t.shape[0],o=t.shape[1],3===t.shape.length&&(f=t.shape[2],_(f>0&&f<=4,\"invalid number of channels\"),u=!0),_(i>=0&&i<=a.maxTextureSize,\"invalid width\"),_(o>=0&&o<=a.maxTextureSize,\"invalid height\")):(\"radius\"in t&&(i=o=t.radius,_(i>=0&&i<=a.maxTextureSize,\"invalid radius\")),\"width\"in t&&(i=t.width,_(i>=0&&i<=a.maxTextureSize,\"invalid width\")),\"height\"in t&&(o=t.height,_(o>=0&&o<=a.maxTextureSize,\"invalid height\")),\"channels\"in t&&(f=t.channels,_(f>0&&f<=4,\"invalid number of channels\"),u=!0)),e.width=0|i,e.height=0|o,e.channels=0|f;var s=!1;if(\"format\"in t){var c=t.format;_(n.webgl_depth_texture||!(\"depth\"===c||\"depth stencil\"===c),\"you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures.\"),_.parameter(c,h,\"invalid texture format\");var l=e.internalformat=h[c];e.format=S[l],c in p&&(\"type\"in t||(e.type=p[c])),c in b&&(e.compressed=!0),s=!0}!u&&s?e.channels=Ne[e.format]:u&&!s?e.channels!==He[e.format]&&(e.format=e.internalformat=He[e.channels]):s&&u&&_(e.channels===Ne[e.format],\"number of channels inconsistent with specified format\")}}function D(e){r.pixelStorei(37440,e.flipY),r.pixelStorei(37441,e.premultiplyAlpha),r.pixelStorei(37443,e.colorSpace),r.pixelStorei(3317,e.unpackAlignment)}function j(){O.call(this),this.xOffset=0,this.yOffset=0,this.data=null,this.needsFree=!1,this.element=null,this.needsCopy=!1}function C(t,r){var n=null;if(ft(r)?n=r:r&&(_.type(r,\"object\",\"invalid pixel data type\"),T(t,r),\"x\"in r&&(t.xOffset=0|r.x),\"y\"in r&&(t.yOffset=0|r.y),ft(r.data)&&(n=r.data)),_(!t.compressed||n instanceof Uint8Array,\"compressed texture data must be stored in a uint8array\"),r.copy){_(!n,\"can not specify copy and data field for the same texture\");var i=o.viewportWidth,f=o.viewportHeight;t.width=t.width||i-t.xOffset,t.height=t.height||f-t.yOffset,t.needsCopy=!0,_(t.xOffset>=0&&t.xOffset=0&&t.yOffset0&&t.width<=i&&t.height>0&&t.height<=f,\"copy texture read out of bounds\")}else if(n){if(e(n))t.channels=t.channels||4,t.data=n,\"type\"in r||t.type!==Fe||(t.type=ut(n));else if(rt(n))t.channels=t.channels||4,function(e,t){var r=t.length;switch(e.type){case Fe:case Be:case Ve:case Ie:var n=L.allocType(e.type,r);n.set(t),e.data=n;break;case Te:e.data=de(t);break;default:_.raise(\"unsupported texture type, must specify a typed array\")}}(t,n),t.alignment=1,t.needsFree=!0;else if(G(n)){var u=n.data;Array.isArray(u)||t.type!==Fe||(t.type=ut(u));var s,c,l,d,m,p,h=n.shape,b=n.stride;3===h.length?(l=h[2],p=b[2]):(_(2===h.length,\"invalid ndarray pixel data, must be 2 or 3D\"),l=1,p=1),s=h[0],c=h[1],d=b[0],m=b[1],t.alignment=1,t.width=s,t.height=c,t.channels=l,t.format=t.internalformat=He[l],t.needsFree=!0,function(e,t,r,n,a,i){for(var o=e.width,f=e.height,u=e.channels,s=st(e,o*f*u),c=0,l=0;l=0,\"oes_texture_float extension not enabled\"):t.type===Te&&_(a.extensions.indexOf(\"oes_texture_half_float\")>=0,\"oes_texture_half_float extension not enabled\")}function z(e,t,n){var a=e.element,o=e.data,f=e.internalformat,u=e.format,s=e.type,c=e.width,l=e.height;D(e),a?r.texImage2D(t,n,u,u,s,a):e.compressed?r.compressedTexImage2D(t,n,f,c,l,0,o):e.needsCopy?(i(),r.copyTexImage2D(t,n,u,e.xOffset,e.yOffset,c,l,0)):r.texImage2D(t,n,u,c,l,0,u,s,o||null)}function F(e,t,n,a,o){var f=e.element,u=e.data,s=e.internalformat,c=e.format,l=e.type,d=e.width,m=e.height;D(e),f?r.texSubImage2D(t,o,n,a,c,l,f):e.compressed?r.compressedTexSubImage2D(t,o,n,a,s,d,m,u):e.needsCopy?(i(),r.copyTexSubImage2D(t,o,n,a,e.xOffset,e.yOffset,d,m)):r.texSubImage2D(t,o,n,a,d,m,c,l,u)}var B=[];function V(){return B.pop()||new j}function I(e){e.needsFree&&L.freeType(e.data),j.call(e),B.push(e)}function P(){O.call(this),this.genMipmaps=!1,this.mipmapHint=We,this.mipmask=0,this.images=Array(16)}function R(e,t,r){var n=e.images[0]=V();e.mipmask=1,n.width=e.width=t,n.height=e.height=r,n.channels=e.channels=4}function M(e,t){var r=null;if(ft(t))E(r=e.images[0]=V(),e),C(r,t),e.mipmask=1;else if(T(e,t),Array.isArray(t.mipmap))for(var n=t.mipmap,a=0;a>=a,r.height>>=a,C(r,n[a]),e.mipmask|=1<=0&&!(\"faces\"in t)&&(e.genMipmaps=!0)}if(\"mag\"in t){var n=t.mag;_.parameter(n,l),e.magFilter=l[n]}var i=e.wrapS,o=e.wrapT;if(\"wrap\"in t){var f=t.wrap;\"string\"==typeof f?(_.parameter(f,c),i=o=c[f]):Array.isArray(f)&&(_.parameter(f[0],c),_.parameter(f[1],c),i=c[f[0]],o=c[f[1]])}else{if(\"wrapS\"in t){var u=t.wrapS;_.parameter(u,c),i=c[u]}if(\"wrapT\"in t){var m=t.wrapT;_.parameter(m,c),o=c[m]}}if(e.wrapS=i,e.wrapT=o,\"anisotropic\"in t){var p=t.anisotropic;_(\"number\"==typeof p&&p>=1&&p<=a.maxAnisotropic,\"aniso samples must be between 1 and \"),e.anisotropic=t.anisotropic}if(\"mipmap\"in t){var h=!1;switch(typeof t.mipmap){case\"string\":_.parameter(t.mipmap,s,\"invalid mipmap hint\"),e.mipmapHint=s[t.mipmap],e.genMipmaps=!0,h=!0;break;case\"boolean\":h=e.genMipmaps=t.mipmap;break;case\"object\":_(Array.isArray(t.mipmap),\"invalid mipmap type\"),e.genMipmaps=!1,h=!0;break;default:_.raise(\"invalid mipmap type\")}h&&!(\"min\"in t)&&(e.minFilter=Re)}}function $(e,t){r.texParameteri(t,10241,e.minFilter),r.texParameteri(t,10240,e.magFilter),r.texParameteri(t,10242,e.wrapS),r.texParameteri(t,10243,e.wrapT),n.ext_texture_filter_anisotropic&&r.texParameteri(t,34046,e.anisotropic),e.genMipmaps&&(r.hint(33170,e.mipmapHint),r.generateMipmap(t))}var K=0,J={},Z=a.maxTextureUnits,ee=Array(Z).map((function(){return null}));function te(e){O.call(this),this.mipmask=0,this.internalformat=ge,this.id=K++,this.refCount=1,this.target=e,this.texture=r.createTexture(),this.unit=-1,this.bindCount=0,this.texInfo=new Y,u.profile&&(this.stats={size:0})}function re(e){r.activeTexture(Ue),r.bindTexture(e.target,e.texture)}function ne(){var e=ee[0];e?r.bindTexture(e.target,e.texture):r.bindTexture(he,null)}function ae(e){var t=e.texture;_(t,\"must not double destroy texture\");var n=e.unit,a=e.target;n>=0&&(r.activeTexture(Ue+n),r.bindTexture(a,null),ee[n]=null),r.deleteTexture(t),e.texture=null,e.params=null,e.pixels=null,e.refCount=0,delete J[e.id],f.textureCount--}return t(te.prototype,{bind:function(){var e=this;e.bindCount+=1;var t=e.unit;if(t<0){for(var n=0;n0)continue;a.unit=-1}ee[n]=e,t=n;break}t>=Z&&_.raise(\"insufficient number of texture units\"),u.profile&&f.maxTextureUnits>u)-o,s.height=s.height||(n.height>>u)-f,_(n.type===s.type&&n.format===s.format&&n.internalformat===s.internalformat,\"incompatible format for texture.subimage\"),_(o>=0&&f>=0&&o+s.width<=n.width&&f+s.height<=n.height,\"texture.subimage write out of bounds\"),_(n.mipmask&1<>f;++f){var s=a>>f,c=o>>f;if(!s||!c)break;r.texImage2D(he,f,n.format,s,c,0,n.format,n.type,null)}return ne(),u.profile&&(n.stats.size=lt(n.internalformat,n.type,a,o,!1,!1)),i},i._reglType=\"texture2d\",i._texture=n,u.profile&&(i.stats=n.stats),i.destroy=function(){n.decRef()},i},createCube:function(e,t,n,i,o,s){var c=new te(be);J[c.id]=c,f.cubeCount++;var l=new Array(6);function d(e,t,r,n,i,o){var f,s=c.texInfo;for(Y.call(s),f=0;f<6;++f)l[f]=q();if(\"number\"!=typeof e&&e)if(\"object\"==typeof e)if(t)M(l[0],e),M(l[1],t),M(l[2],r),M(l[3],n),M(l[4],i),M(l[5],o);else if(X(s,e),T(c,e),\"faces\"in e){var m=e.faces;for(_(Array.isArray(m)&&6===m.length,\"cube faces must be a length 6 array\"),f=0;f<6;++f)_(\"object\"==typeof m[f]&&!!m[f],\"invalid input for cube map face\"),E(l[f],c),M(l[f],m[f])}else for(f=0;f<6;++f)M(l[f],e);else _.raise(\"invalid arguments to cube map\");else{var p=0|e||1;for(f=0;f<6;++f)R(l[f],p,p)}for(E(c,l[0]),_.optional((function(){a.npotTextureCube||_(pe(c.width)&&pe(c.height),\"your browser does not support non power or two texture dimensions\")})),s.genMipmaps?c.mipmask=(l[0].width<<1)-1:c.mipmask=l[0].mipmask,_.textureCube(c,s,l,a),c.internalformat=l[0].internalformat,d.width=l[0].width,d.height=l[0].height,re(c),f=0;f<6;++f)W(l[f],ve+f);for($(s,be),ne(),u.profile&&(c.stats.size=lt(c.internalformat,c.type,d.width,d.height,s.genMipmaps,!0)),d.format=y[c.internalformat],d.type=x[c.type],d.mag=w[s.magFilter],d.min=A[s.minFilter],d.wrapS=k[s.wrapS],d.wrapT=k[s.wrapT],f=0;f<6;++f)Q(l[f]);return d}return d(e,t,n,i,o,s),d.subimage=function(e,t,r,n,a){_(!!t,\"must specify image data\"),_(\"number\"==typeof e&&e===(0|e)&&e>=0&&e<6,\"invalid face\");var i=0|r,o=0|n,f=0|a,u=V();return E(u,c),u.width=0,u.height=0,C(u,t),u.width=u.width||(c.width>>f)-i,u.height=u.height||(c.height>>f)-o,_(c.type===u.type&&c.format===u.format&&c.internalformat===u.internalformat,\"incompatible format for texture.subimage\"),_(i>=0&&o>=0&&i+u.width<=c.width&&o+u.height<=c.height,\"texture.subimage write out of bounds\"),_(c.mipmask&1<>a;++a)r.texImage2D(ve+n,a,c.format,t>>a,t>>a,0,c.format,c.type,null);return ne(),u.profile&&(c.stats.size=lt(c.internalformat,c.type,d.width,d.height,!1,!0)),d}},d._reglType=\"textureCube\",d._texture=c,u.profile&&(d.stats=c.stats),d.destroy=function(){c.decRef()},d},clear:function(){for(var e=0;e>t,e.height>>t,0,e.internalformat,e.type,null);else for(var n=0;n<6;++n)r.texImage2D(ve+n,t,e.internalformat,e.width>>t,e.height>>t,0,e.internalformat,e.type,null);$(e.texInfo,e.target)}))},refresh:function(){for(var e=0;e=0&&c=0&&l0&&d+c<=a.framebufferWidth,\"invalid width for read pixels\"),_(m>0&&m+l<=a.framebufferHeight,\"invalid height for read pixels\"),n();var h=d*m*4;return p||(s===Dt?p=new Uint8Array(h):s===jt&&(p=p||new Float32Array(h))),_.isTypedArray(p,\"data buffer for regl.read() must be a typedarray\"),_(p.byteLength>=h,\"data buffer for regl.read() too small\"),t.pixelStorei(3333,4),t.readPixels(c,l,d,m,6408,s,p),p}return function(e){return e&&\"framebuffer\"in e?function(e){var t;return r.setFBO({framebuffer:e.framebuffer},(function(){t=u(e)})),t}(e):u(e)}}function zt(e){return Array.prototype.slice.call(e)}function Ft(e){return zt(e).join(\"\")}var Bt=\"xyzw\".split(\"\"),Vt=\"dither\",It=\"blend.enable\",Pt=\"blend.color\",Lt=\"blend.equation\",Rt=\"blend.func\",Mt=\"depth.enable\",Wt=\"depth.func\",Ut=\"depth.range\",Gt=\"depth.mask\",Ht=\"colorMask\",Nt=\"cull.enable\",qt=\"cull.face\",Qt=\"frontFace\",Yt=\"lineWidth\",Xt=\"polygonOffset.enable\",$t=\"polygonOffset.offset\",Kt=\"sample.alpha\",Jt=\"sample.enable\",Zt=\"sample.coverage\",er=\"stencil.enable\",tr=\"stencil.mask\",rr=\"stencil.func\",nr=\"stencil.opFront\",ar=\"stencil.opBack\",ir=\"scissor.enable\",or=\"scissor.box\",fr=\"viewport\",ur=\"profile\",sr=\"framebuffer\",cr=\"vert\",lr=\"frag\",dr=\"elements\",mr=\"primitive\",pr=\"count\",hr=\"offset\",br=\"instances\",vr=\"vao\",gr=\"Width\",yr=\"Height\",xr=sr+gr,wr=sr+yr,Ar=\"drawingBufferWidth\",_r=\"drawingBufferHeight\",kr=[Rt,Lt,rr,nr,ar,Zt,fr,or,$t],Sr=34962,Or=34963,Er=5126,Tr=35664,Dr=35665,jr=35666,Cr=5124,zr=35667,Fr=35668,Br=35669,Vr=35670,Ir=35671,Pr=35672,Lr=35673,Rr=35674,Mr=35675,Wr=35676,Ur=35678,Gr=35680,Hr=1028,Nr=1029,qr=2305,Qr=7680,Yr={0:0,1:1,zero:0,one:1,\"src color\":768,\"one minus src color\":769,\"src alpha\":770,\"one minus src alpha\":771,\"dst color\":774,\"one minus dst color\":775,\"dst alpha\":772,\"one minus dst alpha\":773,\"constant color\":32769,\"one minus constant color\":32770,\"constant alpha\":32771,\"one minus constant alpha\":32772,\"src alpha saturate\":776},Xr=[\"constant color, constant alpha\",\"one minus constant color, constant alpha\",\"constant color, one minus constant alpha\",\"one minus constant color, one minus constant alpha\",\"constant alpha, constant color\",\"constant alpha, one minus constant color\",\"one minus constant alpha, constant color\",\"one minus constant alpha, one minus constant color\"],$r={never:512,less:513,\"<\":513,equal:514,\"=\":514,\"==\":514,\"===\":514,lequal:515,\"<=\":515,greater:516,\">\":516,notequal:517,\"!=\":517,\"!==\":517,gequal:518,\">=\":518,always:519},Kr={0:0,zero:0,keep:7680,replace:7681,increment:7682,decrement:7683,\"increment wrap\":34055,\"decrement wrap\":34056,invert:5386},Jr={frag:35632,vert:35633},Zr={cw:2304,ccw:qr};function en(t){return Array.isArray(t)||e(t)||G(t)}function tn(e){return e.sort((function(e,t){return e===fr?-1:t===fr?1:e=1,n>=2,t)}if(4===r){var a=e.data;return new rn(a.thisDep,a.contextDep,a.propDep,t)}if(5===r)return new rn(!1,!1,!1,t);if(6===r){for(var i=!1,o=!1,f=!1,u=0;u=1&&(o=!0),c>=2&&(f=!0)}else 4===s.type&&(i=i||s.data.thisDep,o=o||s.data.contextDep,f=f||s.data.propDep)}return new rn(i,o,f,t)}return new rn(3===r,2===r,1===r,t)}var fn=new rn(!1,!1,!1,(function(){}));function un(e,r,n,a,i,o,f,u,s,c,l,d,m,p,h){var b=c.Record,v={add:32774,subtract:32778,\"reverse subtract\":32779};n.ext_blend_minmax&&(v.min=32775,v.max=32776);var g=n.angle_instanced_arrays,y=n.webgl_draw_buffers,x=n.oes_vertex_array_object,w={dirty:!0,profile:h.profile},A={},k=[],S={},O={};function E(e){return e.replace(\".\",\"_\")}function T(e,t,r){var n=E(e);k.push(e),A[n]=w[n]=!!r,S[n]=t}function j(e,t,r){var n=E(e);k.push(e),Array.isArray(r)?(w[n]=r.slice(),A[n]=r.slice()):w[n]=A[n]=r,O[n]=t}T(Vt,3024),T(It,3042),j(Pt,\"blendColor\",[0,0,0,0]),j(Lt,\"blendEquationSeparate\",[32774,32774]),j(Rt,\"blendFuncSeparate\",[1,0,1,0]),T(Mt,2929,!0),j(Wt,\"depthFunc\",513),j(Ut,\"depthRange\",[0,1]),j(Gt,\"depthMask\",!0),j(Ht,Ht,[!0,!0,!0,!0]),T(Nt,2884),j(qt,\"cullFace\",Nr),j(Qt,Qt,qr),j(Yt,Yt,1),T(Xt,32823),j($t,\"polygonOffset\",[0,0]),T(Kt,32926),T(Jt,32928),j(Zt,\"sampleCoverage\",[1,!1]),T(er,2960),j(tr,\"stencilMask\",-1),j(rr,\"stencilFunc\",[519,0,-1]),j(nr,\"stencilOpSeparate\",[Hr,Qr,Qr,Qr]),j(ar,\"stencilOpSeparate\",[Nr,Qr,Qr,Qr]),T(ir,3089),j(or,\"scissor\",[0,0,e.drawingBufferWidth,e.drawingBufferHeight]),j(fr,fr,[0,0,e.drawingBufferWidth,e.drawingBufferHeight]);var C={gl:e,context:m,strings:r,next:A,current:w,draw:d,elements:o,buffer:i,shader:l,attributes:c.state,vao:c,uniforms:s,framebuffer:u,extensions:n,timer:p,isBufferArgs:en},z={primTypes:ie,compareFuncs:$r,blendFuncs:Yr,blendEquations:v,stencilOps:Kr,glTypes:X,orientationType:Zr};_.optional((function(){C.isArrayLike=me})),y&&(z.backBuffer=[Nr],z.drawBuffer=V(a.maxDrawbuffers,(function(e){return 0===e?[0]:V(e,(function(e){return 36064+e}))})));var F=0;function B(){var e=function(){var e=0,r=[],n=[];function a(){var r=[],n=[];return t((function(){r.push.apply(r,zt(arguments))}),{def:function(){var t=\"v\"+e++;return n.push(t),arguments.length>0&&(r.push(t,\"=\"),r.push.apply(r,zt(arguments)),r.push(\";\")),t},toString:function(){return Ft([n.length>0?\"var \"+n.join(\",\")+\";\":\"\",Ft(r)])}})}function i(){var e=a(),r=a(),n=e.toString,i=r.toString;function o(t,n){r(t,n,\"=\",e.def(t,n),\";\")}return t((function(){e.apply(e,zt(arguments))}),{def:e.def,entry:e,exit:r,save:o,set:function(t,r,n){o(t,r),e(t,r,\"=\",n,\";\")},toString:function(){return n()+i()}})}var o=a(),f={};return{global:o,link:function(t){for(var a=0;a=0,'unknown parameter \"'+t+'\"',d.commandStr)}))}t(m),t(p)}));var h=function(e,t){var r=e.static;if(\"string\"==typeof r[lr]&&\"string\"==typeof r[cr]){if(Object.keys(t.dynamic).length>0)return null;var n=t.static,a=Object.keys(n);if(a.length>0&&\"number\"==typeof n[a[0]]){for(var i=[],o=0;o=0,\"invalid \"+e,r.commandStr)):u=!1,\"height\"in i?(f=0|i.height,_.command(f>=0,\"invalid \"+e,r.commandStr)):u=!1,new rn(!u&&t&&t.thisDep,!u&&t&&t.contextDep,!u&&t&&t.propDep,(function(e,t){var r=e.shared.context,n=o;\"width\"in i||(n=t.def(r,\".\",xr,\"-\",s));var a=f;return\"height\"in i||(a=t.def(r,\".\",wr,\"-\",c)),[s,c,n,a]}))}if(e in a){var l=a[e],d=on(l,(function(t,r){var n=t.invoke(r,l);_.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e)}));var a=t.shared.context,i=r.def(n,\".x|0\"),o=r.def(n,\".y|0\"),f=r.def('\"width\" in ',n,\"?\",n,\".width|0:\",\"(\",a,\".\",xr,\"-\",i,\")\"),u=r.def('\"height\" in ',n,\"?\",n,\".height|0:\",\"(\",a,\".\",wr,\"-\",o,\")\");return _.optional((function(){t.assert(r,f+\">=0&&\"+u+\">=0\",\"invalid \"+e)})),[i,o,f,u]}));return t&&(d.thisDep=d.thisDep||t.thisDep,d.contextDep=d.contextDep||t.contextDep,d.propDep=d.propDep||t.propDep),d}return t?new rn(t.thisDep,t.contextDep,t.propDep,(function(e,t){var r=e.shared.context;return[0,0,t.def(r,\".\",xr),t.def(r,\".\",wr)]})):null}var o=i(fr);if(o){var f=o;o=new rn(o.thisDep,o.contextDep,o.propDep,(function(e,t){var r=f.append(e,t),n=e.shared.context;return t.set(n,\".viewportWidth\",r[2]),t.set(n,\".viewportHeight\",r[3]),r}))}return{viewport:o,scissor_box:i(or)}}(e,y,d),w=function(e,t){var r=e.static,n=e.dynamic,a={},i=!1,f=function(){if(vr in r){var e=r[vr];return null!==e&&null===c.getVAO(e)&&(e=c.createVAO(e)),i=!0,a.vao=e,an((function(t){var r=c.getVAO(e);return r?t.link(r):\"null\"}))}if(vr in n){i=!0;var t=n[vr];return on(t,(function(e,r){var n=e.invoke(r,t);return r.def(e.shared.vao+\".getVAO(\"+n+\")\")}))}return null}(),u=!1,s=function(){if(dr in r){var e=r[dr];if(a.elements=e,en(e)){var s=a.elements=o.create(e,!0);e=o.getElements(s),u=!0}else e&&(e=o.getElements(e),u=!0,_.command(e,\"invalid elements\",t.commandStr));var c=an((function(t,r){if(e){var n=t.link(e);return t.ELEMENTS=n,n}return t.ELEMENTS=null,null}));return c.value=e,c}if(dr in n){u=!0;var l=n[dr];return on(l,(function(e,t){var r=e.shared,n=r.isBufferArgs,a=r.elements,i=e.invoke(t,l),o=t.def(\"null\"),f=t.def(n,\"(\",i,\")\"),u=e.cond(f).then(o,\"=\",a,\".createStream(\",i,\");\").else(o,\"=\",a,\".getElements(\",i,\");\");return _.optional((function(){e.assert(u.else,\"!\"+i+\"||\"+o,\"invalid elements\")})),t.entry(u),t.exit(e.cond(f).then(a,\".destroyStream(\",o,\");\")),e.ELEMENTS=o,o}))}return i?new rn(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.elements+\".getElements(\"+e.shared.vao+\".currentVAO.elements):null\")})):null}();function l(e,o){if(e in r){var s=0|r[e];return o?a.offset=s:a.instances=s,_.command(!o||s>=0,\"invalid \"+e,t.commandStr),an((function(e,t){return o&&(e.OFFSET=s),s}))}if(e in n){var c=n[e];return on(c,(function(t,r){var n=t.invoke(r,c);return o&&(t.OFFSET=n,_.optional((function(){t.assert(r,n+\">=0\",\"invalid \"+e)}))),n}))}if(o){if(u)return an((function(e,t){return e.OFFSET=0,0}));if(i)return new rn(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.vao+\".currentVAO.offset:0\")}))}else if(i)return new rn(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.vao+\".currentVAO.instances:-1\")}));return null}var d=l(hr,!0),m=function(){if(mr in r){var e=r[mr];return a.primitive=e,_.commandParameter(e,ie,\"invalid primitve\",t.commandStr),an((function(t,r){return ie[e]}))}if(mr in n){var o=n[mr];return on(o,(function(e,t){var r=e.constants.primTypes,n=e.invoke(t,o);return _.optional((function(){e.assert(t,n+\" in \"+r,\"invalid primitive, must be one of \"+Object.keys(ie))})),t.def(r,\"[\",n,\"]\")}))}return u?nn(s)?s.value?an((function(e,t){return t.def(e.ELEMENTS,\".primType\")})):an((function(){return 4})):new rn(s.thisDep,s.contextDep,s.propDep,(function(e,t){var r=e.ELEMENTS;return t.def(r,\"?\",r,\".primType:\",4)})):i?new rn(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.vao+\".currentVAO.primitive:4\")})):null}(),p=function(){if(pr in r){var e=0|r[pr];return a.count=e,_.command(\"number\"==typeof e&&e>=0,\"invalid vertex count\",t.commandStr),an((function(){return e}))}if(pr in n){var o=n[pr];return on(o,(function(e,t){var r=e.invoke(t,o);return _.optional((function(){e.assert(t,\"typeof \"+r+'===\"number\"&&'+r+\">=0&&\"+r+\"===(\"+r+\"|0)\",\"invalid vertex count\")})),r}))}if(u){if(nn(s)){if(s)return d?new rn(d.thisDep,d.contextDep,d.propDep,(function(e,t){var r=t.def(e.ELEMENTS,\".vertCount-\",e.OFFSET);return _.optional((function(){e.assert(t,r+\">=0\",\"invalid vertex offset/element buffer too small\")})),r})):an((function(e,t){return t.def(e.ELEMENTS,\".vertCount\")}));var c=an((function(){return-1}));return _.optional((function(){c.MISSING=!0})),c}var l=new rn(s.thisDep||d.thisDep,s.contextDep||d.contextDep,s.propDep||d.propDep,(function(e,t){var r=e.ELEMENTS;return e.OFFSET?t.def(r,\"?\",r,\".vertCount-\",e.OFFSET,\":-1\"):t.def(r,\"?\",r,\".vertCount:-1\")}));return _.optional((function(){l.DYNAMIC=!0})),l}if(i){var m=new rn(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao,\".currentVAO?\",e.shared.vao,\".currentVAO.count:-1\")}));return m}return null}(),h=l(br,!1);return{elements:s,primitive:m,count:p,instances:h,offset:d,vao:f,vaoActive:i,elementsActive:u,static:a}}(e,d),A=function(e,t){var r=e.static,n=e.dynamic,i={};return k.forEach((function(e){var o=E(e);function f(t,a){if(e in r){var f=t(r[e]);i[o]=an((function(){return f}))}else if(e in n){var u=n[e];i[o]=on(u,(function(e,t){return a(e,t,e.invoke(t,u))}))}}switch(e){case Nt:case It:case Vt:case er:case Mt:case ir:case Xt:case Kt:case Jt:case Gt:return f((function(r){return _.commandType(r,\"boolean\",e,t.commandStr),r}),(function(t,r,n){return _.optional((function(){t.assert(r,\"typeof \"+n+'===\"boolean\"',\"invalid flag \"+e,t.commandStr)})),n}));case Wt:return f((function(r){return _.commandParameter(r,$r,\"invalid \"+e,t.commandStr),$r[r]}),(function(t,r,n){var a=t.constants.compareFuncs;return _.optional((function(){t.assert(r,n+\" in \"+a,\"invalid \"+e+\", must be one of \"+Object.keys($r))})),r.def(a,\"[\",n,\"]\")}));case Ut:return f((function(e){return _.command(me(e)&&2===e.length&&\"number\"==typeof e[0]&&\"number\"==typeof e[1]&&e[0]<=e[1],\"depth range is 2d array\",t.commandStr),e}),(function(e,t,r){return _.optional((function(){e.assert(t,e.shared.isArrayLike+\"(\"+r+\")&&\"+r+\".length===2&&typeof \"+r+'[0]===\"number\"&&typeof '+r+'[1]===\"number\"&&'+r+\"[0]<=\"+r+\"[1]\",\"depth range must be a 2d array\")})),[t.def(\"+\",r,\"[0]\"),t.def(\"+\",r,\"[1]\")]}));case Rt:return f((function(e){_.commandType(e,\"object\",\"blend.func\",t.commandStr);var r=\"srcRGB\"in e?e.srcRGB:e.src,n=\"srcAlpha\"in e?e.srcAlpha:e.src,a=\"dstRGB\"in e?e.dstRGB:e.dst,i=\"dstAlpha\"in e?e.dstAlpha:e.dst;return _.commandParameter(r,Yr,o+\".srcRGB\",t.commandStr),_.commandParameter(n,Yr,o+\".srcAlpha\",t.commandStr),_.commandParameter(a,Yr,o+\".dstRGB\",t.commandStr),_.commandParameter(i,Yr,o+\".dstAlpha\",t.commandStr),_.command(-1===Xr.indexOf(r+\", \"+a),\"unallowed blending combination (srcRGB, dstRGB) = (\"+r+\", \"+a+\")\",t.commandStr),[Yr[r],Yr[a],Yr[n],Yr[i]]}),(function(t,r,n){var a=t.constants.blendFuncs;function i(i,o){var f=r.def('\"',i,o,'\" in ',n,\"?\",n,\".\",i,o,\":\",n,\".\",i);return _.optional((function(){t.assert(r,f+\" in \"+a,\"invalid \"+e+\".\"+i+o+\", must be one of \"+Object.keys(Yr))})),f}_.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid blend func, must be an object\")}));var o=i(\"src\",\"RGB\"),f=i(\"dst\",\"RGB\");_.optional((function(){var e=t.constants.invalidBlendCombinations;t.assert(r,e+\".indexOf(\"+o+'+\", \"+'+f+\") === -1 \",\"unallowed blending combination for (srcRGB, dstRGB)\")}));var u=r.def(a,\"[\",o,\"]\"),s=r.def(a,\"[\",i(\"src\",\"Alpha\"),\"]\");return[u,r.def(a,\"[\",f,\"]\"),s,r.def(a,\"[\",i(\"dst\",\"Alpha\"),\"]\")]}));case Lt:return f((function(r){return\"string\"==typeof r?(_.commandParameter(r,v,\"invalid \"+e,t.commandStr),[v[r],v[r]]):\"object\"==typeof r?(_.commandParameter(r.rgb,v,e+\".rgb\",t.commandStr),_.commandParameter(r.alpha,v,e+\".alpha\",t.commandStr),[v[r.rgb],v[r.alpha]]):void _.commandRaise(\"invalid blend.equation\",t.commandStr)}),(function(t,r,n){var a=t.constants.blendEquations,i=r.def(),o=r.def(),f=t.cond(\"typeof \",n,'===\"string\"');return _.optional((function(){function r(e,r,n){t.assert(e,n+\" in \"+a,\"invalid \"+r+\", must be one of \"+Object.keys(v))}r(f.then,e,n),t.assert(f.else,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e),r(f.else,e+\".rgb\",n+\".rgb\"),r(f.else,e+\".alpha\",n+\".alpha\")})),f.then(i,\"=\",o,\"=\",a,\"[\",n,\"];\"),f.else(i,\"=\",a,\"[\",n,\".rgb];\",o,\"=\",a,\"[\",n,\".alpha];\"),r(f),[i,o]}));case Pt:return f((function(e){return _.command(me(e)&&4===e.length,\"blend.color must be a 4d array\",t.commandStr),V(4,(function(t){return+e[t]}))}),(function(e,t,r){return _.optional((function(){e.assert(t,e.shared.isArrayLike+\"(\"+r+\")&&\"+r+\".length===4\",\"blend.color must be a 4d array\")})),V(4,(function(e){return t.def(\"+\",r,\"[\",e,\"]\")}))}));case tr:return f((function(e){return _.commandType(e,\"number\",o,t.commandStr),0|e}),(function(e,t,r){return _.optional((function(){e.assert(t,\"typeof \"+r+'===\"number\"',\"invalid stencil.mask\")})),t.def(r,\"|0\")}));case rr:return f((function(r){_.commandType(r,\"object\",o,t.commandStr);var n=r.cmp||\"keep\",a=r.ref||0,i=\"mask\"in r?r.mask:-1;return _.commandParameter(n,$r,e+\".cmp\",t.commandStr),_.commandType(a,\"number\",e+\".ref\",t.commandStr),_.commandType(i,\"number\",e+\".mask\",t.commandStr),[$r[n],a,i]}),(function(e,t,r){var n=e.constants.compareFuncs;return _.optional((function(){function a(){e.assert(t,Array.prototype.join.call(arguments,\"\"),\"invalid stencil.func\")}a(r+\"&&typeof \",r,'===\"object\"'),a('!(\"cmp\" in ',r,\")||(\",r,\".cmp in \",n,\")\")})),[t.def('\"cmp\" in ',r,\"?\",n,\"[\",r,\".cmp]\",\":\",Qr),t.def(r,\".ref|0\"),t.def('\"mask\" in ',r,\"?\",r,\".mask|0:-1\")]}));case nr:case ar:return f((function(r){_.commandType(r,\"object\",o,t.commandStr);var n=r.fail||\"keep\",a=r.zfail||\"keep\",i=r.zpass||\"keep\";return _.commandParameter(n,Kr,e+\".fail\",t.commandStr),_.commandParameter(a,Kr,e+\".zfail\",t.commandStr),_.commandParameter(i,Kr,e+\".zpass\",t.commandStr),[e===ar?Nr:Hr,Kr[n],Kr[a],Kr[i]]}),(function(t,r,n){var a=t.constants.stencilOps;function i(i){return _.optional((function(){t.assert(r,'!(\"'+i+'\" in '+n+\")||(\"+n+\".\"+i+\" in \"+a+\")\",\"invalid \"+e+\".\"+i+\", must be one of \"+Object.keys(Kr))})),r.def('\"',i,'\" in ',n,\"?\",a,\"[\",n,\".\",i,\"]:\",Qr)}return _.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e)})),[e===ar?Nr:Hr,i(\"fail\"),i(\"zfail\"),i(\"zpass\")]}));case $t:return f((function(e){_.commandType(e,\"object\",o,t.commandStr);var r=0|e.factor,n=0|e.units;return _.commandType(r,\"number\",o+\".factor\",t.commandStr),_.commandType(n,\"number\",o+\".units\",t.commandStr),[r,n]}),(function(t,r,n){return _.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e)})),[r.def(n,\".factor|0\"),r.def(n,\".units|0\")]}));case qt:return f((function(e){var r=0;return\"front\"===e?r=Hr:\"back\"===e&&(r=Nr),_.command(!!r,o,t.commandStr),r}),(function(e,t,r){return _.optional((function(){e.assert(t,r+'===\"front\"||'+r+'===\"back\"',\"invalid cull.face\")})),t.def(r,'===\"front\"?',Hr,\":\",Nr)}));case Yt:return f((function(e){return _.command(\"number\"==typeof e&&e>=a.lineWidthDims[0]&&e<=a.lineWidthDims[1],\"invalid line width, must be a positive number between \"+a.lineWidthDims[0]+\" and \"+a.lineWidthDims[1],t.commandStr),e}),(function(e,t,r){return _.optional((function(){e.assert(t,\"typeof \"+r+'===\"number\"&&'+r+\">=\"+a.lineWidthDims[0]+\"&&\"+r+\"<=\"+a.lineWidthDims[1],\"invalid line width\")})),r}));case Qt:return f((function(e){return _.commandParameter(e,Zr,o,t.commandStr),Zr[e]}),(function(e,t,r){return _.optional((function(){e.assert(t,r+'===\"cw\"||'+r+'===\"ccw\"',\"invalid frontFace, must be one of cw,ccw\")})),t.def(r+'===\"cw\"?2304:'+qr)}));case Ht:return f((function(e){return _.command(me(e)&&4===e.length,\"color.mask must be length 4 array\",t.commandStr),e.map((function(e){return!!e}))}),(function(e,t,r){return _.optional((function(){e.assert(t,e.shared.isArrayLike+\"(\"+r+\")&&\"+r+\".length===4\",\"invalid color.mask\")})),V(4,(function(e){return\"!!\"+r+\"[\"+e+\"]\"}))}));case Zt:return f((function(e){_.command(\"object\"==typeof e&&e,o,t.commandStr);var r=\"value\"in e?e.value:1,n=!!e.invert;return _.command(\"number\"==typeof r&&r>=0&&r<=1,\"sample.coverage.value must be a number between 0 and 1\",t.commandStr),[r,n]}),(function(e,t,r){return _.optional((function(){e.assert(t,r+\"&&typeof \"+r+'===\"object\"',\"invalid sample.coverage\")})),[t.def('\"value\" in ',r,\"?+\",r,\".value:1\"),t.def(\"!!\",r,\".invert\")]}))}})),i}(e,d),S=function(e,t,n){var a=e.static,i=e.dynamic;function o(e){if(e in a){var t=r.id(a[e]);_.optional((function(){l.shader(Jr[e],t,_.guessCommand())}));var n=an((function(){return t}));return n.id=t,n}if(e in i){var o=i[e];return on(o,(function(t,r){var n=t.invoke(r,o),a=r.def(t.shared.strings,\".id(\",n,\")\");return _.optional((function(){r(t.shared.shader,\".shader(\",Jr[e],\",\",a,\",\",t.command,\");\")})),a}))}return null}var f,u=o(lr),s=o(cr),c=null;return nn(u)&&nn(s)?(c=l.program(s.id,u.id,null,n),f=an((function(e,t){return e.link(c)}))):f=new rn(u&&u.thisDep||s&&s.thisDep,u&&u.contextDep||s&&s.contextDep,u&&u.propDep||s&&s.propDep,(function(e,t){var r,n=e.shared.shader;r=u?u.append(e,t):t.def(n,\".\",lr);var a=n+\".program(\"+(s?s.append(e,t):t.def(n,\".\",cr))+\",\"+r;return _.optional((function(){a+=\",\"+e.command})),t.def(a+\")\")})),{frag:u,vert:s,progVar:f,program:c}}(e,0,h);function O(e){var t=x[e];t&&(A[e]=t)}O(fr),O(E(or));var T=Object.keys(A).length>0,D={framebuffer:y,draw:w,shader:S,state:A,dirty:T,scopeVAO:null,drawVAO:null,useVAO:!1,attributes:{}};if(D.profile=function(e){var t,r=e.static,n=e.dynamic;if(ur in r){var a=!!r[ur];(t=an((function(e,t){return a}))).enable=a}else if(ur in n){var i=n[ur];t=on(i,(function(e,t){return e.invoke(t,i)}))}return t}(e),D.uniforms=function(e,t){var r=e.static,n=e.dynamic,a={};return Object.keys(r).forEach((function(e){var n,i=r[e];if(\"number\"==typeof i||\"boolean\"==typeof i)n=an((function(){return i}));else if(\"function\"==typeof i){var o=i._reglType;\"texture2d\"===o||\"textureCube\"===o?n=an((function(e){return e.link(i)})):\"framebuffer\"===o||\"framebufferCube\"===o?(_.command(i.color.length>0,'missing color attachment for framebuffer sent to uniform \"'+e+'\"',t.commandStr),n=an((function(e){return e.link(i.color[0])}))):_.commandRaise('invalid data for uniform \"'+e+'\"',t.commandStr)}else me(i)?n=an((function(t){return t.global.def(\"[\",V(i.length,(function(r){return _.command(\"number\"==typeof i[r]||\"boolean\"==typeof i[r],\"invalid uniform \"+e,t.commandStr),i[r]})),\"]\")})):_.commandRaise('invalid or missing data for uniform \"'+e+'\"',t.commandStr);n.value=i,a[e]=n})),Object.keys(n).forEach((function(e){var t=n[e];a[e]=on(t,(function(e,r){return e.invoke(r,t)}))})),a}(f,d),D.drawVAO=D.scopeVAO=w.vao,!D.drawVAO&&S.program&&!h&&n.angle_instanced_arrays&&w.static.elements){var j=!0,C=S.program.attributes.map((function(e){var r=t.static[e];return j=j&&!!r,r}));if(j&&C.length>0){var z=c.getVAO(c.createVAO({attributes:C,elements:w.static.elements}));D.drawVAO=new rn(null,null,null,(function(e,t){return e.link(z)})),D.useVAO=!0}}return h?D.useVAO=!0:D.attributes=function(e,t){var n=e.static,a=e.dynamic,o={};return Object.keys(n).forEach((function(e){var a=n[e],f=r.id(e),u=new b;if(en(a))u.state=1,u.buffer=i.getBuffer(i.create(a,Sr,!1,!0)),u.type=0;else{var s=i.getBuffer(a);if(s)u.state=1,u.buffer=s,u.type=0;else if(_.command(\"object\"==typeof a&&a,\"invalid data for attribute \"+e,t.commandStr),\"constant\"in a){var c=a.constant;u.buffer=\"null\",u.state=2,\"number\"==typeof c?u.x=c:(_.command(me(c)&&c.length>0&&c.length<=4,\"invalid constant for attribute \"+e,t.commandStr),Bt.forEach((function(e,t){t=0,'invalid offset for attribute \"'+e+'\"',t.commandStr);var d=0|a.stride;_.command(d>=0&&d<256,'invalid stride for attribute \"'+e+'\", must be integer betweeen [0, 255]',t.commandStr);var m=0|a.size;_.command(!(\"size\"in a)||m>0&&m<=4,'invalid size for attribute \"'+e+'\", must be 1,2,3,4',t.commandStr);var p=!!a.normalized,h=0;\"type\"in a&&(_.commandParameter(a.type,X,\"invalid type for attribute \"+e,t.commandStr),h=X[a.type]);var v=0|a.divisor;_.optional((function(){\"divisor\"in a&&(_.command(0===v||g,'cannot specify divisor for attribute \"'+e+'\", instancing not supported',t.commandStr),_.command(v>=0,'invalid divisor for attribute \"'+e+'\"',t.commandStr));var r=t.commandStr,n=[\"buffer\",\"offset\",\"divisor\",\"normalized\",\"type\",\"size\",\"stride\"];Object.keys(a).forEach((function(t){_.command(n.indexOf(t)>=0,'unknown parameter \"'+t+'\" for attribute pointer \"'+e+'\" (valid parameters are '+n+\")\",r)}))})),u.buffer=s,u.state=1,u.size=m,u.normalized=p,u.type=h||s.dtype,u.offset=l,u.stride=d,u.divisor=v}}o[e]=an((function(e,t){var r=e.attribCache;if(f in r)return r[f];var n={isStream:!1};return Object.keys(u).forEach((function(e){n[e]=u[e]})),u.buffer&&(n.buffer=e.link(u.buffer),n.type=n.type||n.buffer+\".dtype\"),r[f]=n,n}))})),Object.keys(a).forEach((function(e){var t=a[e];o[e]=on(t,(function(r,n){var a=r.invoke(n,t),i=r.shared,o=r.constants,f=i.isBufferArgs,u=i.buffer;_.optional((function(){r.assert(n,a+\"&&(typeof \"+a+'===\"object\"||typeof '+a+'===\"function\")&&('+f+\"(\"+a+\")||\"+u+\".getBuffer(\"+a+\")||\"+u+\".getBuffer(\"+a+\".buffer)||\"+f+\"(\"+a+'.buffer)||(\"constant\" in '+a+\"&&(typeof \"+a+'.constant===\"number\"||'+i.isArrayLike+\"(\"+a+\".constant))))\",'invalid dynamic attribute \"'+e+'\"')}));var s={isStream:n.def(!1)},c=new b;c.state=1,Object.keys(c).forEach((function(e){s[e]=n.def(\"\"+c[e])}));var l=s.buffer,d=s.type;function m(e){n(s[e],\"=\",a,\".\",e,\"|0;\")}return n(\"if(\",f,\"(\",a,\")){\",s.isStream,\"=true;\",l,\"=\",u,\".createStream(\",Sr,\",\",a,\");\",d,\"=\",l,\".dtype;\",\"}else{\",l,\"=\",u,\".getBuffer(\",a,\");\",\"if(\",l,\"){\",d,\"=\",l,\".dtype;\",'}else if(\"constant\" in ',a,\"){\",s.state,\"=\",2,\";\",\"if(typeof \"+a+'.constant === \"number\"){',s[Bt[0]],\"=\",a,\".constant;\",Bt.slice(1).map((function(e){return s[e]})).join(\"=\"),\"=0;\",\"}else{\",Bt.map((function(e,t){return s[e]+\"=\"+a+\".constant.length>\"+t+\"?\"+a+\".constant[\"+t+\"]:0;\"})).join(\"\"),\"}}else{\",\"if(\",f,\"(\",a,\".buffer)){\",l,\"=\",u,\".createStream(\",Sr,\",\",a,\".buffer);\",\"}else{\",l,\"=\",u,\".getBuffer(\",a,\".buffer);\",\"}\",d,'=\"type\" in ',a,\"?\",o.glTypes,\"[\",a,\".type]:\",l,\".dtype;\",s.normalized,\"=!!\",a,\".normalized;\"),m(\"size\"),m(\"offset\"),m(\"stride\"),m(\"divisor\"),n(\"}}\"),n.exit(\"if(\",s.isStream,\"){\",u,\".destroyStream(\",l,\");\",\"}\"),s}))})),o}(t,d),D.context=function(e){var t=e.static,r=e.dynamic,n={};return Object.keys(t).forEach((function(e){var r=t[e];n[e]=an((function(e,t){return\"number\"==typeof r||\"boolean\"==typeof r?\"\"+r:e.link(r)}))})),Object.keys(r).forEach((function(e){var t=r[e];n[e]=on(t,(function(e,r){return e.invoke(r,t)}))})),n}(s),D}function P(e,t,r){var n=e.shared.context,a=e.scope();Object.keys(r).forEach((function(i){t.save(n,\".\"+i);var o=r[i].append(e,t);Array.isArray(o)?a(n,\".\",i,\"=[\",o.join(),\"];\"):a(n,\".\",i,\"=\",o,\";\")})),t(a)}function L(e,t,r,n){var a,i=e.shared,o=i.gl,f=i.framebuffer;y&&(a=t.def(i.extensions,\".webgl_draw_buffers\"));var u,s=e.constants,c=s.drawBuffer,l=s.backBuffer;u=r?r.append(e,t):t.def(f,\".next\"),n||t(\"if(\",u,\"!==\",f,\".cur){\"),t(\"if(\",u,\"){\",o,\".bindFramebuffer(\",36160,\",\",u,\".framebuffer);\"),y&&t(a,\".drawBuffersWEBGL(\",c,\"[\",u,\".colorAttachments.length]);\"),t(\"}else{\",o,\".bindFramebuffer(\",36160,\",null);\"),y&&t(a,\".drawBuffersWEBGL(\",l,\");\"),t(\"}\",f,\".cur=\",u,\";\"),n||t(\"}\")}function R(e,t,r){var n=e.shared,a=n.gl,i=e.current,o=e.next,f=n.current,u=n.next,s=e.cond(f,\".dirty\");k.forEach((function(t){var n,c,l=E(t);if(!(l in r.state))if(l in o){n=o[l],c=i[l];var d=V(w[l].length,(function(e){return s.def(n,\"[\",e,\"]\")}));s(e.cond(d.map((function(e,t){return e+\"!==\"+c+\"[\"+t+\"]\"})).join(\"||\")).then(a,\".\",O[l],\"(\",d,\");\",d.map((function(e,t){return c+\"[\"+t+\"]=\"+e})).join(\";\"),\";\"))}else{n=s.def(u,\".\",l);var m=e.cond(n,\"!==\",f,\".\",l);s(m),l in S?m(e.cond(n).then(a,\".enable(\",S[l],\");\").else(a,\".disable(\",S[l],\");\"),f,\".\",l,\"=\",n,\";\"):m(a,\".\",O[l],\"(\",n,\");\",f,\".\",l,\"=\",n,\";\")}})),0===Object.keys(r.state).length&&s(f,\".dirty=false;\"),t(s)}function M(e,t,r,n){var a=e.shared,i=e.current,o=a.current,f=a.gl;tn(Object.keys(r)).forEach((function(a){var u=r[a];if(!n||n(u)){var s=u.append(e,t);if(S[a]){var c=S[a];nn(u)?t(f,s?\".enable(\":\".disable(\",c,\");\"):t(e.cond(s).then(f,\".enable(\",c,\");\").else(f,\".disable(\",c,\");\")),t(o,\".\",a,\"=\",s,\";\")}else if(me(s)){var l=i[a];t(f,\".\",O[a],\"(\",s,\");\",s.map((function(e,t){return l+\"[\"+t+\"]=\"+e})).join(\";\"),\";\")}else t(f,\".\",O[a],\"(\",s,\");\",o,\".\",a,\"=\",s,\";\")}}))}function W(e,t){g&&(e.instancing=t.def(e.shared.extensions,\".angle_instanced_arrays\"))}function U(e,t,r,n,a){var i,o,f,u=e.shared,s=e.stats,c=u.current,l=u.timer,d=r.profile;function m(){return\"undefined\"==typeof performance?\"Date.now()\":\"performance.now()\"}function h(e){e(i=t.def(),\"=\",m(),\";\"),\"string\"==typeof a?e(s,\".count+=\",a,\";\"):e(s,\".count++;\"),p&&(n?e(o=t.def(),\"=\",l,\".getNumPendingQueries();\"):e(l,\".beginQuery(\",s,\");\"))}function b(e){e(s,\".cpuTime+=\",m(),\"-\",i,\";\"),p&&(n?e(l,\".pushScopeStats(\",o,\",\",l,\".getNumPendingQueries(),\",s,\");\"):e(l,\".endQuery();\"))}function v(e){var r=t.def(c,\".profile\");t(c,\".profile=\",e,\";\"),t.exit(c,\".profile=\",r,\";\")}if(d){if(nn(d))return void(d.enable?(h(t),b(t.exit),v(\"true\")):v(\"false\"));v(f=d.append(e,t))}else f=t.def(c,\".profile\");var g=e.block();h(g),t(\"if(\",f,\"){\",g,\"}\");var y=e.block();b(y),t.exit(\"if(\",f,\"){\",y,\"}\")}function G(e,t,r,n,a){var i=e.shared;n.forEach((function(n){var o,f=n.name,u=r.attributes[f];if(u){if(!a(u))return;o=u.append(e,t)}else{if(!a(fn))return;var s=e.scopeAttrib(f);_.optional((function(){e.assert(t,s+\".state\",\"missing attribute \"+f)})),o={},Object.keys(new b).forEach((function(e){o[e]=t.def(s,\".\",e)}))}!function(r,n,a){var o=i.gl,f=t.def(r,\".location\"),u=t.def(i.attributes,\"[\",f,\"]\"),s=a.state,c=a.buffer,l=[a.x,a.y,a.z,a.w],d=[\"buffer\",\"normalized\",\"offset\",\"stride\"];function m(){t(\"if(!\",u,\".buffer){\",o,\".enableVertexAttribArray(\",f,\");}\");var r,i=a.type;if(r=a.size?t.def(a.size,\"||\",n):n,t(\"if(\",u,\".type!==\",i,\"||\",u,\".size!==\",r,\"||\",d.map((function(e){return u+\".\"+e+\"!==\"+a[e]})).join(\"||\"),\"){\",o,\".bindBuffer(\",Sr,\",\",c,\".buffer);\",o,\".vertexAttribPointer(\",[f,r,i,a.normalized,a.stride,a.offset],\");\",u,\".type=\",i,\";\",u,\".size=\",r,\";\",d.map((function(e){return u+\".\"+e+\"=\"+a[e]+\";\"})).join(\"\"),\"}\"),g){var s=a.divisor;t(\"if(\",u,\".divisor!==\",s,\"){\",e.instancing,\".vertexAttribDivisorANGLE(\",[f,s],\");\",u,\".divisor=\",s,\";}\")}}function p(){t(\"if(\",u,\".buffer){\",o,\".disableVertexAttribArray(\",f,\");\",u,\".buffer=null;\",\"}if(\",Bt.map((function(e,t){return u+\".\"+e+\"!==\"+l[t]})).join(\"||\"),\"){\",o,\".vertexAttrib4f(\",f,\",\",l,\");\",Bt.map((function(e,t){return u+\".\"+e+\"=\"+l[t]+\";\"})).join(\"\"),\"}\")}1===s?m():2===s?p():(t(\"if(\",s,\"===\",1,\"){\"),m(),t(\"}else{\"),p(),t(\"}\"))}(e.link(n),function(e){switch(e){case Tr:case zr:case Ir:return 2;case Dr:case Fr:case Pr:return 3;case jr:case Br:case Lr:return 4;default:return 1}}(n.info.type),o)}))}function H(e,t,n,a,i,o){for(var f,u=e.shared,s=u.gl,c={},l=0;l1){if(!b)continue;var v=m.replace(\"[0]\",\"\");if(c[v])continue;c[v]=1}var g,y=e.link(d)+\".location\";if(b){if(!i(b))continue;if(nn(b)){var x=b.value;if(_.command(null!=x,'missing uniform \"'+m+'\"',e.commandStr),p===Ur||p===Gr){_.command(\"function\"==typeof x&&(p===Ur&&(\"texture2d\"===x._reglType||\"framebuffer\"===x._reglType)||p===Gr&&(\"textureCube\"===x._reglType||\"framebufferCube\"===x._reglType)),\"invalid texture for uniform \"+m,e.commandStr);var w=e.link(x._texture||x.color[0]._texture);t(s,\".uniform1i(\",y,\",\",w+\".bind());\"),t.exit(w,\".unbind();\")}else if(p===Rr||p===Mr||p===Wr){_.optional((function(){_.command(me(x),\"invalid matrix for uniform \"+m,e.commandStr),_.command(p===Rr&&4===x.length||p===Mr&&9===x.length||p===Wr&&16===x.length,\"invalid length for matrix uniform \"+m,e.commandStr)}));var A=e.global.def(\"new Float32Array([\"+Array.prototype.slice.call(x)+\"])\"),k=2;p===Mr?k=3:p===Wr&&(k=4),t(s,\".uniformMatrix\",k,\"fv(\",y,\",false,\",A,\");\")}else{switch(p){case Er:1===h?_.commandType(x,\"number\",\"uniform \"+m,e.commandStr):_.command(me(x)&&x.length===h,\"uniform \"+m,e.commandStr),f=\"1f\";break;case Tr:_.command(me(x)&&x.length&&x.length%2==0&&x.length<=2*h,\"uniform \"+m,e.commandStr),f=\"2f\";break;case Dr:_.command(me(x)&&x.length&&x.length%3==0&&x.length<=3*h,\"uniform \"+m,e.commandStr),f=\"3f\";break;case jr:_.command(me(x)&&x.length&&x.length%4==0&&x.length<=4*h,\"uniform \"+m,e.commandStr),f=\"4f\";break;case Vr:1===h?_.commandType(x,\"boolean\",\"uniform \"+m,e.commandStr):_.command(me(x)&&x.length===h,\"uniform \"+m,e.commandStr),f=\"1i\";break;case Cr:1===h?_.commandType(x,\"number\",\"uniform \"+m,e.commandStr):_.command(me(x)&&x.length===h,\"uniform \"+m,e.commandStr),f=\"1i\";break;case Ir:case zr:_.command(me(x)&&x.length&&x.length%2==0&&x.length<=2*h,\"uniform \"+m,e.commandStr),f=\"2i\";break;case Pr:case Fr:_.command(me(x)&&x.length&&x.length%3==0&&x.length<=3*h,\"uniform \"+m,e.commandStr),f=\"3i\";break;case Lr:case Br:_.command(me(x)&&x.length&&x.length%4==0&&x.length<=4*h,\"uniform \"+m,e.commandStr),f=\"4i\"}h>1?(f+=\"v\",x=e.global.def(\"[\"+Array.prototype.slice.call(x)+\"]\")):x=me(x)?Array.prototype.slice.call(x):x,t(s,\".uniform\",f,\"(\",y,\",\",x,\");\")}continue}g=b.append(e,t)}else{if(!i(fn))continue;g=t.def(u.uniforms,\"[\",r.id(m),\"]\")}p===Ur?(_(!Array.isArray(g),\"must specify a scalar prop for textures\"),t(\"if(\",g,\"&&\",g,'._reglType===\"framebuffer\"){',g,\"=\",g,\".color[0];\",\"}\")):p===Gr&&(_(!Array.isArray(g),\"must specify a scalar prop for cube maps\"),t(\"if(\",g,\"&&\",g,'._reglType===\"framebufferCube\"){',g,\"=\",g,\".color[0];\",\"}\")),_.optional((function(){function r(r,n){e.assert(t,r,'bad data or missing for uniform \"'+m+'\". '+n)}function n(e,t){1===t&&_(!Array.isArray(g),\"must not specify an array type for uniform\"),r(\"Array.isArray(\"+g+\") && typeof \"+g+'[0]===\" '+e+'\" || typeof '+g+'===\"'+e+'\"',\"invalid type, expected \"+e)}function a(t,n,a){Array.isArray(g)?_(g.length&&g.length%t==0&&g.length<=t*a,\"must have length of \"+(1===a?\"\":\"n * \")+t):r(u.isArrayLike+\"(\"+g+\")&&\"+g+\".length && \"+g+\".length % \"+t+\" === 0 && \"+g+\".length<=\"+t*a,\"invalid vector, should have length of \"+(1===a?\"\":\"n * \")+t,e.commandStr)}function i(t){_(!Array.isArray(g),\"must not specify a value type\"),r(\"typeof \"+g+'===\"function\"&&'+g+'._reglType===\"texture'+(3553===t?\"2d\":\"Cube\")+'\"',\"invalid texture type\",e.commandStr)}switch(p){case Cr:n(\"number\",h);break;case zr:a(2,0,h);break;case Fr:a(3,0,h);break;case Br:a(4,0,h);break;case Er:n(\"number\",h);break;case Tr:a(2,0,h);break;case Dr:a(3,0,h);break;case jr:a(4,0,h);break;case Vr:n(\"boolean\",h);break;case Ir:a(2,0,h);break;case Pr:a(3,0,h);break;case Lr:case Rr:a(4,0,h);break;case Mr:a(9,0,h);break;case Wr:a(16,0,h);break;case Ur:i(3553);break;case Gr:i(34067)}}));var S=1;switch(p){case Ur:case Gr:var O=t.def(g,\"._texture\");t(s,\".uniform1i(\",y,\",\",O,\".bind());\"),t.exit(O,\".unbind();\");continue;case Cr:case Vr:f=\"1i\";break;case zr:case Ir:f=\"2i\",S=2;break;case Fr:case Pr:f=\"3i\",S=3;break;case Br:case Lr:f=\"4i\",S=4;break;case Er:f=\"1f\";break;case Tr:f=\"2f\",S=2;break;case Dr:f=\"3f\",S=3;break;case jr:f=\"4f\",S=4;break;case Rr:f=\"Matrix2fv\";break;case Mr:f=\"Matrix3fv\";break;case Wr:f=\"Matrix4fv\"}if(-1===f.indexOf(\"Matrix\")&&h>1&&(f+=\"v\",S=1),\"M\"===f.charAt(0)){t(s,\".uniform\",f,\"(\",y,\",\");var E=Math.pow(p-Rr+2,2),T=e.global.def(\"new Float32Array(\",E,\")\");Array.isArray(g)?t(\"false,(\",V(E,(function(e){return T+\"[\"+e+\"]=\"+g[e]})),\",\",T,\")\"):t(\"false,(Array.isArray(\",g,\")||\",g,\" instanceof Float32Array)?\",g,\":(\",V(E,(function(e){return T+\"[\"+e+\"]=\"+g+\"[\"+e+\"]\"})),\",\",T,\")\"),t(\");\")}else if(S>1){for(var D=[],j=[],C=0;C=0\",\"missing vertex count\")}))):(a=u.def(o,\".\",pr),_.optional((function(){e.assert(u,a+\">=0\",\"missing vertex count\")}))),a}();if(\"number\"==typeof p){if(0===p)return}else r(\"if(\",p,\"){\"),r.exit(\"}\");g&&(c=s(br),l=e.instancing);var h=u+\".type\",b=f.elements&&nn(f.elements)&&!f.vaoActive;function v(){function e(){r(l,\".drawElementsInstancedANGLE(\",[d,p,h,m+\"<<((\"+h+\"-5121)>>1)\",c],\");\")}function t(){r(l,\".drawArraysInstancedANGLE(\",[d,m,p,c],\");\")}u&&\"null\"!==u?b?e():(r(\"if(\",u,\"){\"),e(),r(\"}else{\"),t(),r(\"}\")):t()}function y(){function e(){r(i+\".drawElements(\"+[d,p,h,m+\"<<((\"+h+\"-5121)>>1)\"]+\");\")}function t(){r(i+\".drawArrays(\"+[d,m,p]+\");\")}u&&\"null\"!==u?b?e():(r(\"if(\",u,\"){\"),e(),r(\"}else{\"),t(),r(\"}\")):t()}g&&(\"number\"!=typeof c||c>=0)?\"string\"==typeof c?(r(\"if(\",c,\">0){\"),v(),r(\"}else if(\",c,\"<0){\"),y(),r(\"}\")):v():y()}function q(e,t,r,n,a){var i=B(),o=i.proc(\"body\",a);return _.optional((function(){i.commandStr=t.commandStr,i.command=i.link(t.commandStr)})),g&&(i.instancing=o.def(i.shared.extensions,\".angle_instanced_arrays\")),e(i,o,r,n),i.compile().body}function Q(e,t,r,n){W(e,t),r.useVAO?r.drawVAO?t(e.shared.vao,\".setVAO(\",r.drawVAO.append(e,t),\");\"):t(e.shared.vao,\".setVAO(\",e.shared.vao,\".targetVAO);\"):(t(e.shared.vao,\".setVAO(null);\"),G(e,t,r,n.attributes,(function(){return!0}))),H(e,t,r,n.uniforms,(function(){return!0}),!1),N(e,t,t,r)}function Y(e,t,r,n){function a(){return!0}e.batchId=\"a1\",W(e,t),G(e,t,r,n.attributes,a),H(e,t,r,n.uniforms,a,!1),N(e,t,t,r)}function $(e,t,r,n){W(e,t);var a=r.contextDep,i=t.def(),o=t.def();e.shared.props=o,e.batchId=i;var f=e.scope(),u=e.scope();function s(e){return e.contextDep&&a||e.propDep}function c(e){return!s(e)}if(t(f.entry,\"for(\",i,\"=0;\",i,\"<\",\"a1\",\";++\",i,\"){\",o,\"=\",\"a0\",\"[\",i,\"];\",u,\"}\",f.exit),r.needsContext&&P(e,u,r.context),r.needsFramebuffer&&L(e,u,r.framebuffer),M(e,u,r.state,s),r.profile&&s(r.profile)&&U(e,u,r,!1,!0),n)r.useVAO?r.drawVAO?s(r.drawVAO)?u(e.shared.vao,\".setVAO(\",r.drawVAO.append(e,u),\");\"):f(e.shared.vao,\".setVAO(\",r.drawVAO.append(e,f),\");\"):f(e.shared.vao,\".setVAO(\",e.shared.vao,\".targetVAO);\"):(f(e.shared.vao,\".setVAO(null);\"),G(e,f,r,n.attributes,c),G(e,u,r,n.attributes,s)),H(e,f,r,n.uniforms,c,!1),H(e,u,r,n.uniforms,s,!0),N(e,f,u,r);else{var l=e.global.def(\"{}\"),d=r.shader.progVar.append(e,u),m=u.def(d,\".id\"),p=u.def(l,\"[\",m,\"]\");u(e.shared.gl,\".useProgram(\",d,\".program);\",\"if(!\",p,\"){\",p,\"=\",l,\"[\",m,\"]=\",e.link((function(t){return q(Y,e,r,t,2)})),\"(\",d,\");}\",p,\".call(this,a0[\",i,\"],\",i,\");\")}}function K(e,t,r){var n=t.static[r];if(n&&function(e){if(\"object\"==typeof e&&!me(e)){for(var t=Object.keys(e),r=0;r0&&r(e.shared.current,\".dirty=true;\"),e.shared.vao&&r(e.shared.vao,\".setVAO(null);\")}(f,u),function(e,t){var n=e.proc(\"scope\",3);e.batchId=\"a2\";var a=e.shared,i=a.current;function o(r){var i=t.shader[r];i&&n.set(a.shader,\".\"+r,i.append(e,n))}P(e,n,t.context),t.framebuffer&&t.framebuffer.append(e,n),tn(Object.keys(t.state)).forEach((function(r){var i=t.state[r].append(e,n);me(i)?i.forEach((function(t,a){n.set(e.next[r],\"[\"+a+\"]\",t)})):n.set(a.next,\".\"+r,i)})),U(e,n,t,!0,!0),[dr,hr,pr,br,mr].forEach((function(r){var i=t.draw[r];i&&n.set(a.draw,\".\"+r,\"\"+i.append(e,n))})),Object.keys(t.uniforms).forEach((function(i){var o=t.uniforms[i].append(e,n);Array.isArray(o)&&(o=\"[\"+o.join()+\"]\"),n.set(a.uniforms,\"[\"+r.id(i)+\"]\",o)})),Object.keys(t.attributes).forEach((function(r){var a=t.attributes[r].append(e,n),i=e.scopeAttrib(r);Object.keys(new b).forEach((function(e){n.set(i,\".\"+e,a[e])}))})),t.scopeVAO&&n.set(a.vao,\".targetVAO\",t.scopeVAO.append(e,n)),o(cr),o(lr),Object.keys(t.state).length>0&&(n(i,\".dirty=true;\"),n.exit(i,\".dirty=true;\")),n(\"a1(\",e.shared.context,\",a0,\",e.batchId,\");\")}(f,u),function(e,t){var r=e.proc(\"batch\",2);e.batchId=\"0\",W(e,r);var n=!1,a=!0;Object.keys(t.context).forEach((function(e){n=n||t.context[e].propDep})),n||(P(e,r,t.context),a=!1);var i=t.framebuffer,o=!1;function f(e){return e.contextDep&&n||e.propDep}i?(i.propDep?n=o=!0:i.contextDep&&n&&(o=!0),o||L(e,r,i)):L(e,r,null),t.state.viewport&&t.state.viewport.propDep&&(n=!0),R(e,r,t),M(e,r,t.state,(function(e){return!f(e)})),t.profile&&f(t.profile)||U(e,r,t,!1,\"a1\"),t.contextDep=n,t.needsContext=a,t.needsFramebuffer=o;var u=t.shader.progVar;if(u.contextDep&&n||u.propDep)$(e,r,t,null);else{var s=u.append(e,r);if(r(e.shared.gl,\".useProgram(\",s,\".program);\"),t.shader.program)$(e,r,t,t.shader.program);else{r(e.shared.vao,\".setVAO(null);\");var c=e.global.def(\"{}\"),l=r.def(s,\".id\"),d=r.def(c,\"[\",l,\"]\");r(e.cond(d).then(d,\".call(this,a0,a1);\").else(d,\"=\",c,\"[\",l,\"]=\",e.link((function(r){return q($,e,t,r,2)})),\"(\",s,\");\",d,\".call(this,a0,a1);\"))}}Object.keys(t.state).length>0&&r(e.shared.current,\".dirty=true;\"),e.shared.vao&&r(e.shared.vao,\".setVAO(null);\")}(f,u),t(f.compile(),{destroy:function(){u.shader.program.destroy()}})}}}var sn=function(e,t){if(!t.ext_disjoint_timer_query)return null;var r=[];function n(e){r.push(e)}var a=[];function i(){this.startQueryIndex=-1,this.endQueryIndex=-1,this.sum=0,this.stats=null}var o=[];function f(e){o.push(e)}var u=[];function s(e,t,r){var n=o.pop()||new i;n.startQueryIndex=e,n.endQueryIndex=t,n.sum=0,n.stats=r,u.push(n)}var c=[],l=[];return{beginQuery:function(e){var n=r.pop()||t.ext_disjoint_timer_query.createQueryEXT();t.ext_disjoint_timer_query.beginQueryEXT(35007,n),a.push(n),s(a.length-1,a.length,e)},endQuery:function(){t.ext_disjoint_timer_query.endQueryEXT(35007)},pushScopeStats:s,update:function(){var e,r,i=a.length;if(0!==i){l.length=Math.max(l.length,i+1),c.length=Math.max(c.length,i+1),c[0]=0,l[0]=0;var o=0;for(e=0,r=0;r0)if(Array.isArray(r[0])){f=J(r);for(var c=1,l=1;l0)if(\"number\"==typeof t[0]){var i=L.allocType(d.dtype,t.length);ne(i,t),p(i,a),L.freeType(i)}else if(Array.isArray(t[0])||e(t[0])){n=J(t);var o=K(t,n,d.dtype);p(o,a),L.freeType(o)}else _.raise(\"invalid buffer data\")}else if(G(t)){n=t.shape;var f=t.stride,u=0,s=0,c=0,l=0;1===n.length?(u=n[0],s=1,c=f[0],l=0):2===n.length?(u=n[0],s=n[1],c=f[0],l=f[1]):_.raise(\"invalid shape\");var h=Array.isArray(t.data)?d.dtype:re(t.data),b=L.allocType(h,u*s);ae(b,t.data,u,s,c,l,t.offset),p(b,a),L.freeType(b)}else _.raise(\"invalid data for buffer subdata\");return m},n.profile&&(m.stats=d.stats),m.destroy=function(){l(d)},m},createStream:function(e,t){var r=u.pop();return r||(r=new f(e)),r.bind(),c(r,t,35040,0,1,!1),r},destroyStream:function(e){u.push(e)},clear:function(){H(o).forEach(l),u.forEach(l)},getBuffer:function(e){return e&&e._buffer instanceof f?e._buffer:null},restore:function(){H(o).forEach((function(e){e.buffer=t.createBuffer(),t.bindBuffer(e.type,e.buffer),t.bufferData(e.type,e.persistentData||e.byteLength,e.usage)}))},_initBuffer:c}}(a,l,n,(function(e){return A.destroyBuffer(e)})),w=function(t,r,n,a){var i={},o=0,f={uint8:oe,uint16:fe};function u(e){this.id=o++,i[this.id]=this,this.buffer=e,this.primType=4,this.vertCount=0,this.type=0}r.oes_element_index_uint&&(f.uint32=ue),u.prototype.bind=function(){this.buffer.bind()};var s=[];function c(a,i,o,f,u,s,c){var l;if(a.buffer.bind(),i){var d=c;c||e(i)&&(!G(i)||e(i.data))||(d=r.oes_element_index_uint?ue:fe),n._initBuffer(a.buffer,i,o,d,3)}else t.bufferData(se,s,o),a.buffer.dtype=l||oe,a.buffer.usage=o,a.buffer.dimension=3,a.buffer.byteLength=s;if(l=c,!c){switch(a.buffer.dtype){case oe:case 5120:l=oe;break;case fe:case 5122:l=fe;break;case ue:case 5124:l=ue;break;default:_.raise(\"unsupported type for element array\")}a.buffer.dtype=l}a.type=l,_(l!==ue||!!r.oes_element_index_uint,\"32 bit element buffers not supported, enable oes_element_index_uint first\");var m=u;m<0&&(m=a.buffer.byteLength,l===fe?m>>=1:l===ue&&(m>>=2)),a.vertCount=m;var p=f;if(f<0){p=4;var h=a.buffer.dimension;1===h&&(p=0),2===h&&(p=1),3===h&&(p=4)}a.primType=p}function l(e){a.elementsCount--,_(null!==e.buffer,\"must not double destroy elements\"),delete i[e.id],e.buffer.destroy(),e.buffer=null}return{create:function(t,r){var i=n.create(null,se,!0),o=new u(i._buffer);function s(t){if(t)if(\"number\"==typeof t)i(t),o.primType=4,o.vertCount=0|t,o.type=oe;else{var r=null,n=35044,a=-1,u=-1,l=0,d=0;Array.isArray(t)||e(t)||G(t)?r=t:(_.type(t,\"object\",\"invalid arguments for elements\"),\"data\"in t&&(r=t.data,_(Array.isArray(r)||e(r)||G(r),\"invalid data for element buffer\")),\"usage\"in t&&(_.parameter(t.usage,$,\"invalid element buffer usage\"),n=$[t.usage]),\"primitive\"in t&&(_.parameter(t.primitive,ie,\"invalid element buffer primitive\"),a=ie[t.primitive]),\"count\"in t&&(_(\"number\"==typeof t.count&&t.count>=0,\"invalid vertex count for elements\"),u=0|t.count),\"type\"in t&&(_.parameter(t.type,f,\"invalid buffer type\"),d=f[t.type]),\"length\"in t?l=0|t.length:(l=u,d===fe||5122===d?l*=2:d!==ue&&5124!==d||(l*=4))),c(o,r,n,a,u,l,d)}else i(),o.primType=4,o.vertCount=0,o.type=oe;return s}return a.elementsCount++,s(t),s._reglType=\"elements\",s._elements=o,s.subdata=function(e,t){return i.subdata(e,t),s},s.destroy=function(){l(o)},s},createStream:function(e){var t=s.pop();return t||(t=new u(n.create(null,se,!0,!1)._buffer)),c(t,e,35040,-1,-1,0,0),t},destroyStream:function(e){s.push(e)},getElements:function(e){return\"function\"==typeof e&&e._elements instanceof u?e._elements:null},clear:function(){H(i).forEach(l)}}}(a,d,x,l),A=function(t,r,n,a,i,o,f){for(var u=n.maxAttributes,s=new Array(u),c=0;c{for(var e=Object.keys(t),r=0;r=0,'invalid option for vao: \"'+e[r]+'\" valid options are '+Et)})),_(Array.isArray(a),\"attributes must be an array\")}_(a.length0,\"must specify at least one attribute\");var c={},l=n.attributes;l.length=a.length;for(var d=0;d=b.byteLength?m.subdata(b):(m.destroy(),n.buffers[d]=null)),n.buffers[d]||(m=n.buffers[d]=i.create(p,34962,!1,!0)),h.buffer=i.getBuffer(m),h.size=0|h.buffer.dimension,h.normalized=!1,h.type=h.buffer.dtype,h.offset=0,h.stride=0,h.divisor=0,h.state=1,c[d]=1):i.getBuffer(p)?(h.buffer=i.getBuffer(p),h.size=0|h.buffer.dimension,h.normalized=!1,h.type=h.buffer.dtype,h.offset=0,h.stride=0,h.divisor=0,h.state=1):i.getBuffer(p.buffer)?(h.buffer=i.getBuffer(p.buffer),h.size=0|(+p.size||h.buffer.dimension),h.normalized=!!p.normalized||!1,\"type\"in p?(_.parameter(p.type,X,\"invalid buffer type\"),h.type=X[p.type]):h.type=h.buffer.dtype,h.offset=0|(p.offset||0),h.stride=0|(p.stride||0),h.divisor=0|(p.divisor||0),h.state=1,_(h.size>=1&&h.size<=4,\"size must be between 1 and 4\"),_(h.offset>=0,\"invalid offset\"),_(h.stride>=0&&h.stride<=255,\"stride must be between 0 and 255\"),_(h.divisor>=0,\"divisor must be positive\"),_(!h.divisor||!!r.angle_instanced_arrays,\"ANGLE_instanced_arrays must be enabled to use divisor\")):\"x\"in p?(_(d>0,\"first attribute must not be a constant\"),h.x=+p.x||0,h.y=+p.y||0,h.z=+p.z||0,h.w=+p.w||0,h.state=2):_(!1,\"invalid attribute spec for location \"+d)}for(var v=0;v1)for(var v=0;v1&&(y=y.replace(\"[0]\",\"\")),u(b,new f(y,r.id(y),e.getUniformLocation(m,y),c))}var x=e.getProgramParameter(m,35721);a.profile&&(t.stats.attributesCount=x);var w=t.attributes;for(o=0;oe&&(e=t.stats.uniformsCount)})),e},n.getMaxAttributesCount=function(){var e=0;return l.forEach((function(t){t.stats.attributesCount>e&&(e=t.stats.attributesCount)})),e}),{clear:function(){var t=e.deleteShader.bind(e);H(i).forEach(t),i={},H(o).forEach(t),o={},l.forEach((function(t){e.deleteProgram(t.program)})),l.length=0,c={},n.shaderCount=0},program:function(r,a,f,u){_.command(r>=0,\"missing vertex shader\",f),_.command(a>=0,\"missing fragment shader\",f);var s=c[a];s||(s=c[a]={});var d=s[r];if(d&&(d.refCount++,!u))return d;var h=new m(a,r);return n.shaderCount++,p(h,f,u),d||(s[r]=h),l.push(h),t(h,{destroy:function(){if(h.refCount--,h.refCount<=0){e.deleteProgram(h.program);var t=l.indexOf(h);l.splice(t,1),n.shaderCount--}s[h.vertId].refCount<=0&&(e.deleteShader(o[h.vertId]),delete o[h.vertId],delete c[h.fragId][h.vertId]),Object.keys(c[h.fragId]).length||(e.deleteShader(i[h.fragId]),delete i[h.fragId],delete c[h.fragId])}})},restore:function(){i={},o={};for(var e=0;e=2,\"invalid renderbuffer shape\"),f=0|m[0],u=0|m[1]}else\"radius\"in d&&(f=u=0|d.radius),\"width\"in d&&(f=0|d.width),\"height\"in d&&(u=0|d.height);\"format\"in d&&(_.parameter(d.format,i,\"invalid renderbuffer format\"),s=i[d.format])}else\"number\"==typeof t?(f=0|t,u=\"number\"==typeof n?0|n:f):t?_.raise(\"invalid arguments to renderbuffer constructor\"):f=u=1;if(_(f>0&&u>0&&f<=r.maxRenderbufferSize&&u<=r.maxRenderbufferSize,\"invalid renderbuffer size\"),f!==c.width||u!==c.height||s!==c.format)return l.width=c.width=f,l.height=c.height=u,c.format=s,e.bindRenderbuffer(mt,c.renderbuffer),e.renderbufferStorage(mt,s,f,u),_(0===e.getError(),\"invalid render buffer format\"),a.profile&&(c.stats.size=bt(c.format,c.width,c.height)),l.format=o[c.format],l}return u[c.id]=c,n.renderbufferCount++,l(t,f),l.resize=function(t,n){var i=0|t,o=0|n||i;return i===c.width&&o===c.height||(_(i>0&&o>0&&i<=r.maxRenderbufferSize&&o<=r.maxRenderbufferSize,\"invalid renderbuffer size\"),l.width=c.width=i,l.height=c.height=o,e.bindRenderbuffer(mt,c.renderbuffer),e.renderbufferStorage(mt,c.format,i,o),_(0===e.getError(),\"invalid render buffer format\"),a.profile&&(c.stats.size=bt(c.format,c.width,c.height))),l},l._reglType=\"renderbuffer\",l._renderbuffer=c,a.profile&&(l.stats=c.stats),l.destroy=function(){c.decRef()},l},clear:function(){H(u).forEach(c)},restore:function(){H(u).forEach((function(t){t.renderbuffer=e.createRenderbuffer(),e.bindRenderbuffer(mt,t.renderbuffer),e.renderbufferStorage(mt,t.format,t.width,t.height)})),e.bindRenderbuffer(mt,null)}}}(a,d,y,l,n),E=function(e,r,n,a,i,o){var f={cur:null,next:null,dirty:!1,setFBO:null},u=[\"rgba\"],s=[\"rgba4\",\"rgb565\",\"rgb5 a1\"];r.ext_srgb&&s.push(\"srgba\"),r.ext_color_buffer_half_float&&s.push(\"rgba16f\",\"rgb16f\"),r.webgl_color_buffer_float&&s.push(\"rgba32f\");var c=[\"uint8\"];function l(e,t,r){this.target=e,this.texture=t,this.renderbuffer=r;var n=0,a=0;t?(n=t.width,a=t.height):r&&(n=r.width,a=r.height),this.width=n,this.height=a}function d(e){e&&(e.texture&&e.texture._texture.decRef(),e.renderbuffer&&e.renderbuffer._renderbuffer.decRef())}function m(e,t,r){if(e)if(e.texture){var n=e.texture._texture,a=Math.max(1,n.width),i=Math.max(1,n.height);_(a===t&&i===r,\"inconsistent width/height for supplied texture\"),n.refCount+=1}else{var o=e.renderbuffer._renderbuffer;_(o.width===t&&o.height===r,\"inconsistent width/height for renderbuffer\"),o.refCount+=1}}function p(t,r){r&&(r.texture?e.framebufferTexture2D(vt,t,r.target,r.texture._texture.texture,0):e.framebufferRenderbuffer(vt,t,gt,r.renderbuffer._renderbuffer.renderbuffer))}function h(e){var t=yt,r=null,n=null,a=e;\"object\"==typeof e&&(a=e.data,\"target\"in e&&(t=0|e.target)),_.type(a,\"function\",\"invalid attachment data\");var i=a._reglType;return\"texture2d\"===i?(r=a,_(t===yt)):\"textureCube\"===i?(r=a,_(t>=xt&&t<34075,\"invalid cube map target\")):\"renderbuffer\"===i?(n=a,t=gt):_.raise(\"invalid regl object for attachment\"),new l(t,r,n)}function b(e,t,r,n,o){if(r){var f=a.create2D({width:e,height:t,format:n,type:o});return f._texture.refCount=0,new l(yt,f,null)}var u=i.create({width:e,height:t,format:n});return u._renderbuffer.refCount=0,new l(gt,null,u)}function v(e){return e&&(e.texture||e.renderbuffer)}function g(e,t,r){e&&(e.texture?e.texture.resize(t,r):e.renderbuffer&&e.renderbuffer.resize(t,r),e.width=t,e.height=r)}r.oes_texture_half_float&&c.push(\"half float\",\"float16\"),r.oes_texture_float&&c.push(\"float\",\"float32\");var y=0,x={};function w(){this.id=y++,x[this.id]=this,this.framebuffer=e.createFramebuffer(),this.width=0,this.height=0,this.colorAttachments=[],this.depthAttachment=null,this.stencilAttachment=null,this.depthStencilAttachment=null}function A(e){e.colorAttachments.forEach(d),d(e.depthAttachment),d(e.stencilAttachment),d(e.depthStencilAttachment)}function k(t){var r=t.framebuffer;_(r,\"must not double destroy framebuffer\"),e.deleteFramebuffer(r),t.framebuffer=null,o.framebufferCount--,delete x[t.id]}function S(t){var r;e.bindFramebuffer(vt,t.framebuffer);var a=t.colorAttachments;for(r=0;r=2,\"invalid shape for framebuffer\"),o=z[0],d=z[1]}else\"radius\"in C&&(o=d=C.radius),\"width\"in C&&(o=C.width),\"height\"in C&&(d=C.height);(\"color\"in C||\"colors\"in C)&&(y=C.color||C.colors,Array.isArray(y)&&_(1===y.length||r.webgl_draw_buffers,\"multiple render targets not supported\")),y||(\"colorCount\"in C&&(O=0|C.colorCount,_(O>0,\"invalid color buffer count\")),\"colorTexture\"in C&&(x=!!C.colorTexture,w=\"rgba4\"),\"colorType\"in C&&(k=C.colorType,x?(_(r.oes_texture_float||!(\"float\"===k||\"float32\"===k),\"you must enable OES_texture_float in order to use floating point framebuffer objects\"),_(r.oes_texture_half_float||!(\"half float\"===k||\"float16\"===k),\"you must enable OES_texture_half_float in order to use 16-bit floating point framebuffer objects\")):\"half float\"===k||\"float16\"===k?(_(r.ext_color_buffer_half_float,\"you must enable EXT_color_buffer_half_float to use 16-bit render buffers\"),w=\"rgba16f\"):\"float\"!==k&&\"float32\"!==k||(_(r.webgl_color_buffer_float,\"you must enable WEBGL_color_buffer_float in order to use 32-bit floating point renderbuffers\"),w=\"rgba32f\"),_.oneOf(k,c,\"invalid color type\")),\"colorFormat\"in C&&(w=C.colorFormat,u.indexOf(w)>=0?x=!0:s.indexOf(w)>=0?x=!1:_.optional((function(){x?_.oneOf(C.colorFormat,u,\"invalid color format for texture\"):_.oneOf(C.colorFormat,s,\"invalid color format for renderbuffer\")})))),(\"depthTexture\"in C||\"depthStencilTexture\"in C)&&(j=!(!C.depthTexture&&!C.depthStencilTexture),_(!j||r.webgl_depth_texture,\"webgl_depth_texture extension not supported\")),\"depth\"in C&&(\"boolean\"==typeof C.depth?p=C.depth:(E=C.depth,g=!1)),\"stencil\"in C&&(\"boolean\"==typeof C.stencil?g=C.stencil:(T=C.stencil,p=!1)),\"depthStencil\"in C&&(\"boolean\"==typeof C.depthStencil?p=g=C.depthStencil:(D=C.depthStencil,p=!1,g=!1))}else o=d=1;var F=null,B=null,V=null,I=null;if(Array.isArray(y))F=y.map(h);else if(y)F=[h(y)];else for(F=new Array(O),a=0;a=0||F[a].renderbuffer&&kt.indexOf(F[a].renderbuffer._renderbuffer.format)>=0,\"framebuffer color attachment \"+a+\" is invalid\"),F[a]&&F[a].texture){var L=At[F[a].texture._texture.format]*_t[F[a].texture._texture.type];null===P?P=L:_(P===L,\"all color attachments much have the same number of bits per pixel.\")}return m(B,o,d),_(!B||B.texture&&6402===B.texture._texture.format||B.renderbuffer&&33189===B.renderbuffer._renderbuffer.format,\"invalid depth attachment for framebuffer object\"),m(V,o,d),_(!V||V.renderbuffer&&36168===V.renderbuffer._renderbuffer.format,\"invalid stencil attachment for framebuffer object\"),m(I,o,d),_(!I||I.texture&&34041===I.texture._texture.format||I.renderbuffer&&34041===I.renderbuffer._renderbuffer.format,\"invalid depth-stencil attachment for framebuffer object\"),A(i),i.width=o,i.height=d,i.colorAttachments=F,i.depthAttachment=B,i.stencilAttachment=V,i.depthStencilAttachment=I,l.color=F.map(v),l.depth=v(B),l.stencil=v(V),l.depthStencil=v(I),l.width=i.width,l.height=i.height,S(i),l}return o.framebufferCount++,l(e,a),t(l,{resize:function(e,t){_(f.next!==i,\"can not resize a framebuffer which is currently in use\");var r=Math.max(0|e,1),n=Math.max(0|t||r,1);if(r===i.width&&n===i.height)return l;for(var a=i.colorAttachments,o=0;o=2,\"invalid shape for framebuffer\"),_(g[0]===g[1],\"cube framebuffer must be square\"),d=g[0]}else\"radius\"in v&&(d=0|v.radius),\"width\"in v?(d=0|v.width,\"height\"in v&&_(v.height===d,\"must be square\")):\"height\"in v&&(d=0|v.height);(\"color\"in v||\"colors\"in v)&&(m=v.color||v.colors,Array.isArray(m)&&_(1===m.length||r.webgl_draw_buffers,\"multiple render targets not supported\")),m||(\"colorCount\"in v&&(b=0|v.colorCount,_(b>0,\"invalid color buffer count\")),\"colorType\"in v&&(_.oneOf(v.colorType,c,\"invalid color type\"),h=v.colorType),\"colorFormat\"in v&&(p=v.colorFormat,_.oneOf(v.colorFormat,u,\"invalid color format for texture\"))),\"depth\"in v&&(l.depth=v.depth),\"stencil\"in v&&(l.stencil=v.stencil),\"depthStencil\"in v&&(l.depthStencil=v.depthStencil)}else d=1;if(m)if(Array.isArray(m))for(s=[],n=0;n0&&(l.depth=i[0].depth,l.stencil=i[0].stencil,l.depthStencil=i[0].depthStencil),i[n]?i[n](l):i[n]=O(l)}return t(o,{width:d,height:d,color:s})}return o(e),t(o,{faces:i,resize:function(e){var t,r=0|e;if(_(r>0&&r<=n.maxCubeMapSize,\"invalid radius for cube fbo\"),r===o.width)return o;var a=o.color;for(t=0;t=0;--e){var t=I[e];t&&t(v,null,0)}a.flush(),m&&m.update()}function ce(){!Q&&I.length>0&&(Q=j.next(Y))}function le(){Q&&(j.cancel(Y),Q=null)}function de(e){e.preventDefault(),o=!0,le(),P.forEach((function(e){e()}))}function me(e){a.getError(),o=!1,f.restore(),k.restore(),x.restore(),S.restore(),O.restore(),E.restore(),A.restore(),m&&m.restore(),T.procs.refresh(),ce(),N.forEach((function(e){e()}))}function pe(e){function r(e,t){var r={},n={};return Object.keys(e).forEach((function(a){var i=e[a];if(D.isDynamic(i))n[a]=D.unbox(i,a);else{if(t&&Array.isArray(i))for(var o=0;o0)return l.call(this,function(e){for(;m.length=0,\"cannot cancel a frame twice\"),I[t]=function e(){var t=dn(I,e);I[t]=I[I.length-1],I.length-=1,I.length<=0&&le()}}}}function ge(){var e=F.viewport,t=F.scissor_box;e[0]=e[1]=t[0]=t[1]=0,v.viewportWidth=v.framebufferWidth=v.drawingBufferWidth=e[2]=t[2]=a.drawingBufferWidth,v.viewportHeight=v.framebufferHeight=v.drawingBufferHeight=e[3]=t[3]=a.drawingBufferHeight}function ye(){v.tick+=1,v.time=we(),ge(),T.procs.poll()}function xe(){S.refresh(),ge(),T.procs.refresh(),m&&m.update()}function we(){return(C()-p)/1e3}xe();var Ae=t(pe,{clear:function(e){if(_(\"object\"==typeof e&&e,\"regl.clear() takes an object as input\"),\"framebuffer\"in e)if(e.framebuffer&&\"framebufferCube\"===e.framebuffer_reglType)for(var r=0;r<6;++r)he(t({framebuffer:e.framebuffer.faces[r]},e),be);else he(e,be);else be(0,e)},prop:D.define.bind(null,1),context:D.define.bind(null,2),this:D.define.bind(null,3),draw:pe({}),buffer:function(e){return x.create(e,34962,!1,!1)},elements:function(e){return w.create(e,!1)},texture:S.create2D,cube:S.createCube,renderbuffer:O.create,framebuffer:E.create,framebufferCube:E.createCube,vao:A.createVAO,attributes:i,frame:ve,on:function(e,t){var r;switch(_.type(t,\"function\",\"listener callback must be a function\"),e){case\"frame\":return ve(t);case\"lost\":r=P;break;case\"restore\":r=N;break;case\"destroy\":r=q;break;default:_.raise(\"invalid event, must be one of frame,lost,restore,destroy\")}return r.push(t),{cancel:function(){for(var e=0;e=0},read:z,destroy:function(){I.length=0,le(),V&&(V.removeEventListener(cn,de),V.removeEventListener(ln,me)),k.clear(),E.clear(),O.clear(),A.clear(),S.clear(),w.clear(),x.clear(),m&&m.clear(),q.forEach((function(e){e()}))},_gl:a,_refresh:xe,poll:function(){ye(),m&&m.update()},now:we,stats:l});return n.onDone(null,Ae),Ae}},\"object\"==typeof r&&void 0!==t?t.exports=o():\"function\"==typeof define&&define.amd?define(o):i.createREGL=o()},\n", " 413: function _(t,e,s,a,r){a();const n=t(414),_=t(12);class o{constructor(t){this._regl=t,this._map=new Map}_create_texture(t){const e=t.length;let s=0;const a=[];let r=0,_=0;for(let n=0;nc[f+1]&&f++;const a=t[f],n=c[f]+.5*a;let o=.5*a-Math.abs(s-n);f%2==1&&(o=-o),m[e]=Math.round(255*(o-r)/(_-r))}return[[s,u,r,_],this._regl.texture({shape:[l,1,1],data:m,wrapS:\"repeat\",format:\"alpha\",type:\"uint8\",mag:\"linear\",min:\"linear\"})]}_get_key(t){return t.join(\",\")}_get_or_create(t){const e=this._get_key(t);let s=this._map.get(e);if(null==s){const a=(0,n.gcd)(t);if(a>1){t=(0,_.map)(t,(t=>t/a)),s=this._get_or_create(t);const[r,n,o]=s;s=[r,n,a],this._map.set(e,s)}else{const[r,n]=this._create_texture(t);s=[r,n,a],this._map.set(e,s)}}return s}get(t){return t.length%2==1&&(t=t.slice(0,-1)),this._get_or_create(t)}}s.DashCache=o,o.__name__=\"DashCache\"},\n", " 414: function _(n,t,e,r,o){function u(n,t){let e,r;n>t?(e=n,r=t):(e=t,r=n);let o=e%r;for(;0!=o;)e=r,r=o,o=e%r;return r}r(),e.gcd=function(n){let t=n[0];for(let e=1;e u_miter_limit);\\n miter_too_large_end = (miter_factor_end > u_miter_limit);\\n }\\n\\n float sign_at_start = -sign(a_position.x); // +ve at segment start, -ve end.\\n vec2 point = sign_at_start > 0.0 ? a_point_start : a_point_end;\\n vec2 adjacent_point =\\n sign_at_start > 0.0 ? (has_start_cap ? a_point_start : a_point_prev)\\n : (has_end_cap ? a_point_end : a_point_next);\\n\\n if ( (has_start_cap && sign_at_start > 0.0) ||\\n (has_end_cap && sign_at_start < 0.0) ) {\\n // Cap.\\n xy = point - segment_right*(halfwidth*a_position.y);\\n if (cap_type == butt_cap)\\n xy -= sign_at_start*0.5*u_antialias*segment_along;\\n else\\n xy -= sign_at_start*halfwidth*segment_along;\\n }\\n else { // Join.\\n // +ve if turning to right, -ve if to left.\\n float turn_sign = sign_at_start > 0.0 ? turn_right_start : turn_right_end;\\n\\n vec2 adjacent_right = sign_at_start*normalize(right_vector(point - adjacent_point));\\n vec2 point_right = normalize(segment_right + adjacent_right);\\n float miter_factor = sign_at_start > 0.0 ? miter_factor_start : miter_factor_end;\\n bool miter_too_large = sign_at_start > 0.0 ? miter_too_large_start : miter_too_large_end;\\n\\n if (abs(a_position.x) > 1.5) {\\n // Outer point, meets prev/next segment.\\n float factor; // multiplied by halfwidth...\\n\\n if (join_type == bevel_join || (join_type == miter_join && miter_too_large))\\n factor = 1.0 / miter_factor; // cos_theta.\\n else if (join_type == round_join &&\\n miter_factor > min_miter_factor_round_join_mesh)\\n factor = 1.0;\\n else // miter, or round (small angle only).\\n factor = miter_factor;\\n\\n xy = point - point_right*(halfwidth*turn_sign*factor);\\n v_coords.y = turn_sign*halfwidth*factor / miter_factor;\\n }\\n else if (turn_sign*a_position.y < 0.0) {\\n // Inner point, meets prev/next segment.\\n float len = halfwidth*miter_factor;\\n float segment_len = v_segment_length;\\n float adjacent_len = distance(point, adjacent_point);\\n\\n if (len <= min(segment_len, adjacent_len))\\n // Normal behaviour.\\n xy = point - point_right*(len*a_position.y);\\n else\\n // For short wide line segments the inner point using the above\\n // calculation can be outside of the line. Here clipping it.\\n xy = point + segment_right*(halfwidth*turn_sign);\\n }\\n else {\\n // Point along outside edge.\\n xy = point - segment_right*(halfwidth*a_position.y);\\n if (join_type == round_join &&\\n miter_factor > min_miter_factor_round_join_mesh) {\\n xy = line_intersection(xy, segment_along,\\n point - turn_sign*point_right*halfwidth,\\n right_vector(point_right));\\n }\\n }\\n }\\n\\n vec2 pos = xy + 0.5; // Bokeh's offset.\\n pos /= u_canvas_size / u_pixel_ratio; // in 0..1\\n gl_Position = vec4(2.0*pos.x - 1.0, 1.0 - 2.0*pos.y, 0.0, 1.0);\\n\\n v_coords.x = dot(xy - a_point_start, segment_along);\\n v_flags = float(int(has_start_cap) +\\n 2*int(has_end_cap) +\\n 4*int(miter_too_large_start) +\\n 8*int(miter_too_large_end));\\n v_cos_theta_turn_right_start = cos_theta_start*turn_right_start;\\n v_cos_theta_turn_right_end = cos_theta_end*turn_right_end;\\n\\n#ifdef DASHED\\n v_length_so_far = a_length_so_far;\\n#endif\\n}\\n\"},\n", " 416: function _(n,t,a,i,e){i();a.default=\"\\nprecision mediump float;\\n\\nconst int butt_cap = 0;\\nconst int round_cap = 1;\\nconst int square_cap = 2;\\n\\nconst int miter_join = 0;\\nconst int round_join = 1;\\nconst int bevel_join = 2;\\n\\nuniform float u_linewidth;\\nuniform float u_antialias;\\nuniform float u_line_join;\\nuniform float u_line_cap;\\nuniform vec4 u_line_color;\\n#ifdef DASHED\\nuniform sampler2D u_dash_tex;\\nuniform vec4 u_dash_tex_info;\\nuniform float u_dash_scale;\\nuniform float u_dash_offset;\\n#endif\\n\\nvarying float v_segment_length;\\nvarying vec2 v_coords;\\nvarying float v_flags;\\nvarying float v_cos_theta_turn_right_start;\\nvarying float v_cos_theta_turn_right_end;\\n#ifdef DASHED\\nvarying float v_length_so_far;\\n#endif\\n\\nfloat cross_z(in vec2 v0, in vec2 v1)\\n{\\n return v0.x*v1.y - v0.y*v1.x;\\n}\\n\\nfloat point_line_side(in vec2 point, in vec2 start, in vec2 end)\\n{\\n // +ve if point to right of line.\\n // Alternatively could do dot product with right_vector.\\n return cross_z(point - start, end - start);\\n}\\n\\nfloat point_line_distance(in vec2 point, in vec2 start, in vec2 end)\\n{\\n return point_line_side(point, start, end) / distance(start, end);\\n}\\n\\nvec2 right_vector(in vec2 v)\\n{\\n return vec2(v.y, -v.x);\\n}\\n\\nfloat bevel_join_distance(in float sign_start, in float halfwidth)\\n{\\n float cos_theta_turn_right = sign_start > 0.0 ? v_cos_theta_turn_right_start\\n : v_cos_theta_turn_right_end;\\n float cos_theta = abs(cos_theta_turn_right);\\n float turn_right = sign(cos_theta_turn_right);\\n float distance_along = sign_start > 0.0 ? 0.0 : v_segment_length;\\n\\n // In v_coords reference frame (x is along segment, y across).\\n vec2 line_start = vec2(distance_along, halfwidth*turn_right);\\n float sin_alpha = cos_theta;\\n float cos_alpha = sqrt(1.0 - sin_alpha*sin_alpha);\\n vec2 line_along = vec2(-sign_start*turn_right*sin_alpha, -cos_alpha);\\n\\n return halfwidth + sign_start*point_line_distance(\\n v_coords, line_start, line_start+line_along);\\n}\\n\\nfloat cap(in int cap_type, in float x, in float y)\\n{\\n // x is distance along segment in direction away from end of segment,\\n // y is distance across segment.\\n if (cap_type == butt_cap)\\n return max(0.5*u_linewidth - x, abs(y));\\n else if (cap_type == square_cap)\\n return max(-x, abs(y));\\n else // cap_type == round_cap\\n return distance(vec2(min(x, 0.0), y), vec2(0.0, 0.0));\\n}\\n\\nfloat distance_to_alpha(in float dist)\\n{\\n return 1.0 - smoothstep(0.5*(u_linewidth - u_antialias),\\n 0.5*(u_linewidth + u_antialias), dist);\\n}\\n\\n#ifdef DASHED\\nfloat dash_distance(in float x)\\n{\\n // x is in direction of v_coords.x, i.e. along segment.\\n float tex_length = u_dash_tex_info.x;\\n float tex_offset = u_dash_tex_info.y;\\n float tex_dist_min = u_dash_tex_info.z;\\n float tex_dist_max = u_dash_tex_info.w;\\n\\n // Apply offset.\\n x += v_length_so_far - u_dash_scale*tex_offset + u_dash_offset;\\n\\n // Interpolate within texture to obtain distance to dash.\\n float dist = texture2D(u_dash_tex,\\n vec2(x / (tex_length*u_dash_scale), 0.0)).a;\\n\\n // Scale distance within min and max limits.\\n dist = tex_dist_min + dist*(tex_dist_max - tex_dist_min);\\n\\n return u_dash_scale*dist;\\n}\\n\\nmat2 rotation_matrix(in float sign_start)\\n{\\n // Rotation matrix for v_coords from this segment to prev or next segment.\\n float cos_theta_turn_right = sign_start > 0.0 ? v_cos_theta_turn_right_start\\n : v_cos_theta_turn_right_end;\\n float cos_theta = abs(cos_theta_turn_right);\\n float turn_right = sign(cos_theta_turn_right);\\n\\n float sin_theta = sqrt(1.0 - cos_theta*cos_theta)*sign_start*turn_right;\\n float cos_2theta = 2.0*cos_theta*cos_theta - 1.0;\\n float sin_2theta = 2.0*sin_theta*cos_theta;\\n return mat2(cos_2theta, -sin_2theta, sin_2theta, cos_2theta);\\n}\\n#endif\\n\\nvoid main()\\n{\\n int join_type = int(u_line_join + 0.5);\\n int cap_type = int(u_line_cap + 0.5);\\n float halfwidth = 0.5*(u_linewidth + u_antialias);\\n\\n // Extract flags.\\n int flags = int(v_flags + 0.5);\\n bool miter_too_large_end = (flags / 8 > 0);\\n flags -= 8*int(miter_too_large_end);\\n bool miter_too_large_start = (flags / 4 > 0);\\n flags -= 4*int(miter_too_large_start);\\n bool has_end_cap = (flags / 2 > 0);\\n flags -= 2*int(has_end_cap);\\n bool has_start_cap = flags > 0;\\n\\n float dist = v_coords.y; // For straight segment, and miter join.\\n\\n if (v_coords.x <= 0.5*u_antialias) {\\n // At start of segment, either cap or join.\\n if (has_start_cap)\\n dist = cap(cap_type, v_coords.x, v_coords.y);\\n else if (join_type == round_join)\\n dist = distance(v_coords, vec2(0.0, 0.0));\\n else if (join_type == bevel_join ||\\n (join_type == miter_join && miter_too_large_start))\\n dist = max(abs(dist), bevel_join_distance(1.0, halfwidth));\\n // else a miter join which uses the default dist calculation.\\n }\\n else if (v_coords.x >= v_segment_length - 0.5*u_antialias) {\\n // At end of segment, either cap or join.\\n if (has_end_cap)\\n dist = cap(cap_type, v_segment_length - v_coords.x, v_coords.y);\\n else if (join_type == round_join)\\n dist = distance(v_coords, vec2(v_segment_length, 0));\\n else if ((join_type == bevel_join ||\\n (join_type == miter_join && miter_too_large_end)))\\n dist = max(abs(dist), bevel_join_distance(-1.0, halfwidth));\\n // else a miter join which uses the default dist calculation.\\n }\\n\\n float alpha = distance_to_alpha(abs(dist));\\n\\n#ifdef DASHED\\n if (u_dash_tex_info.x >= 0.0) {\\n // Dashes in straight segments (outside of joins) are easily calculated.\\n dist = dash_distance(v_coords.x);\\n\\n if (!has_start_cap && cap_type == butt_cap) {\\n if (v_coords.x < 0.5*u_antialias) {\\n // Outer of start join rendered solid color or not at all\\n // depending on whether corner point is in dash or gap, with\\n // antialiased ends.\\n dist = (dash_distance(0.0) > 0.0 ? 0.5*u_antialias - v_coords.x\\n : -0.5*u_linewidth);\\n\\n // Also consider antialiased end of dash just outside corner.\\n float end_dist = dash_distance(0.5*u_antialias) + v_coords.x -\\n 0.5*u_antialias;\\n dist = max(dist, end_dist);\\n }\\n\\n vec2 prev_coords = rotation_matrix(1.0)*v_coords;\\n\\n if (abs(prev_coords.y) < halfwidth &&\\n prev_coords.x < 0.5*u_antialias) {\\n // Extend dashes across from previous segment, with antialiased\\n // end.\\n float new_dist = dash_distance(min(prev_coords.x,\\n -0.5*u_antialias));\\n\\n if (prev_coords.x > -0.5*u_antialias)\\n new_dist -= prev_coords.x + 0.5*u_antialias;\\n\\n new_dist = min(new_dist, 0.5*u_linewidth - abs(prev_coords.y));\\n dist = max(dist, new_dist);\\n }\\n }\\n\\n if (!has_end_cap && cap_type == butt_cap) {\\n if (v_coords.x > v_segment_length - 0.5*u_antialias) {\\n // Similar for end join.\\n dist = (dash_distance(v_segment_length) > 0.0\\n ? v_coords.x - v_segment_length + 0.5*u_antialias\\n : -0.5*u_linewidth);\\n\\n float end_dist =\\n dash_distance(v_segment_length - 0.5*u_antialias) -\\n v_coords.x + v_segment_length - 0.5*u_antialias;\\n dist = max(dist, end_dist);\\n }\\n\\n vec2 next_coords =\\n rotation_matrix(-1.0)*(v_coords - vec2(v_segment_length, 0.0));\\n\\n if (abs(next_coords.y) < halfwidth &&\\n next_coords.x > -0.5*u_antialias) {\\n // Extend dashes across from next segment, with antialiased end.\\n float new_dist = dash_distance(v_segment_length +\\n max(next_coords.x, 0.5*u_antialias));\\n\\n if (next_coords.x < 0.5*u_antialias)\\n new_dist += next_coords.x - 0.5*u_antialias;\\n\\n new_dist = min(new_dist, 0.5*u_linewidth - abs(next_coords.y));\\n dist = max(dist, new_dist);\\n }\\n }\\n\\n dist = cap(cap_type, dist, v_coords.y);\\n\\n float dash_alpha = distance_to_alpha(dist);\\n alpha = min(alpha, dash_alpha);\\n }\\n#endif\\n\\n alpha = u_line_color.a*alpha;\\n gl_FragColor = vec4(u_line_color.rgb*alpha, alpha); // Premultiplied alpha.\\n}\\n\"},\n", " 417: function _(n,i,o,a,t){a();o.default=\"\\nprecision mediump float;\\n\\nattribute vec2 a_position;\\nattribute vec2 a_center;\\nattribute float a_size;\\nattribute float a_angle; // in radians\\nattribute float a_linewidth;\\nattribute vec4 a_line_color;\\nattribute vec4 a_fill_color;\\nattribute float a_show;\\n\\nuniform float u_pixel_ratio;\\nuniform vec2 u_canvas_size;\\nuniform float u_antialias;\\n\\nvarying float v_linewidth;\\nvarying float v_size;\\nvarying vec4 v_line_color;\\nvarying vec4 v_fill_color;\\nvarying vec2 v_coords;\\n\\nvoid main()\\n{\\n v_size = a_size;\\n v_linewidth = a_linewidth;\\n v_line_color = a_line_color;\\n v_fill_color = a_fill_color;\\n\\n if (a_show < 0.5) {\\n // Do not show this marker.\\n gl_Position = vec4(-2.0, -2.0, 0.0, 1.0);\\n return;\\n }\\n\\n float enclosing_size = v_size + 2.0*v_linewidth + 3.0*u_antialias;\\n\\n // Coordinates in rotated frame with respect to center of marker, used in\\n // distance functions in fragment shader.\\n v_coords = a_position*enclosing_size;\\n\\n float c = cos(-a_angle);\\n float s = sin(-a_angle);\\n mat2 rotation = mat2(c, -s, s, c);\\n\\n vec2 pos = a_center + rotation*v_coords;\\n pos += 0.5; // make up for Bokeh's offset\\n pos /= u_canvas_size / u_pixel_ratio; // in 0..1\\n gl_Position = vec4(2.0*pos.x - 1.0, 1.0 - 2.0*pos.y, 0.0, 1.0);\\n}\\n\"},\n", " 418: function _(n,a,e,t,s){t();e.default=\"\\nprecision mediump float;\\n\\nconst float SQRT_2 = 1.4142135623730951;\\nconst float SQRT_3 = sqrt(3.0);\\nconst float PI = 3.14159265358979323846264;\\n\\nconst float IN_ANGLE = 0.6283185307179586; // PI/5. = 36 degrees (star of 5 pikes)\\n//const float OUT_ANGLE = PI/2. - IN_ANGLE; // External angle for regular stars\\nconst float COS_A = 0.8090169943749475; // cos(IN_ANGLE)\\nconst float SIN_A = 0.5877852522924731; // sin(IN_ANGLE)\\nconst float COS_B = 0.5877852522924731; // cos(OUT_ANGLE)\\nconst float SIN_B = 0.8090169943749475; // sin(OUT_ANGLE)\\n\\nuniform float u_antialias;\\n\\nvarying vec4 v_line_color;\\nvarying vec4 v_fill_color;\\nvarying float v_linewidth;\\nvarying float v_size;\\nvarying vec2 v_coords;\\n\\n#ifdef USE_ASTERISK\\n// asterisk\\nfloat marker(vec2 P, float size)\\n{\\n // Masks\\n float diamond = max(abs(SQRT_2 / 2.0 * (P.x - P.y)), abs(SQRT_2 / 2.0 * (P.x + P.y))) - size / 2.0;\\n float square = max(abs(P.x), abs(P.y)) - size / 2.0;\\n // Shapes\\n float X = min(abs(P.x - P.y), abs(P.x + P.y));\\n float cross = min(abs(P.x), abs(P.y));\\n // Result is union of masked shapes\\n float result = min(max(X, diamond), max(cross, square));\\n return max(result - v_linewidth/2.0 + u_antialias/2.0, 0.0);\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE\\n// circle\\nfloat marker(vec2 P, float size)\\n{\\n return length(P) - size/2.0;\\n}\\n#endif\\n\\n#ifdef USE_DOT\\nfloat marker(vec2 P, float size)\\n{\\n return max(length(P) - size/8.0 - v_linewidth/15.0 + u_antialias, 0.0);\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE_DOT\\nfloat marker(vec2 P, float size)\\n{\\n float circle = length(P) - size/2.0;\\n float dot_ = min(size/8.0 + v_linewidth/15.0 - u_antialias - length(P), 0.0);\\n return max(circle, dot_);\\n}\\n#endif\\n\\n#ifdef USE_SQUARE\\n// square\\nfloat marker(vec2 P, float size)\\n{\\n return max(abs(P.x), abs(P.y)) - size/2.0;\\n}\\n#endif\\n\\n#ifdef USE_SQUARE_DOT\\nfloat marker(vec2 P, float size)\\n{\\n float square = max(abs(P.x), abs(P.y)) - size/2.0;\\n float dot_ = min(size/8.0 + v_linewidth/15.0 - u_antialias - length(P), 0.0);\\n return max(square, dot_);\\n}\\n#endif\\n\\n#ifdef USE_DIAMOND\\n// diamond\\nfloat marker(vec2 P, float size)\\n{\\n float x = SQRT_2 / 2.0 * (P.x * 1.5 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.5 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / (2.0 * SQRT_2);\\n return r1 / SQRT_2;\\n}\\n#endif\\n\\n#ifdef USE_DIAMOND_DOT\\nfloat marker(vec2 P, float size)\\n{\\n float x = SQRT_2 / 2.0 * (P.x * 1.5 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.5 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / (2.0 * SQRT_2);\\n float diamond = r1 / SQRT_2;\\n float dot_ = min(size/8.0 + v_linewidth/15.0 - u_antialias - length(P), 0.0);\\n return max(diamond, dot_);\\n}\\n#endif\\n\\n#ifdef USE_HEX\\n// hex\\nfloat marker(vec2 P, float size)\\n{\\n vec2 q = abs(P);\\n return max(q.y * 0.57735 + q.x - 1.0 * size/2.0, q.y - 0.866 * size/2.0);\\n}\\n#endif\\n\\n#ifdef USE_HEX_DOT\\nfloat marker(vec2 P, float size)\\n{\\n vec2 q = abs(P);\\n float hex = max(q.y * 0.57735 + q.x - 1.0 * size/2.0, q.y - 0.866 * size/2.0);\\n float dot_ = min(size/8.0 + v_linewidth/15.0 - u_antialias - length(P), 0.0);\\n return max(hex, dot_);\\n}\\n#endif\\n\\n#ifdef USE_STAR\\n// star\\n// https://iquilezles.org/www/articles/distfunctions2d/distfunctions2d.htm\\nfloat marker(vec2 P, float size)\\n{\\n float bn = mod(atan(P.x, -P.y), 2.0*IN_ANGLE) - IN_ANGLE;\\n P = length(P)*vec2(cos(bn), abs(sin(bn)));\\n P -= size*vec2(COS_A, SIN_A)/2.;\\n P += vec2(COS_B, SIN_B)*clamp(-(P.x*COS_B + P.y*SIN_B), 0.0, size*SIN_A/SIN_B/2.);\\n return length(P)*sign(P.x);\\n}\\n#endif\\n\\n#ifdef USE_STAR_DOT\\nfloat marker(vec2 P, float size)\\n{\\n float dot_ = min(size/8.0 + v_linewidth/15.0 - u_antialias - length(P), 0.0);\\n float bn = mod(atan(P.x, -P.y), 2.0*IN_ANGLE) - IN_ANGLE;\\n P = length(P)*vec2(cos(bn), abs(sin(bn)));\\n P -= size*vec2(COS_A, SIN_A)/2.;\\n P += vec2(COS_B, SIN_B)*clamp(-(P.x*COS_B + P.y*SIN_B), 0.0, size*SIN_A/SIN_B/2.);\\n float star = length(P)*sign(P.x);\\n return max(star, dot_);\\n}\\n#endif\\n\\n#ifdef USE_TRIANGLE\\n// triangle\\nfloat marker(vec2 P, float size)\\n{\\n P.y -= size * 0.3;\\n float x = SQRT_2 / 2.0 * (P.x * 1.7 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.7 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / 1.6;\\n float r2 = P.y;\\n return max(r1 / SQRT_2, r2); // Intersect diamond with rectangle\\n}\\n#endif\\n\\n#ifdef USE_TRIANGLE_DOT\\nfloat marker(vec2 P, float size)\\n{\\n float dot_ = min(size/8.0 + v_linewidth/15.0 - u_antialias - length(P), 0.0);\\n P.y -= size * 0.3;\\n float x = SQRT_2 / 2.0 * (P.x * 1.7 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.7 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / 1.6;\\n float r2 = P.y;\\n float triangle = max(r1 / SQRT_2, r2); // Intersect diamond with rectangle\\n return max(triangle, dot_);\\n}\\n#endif\\n\\n#ifdef USE_INVERTED_TRIANGLE\\n// inverted_triangle\\nfloat marker(vec2 P, float size)\\n{\\n P.y += size * 0.3;\\n float x = SQRT_2 / 2.0 * (P.x * 1.7 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.7 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / 1.6;\\n float r2 = - P.y;\\n return max(r1 / SQRT_2, r2); // Intersect diamond with rectangle\\n}\\n#endif\\n\\n#ifdef USE_CROSS\\n// cross\\nfloat marker(vec2 P, float size)\\n{\\n float square = max(abs(P.x), abs(P.y)) - size / 2.0;\\n float cross = min(abs(P.x), abs(P.y));\\n cross = max(cross - v_linewidth/2.0 + u_antialias/2.0, 0.0);\\n return max(square, cross);\\n}\\n#endif\\n\\n#ifdef USE_DASH\\nfloat marker(vec2 P, float size)\\n{\\n float square = max(abs(P.x), abs(P.y)) - size / 2.0;\\n float cross = abs(P.y);\\n cross = max(cross - v_linewidth/2.0 + u_antialias/2.0, 0.0);\\n return max(square, cross);\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE_CROSS\\n// circle_cross\\nfloat marker(vec2 P, float size)\\n{\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(P.x - qs), abs(P.y - qs)) - qs;\\n float s2 = max(abs(P.x + qs), abs(P.y - qs)) - qs;\\n float s3 = max(abs(P.x - qs), abs(P.y + qs)) - qs;\\n float s4 = max(abs(P.x + qs), abs(P.y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float circle = length(P) - size/2.0;\\n float c1 = max(circle, s1);\\n float c2 = max(circle, s2);\\n float c3 = max(circle, s3);\\n float c4 = max(circle, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_SQUARE_CROSS\\n// square_cross\\nfloat marker(vec2 P, float size)\\n{\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(P.x - qs), abs(P.y - qs)) - qs;\\n float s2 = max(abs(P.x + qs), abs(P.y - qs)) - qs;\\n float s3 = max(abs(P.x - qs), abs(P.y + qs)) - qs;\\n float s4 = max(abs(P.x + qs), abs(P.y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float square = max(abs(P.x), abs(P.y)) - size/2.0;\\n float c1 = max(square, s1);\\n float c2 = max(square, s2);\\n float c3 = max(square, s3);\\n float c4 = max(square, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_DIAMOND_CROSS\\n// diamond_cross\\nfloat marker(vec2 P, float size)\\n{\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(P.x - qs), abs(P.y - qs)) - qs;\\n float s2 = max(abs(P.x + qs), abs(P.y - qs)) - qs;\\n float s3 = max(abs(P.x - qs), abs(P.y + qs)) - qs;\\n float s4 = max(abs(P.x + qs), abs(P.y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float x = SQRT_2 / 2.0 * (P.x * 1.5 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.5 + P.y);\\n float diamond = max(abs(x), abs(y)) - size / (2.0 * SQRT_2);\\n diamond /= SQRT_2;\\n float c1 = max(diamond, s1);\\n float c2 = max(diamond, s2);\\n float c3 = max(diamond, s3);\\n float c4 = max(diamond, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_X\\n// x\\nfloat marker(vec2 P, float size)\\n{\\n float circle = length(P) - size / 2.0;\\n float X = min(abs(P.x - P.y), abs(P.x + P.y));\\n X = max(X - v_linewidth/2.0, 0.0);\\n return max(circle, X);\\n}\\n#endif\\n\\n#ifdef USE_Y\\nfloat marker(vec2 P, float size)\\n{\\n float circle = length(P) - size / 2.0;\\n\\n float dx = 1.0 / SQRT_3;\\n float dy = SQRT_2 / SQRT_3;\\n\\n // Sideways distance from the three spokes.\\n float d0 = abs(P.x);\\n float d1 = abs(dot(P, vec2(dx, dy)));\\n float d2 = abs(dot(P, vec2(dx, -dy)));\\n\\n // Clip each spoke to semicircle.\\n d0 = max(d0, -P.y);\\n d1 = max(d1, dot(P, vec2(-dy, dx)));\\n d2 = max(d2, dot(P, vec2(dy, dx)));\\n\\n float Y = min(min(d0, d1), d2);\\n Y = max(Y - v_linewidth/2.0 + u_antialias/2.0, 0.0);\\n return max(circle, Y);\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE_X\\n// circle_x\\nfloat marker(vec2 P, float size)\\n{\\n float x = P.x - P.y;\\n float y = P.x + P.y;\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(x - qs), abs(y - qs)) - qs;\\n float s2 = max(abs(x + qs), abs(y - qs)) - qs;\\n float s3 = max(abs(x - qs), abs(y + qs)) - qs;\\n float s4 = max(abs(x + qs), abs(y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float circle = length(P) - size/2.0;\\n float c1 = max(circle, s1);\\n float c2 = max(circle, s2);\\n float c3 = max(circle, s3);\\n float c4 = max(circle, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE_Y\\nfloat marker(vec2 P, float size)\\n{\\n float circle = length(P) - size/2.0;\\n\\n float dx = 1.0 / SQRT_3;\\n float dy = SQRT_2 / SQRT_3;\\n\\n // Sideways distance from the three spokes.\\n float d0 = abs(P.x);\\n float d1 = abs(dot(P, vec2(dx, dy)));\\n float d2 = abs(dot(P, vec2(dx, -dy)));\\n\\n // Clip each spoke to semicircle.\\n d0 = max(d0, -P.y);\\n d1 = max(d1, dot(P, vec2(-dy, dx)));\\n d2 = max(d2, dot(P, vec2(dy, dx)));\\n\\n float Y = min(min(d0, d1), d2);\\n Y = min(v_linewidth/2.0 - u_antialias/2.0 - Y, 0.0);\\n\\n return max(circle, Y);\\n}\\n#endif\\n\\n#ifdef USE_SQUARE_X\\n// square_x\\nfloat marker(vec2 P, float size)\\n{\\n float x = P.x - P.y;\\n float y = P.x + P.y;\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(x - qs), abs(y - qs)) - qs;\\n float s2 = max(abs(x + qs), abs(y - qs)) - qs;\\n float s3 = max(abs(x - qs), abs(y + qs)) - qs;\\n float s4 = max(abs(x + qs), abs(y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float square = max(abs(P.x), abs(P.y)) - size/2.0;\\n float c1 = max(square, s1);\\n float c2 = max(square, s2);\\n float c3 = max(square, s3);\\n float c4 = max(square, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_PLUS\\nfloat marker(vec2 P, float size)\\n{\\n vec2 size2 = vec2(size*0.5, size*0.2);\\n P = abs(P);\\n P = (P.y > P.x) ? P.yx : P.xy;\\n vec2 q = P - size2;\\n float k = max(q.y, q.x);\\n vec2 w = (k > 0.0) ? q : vec2(size2.y - P.x, -k);\\n return sign(k)*length(max(w, 0.0));\\n}\\n#endif\\n\\n#ifdef USE_SQUARE_PIN\\nfloat marker(vec2 P, float size)\\n{\\n float actual_size = size*1.2;\\n float radius = 0.75*actual_size; // Radius of curvature of edges.\\n float offset = actual_size/2.0 + sqrt(radius*radius - actual_size*actual_size/4.0);\\n vec2 centerx = vec2(offset, 0.0);\\n vec2 centery = vec2(0.0, offset);\\n\\n float right = length(P - centerx);\\n float left = length(P + centerx);\\n float up = length(P - centery);\\n float down = length(P + centery);\\n float pin = radius - min(min(right, left), min(up, down));\\n\\n float circle = length(P) - actual_size*0.6;\\n return max(circle, pin);\\n}\\n#endif\\n\\n#ifdef USE_TRIANGLE_PIN\\nfloat marker(vec2 P, float size)\\n{\\n float actual_size = size*1.2;\\n float radius = 1.2*actual_size; // Radius of curvature of edges.\\n\\n float angle = 2.0*PI / 3.0;\\n float c = cos(angle);\\n float s = sin(angle);\\n mat2 rotation = mat2(c, -s, s, c);\\n\\n // Half the length of straight triangle edge.\\n float half_edge = actual_size*SQRT_3/4.0;\\n // Distance from center of triangle to middle of straight edge.\\n float centre_middle_edge = 0.25*actual_size;\\n float offset = centre_middle_edge + sqrt(radius*radius - half_edge*half_edge);\\n // Centre of curvature.\\n vec2 center = vec2(0.0, offset);\\n\\n float dist0 = length(P - center);\\n P = rotation*P;\\n float dist1 = length(P - center);\\n P = rotation*P;\\n float dist2 = length(P - center);\\n float pin = radius - min(min(dist0, dist1), dist2);\\n\\n float circle = length(P) - actual_size / 2.0;\\n return max(circle, pin);\\n}\\n#endif\\n\\nvec4 outline(float distance, float linewidth, float antialias, vec4 line_color,\\n vec4 fill_color)\\n{\\n vec4 frag_color;\\n float t = min(linewidth/2.0 - antialias, 0.0); // Line half-width.\\n float signed_distance = distance;\\n float border_distance = abs(signed_distance) - t;\\n float alpha = border_distance/antialias;\\n alpha = exp(-alpha*alpha);\\n\\n // If line alpha is zero, it probably means no outline. To avoid a dark\\n // outline shining through due to antialiasing, we set the line color to the\\n // fill color.\\n float select = float(bool(line_color.a));\\n line_color.rgb = select*line_color.rgb + (1.0 - select)*fill_color.rgb;\\n // Similarly, if we want a transparent fill.\\n select = float(bool(fill_color.a));\\n fill_color.rgb = select*fill_color.rgb + (1.0 - select)*line_color.rgb;\\n\\n if (border_distance < 0.0)\\n frag_color = line_color;\\n else if (signed_distance < 0.0)\\n frag_color = mix(fill_color, line_color, sqrt(alpha));\\n else {\\n if (abs(signed_distance) < linewidth/2.0 + antialias)\\n frag_color = vec4(line_color.rgb, line_color.a*alpha);\\n else\\n discard;\\n }\\n return frag_color;\\n}\\n\\nvoid main()\\n{\\n float distance = marker(v_coords, v_size);\\n gl_FragColor = outline(\\n distance, v_linewidth, u_antialias, v_line_color, v_fill_color);\\n gl_FragColor.rgb *= gl_FragColor.a; // Premultiplied alpha.\\n}\\n\"},\n", " 419: function _(n,t,a,i,e){i();a.default=\"\\nprecision mediump float;\\n\\nattribute vec2 a_position;\\nattribute vec2 a_center;\\nattribute float a_width;\\nattribute float a_height;\\nattribute float a_angle; // In radians\\nattribute float a_linewidth;\\nattribute vec4 a_line_color;\\nattribute vec4 a_fill_color;\\nattribute float a_line_join;\\nattribute float a_show;\\n#ifdef HATCH\\nattribute float a_hatch_pattern;\\nattribute float a_hatch_scale;\\nattribute float a_hatch_weight;\\nattribute vec4 a_hatch_color;\\n#endif\\n\\nuniform float u_pixel_ratio;\\nuniform vec2 u_canvas_size;\\nuniform float u_antialias;\\n\\nvarying float v_linewidth;\\nvarying vec2 v_size; // 2D size for rects compared to 1D for markers.\\nvarying vec4 v_line_color;\\nvarying vec4 v_fill_color;\\nvarying float v_line_join;\\nvarying vec2 v_coords;\\n#ifdef HATCH\\nvarying float v_hatch_pattern;\\nvarying float v_hatch_scale;\\nvarying float v_hatch_weight;\\nvarying vec4 v_hatch_color;\\nvarying vec2 v_hatch_coords;\\n#endif\\n\\nvoid main()\\n{\\n if (a_show < 0.5) {\\n // Do not show this rect.\\n gl_Position = vec4(-2.0, -2.0, 0.0, 1.0);\\n return;\\n }\\n\\n v_size = vec2(a_width, a_height);\\n v_linewidth = a_linewidth;\\n v_line_color = a_line_color;\\n v_fill_color = a_fill_color;\\n v_line_join = a_line_join;\\n\\n if (v_linewidth < 1.0) {\\n // Linewidth less than 1 is implemented as 1 but with reduced alpha.\\n v_line_color.a *= v_linewidth;\\n v_linewidth = 1.0;\\n }\\n\\n#ifdef HATCH\\n v_hatch_pattern = a_hatch_pattern;\\n v_hatch_scale = a_hatch_scale;\\n v_hatch_weight = a_hatch_weight;\\n v_hatch_color = a_hatch_color;\\n#endif\\n\\n vec2 enclosing_size = v_size + v_linewidth + u_antialias;\\n\\n // Coordinates in rotated frame with respect to center of marker, used for\\n // distance functions in fragment shader.\\n v_coords = a_position*enclosing_size;\\n\\n float c = cos(-a_angle);\\n float s = sin(-a_angle);\\n mat2 rotation = mat2(c, -s, s, c);\\n\\n vec2 pos = a_center + rotation*v_coords;\\n#ifdef HATCH\\n // Coordinates for hatching in unrotated frame of reference.\\n v_hatch_coords = pos - 0.5;\\n#endif\\n pos += 0.5; // Make up for Bokeh's offset.\\n pos /= u_canvas_size / u_pixel_ratio; // 0 to 1.\\n gl_Position = vec4(2.0*pos.x - 1.0, 1.0 - 2.0*pos.y, 0.0, 1.0);\\n}\\n\"},\n", " 420: function _(n,a,t,o,r){o();t.default=\"\\nprecision mediump float;\\n\\nconst float SQRT2 = sqrt(2.0);\\nconst float INVSQRT2 = 1.0/SQRT2;\\nconst float PI = 3.14159265358979323846;\\n\\nconst int miter_join = 0;\\nconst int round_join = 1;\\nconst int bevel_join = 2;\\n#ifdef HATCH\\nconst int hatch_dot = 1;\\nconst int hatch_ring = 2;\\nconst int hatch_horizontal_line = 3;\\nconst int hatch_vertical_line = 4;\\nconst int hatch_cross = 5;\\nconst int hatch_horizontal_dash = 6;\\nconst int hatch_vertical_dash = 7;\\nconst int hatch_spiral = 8;\\nconst int hatch_right_diagonal_line = 9;\\nconst int hatch_left_diagonal_line = 10;\\nconst int hatch_diagonal_cross = 11;\\nconst int hatch_right_diagonal_dash = 12;\\nconst int hatch_left_diagonal_dash = 13;\\nconst int hatch_horizontal_wave = 14;\\nconst int hatch_vertical_wave = 15;\\nconst int hatch_criss_cross = 16;\\n#endif\\n\\nuniform float u_antialias;\\n\\nvarying float v_linewidth;\\nvarying vec2 v_size;\\nvarying vec4 v_line_color;\\nvarying vec4 v_fill_color;\\nvarying float v_line_join;\\nvarying vec2 v_coords;\\n#ifdef HATCH\\nvarying float v_hatch_pattern;\\nvarying float v_hatch_scale;\\nvarying float v_hatch_weight;\\nvarying vec4 v_hatch_color;\\nvarying vec2 v_hatch_coords;\\n#endif\\n\\n// Distance is zero on edge of marker, +ve outside and -ve inside.\\nfloat marker_distance(vec2 p, int line_join)\\n{\\n vec2 dist2 = abs(p) - v_size/2.0;\\n float dist = max(dist2.x, dist2.y);\\n\\n if (dist2.x > 0.0 && dist2.y > 0.0) {\\n // Outside of corner needs correct join, default is miter.\\n if (line_join == round_join)\\n dist = length(dist2);\\n else if (line_join == bevel_join) {\\n vec2 normal = vec2(INVSQRT2, INVSQRT2);\\n dist = dot(dist2, normal) + 0.5*v_linewidth*(1.0 - INVSQRT2);\\n }\\n }\\n\\n return dist;\\n}\\n\\n// Convert distance from edge of marker to fraction in range 0 to 1, depending\\n// on antialiasing width.\\nfloat distance_to_fraction(float dist)\\n{\\n return 1.0 - smoothstep(-0.5*u_antialias, 0.5*u_antialias, dist);\\n}\\n\\n// Return fraction from 0 (no fill color) to 1 (full fill color).\\nfloat fill_fraction(float dist)\\n{\\n return distance_to_fraction(dist);\\n}\\n\\n// Return fraction in range 0 (no line color) to 1 (full line color).\\nfloat line_fraction(float dist)\\n{\\n return distance_to_fraction(abs(dist) - 0.5*v_linewidth);\\n}\\n\\n// Return fraction (in range 0 to 1) of a color, with premultiplied alpha.\\nvec4 fractional_color(vec4 color, float fraction)\\n{\\n color.a *= fraction;\\n color.rgb *= color.a;\\n return color;\\n}\\n\\n// Blend colors that have premultiplied alpha.\\nvec4 blend_colors(vec4 src, vec4 dest)\\n{\\n return (1.0 - src.a)*dest + src;\\n}\\n\\n#ifdef HATCH\\n// Wrap coordinate(s) by removing integer part to give distance from center of\\n// repeat, in the range -0.5 to +0.5.\\nfloat wrap(float x)\\n{\\n return fract(x) - 0.5;\\n}\\n\\nvec2 wrap(vec2 xy)\\n{\\n return fract(xy) - 0.5;\\n}\\n\\n// Return fraction from 0 (no hatch color) to 1 (full hatch color).\\nfloat hatch_fraction(vec2 coords, int hatch_pattern)\\n{\\n float scale = v_hatch_scale; // Hatch repeat distance.\\n\\n // Coordinates and linewidth/halfwidth are scaled to hatch repeat distance.\\n coords = coords / scale;\\n float halfwidth = 0.5*v_hatch_weight / scale; // Half the hatch linewidth.\\n\\n // Default is to return fraction of zero, i.e. no pattern.\\n float dist = u_antialias;\\n\\n if (hatch_pattern == hatch_dot) {\\n const float dot_radius = 0.25;\\n dist = length(wrap(coords)) - dot_radius;\\n }\\n else if (hatch_pattern == hatch_ring) {\\n const float ring_radius = 0.25;\\n dist = abs(length(wrap(coords)) - ring_radius) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_horizontal_line) {\\n dist = abs(wrap(coords.y)) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_vertical_line) {\\n dist = abs(wrap(coords.x)) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_cross) {\\n dist = min(abs(wrap(coords.x)), abs(wrap(coords.y))) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_horizontal_dash) {\\n // Dashes have square caps.\\n const float halflength = 0.25;\\n dist = max(abs(wrap(coords.y)),\\n abs(wrap(coords.x) + 0.25) - halflength) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_vertical_dash) {\\n const float halflength = 0.25;\\n dist = max(abs(wrap(coords.x)),\\n abs(wrap(coords.y) + 0.25) - halflength) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_spiral) {\\n vec2 wrap2 = wrap(coords);\\n float angle = wrap(atan(wrap2.y, wrap2.x) / (2.0*PI));\\n // Canvas spiral radius increases by scale*pi/15 each rotation.\\n const float dr = PI/15.0;\\n float radius = length(wrap2);\\n // At any angle, spiral lines are equally spaced dr apart.\\n // Find distance to nearest of these lines.\\n float frac = fract((radius - dr*angle) / dr); // 0 to 1.\\n dist = dr*(abs(frac - 0.5));\\n dist = min(dist, radius) - halfwidth; // Consider center point also.\\n }\\n else if (hatch_pattern == hatch_right_diagonal_line) {\\n dist = abs(wrap(2.0*coords.x + coords.y))/sqrt(5.0) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_left_diagonal_line) {\\n dist = abs(wrap(2.0*coords.x - coords.y))/sqrt(5.0) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_diagonal_cross) {\\n coords = vec2(coords.x + coords.y + 0.5, coords.x - coords.y + 0.5);\\n dist = min(abs(wrap(coords.x)), abs(wrap(coords.y))) / SQRT2 - halfwidth;\\n }\\n else if (hatch_pattern == hatch_right_diagonal_dash) {\\n float across = coords.x + coords.y + 0.5;\\n dist = abs(wrap(across)) / SQRT2; // Distance to nearest solid line.\\n\\n across = floor(across); // Offset for dash.\\n float along = wrap(0.5*(coords.x - coords.y + across));\\n const float halflength = 0.25;\\n along = abs(along) - halflength; // Distance along line.\\n\\n dist = max(dist, along) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_left_diagonal_dash) {\\n float across = coords.x - coords.y + 0.5;\\n dist = abs(wrap(across)) / SQRT2; // Distance to nearest solid line.\\n\\n across = floor(across); // Offset for dash.\\n float along = wrap(0.5*(coords.x + coords.y + across));\\n const float halflength = 0.25;\\n along = abs(along) - halflength; // Distance along line.\\n\\n dist = max(dist, along) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_horizontal_wave) {\\n float wrapx = wrap(coords.x);\\n float wrapy = wrap(coords.y - 0.25 + abs(wrapx));\\n dist = abs(wrapy) / SQRT2 - halfwidth;\\n }\\n else if (hatch_pattern == hatch_vertical_wave) {\\n float wrapy = wrap(coords.y);\\n float wrapx = wrap(coords.x - 0.25 + abs(wrapy));\\n dist = abs(wrapx) / SQRT2 - halfwidth;\\n }\\n else if (hatch_pattern == hatch_criss_cross) {\\n float plus = min(abs(wrap(coords.x)), abs(wrap(coords.y)));\\n\\n coords = vec2(coords.x + coords.y + 0.5, coords.x - coords.y + 0.5);\\n float X = min(abs(wrap(coords.x)), abs(wrap(coords.y))) / SQRT2;\\n\\n dist = min(plus, X) - halfwidth;\\n }\\n\\n return distance_to_fraction(dist*scale);\\n}\\n#endif\\n\\nvoid main()\\n{\\n int line_join = int(v_line_join + 0.5);\\n#ifdef HATCH\\n int hatch_pattern = int(v_hatch_pattern + 0.5);\\n#endif\\n\\n float dist = marker_distance(v_coords, line_join);\\n\\n float fill_frac = fill_fraction(dist);\\n vec4 color = fractional_color(v_fill_color, fill_frac);\\n\\n#ifdef HATCH\\n if (hatch_pattern > 0 && fill_frac > 0.0) {\\n float hatch_frac = hatch_fraction(v_hatch_coords, hatch_pattern);\\n vec4 hatch_color = fractional_color(v_hatch_color, hatch_frac*fill_frac);\\n color = blend_colors(hatch_color, color);\\n }\\n#endif\\n\\n float line_frac = line_fraction(dist);\\n if (line_frac > 0.0) {\\n vec4 line_color = fractional_color(v_line_color, line_frac);\\n color = blend_colors(line_color, color);\\n }\\n\\n gl_FragColor = color;\\n}\\n\"},\n", " 421: function _(s,i,t,e,_){e();const h=s(422),l=s(22),a=s(46),n=s(423),o=s(424),r=-1e4;class p extends h.BaseGLGlyph{constructor(s,i){super(s,i),this.glyph=i,this._antialias=1.5,this._miter_limit=5}draw(s,i,t){const e=i.glglyph;this.visuals_changed&&(this._set_visuals(),this.visuals_changed=!1),e.data_changed&&(e._set_data(),e.data_changed=!1);const _=this.glyph.visuals.line,h=n.cap_lookup[_.line_cap.value],l=n.join_lookup[_.line_join.value];if(this._is_dashed()){const s={scissor:this.regl_wrapper.scissor,viewport:this.regl_wrapper.viewport,canvas_size:[t.width,t.height],pixel_ratio:t.pixel_ratio,line_color:this._color,linewidth:this._linewidth,antialias:this._antialias,miter_limit:this._miter_limit,points:e._points,nsegments:e._nsegments,line_join:l,line_cap:h,length_so_far:e._length_so_far,dash_tex:this._dash_tex,dash_tex_info:this._dash_tex_info,dash_scale:this._dash_scale,dash_offset:this._dash_offset};this.regl_wrapper.dashed_line()(s)}else{const s={scissor:this.regl_wrapper.scissor,viewport:this.regl_wrapper.viewport,canvas_size:[t.width,t.height],pixel_ratio:t.pixel_ratio,line_color:this._color,linewidth:this._linewidth,antialias:this._antialias,miter_limit:this._miter_limit,points:e._points,nsegments:e._nsegments,line_join:l,line_cap:h};this.regl_wrapper.solid_line()(s)}}_is_dashed(){return this._line_dash.length>0}_set_data(){const s=this.glyph.sx.length;this._nsegments=s-1,null==this._is_closed&&(this._is_closed=this.glyph.sx[0]==this.glyph.sx[s-1]&&this.glyph.sy[0]==this.glyph.sy[s-1]&&isFinite(this.glyph.sx[0])&&isFinite(this.glyph.sy[0])),null==this._points&&(this._points=new o.Float32Buffer(this.regl_wrapper));const i=this._points.get_sized_array(2*(s+2));for(let t=1;t-9e3&&i[2*e+4]>-9e3&&(t+=Math.sqrt((i[2*e+4]-i[2*e+2])**2+(i[2*e+5]-i[2*e+3])**2));this._length_so_far.update()}}_set_visuals(){const s=this.glyph.visuals.line,i=(0,l.color2rgba)(s.line_color.value,s.line_alpha.value);this._color=i.map((s=>s/255)),this._linewidth=s.line_width.value,this._linewidth<1&&(this._color[3]*=this._linewidth,this._linewidth=1),this._line_dash=(0,a.resolve_line_dash)(s.line_dash.value),1==this._line_dash.length&&this._line_dash.push(this._line_dash[0]),this._is_dashed()&&([this._dash_tex_info,this._dash_tex,this._dash_scale]=this.regl_wrapper.get_dash(this._line_dash),this._dash_offset=s.line_dash_offset.value)}}t.LineGL=p,p.__name__=\"LineGL\"},\n", " 422: function _(e,t,s,i,h){i();class a{constructor(e,t){this.glyph=t,this.nvertices=0,this.size_changed=!1,this.data_changed=!1,this.visuals_changed=!1,this.regl_wrapper=e}set_data_changed(){const{data_size:e}=this.glyph;e!=this.nvertices&&(this.nvertices=e,this.size_changed=!0),this.data_changed=!0}set_visuals_changed(){this.visuals_changed=!0}render(e,t,s){if(0==t.length)return!0;const{width:i,height:h}=this.glyph.renderer.plot_view.canvas_view.webgl.canvas,a={pixel_ratio:this.glyph.renderer.plot_view.canvas_view.pixel_ratio,width:i,height:h};return this.draw(t,s,a),!0}}s.BaseGLGlyph=a,a.__name__=\"BaseGLGlyph\"},\n", " 423: function _(a,o,i,n,l){n();const t=a(52);i.cap_lookup={butt:0,round:1,square:2},i.join_lookup={miter:0,round:1,bevel:2};const _={blank:0,dot:1,ring:2,horizontal_line:3,vertical_line:4,cross:5,horizontal_dash:6,vertical_dash:7,spiral:8,right_diagonal_line:9,left_diagonal_line:10,diagonal_cross:11,right_diagonal_dash:12,left_diagonal_dash:13,horizontal_wave:14,vertical_wave:15,criss_cross:16};i.hatch_pattern_to_index=function(a){var o,i;return null!==(i=_[null!==(o=t.hatch_aliases[a])&&void 0!==o?o:a])&&void 0!==i?i:0}},\n", " 424: function _(r,t,a,e,s){e();const i=r(423),_=r(22);class n{constructor(r){this.regl_wrapper=r,this.is_scalar=!0}get_sized_array(r){return null!=this.array&&this.array.length==r||(this.array=this.new_array(r)),this.array}is_normalized(){return!1}get length(){return null!=this.array?this.array.length:0}set_from_array(r){const t=r.length,a=this.get_sized_array(t);for(let e=0;ethis.render()))}remove(){null!=this.icon_view&&this.icon_view.remove(),super.remove()}styles(){return[...super.styles(),d.default]}_render_button(...t){return(0,c.button)({type:\"button\",disabled:this.model.disabled,class:[h.btn,h[`btn_${this.model.button_type}`]]},...t)}render(){super.render(),this.button_el=this._render_button(this.model.label),this.button_el.addEventListener(\"click\",(()=>this.click())),null!=this.icon_view&&(\"\"!=this.model.label?(0,c.prepend)(this.button_el,this.icon_view.el,(0,c.nbsp)()):(0,c.prepend)(this.button_el,this.icon_view.el),this.icon_view.render()),this.group_el=(0,c.div)({class:h.btn_group},this.button_el),this.el.appendChild(this.group_el)}click(){}}n.AbstractButtonView=b,b.__name__=\"AbstractButtonView\";class p extends _.Control{constructor(t){super(t)}}n.AbstractButton=p,o=p,p.__name__=\"AbstractButton\",o.define((({String:t,Ref:e,Nullable:n})=>({label:[t,\"Button\"],icon:[n(e(a.AbstractIcon)),null],button_type:[r.ButtonType,\"default\"]})))},\n", " 439: function _(t,e,o,s,n){s();const i=t(508),l=t(43);class c extends i.WidgetView{connect_signals(){super.connect_signals();const t=this.model.properties;this.on_change(t.disabled,(()=>{for(const t of this.controls())(0,l.toggle_attribute)(t,\"disabled\",this.model.disabled)}))}}o.ControlView=c,c.__name__=\"ControlView\";class r extends i.Widget{constructor(t){super(t)}}o.Control=r,r.__name__=\"Control\"},\n", " 508: function _(i,e,t,n,o){var r;n();const s=i(312);class _ extends s.HTMLBoxView{get orientation(){return\"horizontal\"}get default_size(){return this.model.default_size}_width_policy(){return\"horizontal\"==this.orientation?super._width_policy():\"fixed\"}_height_policy(){return\"horizontal\"==this.orientation?\"fixed\":super._height_policy()}box_sizing(){const i=super.box_sizing();return\"horizontal\"==this.orientation?null==i.width&&(i.width=this.default_size):null==i.height&&(i.height=this.default_size),i}}t.WidgetView=_,_.__name__=\"WidgetView\";class h extends s.HTMLBox{constructor(i){super(i)}}t.Widget=h,r=h,h.__name__=\"Widget\",r.define((({Number:i})=>({default_size:[i,300]}))),r.override({margin:[5,5,5,5]})},\n", " 441: function _(c,t,s,n,e){n();const o=c(53),_=c(226);class a extends _.DOMView{}s.AbstractIconView=a,a.__name__=\"AbstractIconView\";class r extends o.Model{constructor(c){super(c)}}s.AbstractIcon=r,r.__name__=\"AbstractIcon\"},\n", " 442: function _(e,t,n,s,i){s();const h=e(1);var o;const _=e(443),u=e(43),r=e(10),c=(0,h.__importStar)(e(229)),a=c;class l extends _.TextInputView{constructor(){super(...arguments),this._open=!1,this._last_value=\"\",this._hover_index=0}styles(){return[...super.styles(),c.default]}render(){super.render(),this.input_el.addEventListener(\"keydown\",(e=>this._keydown(e))),this.input_el.addEventListener(\"keyup\",(e=>this._keyup(e))),this.menu=(0,u.div)({class:[a.menu,a.below]}),this.menu.addEventListener(\"click\",(e=>this._menu_click(e))),this.menu.addEventListener(\"mouseover\",(e=>this._menu_hover(e))),this.el.appendChild(this.menu),(0,u.undisplay)(this.menu)}change_input(){this._open&&this.menu.children.length>0?(this.model.value=this.menu.children[this._hover_index].textContent,this.input_el.focus(),this._hide_menu()):this.model.restrict||super.change_input()}_update_completions(e){(0,u.empty)(this.menu);for(const t of e){const e=(0,u.div)(t);this.menu.appendChild(e)}e.length>0&&this.menu.children[0].classList.add(a.active)}_show_menu(){if(!this._open){this._open=!0,this._hover_index=0,this._last_value=this.model.value,(0,u.display)(this.menu);const e=t=>{const{target:n}=t;n instanceof HTMLElement&&!this.el.contains(n)&&(document.removeEventListener(\"click\",e),this._hide_menu())};document.addEventListener(\"click\",e)}}_hide_menu(){this._open&&(this._open=!1,(0,u.undisplay)(this.menu))}_menu_click(e){e.target!=e.currentTarget&&e.target instanceof Element&&(this.model.value=e.target.textContent,this.input_el.focus(),this._hide_menu())}_menu_hover(e){if(e.target!=e.currentTarget&&e.target instanceof Element){let t=0;for(t=0;t0&&(this.menu.children[this._hover_index].classList.remove(a.active),this._hover_index=(0,r.clamp)(e,0,t-1),this.menu.children[this._hover_index].classList.add(a.active))}_keydown(e){}_keyup(e){switch(e.keyCode){case u.Keys.Enter:this.change_input();break;case u.Keys.Esc:this._hide_menu();break;case u.Keys.Up:this._bump_hover(this._hover_index-1);break;case u.Keys.Down:this._bump_hover(this._hover_index+1);break;default:{const e=this.input_el.value;if(e.lengthe:e=>e.toLowerCase();for(const n of this.model.completions)s(n).startsWith(s(e))&&t.push(n);this._update_completions(t),0==t.length?this._hide_menu():this._show_menu()}}}}n.AutocompleteInputView=l,l.__name__=\"AutocompleteInputView\";class d extends _.TextInput{constructor(e){super(e)}}n.AutocompleteInput=d,o=d,d.__name__=\"AutocompleteInput\",o.prototype.default_view=l,o.define((({Boolean:e,Int:t,String:n,Array:s})=>({completions:[s(n),[]],min_characters:[t,2],case_sensitive:[e,!0],restrict:[e,!0]})))},\n", " 443: function _(t,e,n,p,_){p();const u=t(1);var i;const s=t(444),r=t(43),x=(0,u.__importStar)(t(446));class a extends s.TextLikeInputView{_render_input(){this.input_el=(0,r.input)({type:\"text\",class:x.input})}}n.TextInputView=a,a.__name__=\"TextInputView\";class c extends s.TextLikeInput{constructor(t){super(t)}}n.TextInput=c,i=c,c.__name__=\"TextInput\",i.prototype.default_view=a},\n", " 444: function _(e,t,n,i,l){var s;i();const h=e(445);class a extends h.InputWidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.name.change,(()=>{var e;return this.input_el.name=null!==(e=this.model.name)&&void 0!==e?e:\"\"})),this.connect(this.model.properties.value.change,(()=>this.input_el.value=this.model.value)),this.connect(this.model.properties.value_input.change,(()=>this.input_el.value=this.model.value_input)),this.connect(this.model.properties.disabled.change,(()=>this.input_el.disabled=this.model.disabled)),this.connect(this.model.properties.placeholder.change,(()=>this.input_el.placeholder=this.model.placeholder)),this.connect(this.model.properties.max_length.change,(()=>{const{max_length:e}=this.model;null!=e?this.input_el.maxLength=e:this.input_el.removeAttribute(\"maxLength\")}))}render(){var e;super.render(),this._render_input();const{input_el:t}=this;t.name=null!==(e=this.model.name)&&void 0!==e?e:\"\",t.value=this.model.value,t.disabled=this.model.disabled,t.placeholder=this.model.placeholder,null!=this.model.max_length&&(t.maxLength=this.model.max_length),t.addEventListener(\"change\",(()=>this.change_input())),t.addEventListener(\"input\",(()=>this.change_input_value())),this.group_el.appendChild(t)}change_input(){this.model.value=this.input_el.value,super.change_input()}change_input_value(){this.model.value_input=this.input_el.value,super.change_input()}}n.TextLikeInputView=a,a.__name__=\"TextLikeInputView\";class u extends h.InputWidget{constructor(e){super(e)}}n.TextLikeInput=u,s=u,u.__name__=\"TextLikeInput\",s.define((({Int:e,String:t,Nullable:n})=>({value:[t,\"\"],value_input:[t,\"\"],placeholder:[t,\"\"],max_length:[n(e),null]})))},\n", " 445: function _(e,t,n,s,l){s();const i=e(1);var o;const r=e(439),_=e(43),p=(0,i.__importStar)(e(446)),a=p;class c extends r.ControlView{*controls(){yield this.input_el}connect_signals(){super.connect_signals(),this.connect(this.model.properties.title.change,(()=>{this.label_el.textContent=this.model.title}))}styles(){return[...super.styles(),p.default]}render(){super.render();const{title:e}=this.model;this.label_el=(0,_.label)({style:{display:0==e.length?\"none\":\"\"}},e),this.group_el=(0,_.div)({class:a.input_group},this.label_el),this.el.appendChild(this.group_el)}change_input(){}}n.InputWidgetView=c,c.__name__=\"InputWidgetView\";class d extends r.Control{constructor(e){super(e)}}n.InputWidget=d,o=d,d.__name__=\"InputWidget\",o.define((({String:e})=>({title:[e,\"\"]})))},\n", " 446: function _(o,p,t,n,i){n(),t.root=\"bk-root\",t.input=\"bk-input\",t.input_group=\"bk-input-group\",t.inline=\"bk-inline\",t.spin_wrapper=\"bk-spin-wrapper\",t.spin_btn=\"bk-spin-btn\",t.spin_btn_up=\"bk-spin-btn-up\",t.spin_btn_down=\"bk-spin-btn-down\",t.default='.bk-root .bk-input{display:inline-block;width:100%;flex-grow:1;min-height:31px;padding:0 12px;background-color:#fff;border:1px solid #ccc;border-radius:4px;}.bk-root .bk-input:focus{border-color:#66afe9;outline:0;box-shadow:inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);}.bk-root .bk-input::placeholder,.bk-root .bk-input:-ms-input-placeholder,.bk-root .bk-input::-moz-placeholder,.bk-root .bk-input::-webkit-input-placeholder{color:#999;opacity:1;}.bk-root .bk-input[disabled]{cursor:not-allowed;background-color:#eee;opacity:1;}.bk-root select:not([multiple]).bk-input,.bk-root select:not([size]).bk-input{height:auto;appearance:none;-webkit-appearance:none;background-image:url(\\'data:image/svg+xml;utf8,\\');background-position:right 0.5em center;background-size:8px 6px;background-repeat:no-repeat;}.bk-root select[multiple].bk-input,.bk-root select[size].bk-input,.bk-root textarea.bk-input{height:auto;}.bk-root .bk-input-group{width:100%;height:100%;display:inline-flex;flex-wrap:nowrap;align-items:start;flex-direction:column;white-space:nowrap;}.bk-root .bk-input-group.bk-inline{flex-direction:row;}.bk-root .bk-input-group.bk-inline > *:not(:first-child){margin-left:5px;}.bk-root .bk-input-group input[type=\"checkbox\"] + span,.bk-root .bk-input-group input[type=\"radio\"] + span{position:relative;top:-2px;margin-left:3px;}.bk-root .bk-input-group > .bk-spin-wrapper{display:inherit;width:inherit;height:inherit;position:relative;overflow:hidden;padding:0;vertical-align:middle;}.bk-root .bk-input-group > .bk-spin-wrapper input{padding-right:20px;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn{position:absolute;display:block;height:50%;min-height:0;min-width:0;width:30px;padding:0;margin:0;right:0;border:none;background:none;cursor:pointer;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn:before{content:\"\";display:inline-block;transform:translateY(-50%);border-left:5px solid transparent;border-right:5px solid transparent;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-up{top:0;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-up:before{border-bottom:5px solid black;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-up:disabled:before{border-bottom-color:grey;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-down{bottom:0;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-down:before{border-top:5px solid black;}.bk-root .bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-down:disabled:before{border-top-color:grey;}'},\n", " 447: function _(t,e,n,o,c){var s;o();const u=t(438),r=t(251);class i extends u.AbstractButtonView{click(){this.model.trigger_event(new r.ButtonClick),super.click()}}n.ButtonView=i,i.__name__=\"ButtonView\";class _ extends u.AbstractButton{constructor(t){super(t)}}n.Button=_,s=_,_.__name__=\"Button\",s.prototype.default_view=i,s.override({label:\"Button\"})},\n", " 448: function _(t,e,o,c,a){c();const s=t(1);var n;const i=t(449),r=t(43),u=(0,s.__importStar)(t(318));class _ extends i.ButtonGroupView{get active(){return new Set(this.model.active)}change_active(t){const{active:e}=this;e.has(t)?e.delete(t):e.add(t),this.model.active=[...e].sort()}_update_active(){const{active:t}=this;this._buttons.forEach(((e,o)=>{(0,r.classes)(e).toggle(u.active,t.has(o))}))}}o.CheckboxButtonGroupView=_,_.__name__=\"CheckboxButtonGroupView\";class h extends i.ButtonGroup{constructor(t){super(t)}}o.CheckboxButtonGroup=h,n=h,h.__name__=\"CheckboxButtonGroup\",n.prototype.default_view=_,n.define((({Int:t,Array:e})=>({active:[e(t),[]]})))},\n", " 449: function _(t,e,n,s,i){s();const o=t(1);var r;const a=t(450),l=t(20),d=t(43),u=(0,o.__importStar)(t(318)),_=u;class c extends a.OrientedControlView{get default_size(){return\"horizontal\"==this.orientation?this.model.default_size:void 0}*controls(){yield*this._buttons}connect_signals(){super.connect_signals();const t=this.model.properties;this.on_change(t.button_type,(()=>this.render())),this.on_change(t.labels,(()=>this.render())),this.on_change(t.active,(()=>this._update_active()))}styles(){return[...super.styles(),u.default]}render(){super.render(),this._buttons=this.model.labels.map(((t,e)=>{const n=(0,d.div)({class:[_.btn,_[`btn_${this.model.button_type}`]],disabled:this.model.disabled},t);return n.addEventListener(\"click\",(()=>this.change_active(e))),n})),this._update_active();const t=\"horizontal\"==this.model.orientation?_.horizontal:_.vertical,e=(0,d.div)({class:[_.btn_group,t]},this._buttons);this.el.appendChild(e)}}n.ButtonGroupView=c,c.__name__=\"ButtonGroupView\";class h extends a.OrientedControl{constructor(t){super(t)}}n.ButtonGroup=h,r=h,h.__name__=\"ButtonGroup\",r.define((({String:t,Array:e})=>({labels:[e(t),[]],button_type:[l.ButtonType,\"default\"]})))},\n", " 450: function _(n,t,e,o,r){var i;o();const a=n(439),l=n(20);class s extends a.ControlView{get orientation(){return this.model.orientation}}e.OrientedControlView=s,s.__name__=\"OrientedControlView\";class _ extends a.Control{constructor(n){super(n)}}e.OrientedControl=_,i=_,_.__name__=\"OrientedControl\",i.define((()=>({orientation:[l.Orientation,\"horizontal\"]})))},\n", " 451: function _(e,t,n,i,s){i();const o=e(1);var a;const c=e(452),l=e(43),d=e(9),p=(0,o.__importStar)(e(446));class r extends c.InputGroupView{render(){super.render();const e=(0,l.div)({class:[p.input_group,this.model.inline?p.inline:null]});this.el.appendChild(e);const{active:t,labels:n}=this.model;this._inputs=[];for(let i=0;ithis.change_active(i))),this._inputs.push(s),this.model.disabled&&(s.disabled=!0),(0,d.includes)(t,i)&&(s.checked=!0);const o=(0,l.label)(s,(0,l.span)(n[i]));e.appendChild(o)}}change_active(e){const t=new Set(this.model.active);t.has(e)?t.delete(e):t.add(e),this.model.active=[...t].sort()}}n.CheckboxGroupView=r,r.__name__=\"CheckboxGroupView\";class h extends c.InputGroup{constructor(e){super(e)}}n.CheckboxGroup=h,a=h,h.__name__=\"CheckboxGroup\",a.prototype.default_view=r,a.define((({Boolean:e,Int:t,String:n,Array:i})=>({active:[i(t),[]],labels:[i(n),[]],inline:[e,!1]})))},\n", " 452: function _(n,t,e,s,o){s();const r=n(1),u=n(439),c=(0,r.__importDefault)(n(446));class _ extends u.ControlView{*controls(){yield*this._inputs}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.render()))}styles(){return[...super.styles(),c.default]}}e.InputGroupView=_,_.__name__=\"InputGroupView\";class i extends u.Control{constructor(n){super(n)}}e.InputGroup=i,i.__name__=\"InputGroup\"},\n", " 453: function _(e,t,i,n,o){n();const s=e(1);var l;const r=e(445),c=e(43),a=e(22),d=(0,s.__importStar)(e(446));class h extends r.InputWidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.name.change,(()=>{var e;return this.input_el.name=null!==(e=this.model.name)&&void 0!==e?e:\"\"})),this.connect(this.model.properties.color.change,(()=>this.input_el.value=(0,a.color2hexrgb)(this.model.color))),this.connect(this.model.properties.disabled.change,(()=>this.input_el.disabled=this.model.disabled))}render(){super.render(),this.input_el=(0,c.input)({type:\"color\",class:d.input,name:this.model.name,value:this.model.color,disabled:this.model.disabled}),this.input_el.addEventListener(\"change\",(()=>this.change_input())),this.group_el.appendChild(this.input_el)}change_input(){this.model.color=this.input_el.value,super.change_input()}}i.ColorPickerView=h,h.__name__=\"ColorPickerView\";class p extends r.InputWidget{constructor(e){super(e)}}i.ColorPicker=p,l=p,p.__name__=\"ColorPicker\",l.prototype.default_view=h,l.define((({Color:e})=>({color:[e,\"#000000\"]})))},\n", " 454: function _(e,t,i,n,s){n();const a=e(1);var l;const o=(0,a.__importDefault)(e(455)),d=e(445),r=e(43),c=e(20),u=e(8),h=(0,a.__importStar)(e(446)),_=(0,a.__importDefault)(e(456));function p(e){const t=[];for(const i of e)if((0,u.isString)(i))t.push(i);else{const[e,n]=i;t.push({from:e,to:n})}return t}class m extends d.InputWidgetView{connect_signals(){super.connect_signals();const{value:e,min_date:t,max_date:i,disabled_dates:n,enabled_dates:s,position:a,inline:l}=this.model.properties;this.connect(e.change,(()=>{var e;return null===(e=this._picker)||void 0===e?void 0:e.setDate(this.model.value)})),this.connect(t.change,(()=>{var e;return null===(e=this._picker)||void 0===e?void 0:e.set(\"minDate\",this.model.min_date)})),this.connect(i.change,(()=>{var e;return null===(e=this._picker)||void 0===e?void 0:e.set(\"maxDate\",this.model.max_date)})),this.connect(n.change,(()=>{var e;return null===(e=this._picker)||void 0===e?void 0:e.set(\"disable\",this.model.disabled_dates)})),this.connect(s.change,(()=>{var e;return null===(e=this._picker)||void 0===e?void 0:e.set(\"enable\",this.model.enabled_dates)})),this.connect(a.change,(()=>{var e;return null===(e=this._picker)||void 0===e?void 0:e.set(\"position\",this.model.position)})),this.connect(l.change,(()=>{var e;return null===(e=this._picker)||void 0===e?void 0:e.set(\"inline\",this.model.inline)}))}remove(){var e;null===(e=this._picker)||void 0===e||e.destroy(),super.remove()}styles(){return[...super.styles(),_.default]}render(){var e,t;null==this._picker&&(super.render(),this.input_el=(0,r.input)({type:\"text\",class:h.input,disabled:this.model.disabled}),this.group_el.appendChild(this.input_el),this._picker=(0,o.default)(this.input_el,{defaultDate:this.model.value,minDate:null!==(e=this.model.min_date)&&void 0!==e?e:void 0,maxDate:null!==(t=this.model.max_date)&&void 0!==t?t:void 0,inline:this.model.inline,position:this.model.position,disable:p(this.model.disabled_dates),enable:p(this.model.enabled_dates),onChange:(e,t,i)=>this._on_change(e,t,i)}))}_on_change(e,t,i){this.model.value=t,this.change_input()}}i.DatePickerView=m,m.__name__=\"DatePickerView\";class v extends d.InputWidget{constructor(e){super(e)}}i.DatePicker=v,l=v,v.__name__=\"DatePicker\",l.prototype.default_view=m,l.define((({Boolean:e,String:t,Array:i,Tuple:n,Or:s,Nullable:a})=>{const l=i(s(t,n(t,t)));return{value:[t],min_date:[a(t),null],max_date:[a(t),null],disabled_dates:[l,[]],enabled_dates:[l,[]],position:[c.CalendarPosition,\"auto\"],inline:[e,!1]}}))},\n", " 455: function _(e,n,t,a,i){\n", " /* flatpickr v4.6.6, @license MIT */var o,r;o=this,r=function(){\"use strict\";\n", " /*! *****************************************************************************\n", " Copyright (c) Microsoft Corporation.\n", " \n", " Permission to use, copy, modify, and/or distribute this software for any\n", " purpose with or without fee is hereby granted.\n", " \n", " THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\n", " REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\n", " AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\n", " INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\n", " LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\n", " OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\n", " PERFORMANCE OF THIS SOFTWARE.\n", " ***************************************************************************** */var e=function(){return e=Object.assign||function(e){for(var n,t=1,a=arguments.length;t\",noCalendar:!1,now:new Date,onChange:[],onClose:[],onDayCreate:[],onDestroy:[],onKeyDown:[],onMonthChange:[],onOpen:[],onParseConfig:[],onReady:[],onValueUpdate:[],onYearChange:[],onPreCalendarPosition:[],plugins:[],position:\"auto\",positionElement:void 0,prevArrow:\"\",shorthandCurrentMonth:!1,showMonths:1,static:!1,time_24hr:!1,weekNumbers:!1,wrap:!1},i={weekdays:{shorthand:[\"Sun\",\"Mon\",\"Tue\",\"Wed\",\"Thu\",\"Fri\",\"Sat\"],longhand:[\"Sunday\",\"Monday\",\"Tuesday\",\"Wednesday\",\"Thursday\",\"Friday\",\"Saturday\"]},months:{shorthand:[\"Jan\",\"Feb\",\"Mar\",\"Apr\",\"May\",\"Jun\",\"Jul\",\"Aug\",\"Sep\",\"Oct\",\"Nov\",\"Dec\"],longhand:[\"January\",\"February\",\"March\",\"April\",\"May\",\"June\",\"July\",\"August\",\"September\",\"October\",\"November\",\"December\"]},daysInMonth:[31,28,31,30,31,30,31,31,30,31,30,31],firstDayOfWeek:0,ordinal:function(e){var n=e%100;if(n>3&&n<21)return\"th\";switch(n%10){case 1:return\"st\";case 2:return\"nd\";case 3:return\"rd\";default:return\"th\"}},rangeSeparator:\" to \",weekAbbreviation:\"Wk\",scrollTitle:\"Scroll to increment\",toggleTitle:\"Click to toggle\",amPM:[\"AM\",\"PM\"],yearAriaLabel:\"Year\",monthAriaLabel:\"Month\",hourAriaLabel:\"Hour\",minuteAriaLabel:\"Minute\",time_24hr:!1},o=function(e,n){return void 0===n&&(n=2),(\"000\"+e).slice(-1*n)},r=function(e){return!0===e?1:0};function l(e,n,t){var a;return void 0===t&&(t=!1),function(){var i=this,o=arguments;null!==a&&clearTimeout(a),a=window.setTimeout((function(){a=null,t||e.apply(i,o)}),n),t&&!a&&e.apply(i,o)}}var c=function(e){return e instanceof Array?e:[e]};function d(e,n,t){if(!0===t)return e.classList.add(n);e.classList.remove(n)}function s(e,n,t){var a=window.document.createElement(e);return n=n||\"\",t=t||\"\",a.className=n,void 0!==t&&(a.textContent=t),a}function u(e){for(;e.firstChild;)e.removeChild(e.firstChild)}function f(e,n){return n(e)?e:e.parentNode?f(e.parentNode,n):void 0}function m(e,n){var t=s(\"div\",\"numInputWrapper\"),a=s(\"input\",\"numInput \"+e),i=s(\"span\",\"arrowUp\"),o=s(\"span\",\"arrowDown\");if(-1===navigator.userAgent.indexOf(\"MSIE 9.0\")?a.type=\"number\":(a.type=\"text\",a.pattern=\"\\\\d*\"),void 0!==n)for(var r in n)a.setAttribute(r,n[r]);return t.appendChild(a),t.appendChild(i),t.appendChild(o),t}function g(e){try{return\"function\"==typeof e.composedPath?e.composedPath()[0]:e.target}catch(n){return e.target}}var p=function(){},h=function(e,n,t){return t.months[n?\"shorthand\":\"longhand\"][e]},v={D:p,F:function(e,n,t){e.setMonth(t.months.longhand.indexOf(n))},G:function(e,n){e.setHours(parseFloat(n))},H:function(e,n){e.setHours(parseFloat(n))},J:function(e,n){e.setDate(parseFloat(n))},K:function(e,n,t){e.setHours(e.getHours()%12+12*r(new RegExp(t.amPM[1],\"i\").test(n)))},M:function(e,n,t){e.setMonth(t.months.shorthand.indexOf(n))},S:function(e,n){e.setSeconds(parseFloat(n))},U:function(e,n){return new Date(1e3*parseFloat(n))},W:function(e,n,t){var a=parseInt(n),i=new Date(e.getFullYear(),0,2+7*(a-1),0,0,0,0);return i.setDate(i.getDate()-i.getDay()+t.firstDayOfWeek),i},Y:function(e,n){e.setFullYear(parseFloat(n))},Z:function(e,n){return new Date(n)},d:function(e,n){e.setDate(parseFloat(n))},h:function(e,n){e.setHours(parseFloat(n))},i:function(e,n){e.setMinutes(parseFloat(n))},j:function(e,n){e.setDate(parseFloat(n))},l:p,m:function(e,n){e.setMonth(parseFloat(n)-1)},n:function(e,n){e.setMonth(parseFloat(n)-1)},s:function(e,n){e.setSeconds(parseFloat(n))},u:function(e,n){return new Date(parseFloat(n))},w:p,y:function(e,n){e.setFullYear(2e3+parseFloat(n))}},D={D:\"(\\\\w+)\",F:\"(\\\\w+)\",G:\"(\\\\d\\\\d|\\\\d)\",H:\"(\\\\d\\\\d|\\\\d)\",J:\"(\\\\d\\\\d|\\\\d)\\\\w+\",K:\"\",M:\"(\\\\w+)\",S:\"(\\\\d\\\\d|\\\\d)\",U:\"(.+)\",W:\"(\\\\d\\\\d|\\\\d)\",Y:\"(\\\\d{4})\",Z:\"(.+)\",d:\"(\\\\d\\\\d|\\\\d)\",h:\"(\\\\d\\\\d|\\\\d)\",i:\"(\\\\d\\\\d|\\\\d)\",j:\"(\\\\d\\\\d|\\\\d)\",l:\"(\\\\w+)\",m:\"(\\\\d\\\\d|\\\\d)\",n:\"(\\\\d\\\\d|\\\\d)\",s:\"(\\\\d\\\\d|\\\\d)\",u:\"(.+)\",w:\"(\\\\d\\\\d|\\\\d)\",y:\"(\\\\d{2})\"},w={Z:function(e){return e.toISOString()},D:function(e,n,t){return n.weekdays.shorthand[w.w(e,n,t)]},F:function(e,n,t){return h(w.n(e,n,t)-1,!1,n)},G:function(e,n,t){return o(w.h(e,n,t))},H:function(e){return o(e.getHours())},J:function(e,n){return void 0!==n.ordinal?e.getDate()+n.ordinal(e.getDate()):e.getDate()},K:function(e,n){return n.amPM[r(e.getHours()>11)]},M:function(e,n){return h(e.getMonth(),!0,n)},S:function(e){return o(e.getSeconds())},U:function(e){return e.getTime()/1e3},W:function(e,n,t){return t.getWeek(e)},Y:function(e){return o(e.getFullYear(),4)},d:function(e){return o(e.getDate())},h:function(e){return e.getHours()%12?e.getHours()%12:12},i:function(e){return o(e.getMinutes())},j:function(e){return e.getDate()},l:function(e,n){return n.weekdays.longhand[e.getDay()]},m:function(e){return o(e.getMonth()+1)},n:function(e){return e.getMonth()+1},s:function(e){return e.getSeconds()},u:function(e){return e.getTime()},w:function(e){return e.getDay()},y:function(e){return String(e.getFullYear()).substring(2)}},b=function(e){var n=e.config,t=void 0===n?a:n,o=e.l10n,r=void 0===o?i:o,l=e.isMobile,c=void 0!==l&&l;return function(e,n,a){var i=a||r;return void 0===t.formatDate||c?n.split(\"\").map((function(n,a,o){return w[n]&&\"\\\\\"!==o[a-1]?w[n](e,i,t):\"\\\\\"!==n?n:\"\"})).join(\"\"):t.formatDate(e,n,i)}},C=function(e){var n=e.config,t=void 0===n?a:n,o=e.l10n,r=void 0===o?i:o;return function(e,n,i,o){if(0===e||e){var l,c=o||r,d=e;if(e instanceof Date)l=new Date(e.getTime());else if(\"string\"!=typeof e&&void 0!==e.toFixed)l=new Date(e);else if(\"string\"==typeof e){var s=n||(t||a).dateFormat,u=String(e).trim();if(\"today\"===u)l=new Date,i=!0;else if(/Z$/.test(u)||/GMT$/.test(u))l=new Date(e);else if(t&&t.parseDate)l=t.parseDate(e,s);else{l=t&&t.noCalendar?new Date((new Date).setHours(0,0,0,0)):new Date((new Date).getFullYear(),0,1,0,0,0,0);for(var f=void 0,m=[],g=0,p=0,h=\"\";gl&&(u=a===w.hourElement?u-l-r(!w.amPM):i,m&&H(void 0,1,w.hourElement)),w.amPM&&f&&(1===c?u+d===23:Math.abs(u-d)>c)&&(w.amPM.textContent=w.l10n.amPM[r(w.amPM.textContent===w.l10n.amPM[0])]),a.value=o(u)}}(e);var c=w._input.value;I(),be(),w._input.value!==c&&w._debouncedChange()}function I(){if(void 0!==w.hourElement&&void 0!==w.minuteElement){var e,n,t=(parseInt(w.hourElement.value.slice(-2),10)||0)%24,a=(parseInt(w.minuteElement.value,10)||0)%60,i=void 0!==w.secondElement?(parseInt(w.secondElement.value,10)||0)%60:0;void 0!==w.amPM&&(e=t,n=w.amPM.textContent,t=e%12+12*r(n===w.l10n.amPM[1]));var o=void 0!==w.config.minTime||w.config.minDate&&w.minDateHasTime&&w.latestSelectedDateObj&&0===M(w.latestSelectedDateObj,w.config.minDate,!0);if(void 0!==w.config.maxTime||w.config.maxDate&&w.maxDateHasTime&&w.latestSelectedDateObj&&0===M(w.latestSelectedDateObj,w.config.maxDate,!0)){var l=void 0!==w.config.maxTime?w.config.maxTime:w.config.maxDate;(t=Math.min(t,l.getHours()))===l.getHours()&&(a=Math.min(a,l.getMinutes())),a===l.getMinutes()&&(i=Math.min(i,l.getSeconds()))}if(o){var c=void 0!==w.config.minTime?w.config.minTime:w.config.minDate;(t=Math.max(t,c.getHours()))===c.getHours()&&(a=Math.max(a,c.getMinutes())),a===c.getMinutes()&&(i=Math.max(i,c.getSeconds()))}O(t,a,i)}}function S(e){var n=e||w.latestSelectedDateObj;n&&O(n.getHours(),n.getMinutes(),n.getSeconds())}function _(){var e=w.config.defaultHour,n=w.config.defaultMinute,t=w.config.defaultSeconds;if(void 0!==w.config.minDate){var a=w.config.minDate.getHours(),i=w.config.minDate.getMinutes();(e=Math.max(e,a))===a&&(n=Math.max(i,n)),e===a&&n===i&&(t=w.config.minDate.getSeconds())}if(void 0!==w.config.maxDate){var o=w.config.maxDate.getHours(),r=w.config.maxDate.getMinutes();(e=Math.min(e,o))===o&&(n=Math.min(r,n)),e===o&&n===r&&(t=w.config.maxDate.getSeconds())}return{hours:e,minutes:n,seconds:t}}function O(e,n,t){void 0!==w.latestSelectedDateObj&&w.latestSelectedDateObj.setHours(e%24,n,t||0,0),w.hourElement&&w.minuteElement&&!w.isMobile&&(w.hourElement.value=o(w.config.time_24hr?e:(12+e)%12+12*r(e%12==0)),w.minuteElement.value=o(n),void 0!==w.amPM&&(w.amPM.textContent=w.l10n.amPM[r(e>=12)]),void 0!==w.secondElement&&(w.secondElement.value=o(t)))}function F(e){var n=g(e),t=parseInt(n.value)+(e.delta||0);(t/1e3>1||\"Enter\"===e.key&&!/[^\\d]/.test(t.toString()))&&Q(t)}function N(e,n,t,a){return n instanceof Array?n.forEach((function(n){return N(e,n,t,a)})):e instanceof Array?e.forEach((function(e){return N(e,n,t,a)})):(e.addEventListener(n,t,a),void w._handlers.push({element:e,event:n,handler:t,options:a}))}function A(){pe(\"onChange\")}function P(e,n){var t=void 0!==e?w.parseDate(e):w.latestSelectedDateObj||(w.config.minDate&&w.config.minDate>w.now?w.config.minDate:w.config.maxDate&&w.config.maxDate=0&&M(e,w.selectedDates[1])<=0}(n)&&!ve(n)&&o.classList.add(\"inRange\"),w.weekNumbers&&1===w.config.showMonths&&\"prevMonthDay\"!==e&&t%7==1&&w.weekNumbers.insertAdjacentHTML(\"beforeend\",\"\"+w.config.getWeek(n)+\"\"),pe(\"onDayCreate\",o),o}function L(e){e.focus(),\"range\"===w.config.mode&&ae(e)}function W(e){for(var n=e>0?0:w.config.showMonths-1,t=e>0?w.config.showMonths:-1,a=n;a!=t;a+=e)for(var i=w.daysContainer.children[a],o=e>0?0:i.children.length-1,r=e>0?i.children.length:-1,l=o;l!=r;l+=e){var c=i.children[l];if(-1===c.className.indexOf(\"hidden\")&&X(c.dateObj))return c}}function R(e,n){var t=ee(document.activeElement||document.body),a=void 0!==e?e:t?document.activeElement:void 0!==w.selectedDateElem&&ee(w.selectedDateElem)?w.selectedDateElem:void 0!==w.todayDateElem&&ee(w.todayDateElem)?w.todayDateElem:W(n>0?1:-1);void 0===a?w._input.focus():t?function(e,n){for(var t=-1===e.className.indexOf(\"Month\")?e.dateObj.getMonth():w.currentMonth,a=n>0?w.config.showMonths:-1,i=n>0?1:-1,o=t-w.currentMonth;o!=a;o+=i)for(var r=w.daysContainer.children[o],l=t-w.currentMonth===o?e.$i+n:n<0?r.children.length-1:0,c=r.children.length,d=l;d>=0&&d0?c:-1);d+=i){var s=r.children[d];if(-1===s.className.indexOf(\"hidden\")&&X(s.dateObj)&&Math.abs(e.$i-d)>=Math.abs(n))return L(s)}w.changeMonth(i),R(W(i),0)}(a,n):L(a)}function B(e,n){for(var t=(new Date(e,n,1).getDay()-w.l10n.firstDayOfWeek+7)%7,a=w.utils.getDaysInMonth((n-1+12)%12,e),i=w.utils.getDaysInMonth(n,e),o=window.document.createDocumentFragment(),r=w.config.showMonths>1,l=r?\"prevMonthDay hidden\":\"prevMonthDay\",c=r?\"nextMonthDay hidden\":\"nextMonthDay\",d=a+1-t,u=0;d<=a;d++,u++)o.appendChild(j(l,new Date(e,n-1,d),d,u));for(d=1;d<=i;d++,u++)o.appendChild(j(\"\",new Date(e,n,d),d,u));for(var f=i+1;f<=42-t&&(1===w.config.showMonths||u%7!=0);f++,u++)o.appendChild(j(c,new Date(e,n+1,f%i),f,u));var m=s(\"div\",\"dayContainer\");return m.appendChild(o),m}function J(){if(void 0!==w.daysContainer){u(w.daysContainer),w.weekNumbers&&u(w.weekNumbers);for(var e=document.createDocumentFragment(),n=0;n1||\"dropdown\"!==w.config.monthSelectorType)){var e=function(e){return!(void 0!==w.config.minDate&&w.currentYear===w.config.minDate.getFullYear()&&ew.config.maxDate.getMonth())};w.monthsDropdownContainer.tabIndex=-1,w.monthsDropdownContainer.innerHTML=\"\";for(var n=0;n<12;n++)if(e(n)){var t=s(\"option\",\"flatpickr-monthDropdown-month\");t.value=new Date(w.currentYear,n).getMonth().toString(),t.textContent=h(n,w.config.shorthandCurrentMonth,w.l10n),t.tabIndex=-1,w.currentMonth===n&&(t.selected=!0),w.monthsDropdownContainer.appendChild(t)}}}function U(){var e,n=s(\"div\",\"flatpickr-month\"),t=window.document.createDocumentFragment();w.config.showMonths>1||\"static\"===w.config.monthSelectorType?e=s(\"span\",\"cur-month\"):(w.monthsDropdownContainer=s(\"select\",\"flatpickr-monthDropdown-months\"),w.monthsDropdownContainer.setAttribute(\"aria-label\",w.l10n.monthAriaLabel),N(w.monthsDropdownContainer,\"change\",(function(e){var n=g(e),t=parseInt(n.value,10);w.changeMonth(t-w.currentMonth),pe(\"onMonthChange\")})),K(),e=w.monthsDropdownContainer);var a=m(\"cur-year\",{tabindex:\"-1\"}),i=a.getElementsByTagName(\"input\")[0];i.setAttribute(\"aria-label\",w.l10n.yearAriaLabel),w.config.minDate&&i.setAttribute(\"min\",w.config.minDate.getFullYear().toString()),w.config.maxDate&&(i.setAttribute(\"max\",w.config.maxDate.getFullYear().toString()),i.disabled=!!w.config.minDate&&w.config.minDate.getFullYear()===w.config.maxDate.getFullYear());var o=s(\"div\",\"flatpickr-current-month\");return o.appendChild(e),o.appendChild(a),t.appendChild(o),n.appendChild(t),{container:n,yearElement:i,monthElement:e}}function q(){u(w.monthNav),w.monthNav.appendChild(w.prevMonthNav),w.config.showMonths&&(w.yearElements=[],w.monthElements=[]);for(var e=w.config.showMonths;e--;){var n=U();w.yearElements.push(n.yearElement),w.monthElements.push(n.monthElement),w.monthNav.appendChild(n.container)}w.monthNav.appendChild(w.nextMonthNav)}function $(){w.weekdayContainer?u(w.weekdayContainer):w.weekdayContainer=s(\"div\",\"flatpickr-weekdays\");for(var e=w.config.showMonths;e--;){var n=s(\"div\",\"flatpickr-weekdaycontainer\");w.weekdayContainer.appendChild(n)}return z(),w.weekdayContainer}function z(){if(w.weekdayContainer){var e=w.l10n.firstDayOfWeek,t=n(w.l10n.weekdays.shorthand);e>0&&e\\n \"+t.join(\"\")+\"\\n \\n \"}}function G(e,n){void 0===n&&(n=!0);var t=n?e:e-w.currentMonth;t<0&&!0===w._hidePrevMonthArrow||t>0&&!0===w._hideNextMonthArrow||(w.currentMonth+=t,(w.currentMonth<0||w.currentMonth>11)&&(w.currentYear+=w.currentMonth>11?1:-1,w.currentMonth=(w.currentMonth+12)%12,pe(\"onYearChange\"),K()),J(),pe(\"onMonthChange\"),De())}function V(e){return!(!w.config.appendTo||!w.config.appendTo.contains(e))||w.calendarContainer.contains(e)}function Z(e){if(w.isOpen&&!w.config.inline){var n=g(e),t=V(n),a=n===w.input||n===w.altInput||w.element.contains(n)||e.path&&e.path.indexOf&&(~e.path.indexOf(w.input)||~e.path.indexOf(w.altInput)),i=\"blur\"===e.type?a&&e.relatedTarget&&!V(e.relatedTarget):!a&&!t&&!V(e.relatedTarget),o=!w.config.ignoredFocusElements.some((function(e){return e.contains(n)}));i&&o&&(void 0!==w.timeContainer&&void 0!==w.minuteElement&&void 0!==w.hourElement&&\"\"!==w.input.value&&void 0!==w.input.value&&T(),w.close(),w.config&&\"range\"===w.config.mode&&1===w.selectedDates.length&&(w.clear(!1),w.redraw()))}}function Q(e){if(!(!e||w.config.minDate&&ew.config.maxDate.getFullYear())){var n=e,t=w.currentYear!==n;w.currentYear=n||w.currentYear,w.config.maxDate&&w.currentYear===w.config.maxDate.getFullYear()?w.currentMonth=Math.min(w.config.maxDate.getMonth(),w.currentMonth):w.config.minDate&&w.currentYear===w.config.minDate.getFullYear()&&(w.currentMonth=Math.max(w.config.minDate.getMonth(),w.currentMonth)),t&&(w.redraw(),pe(\"onYearChange\"),K())}}function X(e,n){void 0===n&&(n=!0);var t=w.parseDate(e,void 0,n);if(w.config.minDate&&t&&M(t,w.config.minDate,void 0!==n?n:!w.minDateHasTime)<0||w.config.maxDate&&t&&M(t,w.config.maxDate,void 0!==n?n:!w.maxDateHasTime)>0)return!1;if(0===w.config.enable.length&&0===w.config.disable.length)return!0;if(void 0===t)return!1;for(var a=w.config.enable.length>0,i=a?w.config.enable:w.config.disable,o=0,r=void 0;o=r.from.getTime()&&t.getTime()<=r.to.getTime())return a}return!a}function ee(e){return void 0!==w.daysContainer&&-1===e.className.indexOf(\"hidden\")&&-1===e.className.indexOf(\"flatpickr-disabled\")&&w.daysContainer.contains(e)}function ne(e){e.target!==w._input||e.relatedTarget&&V(e.relatedTarget)||w.setDate(w._input.value,!0,e.target===w.altInput?w.config.altFormat:w.config.dateFormat)}function te(e){var n=g(e),t=w.config.wrap?p.contains(n):n===w._input,a=w.config.allowInput,i=w.isOpen&&(!a||!t),o=w.config.inline&&t&&!a;if(13===e.keyCode&&t){if(a)return w.setDate(w._input.value,!0,n===w.altInput?w.config.altFormat:w.config.dateFormat),n.blur();w.open()}else if(V(n)||i||o){var r=!!w.timeContainer&&w.timeContainer.contains(n);switch(e.keyCode){case 13:r?(e.preventDefault(),T(),se()):ue(e);break;case 27:e.preventDefault(),se();break;case 8:case 46:t&&!w.config.allowInput&&(e.preventDefault(),w.clear());break;case 37:case 39:if(r||t)w.hourElement&&w.hourElement.focus();else if(e.preventDefault(),void 0!==w.daysContainer&&(!1===a||document.activeElement&&ee(document.activeElement))){var l=39===e.keyCode?1:-1;e.ctrlKey?(e.stopPropagation(),G(l),R(W(1),0)):R(void 0,l)}break;case 38:case 40:e.preventDefault();var c=40===e.keyCode?1:-1;w.daysContainer&&void 0!==n.$i||n===w.input||n===w.altInput?e.ctrlKey?(e.stopPropagation(),Q(w.currentYear-c),R(W(1),0)):r||R(void 0,7*c):n===w.currentYearElement?Q(w.currentYear-c):w.config.enableTime&&(!r&&w.hourElement&&w.hourElement.focus(),T(e),w._debouncedChange());break;case 9:if(r){var d=[w.hourElement,w.minuteElement,w.secondElement,w.amPM].concat(w.pluginElements).filter((function(e){return e})),s=d.indexOf(n);if(-1!==s){var u=d[s+(e.shiftKey?-1:1)];e.preventDefault(),(u||w._input).focus()}}else!w.config.noCalendar&&w.daysContainer&&w.daysContainer.contains(n)&&e.shiftKey&&(e.preventDefault(),w._input.focus())}}if(void 0!==w.amPM&&n===w.amPM)switch(e.key){case w.l10n.amPM[0].charAt(0):case w.l10n.amPM[0].charAt(0).toLowerCase():w.amPM.textContent=w.l10n.amPM[0],I(),be();break;case w.l10n.amPM[1].charAt(0):case w.l10n.amPM[1].charAt(0).toLowerCase():w.amPM.textContent=w.l10n.amPM[1],I(),be()}(t||V(n))&&pe(\"onKeyDown\",e)}function ae(e){if(1===w.selectedDates.length&&(!e||e.classList.contains(\"flatpickr-day\")&&!e.classList.contains(\"flatpickr-disabled\"))){for(var n=e?e.dateObj.getTime():w.days.firstElementChild.dateObj.getTime(),t=w.parseDate(w.selectedDates[0],void 0,!0).getTime(),a=Math.min(n,w.selectedDates[0].getTime()),i=Math.max(n,w.selectedDates[0].getTime()),o=!1,r=0,l=0,c=a;ca&&cr)?r=c:c>t&&(!l||c0&&m0&&m>l;return g?(f.classList.add(\"notAllowed\"),[\"inRange\",\"startRange\",\"endRange\"].forEach((function(e){f.classList.remove(e)})),\"continue\"):o&&!g?\"continue\":([\"startRange\",\"inRange\",\"endRange\",\"notAllowed\"].forEach((function(e){f.classList.remove(e)})),void(void 0!==e&&(e.classList.add(n<=w.selectedDates[0].getTime()?\"startRange\":\"endRange\"),tn&&m===t&&f.classList.add(\"endRange\"),m>=r&&(0===l||m<=l)&&(d=t,u=n,(c=m)>Math.min(d,u)&&c0||t.getMinutes()>0||t.getSeconds()>0),w.selectedDates&&(w.selectedDates=w.selectedDates.filter((function(e){return X(e)})),w.selectedDates.length||\"min\"!==e||S(t),be()),w.daysContainer&&(de(),void 0!==t?w.currentYearElement[e]=t.getFullYear().toString():w.currentYearElement.removeAttribute(e),w.currentYearElement.disabled=!!a&&void 0!==t&&a.getFullYear()===t.getFullYear())}}function re(){return w.config.wrap?p.querySelector(\"[data-input]\"):p}function le(){\"object\"!=typeof w.config.locale&&void 0===k.l10ns[w.config.locale]&&w.config.errorHandler(new Error(\"flatpickr: invalid locale \"+w.config.locale)),w.l10n=e(e({},k.l10ns.default),\"object\"==typeof w.config.locale?w.config.locale:\"default\"!==w.config.locale?k.l10ns[w.config.locale]:void 0),D.K=\"(\"+w.l10n.amPM[0]+\"|\"+w.l10n.amPM[1]+\"|\"+w.l10n.amPM[0].toLowerCase()+\"|\"+w.l10n.amPM[1].toLowerCase()+\")\",void 0===e(e({},v),JSON.parse(JSON.stringify(p.dataset||{}))).time_24hr&&void 0===k.defaultConfig.time_24hr&&(w.config.time_24hr=w.l10n.time_24hr),w.formatDate=b(w),w.parseDate=C({config:w.config,l10n:w.l10n})}function ce(e){if(void 0!==w.calendarContainer){pe(\"onPreCalendarPosition\");var n=e||w._positionElement,t=Array.prototype.reduce.call(w.calendarContainer.children,(function(e,n){return e+n.offsetHeight}),0),a=w.calendarContainer.offsetWidth,i=w.config.position.split(\" \"),o=i[0],r=i.length>1?i[1]:null,l=n.getBoundingClientRect(),c=window.innerHeight-l.bottom,s=\"above\"===o||\"below\"!==o&&ct,u=window.pageYOffset+l.top+(s?-t-2:n.offsetHeight+2);if(d(w.calendarContainer,\"arrowTop\",!s),d(w.calendarContainer,\"arrowBottom\",s),!w.config.inline){var f=window.pageXOffset+l.left,m=!1,g=!1;\"center\"===r?(f-=(a-l.width)/2,m=!0):\"right\"===r&&(f-=a-l.width,g=!0),d(w.calendarContainer,\"arrowLeft\",!m&&!g),d(w.calendarContainer,\"arrowCenter\",m),d(w.calendarContainer,\"arrowRight\",g);var p=window.document.body.offsetWidth-(window.pageXOffset+l.right),h=f+a>window.document.body.offsetWidth,v=p+a>window.document.body.offsetWidth;if(d(w.calendarContainer,\"rightMost\",h),!w.config.static)if(w.calendarContainer.style.top=u+\"px\",h)if(v){var D=function(){for(var e=null,n=0;nw.currentMonth+w.config.showMonths-1)&&\"range\"!==w.config.mode;if(w.selectedDateElem=t,\"single\"===w.config.mode)w.selectedDates=[a];else if(\"multiple\"===w.config.mode){var o=ve(a);o?w.selectedDates.splice(parseInt(o),1):w.selectedDates.push(a)}else\"range\"===w.config.mode&&(2===w.selectedDates.length&&w.clear(!1,!1),w.latestSelectedDateObj=a,w.selectedDates.push(a),0!==M(a,w.selectedDates[0],!0)&&w.selectedDates.sort((function(e,n){return e.getTime()-n.getTime()})));if(I(),i){var r=w.currentYear!==a.getFullYear();w.currentYear=a.getFullYear(),w.currentMonth=a.getMonth(),r&&(pe(\"onYearChange\"),K()),pe(\"onMonthChange\")}if(De(),J(),be(),i||\"range\"===w.config.mode||1!==w.config.showMonths?void 0!==w.selectedDateElem&&void 0===w.hourElement&&w.selectedDateElem&&w.selectedDateElem.focus():L(t),void 0!==w.hourElement&&void 0!==w.hourElement&&w.hourElement.focus(),w.config.closeOnSelect){var l=\"single\"===w.config.mode&&!w.config.enableTime,c=\"range\"===w.config.mode&&2===w.selectedDates.length&&!w.config.enableTime;(l||c)&&se()}A()}}w.parseDate=C({config:w.config,l10n:w.l10n}),w._handlers=[],w.pluginElements=[],w.loadedPlugins=[],w._bind=N,w._setHoursFromDate=S,w._positionCalendar=ce,w.changeMonth=G,w.changeYear=Q,w.clear=function(e,n){if(void 0===e&&(e=!0),void 0===n&&(n=!0),w.input.value=\"\",void 0!==w.altInput&&(w.altInput.value=\"\"),void 0!==w.mobileInput&&(w.mobileInput.value=\"\"),w.selectedDates=[],w.latestSelectedDateObj=void 0,!0===n&&(w.currentYear=w._initialDate.getFullYear(),w.currentMonth=w._initialDate.getMonth()),!0===w.config.enableTime){var t=_(),a=t.hours,i=t.minutes,o=t.seconds;O(a,i,o)}w.redraw(),e&&pe(\"onChange\")},w.close=function(){w.isOpen=!1,w.isMobile||(void 0!==w.calendarContainer&&w.calendarContainer.classList.remove(\"open\"),void 0!==w._input&&w._input.classList.remove(\"active\")),pe(\"onClose\")},w._createElement=s,w.destroy=function(){void 0!==w.config&&pe(\"onDestroy\");for(var e=w._handlers.length;e--;){var n=w._handlers[e];n.element.removeEventListener(n.event,n.handler,n.options)}if(w._handlers=[],w.mobileInput)w.mobileInput.parentNode&&w.mobileInput.parentNode.removeChild(w.mobileInput),w.mobileInput=void 0;else if(w.calendarContainer&&w.calendarContainer.parentNode)if(w.config.static&&w.calendarContainer.parentNode){var t=w.calendarContainer.parentNode;if(t.lastChild&&t.removeChild(t.lastChild),t.parentNode){for(;t.firstChild;)t.parentNode.insertBefore(t.firstChild,t);t.parentNode.removeChild(t)}}else w.calendarContainer.parentNode.removeChild(w.calendarContainer);w.altInput&&(w.input.type=\"text\",w.altInput.parentNode&&w.altInput.parentNode.removeChild(w.altInput),delete w.altInput),w.input&&(w.input.type=w.input._type,w.input.classList.remove(\"flatpickr-input\"),w.input.removeAttribute(\"readonly\")),[\"_showTimeInput\",\"latestSelectedDateObj\",\"_hideNextMonthArrow\",\"_hidePrevMonthArrow\",\"__hideNextMonthArrow\",\"__hidePrevMonthArrow\",\"isMobile\",\"isOpen\",\"selectedDateElem\",\"minDateHasTime\",\"maxDateHasTime\",\"days\",\"daysContainer\",\"_input\",\"_positionElement\",\"innerContainer\",\"rContainer\",\"monthNav\",\"todayDateElem\",\"calendarContainer\",\"weekdayContainer\",\"prevMonthNav\",\"nextMonthNav\",\"monthsDropdownContainer\",\"currentMonthElement\",\"currentYearElement\",\"navigationCurrentMonth\",\"selectedDateElem\",\"config\"].forEach((function(e){try{delete w[e]}catch(e){}}))},w.isEnabled=X,w.jumpToDate=P,w.open=function(e,n){if(void 0===n&&(n=w._positionElement),!0===w.isMobile){if(e){e.preventDefault();var t=g(e);t&&t.blur()}return void 0!==w.mobileInput&&(w.mobileInput.focus(),w.mobileInput.click()),void pe(\"onOpen\")}if(!w._input.disabled&&!w.config.inline){var a=w.isOpen;w.isOpen=!0,a||(w.calendarContainer.classList.add(\"open\"),w._input.classList.add(\"active\"),pe(\"onOpen\"),ce(n)),!0===w.config.enableTime&&!0===w.config.noCalendar&&(!1!==w.config.allowInput||void 0!==e&&w.timeContainer.contains(e.relatedTarget)||setTimeout((function(){return w.hourElement.select()}),50))}},w.redraw=de,w.set=function(e,n){if(null!==e&&\"object\"==typeof e)for(var a in Object.assign(w.config,e),e)void 0!==fe[a]&&fe[a].forEach((function(e){return e()}));else w.config[e]=n,void 0!==fe[e]?fe[e].forEach((function(e){return e()})):t.indexOf(e)>-1&&(w.config[e]=c(n));w.redraw(),be(!0)},w.setDate=function(e,n,t){if(void 0===n&&(n=!1),void 0===t&&(t=w.config.dateFormat),0!==e&&!e||e instanceof Array&&0===e.length)return w.clear(n);me(e,t),w.latestSelectedDateObj=w.selectedDates[w.selectedDates.length-1],w.redraw(),P(void 0,n),S(),0===w.selectedDates.length&&w.clear(!1),be(n),n&&pe(\"onChange\")},w.toggle=function(e){if(!0===w.isOpen)return w.close();w.open(e)};var fe={locale:[le,z],showMonths:[q,E,$],minDate:[P],maxDate:[P]};function me(e,n){var t=[];if(e instanceof Array)t=e.map((function(e){return w.parseDate(e,n)}));else if(e instanceof Date||\"number\"==typeof e)t=[w.parseDate(e,n)];else if(\"string\"==typeof e)switch(w.config.mode){case\"single\":case\"time\":t=[w.parseDate(e,n)];break;case\"multiple\":t=e.split(w.config.conjunction).map((function(e){return w.parseDate(e,n)}));break;case\"range\":t=e.split(w.l10n.rangeSeparator).map((function(e){return w.parseDate(e,n)}))}else w.config.errorHandler(new Error(\"Invalid date supplied: \"+JSON.stringify(e)));w.selectedDates=w.config.allowInvalidPreload?t:t.filter((function(e){return e instanceof Date&&X(e,!1)})),\"range\"===w.config.mode&&w.selectedDates.sort((function(e,n){return e.getTime()-n.getTime()}))}function ge(e){return e.slice().map((function(e){return\"string\"==typeof e||\"number\"==typeof e||e instanceof Date?w.parseDate(e,void 0,!0):e&&\"object\"==typeof e&&e.from&&e.to?{from:w.parseDate(e.from,void 0),to:w.parseDate(e.to,void 0)}:e})).filter((function(e){return e}))}function pe(e,n){if(void 0!==w.config){var t=w.config[e];if(void 0!==t&&t.length>0)for(var a=0;t[a]&&a1||\"static\"===w.config.monthSelectorType?w.monthElements[n].textContent=h(t.getMonth(),w.config.shorthandCurrentMonth,w.l10n)+\" \":w.monthsDropdownContainer.value=t.getMonth().toString(),e.value=t.getFullYear().toString()})),w._hidePrevMonthArrow=void 0!==w.config.minDate&&(w.currentYear===w.config.minDate.getFullYear()?w.currentMonth<=w.config.minDate.getMonth():w.currentYearw.config.maxDate.getMonth():w.currentYear>w.config.maxDate.getFullYear()))}function we(e){return w.selectedDates.map((function(n){return w.formatDate(n,e)})).filter((function(e,n,t){return\"range\"!==w.config.mode||w.config.enableTime||t.indexOf(e)===n})).join(\"range\"!==w.config.mode?w.config.conjunction:w.l10n.rangeSeparator)}function be(e){void 0===e&&(e=!0),void 0!==w.mobileInput&&w.mobileFormatStr&&(w.mobileInput.value=void 0!==w.latestSelectedDateObj?w.formatDate(w.latestSelectedDateObj,w.mobileFormatStr):\"\"),w.input.value=we(w.config.dateFormat),void 0!==w.altInput&&(w.altInput.value=we(w.config.altFormat)),!1!==e&&pe(\"onValueUpdate\")}function Ce(e){var n=g(e),t=w.prevMonthNav.contains(n),a=w.nextMonthNav.contains(n);t||a?G(t?-1:1):w.yearElements.indexOf(n)>=0?n.select():n.classList.contains(\"arrowUp\")?w.changeYear(w.currentYear+1):n.classList.contains(\"arrowDown\")&&w.changeYear(w.currentYear-1)}return function(){w.element=w.input=p,w.isOpen=!1,function(){var n=[\"wrap\",\"weekNumbers\",\"allowInput\",\"allowInvalidPreload\",\"clickOpens\",\"time_24hr\",\"enableTime\",\"noCalendar\",\"altInput\",\"shorthandCurrentMonth\",\"inline\",\"static\",\"enableSeconds\",\"disableMobile\"],i=e(e({},JSON.parse(JSON.stringify(p.dataset||{}))),v),o={};w.config.parseDate=i.parseDate,w.config.formatDate=i.formatDate,Object.defineProperty(w.config,\"enable\",{get:function(){return w.config._enable},set:function(e){w.config._enable=ge(e)}}),Object.defineProperty(w.config,\"disable\",{get:function(){return w.config._disable},set:function(e){w.config._disable=ge(e)}});var r=\"time\"===i.mode;if(!i.dateFormat&&(i.enableTime||r)){var l=k.defaultConfig.dateFormat||a.dateFormat;o.dateFormat=i.noCalendar||r?\"H:i\"+(i.enableSeconds?\":S\":\"\"):l+\" H:i\"+(i.enableSeconds?\":S\":\"\")}if(i.altInput&&(i.enableTime||r)&&!i.altFormat){var d=k.defaultConfig.altFormat||a.altFormat;o.altFormat=i.noCalendar||r?\"h:i\"+(i.enableSeconds?\":S K\":\" K\"):d+\" h:i\"+(i.enableSeconds?\":S\":\"\")+\" K\"}Object.defineProperty(w.config,\"minDate\",{get:function(){return w.config._minDate},set:oe(\"min\")}),Object.defineProperty(w.config,\"maxDate\",{get:function(){return w.config._maxDate},set:oe(\"max\")});var s=function(e){return function(n){w.config[\"min\"===e?\"_minTime\":\"_maxTime\"]=w.parseDate(n,\"H:i:S\")}};Object.defineProperty(w.config,\"minTime\",{get:function(){return w.config._minTime},set:s(\"min\")}),Object.defineProperty(w.config,\"maxTime\",{get:function(){return w.config._maxTime},set:s(\"max\")}),\"time\"===i.mode&&(w.config.noCalendar=!0,w.config.enableTime=!0),Object.assign(w.config,o,i);for(var u=0;u-1?w.config[m]=c(f[m]).map(x).concat(w.config[m]):void 0===i[m]&&(w.config[m]=f[m])}i.altInputClass||(w.config.altInputClass=re().className+\" \"+w.config.altInputClass),pe(\"onParseConfig\")}(),le(),w.input=re(),w.input?(w.input._type=w.input.type,w.input.type=\"text\",w.input.classList.add(\"flatpickr-input\"),w._input=w.input,w.config.altInput&&(w.altInput=s(w.input.nodeName,w.config.altInputClass),w._input=w.altInput,w.altInput.placeholder=w.input.placeholder,w.altInput.disabled=w.input.disabled,w.altInput.required=w.input.required,w.altInput.tabIndex=w.input.tabIndex,w.altInput.type=\"text\",w.input.setAttribute(\"type\",\"hidden\"),!w.config.static&&w.input.parentNode&&w.input.parentNode.insertBefore(w.altInput,w.input.nextSibling)),w.config.allowInput||w._input.setAttribute(\"readonly\",\"readonly\"),w._positionElement=w.config.positionElement||w._input):w.config.errorHandler(new Error(\"Invalid input element specified\")),function(){w.selectedDates=[],w.now=w.parseDate(w.config.now)||new Date;var e=w.config.defaultDate||(\"INPUT\"!==w.input.nodeName&&\"TEXTAREA\"!==w.input.nodeName||!w.input.placeholder||w.input.value!==w.input.placeholder?w.input.value:null);e&&me(e,w.config.dateFormat),w._initialDate=w.selectedDates.length>0?w.selectedDates[0]:w.config.minDate&&w.config.minDate.getTime()>w.now.getTime()?w.config.minDate:w.config.maxDate&&w.config.maxDate.getTime()0&&(w.latestSelectedDateObj=w.selectedDates[0]),void 0!==w.config.minTime&&(w.config.minTime=w.parseDate(w.config.minTime,\"H:i\")),void 0!==w.config.maxTime&&(w.config.maxTime=w.parseDate(w.config.maxTime,\"H:i\")),w.minDateHasTime=!!w.config.minDate&&(w.config.minDate.getHours()>0||w.config.minDate.getMinutes()>0||w.config.minDate.getSeconds()>0),w.maxDateHasTime=!!w.config.maxDate&&(w.config.maxDate.getHours()>0||w.config.maxDate.getMinutes()>0||w.config.maxDate.getSeconds()>0)}(),w.utils={getDaysInMonth:function(e,n){return void 0===e&&(e=w.currentMonth),void 0===n&&(n=w.currentYear),1===e&&(n%4==0&&n%100!=0||n%400==0)?29:w.l10n.daysInMonth[e]}},w.isMobile||function(){var e=window.document.createDocumentFragment();if(w.calendarContainer=s(\"div\",\"flatpickr-calendar\"),w.calendarContainer.tabIndex=-1,!w.config.noCalendar){if(e.appendChild((w.monthNav=s(\"div\",\"flatpickr-months\"),w.yearElements=[],w.monthElements=[],w.prevMonthNav=s(\"span\",\"flatpickr-prev-month\"),w.prevMonthNav.innerHTML=w.config.prevArrow,w.nextMonthNav=s(\"span\",\"flatpickr-next-month\"),w.nextMonthNav.innerHTML=w.config.nextArrow,q(),Object.defineProperty(w,\"_hidePrevMonthArrow\",{get:function(){return w.__hidePrevMonthArrow},set:function(e){w.__hidePrevMonthArrow!==e&&(d(w.prevMonthNav,\"flatpickr-disabled\",e),w.__hidePrevMonthArrow=e)}}),Object.defineProperty(w,\"_hideNextMonthArrow\",{get:function(){return w.__hideNextMonthArrow},set:function(e){w.__hideNextMonthArrow!==e&&(d(w.nextMonthNav,\"flatpickr-disabled\",e),w.__hideNextMonthArrow=e)}}),w.currentYearElement=w.yearElements[0],De(),w.monthNav)),w.innerContainer=s(\"div\",\"flatpickr-innerContainer\"),w.config.weekNumbers){var n=function(){w.calendarContainer.classList.add(\"hasWeeks\");var e=s(\"div\",\"flatpickr-weekwrapper\");e.appendChild(s(\"span\",\"flatpickr-weekday\",w.l10n.weekAbbreviation));var n=s(\"div\",\"flatpickr-weeks\");return e.appendChild(n),{weekWrapper:e,weekNumbers:n}}(),t=n.weekWrapper,a=n.weekNumbers;w.innerContainer.appendChild(t),w.weekNumbers=a,w.weekWrapper=t}w.rContainer=s(\"div\",\"flatpickr-rContainer\"),w.rContainer.appendChild($()),w.daysContainer||(w.daysContainer=s(\"div\",\"flatpickr-days\"),w.daysContainer.tabIndex=-1),J(),w.rContainer.appendChild(w.daysContainer),w.innerContainer.appendChild(w.rContainer),e.appendChild(w.innerContainer)}w.config.enableTime&&e.appendChild(function(){w.calendarContainer.classList.add(\"hasTime\"),w.config.noCalendar&&w.calendarContainer.classList.add(\"noCalendar\"),w.timeContainer=s(\"div\",\"flatpickr-time\"),w.timeContainer.tabIndex=-1;var e=s(\"span\",\"flatpickr-time-separator\",\":\"),n=m(\"flatpickr-hour\",{\"aria-label\":w.l10n.hourAriaLabel});w.hourElement=n.getElementsByTagName(\"input\")[0];var t=m(\"flatpickr-minute\",{\"aria-label\":w.l10n.minuteAriaLabel});if(w.minuteElement=t.getElementsByTagName(\"input\")[0],w.hourElement.tabIndex=w.minuteElement.tabIndex=-1,w.hourElement.value=o(w.latestSelectedDateObj?w.latestSelectedDateObj.getHours():w.config.time_24hr?w.config.defaultHour:function(e){switch(e%24){case 0:case 12:return 12;default:return e%12}}(w.config.defaultHour)),w.minuteElement.value=o(w.latestSelectedDateObj?w.latestSelectedDateObj.getMinutes():w.config.defaultMinute),w.hourElement.setAttribute(\"step\",w.config.hourIncrement.toString()),w.minuteElement.setAttribute(\"step\",w.config.minuteIncrement.toString()),w.hourElement.setAttribute(\"min\",w.config.time_24hr?\"0\":\"1\"),w.hourElement.setAttribute(\"max\",w.config.time_24hr?\"23\":\"12\"),w.minuteElement.setAttribute(\"min\",\"0\"),w.minuteElement.setAttribute(\"max\",\"59\"),w.timeContainer.appendChild(n),w.timeContainer.appendChild(e),w.timeContainer.appendChild(t),w.config.time_24hr&&w.timeContainer.classList.add(\"time24hr\"),w.config.enableSeconds){w.timeContainer.classList.add(\"hasSeconds\");var a=m(\"flatpickr-second\");w.secondElement=a.getElementsByTagName(\"input\")[0],w.secondElement.value=o(w.latestSelectedDateObj?w.latestSelectedDateObj.getSeconds():w.config.defaultSeconds),w.secondElement.setAttribute(\"step\",w.minuteElement.getAttribute(\"step\")),w.secondElement.setAttribute(\"min\",\"0\"),w.secondElement.setAttribute(\"max\",\"59\"),w.timeContainer.appendChild(s(\"span\",\"flatpickr-time-separator\",\":\")),w.timeContainer.appendChild(a)}return w.config.time_24hr||(w.amPM=s(\"span\",\"flatpickr-am-pm\",w.l10n.amPM[r((w.latestSelectedDateObj?w.hourElement.value:w.config.defaultHour)>11)]),w.amPM.title=w.l10n.toggleTitle,w.amPM.tabIndex=-1,w.timeContainer.appendChild(w.amPM)),w.timeContainer}()),d(w.calendarContainer,\"rangeMode\",\"range\"===w.config.mode),d(w.calendarContainer,\"animate\",!0===w.config.animate),d(w.calendarContainer,\"multiMonth\",w.config.showMonths>1),w.calendarContainer.appendChild(e);var i=void 0!==w.config.appendTo&&void 0!==w.config.appendTo.nodeType;if((w.config.inline||w.config.static)&&(w.calendarContainer.classList.add(w.config.inline?\"inline\":\"static\"),w.config.inline&&(!i&&w.element.parentNode?w.element.parentNode.insertBefore(w.calendarContainer,w._input.nextSibling):void 0!==w.config.appendTo&&w.config.appendTo.appendChild(w.calendarContainer)),w.config.static)){var l=s(\"div\",\"flatpickr-wrapper\");w.element.parentNode&&w.element.parentNode.insertBefore(l,w.element),l.appendChild(w.element),w.altInput&&l.appendChild(w.altInput),l.appendChild(w.calendarContainer)}w.config.static||w.config.inline||(void 0!==w.config.appendTo?w.config.appendTo:window.document.body).appendChild(w.calendarContainer)}(),function(){if(w.config.wrap&&[\"open\",\"close\",\"toggle\",\"clear\"].forEach((function(e){Array.prototype.forEach.call(w.element.querySelectorAll(\"[data-\"+e+\"]\"),(function(n){return N(n,\"click\",w[e])}))})),w.isMobile)!function(){var e=w.config.enableTime?w.config.noCalendar?\"time\":\"datetime-local\":\"date\";w.mobileInput=s(\"input\",w.input.className+\" flatpickr-mobile\"),w.mobileInput.tabIndex=1,w.mobileInput.type=e,w.mobileInput.disabled=w.input.disabled,w.mobileInput.required=w.input.required,w.mobileInput.placeholder=w.input.placeholder,w.mobileFormatStr=\"datetime-local\"===e?\"Y-m-d\\\\TH:i:S\":\"date\"===e?\"Y-m-d\":\"H:i:S\",w.selectedDates.length>0&&(w.mobileInput.defaultValue=w.mobileInput.value=w.formatDate(w.selectedDates[0],w.mobileFormatStr)),w.config.minDate&&(w.mobileInput.min=w.formatDate(w.config.minDate,\"Y-m-d\")),w.config.maxDate&&(w.mobileInput.max=w.formatDate(w.config.maxDate,\"Y-m-d\")),w.input.getAttribute(\"step\")&&(w.mobileInput.step=String(w.input.getAttribute(\"step\"))),w.input.type=\"hidden\",void 0!==w.altInput&&(w.altInput.type=\"hidden\");try{w.input.parentNode&&w.input.parentNode.insertBefore(w.mobileInput,w.input.nextSibling)}catch(e){}N(w.mobileInput,\"change\",(function(e){w.setDate(g(e).value,!1,w.mobileFormatStr),pe(\"onChange\"),pe(\"onClose\")}))}();else{var e=l(ie,50);if(w._debouncedChange=l(A,300),w.daysContainer&&!/iPhone|iPad|iPod/i.test(navigator.userAgent)&&N(w.daysContainer,\"mouseover\",(function(e){\"range\"===w.config.mode&&ae(g(e))})),N(window.document.body,\"keydown\",te),w.config.inline||w.config.static||N(window,\"resize\",e),void 0!==window.ontouchstart?N(window.document,\"touchstart\",Z):N(window.document,\"click\",Z),N(window.document,\"focus\",Z,{capture:!0}),!0===w.config.clickOpens&&(N(w._input,\"focus\",w.open),N(w._input,\"click\",w.open)),void 0!==w.daysContainer&&(N(w.monthNav,\"click\",Ce),N(w.monthNav,[\"keyup\",\"increment\"],F),N(w.daysContainer,\"click\",ue)),void 0!==w.timeContainer&&void 0!==w.minuteElement&&void 0!==w.hourElement){var n=function(e){return g(e).select()};N(w.timeContainer,[\"increment\"],T),N(w.timeContainer,\"blur\",T,{capture:!0}),N(w.timeContainer,\"click\",Y),N([w.hourElement,w.minuteElement],[\"focus\",\"click\"],n),void 0!==w.secondElement&&N(w.secondElement,\"focus\",(function(){return w.secondElement&&w.secondElement.select()})),void 0!==w.amPM&&N(w.amPM,\"click\",(function(e){T(e),A()}))}w.config.allowInput&&N(w._input,\"blur\",ne)}}(),(w.selectedDates.length||w.config.noCalendar)&&(w.config.enableTime&&S(w.config.noCalendar?w.latestSelectedDateObj||w.config.minDate:void 0),be(!1)),E();var n=/^((?!chrome|android).)*safari/i.test(navigator.userAgent);!w.isMobile&&n&&ce(),pe(\"onReady\")}(),w}function E(e,n){for(var t=Array.prototype.slice.call(e).filter((function(e){return e instanceof HTMLElement})),a=[],i=0;ithis.render()));const{start:s,end:l,value:o,step:r,title:n}=this.model.properties;this.on_change([s,l,o,r],(()=>{const{start:t,end:e,value:i,step:s}=this._calc_to();this._noUiSlider.updateOptions({range:{min:t,max:e},start:i,step:s},!0)}));const{bar_color:a}=this.model.properties;this.on_change(a,(()=>{this._set_bar_color()}));const{show_value:d}=this.model.properties;this.on_change([o,n,d],(()=>this._update_title()))}styles(){return[...super.styles(),p.default,u.default]}_update_title(){var t;(0,a.empty)(this.title_el);const e=null==this.model.title||0==this.model.title.length&&!this.model.show_value;if(this.title_el.style.display=e?\"none\":\"\",!e&&(0!=(null===(t=this.model.title)||void 0===t?void 0:t.length)&&(this.title_el.textContent=`${this.model.title}: `),this.model.show_value)){const{value:t}=this._calc_to(),e=t.map((t=>this.model.pretty(t))).join(\" .. \");this.title_el.appendChild((0,a.span)({class:m.slider_value},e))}}_set_bar_color(){if(!this.model.disabled){this.slider_el.querySelector(\".noUi-connect\").style.backgroundColor=(0,_.color2css)(this.model.bar_color)}}render(){super.render();const{start:t,end:e,value:i,step:s}=this._calc_to();let l;if(this.model.tooltips){const t={to:t=>this.model.pretty(t)};l=(0,d.repeat)(t,i.length)}else l=!1;if(null==this.slider_el){this.slider_el=(0,a.div)(),this._noUiSlider=n.default.create(this.slider_el,{range:{min:t,max:e},start:i,step:s,behaviour:this.model.behaviour,connect:this.model.connected,tooltips:l,orientation:this.model.orientation,direction:this.model.direction}),this._noUiSlider.on(\"slide\",((t,e,i)=>this._slide(i))),this._noUiSlider.on(\"change\",((t,e,i)=>this._change(i)));const o=(t,e)=>{if(!l)return;this.slider_el.querySelectorAll(\".noUi-handle\")[t].querySelector(\".noUi-tooltip\").style.display=e?\"block\":\"\"};this._noUiSlider.on(\"start\",((t,e)=>o(e,!0))),this._noUiSlider.on(\"end\",((t,e)=>o(e,!1)))}else this._noUiSlider.updateOptions({range:{min:t,max:e},start:i,step:s},!0);this._set_bar_color(),this.model.disabled?this.slider_el.setAttribute(\"disabled\",\"true\"):this.slider_el.removeAttribute(\"disabled\"),this.title_el=(0,a.div)({class:m.slider_title}),this._update_title(),this.group_el=(0,a.div)({class:v.input_group},this.title_el,this.slider_el),this.el.appendChild(this.group_el)}_slide(t){this.model.value=this._calc_from(t)}_change(t){const e=this._calc_from(t);this.model.setv({value:e,value_throttled:e})}}b.__name__=\"AbstractBaseSliderView\";class g extends b{_calc_to(){return{start:this.model.start,end:this.model.end,value:[this.model.value],step:this.model.step}}_calc_from([t]){return Number.isInteger(this.model.start)&&Number.isInteger(this.model.end)&&Number.isInteger(this.model.step)?Math.round(t):t}}i.AbstractSliderView=g,g.__name__=\"AbstractSliderView\";class f extends b{_calc_to(){return{start:this.model.start,end:this.model.end,value:this.model.value,step:this.model.step}}_calc_from(t){return t}}i.AbstractRangeSliderView=f,f.__name__=\"AbstractRangeSliderView\";class S extends h.OrientedControl{constructor(t){super(t),this.connected=!1}pretty(t){return this._formatter(t,this.format)}}i.AbstractSlider=S,r=S,S.__name__=\"AbstractSlider\",r.define((({Any:t,Boolean:e,Number:i,String:s,Color:l,Or:o,Enum:r,Ref:n,Nullable:a})=>({title:[a(s),\"\"],show_value:[e,!0],start:[t],end:[t],value:[t],value_throttled:[t],step:[i,1],format:[o(s,n(c.TickFormatter))],direction:[r(\"ltr\",\"rtl\"),\"ltr\"],tooltips:[e,!0],bar_color:[l,\"#e6e6e6\"]})))},\n", " 459: function _(t,e,r,n,i){var o,s;o=this,s=function(t){\"use strict\";var e,r;function n(t){return\"object\"==typeof t&&\"function\"==typeof t.to}function i(t){t.parentElement.removeChild(t)}function o(t){return null!=t}function s(t){t.preventDefault()}function a(t){return\"number\"==typeof t&&!isNaN(t)&&isFinite(t)}function l(t,e,r){r>0&&(f(t,e),setTimeout((function(){d(t,e)}),r))}function u(t){return Math.max(Math.min(t,100),0)}function c(t){return Array.isArray(t)?t:[t]}function p(t){var e=(t=String(t)).split(\".\");return e.length>1?e[1].length:0}function f(t,e){t.classList&&!/\\s/.test(e)?t.classList.add(e):t.className+=\" \"+e}function d(t,e){t.classList&&!/\\s/.test(e)?t.classList.remove(e):t.className=t.className.replace(new RegExp(\"(^|\\\\b)\"+e.split(\" \").join(\"|\")+\"(\\\\b|$)\",\"gi\"),\" \")}function h(t){var e=void 0!==window.pageXOffset,r=\"CSS1Compat\"===(t.compatMode||\"\");return{x:e?window.pageXOffset:r?t.documentElement.scrollLeft:t.body.scrollLeft,y:e?window.pageYOffset:r?t.documentElement.scrollTop:t.body.scrollTop}}function m(t,e){return 100/(e-t)}function g(t,e,r){return 100*e/(t[r+1]-t[r])}function v(t,e){for(var r=1;t>=e[r];)r+=1;return r}function b(t,e,r){if(r>=t.slice(-1)[0])return 100;var n=v(r,t),i=t[n-1],o=t[n],s=e[n-1],a=e[n];return s+function(t,e){return g(t,t[0]<0?e+Math.abs(t[0]):e-t[0],0)}([i,o],r)/m(s,a)}function S(t,e,r,n){if(100===n)return n;var i=v(n,t),o=t[i-1],s=t[i];return r?n-o>(s-o)/2?s:o:e[i-1]?t[i-1]+function(t,e){return Math.round(t/e)*e}(n-t[i-1],e[i-1]):n}t.PipsMode=void 0,(e=t.PipsMode||(t.PipsMode={})).Range=\"range\",e.Steps=\"steps\",e.Positions=\"positions\",e.Count=\"count\",e.Values=\"values\",t.PipsType=void 0,(r=t.PipsType||(t.PipsType={}))[r.None=-1]=\"None\",r[r.NoValue=0]=\"NoValue\",r[r.LargeValue=1]=\"LargeValue\",r[r.SmallValue=2]=\"SmallValue\";var x=function(){function t(t,e,r){var n;this.xPct=[],this.xVal=[],this.xSteps=[],this.xNumSteps=[],this.xHighestCompleteStep=[],this.xSteps=[r||!1],this.xNumSteps=[!1],this.snap=e;var i=[];for(Object.keys(t).forEach((function(e){i.push([c(t[e]),e])})),i.sort((function(t,e){return t[0][0]-e[0][0]})),n=0;nthis.xPct[i+1];)i++;else t===this.xPct[this.xPct.length-1]&&(i=this.xPct.length-2);r||t!==this.xPct[i+1]||i++,null===e&&(e=[]);var o=1,s=e[i],a=0,l=0,u=0,c=0;for(n=r?(t-this.xPct[i])/(this.xPct[i+1]-this.xPct[i]):(this.xPct[i+1]-t)/(this.xPct[i+1]-this.xPct[i]);s>0;)a=this.xPct[i+1+c]-this.xPct[i+c],e[i+c]*o+100-100*n>100?(l=a*n,o=(s-100*n)/e[i+c],n=1):(l=e[i+c]*a/100*o,o=0),r?(u-=l,this.xPct.length+c>=1&&c--):(u+=l,this.xPct.length-c>=1&&c++),s=e[i+c]*o;return t+u},t.prototype.toStepping=function(t){return t=b(this.xVal,this.xPct,t)},t.prototype.fromStepping=function(t){return function(t,e,r){if(r>=100)return t.slice(-1)[0];var n=v(r,e),i=t[n-1],o=t[n],s=e[n-1];return function(t,e){return e*(t[1]-t[0])/100+t[0]}([i,o],(r-s)*m(s,e[n]))}(this.xVal,this.xPct,t)},t.prototype.getStep=function(t){return t=S(this.xPct,this.xSteps,this.snap,t)},t.prototype.getDefaultStep=function(t,e,r){var n=v(t,this.xPct);return(100===t||e&&t===this.xPct[n-1])&&(n=Math.max(n-1,1)),(this.xVal[n]-this.xVal[n-1])/r},t.prototype.getNearbySteps=function(t){var e=v(t,this.xPct);return{stepBefore:{startValue:this.xVal[e-2],step:this.xNumSteps[e-2],highestStep:this.xHighestCompleteStep[e-2]},thisStep:{startValue:this.xVal[e-1],step:this.xNumSteps[e-1],highestStep:this.xHighestCompleteStep[e-1]},stepAfter:{startValue:this.xVal[e],step:this.xNumSteps[e],highestStep:this.xHighestCompleteStep[e]}}},t.prototype.countStepDecimals=function(){var t=this.xNumSteps.map(p);return Math.max.apply(null,t)},t.prototype.hasNoSize=function(){return this.xVal[0]===this.xVal[this.xVal.length-1]},t.prototype.convert=function(t){return this.getStep(this.toStepping(t))},t.prototype.handleEntryPoint=function(t,e){var r;if(!a(r=\"min\"===t?0:\"max\"===t?100:parseFloat(t))||!a(e[0]))throw new Error(\"noUiSlider: 'range' value isn't numeric.\");this.xPct.push(r),this.xVal.push(e[0]);var n=Number(e[1]);r?this.xSteps.push(!isNaN(n)&&n):isNaN(n)||(this.xSteps[0]=n),this.xHighestCompleteStep.push(0)},t.prototype.handleStepPoint=function(t,e){if(e)if(this.xVal[t]!==this.xVal[t+1]){this.xSteps[t]=g([this.xVal[t],this.xVal[t+1]],e,0)/m(this.xPct[t],this.xPct[t+1]);var r=(this.xVal[t+1]-this.xVal[t])/this.xNumSteps[t],n=Math.ceil(Number(r.toFixed(3))-1),i=this.xVal[t]+this.xNumSteps[t]*n;this.xHighestCompleteStep[t]=i}else this.xSteps[t]=this.xHighestCompleteStep[t]=this.xVal[t]},t}(),y={to:function(t){return void 0===t?\"\":t.toFixed(2)},from:Number},w={target:\"target\",base:\"base\",origin:\"origin\",handle:\"handle\",handleLower:\"handle-lower\",handleUpper:\"handle-upper\",touchArea:\"touch-area\",horizontal:\"horizontal\",vertical:\"vertical\",background:\"background\",connect:\"connect\",connects:\"connects\",ltr:\"ltr\",rtl:\"rtl\",textDirectionLtr:\"txt-dir-ltr\",textDirectionRtl:\"txt-dir-rtl\",draggable:\"draggable\",drag:\"state-drag\",tap:\"state-tap\",active:\"active\",tooltip:\"tooltip\",pips:\"pips\",pipsHorizontal:\"pips-horizontal\",pipsVertical:\"pips-vertical\",marker:\"marker\",markerHorizontal:\"marker-horizontal\",markerVertical:\"marker-vertical\",markerNormal:\"marker-normal\",markerLarge:\"marker-large\",markerSub:\"marker-sub\",value:\"value\",valueHorizontal:\"value-horizontal\",valueVertical:\"value-vertical\",valueNormal:\"value-normal\",valueLarge:\"value-large\",valueSub:\"value-sub\"},E=\".__tooltips\",P=\".__aria\";function C(t,e){if(!a(e))throw new Error(\"noUiSlider: 'step' is not numeric.\");t.singleStep=e}function N(t,e){if(!a(e))throw new Error(\"noUiSlider: 'keyboardPageMultiplier' is not numeric.\");t.keyboardPageMultiplier=e}function V(t,e){if(!a(e))throw new Error(\"noUiSlider: 'keyboardMultiplier' is not numeric.\");t.keyboardMultiplier=e}function k(t,e){if(!a(e))throw new Error(\"noUiSlider: 'keyboardDefaultStep' is not numeric.\");t.keyboardDefaultStep=e}function M(t,e){if(\"object\"!=typeof e||Array.isArray(e))throw new Error(\"noUiSlider: 'range' is not an object.\");if(void 0===e.min||void 0===e.max)throw new Error(\"noUiSlider: Missing 'min' or 'max' in 'range'.\");t.spectrum=new x(e,t.snap||!1,t.singleStep)}function A(t,e){if(e=c(e),!Array.isArray(e)||!e.length)throw new Error(\"noUiSlider: 'start' option is incorrect.\");t.handles=e.length,t.start=e}function U(t,e){if(\"boolean\"!=typeof e)throw new Error(\"noUiSlider: 'snap' option must be a boolean.\");t.snap=e}function D(t,e){if(\"boolean\"!=typeof e)throw new Error(\"noUiSlider: 'animate' option must be a boolean.\");t.animate=e}function O(t,e){if(\"number\"!=typeof e)throw new Error(\"noUiSlider: 'animationDuration' option must be a number.\");t.animationDuration=e}function L(t,e){var r,n=[!1];if(\"lower\"===e?e=[!0,!1]:\"upper\"===e&&(e=[!1,!0]),!0===e||!1===e){for(r=1;r1)throw new Error(\"noUiSlider: 'padding' option must not exceed 100% of the range.\")}}function F(t,e){switch(e){case\"ltr\":t.dir=0;break;case\"rtl\":t.dir=1;break;default:throw new Error(\"noUiSlider: 'direction' option was not recognized.\")}}function R(t,e){if(\"string\"!=typeof e)throw new Error(\"noUiSlider: 'behaviour' must be a string containing options.\");var r=e.indexOf(\"tap\")>=0,n=e.indexOf(\"drag\")>=0,i=e.indexOf(\"fixed\")>=0,o=e.indexOf(\"snap\")>=0,s=e.indexOf(\"hover\")>=0,a=e.indexOf(\"unconstrained\")>=0,l=e.indexOf(\"drag-all\")>=0;if(i){if(2!==t.handles)throw new Error(\"noUiSlider: 'fixed' behaviour must be used with 2 handles\");j(t,t.start[1]-t.start[0])}if(a&&(t.margin||t.limit))throw new Error(\"noUiSlider: 'unconstrained' behaviour cannot be used with margin or limit\");t.events={tap:r||o,drag:n,dragAll:l,fixed:i,snap:o,hover:s,unconstrained:a}}function _(t,e){if(!1!==e)if(!0===e||n(e)){t.tooltips=[];for(var r=0;r= 2) required for mode 'count'.\");for(var r=e.values-1,n=100/r,i=[];r--;)i[r]=r*n;return i.push(100),q(i,e.stepped)}return e.mode===t.PipsMode.Positions?q(e.values,e.stepped):e.mode===t.PipsMode.Values?e.stepped?e.values.map((function(t){return C.fromStepping(C.getStep(C.toStepping(t)))})):e.values:[]}(e),i={},o=C.xVal[0],s=C.xVal[C.xVal.length-1],a=!1,l=!1,u=0;return r=n.slice().sort((function(t,e){return t-e})),(n=r.filter((function(t){return!this[t]&&(this[t]=!0)}),{}))[0]!==o&&(n.unshift(o),a=!0),n[n.length-1]!==s&&(n.push(s),l=!0),n.forEach((function(r,o){var s,c,p,f,d,h,m,g,v,b,S=r,x=n[o+1],y=e.mode===t.PipsMode.Steps;for(y&&(s=C.xNumSteps[o]),s||(s=x-S),void 0===x&&(x=S),s=Math.max(s,1e-7),c=S;c<=x;c=Number((c+s).toFixed(7))){for(g=(d=(f=C.toStepping(c))-u)/(e.density||1),b=d/(v=Math.round(g)),p=1;p<=v;p+=1)i[(h=u+p*b).toFixed(5)]=[C.fromStepping(h),0];m=n.indexOf(c)>-1?t.PipsType.LargeValue:y?t.PipsType.SmallValue:t.PipsType.NoValue,!o&&a&&c!==x&&(m=0),c===x&&l||(i[f.toFixed(5)]=[c,m]),u=f}})),i}function Y(e,n,i){var o,s,a=U.createElement(\"div\"),l=((o={})[t.PipsType.None]=\"\",o[t.PipsType.NoValue]=r.cssClasses.valueNormal,o[t.PipsType.LargeValue]=r.cssClasses.valueLarge,o[t.PipsType.SmallValue]=r.cssClasses.valueSub,o),u=((s={})[t.PipsType.None]=\"\",s[t.PipsType.NoValue]=r.cssClasses.markerNormal,s[t.PipsType.LargeValue]=r.cssClasses.markerLarge,s[t.PipsType.SmallValue]=r.cssClasses.markerSub,s),c=[r.cssClasses.valueHorizontal,r.cssClasses.valueVertical],p=[r.cssClasses.markerHorizontal,r.cssClasses.markerVertical];function d(t,e){var n=e===r.cssClasses.value,i=n?l:u;return e+\" \"+(n?c:p)[r.ort]+\" \"+i[t]}return f(a,r.cssClasses.pips),f(a,0===r.ort?r.cssClasses.pipsHorizontal:r.cssClasses.pipsVertical),Object.keys(e).forEach((function(o){!function(e,o,s){if((s=n?n(o,s):s)!==t.PipsType.None){var l=T(a,!1);l.className=d(s,r.cssClasses.marker),l.style[r.style]=e+\"%\",s>t.PipsType.NoValue&&((l=T(a,!1)).className=d(s,r.cssClasses.value),l.setAttribute(\"data-value\",String(o)),l.style[r.style]=e+\"%\",l.innerHTML=String(i.to(o)))}}(o,e[o][0],e[o][1])})),a}function I(){g&&(i(g),g=null)}function W(t){I();var e=X(t),r=t.filter,n=t.format||{to:function(t){return String(Math.round(t))}};return g=w.appendChild(Y(e,r,n))}function $(){var t=a.getBoundingClientRect(),e=\"offset\"+[\"Width\",\"Height\"][r.ort];return 0===r.ort?t.width||a[e]:t.height||a[e]}function J(t,e,n,i){var o=function(o){var s,a,l=function(t,e,r){var n=0===t.type.indexOf(\"touch\"),i=0===t.type.indexOf(\"mouse\"),o=0===t.type.indexOf(\"pointer\"),s=0,a=0;if(0===t.type.indexOf(\"MSPointer\")&&(o=!0),\"mousedown\"===t.type&&!t.buttons&&!t.touches)return!1;if(n){var l=function(e){var n=e.target;return n===r||r.contains(n)||t.composed&&t.composedPath().shift()===r};if(\"touchstart\"===t.type){var u=Array.prototype.filter.call(t.touches,l);if(u.length>1)return!1;s=u[0].pageX,a=u[0].pageY}else{var c=Array.prototype.find.call(t.changedTouches,l);if(!c)return!1;s=c.pageX,a=c.pageY}}return e=e||h(U),(i||o)&&(s=t.clientX+e.x,a=t.clientY+e.y),t.pageOffset=e,t.points=[s,a],t.cursor=i||o,t}(o,i.pageOffset,i.target||e);return!!l&&!(F()&&!i.doNotReject)&&(s=w,a=r.cssClasses.tap,!((s.classList?s.classList.contains(a):new RegExp(\"\\\\b\"+a+\"\\\\b\").test(s.className))&&!i.doNotReject)&&!(t===x.start&&void 0!==l.buttons&&l.buttons>1)&&(!i.hover||!l.buttons)&&(y||l.preventDefault(),l.calcPoint=l.points[r.ort],void n(l,i)))},s=[];return t.split(\" \").forEach((function(t){e.addEventListener(t,o,!!y&&{passive:!0}),s.push([t,o])})),s}function K(t){var e,n,i,o,s,l,c=100*(t-(e=a,n=r.ort,i=e.getBoundingClientRect(),o=e.ownerDocument,s=o.documentElement,l=h(o),/webkit.*Chrome.*Mobile/i.test(navigator.userAgent)&&(l.x=0),n?i.top+l.y-s.clientTop:i.left+l.x-s.clientLeft))/$();return c=u(c),r.dir?100-c:c}function Q(t,e){\"mouseout\"===t.type&&\"HTML\"===t.target.nodeName&&null===t.relatedTarget&&tt(t,e)}function Z(t,e){if(-1===navigator.appVersion.indexOf(\"MSIE 9\")&&0===t.buttons&&0!==e.buttonsProperty)return tt(t,e);var n=(r.dir?-1:1)*(t.calcPoint-e.startCalcPoint);ut(n>0,100*n/e.baseSize,e.locations,e.handleNumbers,e.connect)}function tt(t,e){e.handle&&(d(e.handle,r.cssClasses.active),M-=1),e.listeners.forEach((function(t){D.removeEventListener(t[0],t[1])})),0===M&&(d(w,r.cssClasses.drag),pt(),t.cursor&&(O.style.cursor=\"\",O.removeEventListener(\"selectstart\",s))),e.handleNumbers.forEach((function(t){st(\"change\",t),st(\"set\",t),st(\"end\",t)}))}function et(t,e){if(!e.handleNumbers.some(R)){var n;1===e.handleNumbers.length&&(n=p[e.handleNumbers[0]].children[0],M+=1,f(n,r.cssClasses.active)),t.stopPropagation();var i=[],o=J(x.move,D,Z,{target:t.target,handle:n,connect:e.connect,listeners:i,startCalcPoint:t.calcPoint,baseSize:$(),pageOffset:t.pageOffset,handleNumbers:e.handleNumbers,buttonsProperty:t.buttons,locations:V.slice()}),a=J(x.end,D,tt,{target:t.target,handle:n,listeners:i,doNotReject:!0,handleNumbers:e.handleNumbers}),l=J(\"mouseout\",D,Q,{target:t.target,handle:n,listeners:i,doNotReject:!0,handleNumbers:e.handleNumbers});i.push.apply(i,o.concat(a,l)),t.cursor&&(O.style.cursor=getComputedStyle(t.target).cursor,p.length>1&&f(w,r.cssClasses.drag),O.addEventListener(\"selectstart\",s,!1)),e.handleNumbers.forEach((function(t){st(\"start\",t)}))}}function rt(t){t.stopPropagation();var e=K(t.calcPoint),n=function(t){var e=100,r=!1;return p.forEach((function(n,i){if(!R(i)){var o=V[i],s=Math.abs(o-t);(so||100===s&&100===e)&&(r=i,e=s)}})),r}(e);!1!==n&&(r.events.snap||l(w,r.cssClasses.tap,r.animationDuration),ft(n,e,!0,!0),pt(),st(\"slide\",n,!0),st(\"update\",n,!0),r.events.snap?et(t,{handleNumbers:[n]}):(st(\"change\",n,!0),st(\"set\",n,!0)))}function nt(t){var e=K(t.calcPoint),r=C.getStep(e),n=C.fromStepping(r);Object.keys(A).forEach((function(t){\"hover\"===t.split(\".\")[0]&&A[t].forEach((function(t){t.call(bt,n)}))}))}function it(t,e){A[t]=A[t]||[],A[t].push(e),\"update\"===t.split(\".\")[0]&&p.forEach((function(t,e){st(\"update\",e)}))}function ot(t){var e=t&&t.split(\".\")[0],r=e?t.substring(e.length):t;Object.keys(A).forEach((function(t){var n=t.split(\".\")[0],i=t.substring(n.length);e&&e!==n||r&&r!==i||function(t){return t===P||t===E}(i)&&r!==i||delete A[t]}))}function st(t,e,n){Object.keys(A).forEach((function(i){var o=i.split(\".\")[0];t===o&&A[i].forEach((function(t){t.call(bt,N.map(r.format.to),e,N.slice(),n||!1,V.slice(),bt)}))}))}function at(t,e,n,i,o,s){var a;return p.length>1&&!r.events.unconstrained&&(i&&e>0&&(a=C.getAbsoluteDistance(t[e-1],r.margin,!1),n=Math.max(n,a)),o&&e1&&r.limit&&(i&&e>0&&(a=C.getAbsoluteDistance(t[e-1],r.limit,!1),n=Math.min(n,a)),o&&e1?n.forEach((function(t,r){var n=at(o,t,o[t]+e,a[r],l[r],!1);!1===n?e=0:(e=n-o[t],o[t]=n)})):a=l=[!0];var u=!1;n.forEach((function(t,n){u=ft(t,r[t]+e,a[n],l[n])||u})),u&&(n.forEach((function(t){st(\"update\",t),st(\"slide\",t)})),null!=i&&st(\"drag\",s))}function ct(t,e){return r.dir?100-t-e:t}function pt(){k.forEach((function(t){var e=V[t]>50?-1:1,r=3+(p.length+e*t);p[t].style.zIndex=String(r)}))}function ft(t,e,n,i,o){return o||(e=at(V,t,e,n,i,!1)),!1!==e&&(function(t,e){V[t]=e,N[t]=C.fromStepping(e);var n=\"translate(\"+lt(10*(ct(e,0)-L)+\"%\",\"0\")+\")\";p[t].style[r.transformRule]=n,dt(t),dt(t+1)}(t,e),!0)}function dt(t){if(m[t]){var e=0,n=100;0!==t&&(e=V[t-1]),t!==m.length-1&&(n=V[t]);var i=n-e,o=\"translate(\"+lt(ct(e,i)+\"%\",\"0\")+\")\",s=\"scale(\"+lt(i/100,\"1\")+\")\";m[t].style[r.transformRule]=o+\" \"+s}}function ht(t,e){return null===t||!1===t||void 0===t?V[e]:(\"number\"==typeof t&&(t=String(t)),!1!==(t=r.format.from(t))&&(t=C.toStepping(t)),!1===t||isNaN(t)?V[e]:t)}function mt(t,e,n){var i=c(t),o=void 0===V[0];e=void 0===e||e,r.animate&&!o&&l(w,r.cssClasses.tap,r.animationDuration),k.forEach((function(t){ft(t,ht(i[t],t),!0,!1,n)}));var s=1===k.length?0:1;if(o&&C.hasNoSize()&&(n=!0,V[0]=0,k.length>1)){var a=100/(k.length-1);k.forEach((function(t){V[t]=t*a}))}for(;sn.stepAfter.startValue&&(o=n.stepAfter.startValue-i),s=i>n.thisStep.startValue?n.thisStep.step:!1!==n.stepBefore.step&&i-n.stepBefore.highestStep,100===e?o=null:0===e&&(s=null);var a=C.countStepDecimals();return null!==o&&!1!==o&&(o=Number(o.toFixed(a))),null!==s&&!1!==s&&(s=Number(s.toFixed(a))),[s,o]}f(b=w,r.cssClasses.target),0===r.dir?f(b,r.cssClasses.ltr):f(b,r.cssClasses.rtl),0===r.ort?f(b,r.cssClasses.horizontal):f(b,r.cssClasses.vertical),f(b,\"rtl\"===getComputedStyle(b).direction?r.cssClasses.textDirectionRtl:r.cssClasses.textDirectionLtr),a=T(b,r.cssClasses.base),function(t,e){var n=T(e,r.cssClasses.connects);p=[],(m=[]).push(z(n,t[0]));for(var i=0;i=0&&t .noUi-tooltip{-webkit-transform:translate(50%, 0);transform:translate(50%, 0);left:auto;bottom:10px;}.bk-root .noUi-vertical .noUi-origin > .noUi-tooltip{-webkit-transform:translate(0, -18px);transform:translate(0, -18px);top:auto;right:28px;}.bk-root .noUi-handle{cursor:grab;cursor:-webkit-grab;}.bk-root .noUi-handle.noUi-active{cursor:grabbing;cursor:-webkit-grabbing;}.bk-root .noUi-handle:after,.bk-root .noUi-handle:before{display:none;}.bk-root .noUi-tooltip{display:none;white-space:nowrap;}.bk-root .noUi-handle:hover .noUi-tooltip{display:block;}.bk-root .noUi-horizontal{width:100%;height:10px;}.bk-root .noUi-vertical{width:10px;height:100%;}.bk-root .noUi-horizontal .noUi-handle{width:14px;height:18px;right:-7px;top:-5px;}.bk-root .noUi-vertical .noUi-handle{width:18px;height:14px;right:-5px;top:-7px;}.bk-root .noUi-target.noUi-horizontal{margin:5px 0px;}.bk-root .noUi-target.noUi-vertical{margin:0px 5px;}'},\n", " 462: function _(e,t,r,a,i){a();var s;const d=(0,e(1).__importDefault)(e(151)),o=e(458),_=e(8);class n extends o.AbstractSliderView{}r.DateSliderView=n,n.__name__=\"DateSliderView\";class c extends o.AbstractSlider{constructor(e){super(e),this.behaviour=\"tap\",this.connected=[!0,!1]}_formatter(e,t){return(0,_.isString)(t)?(0,d.default)(e,t):t.compute(e)}}r.DateSlider=c,s=c,c.__name__=\"DateSlider\",s.prototype.default_view=n,s.override({format:\"%d %b %Y\"})},\n", " 463: function _(e,t,s,r,i){var _;r();const n=e(464);class a extends n.MarkupView{render(){super.render(),this.model.render_as_text?this.markup_el.textContent=this.model.text:this.markup_el.innerHTML=this.has_math_disabled()?this.model.text:this.process_tex()}}s.DivView=a,a.__name__=\"DivView\";class d extends n.Markup{constructor(e){super(e)}}s.Div=d,_=d,d.__name__=\"Div\",_.prototype.default_view=a,_.define((({Boolean:e})=>({render_as_text:[e,!1]})))},\n", " 464: function _(t,e,s,i,r){i();const a=t(1);var n;const o=t(210),d=t(43),h=t(137),l=t(508),_=(0,a.__importStar)(t(465));class u extends l.WidgetView{get provider(){return h.default_provider}async lazy_initialize(){await super.lazy_initialize(),\"not_started\"==this.provider.status&&await this.provider.fetch(),\"not_started\"!=this.provider.status&&\"loading\"!=this.provider.status||this.provider.ready.connect((()=>{this.contains_tex_string()&&this.rerender()}))}after_layout(){super.after_layout(),\"loading\"===this.provider.status&&(this._has_finished=!1)}rerender(){this.layout.invalidate_cache(),this.render(),this.root.compute_layout()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>{this.rerender()}))}styles(){return[...super.styles(),_.default]}_update_layout(){this.layout=new o.CachedVariadicBox(this.el),this.layout.set_sizing(this.box_sizing())}render(){super.render();const t=Object.assign(Object.assign({},this.model.style),{display:\"inline-block\"});this.markup_el=(0,d.div)({class:_.clearfix,style:t}),this.el.appendChild(this.markup_el),\"failed\"!=this.provider.status&&\"loaded\"!=this.provider.status||(this._has_finished=!0)}has_math_disabled(){return this.model.disable_math||!this.contains_tex_string()}process_tex(){if(!this.provider.MathJax)return this.model.text;const{text:t}=this.model,e=this.provider.MathJax.find_tex(t),s=[];let i=0;for(const r of e)s.push(t.slice(i,r.start.n)),s.push(this.provider.MathJax.tex2svg(r.math,{display:r.display}).outerHTML),i=r.end.n;return i0}}s.MarkupView=u,u.__name__=\"MarkupView\";class p extends l.Widget{constructor(t){super(t)}}s.Markup=p,n=p,p.__name__=\"Markup\",n.define((({Boolean:t,String:e,Dict:s})=>({text:[e,\"\"],style:[s(e),{}],disable_math:[t,!1]})))},\n", " 465: function _(o,r,e,t,a){t(),e.root=\"bk-root\",e.clearfix=\"bk-clearfix\",e.default='.bk-root .bk-clearfix:before,.bk-root .bk-clearfix:after{content:\"\";display:table;}.bk-root .bk-clearfix:after{clear:both;}'},\n", " 466: function _(e,t,i,n,s){n();const o=e(1);var l;const r=e(438),d=e(251),_=e(43),u=e(8),c=(0,o.__importStar)(e(318)),h=(0,o.__importStar)(e(229)),m=h;class p extends r.AbstractButtonView{constructor(){super(...arguments),this._open=!1}styles(){return[...super.styles(),h.default]}render(){super.render();const e=(0,_.div)({class:[m.caret,m.down]});if(this.model.is_split){const t=this._render_button(e);t.classList.add(c.dropdown_toggle),t.addEventListener(\"click\",(()=>this._toggle_menu())),this.group_el.appendChild(t)}else this.button_el.appendChild(e);const t=this.model.menu.map(((e,t)=>{if(null==e)return(0,_.div)({class:m.divider});{const i=(0,u.isString)(e)?e:e[0],n=(0,_.div)(i);return n.addEventListener(\"click\",(()=>this._item_click(t))),n}}));this.menu=(0,_.div)({class:[m.menu,m.below]},t),this.el.appendChild(this.menu),(0,_.undisplay)(this.menu)}_show_menu(){if(!this._open){this._open=!0,(0,_.display)(this.menu);const e=t=>{const{target:i}=t;i instanceof HTMLElement&&!this.el.contains(i)&&(document.removeEventListener(\"click\",e),this._hide_menu())};document.addEventListener(\"click\",e)}}_hide_menu(){this._open&&(this._open=!1,(0,_.undisplay)(this.menu))}_toggle_menu(){this._open?this._hide_menu():this._show_menu()}click(){this.model.is_split?(this._hide_menu(),this.model.trigger_event(new d.ButtonClick),super.click()):this._toggle_menu()}_item_click(e){this._hide_menu();const t=this.model.menu[e];if(null!=t){const i=(0,u.isString)(t)?t:t[1];(0,u.isString)(i)?this.model.trigger_event(new d.MenuItemClick(i)):i.execute(this.model,{index:e})}}}i.DropdownView=p,p.__name__=\"DropdownView\";class a extends r.AbstractButton{constructor(e){super(e)}get is_split(){return this.split}}i.Dropdown=a,l=a,a.__name__=\"Dropdown\",l.prototype.default_view=p,l.define((({Null:e,Boolean:t,String:i,Array:n,Tuple:s,Or:o})=>({split:[t,!1],menu:[n(o(i,s(i,o(i)),e)),[]]}))),l.override({label:\"Dropdown\"})},\n", " 467: function _(e,l,i,t,s){var n;t();const a=e(43),o=e(508);class d extends o.WidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.render()))}render(){const{multiple:e,accept:l,disabled:i,width:t}=this.model;null==this.dialog_el&&(this.dialog_el=(0,a.input)({type:\"file\",multiple:e}),this.dialog_el.onchange=()=>{const{files:e}=this.dialog_el;null!=e&&this.load_files(e)},this.el.appendChild(this.dialog_el)),null!=l&&\"\"!=l&&(this.dialog_el.accept=l),this.dialog_el.style.width=`${t}px`,this.dialog_el.disabled=i}async load_files(e){const l=[],i=[],t=[];for(const s of e){const e=await this._read_file(s),[,n=\"\",,a=\"\"]=e.split(/[:;,]/,4);l.push(a),i.push(s.name),t.push(n)}this.model.multiple?this.model.setv({value:l,filename:i,mime_type:t}):this.model.setv({value:l[0],filename:i[0],mime_type:t[0]})}_read_file(e){return new Promise(((l,i)=>{const t=new FileReader;t.onload=()=>{var s;const{result:n}=t;null!=n?l(n):i(null!==(s=t.error)&&void 0!==s?s:new Error(`unable to read '${e.name}'`))},t.readAsDataURL(e)}))}}i.FileInputView=d,d.__name__=\"FileInputView\";class r extends o.Widget{constructor(e){super(e)}}i.FileInput=r,n=r,r.__name__=\"FileInput\",n.prototype.default_view=d,n.define((({Boolean:e,String:l,Array:i,Or:t})=>({value:[t(l,i(l)),\"\"],mime_type:[t(l,i(l)),\"\"],filename:[t(l,i(l)),\"\"],accept:[l,\"\"],multiple:[e,!1]})))},\n", " 468: function _(e,t,i,s,n){s();const l=e(1);var o;const r=e(43),c=e(8),h=e(445),p=(0,l.__importStar)(e(446));class d extends h.InputWidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.value.change,(()=>this.render_selection())),this.connect(this.model.properties.options.change,(()=>this.render())),this.connect(this.model.properties.name.change,(()=>this.render())),this.connect(this.model.properties.title.change,(()=>this.render())),this.connect(this.model.properties.size.change,(()=>this.render())),this.connect(this.model.properties.disabled.change,(()=>this.render()))}render(){super.render();const e=this.model.options.map((e=>{let t,i;return(0,c.isString)(e)?t=i=e:[t,i]=e,(0,r.option)({value:t},i)}));this.input_el=(0,r.select)({multiple:!0,class:p.input,name:this.model.name,disabled:this.model.disabled},e),this.input_el.addEventListener(\"change\",(()=>this.change_input())),this.group_el.appendChild(this.input_el),this.render_selection()}render_selection(){const e=new Set(this.model.value);for(const t of this.el.querySelectorAll(\"option\"))t.selected=e.has(t.value);this.input_el.size=this.model.size}change_input(){const e=null!=this.el.querySelector(\"select:focus\"),t=[];for(const e of this.el.querySelectorAll(\"option\"))e.selected&&t.push(e.value);this.model.value=t,super.change_input(),e&&this.input_el.focus()}}i.MultiSelectView=d,d.__name__=\"MultiSelectView\";class u extends h.InputWidget{constructor(e){super(e)}}i.MultiSelect=u,o=u,u.__name__=\"MultiSelect\",o.prototype.default_view=d,o.define((({Int:e,String:t,Array:i,Tuple:s,Or:n})=>({value:[i(t),[]],options:[i(n(t,s(t,t))),[]],size:[e,4]})))},\n", " 469: function _(e,a,r,t,s){var n;t();const p=e(464),_=e(43);class i extends p.MarkupView{render(){super.render();const e=(0,_.p)({style:{margin:0}});this.has_math_disabled()?e.textContent=this.model.text:e.innerHTML=this.process_tex(),this.markup_el.appendChild(e)}}r.ParagraphView=i,i.__name__=\"ParagraphView\";class h extends p.Markup{constructor(e){super(e)}}r.Paragraph=h,n=h,h.__name__=\"Paragraph\",n.prototype.default_view=i},\n", " 470: function _(e,s,t,n,r){var p;n();const u=e(443);class a extends u.TextInputView{render(){super.render(),this.input_el.type=\"password\"}}t.PasswordInputView=a,a.__name__=\"PasswordInputView\";class o extends u.TextInput{constructor(e){super(e)}}t.PasswordInput=o,p=o,o.__name__=\"PasswordInput\",p.prototype.default_view=a},\n", " 471: function _(e,t,i,l,s){l();const o=e(1);var n;const h=(0,o.__importDefault)(e(472)),a=e(43),u=e(8),c=e(210),_=(0,o.__importStar)(e(446)),d=(0,o.__importDefault)(e(473)),r=e(445);class m extends r.InputWidgetView{constructor(){super(...arguments),this._last_height=null}connect_signals(){super.connect_signals(),this.connect(this.model.properties.disabled.change,(()=>this.set_disabled()));const{value:e,max_items:t,option_limit:i,search_option_limit:l,delete_button:s,placeholder:o,options:n,name:h,title:a}=this.model.properties;this.on_change([e,t,i,l,s,o,n,h,a],(()=>this.render()))}styles(){return[...super.styles(),d.default]}_update_layout(){this.layout=new c.CachedVariadicBox(this.el),this.layout.set_sizing(this.box_sizing())}render(){super.render(),this.input_el=(0,a.select)({multiple:!0,class:_.input,name:this.model.name,disabled:this.model.disabled}),this.group_el.appendChild(this.input_el);const e=new Set(this.model.value),t=this.model.options.map((t=>{let i,l;return(0,u.isString)(t)?i=l=t:[i,l]=t,{value:i,label:l,selected:e.has(i)}})),i=this.model.solid?\"solid\":\"light\",l=`choices__item ${i}`,s=`choices__button ${i}`,o={choices:t,duplicateItemsAllowed:!1,removeItemButton:this.model.delete_button,classNames:{item:l,button:s}};null!=this.model.placeholder&&(o.placeholderValue=this.model.placeholder),null!=this.model.max_items&&(o.maxItemCount=this.model.max_items),null!=this.model.option_limit&&(o.renderChoiceLimit=this.model.option_limit),null!=this.model.search_option_limit&&(o.searchResultLimit=this.model.search_option_limit),this.choice_el=new h.default(this.input_el,o);const n=()=>this.choice_el.containerOuter.element.getBoundingClientRect().height;null!=this._last_height&&this._last_height!=n()&&this.root.invalidate_layout(),this._last_height=n(),this.input_el.addEventListener(\"change\",(()=>this.change_input()))}set_disabled(){this.model.disabled?this.choice_el.disable():this.choice_el.enable()}change_input(){const e=null!=this.el.querySelector(\"select:focus\"),t=[];for(const e of this.el.querySelectorAll(\"option\"))e.selected&&t.push(e.value);this.model.value=t,super.change_input(),e&&this.input_el.focus()}}i.MultiChoiceView=m,m.__name__=\"MultiChoiceView\";class p extends r.InputWidget{constructor(e){super(e)}}i.MultiChoice=p,n=p,p.__name__=\"MultiChoice\",n.prototype.default_view=m,n.define((({Boolean:e,Int:t,String:i,Array:l,Tuple:s,Or:o,Nullable:n})=>({value:[l(i),[]],options:[l(o(i,s(i,i))),[]],max_items:[n(t),null],delete_button:[e,!0],placeholder:[n(i),null],option_limit:[n(t),null],search_option_limit:[n(t),null],solid:[e,!0]})))},\n", " 472: function _(e,t,i,n,s){\n", " /*! choices.js v9.0.1 | © 2019 Josh Johnson | https://github.com/jshjohnson/Choices#readme */\n", " var r,o;r=window,o=function(){return function(e){var t={};function i(n){if(t[n])return t[n].exports;var s=t[n]={i:n,l:!1,exports:{}};return e[n].call(s.exports,s,s.exports,i),s.l=!0,s.exports}return i.m=e,i.c=t,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},i.r=function(e){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(e,\"__esModule\",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&\"object\"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,\"default\",{enumerable:!0,value:e}),2&t&&\"string\"!=typeof e)for(var s in e)i.d(n,s,function(t){return e[t]}.bind(null,s));return n},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,\"a\",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p=\"/public/assets/scripts/\",i(i.s=4)}([function(e,t,i){\"use strict\";var n=function(e){return function(e){return!!e&&\"object\"==typeof e}(e)&&!function(e){var t=Object.prototype.toString.call(e);return\"[object RegExp]\"===t||\"[object Date]\"===t||function(e){return e.$$typeof===s}(e)}(e)},s=\"function\"==typeof Symbol&&Symbol.for?Symbol.for(\"react.element\"):60103;function r(e,t){return!1!==t.clone&&t.isMergeableObject(e)?l((i=e,Array.isArray(i)?[]:{}),e,t):e;var i}function o(e,t,i){return e.concat(t).map((function(e){return r(e,i)}))}function a(e){return Object.keys(e).concat(function(e){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(e).filter((function(t){return e.propertyIsEnumerable(t)})):[]}(e))}function c(e,t,i){var n={};return i.isMergeableObject(e)&&a(e).forEach((function(t){n[t]=r(e[t],i)})),a(t).forEach((function(s){(function(e,t){try{return t in e&&!(Object.hasOwnProperty.call(e,t)&&Object.propertyIsEnumerable.call(e,t))}catch(e){return!1}})(e,s)||(i.isMergeableObject(t[s])&&e[s]?n[s]=function(e,t){if(!t.customMerge)return l;var i=t.customMerge(e);return\"function\"==typeof i?i:l}(s,i)(e[s],t[s],i):n[s]=r(t[s],i))})),n}function l(e,t,i){(i=i||{}).arrayMerge=i.arrayMerge||o,i.isMergeableObject=i.isMergeableObject||n,i.cloneUnlessOtherwiseSpecified=r;var s=Array.isArray(t);return s===Array.isArray(e)?s?i.arrayMerge(e,t,i):c(e,t,i):r(t,i)}l.all=function(e,t){if(!Array.isArray(e))throw new Error(\"first argument should be an array\");return e.reduce((function(e,i){return l(e,i,t)}),{})};var h=l;e.exports=h},function(e,t,i){\"use strict\";(function(e,n){var s,r=i(3);s=\"undefined\"!=typeof self?self:\"undefined\"!=typeof window?window:void 0!==e?e:n;var o=Object(r.a)(s);t.a=o}).call(this,i(5),i(6)(e))},function(e,t,i){\n", " /*!\n", " * Fuse.js v3.4.5 - Lightweight fuzzy-search (http://fusejs.io)\n", " *\n", " * Copyright (c) 2012-2017 Kirollos Risk (http://kiro.me)\n", " * All Rights Reserved. Apache Software License 2.0\n", " *\n", " * http://www.apache.org/licenses/LICENSE-2.0\n", " */\n", " e.exports=function(e){var t={};function i(n){if(t[n])return t[n].exports;var s=t[n]={i:n,l:!1,exports:{}};return e[n].call(s.exports,s,s.exports,i),s.l=!0,s.exports}return i.m=e,i.c=t,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},i.r=function(e){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(e,\"__esModule\",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&\"object\"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,\"default\",{enumerable:!0,value:e}),2&t&&\"string\"!=typeof e)for(var s in e)i.d(n,s,function(t){return e[t]}.bind(null,s));return n},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,\"a\",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p=\"\",i(i.s=1)}([function(e,t){e.exports=function(e){return Array.isArray?Array.isArray(e):\"[object Array]\"===Object.prototype.toString.call(e)}},function(e,t,i){function n(e){return(n=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&\"function\"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?\"symbol\":typeof e})(e)}function s(e,t){for(var i=0;i1&&void 0!==arguments[1]?arguments[1]:{limit:!1};this._log('---------\\nSearch pattern: \"'.concat(e,'\"'));var i=this._prepareSearchers(e),n=i.tokenSearchers,s=i.fullSearcher,r=this._search(n,s),o=r.weights,a=r.results;return this._computeScore(o,a),this.options.shouldSort&&this._sort(a),t.limit&&\"number\"==typeof t.limit&&(a=a.slice(0,t.limit)),this._format(a)}},{key:\"_prepareSearchers\",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:\"\",t=[];if(this.options.tokenize)for(var i=e.split(this.options.tokenSeparator),n=0,s=i.length;n0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1?arguments[1]:void 0,i=this.list,n={},s=[];if(\"string\"==typeof i[0]){for(var r=0,o=i.length;r1)throw new Error(\"Key weight has to be > 0 and <= 1\");p=p.name}else a[p]={weight:1};this._analyze({key:p,value:this.options.getFn(h,p),record:h,index:c},{resultMap:n,results:s,tokenSearchers:e,fullSearcher:t})}return{weights:a,results:s}}},{key:\"_analyze\",value:function(e,t){var i=e.key,n=e.arrayIndex,s=void 0===n?-1:n,r=e.value,o=e.record,c=e.index,l=t.tokenSearchers,h=void 0===l?[]:l,u=t.fullSearcher,d=void 0===u?[]:u,p=t.resultMap,m=void 0===p?{}:p,f=t.results,v=void 0===f?[]:f;if(null!=r){var g=!1,_=-1,b=0;if(\"string\"==typeof r){this._log(\"\\nKey: \".concat(\"\"===i?\"-\":i));var y=d.search(r);if(this._log('Full text: \"'.concat(r,'\", score: ').concat(y.score)),this.options.tokenize){for(var E=r.split(this.options.tokenSeparator),I=[],S=0;S-1&&(P=(P+_)/2),this._log(\"Score average:\",P);var D=!this.options.tokenize||!this.options.matchAllTokens||b>=h.length;if(this._log(\"\\nCheck Matches: \".concat(D)),(g||y.isMatch)&&D){var M=m[c];M?M.output.push({key:i,arrayIndex:s,value:r,score:P,matchedIndices:y.matchedIndices}):(m[c]={item:o,output:[{key:i,arrayIndex:s,value:r,score:P,matchedIndices:y.matchedIndices}]},v.push(m[c]))}}else if(a(r))for(var N=0,F=r.length;N-1&&(o.arrayIndex=r.arrayIndex),t.matches.push(o)}}})),this.options.includeScore&&s.push((function(e,t){t.score=e.score}));for(var r=0,o=e.length;ri)return s(e,this.pattern,n);var o=this.options,a=o.location,c=o.distance,l=o.threshold,h=o.findAllMatches,u=o.minMatchCharLength;return r(e,this.pattern,this.patternAlphabet,{location:a,distance:c,threshold:l,findAllMatches:h,minMatchCharLength:u})}}])&&n(t.prototype,i),a&&n(t,a),e}();e.exports=a},function(e,t){var i=/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g;e.exports=function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:/ +/g,s=new RegExp(t.replace(i,\"\\\\$&\").replace(n,\"|\")),r=e.match(s),o=!!r,a=[];if(o)for(var c=0,l=r.length;c=P;N-=1){var F=N-1,j=i[e.charAt(F)];if(j&&(E[F]=1),M[N]=(M[N+1]<<1|1)&j,0!==T&&(M[N]|=(O[N+1]|O[N])<<1|1|O[N+1]),M[N]&L&&(C=n(t,{errors:T,currentLocation:F,expectedLocation:v,distance:l}))<=_){if(_=C,(b=F)<=v)break;P=Math.max(1,2*v-b)}}if(n(t,{errors:T+1,currentLocation:v,expectedLocation:v,distance:l})>_)break;O=M}return{isMatch:b>=0,score:0===C?.001:C,matchedIndices:s(E,f)}}},function(e,t){e.exports=function(e,t){var i=t.errors,n=void 0===i?0:i,s=t.currentLocation,r=void 0===s?0:s,o=t.expectedLocation,a=void 0===o?0:o,c=t.distance,l=void 0===c?100:c,h=n/e.length,u=Math.abs(a-r);return l?h+u/l:u?1:h}},function(e,t){e.exports=function(){for(var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,i=[],n=-1,s=-1,r=0,o=e.length;r=t&&i.push([n,s]),n=-1)}return e[r-1]&&r-n>=t&&i.push([n,r-1]),i}},function(e,t){e.exports=function(e){for(var t={},i=e.length,n=0;n/g,\"&rt;\").replace(/-1?e.map((function(e){var i=e;return i.id===parseInt(t.choiceId,10)&&(i.selected=!0),i})):e;case\"REMOVE_ITEM\":return t.choiceId>-1?e.map((function(e){var i=e;return i.id===parseInt(t.choiceId,10)&&(i.selected=!1),i})):e;case\"FILTER_CHOICES\":return e.map((function(e){var i=e;return i.active=t.results.some((function(e){var t=e.item,n=e.score;return t.id===i.id&&(i.score=n,!0)})),i}));case\"ACTIVATE_CHOICES\":return e.map((function(e){var i=e;return i.active=t.active,i}));case\"CLEAR_CHOICES\":return v;default:return e}},general:_}),A=function(e,t){var i=e;if(\"CLEAR_ALL\"===t.type)i=void 0;else if(\"RESET_TO\"===t.type)return O(t.state);return C(i,t)};function L(e,t){for(var i=0;i\"'+I(e)+'\"'},maxItemText:function(e){return\"Only \"+e+\" values can be added\"},valueComparer:function(e,t){return e===t},fuseOptions:{includeScore:!0},callbackOnInit:null,callbackOnCreateTemplates:null,classNames:{containerOuter:\"choices\",containerInner:\"choices__inner\",input:\"choices__input\",inputCloned:\"choices__input--cloned\",list:\"choices__list\",listItems:\"choices__list--multiple\",listSingle:\"choices__list--single\",listDropdown:\"choices__list--dropdown\",item:\"choices__item\",itemSelectable:\"choices__item--selectable\",itemDisabled:\"choices__item--disabled\",itemChoice:\"choices__item--choice\",placeholder:\"choices__placeholder\",group:\"choices__group\",groupHeading:\"choices__heading\",button:\"choices__button\",activeState:\"is-active\",focusState:\"is-focused\",openState:\"is-open\",disabledState:\"is-disabled\",highlightedState:\"is-highlighted\",selectedState:\"is-selected\",flippedState:\"is-flipped\",loadingState:\"is-loading\",noResults:\"has-no-results\",noChoices:\"has-no-choices\"}},D=\"showDropdown\",M=\"hideDropdown\",N=\"change\",F=\"choice\",j=\"search\",K=\"addItem\",R=\"removeItem\",H=\"highlightItem\",B=\"highlightChoice\",V=\"ADD_CHOICE\",G=\"FILTER_CHOICES\",q=\"ACTIVATE_CHOICES\",U=\"CLEAR_CHOICES\",z=\"ADD_GROUP\",W=\"ADD_ITEM\",X=\"REMOVE_ITEM\",$=\"HIGHLIGHT_ITEM\",J=46,Y=8,Z=13,Q=65,ee=27,te=38,ie=40,ne=33,se=34,re=\"text\",oe=\"select-one\",ae=\"select-multiple\",ce=function(){function e(e){var t=e.element,i=e.type,n=e.classNames,s=e.position;this.element=t,this.classNames=n,this.type=i,this.position=s,this.isOpen=!1,this.isFlipped=!1,this.isFocussed=!1,this.isDisabled=!1,this.isLoading=!1,this._onFocus=this._onFocus.bind(this),this._onBlur=this._onBlur.bind(this)}var t=e.prototype;return t.addEventListeners=function(){this.element.addEventListener(\"focus\",this._onFocus),this.element.addEventListener(\"blur\",this._onBlur)},t.removeEventListeners=function(){this.element.removeEventListener(\"focus\",this._onFocus),this.element.removeEventListener(\"blur\",this._onBlur)},t.shouldFlip=function(e){if(\"number\"!=typeof e)return!1;var t=!1;return\"auto\"===this.position?t=!window.matchMedia(\"(min-height: \"+(e+1)+\"px)\").matches:\"top\"===this.position&&(t=!0),t},t.setActiveDescendant=function(e){this.element.setAttribute(\"aria-activedescendant\",e)},t.removeActiveDescendant=function(){this.element.removeAttribute(\"aria-activedescendant\")},t.open=function(e){this.element.classList.add(this.classNames.openState),this.element.setAttribute(\"aria-expanded\",\"true\"),this.isOpen=!0,this.shouldFlip(e)&&(this.element.classList.add(this.classNames.flippedState),this.isFlipped=!0)},t.close=function(){this.element.classList.remove(this.classNames.openState),this.element.setAttribute(\"aria-expanded\",\"false\"),this.removeActiveDescendant(),this.isOpen=!1,this.isFlipped&&(this.element.classList.remove(this.classNames.flippedState),this.isFlipped=!1)},t.focus=function(){this.isFocussed||this.element.focus()},t.addFocusState=function(){this.element.classList.add(this.classNames.focusState)},t.removeFocusState=function(){this.element.classList.remove(this.classNames.focusState)},t.enable=function(){this.element.classList.remove(this.classNames.disabledState),this.element.removeAttribute(\"aria-disabled\"),this.type===oe&&this.element.setAttribute(\"tabindex\",\"0\"),this.isDisabled=!1},t.disable=function(){this.element.classList.add(this.classNames.disabledState),this.element.setAttribute(\"aria-disabled\",\"true\"),this.type===oe&&this.element.setAttribute(\"tabindex\",\"-1\"),this.isDisabled=!0},t.wrap=function(e){!function(e,t){void 0===t&&(t=document.createElement(\"div\")),e.nextSibling?e.parentNode.insertBefore(t,e.nextSibling):e.parentNode.appendChild(t),t.appendChild(e)}(e,this.element)},t.unwrap=function(e){this.element.parentNode.insertBefore(e,this.element),this.element.parentNode.removeChild(this.element)},t.addLoadingState=function(){this.element.classList.add(this.classNames.loadingState),this.element.setAttribute(\"aria-busy\",\"true\"),this.isLoading=!0},t.removeLoadingState=function(){this.element.classList.remove(this.classNames.loadingState),this.element.removeAttribute(\"aria-busy\"),this.isLoading=!1},t._onFocus=function(){this.isFocussed=!0},t._onBlur=function(){this.isFocussed=!1},e}();function le(e,t){for(var i=0;i0?this.element.scrollTop+o-s:e.offsetTop;requestAnimationFrame((function(){i._animateScroll(a,t)}))}},t._scrollDown=function(e,t,i){var n=(i-e)/t,s=n>1?n:1;this.element.scrollTop=e+s},t._scrollUp=function(e,t,i){var n=(e-i)/t,s=n>1?n:1;this.element.scrollTop=e-s},t._animateScroll=function(e,t){var i=this,n=this.element.scrollTop,s=!1;t>0?(this._scrollDown(n,4,e),ne&&(s=!0)),s&&requestAnimationFrame((function(){i._animateScroll(e,t)}))},e}();function de(e,t){for(var i=0;i0?\"treeitem\":\"option\"),Object.assign(g.dataset,{choice:\"\",id:l,value:h,selectText:i}),m?(g.classList.add(a),g.dataset.choiceDisabled=\"\",g.setAttribute(\"aria-disabled\",\"true\")):(g.classList.add(r),g.dataset.choiceSelectable=\"\"),g},input:function(e,t){var i=e.input,n=e.inputCloned,s=Object.assign(document.createElement(\"input\"),{type:\"text\",className:i+\" \"+n,autocomplete:\"off\",autocapitalize:\"off\",spellcheck:!1});return s.setAttribute(\"role\",\"textbox\"),s.setAttribute(\"aria-autocomplete\",\"list\"),s.setAttribute(\"aria-label\",t),s},dropdown:function(e){var t=e.list,i=e.listDropdown,n=document.createElement(\"div\");return n.classList.add(t,i),n.setAttribute(\"aria-expanded\",\"false\"),n},notice:function(e,t,i){var n=e.item,s=e.itemChoice,r=e.noResults,o=e.noChoices;void 0===i&&(i=\"\");var a=[n,s];return\"no-choices\"===i?a.push(o):\"no-results\"===i&&a.push(r),Object.assign(document.createElement(\"div\"),{innerHTML:t,className:a.join(\" \")})},option:function(e){var t=e.label,i=e.value,n=e.customProperties,s=e.active,r=e.disabled,o=new Option(t,i,!1,s);return n&&(o.dataset.customProperties=n),o.disabled=r,o}},be=function(e){return void 0===e&&(e=!0),{type:q,active:e}},ye=function(e,t){return{type:$,id:e,highlighted:t}},Ee=function(e){var t=e.value,i=e.id,n=e.active,s=e.disabled;return{type:z,value:t,id:i,active:n,disabled:s}},Ie=function(e){return{type:\"SET_IS_LOADING\",isLoading:e}};function Se(e,t){for(var i=0;i=0?this._store.getGroupById(s):null;return this._store.dispatch(ye(i,!0)),t&&this.passedElement.triggerEvent(H,{id:i,value:o,label:c,groupValue:l&&l.value?l.value:null}),this},r.unhighlightItem=function(e){if(!e)return this;var t=e.id,i=e.groupId,n=void 0===i?-1:i,s=e.value,r=void 0===s?\"\":s,o=e.label,a=void 0===o?\"\":o,c=n>=0?this._store.getGroupById(n):null;return this._store.dispatch(ye(t,!1)),this.passedElement.triggerEvent(H,{id:t,value:r,label:a,groupValue:c&&c.value?c.value:null}),this},r.highlightAll=function(){var e=this;return this._store.items.forEach((function(t){return e.highlightItem(t)})),this},r.unhighlightAll=function(){var e=this;return this._store.items.forEach((function(t){return e.unhighlightItem(t)})),this},r.removeActiveItemsByValue=function(e){var t=this;return this._store.activeItems.filter((function(t){return t.value===e})).forEach((function(e){return t._removeItem(e)})),this},r.removeActiveItems=function(e){var t=this;return this._store.activeItems.filter((function(t){return t.id!==e})).forEach((function(e){return t._removeItem(e)})),this},r.removeHighlightedItems=function(e){var t=this;return void 0===e&&(e=!1),this._store.highlightedActiveItems.forEach((function(i){t._removeItem(i),e&&t._triggerChange(i.value)})),this},r.showDropdown=function(e){var t=this;return this.dropdown.isActive||requestAnimationFrame((function(){t.dropdown.show(),t.containerOuter.open(t.dropdown.distanceFromTopWindow),!e&&t._canSearch&&t.input.focus(),t.passedElement.triggerEvent(D,{})})),this},r.hideDropdown=function(e){var t=this;return this.dropdown.isActive?(requestAnimationFrame((function(){t.dropdown.hide(),t.containerOuter.close(),!e&&t._canSearch&&(t.input.removeActiveDescendant(),t.input.blur()),t.passedElement.triggerEvent(M,{})})),this):this},r.getValue=function(e){void 0===e&&(e=!1);var t=this._store.activeItems.reduce((function(t,i){var n=e?i.value:i;return t.push(n),t}),[]);return this._isSelectOneElement?t[0]:t},r.setValue=function(e){var t=this;return this.initialised?(e.forEach((function(e){return t._setChoiceOrItem(e)})),this):this},r.setChoiceByValue=function(e){var t=this;return!this.initialised||this._isTextElement||(Array.isArray(e)?e:[e]).forEach((function(e){return t._findAndSelectChoiceByValue(e)})),this},r.setChoices=function(e,t,i,n){var s=this;if(void 0===e&&(e=[]),void 0===t&&(t=\"value\"),void 0===i&&(i=\"label\"),void 0===n&&(n=!1),!this.initialised)throw new ReferenceError(\"setChoices was called on a non-initialized instance of Choices\");if(!this._isSelectElement)throw new TypeError(\"setChoices can't be used with INPUT based Choices\");if(\"string\"!=typeof t||!t)throw new TypeError(\"value parameter must be a name of 'value' field in passed objects\");if(n&&this.clearChoices(),\"function\"==typeof e){var r=e(this);if(\"function\"==typeof Promise&&r instanceof Promise)return new Promise((function(e){return requestAnimationFrame(e)})).then((function(){return s._handleLoadingState(!0)})).then((function(){return r})).then((function(e){return s.setChoices(e,t,i,n)})).catch((function(e){s.config.silent||console.error(e)})).then((function(){return s._handleLoadingState(!1)})).then((function(){return s}));if(!Array.isArray(r))throw new TypeError(\".setChoices first argument function must return either array of choices or Promise, got: \"+typeof r);return this.setChoices(r,t,i,!1)}if(!Array.isArray(e))throw new TypeError(\".setChoices must be called either with array of choices with a function resulting into Promise of array of choices\");return this.containerOuter.removeLoadingState(),this._startLoading(),e.forEach((function(e){e.choices?s._addGroup({id:parseInt(e.id,10)||null,group:e,valueKey:t,labelKey:i}):s._addChoice({value:e[t],label:e[i],isSelected:e.selected,isDisabled:e.disabled,customProperties:e.customProperties,placeholder:e.placeholder})})),this._stopLoading(),this},r.clearChoices=function(){return this._store.dispatch({type:U}),this},r.clearStore=function(){return this._store.dispatch({type:\"CLEAR_ALL\"}),this},r.clearInput=function(){var e=!this._isSelectOneElement;return this.input.clear(e),!this._isTextElement&&this._canSearch&&(this._isSearching=!1,this._store.dispatch(be(!0))),this},r._render=function(){if(!this._store.isLoading()){this._currentState=this._store.state;var e=this._currentState.choices!==this._prevState.choices||this._currentState.groups!==this._prevState.groups||this._currentState.items!==this._prevState.items,t=this._isSelectElement,i=this._currentState.items!==this._prevState.items;e&&(t&&this._renderChoices(),i&&this._renderItems(),this._prevState=this._currentState)}},r._renderChoices=function(){var e=this,t=this._store,i=t.activeGroups,n=t.activeChoices,s=document.createDocumentFragment();if(this.choiceList.clear(),this.config.resetScrollPosition&&requestAnimationFrame((function(){return e.choiceList.scrollToTop()})),i.length>=1&&!this._isSearching){var r=n.filter((function(e){return!0===e.placeholder&&-1===e.groupId}));r.length>=1&&(s=this._createChoicesFragment(r,s)),s=this._createGroupsFragment(i,n,s)}else n.length>=1&&(s=this._createChoicesFragment(n,s));if(s.childNodes&&s.childNodes.length>0){var o=this._store.activeItems,a=this._canAddItem(o,this.input.value);a.response?(this.choiceList.append(s),this._highlightChoice()):this.choiceList.append(this._getTemplate(\"notice\",a.notice))}else{var c,l;this._isSearching?(l=\"function\"==typeof this.config.noResultsText?this.config.noResultsText():this.config.noResultsText,c=this._getTemplate(\"notice\",l,\"no-results\")):(l=\"function\"==typeof this.config.noChoicesText?this.config.noChoicesText():this.config.noChoicesText,c=this._getTemplate(\"notice\",l,\"no-choices\")),this.choiceList.append(c)}},r._renderItems=function(){var e=this._store.activeItems||[];this.itemList.clear();var t=this._createItemsFragment(e);t.childNodes&&this.itemList.append(t)},r._createGroupsFragment=function(e,t,i){var n=this;return void 0===i&&(i=document.createDocumentFragment()),this.config.shouldSort&&e.sort(this.config.sorter),e.forEach((function(e){var s=function(e){return t.filter((function(t){return n._isSelectOneElement?t.groupId===e.id:t.groupId===e.id&&(\"always\"===n.config.renderSelectedChoices||!t.selected)}))}(e);if(s.length>=1){var r=n._getTemplate(\"choiceGroup\",e);i.appendChild(r),n._createChoicesFragment(s,i,!0)}})),i},r._createChoicesFragment=function(e,t,i){var n=this;void 0===t&&(t=document.createDocumentFragment()),void 0===i&&(i=!1);var s=this.config,r=s.renderSelectedChoices,o=s.searchResultLimit,a=s.renderChoiceLimit,c=this._isSearching?w:this.config.sorter,l=function(e){if(\"auto\"!==r||n._isSelectOneElement||!e.selected){var i=n._getTemplate(\"choice\",e,n.config.itemSelectText);t.appendChild(i)}},h=e;\"auto\"!==r||this._isSelectOneElement||(h=e.filter((function(e){return!e.selected})));var u=h.reduce((function(e,t){return t.placeholder?e.placeholderChoices.push(t):e.normalChoices.push(t),e}),{placeholderChoices:[],normalChoices:[]}),d=u.placeholderChoices,p=u.normalChoices;(this.config.shouldSort||this._isSearching)&&p.sort(c);var m=h.length,f=this._isSelectOneElement?[].concat(d,p):p;this._isSearching?m=o:a&&a>0&&!i&&(m=a);for(var v=0;v=n){var o=s?this._searchChoices(e):0;this.passedElement.triggerEvent(j,{value:e,resultCount:o})}else r&&(this._isSearching=!1,this._store.dispatch(be(!0)))}},r._canAddItem=function(e,t){var i=!0,n=\"function\"==typeof this.config.addItemText?this.config.addItemText(t):this.config.addItemText;if(!this._isSelectOneElement){var s=function(e,t,i){return void 0===i&&(i=\"value\"),e.some((function(e){return\"string\"==typeof t?e[i]===t.trim():e[i]===t}))}(e,t);this.config.maxItemCount>0&&this.config.maxItemCount<=e.length&&(i=!1,n=\"function\"==typeof this.config.maxItemText?this.config.maxItemText(this.config.maxItemCount):this.config.maxItemText),!this.config.duplicateItemsAllowed&&s&&i&&(i=!1,n=\"function\"==typeof this.config.uniqueItemText?this.config.uniqueItemText(t):this.config.uniqueItemText),this._isTextElement&&this.config.addItems&&i&&\"function\"==typeof this.config.addItemFilter&&!this.config.addItemFilter(t)&&(i=!1,n=\"function\"==typeof this.config.customAddItemText?this.config.customAddItemText(t):this.config.customAddItemText)}return{response:i,notice:n}},r._searchChoices=function(e){var t=\"string\"==typeof e?e.trim():e,i=\"string\"==typeof this._currentValue?this._currentValue.trim():this._currentValue;if(t.length<1&&t===i+\" \")return 0;var n=this._store.searchableChoices,r=t,o=[].concat(this.config.searchFields),a=Object.assign(this.config.fuseOptions,{keys:o}),c=new s.a(n,a).search(r);return this._currentValue=t,this._highlightPosition=0,this._isSearching=!0,this._store.dispatch(function(e){return{type:G,results:e}}(c)),c.length},r._addEventListeners=function(){var e=document.documentElement;e.addEventListener(\"touchend\",this._onTouchEnd,!0),this.containerOuter.element.addEventListener(\"keydown\",this._onKeyDown,!0),this.containerOuter.element.addEventListener(\"mousedown\",this._onMouseDown,!0),e.addEventListener(\"click\",this._onClick,{passive:!0}),e.addEventListener(\"touchmove\",this._onTouchMove,{passive:!0}),this.dropdown.element.addEventListener(\"mouseover\",this._onMouseOver,{passive:!0}),this._isSelectOneElement&&(this.containerOuter.element.addEventListener(\"focus\",this._onFocus,{passive:!0}),this.containerOuter.element.addEventListener(\"blur\",this._onBlur,{passive:!0})),this.input.element.addEventListener(\"keyup\",this._onKeyUp,{passive:!0}),this.input.element.addEventListener(\"focus\",this._onFocus,{passive:!0}),this.input.element.addEventListener(\"blur\",this._onBlur,{passive:!0}),this.input.element.form&&this.input.element.form.addEventListener(\"reset\",this._onFormReset,{passive:!0}),this.input.addEventListeners()},r._removeEventListeners=function(){var e=document.documentElement;e.removeEventListener(\"touchend\",this._onTouchEnd,!0),this.containerOuter.element.removeEventListener(\"keydown\",this._onKeyDown,!0),this.containerOuter.element.removeEventListener(\"mousedown\",this._onMouseDown,!0),e.removeEventListener(\"click\",this._onClick),e.removeEventListener(\"touchmove\",this._onTouchMove),this.dropdown.element.removeEventListener(\"mouseover\",this._onMouseOver),this._isSelectOneElement&&(this.containerOuter.element.removeEventListener(\"focus\",this._onFocus),this.containerOuter.element.removeEventListener(\"blur\",this._onBlur)),this.input.element.removeEventListener(\"keyup\",this._onKeyUp),this.input.element.removeEventListener(\"focus\",this._onFocus),this.input.element.removeEventListener(\"blur\",this._onBlur),this.input.element.form&&this.input.element.form.removeEventListener(\"reset\",this._onFormReset),this.input.removeEventListeners()},r._onKeyDown=function(e){var t,i=e.target,n=e.keyCode,s=e.ctrlKey,r=e.metaKey,o=this._store.activeItems,a=this.input.isFocussed,c=this.dropdown.isActive,l=this.itemList.hasChildren(),h=String.fromCharCode(n),u=J,d=Y,p=Z,m=Q,f=ee,v=te,g=ie,_=ne,b=se,y=s||r;!this._isTextElement&&/[a-zA-Z0-9-_ ]/.test(h)&&this.showDropdown();var E=((t={})[m]=this._onAKey,t[p]=this._onEnterKey,t[f]=this._onEscapeKey,t[v]=this._onDirectionKey,t[_]=this._onDirectionKey,t[g]=this._onDirectionKey,t[b]=this._onDirectionKey,t[d]=this._onDeleteKey,t[u]=this._onDeleteKey,t);E[n]&&E[n]({event:e,target:i,keyCode:n,metaKey:r,activeItems:o,hasFocusedInput:a,hasActiveDropdown:c,hasItems:l,hasCtrlDownKeyPressed:y})},r._onKeyUp=function(e){var t=e.target,i=e.keyCode,n=this.input.value,s=this._store.activeItems,r=this._canAddItem(s,n),o=J,a=Y;if(this._isTextElement)if(r.notice&&n){var c=this._getTemplate(\"notice\",r.notice);this.dropdown.element.innerHTML=c.outerHTML,this.showDropdown(!0)}else this.hideDropdown(!0);else{var l=(i===o||i===a)&&!t.value,h=!this._isTextElement&&this._isSearching,u=this._canSearch&&r.response;l&&h?(this._isSearching=!1,this._store.dispatch(be(!0))):u&&this._handleSearch(this.input.value)}this._canSearch=this.config.searchEnabled},r._onAKey=function(e){var t=e.hasItems;e.hasCtrlDownKeyPressed&&t&&(this._canSearch=!1,this.config.removeItems&&!this.input.value&&this.input.element===document.activeElement&&this.highlightAll())},r._onEnterKey=function(e){var t=e.event,i=e.target,n=e.activeItems,s=e.hasActiveDropdown,r=Z,o=i.hasAttribute(\"data-button\");if(this._isTextElement&&i.value){var a=this.input.value;this._canAddItem(n,a).response&&(this.hideDropdown(!0),this._addItem({value:a}),this._triggerChange(a),this.clearInput())}if(o&&(this._handleButtonAction(n,i),t.preventDefault()),s){var c=this.dropdown.getChild(\".\"+this.config.classNames.highlightedState);c&&(n[0]&&(n[0].keyCode=r),this._handleChoiceAction(n,c)),t.preventDefault()}else this._isSelectOneElement&&(this.showDropdown(),t.preventDefault())},r._onEscapeKey=function(e){e.hasActiveDropdown&&(this.hideDropdown(!0),this.containerOuter.focus())},r._onDirectionKey=function(e){var t,i,n,s=e.event,r=e.hasActiveDropdown,o=e.keyCode,a=e.metaKey,c=ie,l=ne,h=se;if(r||this._isSelectOneElement){this.showDropdown(),this._canSearch=!1;var u,d=o===c||o===h?1:-1,p=\"[data-choice-selectable]\";if(a||o===h||o===l)u=d>0?this.dropdown.element.querySelector(\"[data-choice-selectable]:last-of-type\"):this.dropdown.element.querySelector(p);else{var m=this.dropdown.element.querySelector(\".\"+this.config.classNames.highlightedState);u=m?function(e,t,i){if(void 0===i&&(i=1),e instanceof Element&&\"string\"==typeof t){for(var n=(i>0?\"next\":\"previous\")+\"ElementSibling\",s=e[n];s;){if(s.matches(t))return s;s=s[n]}return s}}(m,p,d):this.dropdown.element.querySelector(p)}u&&(t=u,i=this.choiceList.element,void 0===(n=d)&&(n=1),t&&(n>0?i.scrollTop+i.offsetHeight>=t.offsetTop+t.offsetHeight:t.offsetTop>=i.scrollTop)||this.choiceList.scrollToChildElement(u,d),this._highlightChoice(u)),s.preventDefault()}},r._onDeleteKey=function(e){var t=e.event,i=e.target,n=e.hasFocusedInput,s=e.activeItems;!n||i.value||this._isSelectOneElement||(this._handleBackspace(s),t.preventDefault())},r._onTouchMove=function(){this._wasTap&&(this._wasTap=!1)},r._onTouchEnd=function(e){var t=(e||e.touches[0]).target;this._wasTap&&this.containerOuter.element.contains(t)&&((t===this.containerOuter.element||t===this.containerInner.element)&&(this._isTextElement?this.input.focus():this._isSelectMultipleElement&&this.showDropdown()),e.stopPropagation()),this._wasTap=!0},r._onMouseDown=function(e){var t=e.target;if(t instanceof HTMLElement){if(we&&this.choiceList.element.contains(t)){var i=this.choiceList.element.firstElementChild,n=\"ltr\"===this._direction?e.offsetX>=i.offsetWidth:e.offsetX0&&this.unhighlightAll(),this.containerOuter.removeFocusState(),this.hideDropdown(!0))},r._onFocus=function(e){var t,i=this,n=e.target;this.containerOuter.element.contains(n)&&((t={}).text=function(){n===i.input.element&&i.containerOuter.addFocusState()},t[\"select-one\"]=function(){i.containerOuter.addFocusState(),n===i.input.element&&i.showDropdown(!0)},t[\"select-multiple\"]=function(){n===i.input.element&&(i.showDropdown(!0),i.containerOuter.addFocusState())},t)[this.passedElement.element.type]()},r._onBlur=function(e){var t=this,i=e.target;if(this.containerOuter.element.contains(i)&&!this._isScrollingOnIe){var n,s=this._store.activeItems.some((function(e){return e.highlighted}));((n={}).text=function(){i===t.input.element&&(t.containerOuter.removeFocusState(),s&&t.unhighlightAll(),t.hideDropdown(!0))},n[\"select-one\"]=function(){t.containerOuter.removeFocusState(),(i===t.input.element||i===t.containerOuter.element&&!t._canSearch)&&t.hideDropdown(!0)},n[\"select-multiple\"]=function(){i===t.input.element&&(t.containerOuter.removeFocusState(),t.hideDropdown(!0),s&&t.unhighlightAll())},n)[this.passedElement.element.type]()}else this._isScrollingOnIe=!1,this.input.element.focus()},r._onFormReset=function(){this._store.dispatch({type:\"RESET_TO\",state:this._initialState})},r._highlightChoice=function(e){var t=this;void 0===e&&(e=null);var i=Array.from(this.dropdown.element.querySelectorAll(\"[data-choice-selectable]\"));if(i.length){var n=e;Array.from(this.dropdown.element.querySelectorAll(\".\"+this.config.classNames.highlightedState)).forEach((function(e){e.classList.remove(t.config.classNames.highlightedState),e.setAttribute(\"aria-selected\",\"false\")})),n?this._highlightPosition=i.indexOf(n):(n=i.length>this._highlightPosition?i[this._highlightPosition]:i[i.length-1])||(n=i[0]),n.classList.add(this.config.classNames.highlightedState),n.setAttribute(\"aria-selected\",\"true\"),this.passedElement.triggerEvent(B,{el:n}),this.dropdown.isActive&&(this.input.setActiveDescendant(n.id),this.containerOuter.setActiveDescendant(n.id))}},r._addItem=function(e){var t=e.value,i=e.label,n=void 0===i?null:i,s=e.choiceId,r=void 0===s?-1:s,o=e.groupId,a=void 0===o?-1:o,c=e.customProperties,l=void 0===c?null:c,h=e.placeholder,u=void 0!==h&&h,d=e.keyCode,p=void 0===d?null:d,m=\"string\"==typeof t?t.trim():t,f=p,v=l,g=this._store.items,_=n||m,b=r||-1,y=a>=0?this._store.getGroupById(a):null,E=g?g.length+1:1;return this.config.prependValue&&(m=this.config.prependValue+m.toString()),this.config.appendValue&&(m+=this.config.appendValue.toString()),this._store.dispatch(function(e){var t=e.value,i=e.label,n=e.id,s=e.choiceId,r=e.groupId,o=e.customProperties,a=e.placeholder,c=e.keyCode;return{type:W,value:t,label:i,id:n,choiceId:s,groupId:r,customProperties:o,placeholder:a,keyCode:c}}({value:m,label:_,id:E,choiceId:b,groupId:a,customProperties:l,placeholder:u,keyCode:f})),this._isSelectOneElement&&this.removeActiveItems(E),this.passedElement.triggerEvent(K,{id:E,value:m,label:_,customProperties:v,groupValue:y&&y.value?y.value:void 0,keyCode:f}),this},r._removeItem=function(e){if(!e||!E(\"Object\",e))return this;var t=e.id,i=e.value,n=e.label,s=e.choiceId,r=e.groupId,o=r>=0?this._store.getGroupById(r):null;return this._store.dispatch(function(e,t){return{type:X,id:e,choiceId:t}}(t,s)),o&&o.value?this.passedElement.triggerEvent(R,{id:t,value:i,label:n,groupValue:o.value}):this.passedElement.triggerEvent(R,{id:t,value:i,label:n}),this},r._addChoice=function(e){var t=e.value,i=e.label,n=void 0===i?null:i,s=e.isSelected,r=void 0!==s&&s,o=e.isDisabled,a=void 0!==o&&o,c=e.groupId,l=void 0===c?-1:c,h=e.customProperties,u=void 0===h?null:h,d=e.placeholder,p=void 0!==d&&d,m=e.keyCode,f=void 0===m?null:m;if(null!=t){var v=this._store.choices,g=n||t,_=v?v.length+1:1,b=this._baseId+\"-\"+this._idNames.itemChoice+\"-\"+_;this._store.dispatch(function(e){var t=e.value,i=e.label,n=e.id,s=e.groupId,r=e.disabled,o=e.elementId,a=e.customProperties,c=e.placeholder,l=e.keyCode;return{type:V,value:t,label:i,id:n,groupId:s,disabled:r,elementId:o,customProperties:a,placeholder:c,keyCode:l}}({id:_,groupId:l,elementId:b,value:t,label:g,disabled:a,customProperties:u,placeholder:p,keyCode:f})),r&&this._addItem({value:t,label:g,choiceId:_,customProperties:u,placeholder:p,keyCode:f})}},r._addGroup=function(e){var t=this,i=e.group,n=e.id,s=e.valueKey,r=void 0===s?\"value\":s,o=e.labelKey,a=void 0===o?\"label\":o,c=E(\"Object\",i)?i.choices:Array.from(i.getElementsByTagName(\"OPTION\")),l=n||Math.floor((new Date).valueOf()*Math.random()),h=!!i.disabled&&i.disabled;c?(this._store.dispatch(Ee({value:i.label,id:l,active:!0,disabled:h})),c.forEach((function(e){var i=e.disabled||e.parentNode&&e.parentNode.disabled;t._addChoice({value:e[r],label:E(\"Object\",e)?e[a]:e.innerHTML,isSelected:e.selected,isDisabled:i,groupId:l,customProperties:e.customProperties,placeholder:e.placeholder})}))):this._store.dispatch(Ee({value:i.label,id:i.id,active:!1,disabled:i.disabled}))},r._getTemplate=function(e){var t;if(!e)return null;for(var i=this.config.classNames,n=arguments.length,s=new Array(n>1?n-1:0),r=1;r{var e;return this.input_el.name=null!==(e=this.model.name)&&void 0!==e?e:\"\"})),this.connect(this.model.properties.value.change,(()=>{this.input_el.value=this.format_value,this.old_value=this.input_el.value})),this.connect(this.model.properties.low.change,(()=>{const{value:e,low:t,high:l}=this.model;null!=t&&null!=l&&(0,p.assert)(t<=l,\"Invalid bounds, low must be inferior to high\"),null!=e&&null!=t&&e{const{value:e,low:t,high:l}=this.model;null!=t&&null!=l&&(0,p.assert)(l>=t,\"Invalid bounds, high must be superior to low\"),null!=e&&null!=l&&e>l&&(this.model.value=l)})),this.connect(this.model.properties.high.change,(()=>this.input_el.placeholder=this.model.placeholder)),this.connect(this.model.properties.disabled.change,(()=>this.input_el.disabled=this.model.disabled)),this.connect(this.model.properties.placeholder.change,(()=>this.input_el.placeholder=this.model.placeholder))}get format_value(){return null!=this.model.value?this.model.pretty(this.model.value):\"\"}_set_input_filter(e){this.input_el.addEventListener(\"input\",(()=>{const{selectionStart:t,selectionEnd:l}=this.input_el;if(e(this.input_el.value))this.old_value=this.input_el.value;else{const e=this.old_value.length-this.input_el.value.length;this.input_el.value=this.old_value,t&&l&&this.input_el.setSelectionRange(t-1,l+e)}}))}render(){super.render(),this.input_el=(0,r.input)({type:\"text\",class:_.input,name:this.model.name,value:this.format_value,disabled:this.model.disabled,placeholder:this.model.placeholder}),this.old_value=this.format_value,this.set_input_filter(),this.input_el.addEventListener(\"change\",(()=>this.change_input())),this.input_el.addEventListener(\"focusout\",(()=>this.input_el.value=this.format_value)),this.group_el.appendChild(this.input_el)}set_input_filter(){\"int\"==this.model.mode?this._set_input_filter((e=>m.test(e))):\"float\"==this.model.mode&&this._set_input_filter((e=>c.test(e)))}bound_value(e){let t=e;const{low:l,high:i}=this.model;return t=null!=l?Math.max(l,t):t,t=null!=i?Math.min(i,t):t,t}get value(){let e=\"\"!=this.input_el.value?Number(this.input_el.value):null;return null!=e&&(e=this.bound_value(e)),e}change_input(){null==this.value?this.model.value=null:Number.isNaN(this.value)||(this.model.value=this.value)}}l.NumericInputView=v,v.__name__=\"NumericInputView\";class g extends o.InputWidget{constructor(e){super(e)}_formatter(e,t){return(0,d.isString)(t)?h.format(e,t):t.doFormat([e],{loc:0})[0]}pretty(e){return null!=this.format?this._formatter(e,this.format):`${e}`}}l.NumericInput=g,u=g,g.__name__=\"NumericInput\",u.prototype.default_view=v,u.define((({Number:e,String:t,Enum:l,Ref:i,Or:n,Nullable:s})=>({value:[s(e),null],placeholder:[t,\"\"],mode:[l(\"int\",\"float\"),\"int\"],format:[s(n(t,i(a.TickFormatter))),null],low:[s(e),null],high:[s(e),null]})))},\n", " 475: function _(e,t,r,s,n){var a;s();const o=e(464),_=e(43);class p extends o.MarkupView{render(){super.render();const e=(0,_.pre)({style:{overflow:\"auto\"}},this.model.text);this.markup_el.appendChild(e)}}r.PreTextView=p,p.__name__=\"PreTextView\";class u extends o.Markup{constructor(e){super(e)}}r.PreText=u,a=u,u.__name__=\"PreText\",a.prototype.default_view=p},\n", " 476: function _(t,o,e,a,i){a();const n=t(1);var u;const s=t(449),c=t(43),_=(0,n.__importStar)(t(318));class r extends s.ButtonGroupView{change_active(t){this.model.active!==t&&(this.model.active=t)}_update_active(){const{active:t}=this.model;this._buttons.forEach(((o,e)=>{(0,c.classes)(o).toggle(_.active,t===e)}))}}e.RadioButtonGroupView=r,r.__name__=\"RadioButtonGroupView\";class l extends s.ButtonGroup{constructor(t){super(t)}}e.RadioButtonGroup=l,u=l,l.__name__=\"RadioButtonGroup\",u.prototype.default_view=r,u.define((({Int:t,Nullable:o})=>({active:[o(t),null]})))},\n", " 477: function _(e,n,i,t,a){t();const s=e(1);var l;const o=e(43),d=e(34),p=e(452),r=(0,s.__importStar)(e(446));class u extends p.InputGroupView{render(){super.render();const e=(0,o.div)({class:[r.input_group,this.model.inline?r.inline:null]});this.el.appendChild(e);const n=(0,d.uniqueId)(),{active:i,labels:t}=this.model;this._inputs=[];for(let a=0;athis.change_active(a))),this._inputs.push(s),this.model.disabled&&(s.disabled=!0),a==i&&(s.checked=!0);const l=(0,o.label)(s,(0,o.span)(t[a]));e.appendChild(l)}}change_active(e){this.model.active=e}}i.RadioGroupView=u,u.__name__=\"RadioGroupView\";class c extends p.InputGroup{constructor(e){super(e)}}i.RadioGroup=c,l=c,c.__name__=\"RadioGroup\",l.prototype.default_view=u,l.define((({Boolean:e,Int:n,String:i,Array:t,Nullable:a})=>({active:[a(n),null],labels:[t(i),[]],inline:[e,!1]})))},\n", " 478: function _(e,r,t,a,i){a();var n;const o=(0,e(1).__importStar)(e(153)),s=e(458),_=e(8);class d extends s.AbstractRangeSliderView{}t.RangeSliderView=d,d.__name__=\"RangeSliderView\";class c extends s.AbstractSlider{constructor(e){super(e),this.behaviour=\"drag\",this.connected=[!1,!0,!1]}_formatter(e,r){return(0,_.isString)(r)?o.format(e,r):r.compute(e)}}t.RangeSlider=c,n=c,c.__name__=\"RangeSlider\",n.prototype.default_view=d,n.override({format:\"0[.]00\"})},\n", " 479: function _(e,t,n,s,i){s();const l=e(1);var u;const a=e(43),o=e(8),p=e(13),_=e(445),r=(0,l.__importStar)(e(446));class c extends _.InputWidgetView{constructor(){super(...arguments),this._known_values=new Set}connect_signals(){super.connect_signals();const{value:e,options:t}=this.model.properties;this.on_change(e,(()=>{this._update_value()})),this.on_change(t,(()=>{(0,a.empty)(this.input_el),(0,a.append)(this.input_el,...this.options_el()),this._update_value()}))}options_el(){const{_known_values:e}=this;function t(t){return t.map((t=>{let n,s;return(0,o.isString)(t)?n=s=t:[n,s]=t,e.add(n),(0,a.option)({value:n},s)}))}e.clear();const{options:n}=this.model;return(0,o.isArray)(n)?t(n):(0,p.entries)(n).map((([e,n])=>(0,a.optgroup)({label:e},t(n))))}render(){super.render(),this.input_el=(0,a.select)({class:r.input,name:this.model.name,disabled:this.model.disabled},this.options_el()),this._update_value(),this.input_el.addEventListener(\"change\",(()=>this.change_input())),this.group_el.appendChild(this.input_el)}change_input(){const e=this.input_el.value;this.model.value=e,super.change_input()}_update_value(){const{value:e}=this.model;this._known_values.has(e)?this.input_el.value=e:this.input_el.removeAttribute(\"value\")}}n.SelectView=c,c.__name__=\"SelectView\";class h extends _.InputWidget{constructor(e){super(e)}}n.Select=h,u=h,h.__name__=\"Select\",u.prototype.default_view=c,u.define((({String:e,Array:t,Tuple:n,Dict:s,Or:i})=>{const l=t(i(e,n(e,e)));return{value:[e,\"\"],options:[i(l,s(l)),[]]}}))},\n", " 480: function _(e,t,r,i,a){i();var o;const s=(0,e(1).__importStar)(e(153)),_=e(458),n=e(8);class c extends _.AbstractSliderView{}r.SliderView=c,c.__name__=\"SliderView\";class d extends _.AbstractSlider{constructor(e){super(e),this.behaviour=\"tap\",this.connected=[!0,!1]}_formatter(e,t){return(0,n.isString)(t)?s.format(e,t):t.compute(e)}}r.Slider=d,o=d,d.__name__=\"Slider\",o.prototype.default_view=c,o.override({format:\"0[.]00\"})},\n", " 481: function _(e,t,i,n,s){var l;n();const o=e(474),r=e(43),{min:a,max:h,floor:_,abs:u}=Math;function d(e){return _(e)!==e?e.toFixed(16).replace(/0+$/,\"\").split(\".\")[1].length:0}class p extends o.NumericInputView{*buttons(){yield this.btn_up_el,yield this.btn_down_el}initialize(){super.initialize(),this._handles={interval:void 0,timeout:void 0},this._interval=200}connect_signals(){super.connect_signals();const e=this.model.properties;this.on_change(e.disabled,(()=>{for(const e of this.buttons())(0,r.toggle_attribute)(e,\"disabled\",this.model.disabled)}))}render(){super.render(),this.wrapper_el=(0,r.div)({class:\"bk-spin-wrapper\"}),this.group_el.replaceChild(this.wrapper_el,this.input_el),this.btn_up_el=(0,r.button)({class:\"bk-spin-btn bk-spin-btn-up\"}),this.btn_down_el=(0,r.button)({class:\"bk-spin-btn bk-spin-btn-down\"}),this.wrapper_el.appendChild(this.input_el),this.wrapper_el.appendChild(this.btn_up_el),this.wrapper_el.appendChild(this.btn_down_el);for(const e of this.buttons())(0,r.toggle_attribute)(e,\"disabled\",this.model.disabled),e.addEventListener(\"mousedown\",(e=>this._btn_mouse_down(e))),e.addEventListener(\"mouseup\",(()=>this._btn_mouse_up())),e.addEventListener(\"mouseleave\",(()=>this._btn_mouse_leave()));this.input_el.addEventListener(\"keydown\",(e=>this._input_key_down(e))),this.input_el.addEventListener(\"keyup\",(()=>this.model.value_throttled=this.model.value)),this.input_el.addEventListener(\"wheel\",(e=>this._input_mouse_wheel(e))),this.input_el.addEventListener(\"wheel\",function(e,t,i=!1){let n;return function(...s){const l=this,o=i&&void 0===n;void 0!==n&&clearTimeout(n),n=setTimeout((function(){n=void 0,i||e.apply(l,s)}),t),o&&e.apply(l,s)}}((()=>{this.model.value_throttled=this.model.value}),this.model.wheel_wait,!1))}get precision(){const{low:e,high:t,step:i}=this.model,n=d;return h(n(u(null!=e?e:0)),n(u(null!=t?t:0)),n(u(i)))}remove(){this._stop_incrementation(),super.remove()}_start_incrementation(e){clearInterval(this._handles.interval),this._counter=0;const{step:t}=this.model,i=e=>{if(this._counter+=1,this._counter%5==0){const t=Math.floor(this._counter/5);t<10?(clearInterval(this._handles.interval),this._handles.interval=setInterval((()=>i(e)),this._interval/(t+1))):t>=10&&t<=13&&(clearInterval(this._handles.interval),this._handles.interval=setInterval((()=>i(2*e)),this._interval/10))}this.increment(e)};this._handles.interval=setInterval((()=>i(e*t)),this._interval)}_stop_incrementation(){clearTimeout(this._handles.timeout),this._handles.timeout=void 0,clearInterval(this._handles.interval),this._handles.interval=void 0,this.model.value_throttled=this.model.value}_btn_mouse_down(e){e.preventDefault();const t=e.currentTarget===this.btn_up_el?1:-1;this.increment(t*this.model.step),this.input_el.focus(),this._handles.timeout=setTimeout((()=>this._start_incrementation(t)),this._interval)}_btn_mouse_up(){this._stop_incrementation()}_btn_mouse_leave(){this._stop_incrementation()}_input_mouse_wheel(e){if(document.activeElement===this.input_el){e.preventDefault();const t=e.deltaY>0?-1:1;this.increment(t*this.model.step)}}_input_key_down(e){switch(e.keyCode){case r.Keys.Up:return e.preventDefault(),this.increment(this.model.step);case r.Keys.Down:return e.preventDefault(),this.increment(-this.model.step);case r.Keys.PageUp:return e.preventDefault(),this.increment(this.model.page_step_multiplier*this.model.step);case r.Keys.PageDown:return e.preventDefault(),this.increment(-this.model.page_step_multiplier*this.model.step)}}adjust_to_precision(e){return this.bound_value(Number(e.toFixed(this.precision)))}increment(e){const{low:t,high:i}=this.model;null==this.model.value?e>0?this.model.value=null!=t?t:null!=i?a(0,i):0:e<0&&(this.model.value=null!=i?i:null!=t?h(t,0):0):this.model.value=this.adjust_to_precision(this.model.value+e)}change_input(){super.change_input(),this.model.value_throttled=this.model.value}}i.SpinnerView=p,p.__name__=\"SpinnerView\";class m extends o.NumericInput{constructor(e){super(e)}}i.Spinner=m,l=m,m.__name__=\"Spinner\",l.prototype.default_view=p,l.define((({Number:e,Nullable:t})=>({value_throttled:[t(e),null],step:[e,1],page_step_multiplier:[e,10],wheel_wait:[e,100]}))),l.override({mode:\"float\"})},\n", " 482: function _(e,t,s,n,i){n();const o=e(1);var r;const c=e(444),l=e(43),p=(0,o.__importStar)(e(446));class _ extends c.TextLikeInputView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.rows.change,(()=>this.input_el.rows=this.model.rows)),this.connect(this.model.properties.cols.change,(()=>this.input_el.cols=this.model.cols))}_render_input(){this.input_el=(0,l.textarea)({class:p.input})}render(){super.render(),this.input_el.cols=this.model.cols,this.input_el.rows=this.model.rows}}s.TextAreaInputView=_,_.__name__=\"TextAreaInputView\";class a extends c.TextLikeInput{constructor(e){super(e)}}s.TextAreaInput=a,r=a,a.__name__=\"TextAreaInput\",r.prototype.default_view=_,r.define((({Int:e})=>({cols:[e,20],rows:[e,2]}))),r.override({max_length:500})},\n", " 483: function _(e,t,s,c,i){c();const o=e(1);var a;const n=e(438),l=e(43),_=(0,o.__importStar)(e(318));class r extends n.AbstractButtonView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.active.change,(()=>this._update_active()))}render(){super.render(),this._update_active()}click(){this.model.active=!this.model.active,super.click()}_update_active(){(0,l.classes)(this.button_el).toggle(_.active,this.model.active)}}s.ToggleView=r,r.__name__=\"ToggleView\";class g extends n.AbstractButton{constructor(e){super(e)}}s.Toggle=g,a=g,g.__name__=\"Toggle\",a.prototype.default_view=r,a.define((({Boolean:e})=>({active:[e,!1]}))),a.override({label:\"Toggle\"})},\n", " }, 436, {\"models/widgets/main\":436,\"models/widgets/index\":437,\"models/widgets/abstract_button\":438,\"models/widgets/control\":439,\"models/widgets/widget\":508,\"models/widgets/abstract_icon\":441,\"models/widgets/autocomplete_input\":442,\"models/widgets/text_input\":443,\"models/widgets/text_like_input\":444,\"models/widgets/input_widget\":445,\"styles/widgets/inputs.css\":446,\"models/widgets/button\":447,\"models/widgets/checkbox_button_group\":448,\"models/widgets/button_group\":449,\"models/widgets/oriented_control\":450,\"models/widgets/checkbox_group\":451,\"models/widgets/input_group\":452,\"models/widgets/color_picker\":453,\"models/widgets/date_picker\":454,\"styles/widgets/flatpickr.css\":456,\"models/widgets/date_range_slider\":457,\"models/widgets/abstract_slider\":458,\"styles/widgets/sliders.css\":460,\"styles/widgets/nouislider.css\":461,\"models/widgets/date_slider\":462,\"models/widgets/div\":463,\"models/widgets/markup\":464,\"styles/clearfix.css\":465,\"models/widgets/dropdown\":466,\"models/widgets/file_input\":467,\"models/widgets/multiselect\":468,\"models/widgets/paragraph\":469,\"models/widgets/password_input\":470,\"models/widgets/multichoice\":471,\"styles/widgets/choices.css\":473,\"models/widgets/numeric_input\":474,\"models/widgets/pretext\":475,\"models/widgets/radio_button_group\":476,\"models/widgets/radio_group\":477,\"models/widgets/range_slider\":478,\"models/widgets/selectbox\":479,\"models/widgets/slider\":480,\"models/widgets/spinner\":481,\"models/widgets/textarea_input\":482,\"models/widgets/toggle\":483}, {});});\n", "\n", " /* END bokeh-widgets.min.js */\n", " },\n", " function(Bokeh) {\n", " /* BEGIN bokeh-tables.min.js */\n", " /*!\n", " * Copyright (c) 2012 - 2021, Anaconda, Inc., and Bokeh Contributors\n", " * All rights reserved.\n", " * \n", " * Redistribution and use in source and binary forms, with or without modification,\n", " * are permitted provided that the following conditions are met:\n", " * \n", " * Redistributions of source code must retain the above copyright notice,\n", " * this list of conditions and the following disclaimer.\n", " * \n", " * Redistributions in binary form must reproduce the above copyright notice,\n", " * this list of conditions and the following disclaimer in the documentation\n", " * and/or other materials provided with the distribution.\n", " * \n", " * Neither the name of Anaconda nor the names of any contributors\n", " * may be used to endorse or promote products derived from this software\n", " * without specific prior written permission.\n", " * \n", " * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n", " * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n", " * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n", " * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE\n", " * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n", " * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n", " * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\n", " * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\n", " * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n", " * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\n", " * THE POSSIBILITY OF SUCH DAMAGE.\n", " */\n", " (function(root, factory) {\n", " factory(root[\"Bokeh\"], \"2.4.2\");\n", " })(this, function(Bokeh, version) {\n", " let define;\n", " return (function(modules, entry, aliases, externals) {\n", " const bokeh = typeof Bokeh !== \"undefined\" && (version != null ? Bokeh[version] : Bokeh);\n", " if (bokeh != null) {\n", " return bokeh.register_plugin(modules, entry, aliases);\n", " } else {\n", " throw new Error(\"Cannot find Bokeh \" + version + \". You have to load it prior to loading plugins.\");\n", " }\n", " })\n", " ({\n", " 484: function _(t,e,o,r,s){r();const _=(0,t(1).__importStar)(t(485));o.Tables=_;(0,t(7).register_models)(_)},\n", " 485: function _(g,a,r,e,t){e();const o=g(1);(0,o.__exportStar)(g(486),r),(0,o.__exportStar)(g(489),r),t(\"DataTable\",g(492).DataTable),t(\"TableColumn\",g(510).TableColumn),t(\"TableWidget\",g(509).TableWidget);var n=g(512);t(\"AvgAggregator\",n.AvgAggregator),t(\"MinAggregator\",n.MinAggregator),t(\"MaxAggregator\",n.MaxAggregator),t(\"SumAggregator\",n.SumAggregator);var A=g(513);t(\"GroupingInfo\",A.GroupingInfo),t(\"DataCube\",A.DataCube)},\n", " 486: function _(e,t,i,s,a){s();const r=e(1);var l,n,u,d,o,p,_,c,h;const E=e(43),V=e(226),m=e(53),f=e(487),v=(0,r.__importStar)(e(488));class w extends V.DOMView{constructor(e){const{model:t,parent:i}=e.column;super(Object.assign({model:t,parent:i},e)),this.args=e,this.initialize(),this.render()}get emptyValue(){return null}initialize(){super.initialize(),this.inputEl=this._createInput(),this.defaultValue=null}async lazy_initialize(){throw new Error(\"unsupported\")}css_classes(){return super.css_classes().concat(v.cell_editor)}render(){super.render(),this.args.container.append(this.el),this.el.appendChild(this.inputEl),this.renderEditor(),this.disableNavigation()}renderEditor(){}disableNavigation(){this.inputEl.addEventListener(\"keydown\",(e=>{switch(e.keyCode){case E.Keys.Left:case E.Keys.Right:case E.Keys.Up:case E.Keys.Down:case E.Keys.PageUp:case E.Keys.PageDown:e.stopImmediatePropagation()}}))}destroy(){this.remove()}focus(){this.inputEl.focus()}show(){}hide(){}position(){}getValue(){return this.inputEl.value}setValue(e){this.inputEl.value=e}serializeValue(){return this.getValue()}isValueChanged(){return!(\"\"==this.getValue()&&null==this.defaultValue)&&this.getValue()!==this.defaultValue}applyValue(e,t){const i=this.args.grid.getData(),s=i.index.indexOf(e[f.DTINDEX_NAME]);i.setField(s,this.args.column.field,t)}loadValue(e){const t=e[this.args.column.field];this.defaultValue=null!=t?t:this.emptyValue,this.setValue(this.defaultValue)}validateValue(e){if(this.args.column.validator){const t=this.args.column.validator(e);if(!t.valid)return t}return{valid:!0,msg:null}}validate(){return this.validateValue(this.getValue())}}i.CellEditorView=w,w.__name__=\"CellEditorView\";class g extends m.Model{}i.CellEditor=g,g.__name__=\"CellEditor\";class x extends w{get emptyValue(){return\"\"}_createInput(){return(0,E.input)({type:\"text\"})}renderEditor(){this.inputEl.focus(),this.inputEl.select()}loadValue(e){super.loadValue(e),this.inputEl.defaultValue=this.defaultValue,this.inputEl.select()}}i.StringEditorView=x,x.__name__=\"StringEditorView\";class y extends g{}i.StringEditor=y,l=y,y.__name__=\"StringEditor\",l.prototype.default_view=x,l.define((({String:e,Array:t})=>({completions:[t(e),[]]})));class I extends w{_createInput(){return(0,E.textarea)()}renderEditor(){this.inputEl.focus(),this.inputEl.select()}}i.TextEditorView=I,I.__name__=\"TextEditorView\";class b extends g{}i.TextEditor=b,n=b,b.__name__=\"TextEditor\",n.prototype.default_view=I;class N extends w{_createInput(){return(0,E.select)()}renderEditor(){for(const e of this.model.options)this.inputEl.appendChild((0,E.option)({value:e},e));this.focus()}}i.SelectEditorView=N,N.__name__=\"SelectEditorView\";class C extends g{}i.SelectEditor=C,u=C,C.__name__=\"SelectEditor\",u.prototype.default_view=N,u.define((({String:e,Array:t})=>({options:[t(e),[]]})));class D extends w{_createInput(){return(0,E.input)({type:\"text\"})}}i.PercentEditorView=D,D.__name__=\"PercentEditorView\";class S extends g{}i.PercentEditor=S,d=S,S.__name__=\"PercentEditor\",d.prototype.default_view=D;class k extends w{_createInput(){return(0,E.input)({type:\"checkbox\"})}renderEditor(){this.focus()}loadValue(e){this.defaultValue=!!e[this.args.column.field],this.inputEl.checked=this.defaultValue}serializeValue(){return this.inputEl.checked}}i.CheckboxEditorView=k,k.__name__=\"CheckboxEditorView\";class z extends g{}i.CheckboxEditor=z,o=z,z.__name__=\"CheckboxEditor\",o.prototype.default_view=k;class P extends w{_createInput(){return(0,E.input)({type:\"text\"})}renderEditor(){this.inputEl.focus(),this.inputEl.select()}remove(){super.remove()}serializeValue(){var e;return null!==(e=parseInt(this.getValue(),10))&&void 0!==e?e:0}loadValue(e){super.loadValue(e),this.inputEl.defaultValue=this.defaultValue,this.inputEl.select()}validateValue(e){return isNaN(e)?{valid:!1,msg:\"Please enter a valid integer\"}:super.validateValue(e)}}i.IntEditorView=P,P.__name__=\"IntEditorView\";class T extends g{}i.IntEditor=T,p=T,T.__name__=\"IntEditor\",p.prototype.default_view=P,p.define((({Int:e})=>({step:[e,1]})));class K extends w{_createInput(){return(0,E.input)({type:\"text\"})}renderEditor(){this.inputEl.focus(),this.inputEl.select()}remove(){super.remove()}serializeValue(){var e;return null!==(e=parseFloat(this.getValue()))&&void 0!==e?e:0}loadValue(e){super.loadValue(e),this.inputEl.defaultValue=this.defaultValue,this.inputEl.select()}validateValue(e){return isNaN(e)?{valid:!1,msg:\"Please enter a valid number\"}:super.validateValue(e)}}i.NumberEditorView=K,K.__name__=\"NumberEditorView\";class A extends g{}i.NumberEditor=A,_=A,A.__name__=\"NumberEditor\",_.prototype.default_view=K,_.define((({Number:e})=>({step:[e,.01]})));class M extends w{_createInput(){return(0,E.input)({type:\"text\"})}}i.TimeEditorView=M,M.__name__=\"TimeEditorView\";class O extends g{}i.TimeEditor=O,c=O,O.__name__=\"TimeEditor\",c.prototype.default_view=M;class F extends w{_createInput(){return(0,E.input)({type:\"text\"})}get emptyValue(){return new Date}renderEditor(){this.inputEl.focus(),this.inputEl.select()}destroy(){super.destroy()}show(){super.show()}hide(){super.hide()}position(){return super.position()}getValue(){}setValue(e){}}i.DateEditorView=F,F.__name__=\"DateEditorView\";class L extends g{}i.DateEditor=L,h=L,L.__name__=\"DateEditor\",h.prototype.default_view=F},\n", " 487: function _(_,n,i,t,d){t(),i.DTINDEX_NAME=\"__bkdt_internal_index__\"},\n", " 488: function _(e,l,o,t,r){t(),o.root=\"bk-root\",o.data_table=\"bk-data-table\",o.cell_special_defaults=\"bk-cell-special-defaults\",o.cell_select=\"bk-cell-select\",o.cell_index=\"bk-cell-index\",o.header_index=\"bk-header-index\",o.cell_editor=\"bk-cell-editor\",o.cell_editor_completion=\"bk-cell-editor-completion\",o.default='.bk-root .bk-data-table{box-sizing:content-box;font-size:11px;}.bk-root .bk-data-table input[type=\"checkbox\"]{margin-left:4px;margin-right:4px;}.bk-root .bk-cell-special-defaults{border-right-color:silver;border-right-style:solid;background:#f5f5f5;}.bk-root .bk-cell-select{border-right-color:silver;border-right-style:solid;background:#f5f5f5;}.bk-root .slick-cell.bk-cell-index{border-right-color:silver;border-right-style:solid;background:#f5f5f5;text-align:right;background:#f0f0f0;color:#909090;}.bk-root .bk-header-index .slick-column-name{float:right;}.bk-root .slick-row.selected .bk-cell-index{background-color:transparent;}.bk-root .slick-row.odd{background:#f0f0f0;}.bk-root .slick-cell{padding-left:4px;padding-right:4px;border-right-color:transparent;border:0.25px solid transparent;}.bk-root .slick-cell .bk{line-height:inherit;}.bk-root .slick-cell.active{border-style:dashed;}.bk-root .slick-cell.selected{background-color:#F0F8FF;}.bk-root .slick-cell.editable{padding-left:0;padding-right:0;}.bk-root .bk-cell-editor{display:contents;}.bk-root .bk-cell-editor input,.bk-root .bk-cell-editor select{width:100%;height:100%;border:0;margin:0;padding:0;outline:0;background:transparent;vertical-align:baseline;}.bk-root .bk-cell-editor input{padding-left:4px;padding-right:4px;}.bk-root .bk-cell-editor-completion{font-size:11px;}'},\n", " 489: function _(t,e,r,n,a){n();const o=t(1);var l,s,i,c,u,m;const _=(0,o.__importDefault)(t(151)),d=(0,o.__importStar)(t(153)),f=t(490),g=t(43),h=t(20),F=t(8),p=t(34),b=t(22),S=t(53);class x extends S.Model{constructor(t){super(t)}doFormat(t,e,r,n,a){return null==r?\"\":`${r}`.replace(/&/g,\"&\").replace(//g,\">\")}}r.CellFormatter=x,x.__name__=\"CellFormatter\";class M extends x{constructor(t){super(t)}doFormat(t,e,r,n,a){const{font_style:o,text_align:l,text_color:s}=this,i=(0,g.div)(null==r?\"\":`${r}`);switch(o){case\"bold\":i.style.fontWeight=\"bold\";break;case\"italic\":i.style.fontStyle=\"italic\"}return null!=l&&(i.style.textAlign=l),null!=s&&(i.style.color=(0,b.color2css)(s)),i.outerHTML}}r.StringFormatter=M,l=M,M.__name__=\"StringFormatter\",l.define((({Color:t,Nullable:e})=>({font_style:[h.FontStyle,\"normal\"],text_align:[h.TextAlign,\"left\"],text_color:[e(t),null]})));class N extends M{constructor(t){super(t)}get scientific_limit_low(){return 10**this.power_limit_low}get scientific_limit_high(){return 10**this.power_limit_high}doFormat(t,e,r,n,a){const o=Math.abs(r)<=this.scientific_limit_low||Math.abs(r)>=this.scientific_limit_high;let l=this.precision;return l<1&&(l=1),r=null!=r&&!isNaN(r)||null==this.nan_format?0==r?(0,p.to_fixed)(r,1):o?r.toExponential(l):(0,p.to_fixed)(r,l):this.nan_format,super.doFormat(t,e,r,n,a)}}r.ScientificFormatter=N,s=N,N.__name__=\"ScientificFormatter\",s.define((({Number:t,String:e,Nullable:r})=>({nan_format:[r(e),null],precision:[t,10],power_limit_high:[t,5],power_limit_low:[t,-3]})));class w extends M{constructor(t){super(t)}doFormat(t,e,r,n,a){const{format:o,language:l,nan_format:s}=this,i=(()=>{switch(this.rounding){case\"round\":case\"nearest\":return Math.round;case\"floor\":case\"rounddown\":return Math.floor;case\"ceil\":case\"roundup\":return Math.ceil}})();return r=null!=r&&!isNaN(r)||null==s?d.format(r,o,l,i):s,super.doFormat(t,e,r,n,a)}}r.NumberFormatter=w,i=w,w.__name__=\"NumberFormatter\",i.define((({String:t,Nullable:e})=>({format:[t,\"0,0\"],language:[t,\"en\"],rounding:[h.RoundingFunction,\"round\"],nan_format:[e(t),null]})));class C extends x{constructor(t){super(t)}doFormat(t,e,r,n,a){return r?(0,g.i)({class:this.icon}).outerHTML:\"\"}}r.BooleanFormatter=C,c=C,C.__name__=\"BooleanFormatter\",c.define((({String:t})=>({icon:[t,\"check\"]})));class y extends M{constructor(t){super(t)}getFormat(){switch(this.format){case\"ATOM\":case\"W3C\":case\"RFC-3339\":case\"ISO-8601\":return\"%Y-%m-%d\";case\"COOKIE\":return\"%a, %d %b %Y\";case\"RFC-850\":return\"%A, %d-%b-%y\";case\"RFC-1123\":case\"RFC-2822\":return\"%a, %e %b %Y\";case\"RSS\":case\"RFC-822\":case\"RFC-1036\":return\"%a, %e %b %y\";case\"TIMESTAMP\":return;default:return this.format}}doFormat(t,e,r,n,a){const{nan_format:o}=this;let l;return l=null!=(r=(0,F.isString)(r)?parseInt(r,10):r)&&!isNaN(r)&&-9223372036854776!==r||null==o?null==r?\"\":(0,_.default)(r,this.getFormat()):o,super.doFormat(t,e,l,n,a)}}r.DateFormatter=y,u=y,y.__name__=\"DateFormatter\",u.define((({String:t,Nullable:e})=>({format:[t,\"ISO-8601\"],nan_format:[e(t),null]})));class T extends x{constructor(t){super(t)}doFormat(t,e,r,n,a){const{template:o}=this;if(null==r)return\"\";return f._.template(o)(Object.assign(Object.assign({},a),{value:r}))}}r.HTMLTemplateFormatter=T,m=T,T.__name__=\"HTMLTemplateFormatter\",m.define((({String:t})=>({template:[t,\"<%= value %>\"]})))},\n", " 490: function _(e,n,t,f,i){var o=e(491),d=o.template;function r(e,n,t){return d(e,n,t)}r._=o,n.exports=r,\"function\"==typeof define&&define.amd?define((function(){return r})):\"undefined\"==typeof window&&\"undefined\"==typeof navigator||(window.UnderscoreTemplate=r)},\n", " 491: function _(r,e,n,t,a){\n", " // (c) 2009-2013 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n", " // Underscore may be freely distributed under the MIT license.\n", " var u={},c=Array.prototype,o=Object.prototype,l=c.slice,i=o.toString,f=o.hasOwnProperty,s=c.forEach,p=Object.keys,_=Array.isArray,h=function(){},v=h.each=h.forEach=function(r,e,n){if(null!=r)if(s&&r.forEach===s)r.forEach(e,n);else if(r.length===+r.length){for(var t=0,a=r.length;t\":\">\",'\"':\""\",\"'\":\"'\"}},y={escape:new RegExp(\"[\"+h.keys(g.escape).join(\"\")+\"]\",\"g\")};h.each([\"escape\"],(function(r){h[r]=function(e){return null==e?\"\":(\"\"+e).replace(y[r],(function(e){return g[r][e]}))}})),h.templateSettings={evaluate:/<%([\\s\\S]+?)%>/g,interpolate:/<%=([\\s\\S]+?)%>/g,escape:/<%-([\\s\\S]+?)%>/g};var j=/(.)^/,b={\"'\":\"'\",\"\\\\\":\"\\\\\",\"\\r\":\"r\",\"\\n\":\"n\",\"\\t\":\"t\",\"\\u2028\":\"u2028\",\"\\u2029\":\"u2029\"},w=/\\\\|'|\\r|\\n|\\t|\\u2028|\\u2029/g;h.template=function(r,e,n){var t;n=h.defaults({},n,h.templateSettings);var a=new RegExp([(n.escape||j).source,(n.interpolate||j).source,(n.evaluate||j).source].join(\"|\")+\"|$\",\"g\"),u=0,c=\"__p+='\";r.replace(a,(function(e,n,t,a,o){return c+=r.slice(u,o).replace(w,(function(r){return\"\\\\\"+b[r]})),n&&(c+=\"'+\\n((__t=(\"+n+\"))==null?'':_.escape(__t))+\\n'\"),t&&(c+=\"'+\\n((__t=(\"+t+\"))==null?'':__t)+\\n'\"),a&&(c+=\"';\\n\"+a+\"\\n__p+='\"),u=o+e.length,e})),c+=\"';\\n\",n.variable||(c=\"with(obj||{}){\\n\"+c+\"}\\n\"),c=\"var __t,__p='',__j=Array.prototype.join,print=function(){__p+=__j.call(arguments,'');};\\n\"+c+\"return __p;\\n\";try{t=new Function(n.variable||\"obj\",\"_\",c)}catch(r){throw r.source=c,r}if(e)return t(e,h);var o=function(r){return t.call(this,r,h)};return o.source=\"function(\"+(n.variable||\"obj\")+\"){\\n\"+c+\"}\",o},e.exports=h},\n", " 492: function _(e,t,i,s,o){s();const n=e(1);var l;const r=e(493),d=e(497),a=e(498),h=e(499),u=e(34),c=e(8),_=e(9),m=e(13),g=e(19),p=e(508),f=e(487),b=e(509),w=e(510),x=(0,n.__importStar)(e(488)),C=x,v=(0,n.__importDefault)(e(511));i.AutosizeModes={fit_columns:\"FCV\",fit_viewport:\"FVC\",force_fit:\"LFF\",none:\"NOA\"};let z=!1;class A{constructor(e,t){this.init(e,t)}init(e,t){if(f.DTINDEX_NAME in e.data)throw new Error(`special name ${f.DTINDEX_NAME} cannot be used as a data table column`);this.source=e,this.view=t,this.index=[...this.view.indices]}getLength(){return this.index.length}getItem(e){const t={};for(const i of(0,m.keys)(this.source.data))t[i]=this.source.data[i][this.index[e]];return t[f.DTINDEX_NAME]=this.index[e],t}getField(e,t){return t==f.DTINDEX_NAME?this.index[e]:this.source.data[t][this.index[e]]}setField(e,t,i){const s=this.index[e];this.source.patch({[t]:[[s,i]]})}getRecords(){return(0,_.range)(0,this.getLength()).map((e=>this.getItem(e)))}getItems(){return this.getRecords()}slice(e,t,i){return e=null!=e?e:0,t=null!=t?t:this.getLength(),i=null!=i?i:1,(0,_.range)(e,t,i).map((e=>this.getItem(e)))}sort(e){let t=e.map((e=>[e.sortCol.field,e.sortAsc?1:-1]));0==t.length&&(t=[[f.DTINDEX_NAME,1]]);const i=this.getRecords(),s=this.index.slice();this.index.sort(((e,o)=>{for(const[n,l]of t){const t=i[s.indexOf(e)][n],r=i[s.indexOf(o)][n];if(t!==r)return(0,c.isNumber)(t)&&(0,c.isNumber)(r)?l*(t-r||+isNaN(t)-+isNaN(r)):`${t}`>`${r}`?l:-l}return 0}))}}i.TableDataProvider=A,A.__name__=\"TableDataProvider\";class M extends p.WidgetView{constructor(){super(...arguments),this._in_selection_update=!1,this._width=null}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.render())),this.connect(this.model.source.streaming,(()=>this.updateGrid())),this.connect(this.model.source.patching,(()=>this.updateGrid())),this.connect(this.model.source.change,(()=>this.updateGrid())),this.connect(this.model.source.properties.data.change,(()=>this.updateGrid())),this.connect(this.model.source.selected.change,(()=>this.updateSelection())),this.connect(this.model.source.selected.properties.indices.change,(()=>this.updateSelection()));for(const e of this.model.columns)this.connect(e.change,(()=>{this.invalidate_layout(),this.render()}))}remove(){var e;null===(e=this.grid)||void 0===e||e.destroy(),super.remove()}styles(){return[...super.styles(),v.default,x.default]}update_position(){super.update_position(),this.grid.resizeCanvas()}after_layout(){super.after_layout(),this.updateLayout(!0,!1)}box_sizing(){const e=super.box_sizing();return\"fit_viewport\"===this.model.autosize_mode&&null!=this._width&&(e.width=this._width),e}updateLayout(e,t){const s=this.autosize;s===i.AutosizeModes.fit_columns||s===i.AutosizeModes.force_fit?(e||this.grid.resizeCanvas(),this.grid.autosizeColumns()):e&&t&&s===i.AutosizeModes.fit_viewport&&this.invalidate_layout()}updateGrid(){if(this.model.view.compute_indices(),this.data.init(this.model.source,this.model.view),this.model.sortable){const e=this.grid.getColumns(),t=this.grid.getSortColumns().map((t=>({sortCol:{field:e[this.grid.getColumnIndex(t.columnId)].field},sortAsc:t.sortAsc})));this.data.sort(t)}this.grid.invalidate(),this.updateLayout(!0,!0)}updateSelection(){if(this._in_selection_update)return;const{selected:e}=this.model.source,t=e.indices.map((e=>this.data.index.indexOf(e))).sort();this._in_selection_update=!0,this.grid.setSelectedRows(t),this._in_selection_update=!1;const i=this.grid.getViewport(),s=this.model.get_scroll_index(i,t);null!=s&&this.grid.scrollRowToTop(s)}newIndexColumn(){return{id:(0,u.uniqueId)(),name:this.model.index_header,field:f.DTINDEX_NAME,width:this.model.index_width,behavior:\"select\",cannotTriggerInsert:!0,resizable:!1,selectable:!1,sortable:!0,cssClass:C.cell_index,headerCssClass:C.header_index}}css_classes(){return super.css_classes().concat(C.data_table)}get autosize(){let e;return e=!0===this.model.fit_columns?i.AutosizeModes.force_fit:!1===this.model.fit_columns?i.AutosizeModes.none:i.AutosizeModes[this.model.autosize_mode],e}render(){var e;const t=this.model.columns.filter((e=>e.visible)).map((e=>Object.assign(Object.assign({},e.toColumn()),{parent:this})));let s=null;if(\"checkbox\"==this.model.selectable&&(s=new d.CheckboxSelectColumn({cssClass:C.cell_select}),t.unshift(s.getColumnDefinition())),null!=this.model.index_position){const e=this.model.index_position,i=this.newIndexColumn();-1==e?t.push(i):e<-1?t.splice(e+1,0,i):t.splice(e,0,i)}let{reorderable:o}=this.model;!o||\"undefined\"!=typeof $&&null!=$.fn&&null!=$.fn.sortable||(z||(g.logger.warn(\"jquery-ui is required to enable DataTable.reorderable\"),z=!0),o=!1);let n=-1,l=!1;const{frozen_rows:u,frozen_columns:_}=this.model,m=null==_?-1:_-1;null!=u&&(l=u<0,n=Math.abs(u));const p={enableCellNavigation:!1!==this.model.selectable,enableColumnReorder:o,autosizeColsMode:this.autosize,multiColumnSort:this.model.sortable,editable:this.model.editable,autoEdit:this.model.auto_edit,autoHeight:!1,rowHeight:this.model.row_height,frozenColumn:m,frozenRow:n,frozenBottom:l},f=null!=this.grid;if(this.data=new A(this.model.source,this.model.view),this.grid=new h.Grid(this.el,this.data,t,p),this.autosize==i.AutosizeModes.fit_viewport){this.grid.autosizeColumns();let i=0;for(const s of t)i+=null!==(e=s.width)&&void 0!==e?e:0;this._width=Math.ceil(i)}if(this.grid.onSort.subscribe(((e,t)=>{if(!this.model.sortable)return;const i=t.sortCols;null!=i&&(this.data.sort(i),this.grid.invalidate(),this.updateSelection(),this.grid.render(),this.model.header_row||this._hide_header(),this.model.update_sort_columns(i))})),!1!==this.model.selectable){this.grid.setSelectionModel(new r.RowSelectionModel({selectActiveRow:null==s})),null!=s&&this.grid.registerPlugin(s);const e={dataItemColumnValueExtractor(e,t){let i=e[t.field];return(0,c.isString)(i)&&(i=i.replace(/\\n/g,\"\\\\n\")),i},includeHeaderWhenCopying:!1};this.grid.registerPlugin(new a.CellExternalCopyManager(e)),this.grid.onSelectedRowsChanged.subscribe(((e,t)=>{this._in_selection_update||(this.model.source.selected.indices=t.rows.map((e=>this.data.index[e])))})),this.updateSelection(),this.model.header_row||this._hide_header()}f&&this.updateLayout(f,!1)}_hide_header(){for(const e of this.el.querySelectorAll(\".slick-header-columns\"))e.style.height=\"0px\";this.grid.resizeCanvas()}}i.DataTableView=M,M.__name__=\"DataTableView\";class D extends b.TableWidget{constructor(e){super(e),this._sort_columns=[]}get sort_columns(){return this._sort_columns}update_sort_columns(e){this._sort_columns=e.map((({sortCol:e,sortAsc:t})=>({field:e.field,sortAsc:t})))}get_scroll_index(e,t){return this.scroll_to_selection&&0!=t.length?(0,_.some)(t,(t=>e.top<=t&&t<=e.bottom))?null:Math.max(0,Math.min(...t)-1):null}}i.DataTable=D,l=D,D.__name__=\"DataTable\",l.prototype.default_view=M,l.define((({Array:e,Boolean:t,Int:i,Ref:s,String:o,Enum:n,Or:l,Nullable:r})=>({autosize_mode:[n(\"fit_columns\",\"fit_viewport\",\"none\",\"force_fit\"),\"force_fit\"],auto_edit:[t,!1],columns:[e(s(w.TableColumn)),[]],fit_columns:[r(t),null],frozen_columns:[r(i),null],frozen_rows:[r(i),null],sortable:[t,!0],reorderable:[t,!0],editable:[t,!1],selectable:[l(t,n(\"checkbox\")),!0],index_position:[r(i),0],index_header:[o,\"#\"],index_width:[i,40],scroll_to_selection:[t,!0],header_row:[t,!0],row_height:[i,25]}))),l.override({width:600,height:400})},\n", " 493: function _(e,t,n,o,r){var l=e(494),i=e(496);t.exports={RowSelectionModel:function(e){var t,n,o,r=[],c=this,u=new i.EventHandler,s={selectActiveRow:!0};function a(e){return function(){n||(n=!0,e.apply(this,arguments),n=!1)}}function f(e){for(var t=[],n=0;n=0&&r0&&t-1 in e)}w.fn=w.prototype={jquery:b,constructor:w,length:0,toArray:function(){return i.call(this)},get:function(e){return null==e?i.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=w.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return w.each(this,e)},map:function(e){return this.pushStack(w.map(this,(function(t,n){return e.call(t,n,t)})))},slice:function(){return this.pushStack(i.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(w.grep(this,(function(e,t){return(t+1)%2})))},odd:function(){return this.pushStack(w.grep(this,(function(e,t){return t%2})))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(n>=0&&n+~]|[\\\\x20\\\\t\\\\r\\\\n\\\\f])[\\\\x20\\\\t\\\\r\\\\n\\\\f]*\"),U=new RegExp(M+\"|>\"),X=new RegExp(F),V=new RegExp(\"^\"+I+\"$\"),G={ID:new RegExp(\"^#(\"+I+\")\"),CLASS:new RegExp(\"^\\\\.(\"+I+\")\"),TAG:new RegExp(\"^(\"+I+\"|[*])\"),ATTR:new RegExp(\"^\"+W),PSEUDO:new RegExp(\"^\"+F),CHILD:new RegExp(\"^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\([\\\\x20\\\\t\\\\r\\\\n\\\\f]*(even|odd|(([+-]|)(\\\\d*)n|)[\\\\x20\\\\t\\\\r\\\\n\\\\f]*(?:([+-]|)[\\\\x20\\\\t\\\\r\\\\n\\\\f]*(\\\\d+)|))[\\\\x20\\\\t\\\\r\\\\n\\\\f]*\\\\)|)\",\"i\"),bool:new RegExp(\"^(?:\"+R+\")$\",\"i\"),needsContext:new RegExp(\"^[\\\\x20\\\\t\\\\r\\\\n\\\\f]*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\([\\\\x20\\\\t\\\\r\\\\n\\\\f]*((?:-\\\\d)?\\\\d*)[\\\\x20\\\\t\\\\r\\\\n\\\\f]*\\\\)|)(?=[^-]|$)\",\"i\")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\\d$/i,K=/^[^{]+\\{\\s*\\[native \\w/,Z=/^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,ee=/[+~]/,te=new RegExp(\"\\\\\\\\[\\\\da-fA-F]{1,6}[\\\\x20\\\\t\\\\r\\\\n\\\\f]?|\\\\\\\\([^\\\\r\\\\n\\\\f])\",\"g\"),ne=function(e,t){var n=\"0x\"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\\0-\\x1f\\x7f]|^-?\\d)|^-$|[^\\0-\\x1f\\x7f-\\uFFFF\\w-]/g,ie=function(e,t){return t?\"\\0\"===e?\"\\ufffd\":e.slice(0,-1)+\"\\\\\"+e.charCodeAt(e.length-1).toString(16)+\" \":\"\\\\\"+e},oe=function(){p()},ae=be((function(e){return!0===e.disabled&&\"fieldset\"===e.nodeName.toLowerCase()}),{dir:\"parentNode\",next:\"legend\"});try{H.apply(D=O.call(w.childNodes),w.childNodes),D[w.childNodes.length].nodeType}catch(e){H={apply:D.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){for(var n=e.length,r=0;e[n++]=t[r++];);e.length=n-1}}}function se(e,t,r,i){var o,s,l,c,f,h,y,m=t&&t.ownerDocument,w=t?t.nodeType:9;if(r=r||[],\"string\"!=typeof e||!e||1!==w&&9!==w&&11!==w)return r;if(!i&&(p(t),t=t||d,g)){if(11!==w&&(f=Z.exec(e)))if(o=f[1]){if(9===w){if(!(l=t.getElementById(o)))return r;if(l.id===o)return r.push(l),r}else if(m&&(l=m.getElementById(o))&&x(t,l)&&l.id===o)return r.push(l),r}else{if(f[2])return H.apply(r,t.getElementsByTagName(e)),r;if((o=f[3])&&n.getElementsByClassName&&t.getElementsByClassName)return H.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!A[e+\" \"]&&(!v||!v.test(e))&&(1!==w||\"object\"!==t.nodeName.toLowerCase())){if(y=e,m=t,1===w&&(U.test(e)||z.test(e))){for((m=ee.test(e)&&ye(t.parentNode)||t)===t&&n.scope||((c=t.getAttribute(\"id\"))?c=c.replace(re,ie):t.setAttribute(\"id\",c=b)),s=(h=a(e)).length;s--;)h[s]=(c?\"#\"+c:\":scope\")+\" \"+xe(h[s]);y=h.join(\",\")}try{return H.apply(r,m.querySelectorAll(y)),r}catch(t){A(e,!0)}finally{c===b&&t.removeAttribute(\"id\")}}}return u(e.replace($,\"$1\"),t,r,i)}function ue(){var e=[];return function t(n,i){return e.push(n+\" \")>r.cacheLength&&delete t[e.shift()],t[n+\" \"]=i}}function le(e){return e[b]=!0,e}function ce(e){var t=d.createElement(\"fieldset\");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){for(var n=e.split(\"|\"),i=n.length;i--;)r.attrHandle[n[i]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)for(;n=n.nextSibling;)if(n===t)return-1;return e?1:-1}function de(e){return function(t){return\"input\"===t.nodeName.toLowerCase()&&t.type===e}}function he(e){return function(t){var n=t.nodeName.toLowerCase();return(\"input\"===n||\"button\"===n)&&t.type===e}}function ge(e){return function(t){return\"form\"in t?t.parentNode&&!1===t.disabled?\"label\"in t?\"label\"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&ae(t)===e:t.disabled===e:\"label\"in t&&t.disabled===e}}function ve(e){return le((function(t){return t=+t,le((function(n,r){for(var i,o=e([],n.length,t),a=o.length;a--;)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))}))}))}function ye(e){return e&&void 0!==e.getElementsByTagName&&e}for(t in n=se.support={},o=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||\"HTML\")},p=se.setDocument=function(e){var t,i,a=e?e.ownerDocument||e:w;return a!=d&&9===a.nodeType&&a.documentElement?(h=(d=a).documentElement,g=!o(d),w!=d&&(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener(\"unload\",oe,!1):i.attachEvent&&i.attachEvent(\"onunload\",oe)),n.scope=ce((function(e){return h.appendChild(e).appendChild(d.createElement(\"div\")),void 0!==e.querySelectorAll&&!e.querySelectorAll(\":scope fieldset div\").length})),n.attributes=ce((function(e){return e.className=\"i\",!e.getAttribute(\"className\")})),n.getElementsByTagName=ce((function(e){return e.appendChild(d.createComment(\"\")),!e.getElementsByTagName(\"*\").length})),n.getElementsByClassName=K.test(d.getElementsByClassName),n.getById=ce((function(e){return h.appendChild(e).id=b,!d.getElementsByName||!d.getElementsByName(b).length})),n.getById?(r.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute(\"id\")===t}},r.find.ID=function(e,t){if(void 0!==t.getElementById&&g){var n=t.getElementById(e);return n?[n]:[]}}):(r.filter.ID=function(e){var t=e.replace(te,ne);return function(e){var n=void 0!==e.getAttributeNode&&e.getAttributeNode(\"id\");return n&&n.value===t}},r.find.ID=function(e,t){if(void 0!==t.getElementById&&g){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode(\"id\"))&&n.value===e)return[o];for(i=t.getElementsByName(e),r=0;o=i[r++];)if((n=o.getAttributeNode(\"id\"))&&n.value===e)return[o]}return[]}}),r.find.TAG=n.getElementsByTagName?function(e,t){return void 0!==t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if(\"*\"===e){for(;n=o[i++];)1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=n.getElementsByClassName&&function(e,t){if(void 0!==t.getElementsByClassName&&g)return t.getElementsByClassName(e)},y=[],v=[],(n.qsa=K.test(d.querySelectorAll))&&(ce((function(e){var t;h.appendChild(e).innerHTML=\"\",e.querySelectorAll(\"[msallowcapture^='']\").length&&v.push(\"[*^$]=[\\\\x20\\\\t\\\\r\\\\n\\\\f]*(?:''|\\\"\\\")\"),e.querySelectorAll(\"[selected]\").length||v.push(\"\\\\[[\\\\x20\\\\t\\\\r\\\\n\\\\f]*(?:value|\"+R+\")\"),e.querySelectorAll(\"[id~=\"+b+\"-]\").length||v.push(\"~=\"),(t=d.createElement(\"input\")).setAttribute(\"name\",\"\"),e.appendChild(t),e.querySelectorAll(\"[name='']\").length||v.push(\"\\\\[[\\\\x20\\\\t\\\\r\\\\n\\\\f]*name[\\\\x20\\\\t\\\\r\\\\n\\\\f]*=[\\\\x20\\\\t\\\\r\\\\n\\\\f]*(?:''|\\\"\\\")\"),e.querySelectorAll(\":checked\").length||v.push(\":checked\"),e.querySelectorAll(\"a#\"+b+\"+*\").length||v.push(\".#.+[+~]\"),e.querySelectorAll(\"\\\\\\f\"),v.push(\"[\\\\r\\\\n\\\\f]\")})),ce((function(e){e.innerHTML=\"\";var t=d.createElement(\"input\");t.setAttribute(\"type\",\"hidden\"),e.appendChild(t).setAttribute(\"name\",\"D\"),e.querySelectorAll(\"[name=d]\").length&&v.push(\"name[\\\\x20\\\\t\\\\r\\\\n\\\\f]*[*^$|!~]?=\"),2!==e.querySelectorAll(\":enabled\").length&&v.push(\":enabled\",\":disabled\"),h.appendChild(e).disabled=!0,2!==e.querySelectorAll(\":disabled\").length&&v.push(\":enabled\",\":disabled\"),e.querySelectorAll(\"*,:x\"),v.push(\",.*:\")}))),(n.matchesSelector=K.test(m=h.matches||h.webkitMatchesSelector||h.mozMatchesSelector||h.oMatchesSelector||h.msMatchesSelector))&&ce((function(e){n.disconnectedMatch=m.call(e,\"*\"),m.call(e,\"[s!='']:x\"),y.push(\"!=\",F)})),v=v.length&&new RegExp(v.join(\"|\")),y=y.length&&new RegExp(y.join(\"|\")),t=K.test(h.compareDocumentPosition),x=t||K.test(h.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)for(;t=t.parentNode;)if(t===e)return!0;return!1},N=t?function(e,t){if(e===t)return f=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e==d||e.ownerDocument==w&&x(w,e)?-1:t==d||t.ownerDocument==w&&x(w,t)?1:c?P(c,e)-P(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return f=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==d?-1:t==d?1:i?-1:o?1:c?P(c,e)-P(c,t):0;if(i===o)return pe(e,t);for(n=e;n=n.parentNode;)a.unshift(n);for(n=t;n=n.parentNode;)s.unshift(n);for(;a[r]===s[r];)r++;return r?pe(a[r],s[r]):a[r]==w?-1:s[r]==w?1:0},d):d},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(p(e),n.matchesSelector&&g&&!A[t+\" \"]&&(!y||!y.test(t))&&(!v||!v.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(e){A(t,!0)}return se(t,d,null,[e]).length>0},se.contains=function(e,t){return(e.ownerDocument||e)!=d&&p(e),x(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=d&&p(e);var i=r.attrHandle[t.toLowerCase()],o=i&&j.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},se.escape=function(e){return(e+\"\").replace(re,ie)},se.error=function(e){throw new Error(\"Syntax error, unrecognized expression: \"+e)},se.uniqueSort=function(e){var t,r=[],i=0,o=0;if(f=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(N),f){for(;t=e[o++];)t===e[o]&&(i=r.push(o));for(;i--;)e.splice(r[i],1)}return c=null,e},i=se.getText=function(e){var t,n=\"\",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if(\"string\"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else for(;t=e[r++];)n+=i(t);return n},r=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{\">\":{dir:\"parentNode\",first:!0},\" \":{dir:\"parentNode\"},\"+\":{dir:\"previousSibling\",first:!0},\"~\":{dir:\"previousSibling\"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||\"\").replace(te,ne),\"~=\"===e[2]&&(e[3]=\" \"+e[3]+\" \"),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),\"nth\"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*(\"even\"===e[3]||\"odd\"===e[3])),e[5]=+(e[7]+e[8]||\"odd\"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||\"\":n&&X.test(n)&&(t=a(n,!0))&&(t=n.indexOf(\")\",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return\"*\"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=E[e+\" \"];return t||(t=new RegExp(\"(^|[\\\\x20\\\\t\\\\r\\\\n\\\\f])\"+e+\"(\"+M+\"|$)\"))&&E(e,(function(e){return t.test(\"string\"==typeof e.className&&e.className||void 0!==e.getAttribute&&e.getAttribute(\"class\")||\"\")}))},ATTR:function(e,t,n){return function(r){var i=se.attr(r,e);return null==i?\"!=\"===t:!t||(i+=\"\",\"=\"===t?i===n:\"!=\"===t?i!==n:\"^=\"===t?n&&0===i.indexOf(n):\"*=\"===t?n&&i.indexOf(n)>-1:\"$=\"===t?n&&i.slice(-n.length)===n:\"~=\"===t?(\" \"+i.replace(B,\" \")+\" \").indexOf(n)>-1:\"|=\"===t&&(i===n||i.slice(0,n.length+1)===n+\"-\"))}},CHILD:function(e,t,n,r,i){var o=\"nth\"!==e.slice(0,3),a=\"last\"!==e.slice(-4),s=\"of-type\"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,f,p,d,h,g=o!==a?\"nextSibling\":\"previousSibling\",v=t.parentNode,y=s&&t.nodeName.toLowerCase(),m=!u&&!s,x=!1;if(v){if(o){for(;g;){for(p=t;p=p[g];)if(s?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;h=g=\"only\"===e&&!h&&\"nextSibling\"}return!0}if(h=[a?v.firstChild:v.lastChild],a&&m){for(x=(d=(l=(c=(f=(p=v)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1])&&l[2],p=d&&v.childNodes[d];p=++d&&p&&p[g]||(x=d=0)||h.pop();)if(1===p.nodeType&&++x&&p===t){c[e]=[T,d,x];break}}else if(m&&(x=d=(l=(c=(f=(p=t)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1]),!1===x)for(;(p=++d&&p&&p[g]||(x=d=0)||h.pop())&&((s?p.nodeName.toLowerCase()!==y:1!==p.nodeType)||!++x||(m&&((c=(f=p[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]=[T,x]),p!==t)););return(x-=i)===r||x%r==0&&x/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||se.error(\"unsupported pseudo: \"+e);return i[b]?i(t):i.length>1?(n=[e,e,\"\",t],r.setFilters.hasOwnProperty(e.toLowerCase())?le((function(e,n){for(var r,o=i(e,t),a=o.length;a--;)e[r=P(e,o[a])]=!(n[r]=o[a])})):function(e){return i(e,0,n)}):i}},pseudos:{not:le((function(e){var t=[],n=[],r=s(e.replace($,\"$1\"));return r[b]?le((function(e,t,n,i){for(var o,a=r(e,null,i,[]),s=e.length;s--;)(o=a[s])&&(e[s]=!(t[s]=o))})):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}})),has:le((function(e){return function(t){return se(e,t).length>0}})),contains:le((function(e){return e=e.replace(te,ne),function(t){return(t.textContent||i(t)).indexOf(e)>-1}})),lang:le((function(e){return V.test(e||\"\")||se.error(\"unsupported lang: \"+e),e=e.replace(te,ne).toLowerCase(),function(t){var n;do{if(n=g?t.lang:t.getAttribute(\"xml:lang\")||t.getAttribute(\"lang\"))return(n=n.toLowerCase())===e||0===n.indexOf(e+\"-\")}while((t=t.parentNode)&&1===t.nodeType);return!1}})),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===h},focus:function(e){return e===d.activeElement&&(!d.hasFocus||d.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return\"input\"===t&&!!e.checked||\"option\"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return\"input\"===t&&\"button\"===e.type||\"button\"===t},text:function(e){var t;return\"input\"===e.nodeName.toLowerCase()&&\"text\"===e.type&&(null==(t=e.getAttribute(\"type\"))||\"text\"===t.toLowerCase())},first:ve((function(){return[0]})),last:ve((function(e,t){return[t-1]})),eq:ve((function(e,t,n){return[n<0?n+t:n]})),even:ve((function(e,t){for(var n=0;nt?t:n;--r>=0;)e.push(r);return e})),gt:ve((function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){for(var i=e.length;i--;)if(!e[i](t,n,r))return!1;return!0}:e[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s-1&&(o[l]=!(a[l]=f))}}else y=Te(y===a?y.splice(h,y.length):y),i?i(null,a,y,u):H.apply(a,y)}))}function Ee(e){for(var t,n,i,o=e.length,a=r.relative[e[0].type],s=a||r.relative[\" \"],u=a?1:0,c=be((function(e){return e===t}),s,!0),f=be((function(e){return P(t,e)>-1}),s,!0),p=[function(e,n,r){var i=!a&&(r||n!==l)||((t=n).nodeType?c(e,n,r):f(e,n,r));return t=null,i}];u1&&we(p),u>1&&xe(e.slice(0,u-1).concat({value:\" \"===e[u-2].type?\"*\":\"\"})).replace($,\"$1\"),n,u0,i=e.length>0,o=function(o,a,s,u,c){var f,h,v,y=0,m=\"0\",x=o&&[],b=[],w=l,C=o||i&&r.find.TAG(\"*\",c),E=T+=null==w?1:Math.random()||.1,S=C.length;for(c&&(l=a==d||a||c);m!==S&&null!=(f=C[m]);m++){if(i&&f){for(h=0,a||f.ownerDocument==d||(p(f),s=!g);v=e[h++];)if(v(f,a||d,s)){u.push(f);break}c&&(T=E)}n&&((f=!v&&f)&&y--,o&&x.push(f))}if(y+=m,n&&m!==y){for(h=0;v=t[h++];)v(x,b,a,s);if(o){if(y>0)for(;m--;)x[m]||b[m]||(b[m]=q.call(u));b=Te(b)}H.apply(u,b),c&&!o&&b.length>0&&y+t.length>1&&se.uniqueSort(u)}return c&&(T=E,l=w),x};return n?le(o):o}(o,i)),s.selector=e}return s},u=se.select=function(e,t,n,i){var o,u,l,c,f,p=\"function\"==typeof e&&e,d=!i&&a(e=p.selector||e);if(n=n||[],1===d.length){if((u=d[0]=d[0].slice(0)).length>2&&\"ID\"===(l=u[0]).type&&9===t.nodeType&&g&&r.relative[u[1].type]){if(!(t=(r.find.ID(l.matches[0].replace(te,ne),t)||[])[0]))return n;p&&(t=t.parentNode),e=e.slice(u.shift().value.length)}for(o=G.needsContext.test(e)?0:u.length;o--&&(l=u[o],!r.relative[c=l.type]);)if((f=r.find[c])&&(i=f(l.matches[0].replace(te,ne),ee.test(u[0].type)&&ye(t.parentNode)||t))){if(u.splice(o,1),!(e=i.length&&xe(u)))return H.apply(n,i),n;break}}return(p||s(e,d))(i,t,!g,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},n.sortStable=b.split(\"\").sort(N).join(\"\")===b,n.detectDuplicates=!!f,p(),n.sortDetached=ce((function(e){return 1&e.compareDocumentPosition(d.createElement(\"fieldset\"))})),ce((function(e){return e.innerHTML=\"\",\"#\"===e.firstChild.getAttribute(\"href\")}))||fe(\"type|href|height|width\",(function(e,t,n){if(!n)return e.getAttribute(t,\"type\"===t.toLowerCase()?1:2)})),n.attributes&&ce((function(e){return e.innerHTML=\"\",e.firstChild.setAttribute(\"value\",\"\"),\"\"===e.firstChild.getAttribute(\"value\")}))||fe(\"value\",(function(e,t,n){if(!n&&\"input\"===e.nodeName.toLowerCase())return e.defaultValue})),ce((function(e){return null==e.getAttribute(\"disabled\")}))||fe(R,(function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null})),se}(e);w.find=C,w.expr=C.selectors,w.expr[\":\"]=w.expr.pseudos,w.uniqueSort=w.unique=C.uniqueSort,w.text=C.getText,w.isXMLDoc=C.isXML,w.contains=C.contains,w.escapeSelector=C.escape;var E=function(e,t,n){for(var r=[],i=void 0!==n;(e=e[t])&&9!==e.nodeType;)if(1===e.nodeType){if(i&&w(e).is(n))break;r.push(e)}return r},S=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=w.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\\/\\0>:\\x20\\t\\r\\n\\f]*)[\\x20\\t\\r\\n\\f]*\\/?>(?:<\\/\\1>|)$/i;function j(e,t,n){return h(t)?w.grep(e,(function(e,r){return!!t.call(e,r,e)!==n})):t.nodeType?w.grep(e,(function(e){return e===t!==n})):\"string\"!=typeof t?w.grep(e,(function(e){return s.call(t,e)>-1!==n})):w.filter(t,e,n)}w.filter=function(e,t,n){var r=t[0];return n&&(e=\":not(\"+e+\")\"),1===t.length&&1===r.nodeType?w.find.matchesSelector(r,e)?[r]:[]:w.find.matches(e,w.grep(t,(function(e){return 1===e.nodeType})))},w.fn.extend({find:function(e){var t,n,r=this.length,i=this;if(\"string\"!=typeof e)return this.pushStack(w(e).filter((function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,\"string\"==typeof e&&k.test(e)?w(e):e||[],!1).length}});var D,q=/^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]+))$/;(w.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,\"string\"==typeof e){if(!(r=\"<\"===e[0]&&\">\"===e[e.length-1]&&e.length>=3?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:v,!0)),N.test(r[1])&&w.isPlainObject(t))for(r in t)h(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=v.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):h(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,D=w(v);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){for(;(e=e[t])&&1!==e.nodeType;);return e}w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter((function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?w.uniqueSort(o):o)},index:function(e){return e?\"string\"==typeof e?s.call(w(e),this[0]):s.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return E(e,\"parentNode\")},parentsUntil:function(e,t,n){return E(e,\"parentNode\",n)},next:function(e){return O(e,\"nextSibling\")},prev:function(e){return O(e,\"previousSibling\")},nextAll:function(e){return E(e,\"nextSibling\")},prevAll:function(e){return E(e,\"previousSibling\")},nextUntil:function(e,t,n){return E(e,\"nextSibling\",n)},prevUntil:function(e,t,n){return E(e,\"previousSibling\",n)},siblings:function(e){return S((e.parentNode||{}).firstChild,e)},children:function(e){return S(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,\"template\")&&(e=e.content||e),w.merge([],e.childNodes))}},(function(e,t){w.fn[e]=function(n,r){var i=w.map(this,t,n);return\"Until\"!==e.slice(-5)&&(r=n),r&&\"string\"==typeof r&&(i=w.filter(r,i)),this.length>1&&(H[e]||w.uniqueSort(i),L.test(e)&&i.reverse()),this.pushStack(i)}}));var P=/[^\\x20\\t\\r\\n\\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&h(i=e.promise)?i.call(e).done(t).fail(n):e&&h(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}w.Callbacks=function(e){e=\"string\"==typeof e?function(e){var t={};return w.each(e.match(P)||[],(function(e,n){t[n]=!0})),t}(e):w.extend({},e);var t,n,r,i,o=[],a=[],s=-1,u=function(){for(i=i||e.once,r=t=!0;a.length;s=-1)for(n=a.shift();++s-1;)o.splice(n,1),n<=s&&s--})),this},has:function(e){return e?w.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=a=[],o=n=\"\",this},disabled:function(){return!o},lock:function(){return i=a=[],n||t||(o=n=\"\"),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=[e,(n=n||[]).slice?n.slice():n],a.push(n),t||u()),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!r}};return l},w.extend({Deferred:function(t){var n=[[\"notify\",\"progress\",w.Callbacks(\"memory\"),w.Callbacks(\"memory\"),2],[\"resolve\",\"done\",w.Callbacks(\"once memory\"),w.Callbacks(\"once memory\"),0,\"resolved\"],[\"reject\",\"fail\",w.Callbacks(\"once memory\"),w.Callbacks(\"once memory\"),1,\"rejected\"]],r=\"pending\",i={state:function(){return r},always:function(){return o.done(arguments).fail(arguments),this},catch:function(e){return i.then(null,e)},pipe:function(){var e=arguments;return w.Deferred((function(t){w.each(n,(function(n,r){var i=h(e[r[4]])&&e[r[4]];o[r[1]]((function(){var e=i&&i.apply(this,arguments);e&&h(e.promise)?e.promise().progress(t.notify).done(t.resolve).fail(t.reject):t[r[0]+\"With\"](this,i?[e]:arguments)}))})),e=null})).promise()},then:function(t,r,i){var o=0;function a(t,n,r,i){return function(){var s=this,u=arguments,l=function(){var e,l;if(!(t=o&&(r!==M&&(s=void 0,u=[e]),n.rejectWith(s,u))}};t?c():(w.Deferred.getStackHook&&(c.stackTrace=w.Deferred.getStackHook()),e.setTimeout(c))}}return w.Deferred((function(e){n[0][3].add(a(0,e,h(i)?i:R,e.notifyWith)),n[1][3].add(a(0,e,h(t)?t:R)),n[2][3].add(a(0,e,h(r)?r:M))})).promise()},promise:function(e){return null!=e?w.extend(e,i):i}},o={};return w.each(n,(function(e,t){var a=t[2],s=t[5];i[t[1]]=a.add,s&&a.add((function(){r=s}),n[3-e][2].disable,n[3-e][3].disable,n[0][2].lock,n[0][3].lock),a.add(t[3].fire),o[t[0]]=function(){return o[t[0]+\"With\"](this===o?void 0:this,arguments),this},o[t[0]+\"With\"]=a.fireWith})),i.promise(o),t&&t.call(o,o),o},when:function(e){var t=arguments.length,n=t,r=Array(n),o=i.call(arguments),a=w.Deferred(),s=function(e){return function(n){r[e]=this,o[e]=arguments.length>1?i.call(arguments):n,--t||a.resolveWith(r,o)}};if(t<=1&&(I(e,a.done(s(n)).resolve,a.reject,!t),\"pending\"===a.state()||h(o[n]&&o[n].then)))return a.then();for(;n--;)I(o[n],s(n),a.reject);return a.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;w.Deferred.exceptionHook=function(t,n){e.console&&e.console.warn&&t&&W.test(t.name)&&e.console.warn(\"jQuery.Deferred exception: \"+t.message,t.stack,n)},w.readyException=function(t){e.setTimeout((function(){throw t}))};var F=w.Deferred();function B(){v.removeEventListener(\"DOMContentLoaded\",B),e.removeEventListener(\"load\",B),w.ready()}w.fn.ready=function(e){return F.then(e).catch((function(e){w.readyException(e)})),this},w.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--w.readyWait:w.isReady)||(w.isReady=!0,!0!==e&&--w.readyWait>0||F.resolveWith(v,[w]))}}),w.ready.then=F.then,\"complete\"===v.readyState||\"loading\"!==v.readyState&&!v.documentElement.doScroll?e.setTimeout(w.ready):(v.addEventListener(\"DOMContentLoaded\",B),e.addEventListener(\"load\",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if(\"object\"===x(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,h(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(w(e),n)})),t))for(;s1,null,!0)},removeData:function(e){return this.each((function(){Q.remove(this,e)}))}}),w.extend({queue:function(e,t,n){var r;if(e)return t=(t||\"fx\")+\"queue\",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,w.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||\"fx\";var n=w.queue(e,t),r=n.length,i=n.shift(),o=w._queueHooks(e,t);\"inprogress\"===i&&(i=n.shift(),r--),i&&(\"fx\"===t&&n.unshift(\"inprogress\"),delete o.stop,i.call(e,(function(){w.dequeue(e,t)}),o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+\"queueHooks\";return Y.get(e,n)||Y.access(e,n,{empty:w.Callbacks(\"once memory\").add((function(){Y.remove(e,[t+\"queue\",n])}))})}}),w.fn.extend({queue:function(e,t){var n=2;return\"string\"!=typeof e&&(t=e,e=\"fx\",n--),arguments.length\\x20\\t\\r\\n\\f]*)/i,ge=/^$|^module$|\\/(?:java|ecma)script/i;fe=v.createDocumentFragment().appendChild(v.createElement(\"div\")),(pe=v.createElement(\"input\")).setAttribute(\"type\",\"radio\"),pe.setAttribute(\"checked\",\"checked\"),pe.setAttribute(\"name\",\"t\"),fe.appendChild(pe),d.checkClone=fe.cloneNode(!0).cloneNode(!0).lastChild.checked,fe.innerHTML=\"\",d.noCloneChecked=!!fe.cloneNode(!0).lastChild.defaultValue,fe.innerHTML=\"\",d.option=!!fe.lastChild;var ve={thead:[1,\"\",\"
\"],col:[2,\"\",\"
\"],tr:[2,\"\",\"
\"],td:[3,\"\",\"
\"],_default:[0,\"\",\"\"]};function ye(e,t){var n;return n=void 0!==e.getElementsByTagName?e.getElementsByTagName(t||\"*\"):void 0!==e.querySelectorAll?e.querySelectorAll(t||\"*\"):[],void 0===t||t&&A(e,t)?w.merge([e],n):n}function me(e,t){for(var n=0,r=e.length;n\",\"\"]);var xe=/<|&#?\\w+;/;function be(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d-1)i&&i.push(o);else if(l=ie(o),a=ye(f.appendChild(o),\"script\"),l&&me(a),n)for(c=0;o=a[c++];)ge.test(o.type||\"\")&&n.push(o);return f}var we=/^([^.]*)(?:\\.(.+)|)/;function Te(){return!0}function Ce(){return!1}function Ee(e,t){return e===function(){try{return v.activeElement}catch(e){}}()==(\"focus\"===t)}function Se(e,t,n,r,i,o){var a,s;if(\"object\"==typeof t){for(s in\"string\"!=typeof n&&(r=r||n,n=void 0),t)Se(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&(\"string\"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Ce;else if(!i)return e;return 1===o&&(a=i,i=function(e){return w().off(e),a.apply(this,arguments)},i.guid=a.guid||(a.guid=w.guid++)),e.each((function(){w.event.add(this,t,i,r,n)}))}function ke(e,t,n){n?(Y.set(e,t,!1),w.event.add(e,t,{namespace:!1,handler:function(e){var r,o,a=Y.get(this,t);if(1&e.isTrigger&&this[t]){if(a.length)(w.event.special[t]||{}).delegateType&&e.stopPropagation();else if(a=i.call(arguments),Y.set(this,t,a),r=n(this,t),this[t](),a!==(o=Y.get(this,t))||r?Y.set(this,t,!1):o={},a!==o)return e.stopImmediatePropagation(),e.preventDefault(),o&&o.value}else a.length&&(Y.set(this,t,{value:w.event.trigger(w.extend(a[0],w.Event.prototype),a.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,t)&&w.event.add(e,t,Te)}w.event={global:{},add:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(e);if(V(e))for(n.handler&&(n=(o=n).handler,i=o.selector),i&&w.find.matchesSelector(re,i),n.guid||(n.guid=w.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(t){return void 0!==w&&w.event.triggered!==t.type?w.event.dispatch.apply(e,arguments):void 0}),l=(t=(t||\"\").match(P)||[\"\"]).length;l--;)d=g=(s=we.exec(t[l])||[])[1],h=(s[2]||\"\").split(\".\").sort(),d&&(f=w.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=w.event.special[d]||{},c=w.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&w.expr.match.needsContext.test(i),namespace:h.join(\".\")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(e,r,h,a)||e.addEventListener&&e.addEventListener(d,a)),f.add&&(f.add.call(e,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),w.event.global[d]=!0)},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){for(l=(t=(t||\"\").match(P)||[\"\"]).length;l--;)if(d=g=(s=we.exec(t[l])||[])[1],h=(s[2]||\"\").split(\".\").sort(),d){for(f=w.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp(\"(^|\\\\.)\"+h.join(\"\\\\.(?:.*\\\\.|)\")+\"(\\\\.|$)\"),a=o=p.length;o--;)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&(\"**\"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||w.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)w.event.remove(e,d+t[l],n,r,!0);w.isEmptyObject(u)&&Y.remove(e,\"handle events\")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=w.event.fix(e),l=(Y.get(this,\"events\")||Object.create(null))[u.type]||[],c=w.event.special[u.type]||{};for(s[0]=u,t=1;t=1))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&(\"click\"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n-1:w.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u\\s*$/g;function De(e,t){return A(e,\"table\")&&A(11!==t.nodeType?t:t.firstChild,\"tr\")&&w(e).children(\"tbody\")[0]||e}function qe(e){return e.type=(null!==e.getAttribute(\"type\"))+\"/\"+e.type,e}function Le(e){return\"true/\"===(e.type||\"\").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute(\"type\"),e}function He(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,\"handle events\"),s)for(n=0,r=s[i].length;n1&&\"string\"==typeof v&&!d.checkClone&&Ne.test(v))return e.each((function(i){var o=e.eq(i);y&&(t[0]=v.call(this,i,o.html())),Pe(o,t,n,r)}));if(p&&(a=(i=be(t,e[0].ownerDocument,!1,e,r)).firstChild,1===i.childNodes.length&&(i=a),a||r)){for(u=(s=w.map(ye(i,\"script\"),qe)).length;f0&&me(a,!u&&ye(e,\"script\")),s},cleanData:function(e){for(var t,n,r,i=w.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?w.event.remove(n,r):w.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),w.fn.extend({detach:function(e){return Re(this,e,!0)},remove:function(e){return Re(this,e)},text:function(e){return $(this,(function(e){return void 0===e?w.text(this):this.empty().each((function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)}))}),null,e,arguments.length)},append:function(){return Pe(this,arguments,(function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||De(this,e).appendChild(e)}))},prepend:function(){return Pe(this,arguments,(function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=De(this,e);t.insertBefore(e,t.firstChild)}}))},before:function(){return Pe(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this)}))},after:function(){return Pe(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)}))},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(w.cleanData(ye(e,!1)),e.textContent=\"\");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map((function(){return w.clone(this,e,t)}))},html:function(e){return $(this,(function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if(\"string\"==typeof e&&!Ae.test(e)&&!ve[(he.exec(e)||[\"\",\"\"])[1].toLowerCase()]){e=w.htmlPrefilter(e);try{for(;n=0&&(u+=Math.max(0,Math.ceil(e[\"offset\"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Ze(e,t,n){var r=Ie(e),i=(!d.boxSizingReliable()||n)&&\"border-box\"===w.css(e,\"boxSizing\",!1,r),o=i,a=Be(e,t,r),s=\"offset\"+t[0].toUpperCase()+t.slice(1);if(Me.test(a)){if(!n)return a;a=\"auto\"}return(!d.boxSizingReliable()&&i||!d.reliableTrDimensions()&&A(e,\"tr\")||\"auto\"===a||!parseFloat(a)&&\"inline\"===w.css(e,\"display\",!1,r))&&e.getClientRects().length&&(i=\"border-box\"===w.css(e,\"boxSizing\",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Ke(e,t,n||(i?\"border\":\"content\"),o,r,a)+\"px\"}function et(e,t,n,r,i){return new et.prototype.init(e,t,n,r,i)}w.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Be(e,\"opacity\");return\"\"===n?\"1\":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Ge.test(t),l=e.style;if(u||(t=Xe(s)),a=w.cssHooks[t]||w.cssHooks[s],void 0===n)return a&&\"get\"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];\"string\"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o=\"number\"),null!=n&&n==n&&(\"number\"!==o||u||(n+=i&&i[3]||(w.cssNumber[s]?\"\":\"px\")),d.clearCloneStyle||\"\"!==n||0!==t.indexOf(\"background\")||(l[t]=\"inherit\"),a&&\"set\"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Ge.test(t)||(t=Xe(s)),(a=w.cssHooks[t]||w.cssHooks[s])&&\"get\"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Be(e,t,r)),\"normal\"===i&&t in Qe&&(i=Qe[t]),\"\"===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),w.each([\"height\",\"width\"],(function(e,t){w.cssHooks[t]={get:function(e,n,r){if(n)return!Ve.test(w.css(e,\"display\"))||e.getClientRects().length&&e.getBoundingClientRect().width?Ze(e,t,r):We(e,Ye,(function(){return Ze(e,t,r)}))},set:function(e,n,r){var i,o=Ie(e),a=!d.scrollboxSize()&&\"absolute\"===o.position,s=(a||r)&&\"border-box\"===w.css(e,\"boxSizing\",!1,o),u=r?Ke(e,t,r,s,o):0;return s&&a&&(u-=Math.ceil(e[\"offset\"+t[0].toUpperCase()+t.slice(1)]-parseFloat(o[t])-Ke(e,t,\"border\",!1,o)-.5)),u&&(i=te.exec(n))&&\"px\"!==(i[3]||\"px\")&&(e.style[t]=n,n=w.css(e,t)),Je(0,n,u)}}})),w.cssHooks.marginLeft=$e(d.reliableMarginLeft,(function(e,t){if(t)return(parseFloat(Be(e,\"marginLeft\"))||e.getBoundingClientRect().left-We(e,{marginLeft:0},(function(){return e.getBoundingClientRect().left})))+\"px\"})),w.each({margin:\"\",padding:\"\",border:\"Width\"},(function(e,t){w.cssHooks[e+t]={expand:function(n){for(var r=0,i={},o=\"string\"==typeof n?n.split(\" \"):[n];r<4;r++)i[e+ne[r]+t]=o[r]||o[r-2]||o[0];return i}},\"margin\"!==e&&(w.cssHooks[e+t].set=Je)})),w.fn.extend({css:function(e,t){return $(this,(function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Ie(e),i=t.length;a1)}}),w.Tween=et,et.prototype={constructor:et,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||w.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(w.cssNumber[n]?\"\":\"px\")},cur:function(){var e=et.propHooks[this.prop];return e&&e.get?e.get(this):et.propHooks._default.get(this)},run:function(e){var t,n=et.propHooks[this.prop];return this.options.duration?this.pos=t=w.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):et.propHooks._default.set(this),this}},et.prototype.init.prototype=et.prototype,et.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=w.css(e.elem,e.prop,\"\"))&&\"auto\"!==t?t:0},set:function(e){w.fx.step[e.prop]?w.fx.step[e.prop](e):1!==e.elem.nodeType||!w.cssHooks[e.prop]&&null==e.elem.style[Xe(e.prop)]?e.elem[e.prop]=e.now:w.style(e.elem,e.prop,e.now+e.unit)}}},et.propHooks.scrollTop=et.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},w.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:\"swing\"},w.fx=et.prototype.init,w.fx.step={};var tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){nt&&(!1===v.hidden&&e.requestAnimationFrame?e.requestAnimationFrame(ot):e.setTimeout(ot,w.fx.interval),w.fx.tick())}function at(){return e.setTimeout((function(){tt=void 0})),tt=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i[\"margin\"+(n=ne[r])]=i[\"padding\"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners[\"*\"]),o=0,a=i.length;o1)},removeAttr:function(e){return this.each((function(){w.removeAttr(this,e)}))}}),w.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return void 0===e.getAttribute?w.prop(e,t,n):(1===o&&w.isXMLDoc(e)||(i=w.attrHooks[t.toLowerCase()]||(w.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void w.removeAttr(e,t):i&&\"set\"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+\"\"),n):i&&\"get\"in i&&null!==(r=i.get(e,t))?r:null==(r=w.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!d.radioValue&&\"radio\"===t&&A(e,\"input\")){var n=e.value;return e.setAttribute(\"type\",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)for(;n=i[r++];)e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?w.removeAttr(e,n):e.setAttribute(n,n),n}},w.each(w.expr.match.bool.source.match(/\\w+/g),(function(e,t){var n=ft[t]||w.find.attr;ft[t]=function(e,t,r){var i,o,a=t.toLowerCase();return r||(o=ft[a],ft[a]=i,i=null!=n(e,t,r)?a:null,ft[a]=o),i}}));var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(\" \")}function gt(e){return e.getAttribute&&e.getAttribute(\"class\")||\"\"}function vt(e){return Array.isArray(e)?e:\"string\"==typeof e&&e.match(P)||[]}w.fn.extend({prop:function(e,t){return $(this,w.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each((function(){delete this[w.propFix[e]||e]}))}}),w.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&w.isXMLDoc(e)||(t=w.propFix[t]||t,i=w.propHooks[t]),void 0!==n?i&&\"set\"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&\"get\"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=w.find.attr(e,\"tabindex\");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{for:\"htmlFor\",class:\"className\"}}),d.optSelected||(w.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),w.each([\"tabIndex\",\"readOnly\",\"maxLength\",\"cellSpacing\",\"cellPadding\",\"rowSpan\",\"colSpan\",\"useMap\",\"frameBorder\",\"contentEditable\"],(function(){w.propFix[this.toLowerCase()]=this})),w.fn.extend({addClass:function(e){var t,n,r,i,o,a,s,u=0;if(h(e))return this.each((function(t){w(this).addClass(e.call(this,t,gt(this)))}));if((t=vt(e)).length)for(;n=this[u++];)if(i=gt(n),r=1===n.nodeType&&\" \"+ht(i)+\" \"){for(a=0;o=t[a++];)r.indexOf(\" \"+o+\" \")<0&&(r+=o+\" \");i!==(s=ht(r))&&n.setAttribute(\"class\",s)}return this},removeClass:function(e){var t,n,r,i,o,a,s,u=0;if(h(e))return this.each((function(t){w(this).removeClass(e.call(this,t,gt(this)))}));if(!arguments.length)return this.attr(\"class\",\"\");if((t=vt(e)).length)for(;n=this[u++];)if(i=gt(n),r=1===n.nodeType&&\" \"+ht(i)+\" \"){for(a=0;o=t[a++];)for(;r.indexOf(\" \"+o+\" \")>-1;)r=r.replace(\" \"+o+\" \",\" \");i!==(s=ht(r))&&n.setAttribute(\"class\",s)}return this},toggleClass:function(e,t){var n=typeof e,r=\"string\"===n||Array.isArray(e);return\"boolean\"==typeof t&&r?t?this.addClass(e):this.removeClass(e):h(e)?this.each((function(n){w(this).toggleClass(e.call(this,n,gt(this),t),t)})):this.each((function(){var t,i,o,a;if(r)for(i=0,o=w(this),a=vt(e);t=a[i++];)o.hasClass(t)?o.removeClass(t):o.addClass(t);else void 0!==e&&\"boolean\"!==n||((t=gt(this))&&Y.set(this,\"__className__\",t),this.setAttribute&&this.setAttribute(\"class\",t||!1===e?\"\":Y.get(this,\"__className__\")||\"\"))}))},hasClass:function(e){var t,n,r=0;for(t=\" \"+e+\" \";n=this[r++];)if(1===n.nodeType&&(\" \"+ht(gt(n))+\" \").indexOf(t)>-1)return!0;return!1}});var yt=/\\r/g;w.fn.extend({val:function(e){var t,n,r,i=this[0];return arguments.length?(r=h(e),this.each((function(n){var i;1===this.nodeType&&(null==(i=r?e.call(this,n,w(this).val()):e)?i=\"\":\"number\"==typeof i?i+=\"\":Array.isArray(i)&&(i=w.map(i,(function(e){return null==e?\"\":e+\"\"}))),(t=w.valHooks[this.type]||w.valHooks[this.nodeName.toLowerCase()])&&\"set\"in t&&void 0!==t.set(this,i,\"value\")||(this.value=i))}))):i?(t=w.valHooks[i.type]||w.valHooks[i.nodeName.toLowerCase()])&&\"get\"in t&&void 0!==(n=t.get(i,\"value\"))?n:\"string\"==typeof(n=i.value)?n.replace(yt,\"\"):null==n?\"\":n:void 0}}),w.extend({valHooks:{option:{get:function(e){var t=w.find.attr(e,\"value\");return null!=t?t:ht(w.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a=\"select-one\"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r-1)&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),w.each([\"radio\",\"checkbox\"],(function(){w.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=w.inArray(w(e).val(),t)>-1}},d.checkOn||(w.valHooks[this].get=function(e){return null===e.getAttribute(\"value\")?\"on\":e.value})})),d.focusin=\"onfocusin\"in e;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};w.extend(w.event,{trigger:function(t,n,r,i){var o,a,s,u,l,f,p,d,y=[r||v],m=c.call(t,\"type\")?t.type:t,x=c.call(t,\"namespace\")?t.namespace.split(\".\"):[];if(a=d=s=r=r||v,3!==r.nodeType&&8!==r.nodeType&&!mt.test(m+w.event.triggered)&&(m.indexOf(\".\")>-1&&(x=m.split(\".\"),m=x.shift(),x.sort()),l=m.indexOf(\":\")<0&&\"on\"+m,(t=t[w.expando]?t:new w.Event(m,\"object\"==typeof t&&t)).isTrigger=i?2:3,t.namespace=x.join(\".\"),t.rnamespace=t.namespace?new RegExp(\"(^|\\\\.)\"+x.join(\"\\\\.(?:.*\\\\.|)\")+\"(\\\\.|$)\"):null,t.result=void 0,t.target||(t.target=r),n=null==n?[t]:w.makeArray(n,[t]),p=w.event.special[m]||{},i||!p.trigger||!1!==p.trigger.apply(r,n))){if(!i&&!p.noBubble&&!g(r)){for(u=p.delegateType||m,mt.test(u+m)||(a=a.parentNode);a;a=a.parentNode)y.push(a),s=a;s===(r.ownerDocument||v)&&y.push(s.defaultView||s.parentWindow||e)}for(o=0;(a=y[o++])&&!t.isPropagationStopped();)d=a,t.type=o>1?u:p.bindType||m,(f=(Y.get(a,\"events\")||Object.create(null))[t.type]&&Y.get(a,\"handle\"))&&f.apply(a,n),(f=l&&a[l])&&f.apply&&V(a)&&(t.result=f.apply(a,n),!1===t.result&&t.preventDefault());return t.type=m,i||t.isDefaultPrevented()||p._default&&!1!==p._default.apply(y.pop(),n)||!V(r)||l&&h(r[m])&&!g(r)&&((s=r[l])&&(r[l]=null),w.event.triggered=m,t.isPropagationStopped()&&d.addEventListener(m,xt),r[m](),t.isPropagationStopped()&&d.removeEventListener(m,xt),w.event.triggered=void 0,s&&(r[l]=s)),t.result}},simulate:function(e,t,n){var r=w.extend(new w.Event,n,{type:e,isSimulated:!0});w.event.trigger(r,null,t)}}),w.fn.extend({trigger:function(e,t){return this.each((function(){w.event.trigger(e,t,this)}))},triggerHandler:function(e,t){var n=this[0];if(n)return w.event.trigger(e,t,n,!0)}}),d.focusin||w.each({focus:\"focusin\",blur:\"focusout\"},(function(e,t){var n=function(e){w.event.simulate(t,e.target,w.event.fix(e))};w.event.special[t]={setup:function(){var r=this.ownerDocument||this.document||this,i=Y.access(r,t);i||r.addEventListener(e,n,!0),Y.access(r,t,(i||0)+1)},teardown:function(){var r=this.ownerDocument||this.document||this,i=Y.access(r,t)-1;i?Y.access(r,t,i):(r.removeEventListener(e,n,!0),Y.remove(r,t))}}}));var bt=e.location,wt={guid:Date.now()},Tt=/\\?/;w.parseXML=function(t){var n,r;if(!t||\"string\"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,\"text/xml\")}catch(e){}return r=n&&n.getElementsByTagName(\"parsererror\")[0],n&&!r||w.error(\"Invalid XML: \"+(r?w.map(r.childNodes,(function(e){return e.textContent})).join(\"\\n\"):t)),n};var Ct=/\\[\\]$/,Et=/\\r?\\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(e,t,n,r){var i;if(Array.isArray(t))w.each(t,(function(t,i){n||Ct.test(e)?r(e,i):At(e+\"[\"+(\"object\"==typeof i&&null!=i?t:\"\")+\"]\",i,n,r)}));else if(n||\"object\"!==x(t))r(e,t);else for(i in t)At(e+\"[\"+i+\"]\",t[i],n,r)}w.param=function(e,t){var n,r=[],i=function(e,t){var n=h(t)?t():t;r[r.length]=encodeURIComponent(e)+\"=\"+encodeURIComponent(null==n?\"\":n)};if(null==e)return\"\";if(Array.isArray(e)||e.jquery&&!w.isPlainObject(e))w.each(e,(function(){i(this.name,this.value)}));else for(n in e)At(n,e[n],t,i);return r.join(\"&\")},w.fn.extend({serialize:function(){return w.param(this.serializeArray())},serializeArray:function(){return this.map((function(){var e=w.prop(this,\"elements\");return e?w.makeArray(e):this})).filter((function(){var e=this.type;return this.name&&!w(this).is(\":disabled\")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!de.test(e))})).map((function(e,t){var n=w(this).val();return null==n?null:Array.isArray(n)?w.map(n,(function(e){return{name:t.name,value:e.replace(Et,\"\\r\\n\")}})):{name:t.name,value:n.replace(Et,\"\\r\\n\")}})).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \\t]*([^\\r\\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\\/\\//,Ot={},Pt={},Rt=\"*/\".concat(\"*\"),Mt=v.createElement(\"a\");function It(e){return function(t,n){\"string\"!=typeof t&&(n=t,t=\"*\");var r,i=0,o=t.toLowerCase().match(P)||[];if(h(n))for(;r=o[i++];)\"+\"===r[0]?(r=r.slice(1)||\"*\",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function Wt(e,t,n,r){var i={},o=e===Pt;function a(s){var u;return i[s]=!0,w.each(e[s]||[],(function(e,s){var l=s(t,n,r);return\"string\"!=typeof l||o||i[l]?o?!(u=l):void 0:(t.dataTypes.unshift(l),a(l),!1)})),u}return a(t.dataTypes[0])||!i[\"*\"]&&a(\"*\")}function Ft(e,t){var n,r,i=w.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&w.extend(!0,e,r),e}Mt.href=bt.href,w.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:\"GET\",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:\"application/x-www-form-urlencoded; charset=UTF-8\",accepts:{\"*\":Rt,text:\"text/plain\",html:\"text/html\",xml:\"application/xml, text/xml\",json:\"application/json, text/javascript\"},contents:{xml:/\\bxml\\b/,html:/\\bhtml/,json:/\\bjson\\b/},responseFields:{xml:\"responseXML\",text:\"responseText\",json:\"responseJSON\"},converters:{\"* text\":String,\"text html\":!0,\"text json\":JSON.parse,\"text xml\":w.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,w.ajaxSettings),t):Ft(w.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(t,n){\"object\"==typeof t&&(n=t,t=void 0),n=n||{};var r,i,o,a,s,u,l,c,f,p,d=w.ajaxSetup({},n),h=d.context||d,g=d.context&&(h.nodeType||h.jquery)?w(h):w.event,y=w.Deferred(),m=w.Callbacks(\"once memory\"),x=d.statusCode||{},b={},T={},C=\"canceled\",E={readyState:0,getResponseHeader:function(e){var t;if(l){if(!a)for(a={};t=qt.exec(o);)a[t[1].toLowerCase()+\" \"]=(a[t[1].toLowerCase()+\" \"]||[]).concat(t[2]);t=a[e.toLowerCase()+\" \"]}return null==t?null:t.join(\", \")},getAllResponseHeaders:function(){return l?o:null},setRequestHeader:function(e,t){return null==l&&(e=T[e.toLowerCase()]=T[e.toLowerCase()]||e,b[e]=t),this},overrideMimeType:function(e){return null==l&&(d.mimeType=e),this},statusCode:function(e){var t;if(e)if(l)E.always(e[E.status]);else for(t in e)x[t]=[x[t],e[t]];return this},abort:function(e){var t=e||C;return r&&r.abort(t),S(0,t),this}};if(y.promise(E),d.url=((t||d.url||bt.href)+\"\").replace(Ht,bt.protocol+\"//\"),d.type=n.method||n.type||d.method||d.type,d.dataTypes=(d.dataType||\"*\").toLowerCase().match(P)||[\"\"],null==d.crossDomain){u=v.createElement(\"a\");try{u.href=d.url,u.href=u.href,d.crossDomain=Mt.protocol+\"//\"+Mt.host!=u.protocol+\"//\"+u.host}catch(e){d.crossDomain=!0}}if(d.data&&d.processData&&\"string\"!=typeof d.data&&(d.data=w.param(d.data,d.traditional)),Wt(Ot,d,n,E),l)return E;for(f in(c=w.event&&d.global)&&0==w.active++&&w.event.trigger(\"ajaxStart\"),d.type=d.type.toUpperCase(),d.hasContent=!Lt.test(d.type),i=d.url.replace(jt,\"\"),d.hasContent?d.data&&d.processData&&0===(d.contentType||\"\").indexOf(\"application/x-www-form-urlencoded\")&&(d.data=d.data.replace(Nt,\"+\")):(p=d.url.slice(i.length),d.data&&(d.processData||\"string\"==typeof d.data)&&(i+=(Tt.test(i)?\"&\":\"?\")+d.data,delete d.data),!1===d.cache&&(i=i.replace(Dt,\"$1\"),p=(Tt.test(i)?\"&\":\"?\")+\"_=\"+wt.guid+++p),d.url=i+p),d.ifModified&&(w.lastModified[i]&&E.setRequestHeader(\"If-Modified-Since\",w.lastModified[i]),w.etag[i]&&E.setRequestHeader(\"If-None-Match\",w.etag[i])),(d.data&&d.hasContent&&!1!==d.contentType||n.contentType)&&E.setRequestHeader(\"Content-Type\",d.contentType),E.setRequestHeader(\"Accept\",d.dataTypes[0]&&d.accepts[d.dataTypes[0]]?d.accepts[d.dataTypes[0]]+(\"*\"!==d.dataTypes[0]?\", \"+Rt+\"; q=0.01\":\"\"):d.accepts[\"*\"]),d.headers)E.setRequestHeader(f,d.headers[f]);if(d.beforeSend&&(!1===d.beforeSend.call(h,E,d)||l))return E.abort();if(C=\"abort\",m.add(d.complete),E.done(d.success),E.fail(d.error),r=Wt(Pt,d,n,E)){if(E.readyState=1,c&&g.trigger(\"ajaxSend\",[E,d]),l)return E;d.async&&d.timeout>0&&(s=e.setTimeout((function(){E.abort(\"timeout\")}),d.timeout));try{l=!1,r.send(b,S)}catch(e){if(l)throw e;S(-1,e)}}else S(-1,\"No Transport\");function S(t,n,a,u){var f,p,v,b,T,C=n;l||(l=!0,s&&e.clearTimeout(s),r=void 0,o=u||\"\",E.readyState=t>0?4:0,f=t>=200&&t<300||304===t,a&&(b=function(e,t,n){for(var r,i,o,a,s=e.contents,u=e.dataTypes;\"*\"===u[0];)u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader(\"Content-Type\"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+\" \"+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(d,E,a)),!f&&w.inArray(\"script\",d.dataTypes)>-1&&w.inArray(\"json\",d.dataTypes)<0&&(d.converters[\"text script\"]=function(){}),b=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];for(o=c.shift();o;)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if(\"*\"===o)o=u;else if(\"*\"!==u&&u!==o){if(!(a=l[u+\" \"+o]||l[\"* \"+o]))for(i in l)if((s=i.split(\" \"))[1]===o&&(a=l[u+\" \"+s[0]]||l[\"* \"+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e.throws)t=a(t);else try{t=a(t)}catch(e){return{state:\"parsererror\",error:a?e:\"No conversion from \"+u+\" to \"+o}}}return{state:\"success\",data:t}}(d,b,E,f),f?(d.ifModified&&((T=E.getResponseHeader(\"Last-Modified\"))&&(w.lastModified[i]=T),(T=E.getResponseHeader(\"etag\"))&&(w.etag[i]=T)),204===t||\"HEAD\"===d.type?C=\"nocontent\":304===t?C=\"notmodified\":(C=b.state,p=b.data,f=!(v=b.error))):(v=C,!t&&C||(C=\"error\",t<0&&(t=0))),E.status=t,E.statusText=(n||C)+\"\",f?y.resolveWith(h,[p,C,E]):y.rejectWith(h,[E,C,v]),E.statusCode(x),x=void 0,c&&g.trigger(f?\"ajaxSuccess\":\"ajaxError\",[E,d,f?p:v]),m.fireWith(h,[E,C]),c&&(g.trigger(\"ajaxComplete\",[E,d]),--w.active||w.event.trigger(\"ajaxStop\")))}return E},getJSON:function(e,t,n){return w.get(e,t,n,\"json\")},getScript:function(e,t){return w.get(e,void 0,t,\"script\")}}),w.each([\"get\",\"post\"],(function(e,t){w[t]=function(e,n,r,i){return h(n)&&(i=i||r,r=n,n=void 0),w.ajax(w.extend({url:e,type:t,dataType:i,data:n,success:r},w.isPlainObject(e)&&e))}})),w.ajaxPrefilter((function(e){var t;for(t in e.headers)\"content-type\"===t.toLowerCase()&&(e.contentType=e.headers[t]||\"\")})),w._evalUrl=function(e,t,n){return w.ajax({url:e,type:\"GET\",dataType:\"script\",cache:!0,async:!1,global:!1,converters:{\"text script\":function(){}},dataFilter:function(e){w.globalEval(e,t,n)}})},w.fn.extend({wrapAll:function(e){var t;return this[0]&&(h(e)&&(e=e.call(this[0])),t=w(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map((function(){for(var e=this;e.firstElementChild;)e=e.firstElementChild;return e})).append(this)),this},wrapInner:function(e){return h(e)?this.each((function(t){w(this).wrapInner(e.call(this,t))})):this.each((function(){var t=w(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)}))},wrap:function(e){var t=h(e);return this.each((function(n){w(this).wrapAll(t?e.call(this,n):e)}))},unwrap:function(e){return this.parent(e).not(\"body\").each((function(){w(this).replaceWith(this.childNodes)})),this}}),w.expr.pseudos.hidden=function(e){return!w.expr.pseudos.visible(e)},w.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},w.ajaxSettings.xhr=function(){try{return new e.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=w.ajaxSettings.xhr();d.cors=!!$t&&\"withCredentials\"in $t,d.ajax=$t=!!$t,w.ajaxTransport((function(t){var n,r;if(d.cors||$t&&!t.crossDomain)return{send:function(i,o){var a,s=t.xhr();if(s.open(t.type,t.url,t.async,t.username,t.password),t.xhrFields)for(a in t.xhrFields)s[a]=t.xhrFields[a];for(a in t.mimeType&&s.overrideMimeType&&s.overrideMimeType(t.mimeType),t.crossDomain||i[\"X-Requested-With\"]||(i[\"X-Requested-With\"]=\"XMLHttpRequest\"),i)s.setRequestHeader(a,i[a]);n=function(e){return function(){n&&(n=r=s.onload=s.onerror=s.onabort=s.ontimeout=s.onreadystatechange=null,\"abort\"===e?s.abort():\"error\"===e?\"number\"!=typeof s.status?o(0,\"error\"):o(s.status,s.statusText):o(Bt[s.status]||s.status,s.statusText,\"text\"!==(s.responseType||\"text\")||\"string\"!=typeof s.responseText?{binary:s.response}:{text:s.responseText},s.getAllResponseHeaders()))}},s.onload=n(),r=s.onerror=s.ontimeout=n(\"error\"),void 0!==s.onabort?s.onabort=r:s.onreadystatechange=function(){4===s.readyState&&e.setTimeout((function(){n&&r()}))},n=n(\"abort\");try{s.send(t.hasContent&&t.data||null)}catch(e){if(n)throw e}},abort:function(){n&&n()}}})),w.ajaxPrefilter((function(e){e.crossDomain&&(e.contents.script=!1)})),w.ajaxSetup({accepts:{script:\"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript\"},contents:{script:/\\b(?:java|ecma)script\\b/},converters:{\"text script\":function(e){return w.globalEval(e),e}}}),w.ajaxPrefilter(\"script\",(function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type=\"GET\")})),w.ajaxTransport(\"script\",(function(e){var t,n;if(e.crossDomain||e.scriptAttrs)return{send:function(r,i){t=w(\"" ], "text/plain": [ ":DynamicMap [z]\n", " :Overlay\n", " .Image.I :Image [x,y] (field)\n", " .VectorField.I :VectorField [x,y] (angle,mag)" ] }, "execution_count": 5, "metadata": { "application/vnd.holoviews_exec.v0+json": { "id": "1002" } }, "output_type": "execute_result" } ], "source": [ "# NBVAL_IGNORE_OUTPUT\n", "system.m.hv(kdims=[\"x\", \"y\"])" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "We can now create an \"airbox\" in the region with $z < 0$ nm by padding the field object with zeros in the $z$ direction." ] }, { "cell_type": "code", "execution_count": 6, "metadata": {}, "outputs": [], "source": [ "m_field = system.m.pad({\"z\": (0, 20)}, mode=\"constant\")" ] }, { "cell_type": "code", "execution_count": 7, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "m_field.plane(\"x\").mpl()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Now we have a magnetisation texture we can compute the MFM patterns." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Computing MFM images" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The phase shift of an MFM cantilever can be derived from the equation of simple harmonic motion with an external force and is given by\n", "\n", "\\begin{equation}\n", "\\Delta \\phi = \\frac{Q\\mu_0}{k} \\left( q \\frac{\\partial {\\bf H}_{sz}}{\\partial z} + {\\bf M}_t \\cdot \\frac{\\partial^2{\\bf H}_{s}}{\\partial z^2} \\right),\n", "\\end{equation}\n", "\n", "where\n", "$Q$ is the quality factor of the cantilever,\n", "$k$ is the spring constant of the cantilever,\n", "$q$ is the magnetic monopole moment of the tip,\n", "${\\bf M}_t$ is the magnetic dipole moment of the tip and,\n", "${\\bf H}_{sz}$ is the magnetic field due to the sample.\n" ] }, { "cell_type": "code", "execution_count": 8, "metadata": {}, "outputs": [], "source": [ "import mag2exp" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Each component of the magnetic dipole moment of the tip can be specified to calculate a phase shift. This calculates the phase shift across the whole of the region. However, remember this is only relevant in the \"airbox\" and not inside the sample!" ] }, { "cell_type": "code", "execution_count": 9, "metadata": {}, "outputs": [], "source": [ "# NBVAL_IGNORE_OUTPUT\n", "phase_shift = mag2exp.mfm.phase_shift(m_field, quality=650, k=3, tip_m=(0, 0, 1e-16))" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The plane method can be used to easily extract the image obtained at a desired lift off height. For example, at at height of 30 nm above the surface. This is why, for simplicity, we defined the top of the sample to be at $z=0$." ] }, { "cell_type": "code", "execution_count": 10, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "# NBVAL_IGNORE_OUTPUT\n", "phase_shift.plane(z=30e-9).mpl.scalar(\n", " interpolation=\"spline16\", colorbar_label=r\"Phase shift (radians.)\"\n", ")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "We can also use `hvplot` to look at the phase shift. Here we just select the region above $z < 0$ nm" ] }, { "cell_type": "code", "execution_count": 11, "metadata": {}, "outputs": [ { "data": {}, "metadata": {}, "output_type": "display_data" }, { "data": { "application/vnd.holoviews_exec.v0+json": "", "text/html": [ "
\n", "\n", "\n", "\n", "\n", "\n", "
\n", "
\n", "" ], "text/plain": [ ":DynamicMap [z]\n", " :Image [x,y] (field)" ] }, "execution_count": 11, "metadata": { "application/vnd.holoviews_exec.v0+json": { "id": "1335" } }, "output_type": "execute_result" } ], "source": [ "# NBVAL_IGNORE_OUTPUT\n", "sub_region = df.Region(p1=(-100e-9, -100e-9, 7.5e-9), p2=(100e-9, 100e-9, 100e-9))\n", "phase_shift[sub_region].hv(kdims=[\"x\", \"y\"])" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The image below is for with a tip which has an effective monopole moment." ] }, { "cell_type": "code", "execution_count": 12, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "phase_shift_2 = mag2exp.mfm.phase_shift(m_field, quality=650, k=3, tip_q=1e-8)\n", "phase_shift_2.plane(z=30e-9).mpl.scalar(\n", " interpolation=\"spline16\", colorbar_label=r\"Phase shift (radians.)\"\n", ")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The image below is for a tip with both a monopole and a dipole." ] }, { "cell_type": "code", "execution_count": 13, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "phase_shift_3 = mag2exp.mfm.phase_shift(\n", " m_field, quality=650, k=3, tip_q=1e-9, tip_m=(0, 0, 1e-16)\n", ")\n", "phase_shift_3.plane(z=30e-9).mpl.scalar(\n", " interpolation=\"spline16\", colorbar_label=r\"Phase shift (radians.)\"\n", ")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## The finite size of the tip" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Experimentally, the size of the tip limits the resolution of the images. To recreate this the phase shift can be convolved with a Gaussian with a width defined by the full width half maximum." ] }, { "cell_type": "code", "execution_count": 14, "metadata": {}, "outputs": [], "source": [ "conv_phase = mag2exp.util.gaussian_filter(\n", " phase_shift.plane(z=30e-9), fwhm=(15e-9, 15e-9)\n", ")" ] }, { "cell_type": "code", "execution_count": 15, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "# NBVAL_IGNORE_OUTPUT\n", "conv_phase.mpl.scalar(\n", " interpolation=\"spline16\", colorbar_label=r\"Phase shift (radians.)\"\n", ")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Quick plots\n", "`mag2exp` has an integrated `quick_plots` functionality which is designed to be easy to use and output figures of the desired quantities directly from the magnetisation texture with all the intermediary calculations performed under the hood. These figures are created with set themes by design, and only take arguments relevant to the quantities being calculated.\n", "\n", "`quick_plots.mfm_phase_shift` takes the arguments of `mfm.phase_shift` with an additional parameter `z0` for the height of the plane that will be plotted." ] }, { "cell_type": "code", "execution_count": 16, "metadata": {}, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "mag2exp.quick_plots.mfm_phase_shift(m_field, z0=30e-9, tip_m=(0, 0, 1e-16))" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "It is possible to look at how the phase shift varies as a function of lift of height across the sample. Due to the phase shift spanning different orders of magnitude in both positive and negative regions we can use `BoundaryNorm` from `matplotlib` to define our colour bar." ] }, { "cell_type": "code", "execution_count": 17, "metadata": {}, "outputs": [ { "data": { "application/vnd.jupyter.widget-view+json": { "model_id": "b5f0ec15061f406389eeb995ecd58598", "version_major": 2, "version_minor": 0 }, "text/plain": [ "interactive(children=(SelectionSlider(description='x (nm)', index=20, options=((-97.5, -9.749999999999999e-08)…" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "# NBVAL_IGNORE_OUTPUT\n", "import matplotlib.colors as colors\n", "\n", "sub_phase = phase_shift[sub_region]\n", "\n", "boundaries = sorted(sub_phase.array.flat)[:: len(sub_phase.array.flat) // 100][:-1] + [\n", " np.max(sub_phase.array.flat)\n", "]\n", "\n", "\n", "@df.interact(x=system.m.mesh.slider(\"x\"))\n", "def plot(x):\n", " conv_mag2exp = sub_phase.plane(x=x)\n", " conv_mag2exp.mpl.scalar(\n", " norm=colors.BoundaryNorm(boundaries=boundaries, ncolors=256)\n", " )" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.8.13" } }, "nbformat": 4, "nbformat_minor": 4 }