{ "cells": [ { "cell_type": "markdown", "id": "196d6919", "metadata": {}, "source": [ "# Combining wxee and eemont\n", "\n", "[eemont](https://github.com/davemlz/eemont) is a Python package that adds powerful functionality like cloud masking and spectral index calculation to Earth Engine classes. Because `TimeSeries` in `wxee` are a subclass of `ee.ImageCollection`, any methods from `eemont` that work with an `ImageCollection` will also work with a `TimeSeries`! \n", "\n", "In this tutorial, we'll see how we can combine the two packages by generating monthly aggregates of cloud-masked NDVI data from MODIS." ] }, { "cell_type": "markdown", "id": "3081bca9", "metadata": {}, "source": [ "## Setup" ] }, { "cell_type": "code", "execution_count": null, "id": "bb2858a2", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T04:05:45.760299Z", "start_time": "2021-09-17T04:05:40.974940Z" } }, "outputs": [], "source": [ "# !pip install wxee\n", "# !pip install eemont" ] }, { "cell_type": "code", "execution_count": 1, "id": "739f74b7", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:48:59.749133Z", "start_time": "2021-09-17T05:48:56.756557Z" } }, "outputs": [], "source": [ "import ee\n", "import wxee\n", "import eemont\n", "\n", "ee.Authenticate()\n", "wxee.Initialize()" ] }, { "cell_type": "markdown", "id": "108cdcc1", "metadata": {}, "source": [ "## Creating a Time Series" ] }, { "cell_type": "markdown", "id": "6621091f", "metadata": {}, "source": [ "First, we'll load one year of daily imagery from the MODIS sensor as a `TimeSeries`. " ] }, { "cell_type": "code", "execution_count": 2, "id": "ebbf8669", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:49:01.515555Z", "start_time": "2021-09-17T05:49:01.512642Z" } }, "outputs": [], "source": [ "modis = wxee.TimeSeries(\"MODIS/006/MOD09GA\").filterDate(\"2020\", \"2021\")" ] }, { "cell_type": "markdown", "id": "bcb53189", "metadata": {}, "source": [ "### Pre-Processing with eemont" ] }, { "cell_type": "markdown", "id": "13d567a3", "metadata": {}, "source": [ "Now, we'll use `eemont` to mask clouds and calculate the Normalized Difference Vegetation Index (NDVI) of each image in the time series. For more details, see the eemont documentation on [cloud masking](https://eemont.readthedocs.io/en/latest/guide/maskingClouds.html) and [spectral indices](https://eemont.readthedocs.io/en/latest/guide/spectralIndices.html)." ] }, { "cell_type": "code", "execution_count": 3, "id": "2f16a21c", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:49:03.294481Z", "start_time": "2021-09-17T05:49:02.301458Z" } }, "outputs": [], "source": [ "ts = (modis\n", " .maskClouds(maskShadows=False)\n", " .scaleAndOffset()\n", " .spectralIndices(index=\"NDVI\")\n", " .select(\"NDVI\")\n", ")" ] }, { "cell_type": "markdown", "id": "9d809ce1", "metadata": {}, "source": [ "### Monthly Aggregation" ] }, { "cell_type": "markdown", "id": "f2325f4e", "metadata": {}, "source": [ "Now we'll aggregate our daily cloud-masked NDVI images to monthtly medians." ] }, { "cell_type": "code", "execution_count": 4, "id": "e0f04cd2", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:49:04.677116Z", "start_time": "2021-09-17T05:49:04.649748Z" } }, "outputs": [], "source": [ "monthly_ts = ts.aggregate_time(\"month\", ee.Reducer.median())" ] }, { "cell_type": "markdown", "id": "a3fc5b52", "metadata": {}, "source": [ "Before we download our data, we'll clip the MODIS images to a country layer in order to remove areas of ocean." ] }, { "cell_type": "code", "execution_count": 5, "id": "aebc0995", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:49:05.298601Z", "start_time": "2021-09-17T05:49:05.289927Z" } }, "outputs": [], "source": [ "countries = ee.FeatureCollection(\"FAO/GAUL_SIMPLIFIED_500m/2015/level0\")\n", "monthly_ts_land = monthly_ts.map(lambda img: img.clip(countries))" ] }, { "cell_type": "markdown", "id": "1ad4fa79", "metadata": {}, "source": [ "## Downloading the Time Series" ] }, { "cell_type": "markdown", "id": "11e0e833", "metadata": {}, "source": [ "Finally, we're ready to specify a region of interest around the African continent." ] }, { "cell_type": "code", "execution_count": 6, "id": "2fd7c6e8", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:49:07.072163Z", "start_time": "2021-09-17T05:49:07.068899Z" } }, "outputs": [], "source": [ "region = ee.Geometry.Polygon(\n", " [[[-20.94783493615687, 38.550044216461366],\n", " [-20.94783493615687, -36.736958952789465],\n", " [53.58341506384313, -36.736958952789465],\n", " [53.58341506384313, 38.550044216461366]]]\n", ")" ] }, { "cell_type": "markdown", "id": "c0e64b43", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:15:32.700991Z", "start_time": "2021-09-17T05:15:32.697404Z" } }, "source": [ "And download our `TimeSeries` to an `xarray.Dataset`!" ] }, { "cell_type": "code", "execution_count": 7, "id": "645a7781", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:50:19.205425Z", "start_time": "2021-09-17T05:49:08.050242Z" }, "scrolled": true }, "outputs": [ { "data": { "application/vnd.jupyter.widget-view+json": { "model_id": "5bb44eb6edd848d38ca954b9cd807ae1", "version_major": 2, "version_minor": 0 }, "text/plain": [ "Requesting data: 0%| | 0/12 [00:00" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" }, { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" } ], "source": [ "ds.NDVI.plot(col=\"time\", col_wrap=4, cmap=\"YlGn\", vmin=0, vmax=1, aspect=0.8)" ] }, { "cell_type": "markdown", "id": "9e631ce3", "metadata": {}, "source": [ "### The Fun Way" ] }, { "cell_type": "markdown", "id": "568df48c", "metadata": {}, "source": [ "If we want a more exciting visualization, we can use the [hvplot](https://github.com/holoviz/hvplot) library and its `xarray` module to create time series animations!" ] }, { "cell_type": "code", "execution_count": null, "id": "9f13509f", "metadata": {}, "outputs": [], "source": [ "# !pip install hvplot" ] }, { "cell_type": "code", "execution_count": 9, "id": "f50685c9", "metadata": { "ExecuteTime": { "end_time": "2021-09-17T05:50:29.349614Z", "start_time": "2021-09-17T05:50:27.881076Z" } }, "outputs": [ { "data": { "application/javascript": [ "\n", "(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", " root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length;\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': {}, 'shim': {}});\n", " \n", " }\n", " for (var i = 0; i < js_urls.length; i++) {\n", " var url = js_urls[i];\n", " if (skip.indexOf(url) >= 0) { on_load(); continue; }\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) { on_load(); continue; }\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 = [];\n", " var js_modules = [];\n", " var css_urls = [];\n", " var inline_js = [\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", " },\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", " },\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(\".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", " },\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", " },\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 padding-right: 1.5em !important;\\n overflow-wrap: break-word;\\n}\\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", " },\n", " function(Bokeh) {\n", " inject_raw_css(\"\\n .bk.pn-loading.arcs:before {\\n background-image: url(\\\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiBzdHlsZT0ibWFyZ2luOiBhdXRvOyBiYWNrZ3JvdW5kOiBub25lOyBkaXNwbGF5OiBibG9jazsgc2hhcGUtcmVuZGVyaW5nOiBhdXRvOyIgdmlld0JveD0iMCAwIDEwMCAxMDAiIHByZXNlcnZlQXNwZWN0UmF0aW89InhNaWRZTWlkIj4gIDxjaXJjbGUgY3g9IjUwIiBjeT0iNTAiIHI9IjMyIiBzdHJva2Utd2lkdGg9IjgiIHN0cm9rZT0iI2MzYzNjMyIgc3Ryb2tlLWRhc2hhcnJheT0iNTAuMjY1NDgyNDU3NDM2NjkgNTAuMjY1NDgyNDU3NDM2NjkiIGZpbGw9Im5vbmUiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCI+ICAgIDxhbmltYXRlVHJhbnNmb3JtIGF0dHJpYnV0ZU5hbWU9InRyYW5zZm9ybSIgdHlwZT0icm90YXRlIiByZXBlYXRDb3VudD0iaW5kZWZpbml0ZSIgZHVyPSIxcyIga2V5VGltZXM9IjA7MSIgdmFsdWVzPSIwIDUwIDUwOzM2MCA1MCA1MCI+PC9hbmltYXRlVHJhbnNmb3JtPiAgPC9jaXJjbGU+PC9zdmc+\\\")\\n }\\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", " var define;\n", " var 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", " var cache = {};\n", "\n", " var 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", " var prefix = \"@bokehjs/\"\n", " if (name.slice(0, prefix.length) === prefix)\n", " name = name.slice(prefix.length)\n", " }\n", "\n", " var alias = aliases[name]\n", " if (alias != null)\n", " return alias;\n", "\n", " var trailing = name.length > 0 && name[name.lenght-1] === \"/\";\n", " var index = aliases[name + (trailing ? \"\" : \"/\") + \"index\"];\n", " if (index != null)\n", " return index;\n", "\n", " return name;\n", " }\n", "\n", " var require = function(name) {\n", " var mod = cache[name];\n", " if (!mod) {\n", " var 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", " var 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", " var 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 (var name in plugin_modules) {\n", " modules[name] = plugin_modules[name];\n", " }\n", "\n", " for (var name in plugin_aliases) {\n", " aliases[name] = plugin_aliases[name];\n", " }\n", "\n", " for (var name in plugin_externals) {\n", " externals[name] = plugin_externals[name];\n", " }\n", "\n", " var plugin = require(plugin_entry);\n", "\n", " for (var 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();t(1).__exportStar(t(2),n)},\n", " function _(t,e,n,r,o){r();var a=function(t,e){return(a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])})(t,e)};n.__extends=function(t,e){function n(){this.constructor=t}a(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)};function i(t){var e=\"function\"==typeof Symbol&&Symbol.iterator,n=e&&t[e],r=0;if(n)return n.call(t);if(t&&\"number\"==typeof t.length)return{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}};throw new TypeError(e?\"Object is not iterable.\":\"Symbol.iterator is not defined.\")}function c(t,e){var n=\"function\"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var r,o,a=n.call(t),i=[];try{for(;(void 0===e||e-- >0)&&!(r=a.next()).done;)i.push(r.value)}catch(t){o={error:t}}finally{try{r&&!r.done&&(n=a.return)&&n.call(a)}finally{if(o)throw o.error}}return i}function u(t){return this instanceof u?(this.v=t,this):new u(t)}n.__assign=function(){return n.__assign=Object.assign||function(t){for(var e,n=1,r=arguments.length;n=0;c--)(o=t[c])&&(i=(a<3?o(i):a>3?o(e,n,i):o(e,n))||i);return a>3&&i&&Object.defineProperty(e,n,i),i},n.__param=function(t,e){return function(n,r){e(n,r,t)}},n.__metadata=function(t,e){if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.metadata)return Reflect.metadata(t,e)},n.__awaiter=function(t,e,n,r){return new(n||(n=Promise))((function(o,a){function i(t){try{u(r.next(t))}catch(t){a(t)}}function c(t){try{u(r.throw(t))}catch(t){a(t)}}function u(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,c)}u((r=r.apply(t,e||[])).next())}))},n.__generator=function(t,e){var n,r,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(n)throw new TypeError(\"Generator is already executing.\");for(;i;)try{if(n=1,r&&(o=2&a[0]?r.return:a[0]?r.throw||((o=r.return)&&o.call(r),0):r.next)&&!(o=o.call(r,a[1])).done)return o;switch(r=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++,r=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{(n=o[t](e)).value instanceof u?Promise.resolve(n.value.v).then(f,l):s(a[0][2],n)}catch(t){s(a[0][3],t)}var n}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])}},n.__asyncDelegator=function(t){var e,n;return e={},r(\"next\"),r(\"throw\",(function(t){throw t})),r(\"return\"),e[Symbol.iterator]=function(){return this},e;function r(r,o){e[r]=t[r]?function(e){return(n=!n)?{value:u(t[r](e)),done:\"return\"===r}:o?o(e):e}:o}},n.__asyncValues=function(t){if(!Symbol.asyncIterator)throw new TypeError(\"Symbol.asyncIterator is not defined.\");var e,n=t[Symbol.asyncIterator];return n?n.call(t):(t=i(t),e={},r(\"next\"),r(\"throw\"),r(\"return\"),e[Symbol.asyncIterator]=function(){return this},e);function r(n){e[n]=t[n]&&function(e){return new Promise((function(r,o){(function(t,e,n,r){Promise.resolve(r).then((function(e){t({value:e,done:n})}),e)})(r,o,(e=t[n](e)).done,e.value)}))}}},n.__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};n.__importStar=function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var r in t)\"default\"!==r&&Object.prototype.hasOwnProperty.call(t,r)&&n.__createBinding(e,t,r);return f(e,t),e},n.__importDefault=function(t){return t&&t.__esModule?t:{default:t}},n.__classPrivateFieldGet=function(t,e){if(!e.has(t))throw new TypeError(\"attempted to get private field on non-instance\");return e.get(t)},n.__classPrivateFieldSet=function(t,e,n){if(!e.has(t))throw new TypeError(\"attempted to set private field on non-instance\");return e.set(t,n),n}},\n", " function _(e,t,o,s,l){s();const n=e(1);l(\"version\",e(3).version),l(\"index\",e(4).index),o.embed=n.__importStar(e(4)),o.protocol=n.__importStar(e(404)),o._testing=n.__importStar(e(405));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(406).safely)},\n", " function _(n,i,o,c,e){c(),o.version=\"2.3.3\"},\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(395),l=e(397),m=e(396);var f=e(395);s(\"add_document_standalone\",f.add_document_standalone),s(\"index\",f.index),s(\"add_document_from_session\",e(397).add_document_from_session);var g=e(402);async function w(e,o,t,n){i.isString(e)&&(e=JSON.parse(_.unescape(e)));const s={};for(const[o,t]of c.entries(e))s[o]=d.Document.from_json(t);const a=[];for(const e of o){const o=m._resolve_element(e),d=m._resolve_root_elements(e);if(null!=e.docid)a.push(await 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=l._get_ws_url(t,n);r.logger.debug(`embed: computed ws url: ${s}`);try{a.push(await 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(396).BOKEH_ROOT),t.embed_item=async function(e,o){const t={},n=_.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 a.defer();const[r]=await w(t,[d]);return r},t.embed_items=async function(e,o,t,n){return await a.defer(),w(e,o,t,n)}},\n", " function _(t,_,o,r,n){r();const a=t(1);a.__exportStar(t(6),o),a.__exportStar(t(35),o)},\n", " function _(e,t,s,o,n){o();const r=e(1),i=e(7),l=e(3),_=e(19),a=e(264),c=e(14),d=e(30),h=e(15),f=e(17),u=e(31),m=e(9),g=e(13),v=r.__importStar(e(132)),w=e(26),p=e(8),b=e(319),y=e(130),k=e(53),M=e(394),j=e(35);class S{constructor(e){this.document=e,this.session=null,this.subscribed_models=new Set}send_event(e){const t=new j.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=S,S.__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 i.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 S(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 b.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&&(_.logger.info(`document idle at ${Date.now()-this._init_timestamp} ms`),this.event_manager.send_event(new a.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){null==this._interactive_plot&&(this._interactive_plot=e,this._interactive_plot.trigger_event(new a.LODStart)),this._interactive_timestamp=Date.now()}interactive_stop(){null!=this._interactive_plot&&this._interactive_plot.trigger_event(new a.LODEnd),this._interactive_plot=null,this._interactive_timestamp=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=m.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(){_.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=v.union(e,t.references());const t=new Set(this._all_models.values()),s=v.difference(t,e),o=v.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(_.logger.debug(`Adding root: ${e}`),!m.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 j.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 j.RootRemovedEvent(this,e,t))}}title(){return this._title}set_title(e,t){e!==this._title&&(this._title=e,this._trigger_on_change(new j.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 k.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 j.DocumentEventBatch)for(const s of e.events)t(s);else t(e)}_notify_change(e,t,s,o,n){this._trigger_on_change(new j.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 r of e){const e=r.id,i=r.type,l=null!==(o=r.attributes)&&void 0!==o?o:{};let _=t.get(e);null==_&&(_=E._instantiate_object(e,i,l,s),null!=r.subtype&&_.set_subtype(r.subtype)),n.set(_.id,_)}return n}static _resolve_refs(e,t,s,o){function n(e){var r;if(f.is_ref(e)){const o=null!==(r=t.get(e.id))&&void 0!==r?r:s.get(e.id);if(null!=o)return o;throw new Error(`reference ${JSON.stringify(e)} isn't known (not in Document?)`)}return u.is_NDArray_ref(e)?u.decode_NDArray(e,o):p.isArray(e)?function(e){const t=[];for(const s of e)t.push(n(s));return t}(e):p.isPlainObject(e)?function(e){const t={};for(const[s,o]of g.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:r,attributes:i}of e){const e=!t.has(r),l=e?s.get(r):t.get(r),_=E._resolve_refs(i,t,s,o);l.setv(_,{silent:!0}),n.set(r,{instance:l,is_new:e})}const r=[],i=new Set;function l(e){if(e instanceof c.HasProps){if(n.has(e.id)&&!i.has(e.id)){i.add(e.id);const{instance:t,is_new:s}=n.get(e.id),{attributes:o}=t;for(const e of g.values(o))l(e);s&&(t.finalize(),r.push(t))}}else if(p.isArray(e))for(const t of e)l(t);else if(p.isPlainObject(e))for(const t of g.values(e))l(t)}for(const e of n.values())l(e.instance);for(const e of r)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 r={kind:\"ModelChanged\",model:{id:e.id},attr:t,new:s};return c.HasProps._json_record_references(o,s,n,{recursive:!0}),r}return null}static _events_to_sync_objects(e,t,s,o){const n=Object.keys(e.attributes),r=Object.keys(t.attributes),i=m.difference(n,r),l=m.difference(r,n),a=m.intersection(n,r),c=[];for(const e of i)_.logger.warn(`Server sent key ${e} but we don't seem to have it in our JSON`);for(const n of l){const r=t.attributes[n];c.push(E._event_for_attribute_change(e,n,r,s,o))}for(const n of a){const r=e.attributes[n],i=t.attributes[n];null==r&&null==i||(null==r||null==i?c.push(E._event_for_attribute_change(e,n,i,s,o)):w.is_equal(r,i)||c.push(E._event_for_attribute_change(e,n,i,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),r=new Map,i=[];for(const t of e.roots.root_ids)r.set(t,n.get(t)),i.push(t);const l=o(s),_=new Map,a=[];for(const e of s.roots.root_ids)_.set(e,l.get(e)),a.push(e);if(i.sort(),a.sort(),m.difference(i,a).length>0||m.difference(a,i).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),l.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:l.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){_.logger.debug(\"Creating Document from JSON\");const t=e.version,s=-1!==t.indexOf(\"+\")||-1!==t.indexOf(\"-\"),o=`Library versions: JS (${l.version}) / Python (${t})`;s||l.version.replace(/-(dev|rc)\\./,\"$1\")==t?_.logger.debug(o):(_.logger.warn(\"JS/Python version mismatch\"),_.logger.warn(o));const n=new i.ModelResolver;null!=e.defs&&M.resolve_defs(e.defs,n);const r=e.roots,a=r.root_ids,c=r.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 a){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,r=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)r.set(t,s);else if(!r.has(t))throw _.logger.warn(`Got an event for unknown model ${e.model}\"`),new Error(\"event model wasn't known\");break}}const i=new Map(this._all_models),l=new Map;for(const[e,t]of r)i.has(e)||l.set(e,t);E._initialize_references_json(o,i,l,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,i,l,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 r=e.attr,_=E._resolve_refs(e.new,i,l,t);n.setv({[r]:_},{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 r=E._resolve_refs(e.new,new Map,new Map,t);if(null!=e.cols)for(const e in n.data)e in r||(r[e]=n.data[e]);n.setv({data:r},{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 y.ColumnDataSource))throw new Error(\"Cannot stream to non-ColumnDataSource\");const n=e.data,r=e.rollover;o.stream(n,r,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 y.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=r.get(t);this.add_root(o,s);break}case\"RootRemoved\":{const t=e.model.id,o=r.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),d=e(8),i=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 d.isArray(e)?e:i.values(e))if(r=t,d.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 u{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=u,u.__name__=\"ModelResolver\";const _=l.__importStar(e(38));s.register_models(_)},\n", " function _(n,r,t,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 a(n){return\"[object String]\"===u.call(n)}function l(n){const r=typeof n;return\"function\"===r||\"object\"===r&&!!n}function s(n){return l(n)&&void 0!==n[Symbol.iterator]}t.isBoolean=c,t.isNumber=f,t.isInteger=function(n){return f(n)&&Number.isInteger(n)},t.isString=a,t.isPrimitive=function(n){return null===n||c(n)||f(n)||a(n)},t.isFunction=function(n){return\"[object Function]\"===u.call(n)},t.isArray=function(n){return Array.isArray(n)},t.isArrayOf=function(n,r){return o.every(n,r)},t.isArrayableOf=function(n,r){for(let t=0,e=n.length;t0,\"'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=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 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*u;)n-=2*u;return n}function c(n,r){return a(n-r)}function f(){return Math.random()}function i(n){switch(n){case\"deg\":return u/180;case\"rad\":return 1;case\"grad\":return u/200;case\"turn\":return 2*u}}t.angle_norm=a,t.angle_dist=c,t.angle_between=function(n,r,t,e=!1){const o=c(r,t);if(0==o)return!1;if(o==2*u)return!0;const f=a(n),i=c(r,f)<=o&&c(f,t)<=o;return e?!i:i},t.random=f,t.randomIn=function(n,r){return null==r&&(r=n,n=0),n+Math.floor(Math.random()*(r-n+1))},t.atan2=function(n,r){return Math.atan2(r[1]-n[1],r[0]-n[0])},t.radians=function(n){return n*(u/180)},t.degrees=function(n){return n/(u/180)},t.resolve_angle=function(n,r){return-i(r)*n},t.to_radians_coeff=i,t.rnorm=function(n,r){let t,e;for(;t=f(),e=f(),e=(2*e-1)*Math.sqrt(1/Math.E*2),!(-4*t*t*Math.log(t)>=e*e););let o=e/t;return o=n+r*o,o},t.clamp=function(n,r,t){return nt?t:n},t.log=function(n,r=Math.E){return Math.log(n)/Math.log(r)}},\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.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 u(t){return Object.keys(t).length}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=s.concat([Object.keys(t),Object.keys(e)]);for(const o of c){const c=r.call(t,o)?t[o]:[],u=r.call(e,o)?e[o]:[];n[o]=s.union(c,u)}return n},n.size=u,n.isEmpty=function(t){return 0==u(t)},n.to_object=function(t){const e={};for(const[n,c]of t)e[n]=c;return e}},\n", " function _(t,e,s,n,r){n();const i=t(1),o=t(15),c=t(17),a=i.__importStar(t(18)),_=i.__importStar(t(21)),h=t(34),u=t(13),l=t(8),f=t(26),p=t(30),d=t(35),g=t(26),y=t(36),v=t(37),m=i.__importStar(t(21));class b extends(o.Signalable()){constructor(t={}){var e,s;super(),this._subtype=void 0,this.document=null,this.destroyed=new o.Signal0(this,\"destroyed\"),this.change=new o.Signal0(this,\"change\"),this.transformchange=new o.Signal0(this,\"transformchange\"),this.exprchange=new o.Signal0(this,\"exprchange\"),this.properties={},this._pending=!1,this._changing=!1;const n=t instanceof Map?t.get.bind(t):e=>t[e];this.id=null!==(e=n(\"id\"))&&void 0!==e?e:h.uniqueId();for(const[t,{type:e,default_value:s,options:r}]of u.entries(this._props)){let i;e instanceof a.PropertyAlias?Object.defineProperty(this.properties,t,{get:()=>this.properties[e.attr],configurable:!1,enumerable:!1}):(i=e instanceof _.Kind?new a.PrimitiveProperty(this,t,e,s,n(t),r):new e(this,t,_.Any,s,n(t),r),this.properties[t]=i)}null!==(s=n(\"__deferred__\"))&&void 0!==s&&s||(this.finalize(),this.connect_signals())}get is_syncable(){return!0}set type(t){console.warn(\"prototype.type = 'ModelName' is deprecated, use static __name__ instead\"),this.constructor.__name__=t}get type(){return this.constructor.__qualified__}static get __qualified__(){const{__module__:t,__name__:e}=this;return null!=t?`${t}.${e}`:e}static get[Symbol.toStringTag](){return this.__name__}static init_HasProps(){this.prototype._props={},this.prototype._mixins=[]}static _fix_default(t,e){if(void 0===t||l.isFunction(t))return t;if(l.isPrimitive(t))return()=>t;{const e=new v.Cloner;return()=>e.clone(t)}}static define(t){for(const[e,s]of u.entries(l.isFunction(t)?t(m):t)){if(null!=this.prototype._props[e])throw new Error(`attempted to redefine property '${this.prototype.type}.${e}'`);if(null!=this.prototype[e])throw new Error(`attempted to redefine attribute '${this.prototype.type}.${e}'`);Object.defineProperty(this.prototype,e,{get(){return this.properties[e].get_value()},set(t){return this.setv({[e]:t}),this},configurable:!1,enumerable:!0});const[t,n,r={}]=s,i={type:t,default_value:this._fix_default(n,e),options:r},o=Object.assign({},this.prototype._props);o[e]=i,this.prototype._props=o}}static internal(t){const e={};for(const[s,n]of u.entries(l.isFunction(t)?t(m):t)){const[t,r,i={}]=n;e[s]=[t,r,Object.assign(Object.assign({},i),{internal:!0})]}this.define(e)}static mixins(t){function e(t,e){const s={};for(const[n,r]of u.entries(e))s[t+n]=r;return s}const s={},n=[];for(const r of l.isArray(t)?t:[t])if(l.isArray(r)){const[t,i]=r;u.extend(s,e(t,i)),n.push([t,i])}else{const t=r;u.extend(s,t),n.push([\"\",t])}this.define(s),this.prototype._mixins=[...this.prototype._mixins,...n]}static override(t){for(const[e,s]of u.entries(t)){const t=this._fix_default(s,e),n=this.prototype._props[e];if(null==n)throw new Error(`attempted to override nonexistent '${this.prototype.type}.${e}'`);const r=Object.assign({},this.prototype._props);r[e]=Object.assign(Object.assign({},n),{default_value:t}),this.prototype._props=r}}toString(){return`${this.type}(${this.id})`}property(t){const e=this.properties[t];if(null!=e)return e;throw new Error(`unknown property ${this.type}.${t}`)}get attributes(){const t={};for(const e of this)t[e.attr]=e.get_value();return t}[v.clone](t){const e=new Map;for(const s of this)s.dirty&&e.set(s.attr,t.clone(s.get_value()));return new this.constructor(e)}[g.equals](t,e){for(const s of this){const n=t.property(s.attr);if(e.eq(s.get_value(),n.get_value()))return!1}return!0}[y.pretty](t){const e=t.token,s=[];for(const n of this)if(n.dirty){const r=n.get_value();s.push(`${n.attr}${e(\":\")} ${t.to_string(r)}`)}return`${this.constructor.__qualified__}${e(\"(\")}${e(\"{\")}${s.join(`${e(\",\")} `)}${e(\"}\")}${e(\")\")}`}[p.serialize](t){const e=this.ref();t.add_ref(this,e);const s=this.struct();for(const e of this)e.syncable&&(t.include_defaults||e.dirty)&&(s.attributes[e.attr]=t.to_serializable(e.get_value()));return t.add_def(this,s),e}finalize(){for(const t of this){if(!(t instanceof a.VectorSpec||t instanceof a.ScalarSpec))continue;const e=t.get_value();if(null!=e){const{transform:t,expr:s}=e;null!=t&&this.connect(t.change,(()=>this.transformchange.emit())),null!=s&&this.connect(s.change,(()=>this.exprchange.emit()))}}this.initialize()}initialize(){}connect_signals(){}disconnect_signals(){o.Signal.disconnectReceiver(this)}destroy(){this.disconnect_signals(),this.destroyed.emit()}clone(){return(new v.Cloner).clone(this)}_setv(t,e){const s=e.check_eq,n=[],r=this._changing;this._changing=!0;for(const[e,r]of t)!1!==s&&f.is_equal(e.get_value(),r)||(e.set_value(r),n.push(e));n.length>0&&(this._pending=!0);for(const t of n)t.change.emit();if(!r){if(!e.no_change)for(;this._pending;)this._pending=!1,this.change.emit();this._pending=!1,this._changing=!1}}setv(t,e={}){const s=u.entries(t);if(0==s.length)return;if(!0===e.silent){for(const[t,e]of s)this.properties[t].set_value(e);return}const n=new Map,r=new Map;for(const[t,e]of s){const s=this.properties[t];n.set(s,e),r.set(s,s.get_value())}this._setv(n,e);const{document:i}=this;if(null!=i){const t=[];for(const[e,s]of r)t.push([e,s,e.get_value()]);for(const[,e,s]of t)if(this._needs_invalidate(e,s)){i._invalidate_all_models();break}this._push_changes(t,e)}}getv(t){return this.property(t).get_value()}ref(){return{id:this.id}}struct(){const t={type:this.type,id:this.id,attributes:{}};return null!=this._subtype&&(t.subtype=this._subtype),t}set_subtype(t){this._subtype=t}*[Symbol.iterator](){yield*u.values(this.properties)}*syncable_properties(){for(const t of this)t.syncable&&(yield t)}serializable_attributes(){const t={};for(const e of this.syncable_properties())t[e.attr]=e.get_value();return t}static _json_record_references(t,e,s,n){const{recursive:r}=n;if(c.is_ref(e)){const n=t.get_model_by_id(e.id);null==n||s.has(n)||b._value_record_references(n,s,{recursive:r})}else if(l.isArray(e))for(const n of e)b._json_record_references(t,n,s,{recursive:r});else if(l.isPlainObject(e))for(const n of u.values(e))b._json_record_references(t,n,s,{recursive:r})}static _value_record_references(t,e,s){const{recursive:n}=s;if(t instanceof b){if(!e.has(t)&&(e.add(t),n))for(const s of t.syncable_properties()){const t=s.get_value();b._value_record_references(t,e,{recursive:n})}}else if(l.isArray(t))for(const s of t)b._value_record_references(s,e,{recursive:n});else if(l.isPlainObject(t))for(const s of u.values(t))b._value_record_references(s,e,{recursive:n})}references(){const t=new Set;return b._value_record_references(this,t,{recursive:!0}),t}_doc_attached(){}_doc_detached(){}attach_document(t){if(null!=this.document&&this.document!=t)throw new Error(\"models must be owned by only a single document\");this.document=t,this._doc_attached()}detach_document(){this._doc_detached(),this.document=null}_needs_invalidate(t,e){const s=new Set;b._value_record_references(e,s,{recursive:!1});const n=new Set;b._value_record_references(t,n,{recursive:!1});for(const t of s)if(!n.has(t))return!0;for(const t of n)if(!s.has(t))return!0;return!1}_push_changes(t,e={}){if(!this.is_syncable)return;const{document:s}=this;if(null==s)return;const{setter_id:n}=e,r=[];for(const[e,i,o]of t)e.syncable&&r.push(new d.ModelChangedEvent(s,this,e.attr,i,o,n));if(0!=r.length){let t;1==r.length?[t]=r:t=new d.DocumentEventBatch(s,r,n),s._trigger_on_change(t)}}on_change(t,e){for(const s of l.isArray(t)?t:[t])this.connect(s.change,e)}}s.HasProps=b,b.init_HasProps()},\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 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 i.defer(),function(){for(const n of f)o.remove_by(n,(n=>null==n.signal));f.clear()}()})(),f.add(n)}},\n", " function _(e,n,t,s,o){s();const a=new MessageChannel,l=new Map;a.port1.onmessage=e=>{const n=e.data,t=l.get(n);if(null!=t)try{t()}finally{l.delete(n)}};let r=1;t.defer=function(){return new Promise((e=>{const n=r++;l.set(n,e),a.port2.postMessage(n)}))}},\n", " function _(n,t,i,e,c){e();const r=n(8),s=n(13);i.is_ref=function(n){if(r.isPlainObject(n)){const t=s.keys(n);return 1==t.length&&\"id\"==t[0]}return!1}},\n", " function _(e,t,n,a,r){a(),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.NumberSpec=n.BooleanSpec=n.ScreenDistanceSpec=n.NullDistanceSpec=n.DistanceSpec=n.AngleSpec=void 0;const i=e(1),s=e(15),l=e(19),o=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 m.isPlainObject(e)&&(void 0===e.value?0:1)+(void 0===e.field?0:1)+(void 0===e.expr?0:1)==1}r(\"Uniform\",y.Uniform),r(\"UniformScalar\",y.UniformScalar),r(\"UniformVector\",y.UniformVector),n.isSpec=g;class f{constructor(e,t,n,a,r,i={}){var l;let o;if(this.obj=e,this.attr=t,this.kind=n,this.default_value=a,this._dirty=!1,this.change=new s.Signal0(this.obj,\"change\"),this.internal=null!==(l=i.internal)&&void 0!==l&&l,this.on_update=i.on_update,void 0!==r)o=r,this._dirty=!0;else{const t=this._default_override();if(void 0!==t)o=t;else{if(void 0===a)return void(this.spec={value:null});o=a(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;this.validate(e),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 L extends f{}n.Any=L,L.__name__=\"Any\";class T extends f{valid(e){return m.isArray(e)||m.isTypedArray(e)}}n.Array=T,T.__name__=\"Array\";class P extends f{valid(e){return m.isBoolean(e)}}n.Boolean=P,P.__name__=\"Boolean\";class b extends f{valid(e){return S.is_Color(e)}}n.Color=b,b.__name__=\"Color\";class w extends f{}n.Instance=w,w.__name__=\"Instance\";class q extends f{valid(e){return m.isNumber(e)}}n.Number=q,q.__name__=\"Number\";class N extends q{valid(e){return m.isNumber(e)&&(0|e)==e}}n.Int=N,N.__name__=\"Int\";class B extends q{}n.Angle=B,B.__name__=\"Angle\";class D extends q{valid(e){return m.isNumber(e)&&0<=e&&e<=1}}n.Percent=D,D.__name__=\"Percent\";class F extends f{valid(e){return m.isString(e)}}n.String=F,F.__name__=\"String\";class z extends f{valid(e){return null===e||m.isString(e)}}n.NullString=z,z.__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 m.isString(e)&&_.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;n0){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(!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 g.entries(v.log_levels))o.level\",\"*\"),t.HTTPMethod=a.Enum(\"POST\",\"GET\"),t.HexTileOrientation=a.Enum(\"pointytop\",\"flattop\"),t.HoverMode=a.Enum(\"mouse\",\"hline\",\"vline\"),t.LatLon=a.Enum(\"lat\",\"lon\"),t.LegendClickPolicy=a.Enum(\"none\",\"hide\",\"mute\"),t.LegendLocation=t.Anchor,t.LineCap=a.Enum(\"butt\",\"round\",\"square\"),t.LineJoin=a.Enum(\"miter\",\"round\",\"bevel\"),t.LineDash=a.Enum(\"solid\",\"dashed\",\"dotted\",\"dotdash\",\"dashdot\"),t.LinePolicy=a.Enum(\"prev\",\"next\",\"nearest\",\"interp\",\"none\"),t.Location=a.Enum(\"above\",\"below\",\"left\",\"right\"),t.Logo=a.Enum(\"normal\",\"grey\"),t.MarkerType=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=a.Enum(\"show\",\"ignore\"),t.Orientation=a.Enum(\"vertical\",\"horizontal\"),t.OutputBackend=a.Enum(\"canvas\",\"svg\",\"webgl\"),t.PaddingUnits=a.Enum(\"percent\",\"absolute\"),t.Place=a.Enum(\"above\",\"below\",\"left\",\"right\",\"center\"),t.PointPolicy=a.Enum(\"snap_to_data\",\"follow_mouse\",\"none\"),t.RadiusDimension=a.Enum(\"x\",\"y\",\"max\",\"min\"),t.RenderLevel=a.Enum(\"image\",\"underlay\",\"glyph\",\"guide\",\"annotation\",\"overlay\"),t.RenderMode=a.Enum(\"canvas\",\"css\"),t.ResetPolicy=a.Enum(\"standard\",\"event_only\"),t.RoundingFunction=a.Enum(\"round\",\"nearest\",\"floor\",\"rounddown\",\"ceil\",\"roundup\"),t.SelectionMode=a.Enum(\"replace\",\"append\",\"intersect\",\"subtract\"),t.Side=a.Enum(\"above\",\"below\",\"left\",\"right\"),t.SizingMode=a.Enum(\"stretch_width\",\"stretch_height\",\"stretch_both\",\"scale_width\",\"scale_height\",\"scale_both\",\"fixed\"),t.Sort=a.Enum(\"ascending\",\"descending\"),t.SpatialUnits=a.Enum(\"screen\",\"data\"),t.StartEnd=a.Enum(\"start\",\"end\"),t.StepMode=a.Enum(\"after\",\"before\",\"center\"),t.TapBehavior=a.Enum(\"select\",\"inspect\"),t.TextAlign=a.Enum(\"left\",\"right\",\"center\"),t.TextBaseline=a.Enum(\"top\",\"middle\",\"bottom\",\"alphabetic\",\"hanging\",\"ideographic\"),t.TextureRepetition=a.Enum(\"repeat\",\"repeat_x\",\"repeat_y\",\"no_repeat\"),t.TickLabelOrientation=a.Enum(\"vertical\",\"horizontal\",\"parallel\",\"normal\"),t.TooltipAttachment=a.Enum(\"horizontal\",\"vertical\",\"left\",\"right\",\"above\",\"below\"),t.UpdateMode=a.Enum(\"replace\",\"append\"),t.VerticalAlign=a.Enum(\"top\",\"middle\",\"bottom\")},\n", " function _(e,n,t,s,r){s();const i=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 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=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 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]:l.isInteger(n)?[e,s,u,c]=f(n):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*\\)$/,m=/^rgba?\\(\\s*([^\\s,]+?)\\s*,\\s*([^\\s,]+?)\\s*,\\s*([^\\s,]+?)(?:\\s*,\\s*([^\\s,]+?))?\\s*\\)$/,$=(()=>{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(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(m);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=$(n);if(null!=t)return _(t)}return null}r.css4_parse=_,r.is_Color=function(n){return!!l.isInteger(n)||(!(!l.isString(n)||null==_(n))||!(!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:new Float32Array(r)},o(\"Indices\",r(25).BitSet)},\n", " function _(t,s,r,e,i){e();const n=t(26),o=t(11);class a{constructor(t,s=0){this.size=t,this[Symbol.toStringTag]=\"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)):(o.assert(s.length==this._nwords,\"Initializer size mismatch\"),this._array=s)}clone(){return new a(this.size,new Uint32Array(this._array))}[n.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){o.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 _(t,e,s,r,n){var a,i,h,u,l,c,o,y;r();const p=t(8),_=t(11),A=t(26),d=t(30),D=t(31),N=Symbol(\"__ndarray__\");class f extends Uint8Array{constructor(t,e){super(t),this[a]=!0,this.dtype=\"uint8\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(a=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Uint8NDArray=f,f.__name__=\"Uint8NDArray\";class m extends Int8Array{constructor(t,e){super(t),this[i]=!0,this.dtype=\"int8\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(i=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Int8NDArray=m,m.__name__=\"Int8NDArray\";class g extends Uint16Array{constructor(t,e){super(t),this[h]=!0,this.dtype=\"uint16\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(h=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Uint16NDArray=g,g.__name__=\"Uint16NDArray\";class q extends Int16Array{constructor(t,e){super(t),this[u]=!0,this.dtype=\"int16\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(u=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Int16NDArray=q,q.__name__=\"Int16NDArray\";class I extends Uint32Array{constructor(t,e){super(t),this[l]=!0,this.dtype=\"uint32\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(l=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Uint32NDArray=I,I.__name__=\"Uint32NDArray\";class U extends Int32Array{constructor(t,e){super(t),this[c]=!0,this.dtype=\"int32\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(c=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Int32NDArray=U,U.__name__=\"Int32NDArray\";class w extends Float32Array{constructor(t,e){super(t),this[o]=!0,this.dtype=\"float32\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(o=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Float32NDArray=w,w.__name__=\"Float32NDArray\";class x extends Float64Array{constructor(t,e){super(t),this[y]=!0,this.dtype=\"float64\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(y=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}function z(t){return p.isObject(t)&&void 0!==t[N]}s.Float64NDArray=x,x.__name__=\"Float64NDArray\",s.is_NDArray=z,s.ndarray=function(t,e={}){let{dtype:s}=e;null==s&&(s=t instanceof ArrayBuffer||p.isArray(t)?\"float64\":(()=>{switch(!0){case t instanceof Uint8Array:return\"uint8\";case t instanceof Int8Array:return\"int8\";case t instanceof Uint16Array:return\"uint16\";case t instanceof Int16Array:return\"int16\";case t instanceof Uint32Array:return\"uint32\";case t instanceof Int32Array:return\"int32\";case t instanceof Float32Array:return\"float32\";case t instanceof Float64Array:return\"float64\";default:_.unreachable()}})());const{shape:r}=e;switch(s){case\"uint8\":return new f(t,r);case\"int8\":return new m(t,r);case\"uint16\":return new g(t,r);case\"int16\":return new q(t,r);case\"uint32\":return new I(t,r);case\"int32\":return new U(t,r);case\"float32\":return new w(t,r);case\"float64\":return new x(t,r)}}},\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){n.assert(!this._references.has(e)),this._references.set(e,r)}add_def(e,r){const t=this.get_ref(e);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 l.isObject(e)&&void 0!==e[t.serialize]}(e))return e[t.serialize](this);if(l.isArray(e)||l.isTypedArray(e)){const r=e.length,t=new Array(r);for(let i=0;i{switch(t){case\"uint8\":return new u.Uint8NDArray(a,n);case\"int8\":return new u.Int8NDArray(a,n);case\"uint16\":return new u.Uint16NDArray(a,n);case\"int16\":return new u.Int16NDArray(a,n);case\"uint32\":return new u.Uint32NDArray(a,n);case\"int32\":return new u.Int32NDArray(a,n);case\"float32\":return new u.Float32NDArray(a,n);case\"float64\":return new u.Float64NDArray(a,n)}})();return _!==s.BYTE_ORDER&&o.swap(f),f},n.encode_NDArray=function(r,e){const n={order:s.BYTE_ORDER,dtype:r.dtype,shape:r.shape};if(null!=e){const t=`${e.size}`;return e.set(t,r.buffer),Object.assign({__buffer__:t},n)}{const e={toJSON:()=>o.buffer_to_base64(r.buffer)};return Object.assign({__ndarray__:e},n)}}},\n", " function _(t,e,n,r,f){r(),n.buffer_to_base64=function(t){const e=new Uint8Array(t),n=Array.from(e).map((t=>String.fromCharCode(t)));return btoa(n.join(\"\"))},n.base64_to_buffer=function(t){const e=atob(t),n=e.length,r=new Uint8Array(n);for(let t=0,f=n;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,r,n,i,e){i();const s=t(8),o=t(13);n.pretty=Symbol(\"pretty\");class c{constructor(t){this.precision=null==t?void 0:t.precision}to_string(t){return function(t){return s.isObject(t)&&void 0!==t[n.pretty]}(t)?t[n.pretty](this):s.isBoolean(t)?this.boolean(t):s.isNumber(t)?this.number(t):s.isString(t)?this.string(t):s.isArray(t)?this.array(t):s.isIterable(t)?this.iterable(t):s.isPlainObject(t)?this.object(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,\"\\\\'\")}\"`}array(t){const r=this.token,n=[];for(const r of t)n.push(this.to_string(r));return`${r(\"[\")}${n.join(`${r(\",\")} `)}${r(\"]\")}`}iterable(t){var r;const n=this.token,i=null!==(r=Object(t)[Symbol.toStringTag])&&void 0!==r?r:\"Object\",e=this.array(t);return`${i}${n(\"(\")}${e}${n(\")\")}`}object(t){const r=this.token,n=[];for(const[i,e]of o.entries(t))n.push(`${i}${r(\":\")} ${this.to_string(e)}`);return`${r(\"{\")}${n.join(`${r(\",\")} `)}${r(\"}\")}`}}n.Printer=c,c.__name__=\"Printer\",n.to_string=function(t,r){return new c(r).to_string(t)}},\n", " function _(n,o,r,e,t){e();const l=n(13),i=n(8);function c(n){return 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(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=a,a.__name__=\"AnnotationView\";class l extends o.Renderer{constructor(t){super(t)}static init_Annotation(){this.override({level:\"annotation\"})}}i.Annotation=l,l.__name__=\"Annotation\",l.init_Annotation()},\n", " function _(e,i,t,n,s){n();const r=e(1),a=e(42),_=r.__importStar(e(45)),o=e(20),l=e(53),d=e(54);class h extends a.View{get coordinates(){const{_coordinates:e}=this;return null!=e?e:this._coordinates=this._initialize_coordinates()}initialize(){super.initialize(),this.visuals=new _.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()))}_initialize_coordinates(){const{x_range_name:e,y_range_name:i}=this.model,{frame:t}=this.plot_view,n=t.x_scales.get(e),s=t.y_scales.get(i);return new d.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)}notify_finished(){this.plot_view.notify_finished()}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=h,h.__name__=\"RendererView\";class c extends l.Model{constructor(e){super(e)}static init_Renderer(){this.define((({Boolean:e,String:i})=>({level:[o.RenderLevel,\"image\"],visible:[e,!0],x_range_name:[i,\"default\"],y_range_name:[i,\"default\"]})))}}t.Renderer=c,c.__name__=\"Renderer\",c.init_Renderer()},\n", " function _(t,e,s,i,n){i();const r=t(1),o=t(15),h=t(43),l=t(8),a=r.__importDefault(t(44));class _{constructor(t){this.removed=new o.Signal0(this,\"removed\"),this._ready=Promise.resolve(void 0),this._slots=new WeakMap;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=h.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}assert_root(){if(!this.is_root)throw new Error(`${this.toString()} is not a root layout`)}has_finished(){return this._has_finished}get is_idle(){return this.has_finished()}connect_signals(){}disconnect_signals(){o.Signal.disconnect_receiver(this)}on_change(t,e){for(const s of 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[a.default]}}s.View=_,_.__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\");for(let[t,n]of l.entries(e))if(null!=n&&(!s.isBoolean(n)||n))if(\"class\"===t&&(s.isString(n)&&(n=n.split(/\\s+/)),s.isArray(n)))for(const t of n)null!=t&&i.classList.add(t);else if(\"style\"===t&&s.isPlainObject(n))for(const[t,e]of l.entries(n))i.style[t]=e;else if(\"data\"===t&&s.isPlainObject(n))for(const[t,e]of l.entries(n))i.dataset[t]=e;else i.setAttribute(t,n);function o(t){if(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(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 u(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 f(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.nbsp=function(){return document.createTextNode(\" \")},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=u,n.size=f,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}}=u(t),{width:s,height:l}=f(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}=u(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 l=e(1),n=e(46);c(\"Line\",n.Line),c(\"LineScalar\",n.LineScalar),c(\"LineVector\",n.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=l.__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 n.Line(e,t);case u.LineScalar:return new n.LineScalar(e,t);case u.LineVector:return new n.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\")}})();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 n=e(1),a=e(47),o=n.__importStar(e(48)),r=e(22),_=e(8);function h(e){if(_.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=h;class c extends a.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)}set_value(e){const t=this.line_color.get_value(),i=this.line_alpha.get_value();e.strokeStyle=r.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=h(this.line_dash.get_value()),e.lineDashOffset=this.line_dash_offset.get_value()}}i.Line=c,c.__name__=\"Line\";class u extends a.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)}set_value(e){const t=this.line_color.value,i=this.line_alpha.value;e.strokeStyle=r.color2css(t,i),e.lineWidth=this.line_width.value,e.lineJoin=this.line_join.value,e.lineCap=this.line_cap.value,e.lineDash=h(this.line_dash.value),e.lineDashOffset=this.line_dash_offset.value}}i.LineScalar=u,u.__name__=\"LineScalar\";class d extends a.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}set_vectorize(e,t){const i=this.line_color.get(t),l=this.line_alpha.get(t),s=this.line_width.get(t),n=this.line_join.get(t),a=this.line_cap.get(t),o=this.line_dash.get(t),_=this.line_dash_offset.get(t);e.strokeStyle=r.color2css(i,l),e.lineWidth=s,e.lineJoin=n,e.lineCap=a,e.lineDash=h(o),e.lineDashOffset=_}}i.LineVector=d,d.__name__=\"LineVector\",c.prototype.type=\"line\",c.prototype.attrs=Object.keys(o.Line),u.prototype.type=\"line\",u.prototype.attrs=Object.keys(o.LineScalar),d.prototype.type=\"line\",d.prototype.attrs=Object.keys(o.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)}this.update()}*[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=r.__importStar(e(18)),n=e(20),i=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 _.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 o=l(1),a=l(47),r=o.__importStar(l(48)),c=l(22);class _ extends a.VisualProperties{get doit(){const l=this.fill_color.get_value(),t=this.fill_alpha.get_value();return!(null==l||0==t)}set_value(l){const t=this.fill_color.get_value(),e=this.fill_alpha.get_value();l.fillStyle=c.color2css(t,e)}}e.Fill=_,_.__name__=\"Fill\";class n extends a.VisualUniforms{get doit(){const l=this.fill_color.value,t=this.fill_alpha.value;return!(0==l||0==t)}set_value(l){const t=this.fill_color.value,e=this.fill_alpha.value;l.fillStyle=c.color2css(t,e)}}e.FillScalar=n,n.__name__=\"FillScalar\";class p extends a.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}set_vectorize(l,t){const e=this.fill_color.get(t),i=this.fill_alpha.get(t);l.fillStyle=c.color2css(e,i)}}e.FillVector=p,p.__name__=\"FillVector\",_.prototype.type=\"fill\",_.prototype.attrs=Object.keys(r.Fill),n.prototype.type=\"fill\",n.prototype.attrs=Object.keys(r.FillScalar),p.prototype.type=\"fill\",p.prototype.attrs=Object.keys(r.FillVector)},\n", " function _(t,e,s,l,a){l();const o=t(1),_=t(47),i=o.__importStar(t(48)),n=t(22);class x extends _.VisualProperties{get doit(){const t=this.text_color.get_value(),e=this.text_alpha.get_value();return!(null==t||0==e)}set_value(t){const e=this.text_color.get_value(),s=this.text_alpha.get_value();t.fillStyle=n.color2css(e,s),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()}`}}s.Text=x,x.__name__=\"Text\";class r extends _.VisualUniforms{get doit(){const t=this.text_color.value,e=this.text_alpha.value;return!(0==t||0==e)}set_value(t){const e=this.text_color.value,s=this.text_alpha.value,l=this.font_value(),a=this.text_align.value,o=this.text_baseline.value;t.fillStyle=n.color2css(e,s),t.font=l,t.textAlign=a,t.textBaseline=o}font_value(){return`${this.text_font_style.value} ${this.text_font_size.value} ${this.text_font.value}`}}s.TextScalar=r,r.__name__=\"TextScalar\";class u extends _.VisualUniforms{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 s=this.text_color.get(e),l=this.text_alpha.get(e),a=this.font_value(e),o=this.text_align.get(e),_=this.text_baseline.get(e);t.fillStyle=n.color2css(s,l),t.font=a,t.textAlign=o,t.textBaseline=_}font_value(t){return`${this.text_font_style.get(t)} ${this.text_font_size.get(t)} ${this.text_font.get(t)}`}}s.TextVector=u,u.__name__=\"TextVector\",x.prototype.type=\"text\",x.prototype.attrs=Object.keys(i.Text),r.prototype.type=\"text\",r.prototype.attrs=Object.keys(i.TextScalar),u.prototype.type=\"text\",u.prototype.attrs=Object.keys(i.TextVector)},\n", " function _(t,e,a,h,r){h();const i=t(1),s=t(47),c=t(52),n=i.__importStar(t(18)),_=i.__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(),h=this.hatch_pattern.get_value(),r=this.hatch_weight.get_value(),i=t=>{this._hatch_image=t},s=this.hatch_extra.get_value()[h];if(null!=s){const h=s.get_pattern(t,e,a,r);if(h instanceof Promise){const{_update_iteration:t}=this;h.then((e=>{this._update_iteration==t&&(i(e),this.obj.request_render())}))}else i(h)}else{const s=this.obj.canvas.create_layer(),n=c.get_pattern(s,h,t,e,a,r);i(n)}}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)}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 n.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,h=this.hatch_scale.value,r=this.hatch_pattern.value,i=this.hatch_weight.value,s=e=>{this._hatch_image=new n.UniformScalar(e,t)},_=this.hatch_extra.value[r];if(null!=_){const t=_.get_pattern(e,a,h,i);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(),n=c.get_pattern(t,r,e,a,h,i);s(n)}}get doit(){return this._static_doit}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 n.UniformScalar(null,t),this._static_doit=this._compute_static_doit(),!this._static_doit)return;const e=(t,e,a,h,r,i)=>{const s=this.hatch_extra.value[t];if(null!=s){const t=s.get_pattern(e,a,h,r);if(t instanceof Promise){const{_update_iteration:e}=this;t.then((t=>{this._update_iteration==e&&(i(t),this.obj.request_render())}))}else i(t)}else{const s=this.obj.canvas.create_layer(),n=c.get_pattern(s,t,e,a,h,r);i(n)}};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,h=this.hatch_alpha.value,r=this.hatch_scale.value;e(this.hatch_pattern.value,a,h,r,this.hatch_weight.value,(e=>{this._hatch_image=new n.UniformScalar(e,t)}))}else{const a=new Array(t);a.fill(null),this._hatch_image=new n.UniformVector(a);for(let h=0;h{a[h]=t}))}}}get doit(){return this._static_doit}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=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){n();const a=e(14),i=e(8),r=e(13),l=e(19);class o extends a.HasProps{constructor(e){super(e)}get is_syncable(){return this.syncable}static init_Model(){this.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]})))}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):l.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 r.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(){r.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(i.isString(e))return[...this.references()].filter((t=>t instanceof o&&t.name===e));if(e.prototype instanceof a.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=o,o.__name__=\"Model\",o.init_Model()},\n", " function _(s,e,_,t,a){t();class r{constructor(s,e){this.x_scale=s,this.y_scale=e,this.x_range=this.x_scale.source_range,this.y_range=this.y_scale.source_range,this.ranges=[this.x_range,this.y_range],this.scales=[this.x_scale,this.y_scale]}map_to_screen(s,e){return[this.x_scale.v_compute(s),this.y_scale.v_compute(e)]}map_from_screen(s,e){return[this.x_scale.v_invert(s),this.y_scale.v_invert(e)]}}_.CoordinateTransform=r,r.__name__=\"CoordinateTransform\"},\n", " function _(t,e,s,a,i){a();const n=t(1),_=t(56),r=t(133),o=t(48),l=t(20),d=t(24),h=t(122),c=n.__importStar(t(18)),u=t(10);class v extends _.DataAnnotationView{async lazy_initialize(){await super.lazy_initialize();const{start:t,end:e}=this.model;null!=t&&(this.start=await h.build_view(t,{parent:this})),null!=e&&(this.end=await h.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 d.ScreenArray(n);for(let t=0;t({x_start:[c.XCoordinateSpec,{field:\"x_start\"}],y_start:[c.YCoordinateSpec,{field:\"y_start\"}],start_units:[l.SpatialUnits,\"data\"],start:[e(t(r.ArrowHead)),null],x_end:[c.XCoordinateSpec,{field:\"x_end\"}],y_end:[c.YCoordinateSpec,{field:\"y_end\"}],end_units:[l.SpatialUnits,\"data\"],end:[e(t(r.ArrowHead)),()=>new r.OpenHead]})))}}s.Arrow=p,p.__name__=\"Arrow\",p.init_Arrow()},\n", " function _(t,n,s,a,e){a();const i=t(1),o=t(40),c=t(57),_=t(130),r=t(65),l=i.__importStar(t(18));class h extends o.AnnotationView{constructor(){super(...arguments),this._initial_set_data=!1}connect_signals(){super.connect_signals();const t=()=>{this.set_data(this.model.source),this.request_render()};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)}set_data(t){const n=this;for(const s of this.model)if(s instanceof l.VectorSpec||s instanceof l.ScalarSpec)if(s instanceof l.BaseCoordinateSpec){const a=s.array(t);n[`_${s.attr}`]=a}else{const a=s.uniform(t);n[`${s.attr}`]=a}this.plot_model.use_map&&(null!=n._x&&r.inplace.project_xy(n._x,n._y),null!=n._xs&&r.inplace.project_xsys(n._xs,n._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)}}s.DataAnnotationView=h,h.__name__=\"DataAnnotationView\";class u extends o.Annotation{constructor(t){super(t)}static init_DataAnnotation(){this.define((({Ref:t})=>({source:[t(c.ColumnarDataSource),()=>new _.ColumnDataSource]})))}}s.DataAnnotation=u,u.__name__=\"DataAnnotation\",u.init_DataAnnotation()},\n", " function _(t,e,n,a,i){a();const s=t(58),r=t(15),l=t(19),o=t(60),c=t(8),u=t(9),h=t(13),g=t(59),d=t(129),_=t(29);class m extends s.DataSource{constructor(t){super(t)}get_array(t){let e=this.data[t];return null==e?this.data[t]=e=[]:c.isArray(e)||(this.data[t]=e=Array.from(e)),e}static init_ColumnarDataSource(){this.define((({Ref:t})=>({selection_policy:[t(d.SelectionPolicy),()=>new d.UnionRenderers]}))),this.internal((({AnyRef:t})=>({selection_manager:[t(),t=>new o.SelectionManager({source:t})],inspected:[t(),()=>new g.Selection]})))}initialize(){super.initialize(),this._select=new r.Signal0(this,\"select\"),this.inspect=new r.Signal(this,\"inspect\"),this.streaming=new r.Signal0(this,\"streaming\"),this.patching=new r.Signal(this,\"patching\")}get_column(t){const e=this.data[t];return null!=e?e:null}columns(){return h.keys(this.data)}get_length(t=!0){const e=u.uniq(h.values(this.data).map((t=>_.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 l.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=m,m.__name__=\"ColumnarDataSource\",m.init_ColumnarDataSource()},\n", " function _(e,t,c,n,a){n();const o=e(53),i=e(59);class s extends o.Model{constructor(e){super(e)}static init_DataSource(){this.define((({Ref:e})=>({selected:[e(i.Selection),()=>new i.Selection]})))}}c.DataSource=s,s.__name__=\"DataSource\",s.init_DataSource()},\n", " function _(i,e,s,t,n){t();const l=i(53),c=i(9),h=i(13);class d extends l.Model{constructor(i){super(i)}get_view(){return this.view}static init_Selection(){this.define((({Int:i,Array:e,Dict:s})=>({indices:[e(i),[]],line_indices:[e(i),[]],multiline_indices:[s(e(i)),{}]}))),this.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})),[]]})))}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.selected_glyphs=i.selected_glyphs,this.view=i.view,this.multiline_indices=i.multiline_indices,this.image_indices=i.image_indices;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.view=null,this.selected_glyphs=[]}is_empty(){return 0==this.indices.length&&0==this.line_indices.length&&0==this.image_indices.length}update_through_union(i){this.indices=c.union(this.indices,i.indices),this.selected_glyphs=c.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=c.union(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}update_through_intersection(i){this.indices=c.intersection(this.indices,i.indices),this.selected_glyphs=c.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=c.union(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}update_through_subtraction(i){this.indices=c.difference(this.indices,i.indices),this.selected_glyphs=c.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=c.union(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}}s.Selection=d,d.__name__=\"Selection\",d.init_Selection()},\n", " function _(e,t,s,n,i){n();const o=e(14),c=e(59),r=e(61),l=e(123);class p extends o.HasProps{constructor(e){super(e),this.inspectors=new Map}static init_SelectionManager(){this.internal((({AnyRef:e})=>({source:[e()]})))}select(e,t,s,n=\"replace\"){const i=[],o=[];for(const t of e)t instanceof r.GlyphRendererView?i.push(t):t instanceof l.GraphRendererView&&o.push(t);let c=!1;for(const e of o){const i=e.model.selection_policy.hit_test(t,e);c=c||e.model.selection_policy.do_selection(i,e.model,s,n)}if(i.length>0){const e=this.source.selection_policy.hit_test(t,i);c=c||this.source.selection_policy.do_selection(e,this.source,s,n)}return c}inspect(e,t){let s=!1;if(e instanceof r.GlyphRendererView){const n=e.hit_test(t);if(null!=n){s=!n.is_empty();const i=this.get_or_create_inspector(e.model);i.update(n,!0,\"replace\"),this.source.setv({inspected:i},{silent:!0}),this.source.inspect.emit([e.model,{geometry:t}])}}else if(e instanceof l.GraphRendererView){const n=e.model.inspection_policy.hit_test(t,e);s=s||e.model.inspection_policy.do_inspection(n,t,e,!1,\"replace\")}return s}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 c.Selection,this.inspectors.set(e,t)),t}}s.SelectionManager=p,p.__name__=\"SelectionManager\",p.init_SelectionManager()},\n", " function _(e,t,i,s,l){s();const h=e(62),n=e(63),o=e(116),a=e(117),c=e(119),d=e(98),_=e(57),r=e(120),p=e(24),g=e(12),u=e(9),y=e(13),m=e(122),v=e(104),f={fill:{},line:{}},w={fill:{fill_alpha:.3,fill_color:\"grey\"},line:{line_alpha:.3,line_color:\"grey\"}},b={fill:{fill_alpha:.2},line:{}};class V extends h.DataRendererView{get glyph_view(){return this.glyph}async lazy_initialize(){var e,t;await super.lazy_initialize();const i=this.model.glyph;this.glyph=await this.build_glyph_view(i);const s=\"fill\"in this.glyph.visuals,l=\"line\"in this.glyph.visuals,h=Object.assign({},i.attributes);function n(e){const t=y.clone(h);return s&&y.extend(t,e.fill),l&&y.extend(t,e.line),new i.constructor(t)}delete h.id;let{selection_glyph:o}=this.model;null==o?o=n({fill:{},line:{}}):\"auto\"==o&&(o=n(f)),this.selection_glyph=await this.build_glyph_view(o);let{nonselection_glyph:a}=this.model;null==a?a=n({fill:{},line:{}}):\"auto\"==a&&(a=n(b)),this.nonselection_glyph=await this.build_glyph_view(a);const{hover_glyph:c}=this.model;null!=c&&(this.hover_glyph=await this.build_glyph_view(c));const{muted_glyph:d}=this.model;null!=d&&(this.muted_glyph=await this.build_glyph_view(d));const _=n(w);this.decimated_glyph=await this.build_glyph_view(_),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),null===(t=this.muted_glyph)||void 0===t||t.set_base(this.glyph),this.decimated_glyph.set_base(this.glyph),this.set_data()}async build_glyph_view(e){return m.build_view(e,{parent:this})}remove(){var e,t;this.glyph.remove(),this.selection_glyph.remove(),this.nonselection_glyph.remove(),null===(e=this.hover_glyph)||void 0===e||e.remove(),null===(t=this.muted_glyph)||void 0===t||t.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),null!=this.muted_glyph&&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 p.Indices(l);for(let e=0;e!d||d.is_empty()?[]:d.selected_glyph?this.model.view.convert_indices_from_subset(i):d.indices.length>0?d.indices:Object.keys(d.multiline_indices).map((e=>parseInt(e))))()),r=g.filter(i,(e=>_.has(t[e]))),{lod_threshold:p}=this.plot_model;let y,m,v;if(null!=this.model.document&&this.model.document.interactive_duration()>0&&!e&&null!=p&&t.length>p?(i=[...this.decimated],y=this.decimated_glyph,m=this.decimated_glyph,v=this.selection_glyph):(y=this.model.muted&&null!=this.muted_glyph?this.muted_glyph:this.glyph,m=this.nonselection_glyph,v=this.selection_glyph),null!=this.hover_glyph&&r.length&&(i=u.difference(i,r)),h.length){const e={};for(const t of h)e[t]=!0;const l=new Array,o=new Array;if(this.glyph instanceof n.LineView)for(const i of t)null!=e[i]?l.push(i):o.push(i);else for(const s of i)null!=e[t[s]]?l.push(s):o.push(s);m.render(s,o),v.render(s,l),null!=this.hover_glyph&&(this.glyph instanceof n.LineView?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(r)):this.hover_glyph.render(s,r))}else if(this.glyph instanceof n.LineView)this.hover_glyph&&r.length?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(r)):y.render(s,t);else if(this.glyph instanceof o.PatchView||this.glyph instanceof a.HAreaView||this.glyph instanceof c.VAreaView)if(0==d.selected_glyphs.length||null==this.hover_glyph)y.render(s,t);else for(const e of d.selected_glyphs)e==this.glyph.model&&this.hover_glyph.render(s,t);else y.render(s,i),this.hover_glyph&&r.length&&this.hover_glyph.render(s,r);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=V,V.__name__=\"GlyphRendererView\";class G extends h.DataRenderer{constructor(e){super(e)}static init_GlyphRenderer(){this.prototype.default_view=V,this.define((({Boolean:e,Auto:t,Or:i,Ref:s,Null:l,Nullable:h})=>({data_source:[s(_.ColumnarDataSource)],view:[s(r.CDSView),e=>new r.CDSView({source:e.data_source})],glyph:[s(d.Glyph)],hover_glyph:[h(s(d.Glyph)),null],nonselection_glyph:[i(s(d.Glyph),t,l),\"auto\"],selection_glyph:[i(s(d.Glyph),t,l),\"auto\"],muted_glyph:[h(s(d.Glyph)),null],muted:[e,!1]})))}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,G.__name__=\"GlyphRenderer\",G.init_GlyphRenderer()},\n", " function _(e,r,t,a,n){a();const s=e(41);class i extends s.RendererView{get xscale(){return this.coordinates.x_scale}get yscale(){return this.coordinates.y_scale}}t.DataRendererView=i,i.__name__=\"DataRendererView\";class _ extends s.Renderer{constructor(e){super(e)}static init_DataRenderer(){this.override({level:\"glyph\"})}get selection_manager(){return this.get_selection_manager()}}t.DataRenderer=_,_.__name__=\"DataRenderer\",_.init_DataRenderer()},\n", " function _(e,i,t,s,n){s();const l=e(1),_=e(64),r=e(106),h=e(108),o=l.__importStar(e(48)),a=l.__importStar(e(107)),c=e(59);class d extends _.XYGlyphView{initialize(){super.initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;null!=e&&(this.glglyph=new h.LineGL(e.gl,this))}_render(e,i,t){const{sx:s,sy:n}=null!=t?t:this;let l=!0;e.beginPath();for(const t of i){const i=s[t],_=n[t];isFinite(i+_)?l?(e.moveTo(i,_),l=!1):e.lineTo(i,_):l=!0}this.visuals.line.set_value(e),e.stroke()}_hit_point(e){const i=new c.Selection,t={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:[p.XCoordinateSpec,{field:\"x\"}],y:[p.YCoordinateSpec,{field:\"y\"}]})))}}i.XYGlyph=d,d.__name__=\"XYGlyph\",d.init_XYGlyph()},\n", " function _(n,t,e,o,r){o();const c=n(1),l=c.__importDefault(n(66)),i=c.__importDefault(n(67)),u=n(24),a=new i.default(\"GOOGLE\"),s=new i.default(\"WGS84\"),f=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=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 r.z?[r.x,r.y,r.z].concat(t.splice(3)):[r.x,r.y,t[2]].concat(t.splice(3)):[r.x,r.y].concat(t.splice(2)):[r.x,r.y]):(o=c.default(e,n,t),2===(a=Object.keys(t)).length||a.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;o[r]=t[r]})),o)}function l(e){return e instanceof i.default?e:e.oProj?e.oProj: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){return f(e,n,t)},inverse:function(t){return f(n,e,t)}},o&&(r.oProj=n),r)}},\n", " function _(t,e,a,s,i){s();const u=t(1),l=u.__importDefault(t(68)),o=u.__importDefault(t(79)),r=u.__importDefault(t(80)),f=t(88),p=u.__importDefault(t(90)),d=u.__importDefault(t(91)),m=u.__importDefault(t(75));function n(t,e){if(!(this instanceof n))return new n(t);e=e||function(t){if(t)throw t};var a=l.default(t);if(\"object\"==typeof a){var s=n.projections.get(a.projName);if(s){if(a.datumCode&&\"none\"!==a.datumCode){var i=m.default(p.default,a.datumCode);i&&(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\";var u=f.sphere(a.a,a.b,a.rf,a.ellps,a.sphere),r=f.eccentricity(u.a,u.b,u.rf,a.R_A),h=a.datum||d.default(a.datumCode,a.datum_params,u.a,u.b,r.es,r.ep2);o.default(this,a),o.default(this,s),this.a=u.a,this.b=u.b,this.rf=u.rf,this.sphere=u.sphere,this.es=r.es,this.e=r.e,this.ep2=r.ep2,this.datum=h,this.init(),e(null,this)}else e(t)}else e(t)}n.projections=r.default,n.projections.start(),a.default=n},\n", " function _(t,r,n,u,e){u();const f=t(1),i=f.__importDefault(t(69)),a=f.__importDefault(t(76)),o=f.__importDefault(t(71)),l=f.__importDefault(t(75));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=a.default(t);if(function(t){var r=l.default(t,\"authority\");if(r){var n=l.default(r,\"epsg\");return n&&d.indexOf(n)>-1}}(r))return i.default[\"EPSG:3857\"];var n=function(t){var r=l.default(t,\"extension\");if(r)return l.default(r,\"proj4\")}(r);return n?o.default(n):r}return function(t){return\"+\"===t[0]}(t)?o.default(t):void 0}},\n", " function _(t,r,i,e,n){e();const f=t(1),a=f.__importDefault(t(70)),l=f.__importDefault(t(71)),u=f.__importDefault(t(76));function o(t){var r=this;if(2===arguments.length){var i=arguments[1];\"string\"==typeof i?\"+\"===i.charAt(0)?o[t]=l.default(arguments[1]):o[t]=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}}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(72),i=e.__importDefault(t(73)),f=e.__importDefault(t(74)),l=e.__importDefault(t(75));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},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=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=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)}};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 _(P,A,_,D,I){D(),_.PJD_3PARAM=1,_.PJD_7PARAM=2,_.PJD_WGS84=4,_.PJD_NODATUM=5,_.SEC_TO_RAD=484813681109536e-20,_.HALF_PI=Math.PI/2,_.SIXTH=.16666666666666666,_.RA4=.04722222222222222,_.RA6=.022156084656084655,_.EPSLN=1e-10,_.D2R=.017453292519943295,_.R2D=57.29577951308232,_.FORTPI=Math.PI/4,_.TWO_PI=2*Math.PI,_.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)}(d),d}},\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*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=l.default(this.e,a,e);i=this.x0+this.a*this.k0*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=u.default(this.e,e)))return null}return i=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(72),_=e.__importDefault(t(84));u.default=function(t){return Math.abs(t)<=o.SPI?t:t-_.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(72);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(72);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(72),u=f.__importStar(t(89)),c=f.__importDefault(t(75));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=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===r.datum_params[3]&&0===r.datum_params[4]&&0===r.datum_params[5]&&0===r.datum_params[6]||(r.datum_type=p.PJD_7PARAM,r.datum_params[3]*=p.SEC_TO_RAD,r.datum_params[4]*=p.SEC_TO_RAD,r.datum_params[5]*=p.SEC_TO_RAD,r.datum_params[6]=r.datum_params[6]/1e6+1))),r.a=_,r.b=t,r.es=u,r.ep2=d,r}},\n", " function _(t,e,a,r,u){r();const m=t(1),_=t(72),o=m.__importDefault(t(93)),d=m.__importDefault(t(95)),f=m.__importDefault(t(67)),n=m.__importDefault(t(96)),i=m.__importDefault(t(97));a.default=function t(e,a,r){var u;if(Array.isArray(r)&&(r=n.default(r)),i.default(r),e.datum&&a.datum&&function(t,e){return(t.datum.datum_type===_.PJD_3PARAM||t.datum.datum_type===_.PJD_7PARAM)&&\"WGS84\"!==e.datumCode||(e.datum.datum_type===_.PJD_3PARAM||e.datum.datum_type===_.PJD_7PARAM)&&\"WGS84\"!==t.datumCode}(e,a)&&(r=t(e,u=new f.default(\"WGS84\"),r),e=u),\"enu\"!==e.axis&&(r=d.default(e,!1,r)),\"longlat\"===e.projName)r={x:r.x*_.D2R,y:r.y*_.D2R,z:r.z||0};else if(e.to_meter&&(r={x:r.x*e.to_meter,y:r.y*e.to_meter,z:r.z||0}),!(r=e.inverse(r)))return;return e.from_greenwich&&(r.x+=e.from_greenwich),r=o.default(e.datum,a.datum,r),a.from_greenwich&&(r={x:r.x-a.from_greenwich,y:r.y,z:r.z||0}),\"longlat\"===a.projName?r={x:r.x*_.R2D,y:r.y*_.R2D,z:r.z||0}:(r=a.forward(r),a.to_meter&&(r={x:r.x/a.to_meter,y:r.y/a.to_meter,z:r.z||0})),\"enu\"!==a.axis?d.default(a,!0,r):r}},\n", " function _(t,e,a,u,c){u();const m=t(72),o=t(94);function _(t){return t===m.PJD_3PARAM||t===m.PJD_7PARAM}a.default=function(t,e,a){return o.compareDatums(t,e)||t.datum_type===m.PJD_NODATUM||e.datum_type===m.PJD_NODATUM?a:t.es!==e.es||t.a!==e.a||_(t.datum_type)||_(e.datum_type)?(a=o.geodeticToGeocentric(a,t.es,t.a),_(t.datum_type)&&(a=o.geocentricToWgs84(a,t.datum_type,t.datum_params)),_(e.datum_type)&&(a=o.geocentricFromWgs84(a,e.datum_type,e.datum_params)),o.geocentricToGeodetic(a,e.es,e.a,e.b)):a}},\n", " function _(a,t,r,m,s){m();const u=a(72);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,t,s,i,n){i();const r=e(1),a=r.__importStar(e(18)),o=r.__importStar(e(99)),_=r.__importStar(e(45)),l=e(42),c=e(53),h=e(19),d=e(24),u=e(8),f=e(100),p=e(12),g=e(26),y=e(101),x=e(104),v=e(59),{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)||(e.beginPath(),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,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&&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();null===(s=this.glglyph)||void 0===s||s.set_visuals_changed()}set_data(e,t,s){var i;const{x_range:n,y_range: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=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;h{const s=new Uint32Array(r);for(let n=0;n>1;i[s]>n?e=s:t=s+1}return i[t]}class r extends o.default{search_indices(n,i,t,e){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let s=this._boxes.length-4;const o=[],x=new d.Indices(this.numItems);for(;void 0!==s;){const d=Math.min(s+4*this.nodeSize,h(s,this._levelBounds));for(let h=s;h>2];tthis._boxes[h+2]||i>this._boxes[h+3]||(s<4*this.numItems?x.set(d):o.push(d)))}s=o.pop()}return x}}r.__name__=\"_FlatBush\";class l{constructor(n){this.index=null,n>0&&(this.index=new r(n))}add(n,i,t,e){var s;null===(s=this.index)||void 0===s||s.add(n,i,t,e)}add_empty(){var n;null===(n=this.index)||void 0===n||n.add(1/0,1/0,-1/0,-1/0)}finish(){var n;null===(n=this.index)||void 0===n||n.finish()}_normalize(n){let{x0:i,y0:t,x1:e,y1:s}=n;return i>e&&([i,e]=[e,i]),t>s&&([t,s]=[s,t]),{x0:i,y0:t,x1:e,y1:s}}get bbox(){if(null==this.index)return x.empty();{const{minX:n,minY:i,maxX:t,maxY:e}=this.index;return{x0:n,y0:i,x1:t,y1:e}}}indices(n){if(null==this.index)return new d.Indices(0);{const{x0:i,y0:t,x1:e,y1:s}=this._normalize(n);return this.index.search_indices(i,t,e,s)}}bounds(n){const i=x.empty();for(const t of this.indices(n)){const n=this.index._boxes,e=n[4*t+0],s=n[4*t+1],o=n[4*t+2],d=n[4*t+3];ei.x1&&(i.x1=o),si.y1&&(i.y1=d)}return i}}t.SpatialIndex=l,l.__name__=\"SpatialIndex\"},\n", " function _(t,s,i,e,h){e();const n=t(1).__importDefault(t(103)),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 _(t,n,e,i,s){i();const r=t(105),a=t(20),o=t(21),g=t(24),p=t(9),c=t(8),l=t(11);function u(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+c}return[r,(a.size-1)*n+g]}function d(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,c=0;for(const[t,s]of o){const r=s.length,[o,l]=h(s,e,i,g);c+=l;const u=p.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+c]}e.Factor=o.Or(o.String,o.Tuple(o.String,o.String),o.Tuple(o.String,o.String,o.String)),e.FactorSeq=o.Or(o.Array(o.String),o.Array(o.Tuple(o.String,o.String)),o.Array(o.Tuple(o.String,o.String,o.String))),e.map_one_level=u,e.map_two_levels=h,e.map_three_levels=d;class _ extends r.Range{constructor(t){super(t)}static init_FactorRange(){this.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:[a.PaddingUnits,\"percent\"],start:[t],end:[t]}))),this.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]})))}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:l.unreachable()}}synthetic(t){if(c.isNumber(t))return t;if(c.isString(t))return this._lookup([t]);let n=0;const e=t[t.length-1];return c.isNumber(e)&&(n=e,t=t.slice(0,-1)),this._lookup(t)+n}v_synthetic(t){const n=t.length,e=new g.ScreenArray(n);for(let i=0;i{if(p.every(this.factors,c.isString)){const t=this.factors,[n,e]=u(t,this.factor_padding);return{levels:1,mapping:n,tops:null,mids:null,inside_padding:e}}if(p.every(this.factors,(t=>c.isArray(t)&&2==t.length&&c.isString(t[0])&&c.isString(t[1])))){const t=this.factors,[n,e]=h(t,this.group_padding,this.factor_padding),i=[...n.keys()];return{levels:2,mapping:n,tops:i,mids:null,inside_padding:e}}if(p.every(this.factors,(t=>c.isArray(t)&&3==t.length&&c.isString(t[0])&&c.isString(t[1])&&c.isString(t[2])))){const t=this.factors,[n,e]=d(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}}l.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=_,_.__name__=\"FactorRange\",_.init_FactorRange()},\n", " function _(e,t,i,n,s){n();const a=e(53);class l extends a.Model{constructor(e){super(e),this.have_updated_interactively=!1}static init_Range(){this.define((({Number:e,Tuple:t,Or:i,Auto:n,Nullable:s})=>({bounds:[s(i(t(s(e),s(e)),n)),null],min_interval:[s(e),null],max_interval:[s(e),null]}))),this.internal((({Array:e,AnyRef:t})=>({plots:[e(t()),[]]})))}get is_reversed(){return this.start>this.end}get is_valid(){return isFinite(this.min)&&isFinite(this.max)}}i.Range=l,l.__name__=\"Range\",l.init_Range()},\n", " function _(e,t,i,n,l){n();const o=e(1).__importStar(e(107));function a(e,t,{x0:i,x1:n,y0:l,y1:o},a){t.save(),t.beginPath(),t.moveTo(i,(l+o)/2),t.lineTo(n,(l+o)/2),e.line.doit&&(e.line.set_vectorize(t,a),t.stroke()),t.restore()}function r(e,t,{x0:i,x1:n,y0:l,y1:o},a){var r,c;const s=.1*Math.abs(n-i),_=.1*Math.abs(o-l),v=i+s,d=n-s,h=l+_,g=o-_;t.beginPath(),t.rect(v,h,d-v,g-h),e.fill.doit&&(e.fill.set_vectorize(t,a),t.fill()),(null===(r=e.hatch)||void 0===r?void 0:r.doit)&&(e.hatch.set_vectorize(t,a),t.fill()),(null===(c=e.line)||void 0===c?void 0:c.doit)&&(e.line.set_vectorize(t,a),t.stroke())}i.generic_line_scalar_legend=function(e,t,{x0:i,x1:n,y0:l,y1:o}){t.save(),t.beginPath(),t.moveTo(i,(l+o)/2),t.lineTo(n,(l+o)/2),e.line.doit&&(e.line.set_value(t),t.stroke()),t.restore()},i.generic_line_vector_legend=a,i.generic_line_legend=a,i.generic_area_scalar_legend=function(e,t,{x0:i,x1:n,y0:l,y1:o}){var a,r;const c=.1*Math.abs(n-i),s=.1*Math.abs(o-l),_=i+c,v=n-c,d=l+s,h=o-s;t.beginPath(),t.rect(_,d,v-_,h-d),e.fill.doit&&(e.fill.set_value(t),t.fill()),(null===(a=e.hatch)||void 0===a?void 0:a.doit)&&(e.hatch.set_value(t),t.fill()),(null===(r=e.line)||void 0===r?void 0:r.doit)&&(e.line.set_value(t),t.stroke())},i.generic_area_vector_legend=r,i.generic_area_legend=r,i.line_interpolation=function(e,t,i,n,l,a){const{sx:r,sy:c}=t;let s,_,v,d;\"point\"==t.type?([v,d]=e.yscale.r_invert(c-1,c+1),[s,_]=e.xscale.r_invert(r-1,r+1)):\"v\"==t.direction?([v,d]=e.yscale.r_invert(c,c),[s,_]=[Math.min(i-1,l-1),Math.max(i+1,l+1)]):([s,_]=e.xscale.r_invert(r,r),[v,d]=[Math.min(n-1,a-1),Math.max(n+1,a+1)]);const{x:h,y:g}=o.check_2_segments_intersect(s,v,_,d,i,n,l,a);return[h,g]}},\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,e,s,i,a){i();const o=t(1),n=t(109),_=t(113),r=o.__importDefault(t(114)),h=o.__importDefault(t(115)),l=t(22),g=t(46);class u{constructor(t){this._atlas=new Map,this._width=256,this._height=256,this.tex=new n.Texture2d(t),this.tex.set_wrapping(t.REPEAT,t.REPEAT),this.tex.set_interpolation(t.NEAREST,t.NEAREST),this.tex.set_size([this._width,this._height],t.RGBA),this.tex.set_data([0,0],[this._width,this._height],new Uint8Array(4*this._width*this._height)),this.get_atlas_data([1])}get_atlas_data(t){const e=t.join(\"-\");let s=this._atlas.get(e);if(null==s){const[i,a]=this.make_pattern(t),o=this._atlas.size;this.tex.set_data([0,o],[this._width,1],new Uint8Array(i.map((t=>t+10)))),s=[o/this._height,a],this._atlas.set(e,s)}return s}make_pattern(t){t.length>1&&t.length%2&&(t=t.concat(t));let e=0;for(const s of t)e+=s;const s=[];let i=0;for(let e=0,a=t.length+2;es[h]?-1:0,n=s[h-1],i=s[h]),o[4*t+0]=s[h],o[4*t+1]=_,o[4*t+2]=n,o[4*t+3]=i}return[o,e]}}u.__name__=\"DashAtlas\";const f={miter:0,round:1,bevel:2},c={\"\":0,none:0,\".\":0,round:1,\")\":1,\"(\":1,o:1,\"triangle in\":2,\"<\":2,\"triangle out\":3,\">\":3,square:4,\"[\":4,\"]\":4,\"=\":4,butt:5,\"|\":5};class d extends _.BaseGLGlyph{constructor(t,e){super(t,e),this.glyph=e,this._scale_aspect=0;const s=r.default,i=h.default;this.prog=new n.Program(t),this.prog.set_shaders(s,i),this.index_buffer=new n.IndexBuffer(t),this.vbo_position=new n.VertexBuffer(t),this.vbo_tangents=new n.VertexBuffer(t),this.vbo_segment=new n.VertexBuffer(t),this.vbo_angles=new n.VertexBuffer(t),this.vbo_texcoord=new n.VertexBuffer(t),this.dash_atlas=new u(t)}draw(t,e,s){const i=e.glglyph;if(i.data_changed&&(i._set_data(),i.data_changed=!1),this.visuals_changed&&(this._set_visuals(),this.visuals_changed=!1),i._update_scale(1,1),this._scale_aspect=1,this.prog.set_attribute(\"a_position\",\"vec2\",i.vbo_position),this.prog.set_attribute(\"a_tangents\",\"vec4\",i.vbo_tangents),this.prog.set_attribute(\"a_segment\",\"vec2\",i.vbo_segment),this.prog.set_attribute(\"a_angles\",\"vec2\",i.vbo_angles),this.prog.set_attribute(\"a_texcoord\",\"vec2\",i.vbo_texcoord),this.prog.set_uniform(\"u_length\",\"float\",[i.cumsum]),this.prog.set_texture(\"u_dash_atlas\",this.dash_atlas.tex),this.prog.set_uniform(\"u_pixel_ratio\",\"float\",[s.pixel_ratio]),this.prog.set_uniform(\"u_canvas_size\",\"vec2\",[s.width,s.height]),this.prog.set_uniform(\"u_scale_aspect\",\"vec2\",[1,1]),this.prog.set_uniform(\"u_scale_length\",\"float\",[Math.sqrt(2)]),this.I_triangles=i.I_triangles,this.I_triangles.length<65535)this.index_buffer.set_size(2*this.I_triangles.length),this.index_buffer.set_data(0,new Uint16Array(this.I_triangles)),this.prog.draw(this.gl.TRIANGLES,this.index_buffer);else{t=Array.from(this.I_triangles);const e=this.I_triangles.length,s=64008,a=[];for(let t=0,i=Math.ceil(e/s);t1)for(let e=0;e0||console.log(`Variable ${t} is not an active attribute`));else if(this._unset_variables.has(t)&&this._unset_variables.delete(t),this.activate(),i instanceof r.VertexBuffer){const[r,o]=this.ATYPEINFO[e],l=\"vertexAttribPointer\",_=[r,o,n,s,a];this._attributes.set(t,[i.handle,h,l,_])}else{const s=this.ATYPEMAP[e];this._attributes.set(t,[null,h,s,i])}}_pre_draw(){this.activate();for(const[t,e,i]of this._samplers.values())this.gl.activeTexture(this.gl.TEXTURE0+i),this.gl.bindTexture(t,e);for(const[t,e,i,s]of this._attributes.values())null!=t?(this.gl.bindBuffer(this.gl.ARRAY_BUFFER,t),this.gl.enableVertexAttribArray(e),this.gl[i].apply(this.gl,[e,...s])):(this.gl.bindBuffer(this.gl.ARRAY_BUFFER,null),this.gl.disableVertexAttribArray(e),this.gl[i].apply(this.gl,[e,...s]));this._validated||(this._validated=!0,this._validate())}_validate(){if(this._unset_variables.size&&console.log(`Program has unset variables: ${this._unset_variables}`),this.gl.validateProgram(this.handle),!this.gl.getProgramParameter(this.handle,this.gl.VALIDATE_STATUS))throw console.log(this.gl.getProgramInfoLog(this.handle)),new Error(\"Program validation error\")}draw(t,e){if(!this._linked)throw new Error(\"Cannot draw program if code has not been set\");if(e instanceof r.IndexBuffer){this._pre_draw(),e.activate();const i=e.buffer_size/2,s=this.gl.UNSIGNED_SHORT;this.gl.drawElements(t,i,s,0),e.deactivate()}else{const[i,s]=e;0!=s&&(this._pre_draw(),this.gl.drawArrays(t,i,s))}}}i.Program=n,n.__name__=\"Program\"},\n", " function _(t,e,s,i,a){i();class r{constructor(t){this.gl=t,this._usage=35048,this.buffer_size=0,this.handle=this.gl.createBuffer()}delete(){this.gl.deleteBuffer(this.handle)}activate(){this.gl.bindBuffer(this._target,this.handle)}deactivate(){this.gl.bindBuffer(this._target,null)}set_size(t){t!=this.buffer_size&&(this.activate(),this.gl.bufferData(this._target,t,this._usage),this.buffer_size=t)}set_data(t,e){this.activate(),this.gl.bufferSubData(this._target,t,e)}}s.Buffer=r,r.__name__=\"Buffer\";class f extends r{constructor(){super(...arguments),this._target=34962}}s.VertexBuffer=f,f.__name__=\"VertexBuffer\";class h extends r{constructor(){super(...arguments),this._target=34963}}s.IndexBuffer=h,h.__name__=\"IndexBuffer\"},\n", " function _(t,e,i,a,r){a();const s=t(11);class h{constructor(t){this.gl=t,this._target=3553,this._types={Int8Array:5120,Uint8Array:5121,Int16Array:5122,Uint16Array:5123,Int32Array:5124,Uint32Array:5125,Float32Array:5126},this.handle=this.gl.createTexture()}delete(){this.gl.deleteTexture(this.handle)}activate(){this.gl.bindTexture(this._target,this.handle)}deactivate(){this.gl.bindTexture(this._target,0)}_get_alignment(t){const e=[4,8,2,1];for(const i of e)if(t%i==0)return i;s.unreachable()}set_wrapping(t,e){this.activate(),this.gl.texParameterf(this._target,this.gl.TEXTURE_WRAP_S,t),this.gl.texParameterf(this._target,this.gl.TEXTURE_WRAP_T,e)}set_interpolation(t,e){this.activate(),this.gl.texParameterf(this._target,this.gl.TEXTURE_MIN_FILTER,t),this.gl.texParameterf(this._target,this.gl.TEXTURE_MAG_FILTER,e)}set_size([t,e],i){var a,r,s;t==(null===(a=this._shape_format)||void 0===a?void 0:a.width)&&e==(null===(r=this._shape_format)||void 0===r?void 0:r.height)&&i==(null===(s=this._shape_format)||void 0===s?void 0:s.format)||(this._shape_format={width:t,height:e,format:i},this.activate(),this.gl.texImage2D(this._target,0,i,t,e,0,i,this.gl.UNSIGNED_BYTE,null))}set_data(t,[e,i],a){this.activate();const{format:r}=this._shape_format,[s,h]=t,l=this._types[a.constructor.name];if(null==l)throw new Error(`Type ${a.constructor.name} not allowed for texture`);const _=this._get_alignment(e);4!=_&&this.gl.pixelStorei(this.gl.UNPACK_ALIGNMENT,_),this.gl.texSubImage2D(this._target,0,s,h,e,i,r,l,a),4!=_&&this.gl.pixelStorei(this.gl.UNPACK_ALIGNMENT,4)}}i.Texture2d=h,h.__name__=\"Texture2d\"},\n", " function _(e,t,s,i,h){i();class a{constructor(e,t){this.gl=e,this.glyph=t,this.nvertices=0,this.size_changed=!1,this.data_changed=!1,this.visuals_changed=!1}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", " function _(n,e,t,a,i){a();t.default=\"\\nprecision mediump float;\\n\\nconst float PI = 3.14159265358979323846264;\\nconst float THETA = 15.0 * 3.14159265358979323846264/180.0;\\n\\nuniform float u_pixel_ratio;\\nuniform vec2 u_canvas_size, u_offset;\\nuniform vec2 u_scale_aspect;\\nuniform float u_scale_length;\\n\\nuniform vec4 u_color;\\nuniform float u_antialias;\\nuniform float u_length;\\nuniform float u_linewidth;\\nuniform float u_dash_index;\\nuniform float u_closed;\\n\\nattribute vec2 a_position;\\nattribute vec4 a_tangents;\\nattribute vec2 a_segment;\\nattribute vec2 a_angles;\\nattribute vec2 a_texcoord;\\n\\nvarying vec4 v_color;\\nvarying vec2 v_segment;\\nvarying vec2 v_angles;\\nvarying vec2 v_texcoord;\\nvarying vec2 v_miter;\\nvarying float v_length;\\nvarying float v_linewidth;\\n\\nfloat cross(in vec2 v1, in vec2 v2)\\n{\\n return v1.x*v2.y - v1.y*v2.x;\\n}\\n\\nfloat signed_distance(in vec2 v1, in vec2 v2, in vec2 v3)\\n{\\n return cross(v2-v1,v1-v3) / length(v2-v1);\\n}\\n\\nvoid rotate( in vec2 v, in float alpha, out vec2 result )\\n{\\n float c = cos(alpha);\\n float s = sin(alpha);\\n result = vec2( c*v.x - s*v.y,\\n s*v.x + c*v.y );\\n}\\n\\nvoid main()\\n{\\n bool closed = (u_closed > 0.0);\\n\\n // Attributes and uniforms to varyings\\n v_color = u_color;\\n v_linewidth = u_linewidth;\\n v_segment = a_segment * u_scale_length;\\n v_length = u_length * u_scale_length;\\n\\n // Scale to map to pixel coordinates. The original algorithm from the paper\\n // assumed isotropic scale. We obviously do not have this.\\n vec2 abs_scale_aspect = abs(u_scale_aspect);\\n vec2 abs_scale = u_scale_length * abs_scale_aspect;\\n\\n // Correct angles for aspect ratio\\n vec2 av;\\n av = vec2(1.0, tan(a_angles.x)) / abs_scale_aspect;\\n v_angles.x = atan(av.y, av.x);\\n av = vec2(1.0, tan(a_angles.y)) / abs_scale_aspect;\\n v_angles.y = atan(av.y, av.x);\\n\\n // Thickness below 1 pixel are represented using a 1 pixel thickness\\n // and a modified alpha\\n v_color.a = min(v_linewidth, v_color.a);\\n v_linewidth = max(v_linewidth, 1.0);\\n\\n // If color is fully transparent we just will discard the fragment anyway\\n if( v_color.a <= 0.0 ) {\\n gl_Position = vec4(0.0,0.0,0.0,1.0);\\n return;\\n }\\n\\n // This is the actual half width of the line\\n float w = ceil(u_antialias+v_linewidth)/2.0;\\n\\n vec2 position = a_position;\\n\\n vec2 t1 = normalize(a_tangents.xy * abs_scale_aspect); // note the scaling for aspect ratio here\\n vec2 t2 = normalize(a_tangents.zw * abs_scale_aspect);\\n float u = a_texcoord.x;\\n float v = a_texcoord.y;\\n vec2 o1 = vec2( +t1.y, -t1.x);\\n vec2 o2 = vec2( +t2.y, -t2.x);\\n\\n // This is a join\\n // ----------------------------------------------------------------\\n if( t1 != t2 ) {\\n float angle = atan (t1.x*t2.y-t1.y*t2.x, t1.x*t2.x+t1.y*t2.y); // Angle needs recalculation for some reason\\n vec2 t = normalize(t1+t2);\\n vec2 o = vec2( + t.y, - t.x);\\n\\n if ( u_dash_index > 0.0 )\\n {\\n // Broken angle\\n // ----------------------------------------------------------------\\n if( (abs(angle) > THETA) ) {\\n position += v * w * o / cos(angle/2.0);\\n float s = sign(angle);\\n if( angle < 0.0 ) {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n if( v == 1.0 ) {\\n position -= 2.0 * w * t1 / sin(angle);\\n u -= 2.0 * w / sin(angle);\\n }\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n if( v == 1.0 ) {\\n position += 2.0 * w * t2 / sin(angle);\\n u += 2.0*w / sin(angle);\\n }\\n }\\n } else {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n if( v == -1.0 ) {\\n position += 2.0 * w * t1 / sin(angle);\\n u += 2.0 * w / sin(angle);\\n }\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n if( v == -1.0 ) {\\n position -= 2.0 * w * t2 / sin(angle);\\n u -= 2.0*w / sin(angle);\\n }\\n }\\n }\\n // Continuous angle\\n // ------------------------------------------------------------\\n } else {\\n position += v * w * o / cos(angle/2.0);\\n if( u == +1.0 ) u = v_segment.y;\\n else u = v_segment.x;\\n }\\n }\\n\\n // Solid line\\n // --------------------------------------------------------------------\\n else\\n {\\n position.xy += v * w * o / cos(angle/2.0);\\n if( angle < 0.0 ) {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n }\\n } else {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n }\\n }\\n }\\n\\n // This is a line start or end (t1 == t2)\\n // ------------------------------------------------------------------------\\n } else {\\n position += v * w * o1;\\n if( u == -1.0 ) {\\n u = v_segment.x - w;\\n position -= w * t1;\\n } else {\\n u = v_segment.y + w;\\n position += w * t2;\\n }\\n }\\n\\n // Miter distance\\n // ------------------------------------------------------------------------\\n vec2 t;\\n vec2 curr = a_position * abs_scale;\\n if( a_texcoord.x < 0.0 ) {\\n vec2 next = curr + t2*(v_segment.y-v_segment.x);\\n\\n rotate( t1, +v_angles.x/2.0, t);\\n v_miter.x = signed_distance(curr, curr+t, position);\\n\\n rotate( t2, +v_angles.y/2.0, t);\\n v_miter.y = signed_distance(next, next+t, position);\\n } else {\\n vec2 prev = curr - t1*(v_segment.y-v_segment.x);\\n\\n rotate( t1, -v_angles.x/2.0,t);\\n v_miter.x = signed_distance(prev, prev+t, position);\\n\\n rotate( t2, -v_angles.y/2.0,t);\\n v_miter.y = signed_distance(curr, curr+t, position);\\n }\\n\\n if (!closed && v_segment.x <= 0.0) {\\n v_miter.x = 1e10;\\n }\\n if (!closed && v_segment.y >= v_length)\\n {\\n v_miter.y = 1e10;\\n }\\n\\n v_texcoord = vec2( u, v*w );\\n\\n // Calculate position in device coordinates. Note that we\\n // already scaled with abs scale above.\\n vec2 normpos = position * sign(u_scale_aspect);\\n normpos += 0.5; // make up for Bokeh's offset\\n normpos /= u_canvas_size / u_pixel_ratio; // in 0..1\\n gl_Position = vec4(normpos*2.0-1.0, 0.0, 1.0);\\n gl_Position.y *= -1.0;\\n}\\n\"},\n", " function _(n,t,e,s,a){s();e.default=\"\\nprecision mediump float;\\n\\nconst float PI = 3.14159265358979323846264;\\nconst float THETA = 15.0 * 3.14159265358979323846264/180.0;\\n\\nuniform sampler2D u_dash_atlas;\\n\\nuniform vec2 u_linecaps;\\nuniform float u_miter_limit;\\nuniform float u_linejoin;\\nuniform float u_antialias;\\nuniform float u_dash_phase;\\nuniform float u_dash_period;\\nuniform float u_dash_index;\\nuniform vec2 u_dash_caps;\\nuniform float u_closed;\\n\\nvarying vec4 v_color;\\nvarying vec2 v_segment;\\nvarying vec2 v_angles;\\nvarying vec2 v_texcoord;\\nvarying vec2 v_miter;\\nvarying float v_length;\\nvarying float v_linewidth;\\n\\n// Compute distance to cap ----------------------------------------------------\\nfloat cap( int type, float dx, float dy, float t, float linewidth )\\n{\\n float d = 0.0;\\n dx = abs(dx);\\n dy = abs(dy);\\n if (type == 0) discard; // None\\n else if (type == 1) d = sqrt(dx*dx+dy*dy); // Round\\n else if (type == 3) d = (dx+abs(dy)); // Triangle in\\n else if (type == 2) d = max(abs(dy),(t+dx-abs(dy))); // Triangle out\\n else if (type == 4) d = max(dx,dy); // Square\\n else if (type == 5) d = max(dx+t,dy); // Butt\\n return d;\\n}\\n\\n// Compute distance to join -------------------------------------------------\\nfloat join( in int type, in float d, in vec2 segment, in vec2 texcoord, in vec2 miter,\\n in float linewidth )\\n{\\n // texcoord.x is distance from start\\n // texcoord.y is distance from centerline\\n // segment.x and y indicate the limits (as for texcoord.x) for this segment\\n\\n float dx = texcoord.x;\\n\\n // Round join\\n if( type == 1 ) {\\n if (dx < segment.x) {\\n d = max(d,length( texcoord - vec2(segment.x,0.0)));\\n //d = length( texcoord - vec2(segment.x,0.0));\\n } else if (dx > segment.y) {\\n d = max(d,length( texcoord - vec2(segment.y,0.0)));\\n //d = length( texcoord - vec2(segment.y,0.0));\\n }\\n }\\n // Bevel join\\n else if ( type == 2 ) {\\n if (dx < segment.x) {\\n vec2 x = texcoord - vec2(segment.x,0.0);\\n d = max(d, max(abs(x.x), abs(x.y)));\\n\\n } else if (dx > segment.y) {\\n vec2 x = texcoord - vec2(segment.y,0.0);\\n d = max(d, max(abs(x.x), abs(x.y)));\\n }\\n /* Original code for bevel which does not work for us\\n if( (dx < segment.x) || (dx > segment.y) )\\n d = max(d, min(abs(x.x),abs(x.y)));\\n */\\n }\\n\\n return d;\\n}\\n\\nvoid main()\\n{\\n // If color is fully transparent we just discard the fragment\\n if( v_color.a <= 0.0 ) {\\n discard;\\n }\\n\\n // Test if dash pattern is the solid one (0)\\n bool solid = (u_dash_index == 0.0);\\n\\n // Test if path is closed\\n bool closed = (u_closed > 0.0);\\n\\n vec4 color = v_color;\\n float dx = v_texcoord.x;\\n float dy = v_texcoord.y;\\n float t = v_linewidth/2.0-u_antialias;\\n float width = 1.0; //v_linewidth; original code had dashes scale with line width, we do not\\n float d = 0.0;\\n\\n vec2 linecaps = u_linecaps;\\n vec2 dash_caps = u_dash_caps;\\n float line_start = 0.0;\\n float line_stop = v_length;\\n\\n // Apply miter limit; fragments too far into the miter are simply discarded\\n if( (dx < v_segment.x) || (dx > v_segment.y) ) {\\n float into_miter = max(v_segment.x - dx, dx - v_segment.y);\\n if (into_miter > u_miter_limit*v_linewidth/2.0)\\n discard;\\n }\\n\\n // Solid line --------------------------------------------------------------\\n if( solid ) {\\n d = abs(dy);\\n if( (!closed) && (dx < line_start) ) {\\n d = cap( int(u_linecaps.x), abs(dx), abs(dy), t, v_linewidth );\\n }\\n else if( (!closed) && (dx > line_stop) ) {\\n d = cap( int(u_linecaps.y), abs(dx)-line_stop, abs(dy), t, v_linewidth );\\n }\\n else {\\n d = join( int(u_linejoin), abs(dy), v_segment, v_texcoord, v_miter, v_linewidth );\\n }\\n\\n // Dash line --------------------------------------------------------------\\n } else {\\n float segment_start = v_segment.x;\\n float segment_stop = v_segment.y;\\n float segment_center= (segment_start+segment_stop)/2.0;\\n float freq = u_dash_period*width;\\n float u = mod( dx + u_dash_phase*width, freq);\\n vec4 tex = texture2D(u_dash_atlas, vec2(u/freq, u_dash_index)) * 255.0 -10.0; // conversion to int-like\\n float dash_center= tex.x * width;\\n float dash_type = tex.y;\\n float _start = tex.z * width;\\n float _stop = tex.a * width;\\n float dash_start = dx - u + _start;\\n float dash_stop = dx - u + _stop;\\n\\n // Compute extents of the first dash (the one relative to v_segment.x)\\n // Note: this could be computed in the vertex shader\\n if( (dash_stop < segment_start) && (dash_caps.x != 5.0) ) {\\n float u = mod(segment_start + u_dash_phase*width, freq);\\n vec4 tex = texture2D(u_dash_atlas, vec2(u/freq, u_dash_index)) * 255.0 -10.0; // conversion to int-like\\n dash_center= tex.x * width;\\n //dash_type = tex.y;\\n float _start = tex.z * width;\\n float _stop = tex.a * width;\\n dash_start = segment_start - u + _start;\\n dash_stop = segment_start - u + _stop;\\n }\\n\\n // Compute extents of the last dash (the one relatives to v_segment.y)\\n // Note: This could be computed in the vertex shader\\n else if( (dash_start > segment_stop) && (dash_caps.y != 5.0) ) {\\n float u = mod(segment_stop + u_dash_phase*width, freq);\\n vec4 tex = texture2D(u_dash_atlas, vec2(u/freq, u_dash_index)) * 255.0 -10.0; // conversion to int-like\\n dash_center= tex.x * width;\\n //dash_type = tex.y;\\n float _start = tex.z * width;\\n float _stop = tex.a * width;\\n dash_start = segment_stop - u + _start;\\n dash_stop = segment_stop - u + _stop;\\n }\\n\\n // This test if the we are dealing with a discontinuous angle\\n bool discontinuous = ((dx < segment_center) && abs(v_angles.x) > THETA) ||\\n ((dx >= segment_center) && abs(v_angles.y) > THETA);\\n //if( dx < line_start) discontinuous = false;\\n //if( dx > line_stop) discontinuous = false;\\n\\n float d_join = join( int(u_linejoin), abs(dy),\\n v_segment, v_texcoord, v_miter, v_linewidth );\\n\\n // When path is closed, we do not have room for linecaps, so we make room\\n // by shortening the total length\\n if (closed) {\\n line_start += v_linewidth/2.0;\\n line_stop -= v_linewidth/2.0;\\n }\\n\\n // We also need to take antialias area into account\\n //line_start += u_antialias;\\n //line_stop -= u_antialias;\\n\\n // Check is dash stop is before line start\\n if( dash_stop <= line_start ) {\\n discard;\\n }\\n // Check is dash start is beyond line stop\\n if( dash_start >= line_stop ) {\\n discard;\\n }\\n\\n // Check if current dash start is beyond segment stop\\n if( discontinuous ) {\\n // Dash start is beyond segment, we discard\\n if( (dash_start > segment_stop) ) {\\n discard;\\n //gl_FragColor = vec4(1.0,0.0,0.0,.25); return;\\n }\\n\\n // Dash stop is before segment, we discard\\n if( (dash_stop < segment_start) ) {\\n discard; //gl_FragColor = vec4(0.0,1.0,0.0,.25); return;\\n }\\n\\n // Special case for round caps (nicer with this)\\n if( dash_caps.x == 1.0 ) {\\n if( (u > _stop) && (dash_stop > segment_stop ) && (abs(v_angles.y) < PI/2.0)) {\\n discard;\\n }\\n }\\n\\n // Special case for round caps (nicer with this)\\n if( dash_caps.y == 1.0 ) {\\n if( (u < _start) && (dash_start < segment_start ) && (abs(v_angles.x) < PI/2.0)) {\\n discard;\\n }\\n }\\n\\n // Special case for triangle caps (in & out) and square\\n // We make sure the cap stop at crossing frontier\\n if( (dash_caps.x != 1.0) && (dash_caps.x != 5.0) ) {\\n if( (dash_start < segment_start ) && (abs(v_angles.x) < PI/2.0) ) {\\n float a = v_angles.x/2.0;\\n float x = (segment_start-dx)*cos(a) - dy*sin(a);\\n float y = (segment_start-dx)*sin(a) + dy*cos(a);\\n if( x > 0.0 ) discard;\\n // We transform the cap into square to avoid holes\\n dash_caps.x = 4.0;\\n }\\n }\\n\\n // Special case for triangle caps (in & out) and square\\n // We make sure the cap stop at crossing frontier\\n if( (dash_caps.y != 1.0) && (dash_caps.y != 5.0) ) {\\n if( (dash_stop > segment_stop ) && (abs(v_angles.y) < PI/2.0) ) {\\n float a = v_angles.y/2.0;\\n float x = (dx-segment_stop)*cos(a) - dy*sin(a);\\n float y = (dx-segment_stop)*sin(a) + dy*cos(a);\\n if( x > 0.0 ) discard;\\n // We transform the caps into square to avoid holes\\n dash_caps.y = 4.0;\\n }\\n }\\n }\\n\\n // Line cap at start\\n if( (dx < line_start) && (dash_start < line_start) && (dash_stop > line_start) ) {\\n d = cap( int(linecaps.x), dx-line_start, dy, t, v_linewidth);\\n }\\n // Line cap at stop\\n else if( (dx > line_stop) && (dash_stop > line_stop) && (dash_start < line_stop) ) {\\n d = cap( int(linecaps.y), dx-line_stop, dy, t, v_linewidth);\\n }\\n // Dash cap left - dash_type = -1, 0 or 1, but there may be roundoff errors\\n else if( dash_type < -0.5 ) {\\n d = cap( int(dash_caps.y), abs(u-dash_center), dy, t, v_linewidth);\\n if( (dx > line_start) && (dx < line_stop) )\\n d = max(d,d_join);\\n }\\n // Dash cap right\\n else if( dash_type > 0.5 ) {\\n d = cap( int(dash_caps.x), abs(dash_center-u), dy, t, v_linewidth);\\n if( (dx > line_start) && (dx < line_stop) )\\n d = max(d,d_join);\\n }\\n // Dash body (plain)\\n else {// if( dash_type > -0.5 && dash_type < 0.5) {\\n d = abs(dy);\\n }\\n\\n // Line join\\n if( (dx > line_start) && (dx < line_stop)) {\\n if( (dx <= segment_start) && (dash_start <= segment_start)\\n && (dash_stop >= segment_start) ) {\\n d = d_join;\\n // Antialias at outer border\\n float angle = PI/2.+v_angles.x;\\n float f = abs( (segment_start - dx)*cos(angle) - dy*sin(angle));\\n d = max(f,d);\\n }\\n else if( (dx > segment_stop) && (dash_start <= segment_stop)\\n && (dash_stop >= segment_stop) ) {\\n d = d_join;\\n // Antialias at outer border\\n float angle = PI/2.+v_angles.y;\\n float f = abs((dx - segment_stop)*cos(angle) - dy*sin(angle));\\n d = max(f,d);\\n }\\n else if( dx < (segment_start - v_linewidth/2.)) {\\n discard;\\n }\\n else if( dx > (segment_stop + v_linewidth/2.)) {\\n discard;\\n }\\n }\\n else if( dx < (segment_start - v_linewidth/2.)) {\\n discard;\\n }\\n else if( dx > (segment_stop + v_linewidth/2.)) {\\n discard;\\n }\\n }\\n\\n // Distance to border ------------------------------------------------------\\n d = d - t;\\n if( d < 0.0 ) {\\n gl_FragColor = color;\\n } else {\\n d /= u_antialias;\\n gl_FragColor = vec4(color.rgb, exp(-d*d)*color.a);\\n }\\n}\\n\"},\n", " function _(i,t,s,e,l){e();const a=i(1),n=i(64),_=i(106),o=a.__importStar(i(107)),h=a.__importStar(i(48)),c=i(59);class r extends n.XYGlyphView{_inner_loop(i,t,s,e,l){for(const a of t){const t=s[a],n=e[a];0!=a?isNaN(t+n)?(i.closePath(),l.apply(i),i.beginPath()):i.lineTo(t,n):(i.beginPath(),i.moveTo(t,n))}i.closePath(),l.call(i)}_render(i,t,s){const{sx:e,sy:l}=null!=s?s:this;this.visuals.fill.doit&&(this.visuals.fill.set_value(i),this._inner_loop(i,t,e,l,i.fill)),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(i),this._inner_loop(i,t,e,l,i.fill)),this.visuals.line.doit&&(this.visuals.line.set_value(i),this._inner_loop(i,t,e,l,i.stroke))}draw_legend_for_index(i,t,s){_.generic_area_scalar_legend(this.visuals,i,t)}_hit_point(i){const t=new c.Selection;return o.point_in_poly(i.sx,i.sy,this.sx,this.sy)&&(t.add_to_selected_glyphs(this.model),t.view=this),t}}s.PatchView=r,r.__name__=\"PatchView\";class p extends n.XYGlyph{constructor(i){super(i)}static init_Patch(){this.prototype.default_view=r,this.mixins([h.LineScalar,h.FillScalar,h.HatchScalar])}}s.Patch=p,p.__name__=\"Patch\",p.init_Patch()},\n", " function _(t,e,s,i,n){i();const a=t(1),r=t(24),h=t(118),_=a.__importStar(t(107)),l=a.__importStar(t(18)),o=t(59);class c extends h.AreaView{_index_data(t){const{min:e,max:s}=Math,{data_size:i}=this;for(let n=0;n=0;e--)t.lineTo(s[e],i[e]);t.closePath(),n.call(t)}_render(t,e,s){const{sx1:i,sx2:n,sy:a}=null!=s?s:this;this.visuals.fill.doit&&(this.visuals.fill.set_value(t),this._inner(t,i,n,a,t.fill)),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(t),this._inner(t,i,n,a,t.fill))}_hit_point(t){const e=this.sy.length,s=new r.ScreenArray(2*e),i=new r.ScreenArray(2*e);for(let t=0,n=e;t({x1:[l.XCoordinateSpec,{field:\"x1\"}],x2:[l.XCoordinateSpec,{field:\"x2\"}],y:[l.YCoordinateSpec,{field:\"y\"}]})))}}s.HArea=d,d.__name__=\"HArea\",d.init_HArea()},\n", " function _(e,a,_,i,r){i();const s=e(1),n=e(98),t=e(106),c=s.__importStar(e(48));class l extends n.GlyphView{draw_legend_for_index(e,a,_){t.generic_area_scalar_legend(this.visuals,e,a)}}_.AreaView=l,l.__name__=\"AreaView\";class d extends n.Glyph{constructor(e){super(e)}static init_Area(){this.mixins([c.FillScalar,c.HatchScalar])}}_.Area=d,d.__name__=\"Area\",d.init_Area()},\n", " function _(t,e,s,i,n){i();const a=t(1),r=t(24),h=t(118),_=a.__importStar(t(107)),l=a.__importStar(t(18)),o=t(59);class c extends h.AreaView{_index_data(t){const{min:e,max:s}=Math,{data_size:i}=this;for(let n=0;n=0;s--)t.lineTo(e[s],i[s]);t.closePath(),n.call(t)}_render(t,e,s){const{sx:i,sy1:n,sy2:a}=null!=s?s:this;this.visuals.fill.doit&&(this.visuals.fill.set_value(t),this._inner(t,i,n,a,t.fill)),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(t),this._inner(t,i,n,a,t.fill))}scenterxy(t){return[this.sx[t],(this.sy1[t]+this.sy2[t])/2]}_hit_point(t){const e=this.sx.length,s=new r.ScreenArray(2*e),i=new r.ScreenArray(2*e);for(let t=0,n=e;t({x:[l.XCoordinateSpec,{field:\"x\"}],y1:[l.YCoordinateSpec,{field:\"y1\"}],y2:[l.YCoordinateSpec,{field:\"y2\"}]})))}}s.VArea=d,d.__name__=\"VArea\",d.init_VArea()},\n", " function _(i,e,s,t,n){t();const c=i(53),o=i(59),r=i(24),a=i(121),u=i(57);class _ extends c.Model{constructor(i){super(i)}static init_CDSView(){this.define((({Array:i,Ref:e})=>({filters:[i(e(a.Filter)),[]],source:[e(u.ColumnarDataSource)]}))),this.internal((({Int:i,Dict:e,Ref:s,Nullable:t})=>({indices:[s(r.Indices)],indices_map:[e(i),{}],masked:[t(s(r.Indices)),null]})))}initialize(){super.initialize(),this.compute_indices()}connect_signals(){super.connect_signals(),this.connect(this.properties.filters.change,(()=>this.compute_indices()));const i=()=>{const i=()=>this.compute_indices();null!=this.source&&(this.connect(this.source.change,i),this.source instanceof u.ColumnarDataSource&&(this.connect(this.source.streaming,i),this.connect(this.source.patching,i)))};let e=null!=this.source;e?i():this.connect(this.properties.source.change,(()=>{e||(i(),e=!0)}))}compute_indices(){var i;const{source:e}=this;if(null==e)return;const s=null!==(i=e.get_length())&&void 0!==i?i:1,t=r.Indices.all_set(s);for(const i of this.filters)t.intersect(i.compute_indices(e));this.indices=t,this._indices=[...t],this.indices_map_to_subset()}indices_map_to_subset(){this.indices_map={};for(let i=0;ithis._indices[i]));return new o.Selection(Object.assign(Object.assign({},i.attributes),{indices:e}))}convert_selection_to_subset(i){const e=i.indices.map((i=>this.indices_map[i]));return new o.Selection(Object.assign(Object.assign({},i.attributes),{indices:e}))}convert_indices_from_subset(i){return i.map((i=>this._indices[i]))}}s.CDSView=_,_.__name__=\"CDSView\",_.init_CDSView()},\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 _(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=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,r,n,t,i){t();const s=e(62),o=e(61),l=e(124),d=e(125),a=e(126),p=e(122),_=e(64),h=e(127),c=e(128),u=e(11);class y extends s.DataRendererView{get glyph_view(){return this.node_view.glyph}async lazy_initialize(){await super.lazy_initialize();const e=this.model;let r=null,n=null;const t=new class extends l.Expression{_v_compute(n){u.assert(null==r);const[t]=r=e.layout_provider.get_edge_coordinates(n);return t}},i=new class extends l.Expression{_v_compute(e){u.assert(null!=r);const[,n]=r;return r=null,n}},s=new class extends l.Expression{_v_compute(r){u.assert(null==n);const[t]=n=e.layout_provider.get_node_coordinates(r);return t}},o=new class extends l.Expression{_v_compute(e){u.assert(null!=n);const[,r]=n;return n=null,r}},{edge_renderer:d,node_renderer:a}=this.model;if(!(d.glyph instanceof h.MultiLine||d.glyph instanceof c.Patches))throw new Error(`${this}.edge_renderer.glyph must be a MultiLine glyph`);if(!(a.glyph instanceof _.XYGlyph))throw new Error(`${this}.node_renderer.glyph must be a XYGlyph glyph`);d.glyph.properties.xs.internal=!0,d.glyph.properties.ys.internal=!0,a.glyph.properties.x.internal=!0,a.glyph.properties.y.internal=!0,d.glyph.xs={expr:t},d.glyph.ys={expr:i},a.glyph.x={expr:s},a.glyph.y={expr:o};const{parent:y}=this;this.edge_view=await p.build_view(d,{parent:y}),this.node_view=await p.build_view(a,{parent:y})}connect_signals(){super.connect_signals(),this.connect(this.model.layout_provider.change,(()=>{this.edge_view.set_data(),this.node_view.set_data(),this.request_render()}))}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 o.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)}}n.GraphRendererView=y,y.__name__=\"GraphRendererView\";class g extends s.DataRenderer{constructor(e){super(e)}static init_GraphRenderer(){this.prototype.default_view=y,this.define((({Ref:e})=>({layout_provider:[e(d.LayoutProvider)],node_renderer:[e(o.GlyphRenderer)],edge_renderer:[e(o.GlyphRenderer)],selection_policy:[e(a.GraphHitTestPolicy),()=>new a.NodesOnly],inspection_policy:[e(a.GraphHitTestPolicy),()=>new a.NodesOnly]})))}get_selection_manager(){return this.node_renderer.data_source.selection_manager}}n.GraphRenderer=g,g.__name__=\"GraphRenderer\",g.init_GraphRenderer()},\n", " function _(e,t,s,n,i){n();const c=e(53);class l extends c.Model{constructor(e){super(e)}initialize(){super.initialize(),this._connected=new Set,this._result=new Map}v_compute(e){this._connected.has(e)||(this.connect(e.change,(()=>this._result.delete(e))),this.connect(e.patching,(()=>this._result.delete(e))),this.connect(e.streaming,(()=>this._result.delete(e))),this._connected.add(e));let t=this._result.get(e);return null==t&&(t=this._v_compute(e),this._result.set(e,t)),t}}s.Expression=l,l.__name__=\"Expression\";class h extends c.Model{constructor(e){super(e)}initialize(){super.initialize(),this._connected=new Set,this._result=new Map}compute(e){this._connected.has(e)||(this.connect(e.change,(()=>this._result.delete(e))),this.connect(e.patching,(()=>this._result.delete(e))),this.connect(e.streaming,(()=>this._result.delete(e))),this._connected.add(e));let t=this._result.get(e);return null==t&&(t=this._compute(e),this._result.set(e,t)),t}}s.ScalarExpression=h,h.__name__=\"ScalarExpression\"},\n", " function _(o,e,r,t,n){t();const s=o(53);class c extends s.Model{constructor(o){super(o)}}r.LayoutProvider=c,c.__name__=\"LayoutProvider\"},\n", " function _(e,t,d,n,s){n();const o=e(53),r=e(12),_=e(9),i=e(59);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;er.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 _(t,e,i,n,s){n();const o=t(1),l=t(65),r=t(48),_=o.__importStar(t(107)),c=o.__importStar(t(18)),h=t(12),a=t(13),d=t(98),x=t(106),y=t(59);class g extends d.GlyphView{_project_data(){l.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(t){const{data_size:e}=this;for(let i=0;i0&&o.set(t,i)}return new y.Selection({indices:[...o.keys()],multiline_indices:a.to_object(o)})}get_interpolation_hit(t,e,i){const n=this._xs.get(t),s=this._ys.get(t),o=n[e],l=s[e],r=n[e+1],_=s[e+1];return x.line_interpolation(this.renderer,i,o,l,r,_)}draw_legend_for_index(t,e,i){x.generic_line_vector_legend(this.visuals,t,e,i)}scenterxy(){throw new Error(`${this}.scenterxy() is not implemented`)}}i.MultiLineView=g,g.__name__=\"MultiLineView\";class u extends d.Glyph{constructor(t){super(t)}static init_MultiLine(){this.prototype.default_view=g,this.define((({})=>({xs:[c.XCoordinateSeqSpec,{field:\"xs\"}],ys:[c.YCoordinateSeqSpec,{field:\"ys\"}]}))),this.mixins(r.LineVector)}}i.MultiLine=u,u.__name__=\"MultiLine\",u.init_MultiLine()},\n", " function _(e,t,s,i,n){i();const r=e(1),o=e(98),a=e(106),_=e(12),c=e(48),l=r.__importStar(e(107)),h=r.__importStar(e(18)),d=e(59),y=e(11),p=e(65);class x extends o.GlyphView{_project_data(){p.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(e){const{data_size:t}=this;for(let s=0;s({xs:[h.XCoordinateSeqSpec,{field:\"xs\"}],ys:[h.YCoordinateSeqSpec,{field:\"ys\"}]}))),this.mixins([c.LineVector,c.FillVector,c.HatchVector])}}s.Patches=f,f.__name__=\"Patches\",f.init_Patches()},\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),i=t(57),l=t(8),c=t(13),a=r.__importStar(t(131)),u=t(132),h=t(35);function d(t,n,e){if(l.isArray(t)){const s=t.concat(n);return null!=e&&s.length>e?s.slice(-e):s}if(l.isTypedArray(t)){const s=t.length+n.length;if(null!=e&&s>e){const o=s-e,r=t.length;let i;t.length({data:[t(n),{}]})))}stream(t,n,e){const{data:s}=this;for(const[e,o]of c.entries(t))s[e]=d(s[e],o,n);if(this.setv({data:s},{silent:!0}),this.streaming.emit(),null!=this.document){const s=new h.ColumnsStreamedEvent(this.document,this.ref(),t,n);this.document._notify_change(this,\"data\",null,null,{setter_id:e,hint:s})}}patch(t,n){const{data:e}=this;let s=new Set;for(const[n,o]of c.entries(t))s=u.union(s,m(e[n],o));if(this.setv({data:e},{silent:!0}),this.patching.emit([...s]),null!=this.document){const e=new h.ColumnsPatchedEvent(this.document,this.ref(),t);this.document._notify_change(this,\"data\",null,null,{setter_id:n,hint:e})}}}e.ColumnDataSource=_,_.__name__=\"ColumnDataSource\",_.init_ColumnDataSource()},\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 _(e,i,t,s,o){s();const n=e(1),a=e(53),l=e(42),r=n.__importStar(e(45)),_=e(48),c=n.__importStar(e(18));class d extends l.View{initialize(){super.initialize(),this.visuals=new r.Visuals(this)}request_render(){this.parent.request_render()}get canvas(){return this.parent.canvas}set_data(e){const i=this;for(const t of this.model){if(!(t instanceof c.VectorSpec||t instanceof c.ScalarSpec))continue;const s=t.uniform(e);i[`${t.attr}`]=s}}}t.ArrowHeadView=d,d.__name__=\"ArrowHeadView\";class h extends a.Model{constructor(e){super(e)}static init_ArrowHead(){this.define((()=>({size:[c.NumberSpec,25]})))}}t.ArrowHead=h,h.__name__=\"ArrowHead\",h.init_ArrowHead();class v extends d{clip(e,i){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.moveTo(.5*t,t),e.lineTo(.5*t,-2),e.lineTo(-.5*t,-2),e.lineTo(-.5*t,t),e.lineTo(0,0),e.lineTo(.5*t,t)}render(e,i){if(this.visuals.line.doit){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,t),e.lineTo(0,0),e.lineTo(-.5*t,t),e.stroke()}}}t.OpenHeadView=v,v.__name__=\"OpenHeadView\";class u extends h{constructor(e){super(e)}static init_OpenHead(){this.prototype.default_view=v,this.mixins(_.LineVector)}}t.OpenHead=u,u.__name__=\"OpenHead\",u.init_OpenHead();class m extends d{clip(e,i){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.moveTo(.5*t,t),e.lineTo(.5*t,-2),e.lineTo(-.5*t,-2),e.lineTo(-.5*t,t),e.lineTo(.5*t,t)}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 t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,t),e.lineTo(0,0),e.lineTo(-.5*t,t),e.closePath()}}t.NormalHeadView=m,m.__name__=\"NormalHeadView\";class T extends h{constructor(e){super(e)}static init_NormalHead(){this.prototype.default_view=m,this.mixins([_.LineVector,_.FillVector]),this.override({fill_color:\"black\"})}}t.NormalHead=T,T.__name__=\"NormalHead\",T.init_NormalHead();class p extends d{clip(e,i){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.moveTo(.5*t,t),e.lineTo(.5*t,-2),e.lineTo(-.5*t,-2),e.lineTo(-.5*t,t),e.lineTo(0,.5*t),e.lineTo(.5*t,t)}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 t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,t),e.lineTo(0,0),e.lineTo(-.5*t,t),e.lineTo(0,.5*t),e.closePath()}}t.VeeHeadView=p,p.__name__=\"VeeHeadView\";class H extends h{constructor(e){super(e)}static init_VeeHead(){this.prototype.default_view=p,this.mixins([_.LineVector,_.FillVector]),this.override({fill_color:\"black\"})}}t.VeeHead=H,H.__name__=\"VeeHead\",H.init_VeeHead();class V extends d{render(e,i){if(this.visuals.line.doit){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,0),e.lineTo(-.5*t,0),e.stroke()}}clip(e,i){}}t.TeeHeadView=V,V.__name__=\"TeeHeadView\";class f extends h{constructor(e){super(e)}static init_TeeHead(){this.prototype.default_view=V,this.mixins(_.LineVector)}}t.TeeHead=f,f.__name__=\"TeeHead\",f.init_TeeHead()},\n", " function _(s,e,i,t,l){t();const _=s(1),o=s(135),r=_.__importStar(s(48));class h extends o.UpperLowerView{paint(s){s.beginPath(),s.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let e=0,i=this._lower_sx.length;e=0;e--)s.lineTo(this._upper_sx[e],this._upper_sy[e]);s.closePath(),this.visuals.fill.doit&&(this.visuals.fill.set_value(s),s.fill()),s.beginPath(),s.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let e=0,i=this._lower_sx.length;e({dimension:[n.Dimension,\"height\"],lower:[h,{field:\"lower\"}],upper:[h,{field:\"upper\"}],base:[h,{field:\"base\"}]})))}}i.UpperLower=d,d.__name__=\"UpperLower\",d.init_UpperLower()},\n", " function _(t,i,o,n,e){n();const s=t(1),l=t(40),a=s.__importStar(t(48)),r=t(20),h=t(99);o.EDGE_TOLERANCE=2.5;class c extends l.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:i,top:o,bottom:n}=this.model;if(null==t&&null==i&&null==o&&null==n)return;const{frame:e}=this.plot_view,s=this.coordinates.x_scale,l=this.coordinates.y_scale,a=(t,i,o,n,e)=>{let s;return s=null!=t?this.model.screen?t:\"data\"==i?o.compute(t):n.compute(t):e,s};this.bbox=h.BBox.from_rect({left:a(t,this.model.left_units,s,e.bbox.xview,e.bbox.left),right:a(i,this.model.right_units,s,e.bbox.xview,e.bbox.right),top:a(o,this.model.top_units,l,e.bbox.yview,e.bbox.top),bottom:a(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:i,top:o,width:n,height:e}=this.bbox;t.beginPath(),t.rect(i,o,n,e),this.visuals.fill.doit&&(this.visuals.fill.set_value(t),t.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(t),t.fill()),this.visuals.line.doit&&(this.visuals.line.set_value(t),t.stroke()),t.restore()}interactive_bbox(){const t=this.model.line_width+o.EDGE_TOLERANCE;return this.bbox.grow_by(t)}interactive_hit(t,i){if(null==this.model.in_cursor)return!1;return this.interactive_bbox().contains(t,i)}cursor(t,i){const{left:o,right:n,bottom:e,top:s}=this.bbox;return Math.abs(t-o)<3||Math.abs(t-n)<3?this.model.ew_cursor:Math.abs(i-e)<3||Math.abs(i-s)<3?this.model.ns_cursor:this.bbox.contains(t,i)?this.model.in_cursor:null}}o.BoxAnnotationView=c,c.__name__=\"BoxAnnotationView\";class u extends l.Annotation{constructor(t){super(t)}static init_BoxAnnotation(){this.prototype.default_view=c,this.mixins([a.Line,a.Fill,a.Hatch]),this.define((({Number:t,Nullable:i})=>({top:[i(t),null],top_units:[r.SpatialUnits,\"data\"],bottom:[i(t),null],bottom_units:[r.SpatialUnits,\"data\"],left:[i(t),null],left_units:[r.SpatialUnits,\"data\"],right:[i(t),null],right_units:[r.SpatialUnits,\"data\"],render_mode:[r.RenderMode,\"canvas\"]}))),this.internal((({Boolean:t,String:i,Nullable:o})=>({screen:[t,!1],ew_cursor:[o(i),null],ns_cursor:[o(i),null],in_cursor:[o(i),null]}))),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}update({left:t,right:i,top:o,bottom:n}){this.setv({left:t,right:i,top:o,bottom:n,screen:!0})}}o.BoxAnnotation=u,u.__name__=\"BoxAnnotation\",u.init_BoxAnnotation()},\n", " function _(t,e,i,o,n){o();const a=t(1),r=t(40),s=t(138),l=t(144),_=t(162),c=t(165),h=t(198),u=t(166),p=t(205),m=t(169),g=t(203),d=t(202),f=t(209),w=t(217),b=t(220),v=t(20),x=a.__importStar(t(48)),y=t(9),k=t(221),C=t(222),z=t(225),j=t(140),B=t(11),L=t(122),S=t(99),M=t(8);class T extends r.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 f.LogColorMapper:return new h.LogTicker;case i instanceof f.ScanningColorMapper:return new h.BinnedTicker({mapper:i});case i instanceof f.CategoricalColorMapper:return new h.CategoricalTicker;default:return new h.BasicTicker}})(),this._formatter=\"auto\"!=e?e:(()=>{switch(!0){case this._ticker instanceof h.LogTicker:return new p.LogTickFormatter;case i instanceof f.CategoricalColorMapper:return new p.CategoricalTickFormatter;default:return new p.BasicTickFormatter}})(),this._major_range=(()=>{if(i instanceof f.CategoricalColorMapper){const{factors:t}=i;return new b.FactorRange({factors:t})}if(i instanceof d.ContinuousColorMapper){const{min:t,max:e}=i.metrics;return new b.Range1d({start:t,end:e})}B.unreachable()})(),this._major_scale=(()=>{if(i instanceof f.LinearColorMapper)return new w.LinearScale;if(i instanceof f.LogColorMapper)return new w.LogScale;if(i instanceof f.ScanningColorMapper){const{binning:t}=i.metrics;return new w.LinearInterpolationScale({binning:t})}if(i instanceof f.CategoricalColorMapper)return new w.CategoricalScale;B.unreachable()})(),this._minor_range=new b.Range1d({start:0,end:1}),this._minor_scale=new w.LinearScale;const o=x.attrs_of(this.model,\"major_label_\",x.Text,!0),n=x.attrs_of(this.model,\"major_tick_\",x.Line,!0),a=x.attrs_of(this.model,\"minor_tick_\",x.Line,!0),r=x.attrs_of(this.model,\"title_\",x.Text),l=i instanceof f.CategoricalColorMapper?_.CategoricalAxis:i instanceof f.LogColorMapper?_.LogAxis:_.LinearAxis;this._axis=new l(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:c}=this.model;c&&(this._title=new s.Title(Object.assign({text:c,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 L.build_view(this._axis,{parent:e}),null!=this._title&&(this._title_view=await L.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 d.ContinuousColorMapper&&t instanceof b.Range1d){const{min:e,max:o}=i.metrics;t.setv({start:e,end:o})}if(i instanceof f.ScanningColorMapper&&e instanceof w.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?y.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 f.LinearColorMapper({palette:e}).rgba_mapper.v_compute(y.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(!M.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})(),_=new C.NodeLayout,c=new C.VStack,h=new C.VStack,u=new C.HStack,p=new C.HStack;_.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 l.CartesianFrame(m,g,d,f),_.on_resize((t=>this._frame.set_geometry(t)));const w=new z.BorderLayout;this._inner_layout=w,w.absolute=!0,w.center_panel=_,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(M.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(!M.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 S.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 S.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 S.BBox({right:n,top:e,width:i,height:o})}else if(\"center\"==r){const{hcenter:n}=this.layout.bbox;t=new S.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 S.BBox({left:e,bottom:n,width:i,height:o})}else if(\"center\"==a){const{vcenter:n}=this.layout.bbox;t=new S.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 S.BBox({left:a+o,top:r+n,width:s,height:l})}return[t,e]}})();let x,y,B,L;if(w.padding=b,null!=this.panel?(x=\"max\",y=void 0,B=void 0,L=void 0):\"auto\"==(\"horizontal\"==s?e:i)?(x=\"fixed\",y=25*this.model.color_mapper.palette.length,B={percent:.3},L={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:B,max_width:L,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:B,max_height:L,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:T}=this;null!=T&&(\"horizontal\"==s?(T.panel=new j.Panel(\"above\"),T.update_layout(),c.children.push(T.layout)):(T.panel=new j.Panel(\"left\"),T.update_layout(),u.children.push(T.layout)));const{panel:A}=this,O=null!=A&&s==A.orientation?A.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 j.Panel(O),F.update_layout(),R.children.push(F.layout),null!=this.panel){const t=new k.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=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=T,T.__name__=\"ColorBarView\";class A extends r.Annotation{constructor(t){super(t)}static init_ColorBar(){this.prototype.default_view=T,this.mixins([[\"major_label_\",x.Text],[\"title_\",x.Text],[\"major_tick_\",x.Line],[\"minor_tick_\",x.Line],[\"border_\",x.Line],[\"bar_\",x.Line],[\"background_\",x.Fill]]),this.define((({Alpha:t,Number:e,String:i,Tuple:o,Dict:n,Or:a,Ref:r,Auto:s,Nullable:l})=>({location:[a(v.Anchor,o(e,e)),\"top_right\"],orientation:[a(v.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(c.Ticker),s),\"auto\"],formatter:[a(r(u.TickFormatter),s),\"auto\"],major_label_overrides:[n(i),{}],major_label_policy:[r(m.LabelingPolicy),()=>new m.NoOverlap],color_mapper:[r(g.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]}))),this.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\"})}}i.ColorBar=A,A.__name__=\"ColorBar\",A.init_ColorBar()},\n", " function _(t,e,i,s,l){s();const o=t(1),a=t(139),n=t(20),r=t(143),c=o.__importStar(t(48));class h extends a.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;if(null==t||0==t.length)return{width:0,height:0};{const{ctx:e}=this.layer;this.visuals.text.set_value(e);const{width:i}=this.layer.ctx.measureText(t),{height:s}=r.font_metrics(e.font);return{width:i,height:2+s*this.model.text_line_height+this.model.standoff}}}}i.TitleView=h,h.__name__=\"TitleView\";class _ extends a.TextAnnotation{constructor(t){super(t)}static init_Title(){this.prototype.default_view=h,this.mixins([c.Text,[\"border_\",c.Line],[\"background_\",c.Fill]]),this.define((({Number:t,String:e})=>({text:[e,\"\"],vertical_align:[n.VerticalAlign,\"bottom\"],align:[n.TextAlign,\"left\"],offset:[t,0],standoff:[t,10]}))),this.prototype._props.text_align.options.internal=!0,this.prototype._props.text_baseline.options.internal=!0,this.override({text_font_size:\"13px\",text_font_style:\"bold\",text_line_height:1,background_fill_color:null,border_line_color:null})}}i.Title=_,_.__name__=\"Title\",_.init_Title()},\n", " function _(e,t,s,i,n){i();const l=e(40),a=e(43),o=e(20),r=e(140),d=e(143),c=e(11);class _ extends l.AnnotationView{update_layout(){const{panel:e}=this;this.layout=null!=e?new r.SideLayout(e,(()=>this.get_size()),!0):void 0}initialize(){super.initialize(),\"css\"==this.model.render_mode&&(this.el=a.div(),this.plot_view.canvas_view.add_overlay(this.el))}remove(){null!=this.el&&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||a.undisplay(this.el),super.render()}_calculate_text_dimensions(e,t){const{width:s}=e.measureText(t),{height:i}=d.font_metrics(this.visuals.text.font_value());return[s,i]}_calculate_bounding_box_dimensions(e,t){const[s,i]=this._calculate_text_dimensions(e,t);let n,l;switch(e.textAlign){case\"left\":n=0;break;case\"center\":n=-s/2;break;case\"right\":n=-s;break;default:c.unreachable()}switch(e.textBaseline){case\"top\":l=0;break;case\"middle\":l=-.5*i;break;case\"bottom\":l=-1*i;break;case\"alphabetic\":l=-.8*i;break;case\"hanging\":l=-.17*i;break;case\"ideographic\":l=-.83*i;break;default:c.unreachable()}return[n,l,s,i]}_canvas_text(e,t,s,i,n){this.visuals.text.set_value(e);const l=this._calculate_bounding_box_dimensions(e,t);e.save(),e.beginPath(),e.translate(s,i),n&&e.rotate(n),e.rect(l[0],l[1],l[2],l[3]),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(e),e.fill()),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(e),e.stroke()),this.visuals.text.doit&&(this.visuals.text.set_value(e),e.fillText(t,0,0)),e.restore()}_css_text(e,t,s,i,n){const{el:l}=this;c.assert(null!=l),a.undisplay(l),this.visuals.text.set_value(e);const[o,r]=this._calculate_bounding_box_dimensions(e,t);l.style.position=\"absolute\",l.style.left=`${s+o}px`,l.style.top=`${i+r}px`,l.style.color=e.fillStyle,l.style.font=e.font,l.style.lineHeight=\"normal\",n&&(l.style.transform=`rotate(${n}rad)`),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(e),l.style.backgroundColor=e.fillStyle),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(e),l.style.borderStyle=e.lineDash.length<2?\"solid\":\"dashed\",l.style.borderWidth=`${e.lineWidth}px`,l.style.borderColor=e.strokeStyle),l.textContent=t,a.display(l)}}s.TextAnnotationView=_,_.__name__=\"TextAnnotationView\";class u extends l.Annotation{constructor(e){super(e)}static init_TextAnnotation(){this.define((()=>({render_mode:[o.RenderMode,\"canvas\"]})))}}s.TextAnnotation=u,u.__name__=\"TextAnnotation\",u.init_TextAnnotation()},\n", " function _(t,e,i,l,r){l();const a=t(141),o=t(142),n=t(8),h=Math.PI/2,s={above:{parallel:0,normal:-h,horizontal:0,vertical:-h},below:{parallel:0,normal:h,horizontal:0,vertical:h},left:{parallel:-h,normal:0,horizontal:0,vertical:-h},right:{parallel:h,normal:0,horizontal:0,vertical:h}},c={above:{parallel:\"bottom\",normal:\"center\",horizontal:\"bottom\",vertical:\"center\"},below:{parallel:\"top\",normal:\"center\",horizontal:\"top\",vertical:\"center\"},left:{parallel:\"bottom\",normal:\"center\",horizontal:\"center\",vertical:\"bottom\"},right:{parallel:\"bottom\",normal:\"center\",horizontal:\"center\",vertical:\"bottom\"}},g={above:{parallel:\"center\",normal:\"left\",horizontal:\"center\",vertical:\"left\"},below:{parallel:\"center\",normal:\"left\",horizontal:\"center\",vertical:\"left\"},left:{parallel:\"center\",normal:\"right\",horizontal:\"right\",vertical:\"center\"},right:{parallel:\"center\",normal:\"left\",horizontal:\"left\",vertical:\"center\"}},_={above:\"right\",below:\"left\",left:\"right\",right:\"left\"},b={above:\"left\",below:\"right\",left:\"right\",right:\"left\"};class z{constructor(t){this.side=t}get dimension(){return\"above\"==this.side||\"below\"==this.side?0:1}get normals(){switch(this.side){case\"above\":return[0,-1];case\"below\":return[0,1];case\"left\":return[-1,0];case\"right\":return[1,0]}}get orientation(){return this.is_horizontal?\"horizontal\":\"vertical\"}get is_horizontal(){return 0==this.dimension}get is_vertical(){return 1==this.dimension}get_label_text_heuristics(t){const{side:e}=this;return n.isString(t)?{vertical_align:c[e][t],align:g[e][t]}:{vertical_align:\"center\",align:(t<0?_:b)[e]}}get_label_angle_heuristic(t){return n.isString(t)?s[this.side][t]:-t}}i.Panel=z,z.__name__=\"Panel\";class m extends o.ContentLayoutable{constructor(t,e,i=!1){super(),this.panel=t,this.get_size=e,this.rotate=i,this.panel.is_horizontal?this.set_sizing({width_policy:\"max\",height_policy:\"fixed\"}):this.set_sizing({width_policy:\"fixed\",height_policy:\"max\"})}_content_size(){const{width:t,height:e}=this.get_size();return!this.rotate||this.panel.is_horizontal?new a.Sizeable({width:t,height:e}):new a.Sizeable({width:e,height:t})}has_size_changed(){const{width:t,height:e}=this._content_size();return this.panel.is_horizontal?this.bbox.height!=e:this.bbox.width!=t}}i.SideLayout=m,m.__name__=\"SideLayout\"},\n", " function _(h,t,i,e,w){e();const n=h(21),{min:d,max:s}=Math;class g{constructor(h={}){this.width=null!=h.width?h.width:0,this.height=null!=h.height?h.height:0}bounded_to({width:h,height:t}){return new g({width:this.width==1/0&&null!=h?h:this.width,height:this.height==1/0&&null!=t?t:this.height})}expanded_to({width:h,height:t}){return new g({width:h!=1/0?s(this.width,h):this.width,height:t!=1/0?s(this.height,t):this.height})}expand_to({width:h,height:t}){this.width=s(this.width,h),this.height=s(this.height,t)}narrowed_to({width:h,height:t}){return new g({width:d(this.width,h),height:d(this.height,t)})}narrow_to({width:h,height:t}){this.width=d(this.width,h),this.height=d(this.height,t)}grow_by({left:h,right:t,top:i,bottom:e}){const w=this.width+h+t,n=this.height+i+e;return new g({width:w,height:n})}shrink_by({left:h,right:t,top:i,bottom:e}){const w=s(this.width-h-t,0),n=s(this.height-i-e,0);return new g({width:w,height:n})}map(h,t){return new g({width:h(this.width),height:(null!=t?t:h)(this.height)})}}i.Sizeable=g,g.__name__=\"Sizeable\",i.SizingPolicy=n.Enum(\"fixed\",\"fit\",\"min\",\"max\")},\n", " function _(i,t,h,e,n){e();const s=i(141),r=i(99),g=i(8),{min:l,max:a,round:_}=Math;class o{constructor(){this.absolute=!1,this._bbox=new r.BBox,this._inner_bbox=new r.BBox,this._dirty=!1,this._handlers=[]}*[Symbol.iterator](){}get bbox(){return this._bbox}get inner_bbox(){return this._inner_bbox}get sizing(){return this._sizing}set visible(i){this._sizing.visible=i,this._dirty=!0}set_sizing(i){var t,h,e,n,s;const r=null!==(t=i.width_policy)&&void 0!==t?t:\"fit\",g=i.width,l=i.min_width,a=i.max_width,_=null!==(h=i.height_policy)&&void 0!==h?h:\"fit\",o=i.height,d=i.min_height,u=i.max_height,c=i.aspect,w=null!==(e=i.margin)&&void 0!==e?e:{top:0,right:0,bottom:0,left:0},m=!1!==i.visible,x=null!==(n=i.halign)&&void 0!==n?n:\"start\",b=null!==(s=i.valign)&&void 0!==s?s:\"start\";this._sizing={width_policy:r,min_width:l,width:g,max_width:a,height_policy:_,min_height:d,height:o,max_height:u,aspect:c,margin:w,visible:m,halign:x,valign:b,size:{width:g,height:o}},this._init()}_init(){}_set_geometry(i,t){this._bbox=i,this._inner_bbox=t}set_geometry(i,t){const{fixup_geometry:h}=this;null!=h&&([i,t]=h(i,t)),this._set_geometry(i,null!=t?t:i);for(const i of this._handlers)i(this._bbox,this._inner_bbox)}on_resize(i){this._handlers.push(i)}is_width_expanding(){return\"max\"==this.sizing.width_policy}is_height_expanding(){return\"max\"==this.sizing.height_policy}apply_aspect(i,{width:t,height:h}){const{aspect:e}=this.sizing;if(null!=e){const{width_policy:n,height_policy:s}=this.sizing,r=(i,t)=>{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:g.isNumber(h)||(h=Math.round(h.percent*t)),null==e?e=1/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 _(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(\"ÅŚg|\"),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};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};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 _(e,t,s,_,a){_();const r=e(145),n=e(157),g=e(156),i=e(159),c=e(104),h=e(99),o=e(13),l=e(11);class x{constructor(e,t,s,_,a={},r={}){this.in_x_scale=e,this.in_y_scale=t,this.x_range=s,this.y_range=_,this.extra_x_ranges=a,this.extra_y_ranges=r,this._bbox=new h.BBox,l.assert(null==e.source_range&&null==e.target_range),l.assert(null==t.source_range&&null==t.target_range),this._configure_scales()}get bbox(){return this._bbox}_get_ranges(e,t){return new Map(o.entries(Object.assign(Object.assign({},t),{default:e})))}_get_scales(e,t,s){const _=new Map;for(const[a,g]of t){if(g instanceof c.FactorRange!=e instanceof r.CategoricalScale)throw new Error(`Range ${g.type} is incompatible is Scale ${e.type}`);e instanceof n.LogScale&&g instanceof i.DataRange1d&&(g.scale_hint=\"log\");const t=e.clone();t.setv({source_range:g,target_range:s}),_.set(a,t)}return _}_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._x_ranges,this._x_target),this._y_scales=this._get_scales(this.in_y_scale,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 o.to_object(this.x_scales)}get yscales(){return o.to_object(this.y_scales)}}s.CartesianFrame=x,x.__name__=\"CartesianFrame\"},\n", " function _(e,t,r,n,_){n();const c=e(146);class s extends c.Scale{constructor(e){super(e)}get s_compute(){const[e,t]=this._linear_compute_state(),r=this.source_range;return n=>e*r.synthetic(n)+t}compute(e){return super._linear_compute(this.source_range.synthetic(e))}v_compute(e){return super._linear_v_compute(this.source_range.v_synthetic(e))}invert(e){return this._linear_invert(e)}v_invert(e){return this._linear_v_invert(e)}}r.CategoricalScale=s,s.__name__=\"CategoricalScale\"},\n", " function _(t,e,r,n,s){n();const i=t(147),_=t(105),a=t(156),c=t(24);class o extends i.Transform{constructor(t){super(t)}static init_Scale(){this.internal((({Ref:t})=>({source_range:[t(_.Range)],target_range:[t(a.Range1d)]})))}r_compute(t,e){return this.target_range.is_reversed?[this.compute(e),this.compute(t)]:[this.compute(t),this.compute(e)]}r_invert(t,e){return this.target_range.is_reversed?[this.invert(e),this.invert(t)]:[this.invert(t),this.invert(e)]}_linear_compute(t){const[e,r]=this._linear_compute_state();return e*t+r}_linear_v_compute(t){const[e,r]=this._linear_compute_state(),n=new c.ScreenArray(t.length);for(let s=0;s({args:[s(t),{}],func:[r,\"\"],v_func:[r,\"\"]})))}get names(){return o.keys(this.args)}get values(){return o.values(this.args)}_make_transform(t,r){return new Function(...this.names,t,u.use_strict(r))}get scalar_transform(){return this._make_transform(\"x\",this.func)}get vector_transform(){return this._make_transform(\"xs\",this.v_func)}compute(t){return this.scalar_transform(...this.values,t)}v_compute(t){return this.vector_transform(...this.values,t)}}s.CustomJSTransform=m,m.__name__=\"CustomJSTransform\",m.init_CustomJSTransform()},\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,o,s){o();const i=e(151);class r extends i.RangeTransform{constructor(e){super(e)}static init_Dodge(){this.define((({Number:e})=>({value:[e,0]})))}_compute(e){return e+this.value}}n.Dodge=r,r.__name__=\"Dodge\",r.init_Dodge()},\n", " function _(e,n,t,r,s){r();const a=e(149),i=e(105),o=e(104),c=e(24),f=e(8);class u extends a.Transform{constructor(e){super(e)}static init_RangeTransform(){this.define((({Ref:e,Nullable:n})=>({range:[n(e(i.Range)),null]})))}v_compute(e){let n;if(this.range instanceof o.FactorRange)n=this.range.v_synthetic(e);else{if(!f.isArrayableOf(e,f.isNumber))throw new Error(\"unexpected\");n=e}const t=new(c.infer_type(n))(n.length);for(let e=0;e({x:[s(r,o(e))],y:[s(r,o(e))],data:[a(n(i.ColumnarDataSource)),null],clip:[t,!0]})))}connect_signals(){super.connect_signals(),this.connect(this.change,(()=>this._sorted_dirty=!0))}v_compute(t){const e=new(a.infer_type(t))(t.length);for(let r=0;rs*(e[t]-e[r]))),this._x_sorted=new(a.infer_type(e))(n),this._y_sorted=new(a.infer_type(r))(n);for(let t=0;t({mean:[t,0],width:[t,1],distribution:[o.Distribution,\"uniform\"]})))}v_compute(t){return null!=this.previous_values&&this.previous_values.length==t.length||(this.previous_values=super.v_compute(t)),this.previous_values}_compute(t){switch(this.distribution){case\"uniform\":return t+this.mean+(a.random()-.5)*this.width;case\"normal\":return t+a.rnorm(this.mean,this.width)}}}e.Jitter=h,h.__name__=\"Jitter\",h.init_Jitter()},\n", " function _(t,s,_,r,e){r();const i=t(9),o=t(152);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=i.find_last_index(this._x_sorted,(s=>s({mode:[_.StepMode,\"after\"]})))}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]}let e;switch(this.mode){case\"after\":e=n.find_last_index(this._x_sorted,(e=>t>=e));break;case\"before\":e=n.find_index(this._x_sorted,(e=>t<=e));break;case\"center\":{const s=n.map(this._x_sorted,(e=>Math.abs(e-t))),r=n.min(s);e=n.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=d,d.__name__=\"StepInterpolator\",d.init_StepInterpolator()},\n", " function _(t,e,s,n,i){n();const a=t(105);class r extends a.Range{constructor(t){super(t)}static init_Range1d(){this.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}}]})))}_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 r({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 r({start:e,end:s})}}s.Range1d=r,r.__name__=\"Range1d\",r.init_Range1d()},\n", " function _(t,e,o,n,s){n();const a=t(158),r=t(24);class c extends a.ContinuousScale{constructor(t){super(t)}get s_compute(){const[t,e,o,n]=this._compute_state();return s=>{if(0==o)return 0;{const a=(Math.log(s)-n)/o;return isFinite(a)?a*t+e:NaN}}}compute(t){const[e,o,n,s]=this._compute_state();let a;if(0==n)a=0;else{const r=(Math.log(t)-s)/n;a=isFinite(r)?r*e+o:NaN}return a}v_compute(t){const[e,o,n,s]=this._compute_state(),a=new r.ScreenArray(t.length);if(0==n)for(let e=0;e({start:[i],end:[i],range_padding:[i,.1],range_padding_units:[_.PaddingUnits,\"percent\"],flipped:[t,!1],follow:[n(_.StartEnd),null],follow_interval:[n(i),null],default_span:[i,2],only_visible:[t,!1]}))),this.internal((({Enum:t})=>({scale_hint:[t(\"log\",\"auto\"),\"auto\"]})))}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=o.concat(this.plots.map((t=>t.data_renderers)));return d.compute_renderers(0==t.length?\"auto\":t,n,i)}_compute_plot_bounds(t,i){let n=r.empty();for(const a of t){const t=i.get(a);null==t||!a.visible&&this.only_visible||(n=r.union(n,t))}return n}adjust_bounds_for_aspect(t,i){const n=r.empty();let a=t.x1-t.x0;a<=0&&(a=1);let e=t.y1-t.y0;e<=0&&(e=1);const s=.5*(t.x1+t.x0),l=.5*(t.y1+t.y0);return al&&(\"start\"==this.follow?e=a+s*l:\"end\"==this.follow&&(a=e-s*l)),[a,e]}update(t,i,n,a){if(this.have_updated_interactively)return;const e=this.computed_renderers();let s=this._compute_plot_bounds(e,t);null!=a&&(s=this.adjust_bounds_for_aspect(s,a)),this._plot_bounds.set(n,s);const[l,_]=this._compute_min_max(this._plot_bounds.values(),i);let[o,h]=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&&(h=this._initial_end):h=this._initial_end);let r=!1;\"auto\"==this.bounds&&(this.setv({bounds:[o,h]},{silent:!0}),r=!0);const[d,u]=[this.start,this.end];if(o!=d||h!=u){const t={};o!=d&&(t.start=o),h!=u&&(t.end=h),this.setv(t),r=!1}r&&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=u,u.__name__=\"DataRange1d\",u.init_DataRange1d()},\n", " function _(a,e,n,t,r){t();const s=a(105),i=a(62);class R extends s.Range{constructor(a){super(a)}static init_DataRange(){this.define((({String:a,Array:e,Ref:n})=>({names:[e(a),[]],renderers:[e(n(i.DataRenderer)),[]]})))}}n.DataRange=R,R.__name__=\"DataRange\",R.init_DataRange()},\n", " function _(n,e,t,r,u){r();const l=n(9);t.compute_renderers=function(n,e,t){if(null==n)return[];let r=\"auto\"==n?e:n;return t.length>0&&(r=r.filter((n=>l.includes(t,n.name)))),r}},\n", " function _(i,s,x,A,o){A(),o(\"Axis\",i(163).Axis),o(\"CategoricalAxis\",i(170).CategoricalAxis),o(\"ContinuousAxis\",i(173).ContinuousAxis),o(\"DatetimeAxis\",i(174).DatetimeAxis),o(\"LinearAxis\",i(175).LinearAxis),o(\"LogAxis\",i(192).LogAxis),o(\"MercatorAxis\",i(195).MercatorAxis)},\n", " function _(t,e,i,s,o){s();const n=t(1),a=t(164),l=t(165),r=t(166),_=t(169),h=n.__importStar(t(48)),c=t(20),b=t(24),m=t(140),d=t(9),u=t(8),x=t(167),g=t(104),{abs:f}=Math;class p extends a.GuideRendererView{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(),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,[o,n]=this.coordinates.map_to_screen(i,s),[a,l]=this.normals,[r,_]=this.offsets;this.visuals.axis_line.set_value(t),t.beginPath();for(let e=0;e0?o+s+3:0}_draw_axis_label(t,e,i){const s=this.model.axis_label;if(!s||null!=this.model.fixed_location)return;const o=new x.TextBox({text:s});o.visuals=this.visuals.axis_label_text,o.angle=this.panel.get_label_angle_heuristic(\"parallel\"),o.base_font_size=this.plot_view.base_font_size;const[n,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]}})(),[l,r]=this.normals,_=e.tick+e.tick_label+this.model.axis_label_standoff,{vertical_align:h,align:c}=this.panel.get_label_text_heuristics(\"parallel\");o.position={sx:n+l*_,sy:a+r*_,x_anchor:c,y_anchor:h},o.align=c,o.paint(t)}_draw_ticks(t,e,i,s,o){if(!o.doit)return;const[n,a]=e,[l,r]=this.coordinates.map_to_screen(n,a),[_,h]=this.normals,[c,b]=this.offsets,[m,d]=[_*(c-i),h*(b-i)],[u,x]=[_*(c+s),h*(b+s)];o.set_value(t),t.beginPath();for(let e=0;et.bbox())),T=(()=>{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,A=O.filter(v,z,T),M=[...A.ones()];if(0!=M.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:o}=y[e];y[e].position=Object.assign(Object.assign({},o),{sx:o.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:o}=y[e];y[e].position=Object.assign(Object.assign({},o),{sy:o.sy-s})}},s=M[0],o=M[M.length-1];0==this.dimension?(e(s),e(o)):(i(s),i(o))}for(const e of A){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,o=this.visuals.major_label_text;return[this._oriented_labels_extent(e,i,s,o)]}get extents(){const t=this._tick_label_extents();return{tick:this._tick_extent(),tick_labels:t,tick_label:d.sum(t),axis_label:this._axis_label_extent()}}_oriented_labels_extent(t,e,i,s){if(0==t.length)return 0;const o=this.panel.get_label_angle_heuristic(e);t.visuals=s,t.angle=o,t.base_font_size=this.plot_view.base_font_size;const n=t.max_size(),a=0==this.dimension?n.height:n.width;return a>0?i+a+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_overrides:i}=this.model;for(let s=0;sf(a-l)?(t=_(r(o,n),a),s=r(_(o,n),l)):(t=r(o,n),s=_(o,n)),[t,s]}}get rule_coords(){const t=this.dimension,e=(t+1)%2,[i]=this.ranges,[s,o]=this.computed_bounds,n=[new Array(2),new Array(2)];return n[t][0]=Math.max(s,i.min),n[t][1]=Math.min(o,i.max),n[t][0]>n[t][1]&&(n[t][0]=n[t][1]=NaN),n[e][0]=this.loc,n[e][1]=this.loc,n}get tick_coords(){const t=this.dimension,e=(t+1)%2,[i]=this.ranges,[s,o]=this.computed_bounds,n=this.model.ticker.get_ticks(s,o,i,this.loc),a=n.major,l=n.minor,r=[[],[]],_=[[],[]],[h,c]=[i.min,i.max];for(let i=0;ic||(r[t].push(a[i]),r[e].push(this.loc));for(let i=0;ic||(_[t].push(l[i]),_[e].push(this.loc));return{major:r,minor:_}}get loc(){const{fixed_location:t}=this.model;if(null!=t){if(u.isNumber(t))return t;const[,e]=this.ranges;if(e instanceof g.FactorRange)return e.synthetic(t);throw new Error(\"unexpected\")}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})}}i.AxisView=p,p.__name__=\"AxisView\";class k extends a.GuideRenderer{constructor(t){super(t)}static init_Axis(){this.prototype.default_view=p,this.mixins([[\"axis_\",h.Line],[\"major_tick_\",h.Line],[\"minor_tick_\",h.Line],[\"major_label_\",h.Text],[\"axis_label_\",h.Text]]),this.define((({Any:t,Int:e,Number:i,String:s,Ref:o,Dict:n,Tuple:a,Or:h,Nullable:b,Auto:m})=>({bounds:[h(a(i,i),m),\"auto\"],ticker:[o(l.Ticker)],formatter:[o(r.TickFormatter)],axis_label:[b(s),\"\"],axis_label_standoff:[e,5],major_label_standoff:[e,5],major_label_orientation:[h(c.TickLabelOrientation,i),\"horizontal\"],major_label_overrides:[n(s),{}],major_label_policy:[o(_.LabelingPolicy),()=>new _.AllLabels],major_tick_in:[i,2],major_tick_out:[i,6],minor_tick_in:[i,0],minor_tick_out:[i,4],fixed_location:[b(h(i,t)),null]}))),this.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\"})}}i.Axis=k,k.__name__=\"Axis\",k.init_Axis()},\n", " function _(e,r,d,i,n){i();const s=e(41);class t extends s.RendererView{}d.GuideRendererView=t,t.__name__=\"GuideRendererView\";class _ extends s.Renderer{constructor(e){super(e)}static init_GuideRenderer(){this.override({level:\"guide\"})}}d.GuideRenderer=_,_.__name__=\"GuideRenderer\",_.init_GuideRenderer()},\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(167);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 _(t,e,s,i,n){i();const h=t(99),o=t(143),a=t(9),r=t(8),c=t(168),_=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._base_font_size=13}set base_font_size(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),a=Math.max(t.x,e.x,s.x,i.x),r=Math.max(t.y,e.y,s.y,i.y);return new h.BBox({left:n,right:a,top:o,bottom:r})}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.align=\"left\",this.text=t}set visuals(t){const e=t.text_color.get_value(),s=t.text_alpha.get_value(),i=t.text_font_style.get_value();let n=t.text_font_size.get_value();const h=t.text_font.get_value(),{font_size_scale:a,base_font_size:r}=this,c=o.parse_css_font_size(n);if(null!=c){let{value:t,unit:e}=c;t*=a,\"em\"==e&&r&&(t*=r,e=\"px\"),n=`${t}${e}`}const l=`${i} ${n} ${h}`;this.font=l,this.color=_.color2css(e,s),this.line_height=t.text_line_height.get_value()}infer_text_height(){if(this.text.includes(\"\\n\"))return\"ascent_descent\";return function(t){for(const e of new Set(t))if(!(\"0\"<=e&&e<=\"9\"))switch(e){case\",\":case\".\":case\"+\":case\"-\":case\"−\":case\"e\":continue;default:return!1}return!0}(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=o.font_metrics(i),h=(this.line_height-1)*n.height,r=\"\"==this.text,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>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:a.max(l)*u,height:r?0:(x+h*(_-1))*p,metrics:n}}_computed_position(t,e,s){const{width:i,height:n}=t,{sx:h,sy:o,x_anchor:a=\"left\",y_anchor:c=\"center\"}=this.position;return{x:h-(()=>{if(r.isNumber(a))return a*i;switch(a){case\"left\":return 0;case\"center\":return.5*i;case\"right\":return i}})(),y:o-(()=>{var t;if(r.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=o.font_metrics(n),r=(this.line_height-1)*h.height,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>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=a.max(l)*p,d=(u+r*(_-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:v}=this;v&&(t.translate(b,m),t.rotate(v),t.translate(-b,-m));let{x:w,y:z}=this._computed_position({width:g,height:d},h,_);if(\"justify\"==y)for(let e=0;e<_;e++){let i=w;const h=c[e].split(\" \"),o=h.length,_=h.map((t=>s.text_width(t,n))),l=(g-a.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+r}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}=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=\"left\",y_anchor:h=\"center\"}=this.position;return{x:s-(()=>{if(r.isNumber(n))return n*t;switch(n){case\"left\":return 0;case\"center\":return.5*t;case\"right\":return t}})(),y:i-(()=>{if(r.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=a.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,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})`}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,p=t.length;for(let o=0;o({min_distance:[e,5]})))}filter(e,n,s){const{min_distance:t}=this;let i=null;for(const n of e)null!=i&&s(i,n)({args:[s(e),{}],code:[n,\"\"]})))}get names(){return c.keys(this.args)}get values(){return c.values(this.args)}get func(){const e=o.use_strict(this.code);return new a.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 l=i.next();if(l.done&&void 0!==l.value){const{value:n}=l;return n instanceof a.Indices?n:void 0===n?e:r.isIterable(n)?a.Indices.from_indices(e.size,n):a.Indices.all_unset(e.size)}{const n=[];do{n.push(l.value),l=i.next()}while(!l.done);return a.Indices.from_indices(e.size,n)}}}s.CustomLabelingPolicy=m,m.__name__=\"CustomLabelingPolicy\",m.init_CustomLabelingPolicy()},\n", " function _(t,s,e,o,i){o();const a=t(1),r=t(163),l=t(171),_=t(172),n=a.__importStar(t(48)),c=t(20),p=t(167),h=t(8);class m extends r.AxisView{_paint(t,s,e){this._draw_group_separators(t,s,e)}_draw_group_separators(t,s,e){const[o]=this.ranges,[i,a]=this.computed_bounds;if(!o.tops||o.tops.length<2||!this.visuals.separator_line.doit)return;const r=this.dimension,l=(r+1)%2,_=[[],[]];let n=0;for(let t=0;ti&&cnew p.GraphicsBoxes(t.map((t=>h.isString(t)?new p.TextBox({text:t}):t))),_=t=>l(this.model.formatter.doFormat(t,this));if(1==t.levels){const t=_(i.major);r.push([t,a.major,this.model.major_label_orientation,this.visuals.major_label_text])}else if(2==t.levels){const t=_(i.major.map((t=>t[1])));r.push([t,a.major,this.model.major_label_orientation,this.visuals.major_label_text]),r.push([l(i.tops),a.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]));r.push([t,a.major,this.model.major_label_orientation,this.visuals.major_label_text]),r.push([l(s),a.mids,this.model.subgroup_label_orientation,this.visuals.subgroup_text]),r.push([l(i.tops),a.tops,this.model.group_label_orientation,this.visuals.group_text])}return r}get tick_coords(){const t=this.dimension,s=(t+1)%2,[e]=this.ranges,[o,i]=this.computed_bounds,a=this.model.ticker.get_ticks(o,i,e,this.loc),r={major:[[],[]],mids:[[],[]],tops:[[],[]],minor:[[],[]]};return r.major[t]=a.major,r.major[s]=a.major.map((()=>this.loc)),3==e.levels&&(r.mids[t]=a.mids,r.mids[s]=a.mids.map((()=>this.loc))),e.levels>1&&(r.tops[t]=a.tops,r.tops[s]=a.tops.map((()=>this.loc))),r}}e.CategoricalAxisView=m,m.__name__=\"CategoricalAxisView\";class u extends r.Axis{constructor(t){super(t)}static init_CategoricalAxis(){this.prototype.default_view=m,this.mixins([[\"separator_\",n.Line],[\"group_\",n.Text],[\"subgroup_\",n.Text]]),this.define((({Number:t,Or:s})=>({group_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"],subgroup_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"]}))),this.override({ticker:()=>new l.CategoricalTicker,formatter:()=>new _.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\"})}}e.CategoricalAxis=u,u.__name__=\"CategoricalAxis\",u.init_CategoricalAxis()},\n", " function _(t,c,o,s,e){s();const r=t(165);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 m.DatetimeTicker,formatter:()=>new r.DatetimeTickFormatter})}}i.DatetimeAxis=c,c.__name__=\"DatetimeAxis\",c.init_DatetimeAxis()},\n", " function _(i,e,s,n,t){n();const r=i(173),a=i(176),o=i(177);class c extends r.ContinuousAxisView{}s.LinearAxisView=c,c.__name__=\"LinearAxisView\";class _ extends r.ContinuousAxis{constructor(i){super(i)}static init_LinearAxis(){this.prototype.default_view=c,this.override({ticker:()=>new o.BasicTicker,formatter:()=>new a.BasicTickFormatter})}}s.LinearAxis=_,_.__name__=\"LinearAxis\",_.init_LinearAxis()},\n", " function _(i,t,e,n,o){n();const s=i(166),r=i(34);function c(i){let t=\"\";for(const e of i)t+=\"-\"==e?\"−\":e;return t}e.unicode_replace=c;class _ extends s.TickFormatter{constructor(i){super(i),this.last_precision=3}static init_BasicTickFormatter(){this.define((({Boolean:i,Int:t,Auto:e,Or:n})=>({precision:[n(t,e),\"auto\"],use_scientific:[i,!0],power_limit_high:[t,5],power_limit_low:[t,-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=>c(i.toExponential(e)))):i.map((i=>c(r.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({base:[t,10],mantissas:[i(t),[1,2,5]],min_interval:[t,0],max_interval:[a(t),null]})))}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=r.nth(this.mantissas,-1)/this.base,i=r.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 e=i-t,s=this.get_ideal_interval(t,i,a),n=Math.floor(_.log(s/this.base_factor,this.base)),l=this.base**n*this.base_factor,h=this.extended_mantissas,m=h.map((t=>Math.abs(a-e/(t*l)))),v=h[r.argmin(m)]*l;return _.clamp(v,this.get_min_interval(),this.get_max_interval())}}a.AdaptiveTicker=l,l.__name__=\"AdaptiveTicker\",l.init_AdaptiveTicker()},\n", " function _(t,i,n,s,e){s();const o=t(165),r=t(9);class c extends o.Ticker{constructor(t){super(t)}static init_ContinuousTicker(){this.define((({Int:t})=>({num_minor_ticks:[t,5],desired_num_ticks:[t,6]})))}get_ticks(t,i,n,s){return this.get_ticks_no_defaults(t,i,s,this.desired_num_ticks)}get_ticks_no_defaults(t,i,n,s){const e=this.get_interval(t,i,s),o=Math.floor(t/e),c=Math.ceil(i/e);let _;_=isFinite(o)&&isFinite(c)?r.range(o,c+1):[];const u=_.map((t=>t*e)).filter((n=>t<=n&&n<=i)),a=this.num_minor_ticks,f=[];if(a>0&&u.length>0){const n=e/a,s=r.range(0,a).map((t=>t*n));for(const n of s.slice(1)){const s=u[0]-n;t<=s&&s<=i&&f.push(s)}for(const n of u)for(const e of s){const s=n+e;t<=s&&s<=i&&f.push(s)}}return{major:u,minor:f}}get_ideal_interval(t,i,n){return(i-t)/n}}n.ContinuousTicker=c,c.__name__=\"ContinuousTicker\",c.init_ContinuousTicker()},\n", " function _(t,s,e,i,n){i();const r=t(1).__importDefault(t(181)),o=t(166),a=t(19),c=t(182),m=t(9),u=t(8);function h(t){return r.default(t,\"%Y %m %d %H %M %S\").split(/\\s+/).map((t=>parseInt(t,10)))}function d(t,s){if(u.isFunction(s))return s(t);{const e=c.sprintf(\"$1%06d\",function(t){return Math.round(t/1e3%1*1e6)}(t));return-1==(s=s.replace(/((^|[^%])(%%)*)%f/,e)).indexOf(\"%\")?s:r.default(t,s)}}const l=[\"microseconds\",\"milliseconds\",\"seconds\",\"minsec\",\"minutes\",\"hourmin\",\"hours\",\"days\",\"months\",\"years\"];class f extends o.TickFormatter{constructor(t){super(t),this.strip_leading_zeros=!0}static init_DatetimeTickFormatter(){this.define((({String:t,Array:s})=>({microseconds:[s(t),[\"%fus\"]],milliseconds:[s(t),[\"%3Nms\",\"%S.%3Ns\"]],seconds:[s(t),[\"%Ss\"]],minsec:[s(t),[\":%M:%S\"]],minutes:[s(t),[\":%M\",\"%Mm\"]],hourmin:[s(t),[\"%H:%M\"]],hours:[s(t),[\"%Hh\",\"%H:%M\"]],days:[s(t),[\"%m/%d\",\"%a%d\"]],months:[s(t),[\"%m/%Y\",\"%b %Y\"]],years:[s(t),[\"%Y\"]]})))}initialize(){super.initialize(),this._update_width_formats()}_update_width_formats(){const t=+r.default(new Date),s=function(s){const e=s.map((s=>d(t,s).length)),i=m.sort_by(m.zip(e,s),(([t])=>t));return m.unzip(i)};this._width_formats={microseconds:s(this.microseconds),milliseconds:s(this.milliseconds),seconds:s(this.seconds),minsec:s(this.minsec),minutes:s(this.minutes),hourmin:s(this.hourmin),hours:s(this.hours),days:s(this.days),months:s(this.months),years:s(this.years)}}_get_resolution_str(t,s){const e=1.1*t;switch(!1){case!(e<.001):return\"microseconds\";case!(e<1):return\"milliseconds\";case!(e<60):return s>=60?\"minsec\":\"seconds\";case!(e<3600):return s>=3600?\"hourmin\":\"minutes\";case!(e<86400):return\"hours\";case!(e<2678400):return\"days\";case!(e<31536e3):return\"months\";default:return\"years\"}}doFormat(t,s){if(0==t.length)return[];const e=Math.abs(t[t.length-1]-t[0])/1e3,i=e/(t.length-1),n=this._get_resolution_str(i,e),[,[r]]=this._width_formats[n],o=[],c=l.indexOf(n),m={};for(const t of l)m[t]=0;m.seconds=5,m.minsec=4,m.minutes=4,m.hourmin=3,m.hours=3;for(const s of t){let t,e;try{e=h(s),t=d(s,r)}catch(t){a.logger.warn(`unable to format tick for timestamp value ${s}`),a.logger.warn(` - ${t}`),o.push(\"ERR\");continue}let i=!1,u=c;for(;0==e[m[l[u]]];){let r;if(u+=1,u==l.length)break;if((\"minsec\"==n||\"hourmin\"==n)&&!i){if(\"minsec\"==n&&0==e[4]&&0!=e[5]||\"hourmin\"==n&&0==e[3]&&0!=e[4]){r=this._width_formats[l[c-1]][1][0],t=d(s,r);break}i=!0}r=this._width_formats[l[u]][1][0],t=d(s,r)}if(this.strip_leading_zeros){let s=t.replace(/^0+/g,\"\");s!=t&&isNaN(parseInt(s))&&(s=`0${s}`),o.push(s)}else o.push(t)}return o}}e.DatetimeTickFormatter=f,f.__name__=\"DatetimeTickFormatter\",f.init_DatetimeTickFormatter()},\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=u.__importStar(r(183)),f=r(184),o=u.__importDefault(r(181)),l=r(21),s=r(8);function c(r,...t){return f.sprintf(r,...t)}function m(r,t,n){if(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 p(r,t,e){if(null==t)return m;if(null!=e&&r in e){const t=e[r];if(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 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 function(r,t,n){const e=t.get_column(r);if(null==e)return null;if(s.isNumber(n))return e[n];const i=e[n.index];if(s.isTypedArray(i)||s.isArray(i))return s.isArray(i[0])?i[n.dim2][n.dim1]:i[n.flat_index];return i}(r.substring(1).replace(/[{}]/g,\"\"),t,n)}n.FormatterType=l.Enum(\"numeral\",\"printf\",\"datetime\"),n.DEFAULT_FORMATTERS={numeral:(r,t,n)=>a.format(r,t),datetime:(r,t,n)=>o.default(r,t),printf:(r,t,n)=>c(t,r)},n.sprintf=c,n.basic_formatter=m,n.get_formatter=p,n.get_value=d,n.replace_placeholders=function(r,t,n,e,i={},u){let a,f;if(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=`${p(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){return 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)}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,i,n,t,a){t();const s=e(9),r=e(178),c=e(186),m=e(187),_=e(190),k=e(191),o=e(189);class T extends c.CompositeTicker{constructor(e){super(e)}static init_DatetimeTicker(){this.override({num_minor_ticks:0,tickers:()=>[new r.AdaptiveTicker({mantissas:[1,2,5],base:10,min_interval:0,max_interval:500*o.ONE_MILLI,num_minor_ticks:0}),new r.AdaptiveTicker({mantissas:[1,2,5,10,15,20,30],base:60,min_interval:o.ONE_SECOND,max_interval:30*o.ONE_MINUTE,num_minor_ticks:0}),new r.AdaptiveTicker({mantissas:[1,2,4,6,8,12],base:24,min_interval:o.ONE_HOUR,max_interval:12*o.ONE_HOUR,num_minor_ticks:0}),new m.DaysTicker({days:s.range(1,32)}),new m.DaysTicker({days:s.range(1,31,3)}),new m.DaysTicker({days:[1,8,15,22]}),new m.DaysTicker({days:[1,15]}),new _.MonthsTicker({months:s.range(0,12,1)}),new _.MonthsTicker({months:s.range(0,12,2)}),new _.MonthsTicker({months:s.range(0,12,4)}),new _.MonthsTicker({months:s.range(0,12,6)}),new k.YearsTicker({})]})}}n.DatetimeTicker=T,T.__name__=\"DatetimeTicker\",T.init_DatetimeTicker()},\n", " function _(t,e,i,s,r){s();const n=t(179),_=t(9);class a extends n.ContinuousTicker{constructor(t){super(t)}static init_CompositeTicker(){this.define((({Array:t,Ref:e})=>({tickers:[t(e(n.ContinuousTicker)),[]]})))}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 s=e-t,r=this.get_ideal_interval(t,e,i),n=[_.sorted_index(this.min_intervals,r)-1,_.sorted_index(this.max_intervals,r)],a=[this.min_intervals[n[0]],this.max_intervals[n[1]]].map((t=>Math.abs(i-s/t)));let c;if(_.is_empty(a.filter((t=>!isNaN(t)))))c=this.tickers[0];else{const t=n[_.argmin(a)];c=this.tickers[t]}return c}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,s){return this.get_best_ticker(t,e,s).get_ticks_no_defaults(t,e,i,s)}}i.CompositeTicker=a,a.__name__=\"CompositeTicker\",a.init_CompositeTicker()},\n", " function _(t,e,n,i,s){i();const a=t(188),o=t(189),r=t(9);class c extends a.SingleIntervalTicker{constructor(t){super(t)}static init_DaysTicker(){this.define((({Int:t,Array:e})=>({days:[e(t),[]]}))),this.override({num_minor_ticks:0})}initialize(){super.initialize();const t=this.days;t.length>1?this.interval=(t[1]-t[0])*o.ONE_DAY:this.interval=31*o.ONE_DAY}get_ticks_no_defaults(t,e,n,i){const s=function(t,e){const n=o.last_month_no_later_than(new Date(t)),i=o.last_month_no_later_than(new Date(e));i.setUTCMonth(i.getUTCMonth()+1);const s=[],a=n;for(;s.push(o.copy_date(a)),a.setUTCMonth(a.getUTCMonth()+1),!(a>i););return s}(t,e),a=this.days,c=this.interval;return{major:r.concat(s.map((t=>((t,e)=>{const n=t.getUTCMonth(),i=[];for(const s of a){const a=o.copy_date(t);a.setUTCDate(s),new Date(a.getTime()+e/2).getUTCMonth()==n&&i.push(a)}return i})(t,c)))).map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.DaysTicker=c,c.__name__=\"DaysTicker\",c.init_DaysTicker()},\n", " function _(e,t,n,i,r){i();const l=e(179);class a extends l.ContinuousTicker{constructor(e){super(e)}static init_SingleIntervalTicker(){this.define((({Number:e})=>({interval:[e]})))}get_interval(e,t,n){return this.interval}get_min_interval(){return this.interval}get_max_interval(){return this.interval}}n.SingleIntervalTicker=a,a.__name__=\"SingleIntervalTicker\",a.init_SingleIntervalTicker()},\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,i,s){i();const r=t(188),a=t(189),o=t(9);class c extends r.SingleIntervalTicker{constructor(t){super(t)}static init_MonthsTicker(){this.define((({Int:t,Array:e})=>({months:[e(t),[]]})))}initialize(){super.initialize();const t=this.months;t.length>1?this.interval=(t[1]-t[0])*a.ONE_MONTH:this.interval=12*a.ONE_MONTH}get_ticks_no_defaults(t,e,n,i){const s=function(t,e){const n=a.last_year_no_later_than(new Date(t)),i=a.last_year_no_later_than(new Date(e));i.setUTCFullYear(i.getUTCFullYear()+1);const s=[],r=n;for(;s.push(a.copy_date(r)),r.setUTCFullYear(r.getUTCFullYear()+1),!(r>i););return s}(t,e),r=this.months;return{major:o.concat(s.map((t=>r.map((e=>{const n=a.copy_date(t);return n.setUTCMonth(e),n}))))).map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.MonthsTicker=c,c.__name__=\"MonthsTicker\",c.init_MonthsTicker()},\n", " function _(e,t,a,i,r){i();const n=e(177),_=e(188),s=e(189);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=s.last_year_no_later_than(new Date(e)).getUTCFullYear(),n=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 _(i,s,t,e,o){e();const n=i(173),r=i(193),_=i(194);class c extends n.ContinuousAxisView{}t.LogAxisView=c,c.__name__=\"LogAxisView\";class x extends n.ContinuousAxis{constructor(i){super(i)}static init_LogAxis(){this.prototype.default_view=c,this.override({ticker:()=>new _.LogTicker,formatter:()=>new r.LogTickFormatter})}}t.LogAxis=x,x.__name__=\"LogAxis\",x.init_LogAxis()},\n", " function _(t,e,r,i,n){i();const o=t(166),a=t(176),s=t(194),c=t(167),{log:l,round:u}=Math;class _ extends o.TickFormatter{constructor(t){super(t)}static init_LogTickFormatter(){this.define((({Ref:t,Nullable:e})=>({ticker:[e(t(s.LogTicker)),null]})))}initialize(){super.initialize(),this.basic_formatter=new a.BasicTickFormatter}format_graphics(t,e){var r,i;if(0==t.length)return[];const n=null!==(i=null===(r=this.ticker)||void 0===r?void 0:r.base)&&void 0!==i?i:10,o=this._exponents(t,n);return null==o?this.basic_formatter.format_graphics(t,e):o.map((t=>{const e=new c.TextBox({text:a.unicode_replace(`${n}`)}),r=new c.TextBox({text:a.unicode_replace(`${t}`)});return new c.BaseExpo(e,r)}))}_exponents(t,e){let r=null;const i=[];for(const n of t){const t=u(l(n)/l(e));if(r==t)return null;r=t,i.push(t)}return i}doFormat(t,e){var r,i;if(0==t.length)return[];const n=null!==(i=null===(r=this.ticker)||void 0===r?void 0:r.base)&&void 0!==i?i:10,o=this._exponents(t,n);return null==o?this.basic_formatter.doFormat(t,e):o.map((t=>a.unicode_replace(`${n}^${t}`)))}}r.LogTickFormatter=_,_.__name__=\"LogTickFormatter\",_.init_LogTickFormatter()},\n", " function _(t,o,e,i,s){i();const n=t(178),r=t(9);class c extends n.AdaptiveTicker{constructor(t){super(t)}static init_LogTicker(){this.override({mantissas:[1,5]})}get_ticks_no_defaults(t,o,e,i){const s=this.num_minor_ticks,n=[],c=this.base,a=Math.log(t)/Math.log(c),f=Math.log(o)/Math.log(c),l=f-a;let h;if(isFinite(l))if(l<2){const e=this.get_interval(t,o,i),c=Math.floor(t/e),a=Math.ceil(o/e);if(h=r.range(c,a+1).filter((t=>0!=t)).map((t=>t*e)).filter((e=>t<=e&&e<=o)),s>0&&h.length>0){const t=e/s,o=r.range(0,s).map((o=>o*t));for(const t of o.slice(1))n.push(h[0]-t);for(const t of h)for(const e of o)n.push(t+e)}}else{const t=Math.ceil(.999999*a),o=Math.floor(1.000001*f),e=Math.ceil((o-t)/9);if(h=r.range(t-1,o+1,e).map((t=>c**t)),s>0&&h.length>0){const t=c**e/s,o=r.range(1,s+1).map((o=>o*t));for(const t of o)n.push(h[0]/t);n.push(h[0]);for(const t of h)for(const e of o)n.push(t*e)}}else h=[];return{major:h.filter((e=>t<=e&&e<=o)),minor:n.filter((e=>t<=e&&e<=o))}}}e.LogTicker=c,c.__name__=\"LogTicker\",c.init_LogTicker()},\n", " function _(e,t,i,r,s){r();const a=e(163),o=e(175),c=e(196),n=e(197);class _ extends a.AxisView{}i.MercatorAxisView=_,_.__name__=\"MercatorAxisView\";class x extends o.LinearAxis{constructor(e){super(e)}static init_MercatorAxis(){this.prototype.default_view=_,this.override({ticker:()=>new n.MercatorTicker({dimension:\"lat\"}),formatter:()=>new c.MercatorTickFormatter({dimension:\"lat\"})})}}i.MercatorAxis=x,x.__name__=\"MercatorAxis\",x.init_MercatorAxis()},\n", " function _(r,t,e,o,n){o();const i=r(176),c=r(20),a=r(65);class s extends i.BasicTickFormatter{constructor(r){super(r)}static init_MercatorTickFormatter(){this.define((({Nullable:r})=>({dimension:[r(c.LatLon),null]})))}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:[t(e.LatLon),null]})))}get_ticks_no_defaults(t,o,n,r){if(null==this.dimension)throw new Error(`${this}.dimension wasn't configured`);return[t,o]=c.clip_mercator(t,o,this.dimension),\"lon\"==this.dimension?this._get_ticks_lon(t,o,n,r):this._get_ticks_lat(t,o,n,r)}_get_ticks_lon(t,o,n,r){const[s]=c.wgs84_mercator.invert(t,n),[i,e]=c.wgs84_mercator.invert(o,n),_=super.get_ticks_no_defaults(s,i,n,r),a=[];for(const t of _.major)if(c.in_bounds(t,\"lon\")){const[o]=c.wgs84_mercator.compute(t,e);a.push(o)}const m=[];for(const t of _.minor)if(c.in_bounds(t,\"lon\")){const[o]=c.wgs84_mercator.compute(t,e);m.push(o)}return{major:a,minor:m}}_get_ticks_lat(t,o,n,r){const[,s]=c.wgs84_mercator.invert(n,t),[i,e]=c.wgs84_mercator.invert(n,o),_=super.get_ticks_no_defaults(s,e,n,r),a=[];for(const t of _.major)if(c.in_bounds(t,\"lat\")){const[,o]=c.wgs84_mercator.compute(i,t);a.push(o)}const m=[];for(const t of _.minor)if(c.in_bounds(t,\"lat\")){const[,o]=c.wgs84_mercator.compute(i,t);m.push(o)}return{major:a,minor:m}}}n.MercatorTicker=_,_.__name__=\"MercatorTicker\",_.init_MercatorTicker()},\n", " function _(e,i,r,c,k){c(),k(\"AdaptiveTicker\",e(178).AdaptiveTicker),k(\"BasicTicker\",e(177).BasicTicker),k(\"CategoricalTicker\",e(171).CategoricalTicker),k(\"CompositeTicker\",e(186).CompositeTicker),k(\"ContinuousTicker\",e(179).ContinuousTicker),k(\"DatetimeTicker\",e(185).DatetimeTicker),k(\"DaysTicker\",e(187).DaysTicker),k(\"FixedTicker\",e(199).FixedTicker),k(\"LogTicker\",e(194).LogTicker),k(\"MercatorTicker\",e(197).MercatorTicker),k(\"MonthsTicker\",e(190).MonthsTicker),k(\"SingleIntervalTicker\",e(188).SingleIntervalTicker),k(\"Ticker\",e(165).Ticker),k(\"YearsTicker\",e(191).YearsTicker),k(\"BinnedTicker\",e(200).BinnedTicker)},\n", " function _(i,t,e,r,n){r();const s=i(179);class _ extends s.ContinuousTicker{constructor(i){super(i)}static init_FixedTicker(){this.define((({Number:i,Array:t})=>({ticks:[t(i),[]],minor_ticks:[t(i),[]]})))}get_ticks_no_defaults(i,t,e,r){return{major:this.ticks,minor:this.minor_ticks}}get_interval(i,t,e){return 0}get_min_interval(){return 0}get_max_interval(){return 0}}e.FixedTicker=_,_.__name__=\"FixedTicker\",_.init_FixedTicker()},\n", " function _(e,n,t,i,r){i();const c=e(165),o=e(201),s=e(12);class a extends c.Ticker{constructor(e){super(e)}static init_BinnedTicker(){this.define((({Number:e,Ref:n,Or:t,Auto:i})=>({mapper:[n(o.ScanningColorMapper)],num_major_ticks:[t(e,i),8]})))}get_ticks(e,n,t,i){const{binning:r}=this.mapper.metrics,c=Math.max(0,s.left_edge_index(e,r)),o=Math.min(s.left_edge_index(n,r)+1,r.length-1),a=[];for(let e=c;e<=o;e++)a.push(r[e]);const{num_major_ticks:_}=this,m=[],h=\"auto\"==_?a.length:_,l=Math.max(1,Math.floor(a.length/h));for(let e=0;eo.binning[o.binning.length-1])return r;return e[a.left_edge_index(n,o.binning)]}}i.ScanningColorMapper=c,c.__name__=\"ScanningColorMapper\"},\n", " function _(t,o,e,n,s){n();const l=t(203),i=t(61),c=t(9),a=t(8);class r extends l.ColorMapper{constructor(t){super(t),this._scan_data=null}static init_ContinuousColorMapper(){this.define((({Number:t,String:o,Ref:e,Color:n,Or:s,Tuple:l,Array:c,Nullable:a})=>({high:[a(t),null],low:[a(t),null],high_color:[a(n),null],low_color:[a(n),null],domain:[c(l(e(i.GlyphRenderer),s(o,c(o)))),[]]})))}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:o}=this,e=[...this._collect(t)];this._scan_data=this.scan(e,o.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[o,e]of t)for(const t of a.isArray(e)?e:[e]){let e=o.data_source.get_column(t);e=o.view.indices.select(e);const n=o.view.masked,s=o.data_source.selected.indices;let l;if(null!=n&&s.length>0?l=c.intersection([...n],s):null!=n?l=[...n]:s.length>0&&(l=s),null!=l&&(e=c.map(l,(t=>e[t]))),e.length>0&&!a.isNumber(e[0]))for(const t of e)yield*t;else yield*e}}_v_compute(t,o,e,n){const{nan_color:s}=n;let{low_color:l,high_color:i}=n;null==l&&(l=e[0]),null==i&&(i=e[e.length-1]);const{domain:a}=this,r=c.is_empty(a)?t:[...this._collect(a)];this._scan_data=this.scan(r,e.length),this.metrics_change.emit();for(let n=0,c=t.length;n({palette:[r(t)],nan_color:[t,\"gray\"]})))}v_compute(t){const r=new Array(t.length);return this._v_compute(t,r,this.palette,this._colors((t=>t))),r}get rgba_mapper(){const t=this,r=p(this.palette),e=this._colors(s);return{v_compute(n){const o=new c.ColorArray(n.length);return t._v_compute(n,o,r,e),new Uint8ClampedArray(l.to_big_endian(o).buffer)}}}_colors(t){return{nan_color:t(this.nan_color)}}}e.ColorMapper=u,u.__name__=\"ColorMapper\",u.init_ColorMapper()},\n", " function _(r,e,n,s,o){s();const p=r(149);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 _(t,r,a,e,c){e(),c(\"BasicTickFormatter\",t(176).BasicTickFormatter),c(\"CategoricalTickFormatter\",t(172).CategoricalTickFormatter),c(\"DatetimeTickFormatter\",t(180).DatetimeTickFormatter),c(\"FuncTickFormatter\",t(206).FuncTickFormatter),c(\"LogTickFormatter\",t(193).LogTickFormatter),c(\"MercatorTickFormatter\",t(196).MercatorTickFormatter),c(\"NumeralTickFormatter\",t(207).NumeralTickFormatter),c(\"PrintfTickFormatter\",t(208).PrintfTickFormatter),c(\"TickFormatter\",t(166).TickFormatter)},\n", " function _(t,n,e,s,i){s();const r=t(166),c=t(13),a=t(34);class u extends r.TickFormatter{constructor(t){super(t)}static init_FuncTickFormatter(){this.define((({Unknown:t,String:n,Dict:e})=>({args:[e(t),{}],code:[n,\"\"]})))}get names(){return c.keys(this.args)}get values(){return c.values(this.args)}_make_func(){const t=a.use_strict(this.code);return new Function(\"tick\",\"index\",\"ticks\",...this.names,t)}doFormat(t,n){const e=this._make_func().bind({});return t.map(((t,n,s)=>`${e(t,n,s,...this.values)}`))}}e.FuncTickFormatter=u,u.__name__=\"FuncTickFormatter\",u.init_FuncTickFormatter()},\n", " function _(r,t,n,e,a){e();const o=r(1).__importStar(r(183)),i=r(166),u=r(20);class c extends i.TickFormatter{constructor(r){super(r)}static init_NumeralTickFormatter(){this.define((({String:r})=>({format:[r,\"0,0\"],language:[r,\"en\"],rounding:[u.RoundingFunction,\"round\"]})))}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,t){const{format:n,language:e,_rounding_fn:a}=this;return r.map((r=>o.format(r,n,e,a)))}}n.NumeralTickFormatter=c,c.__name__=\"NumeralTickFormatter\",c.init_NumeralTickFormatter()},\n", " function _(t,r,i,n,o){n();const a=t(166),e=t(182);class c extends a.TickFormatter{constructor(t){super(t)}static init_PrintfTickFormatter(){this.define((({String:t})=>({format:[t,\"%s\"]})))}doFormat(t,r){return t.map((t=>e.sprintf(this.format,t)))}}i.PrintfTickFormatter=c,c.__name__=\"PrintfTickFormatter\",c.init_PrintfTickFormatter()},\n", " function _(r,o,a,p,e){p(),e(\"CategoricalColorMapper\",r(210).CategoricalColorMapper),e(\"CategoricalMarkerMapper\",r(212).CategoricalMarkerMapper),e(\"CategoricalPatternMapper\",r(213).CategoricalPatternMapper),e(\"ContinuousColorMapper\",r(202).ContinuousColorMapper),e(\"ColorMapper\",r(203).ColorMapper),e(\"LinearColorMapper\",r(214).LinearColorMapper),e(\"LogColorMapper\",r(215).LogColorMapper),e(\"ScanningColorMapper\",r(201).ScanningColorMapper),e(\"EqHistColorMapper\",r(216).EqHistColorMapper)},\n", " function _(t,o,a,r,e){r();const c=t(211),l=t(203),i=t(104);class s extends l.ColorMapper{constructor(t){super(t)}static init_CategoricalColorMapper(){this.define((({Number:t,Nullable:o})=>({factors:[i.FactorSeq],start:[t,0],end:[o(t),null]})))}_v_compute(t,o,a,{nan_color:r}){c.cat_v_compute(t,this.factors,a,o,this.start,this.end,r)}}a.CategoricalColorMapper=s,s.__name__=\"CategoricalColorMapper\",s.init_CategoricalColorMapper()},\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 _(r,e,a,t,s){t();const c=r(211),i=r(104),l=r(204),n=r(20);class p extends l.Mapper{constructor(r){super(r)}static init_CategoricalMarkerMapper(){this.define((({Number:r,Array:e,Nullable:a})=>({factors:[i.FactorSeq],markers:[e(n.MarkerType)],start:[r,0],end:[a(r),null],default_value:[n.MarkerType,\"circle\"]})))}v_compute(r){const e=new Array(r.length);return c.cat_v_compute(r,this.factors,this.markers,e,this.start,this.end,this.default_value),e}}a.CategoricalMarkerMapper=p,p.__name__=\"CategoricalMarkerMapper\",p.init_CategoricalMarkerMapper()},\n", " function _(t,a,e,r,n){r();const s=t(211),c=t(104),i=t(204),p=t(20);class l extends i.Mapper{constructor(t){super(t)}static init_CategoricalPatternMapper(){this.define((({Number:t,Array:a,Nullable:e})=>({factors:[c.FactorSeq],patterns:[a(p.HatchPatternType)],start:[t,0],end:[e(t),null],default_value:[p.HatchPatternType,\" \"]})))}v_compute(t){const a=new Array(t.length);return s.cat_v_compute(t,this.factors,this.patterns,a,this.start,this.end,this.default_value),a}}e.CategoricalPatternMapper=l,l.__name__=\"CategoricalPatternMapper\",l.init_CategoricalPatternMapper()},\n", " function _(n,r,o,t,a){t();const e=n(202),i=n(12);class s extends e.ContinuousColorMapper{constructor(n){super(n)}scan(n,r){const o=null!=this.low?this.low:i.min(n),t=null!=this.high?this.high: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(202),s=o(12);class e extends a.ContinuousColorMapper{constructor(o){super(o)}scan(o,t){const n=null!=this.low?this.low:s.min(o),r=null!=this.high?this.high: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,i,e,o){e();const s=n(201),r=n(12),a=n(9),l=n(19);class c extends s.ScanningColorMapper{constructor(n){super(n)}static init_EqHistColorMapper(){this.define((({Int:n})=>({bins:[n,65536]})))}scan(n,t){const i=null!=this.low?this.low:r.min(n),e=null!=this.high?this.high:r.max(n),o=this.bins,s=a.linspace(i,e,o+1),c=r.bin_counts(n,s),h=new Array(o);for(let n=0,t=s.length;nn/g));let m=t-1,M=[],_=0,f=2*t;for(;m!=t&&_<4&&0!=m;){const n=f/m;if(n>1e3)break;f=Math.round(Math.max(t*n,t));const i=a.range(0,f),e=r.map(u,(n=>n*(f-1)));M=r.interpolate(i,e,h);m=a.uniq(M).length-1,_++}if(0==m){M=[i,e];for(let n=0;ne*n+t}compute(e){return this._linear_compute(e)}v_compute(e){return this._linear_v_compute(e)}invert(e){return this._linear_invert(e)}v_invert(e){return this._linear_v_invert(e)}}n.LinearScale=u,u.__name__=\"LinearScale\"},\n", " function _(n,t,e,r,i){r();const a=n(146),o=n(12);class c extends a.Scale{constructor(n){super(n)}static init_LinearInterpolationScale(){this.internal((({Arrayable:n})=>({binning:[n]})))}get s_compute(){throw new Error(\"not implemented\")}compute(n){return n}v_compute(n){const{binning:t}=this,{start:e,end:r}=this.source_range,i=e,a=r,c=t.length,l=(r-e)/(c-1),s=new Float64Array(c);for(let n=0;n{if(na)return a;const e=o.left_edge_index(n,t);if(-1==e)return i;if(e>=c-1)return a;const r=t[e],l=(n-r)/(t[e+1]-r),u=s[e];return u+l*(s[e+1]-u)}));return this._linear_v_compute(u)}invert(n){return n}v_invert(n){return new Float64Array(n)}}e.LinearInterpolationScale=c,c.__name__=\"LinearInterpolationScale\",c.init_LinearInterpolationScale()},\n", " function _(a,n,e,g,R){g(),R(\"DataRange\",a(160).DataRange),R(\"DataRange1d\",a(159).DataRange1d),R(\"FactorRange\",a(104).FactorRange),R(\"Range\",a(105).Range),R(\"Range1d\",a(156).Range1d)},\n", " function _(a,o,i,t,e){t();var n=a(141);e(\"Sizeable\",n.Sizeable),e(\"SizingPolicy\",n.SizingPolicy);var c=a(142);e(\"Layoutable\",c.Layoutable),e(\"LayoutItem\",c.LayoutItem);var r=a(222);e(\"HStack\",r.HStack),e(\"VStack\",r.VStack);var l=a(223);e(\"Grid\",l.Grid),e(\"Row\",l.Row),e(\"Column\",l.Column);var S=a(224);e(\"ContentBox\",S.ContentBox),e(\"VariadicBox\",S.VariadicBox)},\n", " function _(t,e,h,i,r){i();const n=t(142),o=t(99);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(141),l=t(142),r=t(8),h=t(99),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 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 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=r.isPlainObject(this.rows)?null!==(t=this.rows[s])&&void 0!==t?t:this.rows[\"*\"]:this.rows;return null==i?{policy:\"auto\"}:r.isNumber(i)?{policy:\"fixed\",height:i}: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\");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=r.isPlainObject(this.cols)?null!==(i=this.cols[t])&&void 0!==i?i:this.cols[\"*\"]:this.cols;return null==s?{policy:\"auto\"}:r.isNumber(s)?{policy:\"fixed\",width:s}: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\");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]=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:c.sum(t)+(s-1)*o,width: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(142),c=e(141),o=e(43);class r extends a.ContentLayoutable{constructor(e){super(),this.content_size=o.unsized(e,(()=>new c.Sizeable(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 o.sized(this.el,t,(()=>{const e=new c.Sizeable(o.content_size(this.el)),{border:t,padding:s}=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(141),r=t(142),n=t(99);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,n){s();const o=t(1),l=t(139),a=t(10),_=t(143),d=t(20),h=o.__importStar(t(48));class r extends l.TextAnnotationView{_get_size(){const{ctx:t}=this.layer;this.visuals.text.set_value(t);const{width:e}=t.measureText(this.model.text),{height:i}=_.font_metrics(t.font);return{width:e,height:i}}_render(){const{angle:t,angle_units:e}=this.model,i=a.resolve_angle(t,e),s=null!=this.layout?this.layout:this.plot_view.frame,n=this.coordinates.x_scale,o=this.coordinates.y_scale;let l=\"data\"==this.model.x_units?n.compute(this.model.x):s.bbox.xview.compute(this.model.x),_=\"data\"==this.model.y_units?o.compute(this.model.y):s.bbox.yview.compute(this.model.y);l+=this.model.x_offset,_-=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,l,_,i)}}i.LabelView=r,r.__name__=\"LabelView\";class c extends l.TextAnnotation{constructor(t){super(t)}static init_Label(){this.prototype.default_view=r,this.mixins([h.Text,[\"border_\",h.Line],[\"background_\",h.Fill]]),this.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]}))),this.override({background_fill_color:null,border_line_color:null})}}i.Label=c,c.__name__=\"Label\",c.init_Label()},\n", " function _(t,e,s,i,o){i();const l=t(1),n=t(139),a=t(56),r=t(130),_=l.__importStar(t(48)),c=t(20),h=t(43),d=l.__importStar(t(18)),u=t(143);class x extends n.TextAnnotationView{set_data(t){a.DataAnnotationView.prototype.set_data.call(this,t)}initialize(){if(super.initialize(),this.set_data(this.model.source),\"css\"==this.model.render_mode)for(let t=0,e=this.text.length;t{this.set_data(this.model.source),\"css\"==this.model.render_mode?this.render():this.request_render()};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)}_calculate_text_dimensions(t,e){const{width:s}=t.measureText(e),{height:i}=u.font_metrics(this.visuals.text.font_value(0));return[s,i]}_map_data(){const t=this.coordinates.x_scale,e=this.coordinates.y_scale,s=null!=this.layout?this.layout:this.plot_view.frame;return[\"data\"==this.model.x_units?t.v_compute(this._x):s.bbox.xview.v_compute(this._x),\"data\"==this.model.y_units?e.v_compute(this._y):s.bbox.yview.v_compute(this._y)]}_render(){const t=\"canvas\"==this.model.render_mode?this._v_canvas_text.bind(this):this._v_css_text.bind(this),{ctx:e}=this.layer,[s,i]=this._map_data();for(let o=0,l=this.text.length;o({x:[d.XCoordinateSpec,{field:\"x\"}],y:[d.YCoordinateSpec,{field:\"y\"}],x_units:[c.SpatialUnits,\"data\"],y_units:[c.SpatialUnits,\"data\"],text:[d.StringSpec,{field:\"text\"}],angle:[d.AngleSpec,0],x_offset:[d.NumberSpec,{value:0}],y_offset:[d.NumberSpec,{value:0}],source:[t(r.ColumnDataSource),()=>new r.ColumnDataSource]}))),this.override({background_fill_color:null,border_line_color:null})}}s.LabelSet=v,v.__name__=\"LabelSet\",v.init_LabelSet()},\n", " function _(t,e,i,s,l){s();const n=t(1),h=t(40),o=t(229),a=t(20),_=n.__importStar(t(48)),r=t(15),d=t(140),c=t(143),g=t(99),m=t(9),b=t(8),f=t(11);class u extends h.AnnotationView{update_layout(){const{panel:t}=this;this.layout=null!=t?new d.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:s,label_width:l}=this.model;this.max_label_height=m.max([c.font_metrics(this.visuals.label_text.font_value()).height,s,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,m.max([n.measureText(e).width,l]));this.visuals.title_text.set_value(n),this.title_height=this.model.title?c.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 h=Math.max(m.max([...this.text_widths.values()]),0),o=this.model.margin,{legend_padding:a}=this,_=this.model.spacing,{label_standoff:r}=this.model;let d,u;if(\"vertical\"==this.model.orientation)d=t.length*this.max_label_height+Math.max(t.length-1,0)*_+2*a+this.title_height,u=m.max([h+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+=m.max([t,l])+i+r;u=m.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(b.isString(v))switch(v){case\"top_left\":y=p.start+o,k=w.start+o;break;case\"top\":case\"top_center\":y=(p.end+p.start)/2-u/2,k=w.start+o;break;case\"top_right\":y=p.end-o-u,k=w.start+o;break;case\"bottom_right\":y=p.end-o-u,k=w.end-o-d;break;case\"bottom\":case\"bottom_center\":y=(p.end+p.start)/2-u/2,k=w.end-o-d;break;case\"bottom_left\":y=p.start+o,k=w.end-o-d;break;case\"left\":case\"center_left\":y=p.start+o,k=(w.end+w.start)/2-d/2;break;case\"center\":case\"center_center\":y=(p.end+p.start)/2-u/2,k=(w.end+w.start)/2-d/2;break;case\"right\":case\"center_right\":y=p.end-o-u,k=(w.end+w.start)/2-d/2}else if(b.isArray(v)&&2==v.length){const[t,e]=v;y=x.bbox.xview.compute(t),k=x.bbox.yview.compute(e)-d}else f.unreachable();return new g.BBox({left:y,top:k,width:u,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:s}=this.model,{legend_padding:l}=this,n=this.model.spacing,{label_standoff:h}=this.model;let o=i=l;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+o,m=a.y+i+this.title_height;let b,f;[b,f]=_?[a.width-2*l,this.max_label_height]:[this.text_widths.get(c)+s+h,this.max_label_height];if(new g.BBox({left:d,top:m,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:o+=this.text_widths.get(c)+s+h+n}}return!1}_render(){if(0==this.model.items.length)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.set_value(t),t.fill(),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(t),t.stroke())}_draw_legend_items(t,e){const{glyph_width:i,glyph_height:s}=this.model,{legend_padding:l}=this,n=this.model.spacing,{label_standoff:h}=this.model;let o=l,a=l;const _=\"vertical\"==this.model.orientation;for(const r of this.model.items){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 m.every(r.renderers,(t=>t.visible));case\"mute\":return m.every(r.renderers,(t=>!t.muted))}})();for(const m of d){const d=e.x+o,b=e.y+a+this.title_height,f=d+i,u=b+s;_?a+=this.max_label_height+n:o+=this.text_widths.get(m)+i+h+n,this.visuals.label_text.set_value(t),t.fillText(m,f+h,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 s,n;[s,n]=_?[e.width-2*l,this.max_label_height]:[this.text_widths.get(m)+i+h,this.max_label_height],t.beginPath(),t.rect(d,b,s,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=u,u.__name__=\"LegendView\";class x extends h.Annotation{constructor(t){super(t)}initialize(){super.initialize(),this.item_change=new r.Signal0(this,\"item_change\")}static init_Legend(){this.prototype.default_view=u,this.mixins([[\"label_\",_.Text],[\"title_\",_.Text],[\"inactive_\",_.Fill],[\"border_\",_.Line],[\"background_\",_.Fill]]),this.define((({Number:t,String:e,Array:i,Tuple:s,Or:l,Ref:n,Nullable:h})=>({orientation:[a.Orientation,\"vertical\"],location:[l(a.LegendLocation,s(t,t)),\"top_right\"],title:[h(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(o.LegendItem)),[]],click_policy:[a.LegendClickPolicy,\"none\"]}))),this.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\"})}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=x,x.__name__=\"Legend\",x.init_Legend()},\n", " function _(e,r,n,l,t){l();const i=e(1),s=e(53),o=e(61),_=e(57),a=e(230),u=i.__importStar(e(18)),d=e(19),c=e(9);class f extends s.Model{constructor(e){super(e)}static init_LegendItem(){this.define((({Int:e,Array:r,Ref:n,Nullable:l})=>({label:[u.NullStringSpec,null],renderers:[r(n(o.GlyphRenderer)),[]],index:[l(e),null]})))}_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&&!c.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()||d.logger.error(\"Non matching data sources on legend item renderers\");this._check_field_label_on_data_source()||d.logger.error(`Bad column name on label: ${this.label}`)}get_field_from_label_prop(){const{label:e}=this;return a.isField(e)?e.field:null}get_labels_list_from_label_prop(){if(a.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 n=r.get_column(e);return null!=n?c.uniq(Array.from(n)):[\"Invalid field\"]}}return[]}}n.LegendItem=f,f.__name__=\"LegendItem\",f.init_LegendItem()},\n", " function _(i,n,e,t,u){t();const c=i(8);e.isValue=function(i){return c.isPlainObject(i)&&\"value\"in i},e.isField=function(i){return c.isPlainObject(i)&&\"field\"in i},e.isExpr=function(i){return c.isPlainObject(i)&&\"expr\"in i}},\n", " function _(t,i,s,n,e){n();const o=t(1),l=t(40),a=o.__importStar(t(48)),c=t(20);class h extends l.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{xs:t,ys:i}=this.model;if(t.length!=i.length)return;const s=t.length;if(s<3)return;const{frame:n}=this.plot_view,{ctx:e}=this.layer,o=this.coordinates.x_scale,l=this.coordinates.y_scale,{screen:a}=this.model;function c(t,i,s,n){return a?t:\"data\"==i?s.v_compute(t):n.v_compute(t)}const h=c(t,this.model.xs_units,o,n.bbox.xview),r=c(i,this.model.ys_units,l,n.bbox.yview);e.beginPath();for(let t=0;t({xs:[i(t),[]],xs_units:[c.SpatialUnits,\"data\"],ys:[i(t),[]],ys_units:[c.SpatialUnits,\"data\"]}))),this.internal((({Boolean:t})=>({screen:[t,!1]}))),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}update({xs:t,ys:i}){this.setv({xs:t,ys:i,screen:!0},{check_eq:!1})}}s.PolyAnnotation=r,r.__name__=\"PolyAnnotation\",r.init_PolyAnnotation()},\n", " function _(e,t,i,n,o){n();const s=e(1),l=e(40),r=s.__importStar(e(48));class c extends l.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:i}=this.plot_view,n=this.coordinates.x_scale,o=this.coordinates.y_scale;let s,l,r,c;if(0==e)s=o.compute(t),l=s,r=i.bbox.left,c=r+i.bbox.width;else{s=i.bbox.top,l=s+i.bbox.height;const a=(o.invert(s)-t)/e,_=(o.invert(l)-t)/e;r=n.compute(a),c=n.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()}}i.SlopeView=c,c.__name__=\"SlopeView\";class a extends l.Annotation{constructor(e){super(e)}static init_Slope(){this.prototype.default_view=c,this.mixins(r.Line),this.define((({Number:e,Nullable:t})=>({gradient:[t(e),null],y_intercept:[t(e),null]}))),this.override({line_color:\"black\"})}}i.Slope=a,a.__name__=\"Slope\",a.init_Slope()},\n", " function _(e,i,t,n,o){n();const s=e(1),a=e(40),l=s.__importStar(e(48)),h=e(20);class c 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:i}=this.plot_view,t=this.coordinates.x_scale,n=this.coordinates.y_scale,o=(i,t)=>\"data\"==this.model.location_units?i.compute(e):this.model.for_hover?e:t.compute(e);let s,a,l,h;\"width\"==this.model.dimension?(l=o(n,i.bbox.yview),a=i.bbox.left,h=i.bbox.width,s=this.model.line_width):(l=i.bbox.top,a=o(t,i.bbox.xview),h=this.model.line_width,s=i.bbox.height);const{ctx:c}=this.layer;c.save(),c.beginPath(),this.visuals.line.set_value(c),c.moveTo(a,l),\"width\"==this.model.dimension?c.lineTo(a+h,l):c.lineTo(a,l+s),c.stroke(),c.restore()}}t.SpanView=c,c.__name__=\"SpanView\";class d extends a.Annotation{constructor(e){super(e)}static init_Span(){this.prototype.default_view=c,this.mixins(l.Line),this.define((({Number:e,Nullable:i})=>({render_mode:[h.RenderMode,\"canvas\"],location:[i(e),null],location_units:[h.SpatialUnits,\"data\"],dimension:[h.Dimension,\"width\"]}))),this.internal((({Boolean:e})=>({for_hover:[e,!1]}))),this.override({line_color:\"black\"})}}t.Span=d,d.__name__=\"Span\",d.init_Span()},\n", " function _(i,e,t,o,l){o();const s=i(40),a=i(235),n=i(122),r=i(43),_=i(140),h=i(99);class b extends s.AnnotationView{constructor(){super(...arguments),this._invalidate_toolbar=!0,this._previous_bbox=new h.BBox}update_layout(){this.layout=new _.SideLayout(this.panel,(()=>this.get_size()),!0)}initialize(){super.initialize(),this.el=r.div(),this.plot_view.canvas_view.add_event(this.el)}async lazy_initialize(){await super.lazy_initialize(),this._toolbar_view=await 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(),r.remove(this.el),super.remove()}render(){this.model.visible||r.undisplay(this.el),super.render()}_render(){const{bbox:i}=this.layout;this._previous_bbox.equals(i)||(r.position(this.el,i),this._previous_bbox=i),this._invalidate_toolbar&&(this.el.style.position=\"absolute\",this.el.style.overflow=\"hidden\",this._toolbar_view.render(),r.empty(this.el),this.el.appendChild(this._toolbar_view.el),this._invalidate_toolbar=!1),r.display(this.el)}_get_size(){const{tools:i,logo:e}=this.model.toolbar;return{width:30*i.length+(null!=e?25:0),height:30}}}t.ToolbarPanelView=b,b.__name__=\"ToolbarPanelView\";class d extends s.Annotation{constructor(i){super(i)}static init_ToolbarPanel(){this.prototype.default_view=b,this.define((({Ref:i})=>({toolbar:[i(a.Toolbar)]})))}}t.ToolbarPanel=d,d.__name__=\"ToolbarPanel\",d.init_ToolbarPanel()},\n", " function _(t,s,e,i,o){i();const c=t(8),n=t(9),a=t(13),l=t(236),r=t(237),_=t(247),p=t(248);e.Drag=l.Tool,e.Inspection=l.Tool,e.Scroll=l.Tool,e.Tap=l.Tool;const u=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},h=t=>\"tap\"==t||\"pan\"==t;class v extends p.ToolbarBase{constructor(t){super(t)}static init_Toolbar(){this.prototype.default_view=p.ToolbarBaseView,this.define((({Or:t,Ref:s,Auto:i,Null:o,Nullable:c})=>({active_drag:[t(s(e.Drag),i,o),\"auto\"],active_inspect:[t(s(e.Inspection),i,o),\"auto\"],active_scroll:[t(s(e.Scroll),i,o),\"auto\"],active_tap:[t(s(e.Tap),i,o),\"auto\"],active_multi:[c(s(r.GestureTool)),null]})))}connect_signals(){super.connect_signals();const{tools:t,active_drag:s,active_inspect:e,active_scroll:i,active_tap:o,active_multi:c}=this.properties;this.on_change([t,s,e,i,o,c],(()=>this._init_tools()))}_init_tools(){if(super._init_tools(),\"auto\"==this.active_inspect);else if(this.active_inspect instanceof _.InspectTool){let t=!1;for(const s of this.inspectors)s!=this.active_inspect?s.active=!1:t=!0;t||(this.active_inspect=null)}else if(c.isArray(this.active_inspect)){const t=n.intersection(this.active_inspect,this.inspectors);t.length!=this.active_inspect.length&&(this.active_inspect=t);for(const t of this.inspectors)n.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 a.values(this.gestures)){t.tools=n.sort_by(t.tools,(t=>t.default_order));for(const s of t.tools)this.connect(s.properties.active.change,(()=>this._active_change(s)))}for(const[s,e]of a.entries(this.gestures)){const i=u(s);if(i){const o=this[i];\"auto\"==o?0!=e.tools.length&&h(s)&&t(e.tools[0]):null!=o&&(n.includes(this.tools,o)?t(o):this[i]=null)}}}}e.Toolbar=v,v.__name__=\"Toolbar\",v.init_Toolbar()},\n", " function _(t,e,n,i,o){i();const s=t(42),a=t(9),r=t(53);class l extends s.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=l,l.__name__=\"ToolView\";class _ extends r.Model{constructor(t){super(t)}static init_Tool(){this.prototype._known_aliases=new Map,this.define((({String:t,Nullable:e})=>({description:[e(t),null]}))),this.internal((({Boolean:t})=>({active:[t,!1]})))}get synthetic_renderers(){return[]}_get_dim_limits([t,e],[n,i],o,s){const r=o.bbox.h_range;let l;\"width\"==s||\"both\"==s?(l=[a.min([t,n]),a.max([t,n])],l=[a.max([l[0],r.start]),a.min([l[1],r.end])]):l=[r.start,r.end];const _=o.bbox.v_range;let c;return\"height\"==s||\"both\"==s?(c=[a.min([e,i]),a.max([e,i])],c=[a.max([c[0],_.start]),a.min([c[1],_.end])]):c=[_.start,_.end],[l,c]}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=_,_.__name__=\"Tool\",_.init_Tool()},\n", " function _(e,o,t,s,n){s();const u=e(238),_=e(246);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,i,s){i();const n=t(1),l=n.__importDefault(t(239)),r=t(240),a=t(236),u=t(43),h=t(34),_=t(8),c=t(9),d=n.__importStar(t(241)),m=d,p=n.__importDefault(t(242)),g=n.__importDefault(t(243)),v=t(244);class f extends r.DOMView{initialize(){super.initialize();const t=this.model.menu;if(null!=t){const e=this.parent.model.toolbar_location,o=\"left\"==e||\"above\"==e,i=this.parent.model.horizontal?\"vertical\":\"horizontal\";this._menu=new v.ContextMenu(o?c.reversed(t):t,{orientation:i,prevent_hide:t=>t.target==this.el})}this._hammer=new l.default(this.el,{touchAction:\"auto\",inputClass:l.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()))}remove(){var t;this._hammer.destroy(),null===(t=this._menu)||void 0===t||t.remove(),super.remove()}styles(){return[...super.styles(),d.default,p.default,g.default]}css_classes(){return super.css_classes().concat(m.toolbar_button)}render(){u.empty(this.el);const t=this.model.computed_icon;_.isString(t)&&(h.startsWith(t,\"data:image\")?this.el.style.backgroundImage=\"url('\"+t+\"')\":this.el.classList.add(t)),this.el.title=this.model.tooltip,null!=this._menu&&this.root.el.appendChild(this._menu.el)}_pressed(){var t;const{left:e,top:o,right:i,bottom:s}=this.el.getBoundingClientRect(),n=(()=>{switch(this.parent.model.toolbar_location){case\"right\":return{right:e,top:o};case\"left\":return{left:i,top:o};case\"above\":return{left:e,top:s};case\"below\":return{left:e,bottom:o}}})();null===(t=this._menu)||void 0===t||t.toggle(n)}}o.ButtonToolButtonView=f,f.__name__=\"ButtonToolButtonView\";class b extends a.ToolView{}o.ButtonToolView=b,b.__name__=\"ButtonToolView\";class B extends a.Tool{constructor(t){super(t)}static init_ButtonTool(){this.internal((({Boolean:t})=>({disabled:[t,!1]})))}_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=B,B.__name__=\"ButtonTool\",B.init_ButtonTool()},\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.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,s){n();const o=t(1),l=t(43),h=t(245),d=o.__importStar(t(243));class r{constructor(t,e={}){this.items=t,this.options=e,this.el=l.div(),this._open=!1,this._item_click=t=>{var e;null===(e=this.items[t])||void 0===e||e.handler(),this.hide()},this._on_mousedown=t=>{var e,i;const{target:n}=t;n instanceof Node&&this.el.contains(n)||(null===(i=(e=this.options).prevent_hide)||void 0===i?void 0:i.call(e,t))||this.hide()},this._on_keydown=t=>{t.keyCode==l.Keys.Esc&&this.hide()},this._on_blur=()=>{this.hide()},l.undisplay(this.el)}get is_open(){return this._open}get can_open(){return 0!=this.items.length}remove(){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=e.getBoundingClientRect();this.el.style.left=null!=t.left?t.left-i.left+\"px\":\"\",this.el.style.top=null!=t.top?t.top-i.top+\"px\":\"\",this.el.style.right=null!=t.right?i.right-t.right+\"px\":\"\",this.el.style.bottom=null!=t.bottom?i.bottom-t.bottom+\"px\":\"\"}}render(){var t,e;l.empty(this.el,!0);const i=null!==(t=this.options.orientation)&&void 0!==t?t:\"vertical\";l.classes(this.el).add(\"bk-context-menu\",`bk-${i}`);for(const[t,i]of h.enumerate(this.items)){let n;if(null==t)n=l.div({class:d.divider});else{if(null!=t.if&&!t.if())continue;{const i=null!=t.icon?l.div({class:[\"bk-menu-icon\",t.icon]}):null;n=l.div({class:(null===(e=t.active)||void 0===e?void 0:e.call(t))?\"bk-active\":null,title:t.tooltip},i,t.label)}}n.addEventListener(\"click\",(()=>this._item_click(i))),this.el.appendChild(n)}}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}),l.display(this.el),this._listen(),this._open=!0}}hide(){this._open&&(this._open=!1,this._unlisten(),l.undisplay(this.el))}toggle(t){this._open?this.hide():this.show(t)}}i.ContextMenu=r,r.__name__=\"ContextMenu\"},\n", " function _(n,e,o,t,r){t();const f=n(9);function*i(n,e){const o=n.length;if(e>o)return;const t=f.range(e);for(yield t.map((e=>n[e]));;){let r;for(const n of f.reversed(f.range(e)))if(t[n]!=n+o-e){r=n;break}if(null==r)return;t[r]+=1;for(const n of f.range(r+1,e))t[n]=t[n-1]+1;yield t.map((e=>n[e]))}}o.enumerate=function*(n){let e=0;for(const o of n)yield[o,e++]},o.combinations=i,o.subsets=function*(n){for(const e of f.range(n.length+1))yield*i(n,e)}},\n", " function _(t,e,i,n,o){n();const s=t(1),c=t(238),l=s.__importStar(t(241)),a=t(43);class _ extends c.ButtonToolButtonView{render(){super.render(),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 _(t,e,o,n,s){n();const i=t(238),c=t(246);class l extends i.ButtonToolView{}o.InspectToolView=l,l.__name__=\"InspectToolView\";class _ extends i.ButtonTool{constructor(t){super(t),this.event_type=\"move\"}static init_InspectTool(){this.prototype.button_view=c.OnOffButtonView,this.define((({Boolean:t})=>({toggleable:[t,!0]}))),this.override({active:!0})}}o.InspectTool=_,_.__name__=\"InspectTool\",_.init_InspectTool()},\n", " function _(t,o,e,i,s){i();const l=t(1),n=t(19),a=t(43),r=t(122),c=t(240),_=t(20),u=t(9),h=t(13),v=t(8),p=t(249),d=t(99),b=t(53),g=t(236),f=t(237),m=t(251),w=t(252),y=t(247),T=l.__importStar(t(241)),z=T,B=l.__importStar(t(253)),x=B;class L extends b.Model{constructor(t){super(t)}static init_ToolbarViewModel(){this.define((({Boolean:t,Nullable:o})=>({_visible:[o(t),null],autohide:[t,!1]})))}get visible(){return!this.autohide||null!=this._visible&&this._visible}}e.ToolbarViewModel=L,L.__name__=\"ToolbarViewModel\",L.init_ToolbarViewModel();class M extends c.DOMView{constructor(){super(...arguments),this.layout={bbox:new d.BBox}}initialize(){super.initialize(),this._tool_button_views=new Map,this._toolbar_view_model=new L({autohide:this.model.autohide})}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(),T.default,B.default]}remove(){r.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 r.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 t=this._toolbar_view_model.visible,o=z.toolbar_hidden;this.el.classList.contains(o)&&t?this.el.classList.remove(o):t||this.el.classList.add(o)}render(){if(a.empty(this.el),this.el.classList.add(z.toolbar),this.el.classList.add(z[this.model.toolbar_location]),this._toolbar_view_model.autohide=this.model.autohide,this._on_visible_change(),null!=this.model.logo){const t=\"grey\"===this.model.logo?x.grey:null,o=a.a({href:\"https://bokeh.org/\",target:\"_blank\",class:[x.logo,x.logo_small,t]});this.el.appendChild(o)}for(const[,t]of this._tool_button_views)t.render();const t=[],o=t=>this._tool_button_views.get(t).el,{gestures:e}=this.model;for(const i of h.values(e))t.push(i.tools.map(o));t.push(this.model.actions.map(o)),t.push(this.model.inspectors.filter((t=>t.toggleable)).map(o));for(const o of t)if(0!==o.length){const t=a.div({class:z.button_bar},o);this.el.appendChild(t)}}update_layout(){}update_position(){}after_layout(){this._has_finished=!0}export(t,o=!0){const e=\"png\"==t?\"canvas\":\"svg\",i=new p.CanvasLayer(e,o);return i.resize(0,0),i}}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=M,M.__name__=\"ToolbarBaseView\";class S extends b.Model{constructor(t){super(t)}static init_ToolbarBase(){this.prototype.default_view=M,this.define((({Boolean:t,Array:o,Ref:e,Nullable:i})=>({tools:[o(e(g.Tool)),[]],logo:[i(_.Logo),\"normal\"],autohide:[t,!1]}))),this.internal((({Array:t,Struct:o,Ref:e,Nullable:i})=>{const s=o({tools:t(e(f.GestureTool)),active:i(e(g.Tool))});return{gestures:[o({pan:s,scroll:s,pinch:s,tap:s,doubletap:s,press:s,pressup:s,rotate:s,move:s,multi:s}),V],actions:[t(e(m.ActionTool)),[]],inspectors:[t(e(y.InspectTool)),[]],help:[t(e(w.HelpTool)),[]],toolbar_location:[_.Location,\"right\"]}}))}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 u.some(t,(t=>!e.has(t.id)))},o=this.tools.filter((t=>t instanceof y.InspectTool));t(this.inspectors,o)&&(this.inspectors=o);const e=this.tools.filter((t=>t instanceof w.HelpTool));t(this.help,e)&&(this.help=e);const i=this.tools.filter((t=>t instanceof m.ActionTool));t(this.actions,i)&&(this.actions=i);const s=(t,o)=>{t in this.gestures||n.logger.warn(`Toolbar: unknown event type '${t}' for tool: ${o}`)},l={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 f.GestureTool&&t.event_type)if(v.isString(t.event_type))l[t.event_type].tools.push(t),s(t.event_type,t);else{l.multi.tools.push(t);for(const o of t.event_type)s(o,t)}for(const o of Object.keys(l)){const e=this.gestures[o];t(e.tools,l[o].tools)&&(e.tools=l[o].tools),e.active&&u.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=v.isString(o)?[o]:o;for(const o of e)if(t.active){const e=this.gestures[o].active;null!=e&&t!=e&&(n.logger.debug(`Toolbar: deactivating tool: ${e} for event type '${o}'`),e.active=!1),this.gestures[o].active=t,n.logger.debug(`Toolbar: activating tool: ${t} for event type '${o}'`)}else this.gestures[o].active=null}}e.ToolbarBase=S,S.__name__=\"ToolbarBase\",S.init_ToolbarBase()},\n", " function _(e,t,i,n,s){n();const o=e(250),a=e(99),r=e(43);function h(e){!function(e){void 0===e.lineDash&&Object.defineProperty(e,\"lineDash\",{get:()=>e.getLineDash(),set:t=>e.setLineDash(t)})}(e),function(e){e.setImageSmoothingEnabled=t=>{e.imageSmoothingEnabled=t,e.mozImageSmoothingEnabled=t,e.oImageSmoothingEnabled=t,e.webkitImageSmoothingEnabled=t,e.msImageSmoothingEnabled=t},e.getImageSmoothingEnabled=()=>{const t=e.imageSmoothingEnabled;return null==t||t}}(e),function(e){e.ellipse||(e.ellipse=function(t,i,n,s,o,a,r,h=!1){const l=.551784;e.translate(t,i),e.rotate(o);let c=n,g=s;h&&(c=-n,g=-s),e.moveTo(-c,0),e.bezierCurveTo(-c,g*l,-c*l,g,0,g),e.bezierCurveTo(c*l,g,c,g*l,c,0),e.bezierCurveTo(c,-g*l,c*l,-g,0,-g),e.bezierCurveTo(-c*l,-g,-c,-g*l,-c,0),e.rotate(-o),e.translate(-t,-i)})}(e)}const l={position:\"absolute\",top:\"0\",left:\"0\",width:\"100%\",height:\"100%\"};class c{constructor(e,t){switch(this.backend=e,this.hidpi=t,this.pixel_ratio=1,this.bbox=new a.BBox,e){case\"webgl\":case\"canvas\":{this._el=this._canvas=r.canvas({style:l});const e=this.canvas.getContext(\"2d\");if(null==e)throw new Error(\"unable to obtain 2D rendering context\");this._ctx=e,t&&(this.pixel_ratio=devicePixelRatio);break}case\"svg\":{const e=new o.SVGRenderingContext2D;this._ctx=e,this._canvas=e.get_svg(),this._el=r.div({style:l},this._canvas);break}}h(this._ctx)}get canvas(){return this._canvas}get ctx(){return this._ctx}get el(){return this._el}resize(e,t){this.bbox=new a.BBox({left:0,top:0,width:e,height:t});const i=this._ctx instanceof o.SVGRenderingContext2D?this._ctx:this.canvas;i.width=e*this.pixel_ratio,i.height=t*this.pixel_ratio}prepare(){const{ctx:e,hidpi:t,pixel_ratio:i}=this;e.save(),t&&(e.scale(i,i),e.translate(.5,.5)),this.clear()}clear(){const{x:e,y:t,width:i,height:n}=this.bbox;this.ctx.clearRect(e,t,i,n)}finish(){this.ctx.restore()}to_blob(){const{_canvas:e}=this;if(e instanceof HTMLCanvasElement)return null!=e.msToBlob?Promise.resolve(e.msToBlob()):new Promise(((t,i)=>{e.toBlob((e=>null!=e?t(e):i()),\"image/png\")}));{const e=this._ctx.get_serialized_svg(!0),t=new Blob([e],{type:\"image/svg+xml\"});return Promise.resolve(t)}}}i.CanvasLayer=c,c.__name__=\"CanvasLayer\"},\n", " function _(t,e,i,s,n){s();const r=t(168),a=t(8),o=t(43);function l(t){if(!t)throw new Error(\"cannot create a random attribute name for an undefined object\");const e=\"ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz\";let i=\"\";do{i=\"\";for(let t=0;t<12;t++)i+=e[Math.floor(Math.random()*e.length)]}while(t[i]);return i}function h(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 _=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 w=v(f),b=v(g);this.lineTo(d+f[0]*n,m+f[1]*n),this.arc(d,m,n,w,b)}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){if(\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"stroke\"),\"none\"!=this.__currentElement.getAttribute(\"fill\")){const t=this.__currentElement.cloneNode(!0);this.__root.appendChild(t),this.__currentElement=t}this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"fill\"),null!=t&&this.__currentElement.setAttribute(\"fill-rule\",t),null!=this._clip_path&&this.__currentElement.setAttribute(\"clip-path\",this._clip_path)}rect(t,e,i,s){isFinite(t+e+i+s)&&(\"path\"!==this.__currentElement.nodeName&&this.beginPath(),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(){o.empty(this.__defs),o.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 n=this.__createElement(\"rect\",{x:t,y:e,width:i,height:s,fill:\"#FFFFFF\"},!0);this._apply_transform(n),this.__root.appendChild(n)}createLinearGradient(t,e,i,s){if(!isFinite(t+e+i+s))throw new Error(\"The provided double value is non-finite\");const[n,r]=this._transform.apply(t,e),[a,o]=this._transform.apply(i,s),h=this.__createElement(\"linearGradient\",{id:l(this.__ids),x1:`${n}px`,x2:`${a}px`,y1:`${r}px`,y2:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(h),new p(h,this)}createRadialGradient(t,e,i,s,n,r){if(!isFinite(t+e+i+s+n+r))throw new Error(\"The provided double value is non-finite\");const[a,o]=this._transform.apply(t,e),[h,c]=this._transform.apply(s,n),_=this.__createElement(\"radialGradient\",{id:l(this.__ids),cx:`${h}px`,cy:`${c}px`,r:`${r}px`,fx:`${a}px`,fy:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(_),new p(_,this)}__parseFont(){var t,e,i,s,n;const r=/^\\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),a={style:null!==(t=r[1])&&void 0!==t?t:\"normal\",size:null!==(e=r[4])&&void 0!==e?e:\"10px\",family:null!==(i=r[6])&&void 0!==i?i:\"sans-serif\",weight:null!==(s=r[3])&&void 0!==s?s:\"normal\",decoration:null!==(n=r[2])&&void 0!==n?n:\"normal\"};return\"underline\"===this.__fontUnderline&&(a.decoration=\"underline\"),null!=this.__fontHref&&(a.href=this.__fontHref),a}__wrapTextLink(t,e){if(t.href){const i=this.__createElement(\"a\");return i.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",t.href),i.appendChild(e),i}return e}__applyText(t,e,i,s){const n=this.__parseFont(),r=this.__createElement(\"text\",{\"font-family\":n.family,\"font-size\":n.size,\"font-style\":n.style,\"font-weight\":n.weight,\"text-decoration\":n.decoration,x:e,y:i,\"text-anchor\":h(this.textAlign),\"dominant-baseline\":c(this.textBaseline)},!0);r.appendChild(this.__document.createTextNode(t)),this._apply_transform(r),this.__currentElement=r,this.__applyStyleToCurrentElement(s),this.__root.appendChild(this.__wrapTextLink(n,r))}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,n,r=!1){if(!isFinite(t+e+i+s+n))return;if(s===n)return;(s%=2*Math.PI)===(n%=2*Math.PI)&&(n=(n+2*Math.PI-.001*(r?-1:1))%(2*Math.PI));const a=t+i*Math.cos(n),o=e+i*Math.sin(n),l=t+i*Math.cos(s),h=e+i*Math.sin(s),c=r?0:1;let _=0,u=n-s;u<0&&(u+=2*Math.PI),_=r?u>Math.PI?0:1:u>Math.PI?1:0,this.lineTo(l,h);const p=i,d=i,[m,f]=this._transform.apply(a,o);this.__addPathCommand(m,f,`A ${p} ${d} 0 ${_} ${c} ${m} ${f}`)}clip(){const t=this.__createElement(\"clipPath\"),e=l(this.__ids);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,n,r,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,n=l,r=h}else if(4==e.length){if([i,s,n,r]=e,!isFinite(i+s+n+r))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,n,r]=e,!isFinite(a+o+l+h+i+s+n+r))return}const c=this.__root,_=this._transform.clone().translate(i,s);if(t instanceof m||t instanceof SVGSVGElement){const e=(t instanceof SVGSVGElement?t:t.get_svg()).cloneNode(!0);let i;_.is_identity?i=c:(i=this.__createElement(\"g\"),this._apply_transform(i,_),c.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[t]=t,this.__defs.appendChild(e)}}else i.appendChild(t)}else if(t instanceof HTMLImageElement||t instanceof SVGImageElement){const e=this.__createElement(\"image\");if(e.setAttribute(\"width\",`${n}`),e.setAttribute(\"height\",`${r}`),e.setAttribute(\"preserveAspectRatio\",\"none\"),a||o||l!==t.width||h!==t.height){const e=this.__document.createElement(\"canvas\");e.width=n,e.height=r;e.getContext(\"2d\").drawImage(t,a,o,l,h,0,0,n,r),t=e}this._apply_transform(e,_);const i=t instanceof HTMLCanvasElement?t.toDataURL():t.getAttribute(\"src\");e.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",i),c.appendChild(e)}else if(t instanceof HTMLCanvasElement){const e=this.__createElement(\"image\");e.setAttribute(\"width\",`${n}`),e.setAttribute(\"height\",`${r}`),e.setAttribute(\"preserveAspectRatio\",\"none\");const i=this.__document.createElement(\"canvas\");i.width=n,i.height=r;const s=i.getContext(\"2d\");s.imageSmoothingEnabled=!1,s.drawImage(t,a,o,l,h,0,0,n,r),t=i,this._apply_transform(e,_),e.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",t.toDataURL()),c.appendChild(e)}}createPattern(t,e){const i=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"pattern\"),s=l(this.__ids);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.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",s),i.appendChild(e),this.__defs.appendChild(i)}else if(t instanceof m){for(const e of[...t.__root.childNodes])e instanceof SVGDefsElement||i.appendChild(e);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);this.__defs.appendChild(i)}return new d(i,this)}setLineDash(t){t&&t.length>0?this.lineDash=t.join(\",\"):this.lineDash=null}_to_number(t){return a.isNumber(t)?t:t.baseVal.value}}i.SVGRenderingContext2D=m,m.__name__=\"SVGRenderingContext2D\"},\n", " function _(o,t,n,i,e){i();const s=o(238),c=o(15);class l extends s.ButtonToolButtonView{_clicked(){this.model.do.emit(void 0)}}n.ActionToolButtonView=l,l.__name__=\"ActionToolButtonView\";class _ extends s.ButtonToolView{connect_signals(){super.connect_signals(),this.connect(this.model.do,(o=>this.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,i,l){i();const s=o(251),n=o(242);class r extends s.ActionToolView{doit(){window.open(this.model.redirect)}}t.HelpToolView=r,r.__name__=\"HelpToolView\";class c extends s.ActionTool{constructor(o){super(o),this.tool_name=\"Help\",this.icon=n.tool_icon_help}static init_HelpTool(){this.prototype.default_view=r,this.define((({String:o})=>({redirect:[o,\"https://docs.bokeh.org/en/latest/docs/user_guide/tools.html\"]}))),this.override({description:\"Click the question mark to learn more about Bokeh plot tools.\"}),this.register_alias(\"help\",(()=>new c))}}t.HelpTool=c,c.__name__=\"HelpTool\",c.init_HelpTool()},\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(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAABx0RVh0U29mdHdhcmUAQWRvYmUgRmlyZXdvcmtzIENTNui8sowAAAOkSURBVDiNjZRtaJVlGMd/1/08zzln5zjP1LWcU9N0NkN8m2CYjpgQYQXqSs0I84OLIC0hkEKoPtiH3gmKoiJDU7QpLgoLjLIQCpEsNJ1vqUOdO7ppbuec5+V+rj4ctwzd8IIbbi6u+8f1539dt3A78eXC7QizUF7gyV1fD1Yqg4JWz84yffhm0qkFqBogB9rM8tZdtwVsPUhWhGcFJngGeWrPzHm5oaMmkfEg1usvLFyc8jLRqDOMru7AyC8saQr7GG7f5fvDeH7Ej8CM66nIF+8yngt6HWaKh7k49Soy9nXurCi1o3qUbS3zWfrYeQDTB/Qj6kX6Ybhw4B+bOYoLKCC9H3Nu/leUTZ1JdRWkkn2ldcCamzrcf47KKXdAJllSlxAOkRgyHsGC/zRday5Qld9DyoM4/q/rUoy/CXh3jzOu3bHUVZeU+DEn8FInkPBFlu3+nW3Nw0mk6vCDiWg8CeJaxEwuHS3+z5RgY+YBR6V1Z1nxSOfoaPa4LASWxxdNp+VWTk7+4vzaou8v8PN+xo+KY2xsw6une2frhw05CTYOmQvsEhjhWjn0bmXPjpE1+kplmmkP3suftwTubK9Vq22qKmrBhpY4jvd5afdRA3wGjFAgcnTK2s4hY0/GPNIb0nErGMCRxWOOX64Z8RAC4oCXdklmEvcL8o0BfkNK4lUg9HTl+oPlQxdNo3Mg4Nv175e/1LDGzZen30MEjRUtmXSfiTVu1kK8W4txyV6BMKlbgk3lMwYCiusNy9fVfvvwMxv8Ynl6vxoByANLTWplvuj/nF9m2+PDtt1eiHPBr1oIfhCChQMBw6Aw0UulqTKZdfVvfG7VcfIqLG9bcldL/+pdWTLxLUy8Qq38heUIjh4XlzZxzQm19lLFlr8vdQ97rjZVOLf8nclzckbcD4wxXMidpX30sFd37Fv/GtwwhzhxGVAprjbg0gCAEeIgwCZyTV2Z1REEW8O4py0wsjeloKoMr6iCY6dP92H6Vw/oTyICIthibxjm/DfN9lVz8IqtqKYLUXfoKVMVQVVJOElGjrnnUt9T9wbgp8AyYKaGlqingHZU/uG2NTZSVqwHQTWkx9hxjkpWDaCg6Ckj5qebgBVbT3V3NNXMSiWSDdGV3hrtzla7J+duwPOToIg42ChPQOQjspnSlp1V+Gjdged7+8UN5CRAV7a5EdFNwCjEaBR27b3W890TE7g24NAP/mMDXRWrGoFPQI9ls/MWO2dWFAar/xcOIImbbpA3zgAAAABJRU5ErkJggg==);}.bk-root .bk-logo-notebook{display:inline-block;vertical-align:middle;margin-right:5px;}\"},\n", " function _(t,e,i,s,l){s();const o=t(1),n=t(40),h=t(20),a=t(43),r=o.__importStar(t(255)),c=r;class d extends n.AnnotationView{initialize(){super.initialize(),this.el=a.div({class:c.tooltip}),a.undisplay(this.el),this.plot_view.canvas_view.add_overlay(this.el)}remove(){a.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(),r.default]}render(){this.model.visible||a.undisplay(this.el),super.render()}_render(){const{content:t}=this.model;null!=t?(a.empty(this.el),a.classes(this.el).toggle(\"bk-tooltip-custom\",this.model.custom),this.el.appendChild(t),this.model.show_arrow&&this.el.classList.add(c.tooltip_arrow)):a.undisplay(this.el)}_reposition(){const{position:t}=this.model;if(null==t)return void a.undisplay(this.el);const[e,i]=t,s=(()=>{const t=this.parent.layout.bbox.relative(),{attachment:s}=this.model;switch(s){case\"horizontal\":return e({attachment:[h.TooltipAttachment,\"horizontal\"],inner_only:[t,!0],show_arrow:[t,!0]}))),this.internal((({Boolean:t,Number:e,Tuple:i,Ref:s,Nullable:l})=>({position:[l(i(e,e)),null],content:[s(HTMLElement),()=>a.div()],custom:[t]}))),this.override({level:\"overlay\"})}clear(){this.position=null}}i.Tooltip=p,p.__name__=\"Tooltip\",p.init_Tooltip()},\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,i,s,r){s();const a=e(135),h=e(133),_=e(122),l=e(48);class o extends a.UpperLowerView{async lazy_initialize(){await super.lazy_initialize();const{lower_head:e,upper_head:t}=this.model;null!=e&&(this.lower_head=await _.build_view(e,{parent:this})),null!=t&&(this.upper_head=await _.build_view(t,{parent:this}))}set_data(e){var t,i;super.set_data(e),null===(t=this.lower_head)||void 0===t||t.set_data(e),null===(i=this.upper_head)||void 0===i||i.set_data(e)}paint(e){if(this.visuals.line.doit)for(let t=0,i=this._lower_sx.length;t({lower_head:[t(e(h.ArrowHead)),()=>new h.TeeHead({size:10})],upper_head:[t(e(h.ArrowHead)),()=>new h.TeeHead({size:10})]}))),this.override({level:\"underlay\"})}}i.Whisker=n,n.__name__=\"Whisker\",n.init_Whisker()},\n", " function _(n,o,t,u,e){u(),e(\"CustomJS\",n(258).CustomJS),e(\"OpenURL\",n(260).OpenURL)},\n", " function _(t,s,e,n,c){n();const u=t(259),i=t(13),a=t(34);class r extends u.Callback{constructor(t){super(t)}static init_CustomJS(){this.define((({Unknown:t,String:s,Dict:e})=>({args:[e(t),{}],code:[s,\"\"]})))}get names(){return i.keys(this.args)}get values(){return i.values(this.args)}get func(){const t=a.use_strict(this.code);return new Function(...this.names,\"cb_obj\",\"cb_data\",t)}execute(t,s={}){return this.func.apply(t,this.values.concat(t,s))}}e.CustomJS=r,r.__name__=\"CustomJS\",r.init_CustomJS()},\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,i,o){i();const s=e(259),c=e(182),r=e(8);class a extends s.Callback{constructor(e){super(e)}static init_OpenURL(){this.define((({Boolean:e,String:t})=>({url:[t,\"http://\"],same_tab:[e,!1]})))}navigate(e){this.same_tab?window.location.href=e:window.open(e)}execute(e,{source:t}){const n=e=>{const n=c.replace_placeholders(this.url,t,e,void 0,void 0,encodeURI);if(!r.isString(n))throw new Error(\"HTML output is not supported in this context\");this.navigate(n)},{selected:i}=t;for(const e of i.indices)n(e);for(const e of i.line_indices)n(e)}}n.OpenURL=a,a.__name__=\"OpenURL\",a.init_OpenURL()},\n", " function _(a,n,e,r,s){r(),s(\"Canvas\",a(262).Canvas),s(\"CartesianFrame\",a(144).CartesianFrame)},\n", " function _(e,t,s,i,a){i();const l=e(14),n=e(240),r=e(19),o=e(43),h=e(20),_=e(13),c=e(263),d=e(99),p=e(249),v=(()=>{const e=document.createElement(\"canvas\"),t=e.getContext(\"webgl\",{premultipliedAlpha:!0});return null!=t?{canvas:e,gl:t}:void r.logger.trace(\"WebGL is not supported\")})(),u={position:\"absolute\",top:\"0\",left:\"0\",width:\"100%\",height:\"100%\"};class b extends n.DOMView{constructor(){super(...arguments),this.bbox=new d.BBox}initialize(){super.initialize(),\"webgl\"==this.model.output_backend&&(this.webgl=v),this.underlays_el=o.div({style:u}),this.primary=this.create_layer(),this.overlays=this.create_layer(),this.overlays_el=o.div({style:u}),this.events_el=o.div({class:\"bk-canvas-events\",style:u});const e=[this.underlays_el,this.primary.el,this.overlays.el,this.overlays_el,this.events_el];_.extend(this.el.style,u),o.append(this.el,...e),this.ui_event_bus=new c.UIEventBus(this)}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 d.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:s,height:i}=this.bbox;t.canvas.width=this.pixel_ratio*s,t.canvas.height=this.pixel_ratio*i;const{gl:a}=t;a.enable(a.SCISSOR_TEST);const[l,n,r,o]=e,{xview:h,yview:_}=this.bbox,c=h.compute(l),d=_.compute(n+o),p=this.pixel_ratio;a.scissor(p*c,p*d,p*r,p*o),a.enable(a.BLEND),a.blendFuncSeparate(a.SRC_ALPHA,a.ONE_MINUS_SRC_ALPHA,a.ONE_MINUS_DST_ALPHA,a.ONE),this._clear_webgl()}}blit_webgl(e){const{webgl:t}=this;if(null!=t){if(r.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{gl:t,canvas:s}=e;t.viewport(0,0,s.width,s.height),t.clearColor(0,0,0,0),t.clear(t.COLOR_BUFFER_BIT|t.DEPTH_BUFFER_BIT)}}compose(){const e=this.create_layer(),{width:t,height:s}=this.bbox;return e.resize(t,s),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 p.CanvasLayer(e,t)}to_blob(){return this.compose().to_blob()}}s.CanvasView=b,b.__name__=\"CanvasView\";class g extends l.HasProps{constructor(e){super(e)}static init_Canvas(){this.prototype.default_view=b,this.internal((({Boolean:e})=>({hidpi:[e,!0],output_backend:[h.OutputBackend,\"canvas\"]})))}}s.Canvas=g,g.__name__=\"Canvas\",g.init_Canvas()},\n", " function _(t,e,s,n,i){n();const r=t(1),a=r.__importDefault(t(239)),_=t(15),h=t(19),o=t(43),l=r.__importStar(t(264)),c=t(265),p=t(9),u=t(8),v=t(27),d=t(244);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&&(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 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,p.is_empty(r)||(e=this.move_exit)):this._hit_test_frame(t,s.sx,s.sy)&&(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}=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: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 c=e.length-1;c>=0;c--)(_=e[c])&&(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 c{to_json(){const{event_name:e}=this;return{event_name:e,event_values:this._to_json()}}}s.BokehEvent=c,c.__name__=\"BokehEvent\";class r extends c{constructor(){super(...arguments),this.origin=null}_to_json(){return{model:this.origin}}}s.ModelEvent=r,r.__name__=\"ModelEvent\";let l=class extends c{_to_json(){return{}}};s.DocumentReady=l,l.__name__=\"DocumentReady\",s.DocumentReady=l=a([o(\"document_ready\")],l);let i=class extends r{};s.ButtonClick=i,i.__name__=\"ButtonClick\",s.ButtonClick=i=a([o(\"button_click\")],i);let u=class extends r{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 r{}s.UIEvent=d,d.__name__=\"UIEvent\";let h=class extends d{};s.LODStart=h,h.__name__=\"LODStart\",s.LODStart=h=a([o(\"lodstart\")],h);let m=class extends d{};s.LODEnd=m,m.__name__=\"LODEnd\",s.LODEnd=m=a([o(\"lodend\")],m);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 p=class extends d{};s.Reset=p,p.__name__=\"Reset\",s.Reset=p=a([o(\"reset\")],p);class j 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=j,j.__name__=\"PointEvent\";let y=class extends j{constructor(e,t,s,n,_,a){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=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=y,y.__name__=\"Pan\",s.Pan=y=a([o(\"pan\")],y);let P=class extends j{constructor(e,t,s,n,_){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=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 v=class extends j{constructor(e,t,s,n,_){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=n,this.rotation=_}_to_json(){const{rotation:e}=this;return Object.assign(Object.assign({},super._to_json()),{rotation:e})}};s.Rotate=v,v.__name__=\"Rotate\",s.Rotate=v=a([o(\"rotate\")],v);let g=class extends j{constructor(e,t,s,n,_){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=n,this.delta=_}_to_json(){const{delta:e}=this;return Object.assign(Object.assign({},super._to_json()),{delta:e})}};s.MouseWheel=g,g.__name__=\"MouseWheel\",s.MouseWheel=g=a([o(\"wheel\")],g);let E=class extends j{};s.MouseMove=E,E.__name__=\"MouseMove\",s.MouseMove=E=a([o(\"mousemove\")],E);let O=class extends j{};s.MouseEnter=O,O.__name__=\"MouseEnter\",s.MouseEnter=O=a([o(\"mouseenter\")],O);let b=class extends j{};s.MouseLeave=b,b.__name__=\"MouseLeave\",s.MouseLeave=b=a([o(\"mouseleave\")],b);let M=class extends j{};s.Tap=M,M.__name__=\"Tap\",s.Tap=M=a([o(\"tap\")],M);let R=class extends j{};s.DoubleTap=R,R.__name__=\"DoubleTap\",s.DoubleTap=R=a([o(\"doubletap\")],R);let f=class extends j{};s.Press=f,f.__name__=\"Press\",s.Press=f=a([o(\"press\")],f);let S=class extends j{};s.PressUp=S,S.__name__=\"PressUp\",s.PressUp=S=a([o(\"pressup\")],S);let D=class extends j{};s.PanStart=D,D.__name__=\"PanStart\",s.PanStart=D=a([o(\"panstart\")],D);let k=class extends j{};s.PanEnd=k,k.__name__=\"PanEnd\",s.PanEnd=k=a([o(\"panend\")],k);let L=class extends j{};s.PinchStart=L,L.__name__=\"PinchStart\",s.PinchStart=L=a([o(\"pinchstart\")],L);let C=class extends j{};s.PinchEnd=C,C.__name__=\"PinchEnd\",s.PinchEnd=C=a([o(\"pinchend\")],C);let T=class extends j{};s.RotateStart=T,T.__name__=\"RotateStart\",s.RotateStart=T=a([o(\"rotatestart\")],T);let B=class extends j{};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,i,u,s,a){s(),a(\"Expression\",m(124).Expression),a(\"CustomJSExpr\",m(267).CustomJSExpr),a(\"Stack\",m(268).Stack),a(\"CumSum\",m(269).CumSum),a(\"ScalarExpression\",m(124).ScalarExpression),a(\"Minimum\",m(270).Minimum),a(\"Maximum\",m(271).Maximum)},\n", " function _(t,e,s,n,r){n();const i=t(14),o=t(124),a=t(24),c=t(9),u=t(13),l=t(34),h=t(8);class p extends o.Expression{constructor(t){super(t)}static init_CustomJSExpr(){this.define((({Unknown:t,String:e,Dict:s})=>({args:[s(t),{}],code:[e,\"\"]})))}connect_signals(){super.connect_signals();for(const t of u.values(this.args))t instanceof i.HasProps&&t.change.connect((()=>{this._result.clear(),this.change.emit()}))}get names(){return u.keys(this.args)}get values(){return u.values(this.args)}get func(){const t=l.use_strict(this.code);return new a.GeneratorFunction(...this.names,t)}_v_compute(t){const e=this.func.apply(t,this.values);let s=e.next();if(s.done&&void 0!==s.value){const{value:e}=s;return h.isArray(e)||h.isTypedArray(e)?e:h.isIterable(e)?[...e]:c.repeat(e,t.length)}{const t=[];do{t.push(s.value),s=e.next()}while(!s.done);return t}}}s.CustomJSExpr=p,p.__name__=\"CustomJSExpr\",p.init_CustomJSExpr()},\n", " function _(t,n,e,i,s){i();const a=t(124);class c extends a.Expression{constructor(t){super(t)}static init_Stack(){this.define((({String:t,Array:n})=>({fields:[n(t),[]]})))}_v_compute(t){var n;const e=null!==(n=t.get_length())&&void 0!==n?n:0,i=new Float64Array(e);for(const n of this.fields){const s=t.data[n];if(null!=s)for(let t=0,n=Math.min(e,s.length);t({field:[t],include_zero:[e,!1]})))}_v_compute(e){var t;const n=new Float64Array(null!==(t=e.get_length())&&void 0!==t?t:0),i=e.data[this.field],u=this.include_zero?1:0;n[0]=this.include_zero?0:i[0];for(let e=1;e({field:[n],initial:[t(i),null]})))}_compute(i){var n,t;const l=null!==(n=i.data[this.field])&&void 0!==n?n:[];return Math.min(null!==(t=this.initial)&&void 0!==t?t:1/0,m.min(l))}}t.Minimum=s,s.__name__=\"Minimum\",s.init_Minimum()},\n", " function _(i,t,a,n,l){n();const u=i(124),e=i(9);class m extends u.ScalarExpression{constructor(i){super(i)}static init_Maximum(){this.define((({Number:i,String:t,Nullable:a})=>({field:[t],initial:[a(i),null]})))}_compute(i){var t,a;const n=null!==(t=i.data[this.field])&&void 0!==t?t:[];return Math.max(null!==(a=this.initial)&&void 0!==a?a:-1/0,e.max(n))}}a.Maximum=m,m.__name__=\"Maximum\",m.init_Maximum()},\n", " function _(e,t,l,r,i){r(),i(\"BooleanFilter\",e(273).BooleanFilter),i(\"CustomJSFilter\",e(274).CustomJSFilter),i(\"Filter\",e(121).Filter),i(\"GroupFilter\",e(275).GroupFilter),i(\"IndexFilter\",e(276).IndexFilter)},\n", " function _(e,n,l,o,t){o();const i=e(121),s=e(24);class a extends i.Filter{constructor(e){super(e)}static init_BooleanFilter(){this.define((({Boolean:e,Array:n,Nullable:l})=>({booleans:[l(n(e)),null]})))}compute_indices(e){const n=e.length,{booleans:l}=this;return null==l?s.Indices.all_set(n):s.Indices.from_booleans(n,l)}}l.BooleanFilter=a,a.__name__=\"BooleanFilter\",a.init_BooleanFilter()},\n", " function _(e,t,s,n,r){n();const i=e(121),o=e(24),u=e(13),c=e(8),a=e(34);class l extends i.Filter{constructor(e){super(e)}static init_CustomJSFilter(){this.define((({Unknown:e,String:t,Dict:s})=>({args:[s(e),{}],code:[t,\"\"]})))}get names(){return u.keys(this.args)}get values(){return u.values(this.args)}get func(){const e=a.use_strict(this.code);return new Function(...this.names,\"source\",e)}compute_indices(e){const t=e.length,s=this.func(...this.values,e);if(null==s)return o.Indices.all_set(t);if(c.isArrayOf(s,c.isInteger))return o.Indices.from_indices(t,s);if(c.isArrayOf(s,c.isBoolean))return o.Indices.from_booleans(t,s);throw new Error(`expect an array of integers or booleans, or null, got ${s}`)}}s.CustomJSFilter=l,l.__name__=\"CustomJSFilter\",l.init_CustomJSFilter()},\n", " function _(n,t,e,i,o){i();const r=n(121),u=n(24),s=n(19);class c extends r.Filter{constructor(n){super(n)}static init_GroupFilter(){this.define((({String:n})=>({column_name:[n],group:[n]})))}compute_indices(n){const t=n.get_column(this.column_name);if(null==t)return s.logger.warn(`${this}: groupby column '${this.column_name}' not found in the data source`),new u.Indices(n.length,1);{const e=new u.Indices(n.length);for(let n=0;n({indices:[i(n(e)),null]})))}compute_indices(e){const n=e.length,{indices:i}=this;return null==i?c.Indices.all_set(n):c.Indices.from_indices(n,i)}}i.IndexFilter=r,r.__name__=\"IndexFilter\",r.init_IndexFilter()},\n", " function _(e,a,l,i,t){i(),t(\"AnnularWedge\",e(278).AnnularWedge),t(\"Annulus\",e(279).Annulus),t(\"Arc\",e(280).Arc),t(\"Bezier\",e(281).Bezier),t(\"Circle\",e(282).Circle),t(\"Ellipse\",e(286).Ellipse),t(\"EllipseOval\",e(287).EllipseOval),t(\"Glyph\",e(98).Glyph),t(\"HArea\",e(117).HArea),t(\"HBar\",e(289).HBar),t(\"HexTile\",e(291).HexTile),t(\"Image\",e(292).Image),t(\"ImageRGBA\",e(294).ImageRGBA),t(\"ImageURL\",e(295).ImageURL),t(\"Line\",e(63).Line),t(\"MultiLine\",e(127).MultiLine),t(\"MultiPolygons\",e(297).MultiPolygons),t(\"Oval\",e(298).Oval),t(\"Patch\",e(116).Patch),t(\"Patches\",e(128).Patches),t(\"Quad\",e(299).Quad),t(\"Quadratic\",e(300).Quadratic),t(\"Ray\",e(301).Ray),t(\"Rect\",e(302).Rect),t(\"Scatter\",e(303).Scatter),t(\"Segment\",e(306).Segment),t(\"Spline\",e(307).Spline),t(\"Step\",e(309).Step),t(\"Text\",e(310).Text),t(\"VArea\",e(119).VArea),t(\"VBar\",e(311).VBar),t(\"Wedge\",e(312).Wedge)},\n", " function _(e,t,s,i,r){i();const n=e(1),a=e(64),o=e(106),_=e(48),d=e(24),u=e(20),h=n.__importStar(e(18)),l=e(10),c=e(59);class g extends a.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=d.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=d.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],l=_[s],c=n.get(s),g=a.get(s);if(isNaN(t+u+h+l+c+g))continue;const x=g-c;e.translate(t,u),e.rotate(c),e.beginPath(),e.moveTo(l,0),e.arc(0,0,l,0,x,d),e.rotate(x),e.lineTo(h,0),e.arc(0,0,h,0,-x,!d),e.closePath(),e.rotate(-x-c),e.translate(-t,-u),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,s),e.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(e,s),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,s),e.stroke())}}_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]);l.angle_between(-i,-this.start_angle.get(e),-this.end_angle.get(e),u)&&h.push(e)}return new c.Selection({indices:h})}draw_legend_for_index(e,t,s){o.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=g,g.__name__=\"AnnularWedgeView\";class x extends a.XYGlyph{constructor(e){super(e)}static init_AnnularWedge(){this.prototype.default_view=g,this.mixins([_.LineVector,_.FillVector,_.HatchVector]),this.define((({})=>({direction:[u.Direction,\"anticlock\"],inner_radius:[h.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[h.DistanceSpec,{field:\"outer_radius\"}],start_angle:[h.AngleSpec,{field:\"start_angle\"}],end_angle:[h.AngleSpec,{field:\"end_angle\"}]})))}}s.AnnularWedge=x,x.__name__=\"AnnularWedge\",x.init_AnnularWedge()},\n", " function _(s,i,t,e,r){e();const n=s(1),a=s(64),u=s(24),_=s(48),o=n.__importStar(s(18)),h=s(27),d=s(59);class c extends a.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=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=u.to_screen(this.outer_radius)}_render(s,i,t){const{sx:e,sy:r,sinner_radius:n,souter_radius:a}=null!=t?t:this;for(const t of i){const i=e[t],_=r[t],o=n[t],d=a[t];function u(){if(s.beginPath(),h.is_ie)for(const t of[!1,!0])s.arc(i,_,o,0,Math.PI,t),s.arc(i,_,d,Math.PI,0,!t);else s.arc(i,_,o,0,2*Math.PI,!0),s.arc(i,_,d,2*Math.PI,0,!1)}isNaN(i+_+o+d)||(this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(s,t),u(),s.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(s,t),u(),s.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(s,t),s.beginPath(),s.arc(i,_,o,0,2*Math.PI),s.moveTo(i+d,_),s.arc(i,_,d,0,2*Math.PI),s.stroke()))}}_hit_point(s){const{sx:i,sy:t}=s,e=this.renderer.xscale.invert(i),r=this.renderer.yscale.invert(t);let n,a,u,_;if(\"data\"==this.model.properties.outer_radius.units)n=e-this.max_outer_radius,u=e+this.max_outer_radius,a=r-this.max_outer_radius,_=r+this.max_outer_radius;else{const s=i-this.max_outer_radius,e=i+this.max_outer_radius;[n,u]=this.renderer.xscale.r_invert(s,e);const r=t-this.max_outer_radius,o=t+this.max_outer_radius;[a,_]=this.renderer.yscale.r_invert(r,o)}const o=[];for(const s of this.index.indices({x0:n,x1:u,y0:a,y1:_})){const i=this.souter_radius[s]**2,t=this.sinner_radius[s]**2,[n,a]=this.renderer.xscale.r_compute(e,this._x[s]),[u,_]=this.renderer.yscale.r_compute(r,this._y[s]),h=(n-a)**2+(u-_)**2;h<=i&&h>=t&&o.push(s)}return new d.Selection({indices:o})}draw_legend_for_index(s,{x0:i,y0:t,x1:e,y1:r},n){const a=n+1,u=new Array(a);u[n]=(i+e)/2;const _=new Array(a);_[n]=(t+r)/2;const o=.5*Math.min(Math.abs(e-i),Math.abs(r-t)),h=new Array(a);h[n]=.4*o;const d=new Array(a);d[n]=.8*o,this._render(s,[n],{sx:u,sy:_,sinner_radius:h,souter_radius:d})}}t.AnnulusView=c,c.__name__=\"AnnulusView\";class l extends a.XYGlyph{constructor(s){super(s)}static init_Annulus(){this.prototype.default_view=c,this.mixins([_.LineVector,_.FillVector,_.HatchVector]),this.define((({})=>({inner_radius:[o.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[o.DistanceSpec,{field:\"outer_radius\"}]})))}}t.Annulus=l,l.__name__=\"Annulus\",l.init_Annulus()},\n", " function _(e,i,s,t,n){t();const r=e(1),a=e(64),c=e(106),d=e(48),_=e(24),l=e(20),o=r.__importStar(e(18));class h extends a.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius):this.sradius=_.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],_=n[s],l=r[s],o=a.get(s),h=c.get(s);isNaN(i+_+l+o+h)||(e.beginPath(),e.arc(i,_,l,o,h,d),this.visuals.line.set_vectorize(e,s),e.stroke())}}}draw_legend_for_index(e,i,s){c.generic_line_vector_legend(this.visuals,e,i,s)}}s.ArcView=h,h.__name__=\"ArcView\";class u extends a.XYGlyph{constructor(e){super(e)}static init_Arc(){this.prototype.default_view=h,this.mixins(d.LineVector),this.define((({})=>({direction:[l.Direction,\"anticlock\"],radius:[o.DistanceSpec,{field:\"radius\"}],start_angle:[o.AngleSpec,{field:\"start_angle\"}],end_angle:[o.AngleSpec,{field:\"end_angle\"}]})))}}s.Arc=u,u.__name__=\"Arc\",u.init_Arc()},\n", " function _(e,t,i,s,n){s();const o=e(1),c=e(48),r=e(98),a=e(106),_=e(65),d=o.__importStar(e(18));function l(e,t,i,s,n,o,c,r){const a=[],_=[[],[]];for(let _=0;_<=2;_++){let d,l,x;if(0===_?(l=6*e-12*i+6*n,d=-3*e+9*i-9*n+3*c,x=3*i-3*e):(l=6*t-12*s+6*o,d=-3*t+9*s-9*o+3*r,x=3*s-3*t),Math.abs(d)<1e-12){if(Math.abs(l)<1e-12)continue;const e=-x/l;0({x0:[d.XCoordinateSpec,{field:\"x0\"}],y0:[d.YCoordinateSpec,{field:\"y0\"}],x1:[d.XCoordinateSpec,{field:\"x1\"}],y1:[d.YCoordinateSpec,{field:\"y1\"}],cx0:[d.XCoordinateSpec,{field:\"cx0\"}],cy0:[d.YCoordinateSpec,{field:\"cy0\"}],cx1:[d.XCoordinateSpec,{field:\"cx1\"}],cy1:[d.YCoordinateSpec,{field:\"cy1\"}]}))),this.mixins(c.LineVector)}}i.Bezier=h,h.__name__=\"Bezier\",h.init_Bezier()},\n", " function _(s,i,e,t,r){t();const a=s(1),n=s(64),h=s(283),d=s(48),l=s(24),c=s(20),_=a.__importStar(s(107)),u=a.__importStar(s(18)),o=s(9),x=s(12),m=s(59);class y extends n.XYGlyphView{initialize(){super.initialize();const{webgl:s}=this.renderer.plot_view.canvas_view;null!=s&&(this.glglyph=new h.MarkerGL(s.gl,this,\"circle\"))}get use_radius(){return!(this.radius.is_Scalar()&&isNaN(this.radius.value))}_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=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=x.map(s,((s,e)=>Math.min(s,i[e])));break}}else this.sradius=l.to_screen(this.radius),this._configure(\"max_size\",{value:2*this.max_radius});else{const s=new l.ScreenArray(this.size);this.sradius=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];isNaN(i+n+h)||(s.beginPath(),s.arc(i,n,h,0,2*Math.PI,!1),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(s,e),s.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(s,e),s.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(s,e),s.stroke()))}}_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=o.range(0,this.sx.length),r=[];for(let s=0,a=t.length;s({angle:[u.AngleSpec,0],size:[u.ScreenDistanceSpec,{value:4}],radius:[u.NullDistanceSpec,null],radius_dimension:[c.RadiusDimension,\"x\"],hit_dilation:[s,1]})))}}e.Circle=p,p.__name__=\"Circle\",p.init_Circle()},\n", " function _(t,e,s,i,a){i();const r=t(1),o=t(109),_=t(113),l=r.__importDefault(t(284)),h=r.__importDefault(t(285)),n=t(282),f=t(12),u=t(19),c=t(24),g=t(22),b=t(11);function d(t,e,s,i,a,r,o){if(a.doit)if(r.is_Scalar()&&o.is_Scalar()){e.used=!1;const[i,a,_,l]=g.color2rgba(r.value,o.value);t.set_attribute(s,\"vec4\",[i/255,a/255,_/255,l/255])}else{let a;if(e.used=!0,r.is_Vector()){const t=new c.ColorArray(r.array);if(a=new c.RGBAArray(t.buffer),!o.is_Scalar()||1!=o.value)for(let t=0;t2*t))),i.data_changed=!1),this.visuals_changed&&(this._set_visuals(a),this.visuals_changed=!1),this.prog.set_uniform(\"u_pixel_ratio\",\"float\",[s.pixel_ratio]),this.prog.set_uniform(\"u_canvas_size\",\"vec2\",[s.width,s.height]),this.prog.set_attribute(\"a_sx\",\"float\",i.vbo_sx),this.prog.set_attribute(\"a_sy\",\"float\",i.vbo_sy),this.prog.set_attribute(\"a_size\",\"float\",i.vbo_s),this.prog.set_attribute(\"a_angle\",\"float\",i.vbo_a),0!=t.length)if(t.length===a)this.prog.draw(this.gl.POINTS,[0,a]);else if(a<65535){const e=window.navigator.userAgent;e.indexOf(\"MSIE \")+e.indexOf(\"Trident/\")+e.indexOf(\"Edge/\")>0&&u.logger.warn(\"WebGL warning: IE is known to produce 1px sprites whith selections.\"),this.index_buffer.set_size(2*t.length),this.index_buffer.set_data(0,new Uint16Array(t)),this.prog.draw(this.gl.POINTS,this.index_buffer)}else{const e=64e3,s=[];for(let t=0,i=Math.ceil(a/e);t2*t))):this.vbo_s.set_data(0,new Float32Array(this.glyph.size))}_set_visuals(t){const{line:e,fill:s}=this.glyph.visuals;!function(t,e,s,i,a,r){if(a.doit){if(r.is_Scalar())e.used=!1,t.set_attribute(s,\"float\",[r.value]);else if(r.is_Vector()){e.used=!0;const a=new Float32Array(r.array);e.set_size(4*i),e.set_data(0,a),t.set_attribute(s,\"float\",e)}}else e.used=!1,t.set_attribute(s,\"float\",[0])}(this.prog,this.vbo_linewidth,\"a_linewidth\",t,e,e.line_width),d(this.prog,this.vbo_fg_color,\"a_fg_color\",t,e,e.line_color,e.line_alpha),d(this.prog,this.vbo_bg_color,\"a_bg_color\",t,s,s.fill_color,s.fill_alpha),this.prog.set_uniform(\"u_antialias\",\"float\",[.8])}}s.MarkerGL=p,p.__name__=\"MarkerGL\"},\n", " function _(n,i,a,o,_){o();a.default=\"\\nprecision mediump float;\\nconst float SQRT_2 = 1.4142135623730951;\\n//\\nuniform float u_pixel_ratio;\\nuniform vec2 u_canvas_size;\\nuniform vec2 u_offset;\\nuniform vec2 u_scale;\\nuniform float u_antialias;\\n//\\nattribute float a_sx;\\nattribute float a_sy;\\nattribute float a_size;\\nattribute float a_angle; // in radians\\nattribute float a_linewidth;\\nattribute vec4 a_fg_color;\\nattribute vec4 a_bg_color;\\n//\\nvarying float v_linewidth;\\nvarying float v_size;\\nvarying vec4 v_fg_color;\\nvarying vec4 v_bg_color;\\nvarying vec2 v_rotation;\\n\\nvoid main (void)\\n{\\n v_size = a_size * u_pixel_ratio;\\n v_linewidth = a_linewidth * u_pixel_ratio;\\n v_fg_color = a_fg_color;\\n v_bg_color = a_bg_color;\\n v_rotation = vec2(cos(-a_angle), sin(-a_angle));\\n vec2 pos = vec2(a_sx, a_sy); // in pixels\\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(pos*2.0-1.0, 0.0, 1.0);\\n gl_Position.y *= -1.0;\\n gl_PointSize = SQRT_2 * v_size + 2.0 * (v_linewidth + 1.5*u_antialias);\\n}\\n\"},\n", " function _(n,a,s,e,t){e();s.default='\\nprecision mediump float;\\n\\nconst float SQRT_2 = 1.4142135623730951;\\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\\n//\\nuniform float u_antialias;\\n//\\nvarying vec4 v_fg_color;\\nvarying vec4 v_bg_color;\\nvarying float v_linewidth;\\nvarying float v_size;\\nvarying vec2 v_rotation;\\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 * SQRT_2);\\n float square = max(abs(P.x), abs(P.y)) - size / (2.0 * SQRT_2);\\n // Shapes\\n float X = min(abs(P.x - P.y), abs(P.x + P.y)) - size / 100.0; // bit of \"width\" for aa\\n float cross = min(abs(P.x), abs(P.y)) - size / 100.0; // bit of \"width\" for aa\\n // Result is union of masked shapes\\n return min(max(X, diamond), max(cross, square));\\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_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_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_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_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\\n return length(P)*sign(P.x);\\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_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.5; // 2.5 is a tweak\\n float cross = min(abs(P.x), abs(P.y)) - size / 100.0; // bit of \"width\" for aa\\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 / 1.6;\\n float X = min(abs(P.x - P.y), abs(P.x + P.y)) - size / 100.0; // bit of \"width\" for aa\\n return max(circle, X);\\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 float almost = min(min(min(c1, c2), c3), c4);\\n // In this case, the X is also outside of the main shape\\n float Xmask = length(P) - size / 1.6; // a circle\\n float X = min(abs(P.x - P.y), abs(P.x + P.y)) - size / 100.0; // bit of \"width\" for aa\\n return min(max(X, Xmask), almost);\\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\\nvec4 outline(float distance, float linewidth, float antialias, vec4 fg_color, vec4 bg_color)\\n{\\n vec4 frag_color;\\n float t = linewidth/2.0 - antialias;\\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 fg alpha is zero, it probably means no outline. To avoid a dark outline\\n // shining through due to aa, we set the fg color to the bg color. Avoid if (i.e. branching).\\n float select = float(bool(fg_color.a));\\n fg_color.rgb = select * fg_color.rgb + (1.0 - select) * bg_color.rgb;\\n // Similarly, if we want a transparent bg\\n select = float(bool(bg_color.a));\\n bg_color.rgb = select * bg_color.rgb + (1.0 - select) * fg_color.rgb;\\n\\n if( border_distance < 0.0)\\n frag_color = fg_color;\\n else if( signed_distance < 0.0 ) {\\n frag_color = mix(bg_color, fg_color, sqrt(alpha));\\n } else {\\n if( abs(signed_distance) < (linewidth/2.0 + antialias) ) {\\n frag_color = vec4(fg_color.rgb, fg_color.a * alpha);\\n } else {\\n discard;\\n }\\n }\\n return frag_color;\\n}\\n\\nvoid main()\\n{\\n vec2 P = gl_PointCoord.xy - vec2(0.5, 0.5);\\n P = vec2(v_rotation.x*P.x - v_rotation.y*P.y,\\n v_rotation.y*P.x + v_rotation.x*P.y);\\n float point_size = SQRT_2*v_size + 2.0 * (v_linewidth + 1.5*u_antialias);\\n float distance = marker(P*point_size, v_size);\\n gl_FragColor = outline(distance, v_linewidth, u_antialias, v_fg_color, v_bg_color);\\n}\\n'},\n", " function _(e,l,i,s,t){s();const _=e(287);class p extends _.EllipseOvalView{}i.EllipseView=p,p.__name__=\"EllipseView\";class n extends _.EllipseOval{constructor(e){super(e)}static init_Ellipse(){this.prototype.default_view=p}}i.Ellipse=n,n.__name__=\"Ellipse\",n.init_Ellipse()},\n", " function _(t,s,i,e,h){e();const r=t(1),a=t(288),n=r.__importStar(t(107)),l=t(24),o=t(59),_=r.__importStar(t(18));class d extends a.CenterRotatableView{_map_data(){\"data\"==this.model.properties.width.units?this.sw=this.sdist(this.renderer.xscale,this._x,this.width,\"center\"):this.sw=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=l.to_screen(this.height)}_render(t,s,i){const{sx:e,sy:h,sw:r,sh:a,angle:n}=null!=i?i:this;for(const i of s){const s=e[i],l=h[i],o=r[i],_=a[i],d=n.get(i);isNaN(s+l+o+_+d)||(t.beginPath(),t.ellipse(s,l,o/2,_/2,d,0,2*Math.PI),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(t,i),t.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(t,i),t.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(t,i),t.stroke()))}}_hit_point(t){let s,i,e,h,r,a,l,_,d;const{sx:c,sy:w}=t,x=this.renderer.xscale.invert(c),p=this.renderer.yscale.invert(w);\"data\"==this.model.properties.width.units?(s=x-this.max_width,i=x+this.max_width):(a=c-this.max_width,l=c+this.max_width,[s,i]=this.renderer.xscale.r_invert(a,l)),\"data\"==this.model.properties.height.units?(e=p-this.max_height,h=p+this.max_height):(_=w-this.max_height,d=w+this.max_height,[e,h]=this.renderer.yscale.r_invert(_,d));const m=this.index.indices({x0:s,x1:i,y0:e,y1:h}),v=[];for(const t of m)r=n.point_in_ellipse(c,w,this.angle.get(t),this.sh[t]/2,this.sw[t]/2,this.sx[t],this.sy[t]),r&&v.push(t);return new o.Selection({indices:v})}draw_legend_for_index(t,{x0:s,y0:i,x1:e,y1:h},r){const a=r+1,n=new Array(a);n[r]=(s+e)/2;const l=new Array(a);l[r]=(i+h)/2;const o=this.sw[r]/this.sh[r],d=.8*Math.min(Math.abs(e-s),Math.abs(h-i)),c=new Array(a),w=new Array(a);o>1?(c[r]=d,w[r]=d/o):(c[r]=d*o,w[r]=d);const x=new _.UniformScalar(0,a);this._render(t,[r],{sx:n,sy:l,sw:c,sh:w,angle:x})}}i.EllipseOvalView=d,d.__name__=\"EllipseOvalView\";class c extends a.CenterRotatable{constructor(t){super(t)}}i.EllipseOval=c,c.__name__=\"EllipseOval\"},\n", " function _(t,e,i,a,n){a();const s=t(1),h=t(64),r=t(48),o=s.__importStar(t(18));class _ 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:t,x1:e,y0:i,y1:a}){const{max_w2:n,max_h2:s}=this;return{x0:t-n,x1:e+n,y0:i-s,y1:a+s}}}i.CenterRotatableView=_,_.__name__=\"CenterRotatableView\";class l extends h.XYGlyph{constructor(t){super(t)}static init_CenterRotatable(){this.mixins([r.LineVector,r.FillVector,r.HatchVector]),this.define((({})=>({angle:[o.AngleSpec,0],width:[o.DistanceSpec,{field:\"width\"}],height:[o.DistanceSpec,{field:\"height\"}]})))}}i.CenterRotatable=l,l.__name__=\"CenterRotatable\",l.init_CenterRotatable()},\n", " function _(t,e,s,i,h){i();const r=t(1),a=t(290),n=t(24),_=r.__importStar(t(18));class o extends a.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 n.ScreenArray(t),this.sbottom=new n.ScreenArray(t);for(let e=0;e({left:[_.XCoordinateSpec,{value:0}],y:[_.YCoordinateSpec,{field:\"y\"}],height:[_.NumberSpec,{value:1}],right:[_.XCoordinateSpec,{field:\"right\"}]})))}}s.HBar=c,c.__name__=\"HBar\",c.init_HBar()},\n", " function _(t,e,s,i,r){i();const n=t(48),o=t(98),a=t(106),h=t(59);class c extends o.GlyphView{get_anchor_point(t,e,s){const i=Math.min(this.sleft[e],this.sright[e]),r=Math.max(this.sright[e],this.sleft[e]),n=Math.min(this.stop[e],this.sbottom[e]),o=Math.max(this.sbottom[e],this.stop[e]);switch(t){case\"top_left\":return{x:i,y:n};case\"top\":case\"top_center\":return{x:(i+r)/2,y:n};case\"top_right\":return{x:r,y:n};case\"bottom_left\":return{x:i,y:o};case\"bottom\":case\"bottom_center\":return{x:(i+r)/2,y:o};case\"bottom_right\":return{x:r,y:o};case\"left\":case\"center_left\":return{x:i,y:(n+o)/2};case\"center\":case\"center_center\":return{x:(i+r)/2,y:(n+o)/2};case\"right\":case\"center_right\":return{x:r,y:(n+o)/2}}}_index_data(t){const{min:e,max:s}=Math,{data_size:i}=this;for(let r=0;r({r:[c.NumberSpec,{field:\"r\"}],q:[c.NumberSpec,{field:\"q\"}],scale:[c.NumberSpec,1],size:[e,1],aspect_scale:[e,1],orientation:[h.HexTileOrientation,\"pointytop\"]}))),this.override({line_color:null})}}s.HexTile=y,y.__name__=\"HexTile\",y.init_HexTile()},\n", " function _(e,a,t,_,s){_();const i=e(293),n=e(203),r=e(214);class o extends i.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=o,o.__name__=\"ImageView\";class m extends i.ImageBase{constructor(e){super(e)}static init_Image(){this.prototype.default_view=o,this.define((({Ref:e})=>({color_mapper:[e(n.ColorMapper),()=>new r.LinearColorMapper({palette:[\"#000000\",\"#252525\",\"#525252\",\"#737373\",\"#969696\",\"#bdbdbd\",\"#d9d9d9\",\"#f0f0f0\",\"#ffffff\"]})]})))}}t.Image=m,m.__name__=\"Image\",m.init_Image()},\n", " function _(e,t,i,s,a){s();const h=e(1),n=e(64),r=e(24),_=h.__importStar(e(18)),d=e(59),l=e(9),g=e(29),o=e(11);class c extends n.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}=null!=i?i:this,_=e.getImageSmoothingEnabled();e.setImageSmoothingEnabled(!1),e.globalAlpha=this.model.global_alpha;for(const i of t){const t=s[i],_=a[i],d=h[i],l=n[i],g=r[i];if(null==t||isNaN(_+d+l+g))continue;const o=d;e.translate(0,o),e.scale(1,-1),e.translate(0,-o),e.drawImage(t,0|_,0|d,l,g),e.translate(0,o),e.scale(1,-1),e.translate(0,-o)}e.setImageSmoothingEnabled(_)}_set_data(e){this._set_width_heigh_data();for(let t=0,i=this.image.length;t({image:[_.NDArraySpec,{field:\"image\"}],dw:[_.DistanceSpec,{field:\"dw\"}],dh:[_.DistanceSpec,{field:\"dh\"}],dilate:[e,!1],global_alpha:[t,1]})))}}i.ImageBase=m,m.__name__=\"ImageBase\",m.init_ImageBase()},\n", " function _(e,a,t,_,i){_();const n=e(293),s=e(8);class r extends n.ImageBaseView{_flat_img_to_buf8(e){let a;return a=s.isArray(e)?new Uint32Array(e):e,new Uint8ClampedArray(a.buffer)}}t.ImageRGBAView=r,r.__name__=\"ImageRGBAView\";class m extends n.ImageBase{constructor(e){super(e)}static init_ImageRGBA(){this.prototype.default_view=r}}t.ImageRGBA=m,m.__name__=\"ImageRGBA\",m.init_ImageRGBA()},\n", " function _(e,t,s,r,a){r();const i=e(1),n=e(64),o=e(24),c=e(20),_=i.__importStar(e(18)),h=e(12),l=e(296);class d extends n.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,c=new o.ScreenArray(a?2*n:n),_=new o.ScreenArray(i?2*n:n),{anchor:d}=this.model;function m(e,t){switch(d){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(d){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:[_.StringSpec,{field:\"url\"}],anchor:[c.Anchor,\"top_left\"],global_alpha:[s,1],angle:[_.AngleSpec,0],w:[_.NullDistanceSpec,null],h:[_.NullDistanceSpec,null],dilate:[e,!1],retry_attempts:[t,0],retry_timeout:[t,0]})))}}s.ImageURL=m,m.__name__=\"ImageURL\",m.init_ImageURL()},\n", " function _(i,e,t,s,o){s();const a=i(19);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,s,e,i,n){i();const o=t(1),l=t(101),r=t(98),h=t(106),_=t(12),a=t(12),c=t(48),d=o.__importStar(t(107)),x=o.__importStar(t(18)),y=t(59),f=t(11);class g extends r.GlyphView{_project_data(){}_index_data(t){const{min:s,max:e}=Math,{data_size:i}=this;for(let n=0;n1&&c.length>1)for(let e=1,i=n.length;e1){let l=!1;for(let t=1;t({xs:[x.XCoordinateSeqSeqSeqSpec,{field:\"xs\"}],ys:[x.YCoordinateSeqSeqSeqSpec,{field:\"ys\"}]}))),this.mixins([c.LineVector,c.FillVector,c.HatchVector])}}e.MultiPolygons=p,p.__name__=\"MultiPolygons\",p.init_MultiPolygons()},\n", " function _(a,t,e,l,s){l();const _=a(287),i=a(12);class n extends _.EllipseOvalView{_map_data(){super._map_data(),i.mul(this.sw,.75)}}e.OvalView=n,n.__name__=\"OvalView\";class v extends _.EllipseOval{constructor(a){super(a)}static init_Oval(){this.prototype.default_view=n}}e.Oval=v,v.__name__=\"Oval\",v.init_Oval()},\n", " function _(t,e,i,o,s){o();const r=t(1),_=t(290),d=r.__importStar(t(18));class n 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]]}}i.QuadView=n,n.__name__=\"QuadView\";class a extends _.Box{constructor(t){super(t)}static init_Quad(){this.prototype.default_view=n,this.define((({})=>({right:[d.XCoordinateSpec,{field:\"right\"}],bottom:[d.YCoordinateSpec,{field:\"bottom\"}],left:[d.XCoordinateSpec,{field:\"left\"}],top:[d.YCoordinateSpec,{field:\"top\"}]})))}}i.Quad=a,a.__name__=\"Quad\",a.init_Quad()},\n", " function _(e,t,i,s,n){s();const a=e(1),c=e(48),o=e(65),r=e(98),_=e(106),d=a.__importStar(e(18));function l(e,t,i){if(t==(e+i)/2)return[e,i];{const s=(e-t)/(e-2*t+i),n=e*(1-s)**2+2*t*(1-s)*s+i*s**2;return[Math.min(e,i,n),Math.max(e,i,n)]}}class x extends r.GlyphView{_project_data(){o.inplace.project_xy(this._x0,this._y0),o.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{_x0:t,_x1:i,_y0:s,_y1:n,_cx:a,_cy:c,data_size:o}=this;for(let r=0;r({x0:[d.XCoordinateSpec,{field:\"x0\"}],y0:[d.YCoordinateSpec,{field:\"y0\"}],x1:[d.XCoordinateSpec,{field:\"x1\"}],y1:[d.YCoordinateSpec,{field:\"y1\"}],cx:[d.XCoordinateSpec,{field:\"cx\"}],cy:[d.YCoordinateSpec,{field:\"cy\"}]}))),this.mixins(c.LineVector)}}i.Quadratic=y,y.__name__=\"Quadratic\",y.init_Quadratic()},\n", " function _(e,t,s,i,n){i();const a=e(1),l=e(64),h=e(106),r=e(48),o=e(24),_=a.__importStar(e(18));class c extends l.XYGlyphView{_map_data(){\"data\"==this.model.properties.length.units?this.slength=this.sdist(this.renderer.xscale,this._x,this.length):this.slength=o.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:[_.DistanceSpec,0],angle:[_.AngleSpec,0]})))}}s.Ray=g,g.__name__=\"Ray\",g.init_Ray()},\n", " function _(t,s,e,i,h){i();const r=t(288),n=t(106),a=t(24),o=t(12),l=t(59);class _ extends r.CenterRotatableView{_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=a.to_screen(this.width);const t=this.sx.length;this.sx0=new a.ScreenArray(t);for(let s=0;s({dilate:[t,!1]})))}}e.Rect=c,c.__name__=\"Rect\",c.init_Rect()},\n", " function _(e,t,r,s,i){s();const a=e(1),n=e(304),_=e(305),l=e(283),c=a.__importStar(e(18));class o extends n.MarkerView{_init_webgl(){const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e){const t=new Set(this.marker);if(1==t.size){const[r]=[...t];if(l.MarkerGL.is_supported(r)){const{glglyph:t}=this;if(null==t||t.marker_type!=r)return void(this.glglyph=new l.MarkerGL(e.gl,this,r))}}}delete this.glglyph}_set_data(e){super._set_data(e),this._init_webgl()}_render(e,t,r){const{sx:s,sy:i,size:a,angle:n,marker:l}=null!=r?r:this;for(const r of t){const t=s[r],c=i[r],o=a.get(r),g=n.get(r),h=l.get(r);if(isNaN(t+c+o+g)||null==h)continue;const d=o/2;e.beginPath(),e.translate(t,c),g&&e.rotate(g),_.marker_funcs[h](e,r,d,this.visuals),g&&e.rotate(-g),e.translate(-t,-c)}}draw_legend_for_index(e,{x0:t,x1:r,y0:s,y1:i},a){const n=a+1,_=this.marker.get(a),l=Object.assign(Object.assign({},this._get_legend_args({x0:t,x1:r,y0:s,y1:i},a)),{marker:new c.UniformScalar(_,n)});this._render(e,[a],l)}}r.ScatterView=o,o.__name__=\"ScatterView\";class g extends n.Marker{constructor(e){super(e)}static init_Scatter(){this.prototype.default_view=o,this.define((()=>({marker:[c.MarkerSpec,{value:\"circle\"}]})))}}r.Scatter=g,g.__name__=\"Scatter\",g.init_Scatter()},\n", " function _(e,t,s,i,n){i();const r=e(1),a=e(64),c=e(48),_=r.__importStar(e(107)),o=r.__importStar(e(18)),h=e(9),l=e(59);class x extends a.XYGlyphView{_render(e,t,s){const{sx:i,sy:n,size:r,angle:a}=null!=s?s:this;for(const s of t){const t=i[s],c=n[s],_=r.get(s),o=a.get(s);if(isNaN(t+c+_+o))continue;const h=_/2;e.beginPath(),e.translate(t,c),o&&e.rotate(o),this._render_one(e,s,h,this.visuals),o&&e.rotate(-o),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))),i=t.widen(this.max_size).map((e=>this.renderer.yscale.invert(e)));return this.index.indices({x0:s.start,x1:s.end,y0:i.start,y1:i.end})}_hit_point(e){const{sx:t,sy:s}=e,{max_size:i}=this,{hit_dilation:n}=this.model,r=t-i*n,a=t+i*n,[c,_]=this.renderer.xscale.r_invert(r,a),o=s-i*n,h=s+i*n,[x,d]=this.renderer.yscale.r_invert(o,h),y=this.index.indices({x0:c,x1:_,y0:x,y1:d}),g=[];for(const e of y){const i=this.size.get(e)/2*n;Math.abs(this.sx[e]-t)<=i&&Math.abs(this.sy[e]-s)<=i&&g.push(e)}return new l.Selection({indices:g})}_hit_span(e){const{sx:t,sy:s}=e,i=this.bounds(),n=this.max_size/2;let r,a,c,_;if(\"h\"==e.direction){c=i.y0,_=i.y1;const e=t-n,s=t+n;[r,a]=this.renderer.xscale.r_invert(e,s)}else{r=i.x0,a=i.x1;const e=s-n,t=s+n;[c,_]=this.renderer.yscale.r_invert(e,t)}const o=[...this.index.indices({x0:r,x1:a,y0:c,y1:_})];return new l.Selection({indices:o})}_hit_rect(e){const{sx0:t,sx1:s,sy0:i,sy1:n}=e,[r,a]=this.renderer.xscale.r_invert(t,s),[c,_]=this.renderer.yscale.r_invert(i,n),o=[...this.index.indices({x0:r,x1:a,y0:c,y1:_})];return new l.Selection({indices:o})}_hit_poly(e){const{sx:t,sy:s}=e,i=h.range(0,this.sx.length),n=[];for(let e=0,r=i.length;e({size:[o.ScreenDistanceSpec,{value:4}],angle:[o.AngleSpec,0],hit_dilation:[e,1]})))}}s.Marker=d,d.__name__=\"Marker\",d.init_Marker()},\n", " function _(t,e,i,o,l){o();const n=Math.sqrt(3),c=Math.sqrt(5),r=(c+1)/4,s=Math.sqrt((5-c)/8),f=(c-1)/4,a=Math.sqrt((5+c)/8);function h(t,e){t.rotate(Math.PI/4),d(t,e),t.rotate(-Math.PI/4)}function v(t,e){const i=e*n,o=i/3;t.moveTo(-i/2,-o),t.lineTo(0,0),t.lineTo(i/2,-o),t.lineTo(0,0),t.lineTo(0,e)}function d(t,e){t.moveTo(0,e),t.lineTo(0,-e),t.moveTo(-e,0),t.lineTo(e,0)}function _(t,e){t.moveTo(0,e),t.lineTo(e/1.5,0),t.lineTo(0,-e),t.lineTo(-e/1.5,0),t.closePath()}function u(t,e){const i=e*n,o=i/3;t.moveTo(-e,o),t.lineTo(e,o),t.lineTo(0,o-i),t.closePath()}function z(t,e,i,o){t.arc(0,0,i,0,2*Math.PI,!1),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())}function T(t,e,i,o){_(t,i),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())}function k(t,e,i,o){!function(t,e){t.beginPath(),t.arc(0,0,e/4,0,2*Math.PI,!1),t.closePath()}(t,i),o.line.set_vectorize(t,e),t.fillStyle=t.strokeStyle,t.fill()}function P(t,e,i,o){!function(t,e){const i=e/2,o=n*i;t.moveTo(e,0),t.lineTo(i,-o),t.lineTo(-i,-o),t.lineTo(-e,0),t.lineTo(-i,o),t.lineTo(i,o),t.closePath()}(t,i),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())}function m(t,e,i,o){const l=2*i;t.rect(-i,-i,l,l),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())}function q(t,e,i,o){!function(t,e){const i=Math.sqrt(5-2*c)*e;t.moveTo(0,-e),t.lineTo(i*f,i*a-e),t.lineTo(i*(1+f),i*a-e),t.lineTo(i*(1+f-r),i*(a+s)-e),t.lineTo(i*(1+2*f-r),i*(2*a+s)-e),t.lineTo(0,2*i*a-e),t.lineTo(-i*(1+2*f-r),i*(2*a+s)-e),t.lineTo(-i*(1+f-r),i*(a+s)-e),t.lineTo(-i*(1+f),i*a-e),t.lineTo(-i*f,i*a-e),t.closePath()}(t,i),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())}function M(t,e,i,o){u(t,i),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())}i.marker_funcs={asterisk:function(t,e,i,o){d(t,i),h(t,i),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},circle:z,circle_cross:function(t,e,i,o){t.arc(0,0,i,0,2*Math.PI,!1),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),d(t,i),t.stroke())},circle_dot:function(t,e,i,o){z(t,e,i,o),k(t,e,i,o)},circle_y:function(t,e,i,o){t.arc(0,0,i,0,2*Math.PI,!1),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),v(t,i),t.stroke())},circle_x:function(t,e,i,o){t.arc(0,0,i,0,2*Math.PI,!1),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),h(t,i),t.stroke())},cross:function(t,e,i,o){d(t,i),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},diamond:T,diamond_dot:function(t,e,i,o){T(t,e,i,o),k(t,e,i,o)},diamond_cross:function(t,e,i,o){_(t,i),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.moveTo(0,i),t.lineTo(0,-i),t.moveTo(-i/1.5,0),t.lineTo(i/1.5,0),t.stroke())},dot:k,hex:P,hex_dot:function(t,e,i,o){P(t,e,i,o),k(t,e,i,o)},inverted_triangle:function(t,e,i,o){t.rotate(Math.PI),u(t,i),t.rotate(-Math.PI),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},plus:function(t,e,i,o){const l=3*i/8,n=[l,l,i,i,l,l,-l,-l,-i,-i,-l,-l],c=[i,l,l,-l,-l,-i,-i,-l,-l,l,l,i];t.beginPath();for(let e=0;e<12;e++)t.lineTo(n[e],c[e]);t.closePath(),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},square:m,square_cross:function(t,e,i,o){const l=2*i;t.rect(-i,-i,l,l),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),d(t,i),t.stroke())},square_dot:function(t,e,i,o){m(t,e,i,o),k(t,e,i,o)},square_pin:function(t,e,i,o){const l=3*i/8;t.moveTo(-i,-i),t.quadraticCurveTo(0,-l,i,-i),t.quadraticCurveTo(l,0,i,i),t.quadraticCurveTo(0,l,-i,i),t.quadraticCurveTo(-l,0,-i,-i),t.closePath(),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},square_x:function(t,e,i,o){const l=2*i;t.rect(-i,-i,l,l),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.moveTo(-i,i),t.lineTo(i,-i),t.moveTo(-i,-i),t.lineTo(i,i),t.stroke())},star:q,star_dot:function(t,e,i,o){q(t,e,i,o),k(t,e,i,o)},triangle:M,triangle_dot:function(t,e,i,o){M(t,e,i,o),k(t,e,i,o)},triangle_pin:function(t,e,i,o){const l=i*n,c=l/3,r=3*c/8;t.moveTo(-i,c),t.quadraticCurveTo(0,r,i,c),t.quadraticCurveTo(n*r/2,r/2,0,c-l),t.quadraticCurveTo(-n*r/2,r/2,-i,c),t.closePath(),o.fill.doit&&(o.fill.set_vectorize(t,e),t.fill()),o.hatch.doit&&(o.hatch.set_vectorize(t,e),t.fill()),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},dash:function(t,e,i,o){!function(t,e){t.moveTo(-e,0),t.lineTo(e,0)}(t,i),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},x:function(t,e,i,o){h(t,i),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())},y:function(t,e,i,o){v(t,i),o.line.doit&&(o.line.set_vectorize(t,e),t.stroke())}}},\n", " function _(e,t,s,i,n){i();const r=e(1),_=r.__importStar(e(107)),o=r.__importStar(e(18)),h=e(48),a=e(65),c=e(98),d=e(106),x=e(59);class y extends c.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:_,data_size:o}=this;for(let h=0;h({x0:[o.XCoordinateSpec,{field:\"x0\"}],y0:[o.YCoordinateSpec,{field:\"y0\"}],x1:[o.XCoordinateSpec,{field:\"x1\"}],y1:[o.YCoordinateSpec,{field:\"y1\"}]}))),this.mixins(h.LineVector)}}s.Segment=l,l.__name__=\"Segment\",l.init_Segment()},\n", " function _(t,e,s,i,n){i();const _=t(1),l=t(64),o=_.__importStar(t(48)),a=t(308);class c extends l.XYGlyphView{_set_data(){const{tension:t,closed:e}=this.model;[this._xt,this._yt]=a.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;this.visuals.line.set_value(t);const _=i.length;for(let e=0;e<_;e++)0!=e?isNaN(i[e])||isNaN(n[e])?(t.stroke(),t.beginPath()):t.lineTo(i[e],n[e]):(t.beginPath(),t.moveTo(i[e],n[e]));t.stroke()}}s.SplineView=c,c.__name__=\"SplineView\";class h extends l.XYGlyph{constructor(t){super(t)}static init_Spline(){this.prototype.default_view=c,this.mixins(o.LineScalar),this.define((({Boolean:t,Number:e})=>({tension:[e,.5],closed:[t,!1]})))}}s.Spline=h,h.__name__=\"Spline\",h.init_Spline()},\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){l.assert(n.length==t.length);const r=n.length,f=s?r+1:r,w=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,a),e.lineTo(r,_)):(e.beginPath(),e.moveTo(n[i],s[i]),o=!0),l=i}e.lineTo(n[r-1],s[r-1]),e.stroke()}}draw_legend_for_index(e,t,i){r.generic_line_scalar_legend(this.visuals,e,t)}}i.StepView=c,c.__name__=\"StepView\";class d extends l.XYGlyph{constructor(e){super(e)}static init_Step(){this.prototype.default_view=c,this.mixins(a.LineScalar),this.define((()=>({mode:[_.StepMode,\"before\"]})))}}i.Step=d,d.__name__=\"Step\",d.init_Step()},\n", " function _(t,e,s,i,n){i();const o=t(1),_=t(64),h=t(48),l=o.__importStar(t(107)),r=o.__importStar(t(18)),a=t(143),c=t(11),x=t(59);class u extends _.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]=[],c=i[s],x=n[s],u=o.get(s),f=_.get(s),p=h.get(s),g=l.get(s);if(!isNaN(c+x+u+f+p)&&null!=g&&this.visuals.text.doit){const i=`${g}`;t.save(),t.translate(c+u,x+f),t.rotate(p),this.visuals.text.set_vectorize(t,s);const n=this.visuals.text.font_value(s),{height:o}=a.font_metrics(n),_=this.text_line_height.get(s)*o;if(-1==i.indexOf(\"\\n\")){t.fillText(i,0,0);const s=c+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=c+u,n=l+x+f,o=t.measureText(s).width,[h,a]=this._text_bounds(i,n,o,_);e.push(h),r.push(a),l+=_}}t.restore()}}}_hit_point(t){const{sx:e,sy:s}=t,i=[];for(let t=0;t({text:[r.NullStringSpec,{field:\"text\"}],angle:[r.AngleSpec,0],x_offset:[r.NumberSpec,0],y_offset:[r.NumberSpec,0]})))}}s.Text=f,f.__name__=\"Text\",f.init_Text()},\n", " function _(t,s,e,i,r){i();const h=t(1),o=t(290),a=t(24),n=h.__importStar(t(18));class _ extends o.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 a.ScreenArray(t),this.sright=new a.ScreenArray(t);for(let s=0;s({x:[n.XCoordinateSpec,{field:\"x\"}],bottom:[n.YCoordinateSpec,{value:0}],width:[n.NumberSpec,{value:1}],top:[n.YCoordinateSpec,{field:\"top\"}]})))}}e.VBar=c,c.__name__=\"VBar\",c.init_VBar()},\n", " function _(e,t,s,i,n){i();const r=e(1),a=e(64),l=e(106),c=e(48),d=e(24),h=e(20),o=r.__importStar(e(18)),_=e(10),u=e(59);class g extends a.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius):this.sradius=d.to_screen(this.radius)}_render(e,t,s){const{sx:i,sy:n,sradius:r,start_angle:a,end_angle:l}=null!=s?s:this,c=\"anticlock\"==this.model.direction;for(const s of t){const t=i[s],d=n[s],h=r[s],o=a.get(s),_=l.get(s);isNaN(t+d+h+o+_)||(e.beginPath(),e.arc(t,d,h,o,_,c),e.lineTo(t,d),e.closePath(),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,s),e.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(e,s),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,s),e.stroke()))}}_hit_point(e){let t,s,i,n,r,a,l,c,d;const{sx:h,sy:o}=e,g=this.renderer.xscale.invert(h),p=this.renderer.yscale.invert(o),x=2*this.max_radius;\"data\"===this.model.properties.radius.units?(a=g-x,l=g+x,c=p-x,d=p+x):(s=h-x,i=h+x,[a,l]=this.renderer.xscale.r_invert(s,i),n=o-x,r=o+x,[c,d]=this.renderer.yscale.r_invert(n,r));const f=[];for(const e of this.index.indices({x0:a,x1:l,y0:c,y1:d})){const a=this.sradius[e]**2;[s,i]=this.renderer.xscale.r_compute(g,this._x[e]),[n,r]=this.renderer.yscale.r_compute(p,this._y[e]),t=(s-i)**2+(n-r)**2,t<=a&&f.push(e)}const v=\"anticlock\"==this.model.direction,y=[];for(const e of f){const t=Math.atan2(o-this.sy[e],h-this.sx[e]);_.angle_between(-t,-this.start_angle.get(e),-this.end_angle.get(e),v)&&y.push(e)}return new u.Selection({indices:y})}draw_legend_for_index(e,t,s){l.generic_area_vector_legend(this.visuals,e,t,s)}scenterxy(e){const t=this.sradius[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.WedgeView=g,g.__name__=\"WedgeView\";class p extends a.XYGlyph{constructor(e){super(e)}static init_Wedge(){this.prototype.default_view=g,this.mixins([c.LineVector,c.FillVector,c.HatchVector]),this.define((({})=>({direction:[h.Direction,\"anticlock\"],radius:[o.DistanceSpec,{field:\"radius\"}],start_angle:[o.AngleSpec,{field:\"start_angle\"}],end_angle:[o.AngleSpec,{field:\"end_angle\"}]})))}}s.Wedge=p,p.__name__=\"Wedge\",p.init_Wedge()},\n", " function _(t,_,r,o,a){o();const e=t(1);e.__exportStar(t(126),r),e.__exportStar(t(125),r),e.__exportStar(t(314),r)},\n", " function _(t,a,o,r,e){r();const n=t(125);class l extends n.LayoutProvider{constructor(t){super(t)}static init_StaticLayoutProvider(){this.define((({Number:t,Tuple:a,Dict:o})=>({graph_layout:[o(a(t,t)),{}]})))}get_node_coordinates(t){var a;const o=null!==(a=t.data.index)&&void 0!==a?a:[],r=o.length,e=new Float64Array(r),n=new Float64Array(r);for(let t=0;tthis.request_render()))}_draw_regions(i){if(!this.visuals.band_fill.doit&&!this.visuals.band_hatch.doit)return;const[e,t]=this.grid_coords(\"major\",!1);for(let s=0;st[1]&&(n=t[1]);else{[s,n]=t;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,n]=i.computed_bounds)}return[s,n]}grid_coords(i,e=!0){const t=this.model.dimension,s=(t+1)%2,[n,r]=this.ranges();let[o,d]=this.computed_bounds();[o,d]=[Math.min(o,d),Math.max(o,d)];const l=[[],[]],_=this.model.get_ticker();if(null==_)return l;const a=_.get_ticks(o,d,n,r.min)[i],h=n.min,u=n.max,c=r.min,m=r.max;e||(a[0]!=h&&a.splice(0,0,h),a[a.length-1]!=u&&a.push(u));for(let i=0;i({bounds:[r(n(i,i),e),\"auto\"],dimension:[t(0,1),0],axis:[d(s(o.Axis)),null],ticker:[d(s(l.Ticker)),null]}))),this.override({level:\"underlay\",band_fill_color:null,band_fill_alpha:0,grid_line_color:\"#e5e5e5\",minor_grid_line_color:null})}get_ticker(){return null!=this.ticker?this.ticker:null!=this.axis?this.axis.ticker:null}}t.Grid=u,u.__name__=\"Grid\",u.init_Grid()},\n", " function _(o,a,x,B,e){B(),e(\"Box\",o(318).Box),e(\"Column\",o(320).Column),e(\"GridBox\",o(321).GridBox),e(\"HTMLBox\",o(322).HTMLBox),e(\"LayoutDOM\",o(319).LayoutDOM),e(\"Panel\",o(323).Panel),e(\"Row\",o(324).Row),e(\"Spacer\",o(325).Spacer),e(\"Tabs\",o(326).Tabs),e(\"WidgetBox\",o(329).WidgetBox)},\n", " function _(e,n,i,t,s){t();const o=e(319);class c extends o.LayoutDOMView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.children.change,(()=>this.rebuild()))}get child_models(){return this.model.children}}i.BoxView=c,c.__name__=\"BoxView\";class r extends o.LayoutDOM{constructor(e){super(e)}static init_Box(){this.define((({Number:e,Array:n,Ref:i})=>({children:[n(i(o.LayoutDOM)),[]],spacing:[e,0]})))}}i.Box=r,r.__name__=\"Box\",r.init_Box()},\n", " function _(t,i,e,s,o){s();const l=t(53),n=t(20),h=t(43),a=t(19),r=t(8),_=t(22),d=t(143),c=t(122),u=t(240),m=t(221),p=t(44),g=t(249);class f extends u.DOMView{constructor(){super(...arguments),this._idle_notified=!1,this._offset_parent=null,this._viewport={}}get base_font_size(){const t=getComputedStyle(this.el).fontSize,i=d.parse_css_font_size(t);if(null!=i){const{value:t,unit:e}=i;if(\"px\"==e)return t}return 13}initialize(){super.initialize(),this.el.style.position=this.is_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_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 c.build_views(this._child_views,this.child_models,{parent:this})}render(){super.render(),h.empty(this.el);const{background:t}=this.model;this.el.style.backgroundColor=null!=t?_.color2css(t):\"\",h.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_root?this.layout.sizing.margin:void 0;h.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()}build(){return this.assert_root(),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(),a.logger.debug(`layout computed in ${Date.now()-t} ms`),this.notify_finished()}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}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()}_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:_,max_height:d}=this.model;null!=_&&(o.max_width=_),null!=d&&(o.max_height=d),\"auto\"==e&&null!=h&&null!=a?o.aspect=h/a:r.isNumber(e)&&(o.aspect=e);const{margin:c}=this.model;if(null!=c)if(r.isNumber(c))o.margin={top:c,right:c,bottom:c,left:c};else if(2==c.length){const[t,i]=c;o.margin={top:t,right:i,bottom:t,left:i}}else{const[t,i,e,s]=c;o.margin={top:t,right:i,bottom:e,left:s}}o.visible=this.model.visible;const{align:u}=this.model;return r.isArray(u)?[o.halign,o.valign]=u:o.halign=o.valign=u,o}_viewport_size(){return h.undisplayed(this.el,(()=>{let t=this.el;for(;t=t.parentElement;){if(t.classList.contains(p.root))continue;if(t==document.body){const{margin:{left:t,right:i,top:e,bottom:s}}=h.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}}=h.extents(t),{width:l,height:n}=t.getBoundingClientRect(),a=Math.ceil(l-i-e),r=Math.ceil(n-s-o);if(a>0||r>0)return{width:a>0?a:void 0,height:r>0?r:void 0}}return{}}))}export(t,i=!0){const e=\"png\"==t?\"canvas\":\"svg\",s=new g.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 w extends l.Model{constructor(t){super(t)}static init_LayoutDOM(){this.define((t=>{const{Boolean:i,Number:e,String:s,Auto:o,Color:l,Array:h,Tuple:a,Or:r,Null:_,Nullable:d}=t,c=a(e,e),u=a(e,e,e,e);return{width:[d(e),null],height:[d(e),null],min_width:[d(e),null],min_height:[d(e),null],max_width:[d(e),null],max_height:[d(e),null],margin:[d(r(e,c,u)),[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:[d(n.SizingMode),null],visible:[i,!0],disabled:[i,!1],align:[r(n.Align,a(n.Align,n.Align)),\"start\"],background:[d(l),null],css_classes:[h(s),[]]}}))}}e.LayoutDOM=w,w.__name__=\"LayoutDOM\",w.init_LayoutDOM()},\n", " function _(t,s,i,o,n){o();const e=t(318),l=t(223);class u extends e.BoxView{_update_layout(){const t=this.child_views.map((t=>t.layout));this.layout=new l.Column(t),this.layout.rows=this.model.rows,this.layout.spacing=[this.model.spacing,0],this.layout.set_sizing(this.box_sizing())}}i.ColumnView=u,u.__name__=\"ColumnView\";class a extends e.Box{constructor(t){super(t)}static init_Column(){this.prototype.default_view=u,this.define((({Any:t})=>({rows:[t,\"auto\"]})))}}i.Column=a,a.__name__=\"Column\",a.init_Column()},\n", " function _(t,s,i,o,e){o();const n=t(319),l=t(223);class a extends n.LayoutDOMView{connect_signals(){super.connect_signals();const{children:t,rows:s,cols:i,spacing:o}=this.model.properties;this.on_change([t,s,i,o],(()=>this.rebuild()))}get child_models(){return this.model.children.map((([t])=>t))}_update_layout(){this.layout=new l.Grid,this.layout.rows=this.model.rows,this.layout.cols=this.model.cols,this.layout.spacing=this.model.spacing;for(const[t,s,i,o,e]of this.model.children){const n=this._child_views.get(t);this.layout.items.push({layout:n.layout,row:s,col:i,row_span:o,col_span:e})}this.layout.set_sizing(this.box_sizing())}}i.GridBoxView=a,a.__name__=\"GridBoxView\";class r extends n.LayoutDOM{constructor(t){super(t)}static init_GridBox(){this.prototype.default_view=a,this.define((({Any:t,Int:s,Number:i,Tuple:o,Array:e,Ref:l,Or:a,Opt:r})=>({children:[e(o(l(n.LayoutDOM),s,s,r(s),r(s))),[]],rows:[t,\"auto\"],cols:[t,\"auto\"],spacing:[a(i,o(i,i)),0]})))}}i.GridBox=r,r.__name__=\"GridBox\",r.init_GridBox()},\n", " function _(t,e,o,s,n){s();const _=t(319),i=t(221);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,t,i,l){i();const a=e(53),o=e(319);class s extends a.Model{constructor(e){super(e)}static init_Panel(){this.define((({Boolean:e,String:n,Ref:t})=>({title:[n,\"\"],child:[t(o.LayoutDOM)],closable:[e,!1]})))}}t.Panel=s,s.__name__=\"Panel\",s.init_Panel()},\n", " function _(t,s,i,o,e){o();const n=t(318),a=t(223);class _ extends n.BoxView{_update_layout(){const t=this.child_views.map((t=>t.layout));this.layout=new a.Row(t),this.layout.cols=this.model.cols,this.layout.spacing=[0,this.model.spacing],this.layout.set_sizing(this.box_sizing())}}i.RowView=_,_.__name__=\"RowView\";class l extends n.Box{constructor(t){super(t)}static init_Row(){this.prototype.default_view=_,this.define((({Any:t})=>({cols:[t,\"auto\"]})))}}i.Row=l,l.__name__=\"Row\",l.init_Row()},\n", " function _(t,e,a,i,s){i();const _=t(319),c=t(221);class n extends _.LayoutDOMView{get child_models(){return[]}_update_layout(){this.layout=new c.LayoutItem,this.layout.set_sizing(this.box_sizing())}}a.SpacerView=n,n.__name__=\"SpacerView\";class o extends _.LayoutDOM{constructor(t){super(t)}static init_Spacer(){this.prototype.default_view=n}}a.Spacer=o,o.__name__=\"Spacer\",o.init_Spacer()},\n", " function _(e,t,s,i,l){i();const h=e(1),a=e(221),o=e(43),r=e(9),c=e(10),d=e(20),n=e(319),_=e(323),p=h.__importStar(e(327)),b=p,u=h.__importStar(e(328)),m=u,g=h.__importStar(e(243)),v=g;class w extends n.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,g.default,p.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 a.ContentBox{_measure(e){const l=o.size(s),h=o.children(i).slice(0,3).map((e=>o.size(e))),{width:a,height:c}=super._measure(e);if(t){const t=l.width+r.sum(h.map((e=>e.width)));return{width:e.width!=1/0?e.width:t,height:c}}{const t=l.height+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 c={layout:this.header,row:l,col:h},d=this.child_views.map((e=>({layout:e.layout,row:1,col:1})));this.layout=new a.Grid([c,...d]),this.layout.set_sizing(this.box_sizing())}update_position(){super.update_position(),this.header_el.style.position=\"absolute\",o.position(this.header_el,this.header.bbox);const e=this.model.tabs_location,t=\"above\"==e||\"below\"==e,s=o.size(this.scroll_el),i=o.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\",o.display(this.scroll_el),this.do_scroll(this.model.active)):(this.wrapper_el.style.maxWidth=\"\",o.undisplay(this.scroll_el))}else{const{height:e}=this.header.bbox;i.height>e?(this.wrapper_el.style.maxHeight=e-s.height+\"px\",o.display(this.scroll_el),this.do_scroll(this.model.active)):(this.wrapper_el.style.maxHeight=\"\",o.undisplay(this.scroll_el))}const{child_views:l}=this;for(const e of l)o.hide(e.el);const h=l[this.model.active];null!=h&&o.show(h.el)}render(){super.render();const{active:e}=this.model,t=this.model.tabs.map(((t,s)=>{const i=o.div({class:[b.tab,s==e?b.active:null]},t.title);if(i.addEventListener(\"click\",(e=>{e.target==e.currentTarget&&this.change_active(s)})),t.closable){const e=o.div({class:b.close});e.addEventListener(\"click\",(e=>{if(e.target==e.currentTarget){this.model.tabs=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 i}));this.headers_el=o.div({class:[b.headers]},t),this.wrapper_el=o.div({class:b.headers_wrapper},this.headers_el),this.left_el=o.div({class:[m.btn,m.btn_default],disabled:\"\"},o.div({class:[v.caret,b.left]})),this.right_el=o.div({class:[m.btn,m.btn_default]},o.div({class:[v.caret,b.right]})),this.left_el.addEventListener(\"click\",(()=>this.do_scroll(\"left\"))),this.right_el.addEventListener(\"click\",(()=>this.do_scroll(\"right\"))),this.scroll_el=o.div({class:m.btn_group},this.left_el,this.right_el);const s=this.model.tabs_location;this.header_el=o.div({class:[b.tabs_header,b[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=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=o.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=-r.sum(s.map((e=>e.width)));this.headers_el.style.left=`${e}px`}else{const e=-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=o.children(this.headers_el);for(const e of t)e.classList.remove(b.active);t[e].classList.add(b.active);const{child_views:s}=this;for(const e of s)o.hide(e.el);o.show(s[e].el)}}s.TabsView=w,w.__name__=\"TabsView\";class f extends n.LayoutDOM{constructor(e){super(e)}static init_Tabs(){this.prototype.default_view=w,this.define((({Int:e,Array:t,Ref:s})=>({tabs:[t(s(_.Panel)),[]],tabs_location:[d.Location,\"above\"],active:[e,0]})))}}s.Tabs=f,f.__name__=\"Tabs\",f.init_Tabs()},\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.default='.bk-root .bk-tabs-header{display:flex;display:-webkit-flex;flex-wrap:nowrap;-webkit-flex-wrap:nowrap;align-items:center;-webkit-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;-webkit-flex-grow:0;height:auto;padding:4px 4px;}.bk-root .bk-tabs-header .bk-headers-wrapper{flex-grow:1;-webkit-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;-webkit-flex-direction:row;}.bk-root .bk-tabs-header.bk-above .bk-headers,.bk-root .bk-tabs-header.bk-below .bk-headers{flex-direction:row;-webkit-flex-direction:row;}.bk-root .bk-tabs-header.bk-left,.bk-root .bk-tabs-header.bk-right{flex-direction:column;-webkit-flex-direction:column;}.bk-root .bk-tabs-header.bk-left .bk-headers,.bk-root .bk-tabs-header.bk-right .bk-headers{flex-direction:column;-webkit-flex-direction:column;}.bk-root .bk-tabs-header .bk-headers{position:relative;display:flex;display:-webkit-flex;flex-wrap:nowrap;-webkit-flex-wrap:nowrap;align-items:center;-webkit-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-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.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;display:-webkit-flex;flex-wrap:nowrap;-webkit-flex-wrap:nowrap;align-items:center;-webkit-align-items:center;flex-direction:row;-webkit-flex-direction:row;}.bk-root .bk-btn-group > .bk-btn{flex-grow:1;-webkit-flex-grow:1;}.bk-root .bk-btn-group > .bk-btn + .bk-btn{margin-left:-1px;}.bk-root .bk-btn-group > .bk-btn:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0;}.bk-root .bk-btn-group > .bk-btn:not(:first-child):last-child{border-bottom-left-radius:0;border-top-left-radius:0;}.bk-root .bk-btn-group > .bk-btn:not(:first-child):not(:last-child){border-radius:0;}.bk-root .bk-btn-group .bk-dropdown-toggle{flex:0 0 0;-webkit-flex:0 0 0;padding:6px 6px;}\"},\n", " function _(t,e,i,o,n){o();const _=t(320);class s extends _.ColumnView{}i.WidgetBoxView=s,s.__name__=\"WidgetBoxView\";class d extends _.Column{constructor(t){super(t)}static init_WidgetBox(){this.prototype.default_view=s}}i.WidgetBox=d,d.__name__=\"WidgetBox\",d.init_WidgetBox()},\n", " function _(p,o,t,a,n){a(),n(\"MapOptions\",p(331).MapOptions),n(\"GMapOptions\",p(331).GMapOptions),n(\"GMapPlot\",p(331).GMapPlot),n(\"Plot\",p(332).Plot)},\n", " function _(t,i,n,e,a){e();const s=t(332),o=t(53),p=t(156),_=t(337);a(\"GMapPlotView\",_.GMapPlotView);class l extends o.Model{constructor(t){super(t)}static init_MapOptions(){this.define((({Int:t,Number:i})=>({lat:[i],lng:[i],zoom:[t,12]})))}}n.MapOptions=l,l.__name__=\"MapOptions\",l.init_MapOptions();class r extends l{constructor(t){super(t)}static init_GMapOptions(){this.define((({Boolean:t,Int:i,String:n})=>({map_type:[n,\"roadmap\"],scale_control:[t,!1],styles:[n],tilt:[i,45]})))}}n.GMapOptions=r,r.__name__=\"GMapOptions\",r.init_GMapOptions();class c extends s.Plot{constructor(t){super(t),this.use_map=!0}static init_GMapPlot(){this.prototype.default_view=_.GMapPlotView,this.define((({String:t,Ref:i})=>({map_options:[i(r)],api_key:[t],api_version:[t,\"3.43\"]}))),this.override({x_range:()=>new p.Range1d,y_range:()=>new p.Range1d})}}n.GMapPlot=c,c.__name__=\"GMapPlot\",c.init_GMapPlot()},\n", " function _(e,t,i,n,r){n();const o=e(1),a=o.__importStar(e(48)),s=o.__importStar(e(18)),l=e(15),_=e(20),h=e(9),c=e(13),d=e(8),u=e(319),g=e(163),p=e(316),f=e(40),b=e(138),w=e(218),m=e(235),y=e(105),v=e(146),x=e(130),A=e(41),R=e(62),S=e(61),P=e(159),D=e(333);r(\"PlotView\",D.PlotView);class L extends u.LayoutDOM{constructor(e){super(e),this.use_map=!1}static init_Plot(){this.prototype.default_view=D.PlotView,this.mixins([[\"outline_\",a.Line],[\"background_\",a.Fill],[\"border_\",a.Fill]]),this.define((({Boolean:e,Number:t,String:i,Array:n,Dict:r,Or:o,Ref:a,Null:l,Nullable:h})=>({toolbar:[a(m.Toolbar),()=>new m.Toolbar],toolbar_location:[h(_.Location),\"right\"],toolbar_sticky:[e,!0],plot_width:[s.Alias(\"width\")],plot_height:[s.Alias(\"height\")],frame_width:[h(t),null],frame_height:[h(t),null],title:[o(a(b.Title),i,l),()=>new b.Title({text:\"\"})],title_location:[h(_.Location),\"above\"],above:[n(o(a(f.Annotation),a(g.Axis))),[]],below:[n(o(a(f.Annotation),a(g.Axis))),[]],left:[n(o(a(f.Annotation),a(g.Axis))),[]],right:[n(o(a(f.Annotation),a(g.Axis))),[]],center:[n(o(a(f.Annotation),a(p.Grid))),[]],renderers:[n(a(A.Renderer)),[]],x_range:[a(y.Range),()=>new P.DataRange1d],extra_x_ranges:[r(a(y.Range)),{}],y_range:[a(y.Range),()=>new P.DataRange1d],extra_y_ranges:[r(a(y.Range)),{}],x_scale:[a(v.Scale),()=>new w.LinearScale],y_scale:[a(v.Scale),()=>new w.LinearScale],lod_factor:[t,10],lod_interval:[t,300],lod_threshold:[h(t),2e3],lod_timeout:[t,500],hidpi:[e,!0],output_backend:[_.OutputBackend,\"canvas\"],min_border:[h(t),5],min_border_top:[h(t),null],min_border_left:[h(t),null],min_border_bottom:[h(t),null],min_border_right:[h(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:[_.ResetPolicy,\"standard\"]}))),this.override({width:600,height:600,outline_line_color:\"#e5e5e5\",border_fill_color:\"#ffffff\",background_fill_color:\"#ffffff\"})}_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 l.Signal0(this,\"reset\");for(const e of c.values(this.extra_x_ranges).concat(this.x_range)){let t=e.plots;d.isArray(t)&&(t=t.concat(this),e.setv({plots:t},{silent:!0}))}for(const e of c.values(this.extra_y_ranges).concat(this.y_range)){let t=e.plots;d.isArray(t)&&(t=t.concat(this),e.setv({plots:t},{silent:!0}))}}add_layout(e,t=\"center\"){const i=this.properties[t].get_value();this.setv({[t]:[...i,e]})}remove_layout(e){const t=t=>{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 x.ColumnDataSource,i={}){const n=new S.GlyphRenderer(Object.assign(Object.assign({},i),{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:i,right:n}=this;return h.concat([e,t,i,n])}}i.Plot=L,L.__name__=\"Plot\",L.init_Plot()},\n", " function _(e,t,i,s,a){s();const n=e(1),o=e(144),l=e(262),r=e(319),_=e(40),h=e(138),d=e(163),u=e(234),c=e(264),p=e(122),v=e(45),b=e(19),g=e(334),m=e(8),w=e(9),y=e(249),f=e(222),x=e(225),z=e(223),k=e(140),q=e(99),M=e(335),V=e(336),P=e(28);class R extends r.LayoutDOMView{constructor(){super(...arguments),this._outer_bbox=new q.BBox,this._inner_bbox=new q.BBox,this._needs_paint=!0,this._needs_layout=!1,this._invalidated_painters=new Set,this._invalidate_all=!0}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\")}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(m.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(){p.remove_views(this.renderer_views),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._range_manager=new M.RangeManager(this),this._state_manager=new V.StateManager(this,this._initial_state),this.throttled_paint=g.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 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),b.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 x.BorderLayout,this.layout.set_sizing(this.box_sizing());const n=w.copy(this.model.above),o=w.copy(this.model.below),l=w.copy(this.model.left),r=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:b}=this.model;if(null!=v&&null!=b){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 k.Panel(e),null===(i=s.update_layout)||void 0===i||i.call(s),s.layout},y=(e,t)=>{const i=\"above\"==e||\"below\"==e,s=[];for(const a of t)if(m.isArray(a)){const t=a.map((t=>{const s=g(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 z.Row(t),n.set_sizing({width_policy:\"max\",height_policy:\"min\"})):(n=new z.Column(t),n.set_sizing({width_policy:\"min\",height_policy:\"max\"})),n.absolute=!0,s.push(n)}else s.push(g(e,a));return s},q=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:q,top:null!==(i=this.model.min_border_top)&&void 0!==i?i:q,right:null!==(s=this.model.min_border_right)&&void 0!==s?s:q,bottom:null!==(a=this.model.min_border_bottom)&&void 0!==a?a:q};const M=new f.NodeLayout,V=new f.VStack,P=new f.VStack,R=new f.HStack,O=new f.HStack;M.absolute=!0,V.absolute=!0,P.absolute=!0,R.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:S,frame_height:j}=this.model;M.set_sizing(Object.assign(Object.assign({},null!=S?{width_policy:\"fixed\",width:S}:{width_policy:\"fit\"}),null!=j?{height_policy:\"fixed\",height:j}:{height_policy:\"fit\"})),M.on_resize((e=>this.frame.set_geometry(e))),V.children=w.reversed(y(\"above\",n)),P.children=y(\"below\",o),R.children=w.reversed(y(\"left\",l)),O.children=y(\"right\",r),V.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),P.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),R.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=V,this.layout.bottom_panel=P,this.layout.left_panel=R,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)}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 p.build_views(this.renderer_views,this.computed_renderers,{parent:this})}async build_tool_views(){const e=this.model.toolbar.tools;(await 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(){var e;if(this.is_paused||!this.model.visible)return;b.logger.trace(`PlotView.paint() for ${this.model.id}`);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||P.settings.wireframe)&&(o.prepare(),this._paint_levels(o.ctx,\"overlay\",a,!1),P.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 y.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=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=R,R.__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,s,a){s();const o=t(159),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:s}=this.frame;if(null==t){for(const[,t]of e)t.reset();for(const[,t]of s)t.reset();this.update_dataranges()}else{const a=[];for(const[n,s]of e)a.push([s,t.xrs.get(n)]);for(const[n,e]of s)a.push([e,t.yrs.get(n)]);(null==n?void 0:n.scrolling)&&this._update_ranges_together(a),this._update_ranges_individually(a,n)}}reset(){this.update(null)}update_dataranges(){const t=new Map,n=new Map;let e=!1;for(const[,t]of this.frame.x_ranges)t instanceof o.DataRange1d&&\"log\"==t.scale_hint&&(e=!0);for(const[,t]of this.frame.y_ranges)t instanceof o.DataRange1d&&\"log\"==t.scale_hint&&(e=!0);for(const s of this.parent.model.data_renderers){const a=this.parent.renderer_view(s);if(null==a)continue;const o=a.glyph_view.bounds();if(null!=o&&t.set(s,o),e){const t=a.glyph_view.log_bounds();null!=t&&n.set(s,t)}}let s=!1,a=!1;const{width:l,height:i}=this.frame.bbox;let d;!1!==this.parent.model.match_aspect&&0!=l&&0!=i&&(d=1/this.parent.model.aspect_scale*(l/i));for(const[,e]of this.frame.x_ranges){if(e instanceof o.DataRange1d){const a=\"log\"==e.scale_hint?n:t;e.update(a,0,this.parent.model,d),e.follow&&(s=!0)}null!=e.bounds&&(a=!0)}for(const[,e]of this.frame.y_ranges){if(e instanceof o.DataRange1d){const a=\"log\"==e.scale_hint?n:t;e.update(a,1,this.parent.model,d),e.follow&&(s=!0)}null!=e.bounds&&(a=!0)}if(s&&a){r.logger.warn(\"Follow enabled so bounds are unset.\");for(const[,t]of this.frame.x_ranges)t.bounds=null;for(const[,t]of this.frame.y_ranges)t.bounds=null}this.invalidate_dataranges=!1}compute_initial(){let t=!0;const{x_ranges:n,y_ranges:e}=this.frame,s=new Map,a=new Map;for(const[e,a]of n){const{start:n,end:o}=a;if(null==n||null==o||isNaN(n+o)){t=!1;break}s.set(e,{start:n,end:o})}if(t)for(const[n,s]of e){const{start:e,end:o}=s;if(null==e||null==o||isNaN(e+o)){t=!1;break}a.set(n,{start:e,end:o})}return t?{xrs:s,yrs:a}:(r.logger.warn(\"could not set initial ranges\"),null)}_update_ranges_together(t){let n=1;for(const[e,s]of t)n=Math.min(n,this._get_weight_to_constrain_interval(e,s));if(n<1)for(const[e,s]of t)s.start=n*s.start+(1-n)*e.start,s.end=n*s.end+(1-n)*e.end}_update_ranges_individually(t,n){const e=!!(null==n?void 0:n.panning),s=!!(null==n?void 0:n.scrolling);let a=!1;for(const[n,o]of t){if(!s){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&&(a=!0,o.end=t,(e||s)&&(o.start=t+l)),null!=r&&r<=o.start&&(a=!0,o.start=r,(e||s)&&(o.end=r-l))):(null!=t&&t>=o.start&&(a=!0,o.start=t,(e||s)&&(o.end=t+l)),null!=r&&r<=o.end&&(a=!0,o.end=r,(e||s)&&(o.start=r-l)))}}if(!(s&&a&&(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:s}=t;if(null!=t.bounds&&\"auto\"!=t.bounds){const[n,e]=t.bounds;if(null!=n&&null!=e){const t=Math.abs(e-n);s=null!=s?Math.min(s,t):t}}let a=1;if(null!=e||null!=s){const o=Math.abs(t.end-t.start),r=Math.abs(n.end-n.start);null!=e&&e>0&&r0&&r>s&&(a=(s-o)/(r-o)),a=Math.max(0,Math.min(1,a))}return a}}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;null!=i.range&&this.parent.update_range(i.range),null!=i.selection&&this.parent.update_selection(i.selection)}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(){this.can_undo&&(this.index-=1,this._do_state_change(this.index),this.changed.emit())}redo(){this.can_redo&&(this.index+=1,this._do_state_change(this.index),this.changed.emit())}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(){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(),i=o+s;if(i>=2){this.map.setZoom(i);const[t,e,,]=this._get_projected_bounds();e-t<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=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){const e=this.map.getCenter().toJSON();e[t]=this.model.map_options[t],this.map.setCenter(e),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=_.color2css(this.model.border_fill_color),t.fill())}}s.GMapPlotView=d,d.__name__=\"GMapPlotView\"},\n", " function _(t,_,n,o,r){o();t(1).__exportStar(t(169),n)},\n", " function _(e,r,d,n,R){n(),R(\"GlyphRenderer\",e(61).GlyphRenderer),R(\"GraphRenderer\",e(123).GraphRenderer),R(\"GuideRenderer\",e(164).GuideRenderer),R(\"Renderer\",e(41).Renderer)},\n", " function _(e,t,n,o,c){o();e(1).__exportStar(e(129),n),c(\"Selection\",e(59).Selection)},\n", " function _(a,e,S,o,r){o(),r(\"ServerSentDataSource\",a(342).ServerSentDataSource),r(\"AjaxDataSource\",a(344).AjaxDataSource),r(\"ColumnDataSource\",a(130).ColumnDataSource),r(\"ColumnarDataSource\",a(57).ColumnarDataSource),r(\"CDSView\",a(120).CDSView),r(\"DataSource\",a(58).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 _(t,e,a,n,s){n();const r=t(130),i=t(20);class l extends r.ColumnDataSource{constructor(t){super(t)}get_column(t){const e=this.data[t];return null!=e?e:[]}get_length(){var t;return null!==(t=super.get_length())&&void 0!==t?t:0}initialize(){super.initialize(),this.setup()}load_data(t,e,a){const{adapter:n}=this;let s;switch(s=null!=n?n.execute(this,{response:t}):t,e){case\"replace\":this.data=s;break;case\"append\":{const t=this.data;for(const e of this.columns()){const n=Array.from(t[e]),r=Array.from(s[e]),i=n.concat(r);s[e]=null!=a?i.slice(-a):i}this.data=s;break}}}static init_WebDataSource(){this.define((({Any:t,Int:e,String:a,Nullable:n})=>({max_size:[n(e),null],mode:[i.UpdateMode,\"replace\"],adapter:[n(t),null],data_url:[a]})))}}a.WebDataSource=l,l.__name__=\"WebDataSource\",l.init_WebDataSource()},\n", " function _(t,e,i,s,a){s();const n=t(343),r=t(20),o=t(19),l=t(13);class d extends n.WebDataSource{constructor(t){super(t),this.interval=null,this.initialized=!1}static init_AjaxDataSource(){this.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:[r.HTTPMethod,\"POST\"],if_modified:[t,!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 l.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){o.logger.error(`Failed to fetch JSON from ${this.data_url} with code ${t.status}`)}}i.AjaxDataSource=d,d.__name__=\"AjaxDataSource\",d.init_AjaxDataSource()},\n", " function _(e,t,o,r,n){r();const s=e(57),a=e(19),i=e(9),l=e(13);function c(e){return null!=e?e:NaN}const{hasOwnProperty:_}=Object.prototype;class g extends s.ColumnarDataSource{constructor(e){super(e)}static init_GeoJSONDataSource(){this.define((({String:e})=>({geojson:[e]}))),this.internal((({Dict:e,Arrayable:t})=>({data:[e(t),{}]})))}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 i.range(0,e).map((e=>[]))}_get_new_nan_array(e){return i.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 l.entries(s))_.call(t,e)||(t[e]=this._get_new_nan_array(r)),t[e][o]=c(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]=c(s);break}case\"LineString\":{const{coordinates:r}=e;for(let e=0;e1&&a.logger.warn(\"Bokeh does not support Polygons with holes in, only exterior ring used.\");const r=e.coordinates[0];for(let e=0;e1&&a.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({use_latlon:[e,!1]})))}get_image_url(e,t,r){const i=this.string_lookup_replace(this.url,this.extra_url_vars);let o,l,n,s;return this.use_latlon?[l,s,o,n]=this.get_tile_geographic_bounds(e,t,r):[l,s,o,n]=this.get_tile_meter_bounds(e,t,r),i.replace(\"{XMIN}\",l.toString()).replace(\"{YMIN}\",s.toString()).replace(\"{XMAX}\",o.toString()).replace(\"{YMAX}\",n.toString())}}r.BBoxTileSource=n,n.__name__=\"BBoxTileSource\",n.init_BBoxTileSource()},\n", " function _(t,e,i,_,s){_();const r=t(349),o=t(9),n=t(350);class l extends r.TileSource{constructor(t){super(t)}static init_MercatorTileSource(){this.define((({Boolean:t})=>({snap_to_zoom:[t,!1],wrap_around:[t,!0]}))),this.override({x_origin_offset:20037508.34,y_origin_offset:20037508.34,initial_resolution:156543.03392804097})}initialize(){super.initialize(),this._resolutions=o.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=l,l.__name__=\"MercatorTileSource\",l.init_MercatorTileSource()},\n", " function _(e,t,r,i,n){i();const l=e(53),s=e(13);class a extends l.Model{constructor(e){super(e)}static init_TileSource(){this.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]})))}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 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,s=(n-r)/2+r,a=(l-i)/2+i;e.sort((function(e,t){return Math.sqrt((s-e[0])**2+(a-e[1])**2)-Math.sqrt((s-t[0])**2+(a-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=a,a.__name__=\"TileSource\",a.init_TileSource()},\n", " function _(t,e,r,n,o){n();const c=t(65);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),a=t(349),h=t(353),r=t(41),o=t(156),l=t(43),d=t(296),m=t(9),c=t(8),p=n.__importStar(t(354));class g extends r.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()))}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&&l.removeElement(this.attribution_el);const{attribution:t}=this.model.tile_source;if(c.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=l.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 o.Range1d&&(this.x_range.reset_start=e[0],this.x_range.reset_end=e[2]),this.y_range instanceof o.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,a,h]=this.model.tile_source.normalize_xyz(t,e,i),r={img:void 0,tile_coords:[t,e,i],normalized_coords:[n,a,h],quadkey:this.model.tile_source.tile_xyz_to_quadkey(t,e,i),cache_key:this.model.tile_source.tile_xyz_to_key(t,e,i),bounds:s,loaded:!1,finished:!1,x_coord:s[0],y_coord:s[3]},o=this.model.tile_source.get_image_url(n,a,h);new d.ImageLoader(o,{loaded:t=>{Object.assign(r,{img:t,loaded:!0}),_?(r.finished=!0,this.notify_finished()):this.request_render()},failed(){r.finished=!0}}),this.model.tile_source.tiles.set(r.cache_key,r),this._tiles.push(r)}_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,h=t,r=i,o=this.map_canvas.getImageSmoothingEnabled();this.map_canvas.setImageSmoothingEnabled(this.model.smoothing),this.map_canvas.drawImage(e.img,h,r,n,a),this.map_canvas.setImageSmoothingEnabled(o),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,h=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 o=t.get_tiles_by_extent(s,h),l=[],d=[],c=[],p=[];for(const e of o){const[i,s,n]=e,a=t.tile_xyz_to_key(i,s,n),h=t.tiles.get(a);if(null!=h&&h.loaded)d.push(a);else if(this.model.render_parents){const[e,a,h]=t.get_closest_parent_by_tile_xyz(i,s,n),r=t.tile_xyz_to_key(e,a,h),o=t.tiles.get(r);if(null!=o&&o.loaded&&!m.includes(c,r)&&c.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)&&p.push(e)}}}null==h&&l.push(e)}this._render_tiles(c),this._render_tiles(p),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 u extends r.Renderer{constructor(t){super(t)}static init_TileRenderer(){this.prototype.default_view=g,this.define((({Boolean:t,Number:e,Ref:i})=>({alpha:[e,1],smoothing:[t,!0],tile_source:[i(a.TileSource),()=>new h.WMTSTileSource],render_parents:[t,!0]}))),this.override({level:\"image\"})}}i.TileRenderer=u,u.__name__=\"TileRenderer\",u.init_TileRenderer()},\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){c();const a=t(358),i=t(34);class r extends a.Texture{constructor(t){super(t)}static init_CanvasTexture(){this.define((({String:t})=>({code:[t]})))}get func(){const t=i.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=r,r.__name__=\"CanvasTexture\",r.init_CanvasTexture()},\n", " function _(e,t,i,n,r){n();const s=e(53),u=e(20);class o extends s.Model{constructor(e){super(e)}static init_Texture(){this.define((()=>({repetition:[u.TextureRepetition,\"repeat\"]})))}}i.Texture=o,o.__name__=\"Texture\",o.init_Texture()},\n", " function _(e,t,i,r,n){r();const a=e(358),s=e(296);class u extends a.Texture{constructor(e){super(e)}static init_ImageURLTexture(){this.define((({String:e})=>({url:[e]})))}initialize(){super.initialize(),this._loader=new s.ImageLoader(this.url)}get_pattern(e,t,i){const{_loader:r}=this;return this._loader.finished?r.image:r.promise}}i.ImageURLTexture=u,u.__name__=\"ImageURLTexture\",u.init_ImageURLTexture()},\n", " function _(o,l,T,e,t){e(),t(\"ActionTool\",o(251).ActionTool),t(\"CustomAction\",o(361).CustomAction),t(\"HelpTool\",o(252).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(238).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(237).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(247).InspectTool),t(\"Tool\",o(236).Tool),t(\"ToolProxy\",o(392).ToolProxy),t(\"Toolbar\",o(235).Toolbar),t(\"ToolbarBase\",o(248).ToolbarBase),t(\"ProxyToolbar\",o(393).ProxyToolbar),t(\"ToolbarBox\",o(393).ToolbarBox)},\n", " function _(t,o,i,s,n){s();const e=t(251);class c extends e.ActionToolButtonView{css_classes(){return super.css_classes().concat(\"bk-toolbar-button-custom-action\")}}i.CustomActionButtonView=c,c.__name__=\"CustomActionButtonView\";class u extends e.ActionToolView{doit(){var t;null===(t=this.model.callback)||void 0===t||t.execute(this.model)}}i.CustomActionView=u,u.__name__=\"CustomActionView\";class l extends e.ActionTool{constructor(t){super(t),this.tool_name=\"Custom Action\",this.button_view=c}static init_CustomAction(){this.prototype.default_view=u,this.define((({Any:t,String:o,Nullable:i})=>({callback:[i(t)],icon:[o]}))),this.override({description:\"Perform a Custom Action\"})}}i.CustomAction=l,l.__name__=\"CustomAction\",l.init_CustomAction()},\n", " function _(o,e,t,i,s){i();const n=o(251),d=o(242);class l extends n.ActionToolView{connect_signals(){super.connect_signals(),this.connect(this.plot_view.state.changed,(()=>this.model.disabled=!this.plot_view.state.can_redo))}doit(){this.plot_view.state.redo()}}t.RedoToolView=l,l.__name__=\"RedoToolView\";class _ extends n.ActionTool{constructor(o){super(o),this.tool_name=\"Redo\",this.icon=d.tool_icon_redo}static init_RedoTool(){this.prototype.default_view=l,this.override({disabled:!0}),this.register_alias(\"redo\",(()=>new _))}}t.RedoTool=_,_.__name__=\"RedoTool\",_.init_RedoTool()},\n", " function _(e,t,o,s,i){s();const _=e(251),n=e(242);class l extends _.ActionToolView{doit(){this.plot_view.reset()}}o.ResetToolView=l,l.__name__=\"ResetToolView\";class c extends _.ActionTool{constructor(e){super(e),this.tool_name=\"Reset\",this.icon=n.tool_icon_reset}static init_ResetTool(){this.prototype.default_view=l,this.register_alias(\"reset\",(()=>new c))}}o.ResetTool=c,c.__name__=\"ResetTool\",c.init_ResetTool()},\n", " function _(o,e,t,a,i){a();const n=o(251),s=o(242);class c extends n.ActionToolView{async copy(){const o=await this.plot_view.to_blob(),e=new ClipboardItem({[o.type]:o});await navigator.clipboard.write([e])}async save(o){const e=await this.plot_view.to_blob(),t=document.createElement(\"a\");t.href=URL.createObjectURL(e),t.download=o,t.target=\"_blank\",t.dispatchEvent(new MouseEvent(\"click\"))}doit(o=\"save\"){switch(o){case\"save\":this.save(\"bokeh_plot\");break;case\"copy\":this.copy()}}}t.SaveToolView=c,c.__name__=\"SaveToolView\";class l extends n.ActionTool{constructor(o){super(o),this.tool_name=\"Save\",this.icon=s.tool_icon_save}static init_SaveTool(){this.prototype.default_view=c,this.register_alias(\"save\",(()=>new l))}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=l,l.__name__=\"SaveTool\",l.init_SaveTool()},\n", " function _(o,t,n,i,e){i();const s=o(251),d=o(242);class l extends s.ActionToolView{connect_signals(){super.connect_signals(),this.connect(this.plot_view.state.changed,(()=>this.model.disabled=!this.plot_view.state.can_undo))}doit(){this.plot_view.state.undo()}}n.UndoToolView=l,l.__name__=\"UndoToolView\";class _ extends s.ActionTool{constructor(o){super(o),this.tool_name=\"Undo\",this.icon=d.tool_icon_undo}static init_UndoTool(){this.prototype.default_view=l,this.override({disabled:!0}),this.register_alias(\"undo\",(()=>new _))}}n.UndoTool=_,_.__name__=\"UndoTool\",_.init_UndoTool()},\n", " function _(o,i,n,s,e){s();const t=o(367),_=o(242);class m extends t.ZoomBaseToolView{}n.ZoomInToolView=m,m.__name__=\"ZoomInToolView\";class l extends t.ZoomBaseTool{constructor(o){super(o),this.sign=1,this.tool_name=\"Zoom In\",this.icon=_.tool_icon_zoom_in}static init_ZoomInTool(){this.prototype.default_view=m,this.register_alias(\"zoom_in\",(()=>new l({dimensions:\"both\"}))),this.register_alias(\"xzoom_in\",(()=>new l({dimensions:\"width\"}))),this.register_alias(\"yzoom_in\",(()=>new l({dimensions:\"height\"})))}}n.ZoomInTool=l,l.__name__=\"ZoomInTool\",l.init_ZoomInTool()},\n", " function _(o,t,e,i,s){i();const n=o(251),l=o(20),a=o(368);class _ extends n.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=a.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}),null===(o=this.model.document)||void 0===o||o.interactive_start(this.plot_model)}}e.ZoomBaseToolView=_,_.__name__=\"ZoomBaseToolView\";class m extends n.ActionTool{constructor(o){super(o)}static init_ZoomBaseTool(){this.define((({Percent:o})=>({factor:[o,.1],dimensions:[l.Dimensions,\"both\"]})))}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}e.ZoomBaseTool=m,m.__name__=\"ZoomBaseTool\",m.init_ZoomBaseTool()},\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=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,t,i,s,e){s();const n=o(367),_=o(242);class m extends n.ZoomBaseToolView{}i.ZoomOutToolView=m,m.__name__=\"ZoomOutToolView\";class l extends n.ZoomBaseTool{constructor(o){super(o),this.sign=-1,this.tool_name=\"Zoom Out\",this.icon=_.tool_icon_zoom_out}static init_ZoomOutTool(){this.prototype.default_view=m,this.register_alias(\"zoom_out\",(()=>new l({dimensions:\"both\"}))),this.register_alias(\"xzoom_out\",(()=>new l({dimensions:\"width\"}))),this.register_alias(\"yzoom_out\",(()=>new l({dimensions:\"height\"})))}}i.ZoomOutTool=l,l.__name__=\"ZoomOutTool\",l.init_ZoomOutTool()},\n", " function _(e,t,s,o,n){o();const i=e(9),r=e(8),c=e(11),a=e(61),_=e(237);class l extends _.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 c.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(a.GlyphRenderer)),[]]})))}get computed_icon(){var e;return null!==(e=this.custom_icon)&&void 0!==e?e:this.icon}}s.EditTool=d,d.__name__=\"EditTool\",d.init_EditTool()},\n", " function _(e,t,s,i,_){i();const o=e(43),n=e(20),a=e(370),d=e(242);class l extends a.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===o.Keys.Backspace)this._delete_selected(t);else if(e.keyCode==o.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],[x,y]=[d.x.field,d.y.field],[w,v]=[d.width.field,d.height.field];if(_)this._pop_glyphs(l,this.model.num_objects),x&&l.get_array(x).push(c),y&&l.get_array(y).push(m),w&&l.get_array(w).push(f),v&&l.get_array(v).push(b),this._pad_empty_columns(l,[x,y,w,v]);else{const e=l.data[x].length-1;x&&(l.data[x][e]=c),y&&(l.data[y][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=l,l.__name__=\"BoxEditToolView\";class r extends a.EditTool{constructor(e){super(e),this.tool_name=\"Box Edit Tool\",this.icon=d.tool_icon_box_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=1}static init_BoxEditTool(){this.prototype.default_view=l,this.define((({Int:e})=>({dimensions:[n.Dimensions,\"both\"],num_objects:[e,0]})))}}s.BoxEditTool=r,r.__name__=\"BoxEditTool\",r.init_BoxEditTool()},\n", " function _(e,t,a,s,r){s();const _=e(43),i=e(8),o=e(370),d=e(242);class n extends o.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[_,o]=r,d=s.data_source,n=s.glyph,[h,l]=[n.xs.field,n.ys.field];if(\"new\"==t)this._pop_glyphs(d,this.model.num_objects),h&&d.get_array(h).push([_]),l&&d.get_array(l).push([o]),this._pad_empty_columns(d,[h,l]);else if(\"add\"==t){if(h){const e=d.data[h].length-1;let t=d.get_array(h)[e];i.isArray(t)||(t=Array.from(t),d.data[h][e]=t),t.push(_)}if(l){const e=d.data[l].length-1;let t=d.get_array(l)[e];i.isArray(t)||(t=Array.from(t),d.data[l][e]=t),t.push(o)}}this._emit_cds_changes(d,!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===_.Keys.Esc?t.data_source.selection_manager.clear():e.keyCode===_.Keys.Backspace&&this._delete_selected(t)}}a.FreehandDrawToolView=n,n.__name__=\"FreehandDrawToolView\";class h extends o.EditTool{constructor(e){super(e),this.tool_name=\"Freehand Draw Tool\",this.icon=d.tool_icon_freehand_draw,this.event_type=[\"pan\",\"tap\"],this.default_order=3}static init_FreehandDrawTool(){this.prototype.default_view=n,this.define((({Int:e})=>({num_objects:[e,0]}))),this.register_alias(\"freehand_draw\",(()=>new h))}}a.FreehandDrawTool=h,h.__name__=\"FreehandDrawTool\",h.init_FreehandDrawTool()},\n", " function _(e,t,s,o,i){o();const a=e(43),n=e(370),_=e(242);class r extends n.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,i=t.data_source,[a,n]=[o.x.field,o.y.field],[_,r]=s;this._pop_glyphs(i,this.model.num_objects),a&&i.get_array(a).push(_),n&&i.get_array(n).push(r),this._pad_empty_columns(i,[a,n]),i.change.emit(),i.data=i.data,i.properties.data.change.emit()}_keyup(e){if(this.model.active&&this._mouse_in_frame)for(const t of this.model.renderers)e.keyCode===a.Keys.Backspace?this._delete_selected(t):e.keyCode==a.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=r,r.__name__=\"PointDrawToolView\";class d extends n.EditTool{constructor(e){super(e),this.tool_name=\"Point Draw Tool\",this.icon=_.tool_icon_point_draw,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=2}static init_PointDrawTool(){this.prototype.default_view=r,this.define((({Boolean:e,Int:t})=>({add:[e,!0],drag:[e,!0],num_objects:[t,0]})))}}s.PointDrawTool=d,d.__name__=\"PointDrawTool\",d.init_PointDrawTool()},\n", " function _(e,t,s,i,a){i();const o=e(43),r=e(8),n=e(375),_=e(242);class d extends n.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[o,n]=this._snap_to_vertex(e,...a),_=i.data_source,d=i.glyph,[l,h]=[d.xs.field,d.ys.field];if(\"new\"==t)this._pop_glyphs(_,this.model.num_objects),l&&_.get_array(l).push([o,o]),h&&_.get_array(h).push([n,n]),this._pad_empty_columns(_,[l,h]);else if(\"edit\"==t){if(l){const e=_.data[l][_.data[l].length-1];e[e.length-1]=o}if(h){const e=_.data[h][_.data[h].length-1];e[e.length-1]=n}}else if(\"add\"==t){if(l){const e=_.data[l].length-1;let t=_.get_array(l)[e];const s=t[t.length-1];t[t.length-1]=o,r.isArray(t)||(t=Array.from(t),_.data[l][e]=t),t.push(s)}if(h){const e=_.data[h].length-1;let t=_.get_array(h)[e];const s=t[t.length-1];t[t.length-1]=n,r.isArray(t)||(t=Array.from(t),_.data[h][e]=t),t.push(s)}}this._emit_cds_changes(_,!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=d,d.__name__=\"PolyDrawToolView\";class l extends n.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}static init_PolyDrawTool(){this.prototype.default_view=d,this.define((({Boolean:e,Int:t})=>({drag:[e,!0],num_objects:[t,0]})))}}s.PolyDrawTool=l,l.__name__=\"PolyDrawTool\",l.init_PolyDrawTool()},\n", " function _(e,t,r,o,s){o();const i=e(8),l=e(370);class _ extends l.EditToolView{_set_vertices(e,t){const r=this.model.vertex_renderer.glyph,o=this.model.vertex_renderer.data_source,[s,l]=[r.x.field,r.y.field];s&&(i.isArray(e)?o.data[s]=e:r.x={value:e}),l&&(i.isArray(t)?o.data[l]=t:r.y={value:t}),this._emit_cds_changes(o,!0,!0,!1)}_hide_vertices(){this._set_vertices([],[])}_snap_to_vertex(e,t,r){if(this.model.vertex_renderer){const o=this._select_event(e,\"replace\",[this.model.vertex_renderer]),s=this.model.vertex_renderer.data_source,i=this.model.vertex_renderer.glyph,[l,_]=[i.x.field,i.y.field];if(o.length){const e=s.selected.indices[0];l&&(t=s.data[l][e]),_&&(r=s.data[_][e]),s.selection_manager.clear()}}return[t,r]}}r.PolyToolView=_,_.__name__=\"PolyToolView\";class d extends l.EditTool{constructor(e){super(e)}static init_PolyTool(){this.define((({AnyRef:e})=>({vertex_renderer:[e()]})))}}r.PolyTool=d,d.__name__=\"PolyTool\",d.init_PolyTool()},\n", " function _(e,t,s,r,i){r();const _=e(43),d=e(8),n=e(375),l=e(242);class a extends n.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 n,l;i&&null!=r?(n=s.data[i][r],d.isArray(n)||(s.data[i][r]=n=Array.from(n))):n=t.xs.value,_&&null!=r?(l=s.data[_][r],d.isArray(l)||(s.data[_][r]=l=Array.from(l))):l=t.ys.value,this._selected_renderer=e,this._set_vertices(n,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===_.Keys.Backspace?(this._delete_selected(s),this._selected_renderer&&this._emit_cds_changes(this._selected_renderer.data_source)):e.keyCode==_.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=a,a.__name__=\"PolyEditToolView\";class c extends n.PolyTool{constructor(e){super(e),this.tool_name=\"Poly Edit Tool\",this.icon=l.tool_icon_poly_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=4}static init_PolyEditTool(){this.prototype.default_view=a}}s.PolyEditTool=c,c.__name__=\"PolyEditTool\",c.init_PolyEditTool()},\n", " function _(e,t,o,s,i){s();const l=e(378),n=e(136),_=e(20),c=e(242);class h extends l.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=h,h.__name__=\"BoxSelectToolView\";const r=()=>new n.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 a extends l.SelectTool{constructor(e){super(e),this.tool_name=\"Box Select\",this.icon=c.tool_icon_box_select,this.event_type=\"pan\",this.default_order=30}static init_BoxSelectTool(){this.prototype.default_view=h,this.define((({Boolean:e,Ref:t})=>({dimensions:[_.Dimensions,\"both\"],select_every_mousemove:[e,!1],overlay:[t(n.BoxAnnotation),r],origin:[_.BoxOrigin,\"corner\"]}))),this.register_alias(\"box_select\",(()=>new a)),this.register_alias(\"xbox_select\",(()=>new a({dimensions:\"width\"}))),this.register_alias(\"ybox_select\",(()=>new a({dimensions:\"height\"})))}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}o.BoxSelectTool=a,a.__name__=\"BoxSelectTool\",a.init_BoxSelectTool()},\n", " function _(e,t,s,n,o){n();const r=e(237),c=e(61),i=e(123),l=e(62),a=e(161),_=e(20),d=e(43),h=e(264),p=e(15),u=e(11);class m extends r.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 a.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 c.GlyphRenderer)n=s.data_source;else{if(!(s instanceof i.GraphRenderer))continue;n=s.node_renderer.data_source}const o=null!==(e=t.get(n))&&void 0!==e?e:[];t.set(n,[...o,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 u.unreachable():this.model.mode}_keyup(e){e.keyCode==d.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[,o]of n){const n=o[0].get_selection_manager(),r=[];for(const e of o){const t=this.plot_view.renderer_view(e);null!=t&&r.push(t)}n.select(r,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 o;switch(e.type){case\"point\":{const{sx:t,sy:r}=e,c=s.invert(t),i=n.invert(r);o=Object.assign(Object.assign({},e),{x:c,y:i});break}case\"span\":{const{sx:t,sy:r}=e,c=s.invert(t),i=n.invert(r);o=Object.assign(Object.assign({},e),{x:c,y:i});break}case\"rect\":{const{sx0:t,sx1:r,sy0:c,sy1:i}=e,[l,a]=s.r_invert(t,r),[_,d]=n.r_invert(c,i);o=Object.assign(Object.assign({},e),{x0:l,y0:_,x1:a,y1:d});break}case\"poly\":{const{sx:t,sy:r}=e,c=s.v_invert(t),i=n.v_invert(r);o=Object.assign(Object.assign({},e),{x:c,y:i});break}}this.plot_model.trigger_event(new h.SelectionGeometry(o,t))}}s.SelectToolView=m,m.__name__=\"SelectToolView\";class v extends r.GestureTool{constructor(e){super(e)}initialize(){super.initialize(),this.clear=new p.Signal0(this,\"clear\")}static init_SelectTool(){this.define((({String:e,Array:t,Ref:s,Or:n,Auto:o})=>({renderers:[n(t(s(l.DataRenderer)),o),\"auto\"],names:[t(e),[]],mode:[_.SelectionMode,\"replace\"]})))}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=v,v.__name__=\"SelectTool\",v.init_SelectTool()},\n", " function _(t,o,e,s,i){s();const n=t(237),_=t(136),a=t(20),l=t(242);class r extends n.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 _.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 c extends n.GestureTool{constructor(t){super(t),this.tool_name=\"Box Zoom\",this.icon=l.tool_icon_box_zoom,this.event_type=\"pan\",this.default_order=20}static init_BoxZoomTool(){this.prototype.default_view=r,this.define((({Boolean:t,Ref:o})=>({dimensions:[a.Dimensions,\"both\"],overlay:[o(_.BoxAnnotation),h],match_aspect:[t,!1],origin:[a.BoxOrigin,\"corner\"]}))),this.register_alias(\"box_zoom\",(()=>new c({dimensions:\"both\"}))),this.register_alias(\"xbox_zoom\",(()=>new c({dimensions:\"width\"}))),this.register_alias(\"ybox_zoom\",(()=>new c({dimensions:\"height\"})))}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}e.BoxZoomTool=c,c.__name__=\"BoxZoomTool\",c.init_BoxZoomTool()},\n", " function _(s,e,t,o,i){o();const l=s(378),_=s(231),a=s(381),c=s(43),n=s(242);class h extends l.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==c.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 i={type:\"poly\",sx:s,sy:e};this._select(i,t,o)}}t.LassoSelectToolView=h,h.__name__=\"LassoSelectToolView\";class r extends l.SelectTool{constructor(s){super(s),this.tool_name=\"Lasso Select\",this.icon=n.tool_icon_lasso_select,this.event_type=\"pan\",this.default_order=12}static init_LassoSelectTool(){this.prototype.default_view=h,this.define((({Boolean:s,Ref:e})=>({select_every_mousemove:[s,!0],overlay:[e(_.PolyAnnotation),a.DEFAULT_POLY_OVERLAY]}))),this.register_alias(\"lasso_select\",(()=>new r))}}t.LassoSelectTool=r,r.__name__=\"LassoSelectTool\",r.init_LassoSelectTool()},\n", " function _(e,t,s,l,o){l();const i=e(378),a=e(231),_=e(43),c=e(9),n=e(242);class h extends i.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==_.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:c.copy(this.data.sx),ys:c.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=h,h.__name__=\"PolySelectToolView\";s.DEFAULT_POLY_OVERLAY=()=>new a.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 y extends i.SelectTool{constructor(e){super(e),this.tool_name=\"Poly Select\",this.icon=n.tool_icon_polygon_select,this.event_type=\"tap\",this.default_order=11}static init_PolySelectTool(){this.prototype.default_view=h,this.define((({Ref:e})=>({overlay:[e(a.PolyAnnotation),s.DEFAULT_POLY_OVERLAY]}))),this.register_alias(\"poly_select\",(()=>new y))}}s.PolySelectTool=y,y.__name__=\"PolySelectTool\",y.init_PolySelectTool()},\n", " function _(e,t,i,s,n){s();const r=e(20),_=e(383),d=e(242);class o extends _.LineToolView{constructor(){super(...arguments),this._drawing=!1}_doubletap(e){if(!this.model.active)return;const t=this.model.renderers;for(const i of t){1==this._select_event(e,\"replace\",[i]).length&&(this._selected_renderer=i)}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,[i,s]=[t.x.field,t.y.field],n=e.get_array(i),r=e.get_array(s);this._set_intersection(n,r)}_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 i=this._select_mode(e);if(0==this._select_event(e,i,[t]).length)return}const i=this._select_mode(e);this._select_event(e,i,[t]),this._select_event(e,i,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,[i,s]=[e.x.field,e.y.field];if(i&&s){const e=t.data[i],n=t.data[s];this._selected_renderer.data_source.data[i]=e,this._selected_renderer.data_source.data[s]=n}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())}}i.LineEditToolView=o,o.__name__=\"LineEditToolView\";class l extends _.LineTool{constructor(e){super(e),this.tool_name=\"Line Edit Tool\",this.icon=d.tool_icon_line_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=4}static init_LineEditTool(){this.prototype.default_view=o,this.define((()=>({dimensions:[r.Dimensions,\"both\"]})))}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}i.LineEditTool=l,l.__name__=\"LineEditTool\",l.init_LineEditTool()},\n", " function _(e,i,t,n,o){n();const s=e(8),_=e(370);class r extends _.EditToolView{_set_intersection(e,i){const t=this.model.intersection_renderer.glyph,n=this.model.intersection_renderer.data_source,[o,_]=[t.x.field,t.y.field];o&&(s.isArray(e)?n.data[o]=e:t.x={value:e}),_&&(s.isArray(i)?n.data[_]=i:t.y={value:i}),this._emit_cds_changes(n,!0,!0,!1)}_hide_intersections(){this._set_intersection([],[])}}t.LineToolView=r,r.__name__=\"LineToolView\";class c extends _.EditTool{constructor(e){super(e)}static init_LineTool(){this.define((({AnyRef:e})=>({intersection_renderer:[e()]})))}}t.LineTool=c,c.__name__=\"LineTool\",c.init_LineTool()},\n", " function _(t,s,i,n,e){n();const o=t(1),a=t(237),_=t(20),h=o.__importStar(t(242));function l(t,s,i){const n=new Map;for(const[e,o]of t){const[t,a]=o.r_invert(s,i);n.set(e,{start:t,end:a})}return n}i.update_ranges=l;class r extends a.GestureToolView{_pan_start(t){var s;this.last_dx=0,this.last_dy=0;const{sx:i,sy:n}=t,e=this.plot_view.frame.bbox;if(!e.contains(i,n)){const t=e.h_range,s=e.v_range;(it.end)&&(this.v_axis_only=!0),(ns.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})}_update(t,s){const i=this.plot_view.frame,n=t-this.last_dx,e=s-this.last_dy,o=i.bbox.h_range,a=o.start-n,_=o.end-n,h=i.bbox.v_range,r=h.start-e,d=h.end-e,p=this.model.dimensions;let c,m,u,x,v,y;\"width\"!=p&&\"both\"!=p||this.v_axis_only?(c=o.start,m=o.end,u=0):(c=a,m=_,u=-n),\"height\"!=p&&\"both\"!=p||this.h_axis_only?(x=h.start,v=h.end,y=0):(x=r,v=d,y=-e),this.last_dx=t,this.last_dy=s;const{x_scales:g,y_scales:w}=i,f=l(g,c,m),b=l(w,x,v);this.pan_info={xrs:f,yrs:b,sdx:u,sdy:y},this.plot_view.update_range(this.pan_info,{panning:!0})}}i.PanToolView=r,r.__name__=\"PanToolView\";class d extends a.GestureTool{constructor(t){super(t),this.tool_name=\"Pan\",this.event_type=\"pan\",this.default_order=10}static init_PanTool(){this.prototype.default_view=r,this.define((()=>({dimensions:[_.Dimensions,\"both\",{on_update(t,s){switch(t){case\"both\":s.icon=h.tool_icon_pan;break;case\"width\":s.icon=h.tool_icon_xpan;break;case\"height\":s.icon=h.tool_icon_ypan}}}]}))),this.register_alias(\"pan\",(()=>new d({dimensions:\"both\"}))),this.register_alias(\"xpan\",(()=>new d({dimensions:\"width\"}))),this.register_alias(\"ypan\",(()=>new d({dimensions:\"height\"})))}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}i.PanTool=d,d.__name__=\"PanTool\",d.init_PanTool()},\n", " function _(t,e,i,s,n){s();const l=t(136),a=t(156),r=t(19),o=t(237),_=t(242);function h(t){switch(t){case 1:return 2;case 2:return 1;case 4:return 5;case 5:return 4;default:return t}}function d(t,e,i,s){if(null==e)return!1;const n=i.compute(e);return Math.abs(t-n)n.right)&&(l=!1)}if(null!=n.bottom&&null!=n.top){const t=s.invert(e);(tn.top)&&(l=!1)}return l}function c(t,e,i){let s=0;return t>=i.start&&t<=i.end&&(s+=1),e>=i.start&&e<=i.end&&(s+=1),s}function g(t,e,i,s){const n=e.compute(t),l=e.invert(n+i);return l>=s.start&&l<=s.end?l:t}function y(t,e,i){return t>e.start?(e.end=t,i):(e.end=e.start,e.start=t,h(i))}function f(t,e,i){return t=o&&(t.start=a,t.end=r)}i.flip_side=h,i.is_near=d,i.is_inside=u,i.sides_inside=c,i.compute_value=g,i.update_range_end_side=y,i.update_range_start_side=f,i.update_range=m;class v extends o.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(t){this.last_dx=0,this.last_dy=0;const e=this.model.x_range,i=this.model.y_range,{frame:s}=this.plot_view,n=s.x_scale,a=s.y_scale,r=this.model.overlay,{left:o,right:_,top:h,bottom:c}=r,g=this.model.overlay.line_width+l.EDGE_TOLERANCE;null!=e&&this.model.x_interaction&&(d(t.sx,o,n,g)?this.side=1:d(t.sx,_,n,g)?this.side=2:u(t.sx,t.sy,n,a,r)&&(this.side=3)),null!=i&&this.model.y_interaction&&(0==this.side&&d(t.sy,c,a,g)&&(this.side=4),0==this.side&&d(t.sy,h,a,g)?this.side=5:u(t.sx,t.sy,n,a,this.model.overlay)&&(3==this.side?this.side=7:this.side=6))}_pan(t){const e=this.plot_view.frame,i=t.deltaX-this.last_dx,s=t.deltaY-this.last_dy,n=this.model.x_range,l=this.model.y_range,a=e.x_scale,r=e.y_scale;if(null!=n)if(3==this.side||7==this.side)m(n,a,i,e.x_range);else if(1==this.side){const t=g(n.start,a,i,e.x_range);this.side=f(t,n,this.side)}else if(2==this.side){const t=g(n.end,a,i,e.x_range);this.side=y(t,n,this.side)}if(null!=l)if(6==this.side||7==this.side)m(l,r,s,e.y_range);else if(4==this.side){const t=g(l.start,r,s,e.y_range);this.side=f(t,l,this.side)}else if(5==this.side){const t=g(l.end,r,s,e.y_range);this.side=y(t,l,this.side)}this.last_dx=t.deltaX,this.last_dy=t.deltaY}_pan_end(t){this.side=0}}i.RangeToolView=v,v.__name__=\"RangeToolView\";const p=()=>new l.BoxAnnotation({level:\"overlay\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:.5,line_dash:[2,2]});class x extends o.GestureTool{constructor(t){super(t),this.tool_name=\"Range Tool\",this.icon=_.tool_icon_range,this.event_type=\"pan\",this.default_order=1}static init_RangeTool(){this.prototype.default_view=v,this.define((({Boolean:t,Ref:e,Nullable:i})=>({x_range:[i(e(a.Range1d)),null],x_interaction:[t,!0],y_range:[i(e(a.Range1d)),null],y_interaction:[t,!0],overlay:[e(l.BoxAnnotation),p]})))}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,r.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=x,x.__name__=\"RangeTool\",x.init_RangeTool()},\n", " function _(e,t,s,o,i){o();const l=e(378),a=e(20),n=e(242);class c extends l.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=c,c.__name__=\"TapToolView\";class _ extends l.SelectTool{constructor(e){super(e),this.tool_name=\"Tap\",this.icon=n.tool_icon_tap_select,this.event_type=\"tap\",this.default_order=10}static init_TapTool(){this.prototype.default_view=c,this.define((({Any:e,Enum:t,Nullable:s})=>({behavior:[a.TapBehavior,\"select\"],gesture:[t(\"tap\",\"doubletap\"),\"tap\"],callback:[s(e)]}))),this.register_alias(\"click\",(()=>new _({behavior:\"inspect\"}))),this.register_alias(\"tap\",(()=>new _)),this.register_alias(\"doubletap\",(()=>new _({gesture:\"doubletap\"})))}}s.TapTool=_,_.__name__=\"TapTool\",_.init_TapTool()},\n", " function _(e,t,s,i,n){i();const o=e(237),a=e(20),l=e(242),_=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,i=s.bbox.h_range,n=s.bbox.v_range,[o,a]=[i.start,i.end],[l,h]=[n.start,n.end];let r,d,c,p;switch(this.model.dimension){case\"height\":{const t=Math.abs(h-l);r=o,d=a,c=l-t*e,p=h-t*e;break}case\"width\":{const t=Math.abs(a-o);r=o-t*e,d=a-t*e,c=l,p=h;break}}const{x_scales:m,y_scales:u}=s,w={xrs:_.update_ranges(m,r,d),yrs:_.update_ranges(u,c,p),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)}}s.WheelPanToolView=h,h.__name__=\"WheelPanToolView\";class r extends o.GestureTool{constructor(e){super(e),this.tool_name=\"Wheel Pan\",this.icon=l.tool_icon_wheel_pan,this.event_type=\"scroll\",this.default_order=12}static init_WheelPanTool(){this.prototype.default_view=h,this.define((()=>({dimension:[a.Dimension,\"width\"]}))),this.internal((({Number:e})=>({speed:[e,.001]}))),this.register_alias(\"xwheel_pan\",(()=>new r({dimension:\"width\"}))),this.register_alias(\"ywheel_pan\",(()=>new r({dimension:\"height\"})))}get tooltip(){return this._get_dim_tooltip(this.dimension)}}s.WheelPanTool=r,r.__name__=\"WheelPanTool\",r.init_WheelPanTool()},\n", " function _(e,o,t,s,i){s();const l=e(237),n=e(368),h=e(20),_=e(27),a=e(242);class m extends l.GestureToolView{_pinch(e){const{sx:o,sy:t,scale:s,ctrlKey:i,shiftKey:l}=e;let n;n=s>=1?20*(s-1):-20/s,this._scroll({type:\"wheel\",sx:o,sy:t,delta:n,ctrlKey:i,shiftKey:l})}_scroll(e){var o;const{frame:t}=this.plot_view,s=t.bbox.h_range,i=t.bbox.v_range,{sx:l,sy:h}=e,_=this.model.dimensions,a=(\"width\"==_||\"both\"==_)&&s.start({dimensions:[h.Dimensions,\"both\"],maintain_focus:[e,!0],zoom_on_axis:[e,!0],speed:[o,1/600]}))),this.register_alias(\"wheel_zoom\",(()=>new r({dimensions:\"both\"}))),this.register_alias(\"xwheel_zoom\",(()=>new r({dimensions:\"width\"}))),this.register_alias(\"ywheel_zoom\",(()=>new r({dimensions:\"height\"})))}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}t.WheelZoomTool=r,r.__name__=\"WheelZoomTool\",r.init_WheelZoomTool()},\n", " function _(i,s,t,o,e){o();const n=i(247),l=i(233),h=i(20),a=i(13),r=i(242);class _ extends n.InspectToolView{_move(i){if(!this.model.active)return;const{sx:s,sy:t}=i;this.plot_view.frame.bbox.contains(s,t)?this._update_spans(s,t):this._update_spans(null,null)}_move_exit(i){this._update_spans(null,null)}_update_spans(i,s){const t=this.model.dimensions;\"width\"!=t&&\"both\"!=t||(this.model.spans.width.location=s),\"height\"!=t&&\"both\"!=t||(this.model.spans.height.location=i)}}t.CrosshairToolView=_,_.__name__=\"CrosshairToolView\";class c extends n.InspectTool{constructor(i){super(i),this.tool_name=\"Crosshair\",this.icon=r.tool_icon_crosshair}static init_CrosshairTool(){function i(i,s){return new l.Span({for_hover:!0,dimension:s,location_units:\"screen\",level:\"overlay\",line_color:i.line_color,line_width:i.line_width,line_alpha:i.line_alpha})}this.prototype.default_view=_,this.define((({Alpha:i,Number:s,Color:t})=>({dimensions:[h.Dimensions,\"both\"],line_color:[t,\"black\"],line_width:[s,1],line_alpha:[i,1]}))),this.internal((({Struct:s,Ref:t})=>({spans:[s({width:t(l.Span),height:t(l.Span)}),s=>({width:i(s,\"width\"),height:i(s,\"height\")})]}))),this.register_alias(\"crosshair\",(()=>new c))}get tooltip(){return this._get_dim_tooltip(this.dimensions)}get synthetic_renderers(){return a.values(this.spans)}}t.CrosshairTool=c,c.__name__=\"CrosshairTool\",c.init_CrosshairTool()},\n", " function _(t,e,s,o,r){o();const n=t(53),i=t(13),a=t(34);class u extends n.Model{constructor(t){super(t)}static init_CustomJSHover(){this.define((({Unknown:t,String:e,Dict:s})=>({args:[s(t),{}],code:[e,\"\"]})))}get values(){return i.values(this.args)}_make_code(t,e,s,o){return new Function(...i.keys(this.args),t,e,s,a.use_strict(o))}format(t,e,s){return this._make_code(\"value\",\"format\",\"special_vars\",this.code)(...this.values,t,e,s)}}s.CustomJSHover=u,u.__name__=\"CustomJSHover\",u.init_CustomJSHover()},\n", " function _(e,t,n,s,o){s();const i=e(1),r=e(247),l=e(390),a=e(254),c=e(61),_=e(123),d=e(62),p=e(63),h=e(127),u=i.__importStar(e(107)),m=e(182),y=e(43),f=e(22),x=e(13),v=e(245),w=e(8),g=e(122),b=e(20),k=e(242),C=e(15),S=e(161),T=i.__importStar(e(255));function $(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=u.dist_2_pts(r,e),c=u.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 a.Tooltip({custom:w.isString(n)||w.isFunction(n),attachment:this.model.attachment,show_arrow:this.model.show_arrow});t instanceof c.GlyphRenderer?e.set(t,s):t instanceof _.GraphRenderer&&(e.set(t.node_renderer,s),e.set(t.edge_renderer,s))}const s=await g.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 c.GlyphRenderer?yield e:e instanceof _.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)));C.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 S.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 c.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();let r=i.inspectors.get(e);if(r=e.view.convert_selection_to_subset(r),r.is_empty())return void o.clear();const l=i.source,a=this.plot_view.renderer_view(e);if(null==a)return;const{sx:_,sy:d}=t,u=a.coordinates.x_scale,m=a.coordinates.y_scale,f=u.invert(_),v=m.invert(d),{glyph:w}=a,g=[];if(w instanceof p.LineView)for(const n of r.line_indices){let s,o,i=w._x[n+1],a=w._y[n+1],c=n;switch(this.model.line_policy){case\"interp\":[i,a]=w.get_interpolation_hit(n,t),s=u.compute(i),o=m.compute(a);break;case\"prev\":[[s,o],c]=R(w.sx,w.sy,n);break;case\"next\":[[s,o],c]=R(w.sx,w.sy,n+1);break;case\"nearest\":[[s,o],c]=$(n,t,_,d,w.sx,w.sy),i=w._x[c],a=w._y[c];break;default:[s,o]=[_,d]}const p={index:c,x:f,y:v,sx:_,sy:d,data_x:i,data_y:a,rx:s,ry:o,indices:r.line_indices,name:e.name};g.push([s,o,this._render_tooltips(l,c,p)])}for(const t of r.image_indices){const n={index:t.index,x:f,y:v,sx:_,sy:d,name:e.name},s=this._render_tooltips(l,t,n);g.push([_,d,s])}for(const o of r.indices)if(w instanceof h.MultiLineView&&!x.isEmpty(r.multiline_indices))for(const n of r.multiline_indices[o.toString()]){let s,i,a,p=w._xs.get(o)[n],h=w._ys.get(o)[n],y=n;switch(this.model.line_policy){case\"interp\":[p,h]=w.get_interpolation_hit(o,n,t),s=u.compute(p),i=m.compute(h);break;case\"prev\":[[s,i],y]=R(w.sxs.get(o),w.sys.get(o),n);break;case\"next\":[[s,i],y]=R(w.sxs.get(o),w.sys.get(o),n+1);break;case\"nearest\":[[s,i],y]=$(n,t,_,d,w.sxs.get(o),w.sys.get(o)),p=w._xs.get(o)[y],h=w._ys.get(o)[y];break;default:throw new Error(\"shouldn't have happened\")}a=e instanceof c.GlyphRenderer?e.view.convert_indices_from_subset([o])[0]:o;const x={index:a,x:f,y:v,sx:_,sy:d,data_x:p,data_y:h,segment_index:y,indices:r.multiline_indices,name:e.name};g.push([s,i,this._render_tooltips(l,a,x)])}else{const t=null===(n=w._x)||void 0===n?void 0:n[o],i=null===(s=w._y)||void 0===s?void 0:s[o];let a,p,h;if(\"snap_to_data\"==this.model.point_policy){let e=w.get_anchor_point(this.model.anchor,o,[_,d]);if(null==e&&(e=w.get_anchor_point(\"center\",o,[_,d]),null==e))continue;a=e.x,p=e.y}else[a,p]=[_,d];h=e instanceof c.GlyphRenderer?e.view.convert_indices_from_subset([o])[0]:o;const u={index:h,x:f,y:v,sx:_,sy:d,data_x:t,data_y:i,indices:r.indices,name:e.name};g.push([a,p,this._render_tooltips(l,h,u)])}if(0==g.length)o.clear();else{const{content:e}=o;y.empty(o.content);for(const[,,t]of g)null!=t&&e.appendChild(t);const[t,n]=g[g.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 c.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=y.div({style:{display:\"table\",borderSpacing:\"2px\"}});for(const[n]of e){const e=y.div({style:{display:\"table-row\"}});t.appendChild(e);const s=y.div({style:{display:\"table-cell\"},class:T.tooltip_row_label},0!=n.length?`${n}: `:\"\");e.appendChild(s);const o=y.span();o.dataset.value=\"\";const i=y.span({class:T.tooltip_color_block},\" \");i.dataset.swatch=\"\",y.undisplay(i);const r=y.div({style:{display:\"table-cell\"},class:T.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 v.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=w.isNumber(s)?o[s]:null;null!=e&&(l[i].style.backgroundColor=f.color2css(e),y.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=w.isNumber(s)?o[s]:null;if(null==d){r[i].textContent=\"(null)\";continue}r[i].textContent=a?f.color2hex(d):f.color2css(d),c&&(l[i].style.backgroundColor=f.color2css(d),y.display(l[i]))}}else{const t=m.replace_placeholders(e.replace(\"$~\",\"$data_\"),n,s,this.model.formatters,o);if(w.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(w.isString(o)){const s=m.replace_placeholders({html:o},e,t,this.model.formatters,n);return y.div({},s)}if(w.isFunction(o))return o(e,n);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=H,H.__name__=\"HoverToolView\";class M extends r.InspectTool{constructor(e){super(e),this.tool_name=\"Hover\",this.icon=k.tool_icon_hover}static init_HoverTool(){this.prototype.default_view=H,this.define((({Any:e,Boolean:t,String:n,Array:s,Tuple:o,Dict:i,Or:r,Ref:a,Function:c,Auto:_,Nullable:p})=>({tooltips:[p(r(n,s(o(n,n)),c())),[[\"index\",\"$index\"],[\"data (x, y)\",\"($x, $y)\"],[\"screen (x, y)\",\"($sx, $sy)\"]]],formatters:[i(r(a(l.CustomJSHover),m.FormatterType)),{}],renderers:[r(s(a(d.DataRenderer)),_),\"auto\"],names:[s(n),[]],mode:[b.HoverMode,\"mouse\"],muted_policy:[b.MutedPolicy,\"show\"],point_policy:[b.PointPolicy,\"snap_to_data\"],line_policy:[b.LinePolicy,\"nearest\"],show_arrow:[t,!0],anchor:[b.Anchor,\"center\"],attachment:[b.TooltipAttachment,\"horizontal\"],callback:[p(e)]}))),this.register_alias(\"hover\",(()=>new M))}}n.HoverTool=M,M.__name__=\"HoverTool\",M.init_HoverTool()},\n", " function _(t,o,e,n,i){n();const s=t(15),l=t(53),c=t(238),r=t(247),a=t(245);class u extends l.Model{constructor(t){super(t)}static init_ToolProxy(){this.define((({Boolean:t,Array:o,Ref:e})=>({tools:[o(e(c.ButtonTool)),[]],active:[t,!1],disabled:[t,!1]})))}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 r.InspectTool&&t.toggleable}initialize(){super.initialize(),this.do=new s.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 a.enumerate(t))if(null==e)o.push(null);else{const t=()=>{var t,o;for(const e of this.tools)null===(o=null===(t=e.menu)||void 0===t?void 0:t[n])||void 0===o||o.handler()};o.push(Object.assign(Object.assign({},e),{handler:t}))}return o}}e.ToolProxy=u,u.__name__=\"ToolProxy\",u.init_ToolProxy()},\n", " function _(o,t,s,i,e){i();const n=o(20),r=o(9),l=o(13),c=o(248),h=o(235),a=o(392),_=o(319),p=o(221);class f extends c.ToolbarBase{constructor(o){super(o)}static init_ProxyToolbar(){this.define((({Array:o,Ref:t})=>({toolbars:[o(t(h.Toolbar)),[]]})))}initialize(){super.initialize(),this._merge_tools()}_merge_tools(){this._proxied_tools=[];const o={},t={},s={},i=[],e=[];for(const o of this.help)r.includes(e,o.redirect)||(i.push(o),e.push(o.redirect));this._proxied_tools.push(...i),this.help=i;for(const[o,t]of l.entries(this.gestures)){o in s||(s[o]={});for(const i of t.tools)i.type in s[o]||(s[o][i.type]=[]),s[o][i.type].push(i)}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 a.ToolProxy({tools:o,active:t});return this._proxied_tools.push(s),s};for(const o of l.keys(s)){const t=this.gestures[o];t.tools=[];for(const i of l.keys(s[o])){const e=s[o][i];if(e.length>0)if(\"multi\"==o)for(const o of e){const s=n([o]);t.tools.push(s),this.connect(s.properties.active.change,(()=>this._active_change(s)))}else{const o=n(e);t.tools.push(o),this.connect(o.properties.active.change,(()=>this._active_change(o)))}}}this.actions=[];for(const[o,s]of l.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 l.values(o))t.length>0&&this.inspectors.push(n(t,!0));for(const[o,t]of l.entries(this.gestures))0!=t.tools.length&&(t.tools=r.sort_by(t.tools,(o=>o.default_order)),\"pinch\"!=o&&\"scroll\"!=o&&\"multi\"!=o&&(t.tools[0].active=!0))}}s.ProxyToolbar=f,f.__name__=\"ProxyToolbar\",f.init_ProxyToolbar();class u extends _.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 p.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})}}s.ToolbarBoxView=u,u.__name__=\"ToolbarBoxView\";class y extends _.LayoutDOM{constructor(o){super(o)}static init_ToolbarBox(){this.prototype.default_view=u,this.define((({Ref:o})=>({toolbar:[o(c.ToolbarBase)],toolbar_location:[n.Location,\"right\"]})))}}s.ToolbarBox=y,y.__name__=\"ToolbarBox\",y.init_ToolbarBox()},\n", " function _(e,n,r,t,o){t();const s=e(1),u=e(53),c=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(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(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(240),s=n(122),a=n(43),l=n(396);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=a.div({class:l.BOKEH_ROOT}),e.appendChild(d));const w=await 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=l.div({class:n.BOKEH_ROOT});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(398),r=n(19),a=n(395);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=c.parse_token(o).session_id;n in i||(i[n]={});const e=i[n];return s in e||(e[s]=c.pull_session(n,o,t)),e[s]}(n,o,l)}catch(n){const t=c.parse_token(o).session_id;throw r.logger.error(`Failed to load Bokeh session ${t}: ${n}`),n}return 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(399),l=e(400),_=e(401);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: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(399),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(!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(399),_=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(400),a=e(19),c=e(43),g=e(13),f=e(395),u=e(396),m=s.__importDefault(e(44)),p=s.__importDefault(e(253)),d=s.__importDefault(e(403));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=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!=g.size(e))throw new Error(\"embed_items_notebook expects exactly one document in docs_json\");const t=l.Document.from_json(g.values(e)[0]);for(const e of o){null!=e.notebook_comms_target&&b(e.notebook_comms_target,t);const o=u._resolve_element(e),n=u._resolve_root_elements(e);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);a.__exportStar(t(399),o),a.__exportStar(t(400),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/annotations/arrow\":55,\"models/annotations/data_annotation\":56,\"models/sources/columnar_data_source\":57,\"models/sources/data_source\":58,\"models/selections/selection\":59,\"core/selection_manager\":60,\"models/renderers/glyph_renderer\":61,\"models/renderers/data_renderer\":62,\"models/glyphs/line\":63,\"models/glyphs/xy_glyph\":64,\"core/util/projections\":65,\"models/glyphs/glyph\":98,\"core/util/bbox\":99,\"core/util/ragged_array\":100,\"core/util/spatial\":101,\"models/ranges/factor_range\":104,\"models/ranges/range\":105,\"models/glyphs/utils\":106,\"core/hittest\":107,\"models/glyphs/webgl/line\":108,\"models/glyphs/webgl/utils/index\":109,\"models/glyphs/webgl/utils/program\":110,\"models/glyphs/webgl/utils/buffer\":111,\"models/glyphs/webgl/utils/texture\":112,\"models/glyphs/webgl/base\":113,\"models/glyphs/webgl/line.vert\":114,\"models/glyphs/webgl/line.frag\":115,\"models/glyphs/patch\":116,\"models/glyphs/harea\":117,\"models/glyphs/area\":118,\"models/glyphs/varea\":119,\"models/sources/cds_view\":120,\"models/filters/filter\":121,\"core/build_views\":122,\"models/renderers/graph_renderer\":123,\"models/expressions/expression\":124,\"models/graphs/layout_provider\":125,\"models/graphs/graph_hit_test_policy\":126,\"models/glyphs/multi_line\":127,\"models/glyphs/patches\":128,\"models/selections/interaction_policy\":129,\"models/sources/column_data_source\":130,\"core/util/typed_array\":131,\"core/util/set\":132,\"models/annotations/arrow_head\":133,\"models/annotations/band\":134,\"models/annotations/upper_lower\":135,\"models/annotations/box_annotation\":136,\"models/annotations/color_bar\":137,\"models/annotations/title\":138,\"models/annotations/text_annotation\":139,\"core/layout/side_panel\":140,\"core/layout/types\":141,\"core/layout/layoutable\":142,\"core/util/text\":143,\"models/canvas/cartesian_frame\":144,\"models/scales/categorical_scale\":145,\"models/scales/scale\":146,\"models/transforms/index\":147,\"models/transforms/customjs_transform\":148,\"models/transforms/transform\":149,\"models/transforms/dodge\":150,\"models/transforms/range_transform\":151,\"models/transforms/interpolator\":152,\"models/transforms/jitter\":153,\"models/transforms/linear_interpolator\":154,\"models/transforms/step_interpolator\":155,\"models/ranges/range1d\":156,\"models/scales/log_scale\":157,\"models/scales/continuous_scale\":158,\"models/ranges/data_range1d\":159,\"models/ranges/data_range\":160,\"models/util\":161,\"models/axes/index\":162,\"models/axes/axis\":163,\"models/renderers/guide_renderer\":164,\"models/tickers/ticker\":165,\"models/formatters/tick_formatter\":166,\"core/graphics\":167,\"core/util/affine\":168,\"models/policies/labeling\":169,\"models/axes/categorical_axis\":170,\"models/tickers/categorical_ticker\":171,\"models/formatters/categorical_tick_formatter\":172,\"models/axes/continuous_axis\":173,\"models/axes/datetime_axis\":174,\"models/axes/linear_axis\":175,\"models/formatters/basic_tick_formatter\":176,\"models/tickers/basic_ticker\":177,\"models/tickers/adaptive_ticker\":178,\"models/tickers/continuous_ticker\":179,\"models/formatters/datetime_tick_formatter\":180,\"core/util/templating\":182,\"models/tickers/datetime_ticker\":185,\"models/tickers/composite_ticker\":186,\"models/tickers/days_ticker\":187,\"models/tickers/single_interval_ticker\":188,\"models/tickers/util\":189,\"models/tickers/months_ticker\":190,\"models/tickers/years_ticker\":191,\"models/axes/log_axis\":192,\"models/formatters/log_tick_formatter\":193,\"models/tickers/log_ticker\":194,\"models/axes/mercator_axis\":195,\"models/formatters/mercator_tick_formatter\":196,\"models/tickers/mercator_ticker\":197,\"models/tickers/index\":198,\"models/tickers/fixed_ticker\":199,\"models/tickers/binned_ticker\":200,\"models/mappers/scanning_color_mapper\":201,\"models/mappers/continuous_color_mapper\":202,\"models/mappers/color_mapper\":203,\"models/mappers/mapper\":204,\"models/formatters/index\":205,\"models/formatters/func_tick_formatter\":206,\"models/formatters/numeral_tick_formatter\":207,\"models/formatters/printf_tick_formatter\":208,\"models/mappers/index\":209,\"models/mappers/categorical_color_mapper\":210,\"models/mappers/categorical_mapper\":211,\"models/mappers/categorical_marker_mapper\":212,\"models/mappers/categorical_pattern_mapper\":213,\"models/mappers/linear_color_mapper\":214,\"models/mappers/log_color_mapper\":215,\"models/mappers/eqhist_color_mapper\":216,\"models/scales/index\":217,\"models/scales/linear_scale\":218,\"models/scales/linear_interpolation_scale\":219,\"models/ranges/index\":220,\"core/layout/index\":221,\"core/layout/alignments\":222,\"core/layout/grid\":223,\"core/layout/html\":224,\"core/layout/border\":225,\"models/annotations/label\":226,\"models/annotations/label_set\":227,\"models/annotations/legend\":228,\"models/annotations/legend_item\":229,\"core/vectorization\":230,\"models/annotations/poly_annotation\":231,\"models/annotations/slope\":232,\"models/annotations/span\":233,\"models/annotations/toolbar_panel\":234,\"models/tools/toolbar\":235,\"models/tools/tool\":236,\"models/tools/gestures/gesture_tool\":237,\"models/tools/button_tool\":238,\"core/dom_view\":240,\"styles/toolbar.css\":241,\"styles/icons.css\":242,\"styles/menus.css\":243,\"core/util/menus\":244,\"core/util/iterator\":245,\"models/tools/on_off_button\":246,\"models/tools/inspectors/inspect_tool\":247,\"models/tools/toolbar_base\":248,\"core/util/canvas\":249,\"core/util/svg\":250,\"models/tools/actions/action_tool\":251,\"models/tools/actions/help_tool\":252,\"styles/logo.css\":253,\"models/annotations/tooltip\":254,\"styles/tooltips.css\":255,\"models/annotations/whisker\":256,\"models/callbacks/index\":257,\"models/callbacks/customjs\":258,\"models/callbacks/callback\":259,\"models/callbacks/open_url\":260,\"models/canvas/index\":261,\"models/canvas/canvas\":262,\"core/ui_events\":263,\"core/bokeh_events\":264,\"core/util/wheel\":265,\"models/expressions/index\":266,\"models/expressions/customjs_expr\":267,\"models/expressions/stack\":268,\"models/expressions/cumsum\":269,\"models/expressions/minimum\":270,\"models/expressions/maximum\":271,\"models/filters/index\":272,\"models/filters/boolean_filter\":273,\"models/filters/customjs_filter\":274,\"models/filters/group_filter\":275,\"models/filters/index_filter\":276,\"models/glyphs/index\":277,\"models/glyphs/annular_wedge\":278,\"models/glyphs/annulus\":279,\"models/glyphs/arc\":280,\"models/glyphs/bezier\":281,\"models/glyphs/circle\":282,\"models/glyphs/webgl/markers\":283,\"models/glyphs/webgl/markers.vert\":284,\"models/glyphs/webgl/markers.frag\":285,\"models/glyphs/ellipse\":286,\"models/glyphs/ellipse_oval\":287,\"models/glyphs/center_rotatable\":288,\"models/glyphs/hbar\":289,\"models/glyphs/box\":290,\"models/glyphs/hex_tile\":291,\"models/glyphs/image\":292,\"models/glyphs/image_base\":293,\"models/glyphs/image_rgba\":294,\"models/glyphs/image_url\":295,\"core/util/image\":296,\"models/glyphs/multi_polygons\":297,\"models/glyphs/oval\":298,\"models/glyphs/quad\":299,\"models/glyphs/quadratic\":300,\"models/glyphs/ray\":301,\"models/glyphs/rect\":302,\"models/glyphs/scatter\":303,\"models/glyphs/marker\":304,\"models/glyphs/defs\":305,\"models/glyphs/segment\":306,\"models/glyphs/spline\":307,\"core/util/interpolation\":308,\"models/glyphs/step\":309,\"models/glyphs/text\":310,\"models/glyphs/vbar\":311,\"models/glyphs/wedge\":312,\"models/graphs/index\":313,\"models/graphs/static_layout_provider\":314,\"models/grids/index\":315,\"models/grids/grid\":316,\"models/layouts/index\":317,\"models/layouts/box\":318,\"models/layouts/layout_dom\":319,\"models/layouts/column\":320,\"models/layouts/grid_box\":321,\"models/layouts/html_box\":322,\"models/layouts/panel\":323,\"models/layouts/row\":324,\"models/layouts/spacer\":325,\"models/layouts/tabs\":326,\"styles/tabs.css\":327,\"styles/buttons.css\":328,\"models/layouts/widget_box\":329,\"models/plots/index\":330,\"models/plots/gmap_plot\":331,\"models/plots/plot\":332,\"models/plots/plot_canvas\":333,\"core/util/throttle\":334,\"models/plots/range_manager\":335,\"models/plots/state_manager\":336,\"models/plots/gmap_plot_canvas\":337,\"models/policies/index\":338,\"models/renderers/index\":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/tools/tool_proxy\":392,\"models/tools/toolbar_box\":393,\"document/defs\":394,\"embed/standalone\":395,\"embed/dom\":396,\"embed/server\":397,\"client/connection\":398,\"protocol/message\":399,\"protocol/receiver\":400,\"client/session\":401,\"embed/notebook\":402,\"styles/notebook.css\":403,\"protocol/index\":404,\"testing\":405,\"safely\":406}, {});});\n", "\n", " /* END bokeh.min.js */\n", " },\n", " \n", " function(Bokeh) {\n", " /* BEGIN bokeh-widgets.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.3.3\");\n", " })(this, function(Bokeh, version) {\n", " var 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", " 417: function _(t,e,i,o,r){o();const s=t(1).__importStar(t(418));i.Widgets=s;t(7).register_models(s)},\n", " 418: function _(t,e,o,r,u){r(),u(\"AbstractButton\",t(419).AbstractButton),u(\"AbstractIcon\",t(422).AbstractIcon),u(\"AutocompleteInput\",t(423).AutocompleteInput),u(\"Button\",t(428).Button),u(\"CheckboxButtonGroup\",t(429).CheckboxButtonGroup),u(\"CheckboxGroup\",t(431).CheckboxGroup),u(\"ColorPicker\",t(433).ColorPicker),u(\"DatePicker\",t(434).DatePicker),u(\"DateRangeSlider\",t(437).DateRangeSlider),u(\"DateSlider\",t(442).DateSlider),u(\"Div\",t(443).Div),u(\"Dropdown\",t(446).Dropdown),u(\"FileInput\",t(447).FileInput),u(\"InputWidget\",t(426).InputWidget),u(\"Markup\",t(444).Markup),u(\"MultiSelect\",t(448).MultiSelect),u(\"Paragraph\",t(449).Paragraph),u(\"PasswordInput\",t(450).PasswordInput),u(\"MultiChoice\",t(451).MultiChoice),u(\"NumericInput\",t(454).NumericInput),u(\"PreText\",t(455).PreText),u(\"RadioButtonGroup\",t(456).RadioButtonGroup),u(\"RadioGroup\",t(457).RadioGroup),u(\"RangeSlider\",t(458).RangeSlider),u(\"Select\",t(459).Select),u(\"Slider\",t(460).Slider),u(\"Spinner\",t(461).Spinner),u(\"TextInput\",t(424).TextInput),u(\"TextAreaInput\",t(462).TextAreaInput),u(\"Toggle\",t(463).Toggle),u(\"Widget\",t(488).Widget)},\n", " 419: function _(t,e,n,i,s){i();const l=t(1),o=t(20),r=t(43),c=t(122),u=t(420),_=t(422),a=l.__importStar(t(328)),b=a;class d extends u.ControlView{*controls(){yield this.button_el}async lazy_initialize(){await super.lazy_initialize();const{icon:t}=this.model;null!=t&&(this.icon_view=await c.build_view(t,{parent:this}))}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.render()))}remove(){null!=this.icon_view&&this.icon_view.remove(),super.remove()}styles(){return[...super.styles(),a.default]}_render_button(...t){return r.button({type:\"button\",disabled:this.model.disabled,class:[b.btn,b[`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?r.prepend(this.button_el,this.icon_view.el,r.nbsp()):r.prepend(this.button_el,this.icon_view.el),this.icon_view.render()),this.group_el=r.div({class:b.btn_group},this.button_el),this.el.appendChild(this.group_el)}click(){}}n.AbstractButtonView=d,d.__name__=\"AbstractButtonView\";class h extends u.Control{constructor(t){super(t)}static init_AbstractButton(){this.define((({String:t,Ref:e,Nullable:n})=>({label:[t,\"Button\"],icon:[n(e(_.AbstractIcon)),null],button_type:[o.ButtonType,\"default\"]})))}}n.AbstractButton=h,h.__name__=\"AbstractButton\",h.init_AbstractButton()},\n", " 420: function _(t,e,o,s,n){s();const i=t(488),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())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", " 488: function _(i,t,e,o,n){o();const s=i(322),r=i(20);class d extends s.HTMLBoxView{_width_policy(){return\"horizontal\"==this.model.orientation?super._width_policy():\"fixed\"}_height_policy(){return\"horizontal\"==this.model.orientation?\"fixed\":super._height_policy()}box_sizing(){const i=super.box_sizing();return\"horizontal\"==this.model.orientation?null==i.width&&(i.width=this.model.default_size):null==i.height&&(i.height=this.model.default_size),i}}e.WidgetView=d,d.__name__=\"WidgetView\";class _ extends s.HTMLBox{constructor(i){super(i)}static init_Widget(){this.define((({Number:i})=>({orientation:[r.Orientation,\"horizontal\"],default_size:[i,300]}))),this.override({margin:[5,5,5,5]})}}e.Widget=_,_.__name__=\"Widget\",_.init_Widget()},\n", " 422: function _(c,t,s,n,e){n();const o=c(53),_=c(240);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", " 423: function _(e,t,n,i,s){i();const h=e(1),o=e(424),_=e(43),u=e(10),r=h.__importStar(e(243)),c=r;class l extends o.TextInputView{constructor(){super(...arguments),this._open=!1,this._last_value=\"\",this._hover_index=0}styles(){return[...super.styles(),r.default]}render(){super.render(),this.input_el.addEventListener(\"keydown\",(e=>this._keydown(e))),this.input_el.addEventListener(\"keyup\",(e=>this._keyup(e))),this.menu=_.div({class:[c.menu,c.below]}),this.menu.addEventListener(\"click\",(e=>this._menu_click(e))),this.menu.addEventListener(\"mouseover\",(e=>this._menu_hover(e))),this.el.appendChild(this.menu),_.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){_.empty(this.menu);for(const t of e){const e=_.div({},t);this.menu.appendChild(e)}e.length>0&&this.menu.children[0].classList.add(c.active)}_show_menu(){if(!this._open){this._open=!0,this._hover_index=0,this._last_value=this.model.value,_.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,_.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(c.active),this._hover_index=u.clamp(e,0,t-1),this.menu.children[this._hover_index].classList.add(c.active))}_keydown(e){}_keyup(e){switch(e.keyCode){case _.Keys.Enter:this.change_input();break;case _.Keys.Esc:this._hide_menu();break;case _.Keys.Up:this._bump_hover(this._hover_index-1);break;case _.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)i(n).startsWith(i(e))&&t.push(n);this._update_completions(t),0==t.length?this._hide_menu():this._show_menu()}}}}n.AutocompleteInputView=l,l.__name__=\"AutocompleteInputView\";class a extends o.TextInput{constructor(e){super(e)}static init_AutocompleteInput(){this.prototype.default_view=l,this.define((({Boolean:e,Int:t,String:n,Array:i})=>({completions:[i(n),[]],min_characters:[t,2],case_sensitive:[e,!0],restrict:[e,!0]})))}}n.AutocompleteInput=a,a.__name__=\"AutocompleteInput\",a.init_AutocompleteInput()},\n", " 424: function _(t,e,n,i,p){i();const _=t(1),u=t(425),s=t(43),x=_.__importStar(t(427));class a extends u.TextLikeInputView{_render_input(){this.input_el=s.input({type:\"text\",class:x.input})}}n.TextInputView=a,a.__name__=\"TextInputView\";class c extends u.TextLikeInput{constructor(t){super(t)}static init_TextInput(){this.prototype.default_view=a}}n.TextInput=c,c.__name__=\"TextInput\",c.init_TextInput()},\n", " 425: function _(e,t,n,i,l){i();const s=e(426);class h extends s.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=h,h.__name__=\"TextLikeInputView\";class a extends s.InputWidget{constructor(e){super(e)}static init_TextLikeInput(){this.define((({Int:e,String:t,Nullable:n})=>({value:[t,\"\"],value_input:[t,\"\"],placeholder:[t,\"\"],max_length:[n(e),null]})))}}n.TextLikeInput=a,a.__name__=\"TextLikeInput\",a.init_TextLikeInput()},\n", " 426: function _(t,e,i,n,s){n();const l=t(1),o=t(420),r=t(43),_=l.__importStar(t(427)),p=_;class d extends o.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(),_.default]}render(){super.render();const{title:t}=this.model;this.label_el=r.label({style:{display:0==t.length?\"none\":\"\"}},t),this.group_el=r.div({class:p.input_group},this.label_el),this.el.appendChild(this.group_el)}change_input(){}}i.InputWidgetView=d,d.__name__=\"InputWidgetView\";class u extends o.Control{constructor(t){super(t)}static init_InputWidget(){this.define((({String:t})=>({title:[t,\"\"]})))}}i.InputWidget=u,u.__name__=\"InputWidget\",u.init_InputWidget()},\n", " 427: function _(o,i,t,n,p){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;-webkit-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;display:-webkit-inline-flex;flex-wrap:nowrap;-webkit-flex-wrap:nowrap;align-items:start;-webkit-align-items:start;flex-direction:column;-webkit-flex-direction:column;white-space:nowrap;}.bk-root .bk-input-group.bk-inline{flex-direction:row;-webkit-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", " 428: function _(t,e,n,i,o){i();const s=t(419),u=t(264);class c extends s.AbstractButtonView{click(){this.model.trigger_event(new u.ButtonClick),super.click()}}n.ButtonView=c,c.__name__=\"ButtonView\";class _ extends s.AbstractButton{constructor(t){super(t)}static init_Button(){this.prototype.default_view=c,this.override({label:\"Button\"})}}n.Button=_,_.__name__=\"Button\",_.init_Button()},\n", " 429: function _(t,e,o,i,c){i();const n=t(1),s=t(430),a=t(43),u=n.__importStar(t(328));class r extends s.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)=>{a.classes(e).toggle(u.active,t.has(o))}))}}o.CheckboxButtonGroupView=r,r.__name__=\"CheckboxButtonGroupView\";class _ extends s.ButtonGroup{constructor(t){super(t)}static init_CheckboxButtonGroup(){this.prototype.default_view=r,this.define((({Int:t,Array:e})=>({active:[e(t),[]]})))}}o.CheckboxButtonGroup=_,_.__name__=\"CheckboxButtonGroup\",_.init_CheckboxButtonGroup()},\n", " 430: function _(t,e,n,s,i){s();const o=t(1),r=t(420),u=t(20),a=t(43),_=o.__importStar(t(328)),l=_;class c extends r.ControlView{*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(),_.default]}render(){super.render(),this._buttons=this.model.labels.map(((t,e)=>{const n=a.div({class:[l.btn,l[`btn_${this.model.button_type}`]],disabled:this.model.disabled},t);return n.addEventListener(\"click\",(()=>this.change_active(e))),n})),this._update_active();const t=a.div({class:l.btn_group},this._buttons);this.el.appendChild(t)}}n.ButtonGroupView=c,c.__name__=\"ButtonGroupView\";class d extends r.Control{constructor(t){super(t)}static init_ButtonGroup(){this.define((({String:t,Array:e})=>({labels:[e(t),[]],button_type:[u.ButtonType,\"default\"]})))}}n.ButtonGroup=d,d.__name__=\"ButtonGroup\",d.init_ButtonGroup()},\n", " 431: function _(e,t,i,n,s){n();const o=e(1),c=e(432),a=e(43),l=e(9),d=o.__importStar(e(427));class h extends c.InputGroupView{render(){super.render();const e=a.div({class:[d.input_group,this.model.inline?d.inline:null]});this.el.appendChild(e);const{active:t,labels:i}=this.model;this._inputs=[];for(let n=0;nthis.change_active(n))),this._inputs.push(s),this.model.disabled&&(s.disabled=!0),l.includes(t,n)&&(s.checked=!0);const o=a.label({},s,a.span({},i[n]));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()}}i.CheckboxGroupView=h,h.__name__=\"CheckboxGroupView\";class p extends c.InputGroup{constructor(e){super(e)}static init_CheckboxGroup(){this.prototype.default_view=h,this.define((({Boolean:e,Int:t,String:i,Array:n})=>({active:[n(t),[]],labels:[n(i),[]],inline:[e,!1]})))}}i.CheckboxGroup=p,p.__name__=\"CheckboxGroup\",p.init_CheckboxGroup()},\n", " 432: function _(n,t,e,s,o){s();const r=n(1),u=n(420),c=r.__importDefault(n(427));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", " 433: function _(e,i,t,n,o){n();const s=e(1),l=e(426),r=e(43),c=e(22),a=s.__importStar(e(427));class d extends l.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=c.color2hexrgb(this.model.color))),this.connect(this.model.properties.disabled.change,(()=>this.input_el.disabled=this.model.disabled))}render(){super.render(),this.input_el=r.input({type:\"color\",class:a.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()}}t.ColorPickerView=d,d.__name__=\"ColorPickerView\";class h extends l.InputWidget{constructor(e){super(e)}static init_ColorPicker(){this.prototype.default_view=d,this.define((({Color:e})=>({color:[e,\"#000000\"]})))}}t.ColorPicker=h,h.__name__=\"ColorPicker\",h.init_ColorPicker()},\n", " 434: function _(e,t,i,n,s){n();const a=e(1),l=a.__importDefault(e(435)),o=e(426),d=e(43),r=e(20),c=e(8),h=a.__importStar(e(427)),u=a.__importDefault(e(436));function _(e){const t=[];for(const i of e)if(c.isString(i))t.push(i);else{const[e,n]=i;t.push({from:e,to:n})}return t}class p extends o.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(),u.default]}render(){var e,t;null==this._picker&&(super.render(),this.input_el=d.input({type:\"text\",class:h.input,disabled:this.model.disabled}),this.group_el.appendChild(this.input_el),this._picker=l.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:_(this.model.disabled_dates),enable:_(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=p,p.__name__=\"DatePickerView\";class m extends o.InputWidget{constructor(e){super(e)}static init_DatePicker(){this.prototype.default_view=p,this.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:[r.CalendarPosition,\"auto\"],inline:[e,!1]}}))}}i.DatePicker=m,m.__name__=\"DatePicker\",m.init_DatePicker()},\n", " 435: 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:r,step:o,title:n}=this.model.properties;this.on_change([s,l,r,o],(()=>{const{start:t,end:e,value:i,step:s}=this._calc_to();this.noUiSlider.updateOptions({range:{min:t,max:e},start:i,step:s})}));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([r,n,d],(()=>this._update_title()))}styles(){return[...super.styles(),u.default,c.default]}_update_title(){var t;n.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(n.span({class:m.slider_value},e))}}_set_bar_color(){if(!this.model.disabled){this.slider_el.querySelector(\".noUi-connect\").style.backgroundColor=d.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=a.repeat(t,i.length)}else l=!1;if(null==this.slider_el){this.slider_el=n.div(),o.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 r=(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)=>r(e,!0))),this.noUiSlider.on(\"end\",((t,e)=>r(e,!1)))}else this.noUiSlider.updateOptions({range:{min:t,max:e},start:i,step:s});this._set_bar_color(),this.model.disabled?this.slider_el.setAttribute(\"disabled\",\"true\"):this.slider_el.removeAttribute(\"disabled\"),this.title_el=n.div({class:m.slider_title}),this._update_title(),this.group_el=n.div({class:p.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 v 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=v,v.__name__=\"AbstractSliderView\";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 t}}i.AbstractRangeSliderView=g,g.__name__=\"AbstractRangeSliderView\";class S extends _.Control{constructor(t){super(t),this.connected=!1}static init_AbstractSlider(){this.define((({Any:t,Boolean:e,Number:i,String:s,Color:l,Or:r,Enum:o,Ref:n,Nullable:a})=>({title:[a(s),\"\"],show_value:[e,!0],start:[t],end:[t],value:[t],value_throttled:[t],step:[i,1],format:[r(s,n(h.TickFormatter))],direction:[o(\"ltr\",\"rtl\"),\"ltr\"],tooltips:[e,!0],bar_color:[l,\"#e6e6e6\"]})))}pretty(t){return this._formatter(t,this.format)}}i.AbstractSlider=S,S.__name__=\"AbstractSlider\",S.init_AbstractSlider()},\n", " 439: function _(t,e,r,n,i){\n", " /*! nouislider - 14.6.3 - 11/19/2020 */\n", " var o;o=function(){\"use strict\";var t=\"14.6.3\";function e(t){t.parentElement.removeChild(t)}function r(t){return null!=t}function n(t){t.preventDefault()}function i(t){return\"number\"==typeof t&&!isNaN(t)&&isFinite(t)}function o(t,e,r){r>0&&(u(t,e),setTimeout((function(){c(t,e)}),r))}function s(t){return Math.max(Math.min(t,100),0)}function a(t){return Array.isArray(t)?t:[t]}function l(t){var e=(t=String(t)).split(\".\");return e.length>1?e[1].length:0}function u(t,e){t.classList&&!/\\s/.test(e)?t.classList.add(e):t.className+=\" \"+e}function c(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 p(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 f(t,e){return 100/(e-t)}function d(t,e,r){return 100*e/(t[r+1]-t[r])}function h(t,e){for(var r=1;t>=e[r];)r+=1;return r}function m(t,e,r){if(r>=t.slice(-1)[0])return 100;var n=h(r,t),i=t[n-1],o=t[n],s=e[n-1],a=e[n];return s+function(t,e){return d(t,t[0]<0?e+Math.abs(t[0]):e-t[0],0)}([i,o],r)/f(s,a)}function g(t,e,r,n){if(100===n)return n;var i=h(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}function v(t,e,r){var n;if(\"number\"==typeof e&&(e=[e]),!Array.isArray(e))throw new Error(\"noUiSlider (14.6.3): 'range' contains invalid value.\");if(!i(n=\"min\"===t?0:\"max\"===t?100:parseFloat(t))||!i(e[0]))throw new Error(\"noUiSlider (14.6.3): 'range' value isn't numeric.\");r.xPct.push(n),r.xVal.push(e[0]),n?r.xSteps.push(!isNaN(e[1])&&e[1]):isNaN(e[1])||(r.xSteps[0]=e[1]),r.xHighestCompleteStep.push(0)}function b(t,e,r){if(e)if(r.xVal[t]!==r.xVal[t+1]){r.xSteps[t]=d([r.xVal[t],r.xVal[t+1]],e,0)/f(r.xPct[t],r.xPct[t+1]);var n=(r.xVal[t+1]-r.xVal[t])/r.xNumSteps[t],i=Math.ceil(Number(n.toFixed(3))-1),o=r.xVal[t]+r.xNumSteps[t]*i;r.xHighestCompleteStep[t]=o}else r.xSteps[t]=r.xHighestCompleteStep[t]=r.xVal[t]}function x(t,e,r){var n;this.xPct=[],this.xVal=[],this.xSteps=[r||!1],this.xNumSteps=[!1],this.xHighestCompleteStep=[],this.snap=e;var i=[];for(n in t)t.hasOwnProperty(n)&&i.push([t[n],n]);for(i.length&&\"object\"==typeof i[0][0]?i.sort((function(t,e){return t[0][0]-e[0][0]})):i.sort((function(t,e){return t[0]-e[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++;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},x.prototype.toStepping=function(t){return t=m(this.xVal,this.xPct,t)},x.prototype.fromStepping=function(t){return function(t,e,r){if(r>=100)return t.slice(-1)[0];var n=h(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)*f(s,e[n]))}(this.xVal,this.xPct,t)},x.prototype.getStep=function(t){return t=g(this.xPct,this.xSteps,this.snap,t)},x.prototype.getDefaultStep=function(t,e,r){var n=h(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},x.prototype.getNearbySteps=function(t){var e=h(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]}}},x.prototype.countStepDecimals=function(){var t=this.xNumSteps.map(l);return Math.max.apply(null,t)},x.prototype.convert=function(t){return this.getStep(this.toStepping(t))};var S={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\"},y=\".__tooltips\",E=\".__aria\";function C(t){if(function(t){return\"object\"==typeof t&&\"function\"==typeof t.to&&\"function\"==typeof t.from}(t))return!0;throw new Error(\"noUiSlider (14.6.3): 'format' requires 'to' and 'from' methods.\")}function P(t,e){if(!i(e))throw new Error(\"noUiSlider (14.6.3): 'step' is not numeric.\");t.singleStep=e}function N(t,e){if(!i(e))throw new Error(\"noUiSlider (14.6.3): 'keyboardPageMultiplier' is not numeric.\");t.keyboardPageMultiplier=e}function k(t,e){if(!i(e))throw new Error(\"noUiSlider (14.6.3): 'keyboardDefaultStep' is not numeric.\");t.keyboardDefaultStep=e}function U(t,e){if(\"object\"!=typeof e||Array.isArray(e))throw new Error(\"noUiSlider (14.6.3): 'range' is not an object.\");if(void 0===e.min||void 0===e.max)throw new Error(\"noUiSlider (14.6.3): Missing 'min' or 'max' in 'range'.\");if(e.min===e.max)throw new Error(\"noUiSlider (14.6.3): 'range' 'min' and 'max' cannot be equal.\");t.spectrum=new x(e,t.snap,t.singleStep)}function A(t,e){if(e=a(e),!Array.isArray(e)||!e.length)throw new Error(\"noUiSlider (14.6.3): 'start' option is incorrect.\");t.handles=e.length,t.start=e}function V(t,e){if(t.snap=e,\"boolean\"!=typeof e)throw new Error(\"noUiSlider (14.6.3): 'snap' option must be a boolean.\")}function D(t,e){if(t.animate=e,\"boolean\"!=typeof e)throw new Error(\"noUiSlider (14.6.3): 'animate' option must be a boolean.\")}function M(t,e){if(t.animationDuration=e,\"number\"!=typeof e)throw new Error(\"noUiSlider (14.6.3): 'animationDuration' option must be a number.\")}function O(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 (14.6.3): '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 (14.6.3): 'direction' option was not recognized.\")}}function R(t,e){if(\"string\"!=typeof e)throw new Error(\"noUiSlider (14.6.3): '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;if(i){if(2!==t.handles)throw new Error(\"noUiSlider (14.6.3): 'fixed' behaviour must be used with 2 handles\");z(t,t.start[1]-t.start[0])}if(a&&(t.margin||t.limit))throw new Error(\"noUiSlider (14.6.3): 'unconstrained' behaviour cannot be used with margin or limit\");t.events={tap:r||o,drag:n,fixed:i,snap:o,hover:s,unconstrained:a}}function T(t,e){if(!1!==e)if(!0===e){t.tooltips=[];for(var r=0;r0&&((a=L(i,!1)).className=c(s,r.cssClasses.value),a.setAttribute(\"data-value\",o),a.style[r.style]=t+\"%\",a.innerHTML=n.to(o))}}(o,t[o][0],t[o][1])})),i}function q(){h&&(e(h),h=null)}function X(t){q();var e=t.mode,r=t.density||1,n=t.filter||!1,i=function(t,e,r){if(\"range\"===t||\"steps\"===t)return C.xVal;if(\"count\"===t){if(e<2)throw new Error(\"noUiSlider (14.6.3): 'values' (>= 2) required for mode 'count'.\");var n=e-1,i=100/n;for(e=[];n--;)e[n]=n*i;e.push(100),t=\"positions\"}return\"positions\"===t?e.map((function(t){return C.fromStepping(r?C.getStep(t):t)})):\"values\"===t?r?e.map((function(t){return C.fromStepping(C.getStep(C.toStepping(t)))})):e:void 0}(e,t.values||!1,t.stepped||!1),o=function(t,e,r){var n,i={},o=C.xVal[0],s=C.xVal[C.xVal.length-1],a=!1,l=!1,u=0;return n=r.slice().sort((function(t,e){return t-e})),(r=n.filter((function(t){return!this[t]&&(this[t]=!0)}),{}))[0]!==o&&(r.unshift(o),a=!0),r[r.length-1]!==s&&(r.push(s),l=!0),r.forEach((function(n,o){var s,c,p,f,d,h,m,g,v,b,x=n,S=r[o+1],w=\"steps\"===e;if(w&&(s=C.xNumSteps[o]),s||(s=S-x),!1!==x)for(void 0===S&&(S=x),s=Math.max(s,1e-7),c=x;c<=S;c=(c+s).toFixed(7)/1){for(g=(d=(f=C.toStepping(c))-u)/t,b=d/(v=Math.round(g)),p=1;p<=v;p+=1)i[(h=u+p*b).toFixed(5)]=[C.fromStepping(h),0];m=r.indexOf(c)>-1?1:w?2:0,!o&&a&&c!==S&&(m=0),c===S&&l||(i[f.toFixed(5)]=[c,m]),u=f}})),i}(r,e,i),s=t.format||{to:Math.round};return h=w.appendChild(B(o,n,s))}function Y(){var t=l.getBoundingClientRect(),e=\"offset\"+[\"Width\",\"Height\"][r.ort];return 0===r.ort?t.width||l[e]:t.height||l[e]}function I(t,e,n,i){var o=function(o){return!!(o=function(t,e,r){var n,i,o=0===t.type.indexOf(\"touch\"),s=0===t.type.indexOf(\"mouse\"),a=0===t.type.indexOf(\"pointer\");if(0===t.type.indexOf(\"MSPointer\")&&(a=!0),\"mousedown\"===t.type&&!t.buttons&&!t.touches)return!1;if(o){var l=function(t){return t.target===r||r.contains(t.target)||t.target.shadowRoot&&t.target.shadowRoot.contains(r)};if(\"touchstart\"===t.type){var u=Array.prototype.filter.call(t.touches,l);if(u.length>1)return!1;n=u[0].pageX,i=u[0].pageY}else{var c=Array.prototype.find.call(t.changedTouches,l);if(!c)return!1;n=c.pageX,i=c.pageY}}return e=e||p(V),(s||a)&&(n=t.clientX+e.x,i=t.clientY+e.y),t.pageOffset=e,t.points=[n,i],t.cursor=s||a,t}(o,i.pageOffset,i.target||e))&&!(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!==o.buttons&&o.buttons>1)&&(!i.hover||!o.buttons)&&(S||o.preventDefault(),o.calcPoint=o.points[r.ort],void n(o,i)));var s,a},s=[];return t.split(\" \").forEach((function(t){e.addEventListener(t,o,!!S&&{passive:!0}),s.push([t,o])})),s}function $(t){var e,n,i,o,a,u,c=100*(t-(e=l,n=r.ort,i=e.getBoundingClientRect(),o=e.ownerDocument,a=o.documentElement,u=p(o),/webkit.*Chrome.*Mobile/i.test(navigator.userAgent)&&(u.x=0),n?i.top+u.y-a.clientTop:i.left+u.x-a.clientLeft))/Y();return c=s(c),r.dir?100-c:c}function G(t,e){\"mouseout\"===t.type&&\"HTML\"===t.target.nodeName&&null===t.relatedTarget&&K(t,e)}function J(t,e){if(-1===navigator.appVersion.indexOf(\"MSIE 9\")&&0===t.buttons&&0!==e.buttonsProperty)return K(t,e);var n=(r.dir?-1:1)*(t.calcPoint-e.startCalcPoint);st(n>0,100*n/e.baseSize,e.locations,e.handleNumbers)}function K(t,e){e.handle&&(c(e.handle,r.cssClasses.active),U-=1),e.listeners.forEach((function(t){D.removeEventListener(t[0],t[1])})),0===U&&(c(w,r.cssClasses.drag),lt(),t.cursor&&(M.style.cursor=\"\",M.removeEventListener(\"selectstart\",n))),e.handleNumbers.forEach((function(t){nt(\"change\",t),nt(\"set\",t),nt(\"end\",t)}))}function Q(t,e){if(e.handleNumbers.some(R))return!1;var i;1===e.handleNumbers.length&&(i=f[e.handleNumbers[0]].children[0],U+=1,u(i,r.cssClasses.active)),t.stopPropagation();var o=[],s=I(x.move,D,J,{target:t.target,handle:i,listeners:o,startCalcPoint:t.calcPoint,baseSize:Y(),pageOffset:t.pageOffset,handleNumbers:e.handleNumbers,buttonsProperty:t.buttons,locations:N.slice()}),a=I(x.end,D,K,{target:t.target,handle:i,listeners:o,doNotReject:!0,handleNumbers:e.handleNumbers}),l=I(\"mouseout\",D,G,{target:t.target,handle:i,listeners:o,doNotReject:!0,handleNumbers:e.handleNumbers});o.push.apply(o,s.concat(a,l)),t.cursor&&(M.style.cursor=getComputedStyle(t.target).cursor,f.length>1&&u(w,r.cssClasses.drag),M.addEventListener(\"selectstart\",n,!1)),e.handleNumbers.forEach((function(t){nt(\"start\",t)}))}function Z(t){t.stopPropagation();var e=$(t.calcPoint),n=function(t){var e=100,r=!1;return f.forEach((function(n,i){if(!R(i)){var o=N[i],s=Math.abs(o-t);(so||100===s&&100===e)&&(r=i,e=s)}})),r}(e);if(!1===n)return!1;r.events.snap||o(w,r.cssClasses.tap,r.animationDuration),ut(n,e,!0,!0),lt(),nt(\"slide\",n,!0),nt(\"update\",n,!0),nt(\"change\",n,!0),nt(\"set\",n,!0),r.events.snap&&Q(t,{handleNumbers:[n]})}function tt(t){var e=$(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(g,n)}))}))}function et(t,e){A[t]=A[t]||[],A[t].push(e),\"update\"===t.split(\".\")[0]&&f.forEach((function(t,e){nt(\"update\",e)}))}function rt(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===E||t===y}(i)&&r!==i||delete A[t]}))}function nt(t,e,n){Object.keys(A).forEach((function(i){var o=i.split(\".\")[0];t===o&&A[i].forEach((function(t){t.call(g,P.map(r.format.to),e,P.slice(),n||!1,N.slice(),g)}))}))}function it(t,e,n,i,o,a){var l;return f.length>1&&!r.events.unconstrained&&(i&&e>0&&(l=C.getAbsoluteDistance(t[e-1],r.margin,0),n=Math.max(n,l)),o&&e1&&r.limit&&(i&&e>0&&(l=C.getAbsoluteDistance(t[e-1],r.limit,0),n=Math.min(n,l)),o&&e1?n.forEach((function(t,r){var n=it(i,t,i[t]+e,o[r],s[r],!1);!1===n?e=0:(e=n-i[t],i[t]=n)})):o=s=[!0];var a=!1;n.forEach((function(t,n){a=ut(t,r[t]+e,o[n],s[n])||a})),a&&n.forEach((function(t){nt(\"update\",t),nt(\"slide\",t)}))}function at(t,e){return r.dir?100-t-e:t}function lt(){k.forEach((function(t){var e=N[t]>50?-1:1,r=3+(f.length+e*t);f[t].style.zIndex=r}))}function ut(t,e,n,i,o){return o||(e=it(N,t,e,n,i,!1)),!1!==e&&(function(t,e){N[t]=e,P[t]=C.fromStepping(e);var n=\"translate(\"+ot(10*(at(e,0)-O)+\"%\",\"0\")+\")\";f[t].style[r.transformRule]=n,ct(t),ct(t+1)}(t,e),!0)}function ct(t){if(d[t]){var e=0,n=100;0!==t&&(e=N[t-1]),t!==d.length-1&&(n=N[t]);var i=n-e,o=\"translate(\"+ot(at(e,i)+\"%\",\"0\")+\")\",s=\"scale(\"+ot(i/100,\"1\")+\")\";d[t].style[r.transformRule]=o+\" \"+s}}function pt(t,e){return null===t||!1===t||void 0===t?N[e]:(\"number\"==typeof t&&(t=String(t)),t=r.format.from(t),!1===(t=C.toStepping(t))||isNaN(t)?N[e]:t)}function ft(t,e,n){var i=a(t),s=void 0===N[0];e=void 0===e||!!e,r.animate&&!s&&o(w,r.cssClasses.tap,r.animationDuration),k.forEach((function(t){ut(t,pt(i[t],t),!0,!1,n)}));for(var l=1===k.length?0:1;ln.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]}return u(v=w,r.cssClasses.target),0===r.dir?u(v,r.cssClasses.ltr):u(v,r.cssClasses.rtl),0===r.ort?u(v,r.cssClasses.horizontal):u(v,r.cssClasses.vertical),u(v,\"rtl\"===getComputedStyle(v).direction?r.cssClasses.textDirectionRtl:r.cssClasses.textDirectionLtr),l=L(v,r.cssClasses.base),function(t,e){var n=L(e,r.cssClasses.connects);f=[],(d=[]).push(H(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", " 442: function _(t,e,i,r,a){r();const s=t(1).__importDefault(t(181)),d=t(438),_=t(8);class n extends d.AbstractSliderView{}i.DateSliderView=n,n.__name__=\"DateSliderView\";class l extends d.AbstractSlider{constructor(t){super(t),this.behaviour=\"tap\",this.connected=[!0,!1]}static init_DateSlider(){this.prototype.default_view=n,this.override({format:\"%d %b %Y\"})}_formatter(t,e){return _.isString(e)?s.default(t,e):e.compute(t)}}i.DateSlider=l,l.__name__=\"DateSlider\",l.init_DateSlider()},\n", " 443: function _(e,t,i,n,s){n();const r=e(444);class _ extends r.MarkupView{render(){super.render(),this.model.render_as_text?this.markup_el.textContent=this.model.text:this.markup_el.innerHTML=this.model.text}}i.DivView=_,_.__name__=\"DivView\";class a extends r.Markup{constructor(e){super(e)}static init_Div(){this.prototype.default_view=_,this.define((({Boolean:e})=>({render_as_text:[e,!1]})))}}i.Div=a,a.__name__=\"Div\",a.init_Div()},\n", " 444: function _(t,e,s,i,a){i();const n=t(1),l=t(224),r=t(43),c=t(488),u=n.__importStar(t(445));class _ extends c.WidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>{this.layout.invalidate_cache(),this.render(),this.root.compute_layout()}))}styles(){return[...super.styles(),u.default]}_update_layout(){this.layout=new l.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=r.div({class:u.clearfix,style:t}),this.el.appendChild(this.markup_el)}}s.MarkupView=_,_.__name__=\"MarkupView\";class o extends c.Widget{constructor(t){super(t)}static init_Markup(){this.define((({String:t,Dict:e})=>({text:[t,\"\"],style:[e(t),{}]})))}}s.Markup=o,o.__name__=\"Markup\",o.init_Markup()},\n", " 445: 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", " 446: function _(e,t,i,n,s){n();const o=e(1),r=e(419),l=e(264),d=e(43),_=e(8),u=o.__importStar(e(328)),c=o.__importStar(e(243)),h=c;class p extends r.AbstractButtonView{constructor(){super(...arguments),this._open=!1}styles(){return[...super.styles(),c.default]}render(){super.render();const e=d.div({class:[h.caret,h.down]});if(this.model.is_split){const t=this._render_button(e);t.classList.add(u.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 d.div({class:h.divider});{const i=_.isString(e)?e:e[0],n=d.div({},i);return n.addEventListener(\"click\",(()=>this._item_click(t))),n}}));this.menu=d.div({class:[h.menu,h.below]},t),this.el.appendChild(this.menu),d.undisplay(this.menu)}_show_menu(){if(!this._open){this._open=!0,d.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,d.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 l.ButtonClick),super.click()):this._toggle_menu()}_item_click(e){this._hide_menu();const t=this.model.menu[e];if(null!=t){const i=_.isString(t)?t:t[1];_.isString(i)?this.model.trigger_event(new l.MenuItemClick(i)):i.execute(this.model,{index:e})}}}i.DropdownView=p,p.__name__=\"DropdownView\";class m extends r.AbstractButton{constructor(e){super(e)}static init_Dropdown(){this.prototype.default_view=p,this.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)),[]]}))),this.override({label:\"Dropdown\"})}get is_split(){return this.split}}i.Dropdown=m,m.__name__=\"Dropdown\",m.init_Dropdown()},\n", " 447: function _(e,i,l,t,s){t();const n=e(43),a=e(488);class o extends a.WidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.render()))}render(){const{multiple:e,accept:i,disabled:l,width:t}=this.model;null==this.dialog_el&&(this.dialog_el=n.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!=i&&\"\"!=i&&(this.dialog_el.accept=i),this.dialog_el.style.width=`${t}px`,this.dialog_el.disabled=l}async load_files(e){const i=[],l=[],t=[];for(const s of e){const e=await this._read_file(s),[,n=\"\",,a=\"\"]=e.split(/[:;,]/,4);i.push(a),l.push(s.name),t.push(n)}this.model.multiple?(this.model.value=i,this.model.filename=l,this.model.mime_type=t):(this.model.value=i[0],this.model.filename=l[0],this.model.mime_type=t[0])}_read_file(e){return new Promise(((i,l)=>{const t=new FileReader;t.onload=()=>{var s;const{result:n}=t;null!=n?i(n):l(null!==(s=t.error)&&void 0!==s?s:new Error(`unable to read '${e.name}'`))},t.readAsDataURL(e)}))}}l.FileInputView=o,o.__name__=\"FileInputView\";class d extends a.Widget{constructor(e){super(e)}static init_FileInput(){this.prototype.default_view=o,this.define((({Boolean:e,String:i,Array:l,Or:t})=>({value:[t(i,l(i)),\"\"],mime_type:[t(i,l(i)),\"\"],filename:[t(i,l(i)),\"\"],accept:[i,\"\"],multiple:[e,!1]})))}}l.FileInput=d,d.__name__=\"FileInput\",d.init_FileInput()},\n", " 448: function _(e,t,i,s,n){s();const l=e(1),o=e(43),r=e(8),c=e(426),h=l.__importStar(e(427));class p extends c.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 r.isString(e)?t=i=e:[t,i]=e,o.option({value:t},i)}));this.input_el=o.select({multiple:!0,class:h.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=p,p.__name__=\"MultiSelectView\";class u extends c.InputWidget{constructor(e){super(e)}static init_MultiSelect(){this.prototype.default_view=p,this.define((({Int:e,String:t,Array:i,Tuple:s,Or:n})=>({value:[i(t),[]],options:[i(n(t,s(t,t))),[]],size:[e,4]})))}}i.MultiSelect=u,u.__name__=\"MultiSelect\",u.init_MultiSelect()},\n", " 449: function _(a,r,e,t,p){t();const s=a(444),i=a(43);class n extends s.MarkupView{render(){super.render();const a=i.p({style:{margin:0}},this.model.text);this.markup_el.appendChild(a)}}e.ParagraphView=n,n.__name__=\"ParagraphView\";class _ extends s.Markup{constructor(a){super(a)}static init_Paragraph(){this.prototype.default_view=n}}e.Paragraph=_,_.__name__=\"Paragraph\",_.init_Paragraph()},\n", " 450: function _(s,t,e,n,r){n();const p=s(424);class u extends p.TextInputView{render(){super.render(),this.input_el.type=\"password\"}}e.PasswordInputView=u,u.__name__=\"PasswordInputView\";class a extends p.TextInput{constructor(s){super(s)}static init_PasswordInput(){this.prototype.default_view=u}}e.PasswordInput=a,a.__name__=\"PasswordInput\",a.init_PasswordInput()},\n", " 451: function _(e,t,i,l,s){l();const o=e(1),n=o.__importDefault(e(452)),h=e(43),a=e(8),u=e(224),c=o.__importStar(e(427)),d=o.__importDefault(e(453)),_=e(426);class r extends _.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,delete_button:l,placeholder:s,options:o,name:n,title:h}=this.model.properties;this.on_change([e,t,i,l,s,o,n,h],(()=>this.render()))}styles(){return[...super.styles(),d.default]}_update_layout(){this.layout=new u.CachedVariadicBox(this.el),this.layout.set_sizing(this.box_sizing())}render(){super.render(),this.input_el=h.select({multiple:!0,class:c.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 a.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),this.choice_el=new n.default(this.input_el,o);const u=()=>this.choice_el.containerOuter.element.getBoundingClientRect().height;null!=this._last_height&&this._last_height!=u()&&this.root.invalidate_layout(),this._last_height=u(),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=r,r.__name__=\"MultiChoiceView\";class m extends _.InputWidget{constructor(e){super(e)}static init_MultiChoice(){this.prototype.default_view=r,this.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],solid:[e,!0]})))}}i.MultiChoice=m,m.__name__=\"MultiChoice\",m.init_MultiChoice()},\n", " 452: 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&&d.assert(t<=l,\"Invalid bounds, low must be inferior to high\"),null!=e&&null!=t&&(this.model.value=Math.max(e,t))})),this.connect(this.model.properties.high.change,(()=>{const{value:e,low:t,high:l}=this.model;null!=t&&null!=l&&d.assert(l>=t,\"Invalid bounds, high must be superior to low\"),null!=e&&null!=l&&(this.model.value=Math.min(e,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=a.input({type:\"text\",class:p.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=>_.test(e))):\"float\"==this.model.mode&&this._set_input_filter((e=>m.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=c,c.__name__=\"NumericInputView\";class v extends h.InputWidget{constructor(e){super(e)}static init_NumericInput(){this.prototype.default_view=c,this.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(o.TickFormatter))),null],low:[s(e),null],high:[s(e),null]})))}_formatter(e,t){return r.isString(t)?u.format(e,t):t.doFormat([e],{loc:0})[0]}pretty(e){return null!=this.format?this._formatter(e,this.format):`${e}`}}l.NumericInput=v,v.__name__=\"NumericInput\",v.init_NumericInput()},\n", " 455: function _(e,t,r,s,i){s();const n=e(444),_=e(43);class a extends n.MarkupView{render(){super.render();const e=_.pre({style:{overflow:\"auto\"}},this.model.text);this.markup_el.appendChild(e)}}r.PreTextView=a,a.__name__=\"PreTextView\";class o extends n.Markup{constructor(e){super(e)}static init_PreText(){this.prototype.default_view=a}}r.PreText=o,o.__name__=\"PreText\",o.init_PreText()},\n", " 456: function _(t,o,i,e,a){e();const n=t(1),u=t(430),s=t(43),c=n.__importStar(t(328));class _ extends u.ButtonGroupView{change_active(t){this.model.active!==t&&(this.model.active=t)}_update_active(){const{active:t}=this.model;this._buttons.forEach(((o,i)=>{s.classes(o).toggle(c.active,t===i)}))}}i.RadioButtonGroupView=_,_.__name__=\"RadioButtonGroupView\";class r extends u.ButtonGroup{constructor(t){super(t)}static init_RadioButtonGroup(){this.prototype.default_view=_,this.define((({Int:t,Nullable:o})=>({active:[o(t),null]})))}}i.RadioButtonGroup=r,r.__name__=\"RadioButtonGroup\",r.init_RadioButtonGroup()},\n", " 457: function _(e,i,t,n,a){n();const s=e(1),o=e(43),l=e(34),d=e(432),p=s.__importStar(e(427));class u extends d.InputGroupView{render(){super.render();const e=o.div({class:[p.input_group,this.model.inline?p.inline:null]});this.el.appendChild(e);const i=l.uniqueId(),{active:t,labels:n}=this.model;this._inputs=[];for(let a=0;athis.change_active(a))),this._inputs.push(s),this.model.disabled&&(s.disabled=!0),a==t&&(s.checked=!0);const l=o.label({},s,o.span({},n[a]));e.appendChild(l)}}change_active(e){this.model.active=e}}t.RadioGroupView=u,u.__name__=\"RadioGroupView\";class r extends d.InputGroup{constructor(e){super(e)}static init_RadioGroup(){this.prototype.default_view=u,this.define((({Boolean:e,Int:i,String:t,Array:n,Nullable:a})=>({active:[a(i),null],labels:[n(t),[]],inline:[e,!1]})))}}t.RadioGroup=r,r.__name__=\"RadioGroup\",r.init_RadioGroup()},\n", " 458: function _(e,t,i,r,a){r();const n=e(1).__importStar(e(183)),s=e(438),_=e(8);class d extends s.AbstractRangeSliderView{}i.RangeSliderView=d,d.__name__=\"RangeSliderView\";class o extends s.AbstractSlider{constructor(e){super(e),this.behaviour=\"drag\",this.connected=[!1,!0,!1]}static init_RangeSlider(){this.prototype.default_view=d,this.override({format:\"0[.]00\"})}_formatter(e,t){return _.isString(t)?n.format(e,t):t.compute(e)}}i.RangeSlider=o,o.__name__=\"RangeSlider\",o.init_RangeSlider()},\n", " 459: function _(e,t,n,i,s){i();const l=e(1),u=e(43),a=e(8),o=e(13),_=e(426),p=l.__importStar(e(427));class r 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,(()=>{u.empty(this.input_el),u.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,i;return a.isString(t)?n=i=t:[n,i]=t,e.add(n),u.option({value:n},i)}))}e.clear();const{options:n}=this.model;return a.isArray(n)?t(n):o.entries(n).map((([e,n])=>u.optgroup({label:e},t(n))))}render(){super.render(),this.input_el=u.select({class:p.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=r,r.__name__=\"SelectView\";class c extends _.InputWidget{constructor(e){super(e)}static init_Select(){this.prototype.default_view=r,this.define((({String:e,Array:t,Tuple:n,Dict:i,Or:s})=>{const l=t(s(e,n(e,e)));return{value:[e,\"\"],options:[s(l,i(l)),[]]}}))}}n.Select=c,c.__name__=\"Select\",c.init_Select()},\n", " 460: function _(t,e,i,r,s){r();const _=t(1).__importStar(t(183)),a=t(438),n=t(8);class o extends a.AbstractSliderView{}i.SliderView=o,o.__name__=\"SliderView\";class d extends a.AbstractSlider{constructor(t){super(t),this.behaviour=\"tap\",this.connected=[!0,!1]}static init_Slider(){this.prototype.default_view=o,this.override({format:\"0[.]00\"})}_formatter(t,e){return n.isString(e)?_.format(t,e):e.compute(t)}}i.Slider=d,d.__name__=\"Slider\",d.init_Slider()},\n", " 461: function _(e,t,i,n,s){n();const l=e(454),o=e(43),{min:r,max:a,floor:h,abs:_}=Math;function u(e){return h(e)!==e?e.toFixed(16).replace(/0+$/,\"\").split(\".\")[1].length:0}class d extends l.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())o.toggle_attribute(e,\"disabled\",this.model.disabled)}))}render(){super.render(),this.wrapper_el=o.div({class:\"bk-spin-wrapper\"}),this.group_el.replaceChild(this.wrapper_el,this.input_el),this.btn_up_el=o.button({class:\"bk-spin-btn bk-spin-btn-up\"}),this.btn_down_el=o.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())o.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=u;return a(n(_(null!=e?e:0)),n(_(null!=t?t:0)),n(_(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 o.Keys.Up:return e.preventDefault(),this.increment(this.model.step);case o.Keys.Down:return e.preventDefault(),this.increment(-this.model.step);case o.Keys.PageUp:return e.preventDefault(),this.increment(this.model.page_step_multiplier*this.model.step);case o.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?r(0,i):0:e<0&&(this.model.value=null!=i?i:null!=t?a(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=d,d.__name__=\"SpinnerView\";class p extends l.NumericInput{constructor(e){super(e)}static init_Spinner(){this.prototype.default_view=d,this.define((({Number:e,Nullable:t})=>({value_throttled:[t(e),null],step:[e,1],page_step_multiplier:[e,10],wheel_wait:[e,100]}))),this.override({mode:\"float\"})}}i.Spinner=p,p.__name__=\"Spinner\",p.init_Spinner()},\n", " 462: function _(e,t,s,n,i){n();const r=e(1),o=e(425),p=e(43),c=r.__importStar(e(427));class l extends o.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=p.textarea({class:c.input})}render(){super.render(),this.input_el.cols=this.model.cols,this.input_el.rows=this.model.rows}}s.TextAreaInputView=l,l.__name__=\"TextAreaInputView\";class _ extends o.TextLikeInput{constructor(e){super(e)}static init_TextAreaInput(){this.prototype.default_view=l,this.define((({Int:e})=>({cols:[e,20],rows:[e,2]}))),this.override({max_length:500})}}s.TextAreaInput=_,_.__name__=\"TextAreaInput\",_.init_TextAreaInput()},\n", " 463: function _(e,t,i,s,c){s();const o=e(1),a=e(419),n=e(43),l=o.__importStar(e(328));class _ extends a.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(){n.classes(this.button_el).toggle(l.active,this.model.active)}}i.ToggleView=_,_.__name__=\"ToggleView\";class g extends a.AbstractButton{constructor(e){super(e)}static init_Toggle(){this.prototype.default_view=_,this.define((({Boolean:e})=>({active:[e,!1]}))),this.override({label:\"Toggle\"})}}i.Toggle=g,g.__name__=\"Toggle\",g.init_Toggle()},\n", " }, 417, {\"models/widgets/main\":417,\"models/widgets/index\":418,\"models/widgets/abstract_button\":419,\"models/widgets/control\":420,\"models/widgets/widget\":488,\"models/widgets/abstract_icon\":422,\"models/widgets/autocomplete_input\":423,\"models/widgets/text_input\":424,\"models/widgets/text_like_input\":425,\"models/widgets/input_widget\":426,\"styles/widgets/inputs.css\":427,\"models/widgets/button\":428,\"models/widgets/checkbox_button_group\":429,\"models/widgets/button_group\":430,\"models/widgets/checkbox_group\":431,\"models/widgets/input_group\":432,\"models/widgets/color_picker\":433,\"models/widgets/date_picker\":434,\"styles/widgets/flatpickr.css\":436,\"models/widgets/date_range_slider\":437,\"models/widgets/abstract_slider\":438,\"styles/widgets/sliders.css\":440,\"styles/widgets/nouislider.css\":441,\"models/widgets/date_slider\":442,\"models/widgets/div\":443,\"models/widgets/markup\":444,\"styles/clearfix.css\":445,\"models/widgets/dropdown\":446,\"models/widgets/file_input\":447,\"models/widgets/multiselect\":448,\"models/widgets/paragraph\":449,\"models/widgets/password_input\":450,\"models/widgets/multichoice\":451,\"styles/widgets/choices.css\":453,\"models/widgets/numeric_input\":454,\"models/widgets/pretext\":455,\"models/widgets/radio_button_group\":456,\"models/widgets/radio_group\":457,\"models/widgets/range_slider\":458,\"models/widgets/selectbox\":459,\"models/widgets/slider\":460,\"models/widgets/spinner\":461,\"models/widgets/textarea_input\":462,\"models/widgets/toggle\":463}, {});});\n", "\n", " /* END bokeh-widgets.min.js */\n", " },\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.3.3\");\n", " })(this, function(Bokeh, version) {\n", " var 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", " 464: function _(t,e,o,r,s){r();const _=t(1).__importStar(t(465));o.Tables=_;t(7).register_models(_)},\n", " 465: function _(g,a,r,e,t){e();const o=g(1);o.__exportStar(g(466),r),o.__exportStar(g(469),r),t(\"DataTable\",g(472).DataTable),t(\"TableColumn\",g(490).TableColumn),t(\"TableWidget\",g(489).TableWidget);var n=g(492);t(\"AvgAggregator\",n.AvgAggregator),t(\"MinAggregator\",n.MinAggregator),t(\"MaxAggregator\",n.MaxAggregator),t(\"SumAggregator\",n.SumAggregator);var A=g(493);t(\"GroupingInfo\",A.GroupingInfo),t(\"DataCube\",A.DataCube)},\n", " 466: function _(e,t,i,s,r){s();const a=e(1),n=e(43),l=e(240),u=e(53),d=e(467),o=a.__importStar(e(468));class _ extends l.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(o.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 n.Keys.Left:case n.Keys.Right:case n.Keys.Up:case n.Keys.Down:case n.Keys.PageUp:case n.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[d.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=_,_.__name__=\"CellEditorView\";class c extends u.Model{}i.CellEditor=c,c.__name__=\"CellEditor\";class p extends _{get emptyValue(){return\"\"}_createInput(){return n.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=p,p.__name__=\"StringEditorView\";class h extends c{static init_StringEditor(){this.prototype.default_view=p,this.define((({String:e,Array:t})=>({completions:[t(e),[]]})))}}i.StringEditor=h,h.__name__=\"StringEditor\",h.init_StringEditor();class E extends _{_createInput(){return n.textarea()}renderEditor(){this.inputEl.focus(),this.inputEl.select()}}i.TextEditorView=E,E.__name__=\"TextEditorView\";class V extends c{static init_TextEditor(){this.prototype.default_view=E}}i.TextEditor=V,V.__name__=\"TextEditor\",V.init_TextEditor();class m extends _{_createInput(){return n.select()}renderEditor(){for(const e of this.model.options)this.inputEl.appendChild(n.option({value:e},e));this.focus()}}i.SelectEditorView=m,m.__name__=\"SelectEditorView\";class f extends c{static init_SelectEditor(){this.prototype.default_view=m,this.define((({String:e,Array:t})=>({options:[t(e),[]]})))}}i.SelectEditor=f,f.__name__=\"SelectEditor\",f.init_SelectEditor();class x extends _{_createInput(){return n.input({type:\"text\"})}}i.PercentEditorView=x,x.__name__=\"PercentEditorView\";class g extends c{static init_PercentEditor(){this.prototype.default_view=x}}i.PercentEditor=g,g.__name__=\"PercentEditor\",g.init_PercentEditor();class w extends _{_createInput(){return n.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=w,w.__name__=\"CheckboxEditorView\";class v extends c{static init_CheckboxEditor(){this.prototype.default_view=w}}i.CheckboxEditor=v,v.__name__=\"CheckboxEditor\",v.init_CheckboxEditor();class y extends _{_createInput(){return n.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=y,y.__name__=\"IntEditorView\";class I extends c{static init_IntEditor(){this.prototype.default_view=y,this.define((({Int:e})=>({step:[e,1]})))}}i.IntEditor=I,I.__name__=\"IntEditor\",I.init_IntEditor();class b extends _{_createInput(){return n.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=b,b.__name__=\"NumberEditorView\";class N extends c{static init_NumberEditor(){this.prototype.default_view=b,this.define((({Number:e})=>({step:[e,.01]})))}}i.NumberEditor=N,N.__name__=\"NumberEditor\",N.init_NumberEditor();class S extends _{_createInput(){return n.input({type:\"text\"})}}i.TimeEditorView=S,S.__name__=\"TimeEditorView\";class C extends c{static init_TimeEditor(){this.prototype.default_view=S}}i.TimeEditor=C,C.__name__=\"TimeEditor\",C.init_TimeEditor();class D extends _{_createInput(){return n.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=D,D.__name__=\"DateEditorView\";class T extends c{static init_DateEditor(){this.prototype.default_view=D}}i.DateEditor=T,T.__name__=\"DateEditor\",T.init_DateEditor()},\n", " 467: function _(_,n,i,t,d){t(),i.DTINDEX_NAME=\"__bkdt_internal_index__\"},\n", " 468: 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", " 469: function _(t,e,r,a,n){a();const i=t(1),o=i.__importDefault(t(181)),s=i.__importStar(t(183)),l=t(470),c=t(43),m=t(20),u=t(8),_=t(34),F=t(22),d=t(53);class f extends d.Model{constructor(t){super(t)}doFormat(t,e,r,a,n){return null==r?\"\":(r+\"\").replace(/&/g,\"&\").replace(//g,\">\")}}r.CellFormatter=f,f.__name__=\"CellFormatter\";class h extends f{constructor(t){super(t)}static init_StringFormatter(){this.define((({Color:t,Nullable:e})=>({font_style:[m.FontStyle,\"normal\"],text_align:[m.TextAlign,\"left\"],text_color:[e(t),null]})))}doFormat(t,e,r,a,n){const{font_style:i,text_align:o,text_color:s}=this,l=c.div({},null==r?\"\":`${r}`);switch(i){case\"bold\":l.style.fontWeight=\"bold\";break;case\"italic\":l.style.fontStyle=\"italic\"}return null!=o&&(l.style.textAlign=o),null!=s&&(l.style.color=F.color2css(s)),l.outerHTML}}r.StringFormatter=h,h.__name__=\"StringFormatter\",h.init_StringFormatter();class g extends h{constructor(t){super(t)}static init_ScientificFormatter(){this.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]})))}get scientific_limit_low(){return 10**this.power_limit_low}get scientific_limit_high(){return 10**this.power_limit_high}doFormat(t,e,r,a,n){const i=Math.abs(r)<=this.scientific_limit_low||Math.abs(r)>=this.scientific_limit_high;let o=this.precision;return o<1&&(o=1),r=null!=r&&!isNaN(r)||null==this.nan_format?0==r?_.to_fixed(r,1):i?r.toExponential(o):_.to_fixed(r,o):this.nan_format,super.doFormat(t,e,r,a,n)}}r.ScientificFormatter=g,g.__name__=\"ScientificFormatter\",g.init_ScientificFormatter();class p extends h{constructor(t){super(t)}static init_NumberFormatter(){this.define((({String:t,Nullable:e})=>({format:[t,\"0,0\"],language:[t,\"en\"],rounding:[m.RoundingFunction,\"round\"],nan_format:[e(t),null]})))}doFormat(t,e,r,a,n){const{format:i,language:o,nan_format:l}=this,c=(()=>{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==l?s.format(r,i,o,c):l,super.doFormat(t,e,r,a,n)}}r.NumberFormatter=p,p.__name__=\"NumberFormatter\",p.init_NumberFormatter();class S extends f{constructor(t){super(t)}static init_BooleanFormatter(){this.define((({String:t})=>({icon:[t,\"check\"]})))}doFormat(t,e,r,a,n){return r?c.i({class:this.icon}).outerHTML:\"\"}}r.BooleanFormatter=S,S.__name__=\"BooleanFormatter\",S.init_BooleanFormatter();class b extends h{constructor(t){super(t)}static init_DateFormatter(){this.define((({String:t,Nullable:e})=>({format:[t,\"ISO-8601\"],nan_format:[e(t),null]})))}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,a,n){const{nan_format:i}=this;let s;return s=null!=(r=u.isString(r)?parseInt(r,10):r)&&!isNaN(r)&&-9223372036854776!==r||null==i?null==r?\"\":o.default(r,this.getFormat()):i,super.doFormat(t,e,s,a,n)}}r.DateFormatter=b,b.__name__=\"DateFormatter\",b.init_DateFormatter();class x extends f{constructor(t){super(t)}static init_HTMLTemplateFormatter(){this.define((({String:t})=>({template:[t,\"<%= value %>\"]})))}doFormat(t,e,r,a,n){const{template:i}=this;if(null==r)return\"\";return l._.template(i)(Object.assign(Object.assign({},n),{value:r}))}}r.HTMLTemplateFormatter=x,x.__name__=\"HTMLTemplateFormatter\",x.init_HTMLTemplateFormatter()},\n", " 470: function _(e,n,t,f,i){var o=e(471),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", " 471: 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", " 472: function _(e,t,i,s,o){s();const n=e(1),l=e(473),r=e(477),d=e(478),a=e(479),h=e(34),u=e(8),c=e(9),_=e(13),m=e(19),g=e(488),p=e(467),f=e(489),b=e(490),w=n.__importStar(e(468)),x=w,C=n.__importDefault(e(491));i.AutosizeModes={fit_columns:\"FCV\",fit_viewport:\"FVC\",force_fit:\"LFF\",none:\"NOA\"};let z=!1;class v{constructor(e,t){this.init(e,t)}init(e,t){if(p.DTINDEX_NAME in e.data)throw new Error(`special name ${p.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 _.keys(this.source.data))t[i]=this.source.data[i][this.index[e]];return t[p.DTINDEX_NAME]=this.index[e],t}getField(e,t){return t==p.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 c.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,c.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=[[p.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 u.isNumber(t)&&u.isNumber(r)?l*(t-r||+isNaN(t)-+isNaN(r)):`${t}`>`${r}`?l:-l}return 0}))}}i.TableDataProvider=v,v.__name__=\"TableDataProvider\";class A extends g.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()))}remove(){var e;null===(e=this.grid)||void 0===e||e.destroy(),super.remove()}styles(){return[...super.styles(),C.default,w.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:h.uniqueId(),name:this.model.index_header,field:p.DTINDEX_NAME,width:this.model.index_width,behavior:\"select\",cannotTriggerInsert:!0,resizable:!1,selectable:!1,sortable:!0,cssClass:x.cell_index,headerCssClass:x.header_index}}css_classes(){return super.css_classes().concat(x.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.map((e=>Object.assign(Object.assign({},e.toColumn()),{parent:this})));let s=null;if(\"checkbox\"==this.model.selectable&&(s=new r.CheckboxSelectColumn({cssClass:x.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||(m.logger.warn(\"jquery-ui is required to enable DataTable.reorderable\"),z=!0),o=!1);let n=-1,h=!1;const{frozen_rows:c,frozen_columns:_}=this.model,g=null==_?-1:_-1;null!=c&&(h=c<0,n=Math.abs(c));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:g,frozenRow:n,frozenBottom:h},f=null!=this.grid;if(this.data=new v(this.model.source,this.model.view),this.grid=new a.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 l.RowSelectionModel({selectActiveRow:null==s})),null!=s&&this.grid.registerPlugin(s);const e={dataItemColumnValueExtractor(e,t){let i=e[t.field];return u.isString(i)&&(i=i.replace(/\\n/g,\"\\\\n\")),i},includeHeaderWhenCopying:!1};this.grid.registerPlugin(new d.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=A,A.__name__=\"DataTableView\";class D extends f.TableWidget{constructor(e){super(e),this._sort_columns=[]}get sort_columns(){return this._sort_columns}static init_DataTable(){this.prototype.default_view=A,this.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(b.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]}))),this.override({width:600,height:400})}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?c.some(t,(t=>e.top<=t&&t<=e.bottom))?null:Math.max(0,Math.min(...t)-1):null}}i.DataTable=D,D.__name__=\"DataTable\",D.init_DataTable()},\n", " 473: function _(e,t,n,o,r){var l=e(474),i=e(476);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?\"�\":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(j=O.call(w.childNodes),w.childNodes),j[w.childNodes.length].nodeType}catch(e){H={apply:j.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.namespaceURI,n=(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&&D.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))).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 D(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(D(this,e||[],!1))},not:function(e){return this.pushStack(D(this,e||[],!0))},is:function(e){return!!D(this,\"string\"==typeof e&&k.test(e)?w(e):e||[],!1).length}});var j,q=/^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]+))$/;(w.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||j,\"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,j=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=/^key/,Te=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Ce=/^([^.]*)(?:\\.(.+)|)/;function Ee(){return!0}function Se(){return!1}function ke(e,t){return e===function(){try{return v.activeElement}catch(e){}}()==(\"focus\"===t)}function Ae(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)Ae(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=Se;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return w().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=w.guid++)),e.each((function(){w.event.add(this,t,i,r,n)}))}function Ne(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.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,Ee)}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=Ce.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=Ce.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 Le(e,t){return A(e,\"table\")&&A(11!==t.nodeType?t:t.firstChild,\"tr\")&&w(e).children(\"tbody\")[0]||e}function He(e){return e.type=(null!==e.getAttribute(\"type\"))+\"/\"+e.type,e}function Oe(e){return\"true/\"===(e.type||\"\").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute(\"type\"),e}function Pe(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&&je.test(v))return e.each((function(i){var o=e.eq(i);y&&(t[0]=v.call(this,i,o.html())),Me(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\"),He)).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 Ie(this,e,!0)},remove:function(e){return Ie(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 Me(this,arguments,(function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||Le(this,e).appendChild(e)}))},prepend:function(){return Me(this,arguments,(function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Le(this,e);t.insertBefore(e,t.firstChild)}}))},before:function(){return Me(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this)}))},after:function(){return Me(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&&!De.test(e)&&!ve[(he.exec(e)||[\"\",\"\"])[1].toLowerCase()]){e=w.htmlPrefilter(e);try{for(;n3,re.removeChild(t)),s}}))}();var Ue=[\"Webkit\",\"Moz\",\"ms\"],Xe=v.createElement(\"div\").style,Ve={};function Ge(e){var t=w.cssProps[e]||Ve[e];return t||(e in Xe?e:Ve[e]=function(e){for(var t=e[0].toUpperCase()+e.slice(1),n=Ue.length;n--;)if((e=Ue[n]+t)in Xe)return e}(e)||e)}var Ye=/^(none|table(?!-c[ea]).+)/,Qe=/^--/,Je={position:\"absolute\",visibility:\"hidden\",display:\"block\"},Ke={letterSpacing:\"0\",fontWeight:\"400\"};function Ze(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||\"px\"):t}function et(e,t,n,r,i,o){var a=\"width\"===t?1:0,s=0,u=0;if(n===(r?\"border\":\"content\"))return 0;for(;a<4;a+=2)\"margin\"===n&&(u+=w.css(e,n+ne[a],!0,i)),r?(\"content\"===n&&(u-=w.css(e,\"padding\"+ne[a],!0,i)),\"margin\"!==n&&(u-=w.css(e,\"border\"+ne[a]+\"Width\",!0,i))):(u+=w.css(e,\"padding\"+ne[a],!0,i),\"padding\"!==n?u+=w.css(e,\"border\"+ne[a]+\"Width\",!0,i):s+=w.css(e,\"border\"+ne[a]+\"Width\",!0,i));return!r&&o>=0&&(u+=Math.max(0,Math.ceil(e[\"offset\"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function tt(e,t,n){var r=Fe(e),i=(!d.boxSizingReliable()||n)&&\"border-box\"===w.css(e,\"boxSizing\",!1,r),o=i,a=_e(e,t,r),s=\"offset\"+t[0].toUpperCase()+t.slice(1);if(We.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)+et(e,t,n||(i?\"border\":\"content\"),o,r,a)+\"px\"}function nt(e,t,n,r,i){return new nt.prototype.init(e,t,n,r,i)}w.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=_e(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=Qe.test(t),l=e.style;if(u||(t=Ge(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 Qe.test(t)||(t=Ge(s)),(a=w.cssHooks[t]||w.cssHooks[s])&&\"get\"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=_e(e,t,r)),\"normal\"===i&&t in Ke&&(i=Ke[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!Ye.test(w.css(e,\"display\"))||e.getClientRects().length&&e.getBoundingClientRect().width?tt(e,t,r):Be(e,Je,(function(){return tt(e,t,r)}))},set:function(e,n,r){var i,o=Fe(e),a=!d.scrollboxSize()&&\"absolute\"===o.position,s=(a||r)&&\"border-box\"===w.css(e,\"boxSizing\",!1,o),u=r?et(e,t,r,s,o):0;return s&&a&&(u-=Math.ceil(e[\"offset\"+t[0].toUpperCase()+t.slice(1)]-parseFloat(o[t])-et(e,t,\"border\",!1,o)-.5)),u&&(i=te.exec(n))&&\"px\"!==(i[3]||\"px\")&&(e.style[t]=n,n=w.css(e,t)),Ze(0,n,u)}}})),w.cssHooks.marginLeft=ze(d.reliableMarginLeft,(function(e,t){if(t)return(parseFloat(_e(e,\"marginLeft\"))||e.getBoundingClientRect().left-Be(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=Ze)})),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=Fe(e),i=t.length;a1)}}),w.Tween=nt,nt.prototype={constructor:nt,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=nt.propHooks[this.prop];return e&&e.get?e.get(this):nt.propHooks._default.get(this)},run:function(e){var t,n=nt.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):nt.propHooks._default.set(this),this}},nt.prototype.init.prototype=nt.prototype,nt.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[Ge(e.prop)]?e.elem[e.prop]=e.now:w.style(e.elem,e.prop,e.now+e.unit)}}},nt.propHooks.scrollTop=nt.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=nt.prototype.init,w.fx.step={};var rt,it,ot=/^(?:toggle|show|hide)$/,at=/queueHooks$/;function st(){it&&(!1===v.hidden&&e.requestAnimationFrame?e.requestAnimationFrame(st):e.setTimeout(st,w.fx.interval),w.fx.tick())}function ut(){return e.setTimeout((function(){rt=void 0})),rt=Date.now()}function lt(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 ct(e,t,n){for(var r,i=(ft.tweeners[t]||[]).concat(ft.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)?pt: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)}}),pt={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=dt[t]||w.find.attr;dt[t]=function(e,t,r){var i,o,a=t.toLowerCase();return r||(o=dt[a],dt[a]=i,i=null!=n(e,t,r)?a:null,dt[a]=o),i}}));var ht=/^(?:input|select|textarea|button)$/i,gt=/^(?:a|area)$/i;function vt(e){return(e.match(P)||[]).join(\" \")}function yt(e){return e.getAttribute&&e.getAttribute(\"class\")||\"\"}function mt(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):ht.test(e.nodeName)||gt.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,yt(this)))}));if((t=mt(e)).length)for(;n=this[u++];)if(i=yt(n),r=1===n.nodeType&&\" \"+vt(i)+\" \"){for(a=0;o=t[a++];)r.indexOf(\" \"+o+\" \")<0&&(r+=o+\" \");i!==(s=vt(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,yt(this)))}));if(!arguments.length)return this.attr(\"class\",\"\");if((t=mt(e)).length)for(;n=this[u++];)if(i=yt(n),r=1===n.nodeType&&\" \"+vt(i)+\" \"){for(a=0;o=t[a++];)for(;r.indexOf(\" \"+o+\" \")>-1;)r=r.replace(\" \"+o+\" \",\" \");i!==(s=vt(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,yt(this),t),t)})):this.each((function(){var t,i,o,a;if(r)for(i=0,o=w(this),a=mt(e);t=a[i++];)o.hasClass(t)?o.removeClass(t):o.addClass(t);else void 0!==e&&\"boolean\"!==n||((t=yt(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&&(\" \"+vt(yt(n))+\" \").indexOf(t)>-1)return!0;return!1}});var xt=/\\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(xt,\"\"):null==n?\"\":n:void 0}}),w.extend({valHooks:{option:{get:function(e){var t=w.find.attr(e,\"value\");return null!=t?t:vt(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 bt=/^(?:focusinfocus|focusoutblur)$/,wt=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&&!bt.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,bt.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,wt),r[m](),t.isPropagationStopped()&&d.removeEventListener(m,wt),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 Tt=e.location,Ct={guid:Date.now()},Et=/\\?/;w.parseXML=function(t){var n;if(!t||\"string\"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,\"text/xml\")}catch(e){n=void 0}return n&&!n.getElementsByTagName(\"parsererror\").length||w.error(\"Invalid XML: \"+t),n};var St=/\\[\\]$/,kt=/\\r?\\n/g,At=/^(?:submit|button|image|reset|file)$/i,Nt=/^(?:input|select|textarea|keygen)/i;function Dt(e,t,n,r){var i;if(Array.isArray(t))w.each(t,(function(t,i){n||St.test(e)?r(e,i):Dt(e+\"[\"+(\"object\"==typeof i&&null!=i?t:\"\")+\"]\",i,n,r)}));else if(n||\"object\"!==x(t))r(e,t);else for(i in t)Dt(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)Dt(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\")&&Nt.test(this.nodeName)&&!At.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(kt,\"\\r\\n\")}})):{name:t.name,value:n.replace(kt,\"\\r\\n\")}})).get()}});var jt=/%20/g,qt=/#.*$/,Lt=/([?&])_=[^&]*/,Ht=/^(.*?):[ \\t]*([^\\r\\n]*)$/gm,Ot=/^(?:GET|HEAD)$/,Pt=/^\\/\\//,Rt={},Mt={},It=\"*/\".concat(\"*\"),Wt=v.createElement(\"a\");function Ft(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 Bt(e,t,n,r){var i={},o=e===Mt;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 $t(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}Wt.href=Tt.href,w.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Tt.href,type:\"GET\",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(Tt.protocol),global:!0,processData:!0,async:!0,contentType:\"application/x-www-form-urlencoded; charset=UTF-8\",accepts:{\"*\":It,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?$t($t(e,w.ajaxSettings),t):$t(w.ajaxSettings,e)},ajaxPrefilter:Ft(Rt),ajaxTransport:Ft(Mt),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=Ht.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||Tt.href)+\"\").replace(Pt,Tt.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=Wt.protocol+\"//\"+Wt.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)),Bt(Rt,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=!Ot.test(d.type),i=d.url.replace(qt,\"\"),d.hasContent?d.data&&d.processData&&0===(d.contentType||\"\").indexOf(\"application/x-www-form-urlencoded\")&&(d.data=d.data.replace(jt,\"+\")):(p=d.url.slice(i.length),d.data&&(d.processData||\"string\"==typeof d.data)&&(i+=(Et.test(i)?\"&\":\"?\")+d.data,delete d.data),!1===d.cache&&(i=i.replace(Lt,\"$1\"),p=(Et.test(i)?\"&\":\"?\")+\"_=\"+Ct.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]?\", \"+It+\"; 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=Bt(Mt,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&&(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 _t={0:200,1223:204},zt=w.ajaxSettings.xhr();d.cors=!!zt&&\"withCredentials\"in zt,d.ajax=zt=!!zt,w.ajaxTransport((function(t){var n,r;if(d.cors||zt&&!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(_t[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": [ "Column\n", " [0] HoloViews(DynamicMap, widget_location='bottom', widget_type='scrubber')\n", " [1] Row\n", " [0] HSpacer()\n", " [1] WidgetBox\n", " [0] Player(end=11, width=550)\n", " [2] HSpacer()" ] }, "execution_count": 10, "metadata": { "application/vnd.holoviews_exec.v0+json": { "id": "1002" } }, "output_type": "execute_result" } ], "source": [ "hv.extension(\"bokeh\")\n", "ds.NDVI.hvplot(\n", " groupby=\"time\", clim=(0, 1), cmap=\"YlGn\", \n", " frame_height=600, aspect=0.8, \n", " widget_location=\"bottom\", widget_type=\"scrubber\",\n", ")" ] } ], "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.9.6" }, "widgets": { "application/vnd.jupyter.widget-state+json": { "state": { "01089a83eded470ca7a0dc42e0a40d52": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_2d731ca3b8d94e1c8047d3ba5009da3c", "max": 12, "style": "IPY_MODEL_c3a44e05e692471988f22dc71b494693", "value": 12 } }, "01b0a93b131e46649fed72db9442cc03": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "0321077fa3c3459882d681362bcdab93": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_f962814ef3014b8aba4ac740b1185ac0", "style": "IPY_MODEL_f2850d88b68d46f299c22c5a4ff21b12", "value": "Downloading collection: 7%" } }, "0378a83834a64e75bce9098825df91a2": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "058eb42c331c466ab66c6723ad0c1ab4": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_c75f39b203354f9080d8cd4c44799e9f", "style": "IPY_MODEL_9463ff7440404206aac26408fce0e6b5", "value": "Downloading data: 100%" } }, "05af09dbd51044d5b518c448cb1a3591": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "05e25e2cba5e4ec696d1dfa2914222c5": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_2e0a6881223841ab94c6c271c3e0fa8f", "style": "IPY_MODEL_4f6b9c71a1b84adbbdd37a95bc0570dd", "value": " 12/12 [00:35<00:00, 1.62s/it]" } }, "0aca1be630664e40ba9dd480b5e631ea": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_26edec6caaad4f4a856ec318b5139645", "style": "IPY_MODEL_9e94b2fb3b3547e79facfe2497eccccf", "value": " 12/12 [00:28<00:00, 1.30s/it]" } }, "0b54464a9d6045269607be0c130aae23": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "0bac76cdbadb43a88b865e913272545c": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "0c25c7a816204ad7b7201cce149b184d": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "0d61818f9e3d4ab7ba6e0ce5a5ebbeb9": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "0d788ea2245e4619987ecdc05f51cce4": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "0dfb7849ee4b43e99a288f8d545b09b6": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "0ed35c7ecd664eb69f1cbfca2ab68266": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "0fba34f464a744a5a0d681d12a5a152a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_260f8964aa8d41f1add8d9dfefe1cb7e", "max": 12, "style": "IPY_MODEL_6c60b17c2fc44bf8b0f1c15941f2d1f6", "value": 12 } }, "10ca112ce222454d87c111f2ac559caa": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "12ad87a3913d4f24890ec2ea7521974f": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_7fbe85b856b242478a9f282a6fb11a2d", "IPY_MODEL_e2801d284e4b44d8a8a64058bbcd42b7", "IPY_MODEL_0aca1be630664e40ba9dd480b5e631ea" ], "layout": "IPY_MODEL_f8c184ba98674a3b9e2d91a43d091aee" } }, "148045615c414655a3bdd3e42456770b": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "16b83d11c1484913ac59fb1c8a6b81b1": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_8f07a794ea74460a952c881ee0a0c6b1", "style": "IPY_MODEL_aba57f4c55234bf8bba6a61a9591a122", "value": "Requesting data: 100%" } }, "17b6abd24e6b4ddba747b5d5fb9b93c6": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "18ff1c4b51074520b1b41a0aacb4f508": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "1aed82889b8b4ebe9c0031795b0301ff": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "1b82a5d71a6c4a01b2f42ac059004c60": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_e589d859c7fe4a7a93f84bfa606c0523", "IPY_MODEL_5bbd9de008fd4f93b386e561f79d7304", "IPY_MODEL_8118839b53f24097b8b262b65fe3e51a" ], "layout": "IPY_MODEL_831908642d4149ae86e26bc9857bee99" } }, "1d78fc7cb2ea48ab8eac88a39d04bff1": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_9c77d80d3dd64af4af78e3600355ed84", "style": "IPY_MODEL_17b6abd24e6b4ddba747b5d5fb9b93c6", "value": "Downloading data: 100%" } }, "1f7e087fdc314ae7af0e1ba06df794b2": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "1fdef5ebfd0044c9bc6651957cd0a697": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_690106aaecc940b5abb5bd5139bb0a66", "IPY_MODEL_8f18d1b5a31a4796b8e8d8c3a40712f5", "IPY_MODEL_500327293160483e8aa923db47768af5" ], "layout": "IPY_MODEL_b1525fc3944e4416a750800e22d2c599" } }, "1fe675466e4e466bbd1620f20c2bb25c": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_2bdfbb2ae1fe41c294d74df03225849a", "max": 12, "style": "IPY_MODEL_689c37e6d9da456681f7314eb07714a2", "value": 12 } }, "207e51f753454df0a5518603206f5d54": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "217d8c4cf2444480a1e21aa7c1a37659": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_b0574241ca2e403d828ed12e26973948", "style": "IPY_MODEL_18ff1c4b51074520b1b41a0aacb4f508", "value": "Requesting data: 100%" } }, "22249722ca4a46d9a3d79af842fabb8b": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "2521564b5ede4f099e2769797b4bbdfa": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "260f8964aa8d41f1add8d9dfefe1cb7e": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "26edec6caaad4f4a856ec318b5139645": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "26f978a57034472a927e0dae3979a800": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "2748cec5cb1f45c6b0157f9b6ce9ac65": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "2a788265166e4a7fa389ae9245db74f9": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "2b9a100c0994413591e5127428219f66": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "2bdfbb2ae1fe41c294d74df03225849a": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "2cfd2d0feda2475a96fb0e6d6e81396e": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "2d731ca3b8d94e1c8047d3ba5009da3c": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "2ddf42d3ca17417f89fce536396f5a0b": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "2e0a6881223841ab94c6c271c3e0fa8f": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "2f992a35dc6741d497444cbdbeadaf3e": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "310d7fc00f1144b4a36fa2473e4b6062": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_6d2a66a945c145a3983c936481c496f5", "max": 12, "style": "IPY_MODEL_7ad465f827794e9fae7f34905f23ed4c", "value": 12 } }, "31caa58e2b2b4612bbcffd5732eb0abc": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "3283a76deb734e5cbd6ec6fda3b2a7df": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_01b0a93b131e46649fed72db9442cc03", "style": "IPY_MODEL_7b62bc95f7d5486aa52a9f7cf4007034", "value": " 12/12 [00:49<00:00, 4.14s/it]" } }, "331da779ea1f47ac9545619baedc9ab8": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "355fd7f9a3544b1a91b8fcfa1978354e": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "3660433dc0de4f849196c0e92a197074": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "37de4a9bd55046c48eae50eb211340a8": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_a4306658b64d4829bfccb78948713e1a", "IPY_MODEL_310d7fc00f1144b4a36fa2473e4b6062", "IPY_MODEL_b57dd9f412ea431ea610006641d8d39e" ], "layout": "IPY_MODEL_a8597269c2be45a5910de45f6703f8d6" } }, "37f087acb09d4fcc889e53ecb93f6f78": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_22249722ca4a46d9a3d79af842fabb8b", "style": "IPY_MODEL_0d788ea2245e4619987ecdc05f51cce4", "value": "Downloading data: 100%" } }, "394d6ad0d8094679adec3a919a361894": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_a618e922fe32409d976d347d645784cf", "IPY_MODEL_ef782dafe3244d85a444706bc2ecc656", "IPY_MODEL_876ccb2c0c31497bbb5cac2552a647de" ], "layout": "IPY_MODEL_d6fccf6a112e4779b7f0a73434292867" } }, "3b70db564fa347dead16adb2f9b41235": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "3c1035113a10491cbfd67f420d3c6972": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_9f1b5aa653cd42e9b4812e56b5b034d3", "IPY_MODEL_41a3305ee913402587ee848471210c08", "IPY_MODEL_f71b04cb4b05432aacf643ed8639e46a" ], "layout": "IPY_MODEL_3ef7f4d11ee242988672b2ecd86c75e4" } }, "3ca57f3f2fdc4aadb198fedaf98fbc9c": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "3d6e73e09142458181c88a073f66d9fc": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_d30c2347f0ac4a84bbdbdd74ea997bd5", "style": "IPY_MODEL_6822a554d10d4856a5a7b04545dfaa74", "value": " 12/12 [00:28<00:00, 1.45s/it]" } }, "3ddf6a59b1c64d9699891a8f63123722": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "3ef7f4d11ee242988672b2ecd86c75e4": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "41a3305ee913402587ee848471210c08": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_7a6e175e330047d3a568672020190cc6", "max": 53, "style": "IPY_MODEL_4c569239b311468ab257da56207c2ade", "value": 53 } }, "43c7b15817074b2f9551eaa3a483561d": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "443acd343074493b86920f997720da88": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "47232b9f0f7f402fa2898726a818779a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "4898ccef6d10410eb261caae7fe74b74": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "4905891de9f24decadff9a471964f6ad": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_af9e96c07ee547dda3f99dc6b2e7f1df", "max": 5, "style": "IPY_MODEL_cb1fd55acbba464db435cd6e43209aad", "value": 5 } }, "49c18587a42b4ae791cc86b494170c88": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_7af7412c6e104a41b3a0d8cbac8dbcd7", "style": "IPY_MODEL_84af6446af3a4f00949129e69fbfce26", "value": " 12/12 [00:31<00:00, 1.40s/it]" } }, "4b8c373f26574b5fa11dc1f3b62fb0d1": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "4c4b10d2021647329b5fcb1fcfc77198": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_1d78fc7cb2ea48ab8eac88a39d04bff1", "IPY_MODEL_1fe675466e4e466bbd1620f20c2bb25c", "IPY_MODEL_c380e3ba1ed04f088ce714371406745a" ], "layout": "IPY_MODEL_db72865d25904618b665383508884314" } }, "4c569239b311468ab257da56207c2ade": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "4e51ba1e406741d280bdbba1954cb4b8": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "4e8548c3579b4c5fa0ef05877fab202a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_0ed35c7ecd664eb69f1cbfca2ab68266", "style": "IPY_MODEL_6540c980125244d8921bc37c2eefe739", "value": "Requesting data: 100%" } }, "4f6b9c71a1b84adbbdd37a95bc0570dd": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "500327293160483e8aa923db47768af5": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_a3166c9c9c3147deb492c02fc1ac6d81", "style": "IPY_MODEL_60ba9dac239a4c24be2d5e6016a13482", "value": " 12/12 [00:25<00:00, 1.36it/s]" } }, "512a8535fbb542839c8dc482bb9b1231": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "525959e7456643329607ba3db734856f": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "5517bed0648b4cc0923795b2809648d6": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "56a428eeeab84dc79e441468e6f545b7": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_dff3b5047fa446c885525ba50f95029c", "IPY_MODEL_7ca8ea4d8d3041008a00bd94ae54639a", "IPY_MODEL_edc515f8f6d74434b857d56d46778a64" ], "layout": "IPY_MODEL_89a80709f40a4c3ea39f08849cb6b6a8" } }, "56e1f7e00e7d42d7a03db19b893087b4": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_0321077fa3c3459882d681362bcdab93", "IPY_MODEL_e38472d3ea934396ba654163c2c0359e", "IPY_MODEL_b36801a5ecd7465bb0aebcc481fe79ec" ], "layout": "IPY_MODEL_990d346595e04b0a868d528cd4f7e2ff" } }, "570a974b70764970a290a0cc84cd876b": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_2f992a35dc6741d497444cbdbeadaf3e", "style": "IPY_MODEL_0bac76cdbadb43a88b865e913272545c", "value": " 12/12 [00:36<00:00, 1.56s/it]" } }, "58cfed1a13fa4d81aa76073f26382362": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_26f978a57034472a927e0dae3979a800", "style": "IPY_MODEL_c17326b27a8547118ef14ad43628914e", "value": "Downloading data: 100%" } }, "5956156439954429b1b21d3874b3dfe6": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "5976dc80a58c417e90cacd8e1b07d373": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "5a8503c9cee84b2f807c452e588a3e44": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "5bb44eb6edd848d38ca954b9cd807ae1": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_16b83d11c1484913ac59fb1c8a6b81b1", "IPY_MODEL_8e44a32aafc3487e9d9f12bef629d926", "IPY_MODEL_c004e118a489464f8c716cb126c412fa" ], "layout": "IPY_MODEL_3ddf6a59b1c64d9699891a8f63123722" } }, "5bbd9de008fd4f93b386e561f79d7304": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_79d76b20478548baa6637630725a5ea8", "max": 5, "style": "IPY_MODEL_dd4d1f11f75548809549d5b7ef97d107", "value": 5 } }, "5bce57b9288847b88ca08cf30d05b7e7": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "5bf96e8333714f09a40424c72b9eb857": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "5db89d4a3441467498583aabb730f544": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_82adc79dad9f4c08be7e6decc261cf61", "IPY_MODEL_4905891de9f24decadff9a471964f6ad", "IPY_MODEL_efd06ec268d344cd92c9f1afa904bb6f" ], "layout": "IPY_MODEL_be9a6f33f71841619cceb51b28a569e3" } }, "604ece9d499f4e5880771d3eff243f20": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "60ba9dac239a4c24be2d5e6016a13482": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "6533005e2bbe49c8b149af09b88c57fa": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "6540c980125244d8921bc37c2eefe739": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "65a01341949747efa603189c526b0912": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "65d25d2ca42a4e78b1ec14ef6b44af21": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "65d6ceb2b0c0470292452cd2e72e063e": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "66c7a0827f664c019248c0ce2e8e4107": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "68174a7bd887426fb8b32b5712d01a30": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "6822a554d10d4856a5a7b04545dfaa74": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "689c37e6d9da456681f7314eb07714a2": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "690106aaecc940b5abb5bd5139bb0a66": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_bb21371dfa7544cdb0314b7213f7df15", "style": "IPY_MODEL_31caa58e2b2b4612bbcffd5732eb0abc", "value": "Requesting data: 100%" } }, "6983556fecc94290b2893901cfd60ada": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "6997454413b24b048696008a5ccf65de": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_4b8c373f26574b5fa11dc1f3b62fb0d1", "style": "IPY_MODEL_05af09dbd51044d5b518c448cb1a3591", "value": " 53/53 [07:07<00:00, 12.91s/it]" } }, "6a7cd7a5bde54e1c9c3c8555d550cb80": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "6c4a237017ec4da0bb1424fa8e2ccd89": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_a651a0a0fb6347fd91b222c959d7bfbb", "IPY_MODEL_0fba34f464a744a5a0d681d12a5a152a", "IPY_MODEL_3283a76deb734e5cbd6ec6fda3b2a7df" ], "layout": "IPY_MODEL_de679d8c01d84b5785e91358d6f6f04c" } }, "6c60b17c2fc44bf8b0f1c15941f2d1f6": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "6d2a66a945c145a3983c936481c496f5": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "6faaeeb746c34554b79aad2ed3522530": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "738defed893d4595865010354705e9ed": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "7687f5d2d9004b94a628bf06138907df": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_d839553ce5ae41309f354eff8b2fe791", "style": "IPY_MODEL_a78ee857ec404162a77cbf2e1406523b", "value": " 12/12 [02:24<00:00, 18.07s/it]" } }, "77116eed650b4272bace90c3b6a7076c": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "77b3bac5fca741babc06fa5803f47a99": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_3660433dc0de4f849196c0e92a197074", "max": 12, "style": "IPY_MODEL_ae0cc4bc4d6242859f2399573e679a89", "value": 12 } }, "79d76b20478548baa6637630725a5ea8": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "7a6e175e330047d3a568672020190cc6": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "7ad465f827794e9fae7f34905f23ed4c": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "7af7412c6e104a41b3a0d8cbac8dbcd7": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "7b62bc95f7d5486aa52a9f7cf4007034": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "7bbe4a587b224864af6a67fbdae5eeae": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "7bd53939eafb494d8b17edab7b842d43": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_58cfed1a13fa4d81aa76073f26382362", "IPY_MODEL_dd90f7c73a6f476b83f91b72081ea397", "IPY_MODEL_7687f5d2d9004b94a628bf06138907df" ], "layout": "IPY_MODEL_86cd486089b24335a60dec1d793da421" } }, "7ca8ea4d8d3041008a00bd94ae54639a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_fc25374c3337406699a8a9464cf82f8a", "max": 12, "style": "IPY_MODEL_96223aa743b54960aa1bc5fd87985d21", "value": 12 } }, "7cf76e9ab972438c9a0c47ca8273c925": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "7f7363789c5f45729c3e27f5f0fddf89": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_058eb42c331c466ab66c6723ad0c1ab4", "IPY_MODEL_01089a83eded470ca7a0dc42e0a40d52", "IPY_MODEL_05e25e2cba5e4ec696d1dfa2914222c5" ], "layout": "IPY_MODEL_c58421d8599b40d4903e6a36d2f7b79d" } }, "7fbe85b856b242478a9f282a6fb11a2d": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_0378a83834a64e75bce9098825df91a2", "style": "IPY_MODEL_525959e7456643329607ba3db734856f", "value": "Requesting data: 100%" } }, "8091fcf6dc744d4493862c5305abb88f": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_98c3c4b5c0634fdeb2988c9a5c275401", "style": "IPY_MODEL_b1ebaca4cd0e4ef38648e8419776cf00", "value": " 0/12 [00:04<?, ?it/s]" } }, "8118839b53f24097b8b262b65fe3e51a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_77116eed650b4272bace90c3b6a7076c", "style": "IPY_MODEL_2521564b5ede4f099e2769797b4bbdfa", "value": " 5/5 [00:15<00:00, 2.24s/it]" } }, "82adc79dad9f4c08be7e6decc261cf61": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_5bf96e8333714f09a40424c72b9eb857", "style": "IPY_MODEL_68174a7bd887426fb8b32b5712d01a30", "value": "Downloading collection: 100%" } }, "82f5ddc1663a4087bc9814167915939a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_bf0c9f1076ec4842ac7b98f9d4f3f23d", "max": 53, "style": "IPY_MODEL_65d25d2ca42a4e78b1ec14ef6b44af21", "value": 53 } }, "831908642d4149ae86e26bc9857bee99": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "8486babeefdc44e6a7f4666614b7bc64": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_b30c0243629d44ae8611cfec0ca2c1ae", "max": 12, "style": "IPY_MODEL_8b561ec21e2f434994eb95661af6018c", "value": 12 } }, "84af6446af3a4f00949129e69fbfce26": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "8636976e646844c6aeeb86573b9823a5": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "86cd486089b24335a60dec1d793da421": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "876ccb2c0c31497bbb5cac2552a647de": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_ab30761189ae4295a5b6fbc032b2dc75", "style": "IPY_MODEL_c7df0793a15c4f85ab0f75872bece8e7", "value": " 12/12 [00:04<00:00, 3.19it/s]" } }, "89a80709f40a4c3ea39f08849cb6b6a8": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "8a6b1ffc42a542b59352d320e8ec4b64": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "8b561ec21e2f434994eb95661af6018c": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "8e44a32aafc3487e9d9f12bef629d926": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_0c25c7a816204ad7b7201cce149b184d", "max": 12, "style": "IPY_MODEL_8a6b1ffc42a542b59352d320e8ec4b64", "value": 12 } }, "8e5e7fc6140143f6a5f54a7dfef4be35": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "8f07a794ea74460a952c881ee0a0c6b1": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "8f18d1b5a31a4796b8e8d8c3a40712f5": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_6983556fecc94290b2893901cfd60ada", "max": 12, "style": "IPY_MODEL_94caffe54a914c2fbc2a7030fe853cdf", "value": 12 } }, "91e8efa8b0ac476dba0dd92a5dba4cf2": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "9463ff7440404206aac26408fce0e6b5": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "94a23f02b6484a63b840846d90636df0": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "94caffe54a914c2fbc2a7030fe853cdf": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "958e5a1140d94d9c98ee9aba1fd9cf0f": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "95c595b2bcc645998f4a87395babaec2": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "96223aa743b54960aa1bc5fd87985d21": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "982f6cccca6045c79428ed321a36f28a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_cc237d0f4e104a2eb95ff438ed0c867b", "style": "IPY_MODEL_a47d06ed52b54b9395c226b5b2aec0be", "value": " 12/366 [00:04<01:03, 5.54it/s]" } }, "98c3bf2629d34ab78dce0024016c192e": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_738defed893d4595865010354705e9ed", "max": 12, "style": "IPY_MODEL_207e51f753454df0a5518603206f5d54", "value": 12 } }, "98c3c4b5c0634fdeb2988c9a5c275401": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "990d346595e04b0a868d528cd4f7e2ff": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "9bf4dde3f2f842aeb2629b93fc7aa4a5": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_d7fe1e26a00b4f608876bfecf0ee9ee9", "IPY_MODEL_77b3bac5fca741babc06fa5803f47a99", "IPY_MODEL_b3208ac4bd4b449c8e70007212f0709f" ], "layout": "IPY_MODEL_43c7b15817074b2f9551eaa3a483561d" } }, "9c0ef6d2a6454d4ea643bbc5d954208c": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_6faaeeb746c34554b79aad2ed3522530", "style": "IPY_MODEL_d39c16f1ed6a449b94a7643ee5406ad6", "value": "Requesting data: 3%" } }, "9c77d80d3dd64af4af78e3600355ed84": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "9e94b2fb3b3547e79facfe2497eccccf": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "9efcf850681b4561aeb551788bf3d203": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_9c0ef6d2a6454d4ea643bbc5d954208c", "IPY_MODEL_e95dfd530fd0427bb4d2b844dd976993", "IPY_MODEL_982f6cccca6045c79428ed321a36f28a" ], "layout": "IPY_MODEL_c845b2870678476495e277f9785ffec1" } }, "9f1b5aa653cd42e9b4812e56b5b034d3": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_b673e92095584c099922e05f76a19e9d", "style": "IPY_MODEL_a57589c4ca0c4209b3d54a4cc6881c01", "value": "Requesting data: 100%" } }, "a3166c9c9c3147deb492c02fc1ac6d81": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "a3636031b81d45eb9ef283a4e4ec99d4": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "a397f629fc09408e95696e92887d5c37": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "a4306658b64d4829bfccb78948713e1a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_ca75ee51ffc445858f528be0de1837cb", "style": "IPY_MODEL_7cf76e9ab972438c9a0c47ca8273c925", "value": "Downloading collection: 100%" } }, "a47d06ed52b54b9395c226b5b2aec0be": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "a4b74de69211422fa6866893ded41325": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_e8301dc3b24f4c588c44b9e86d9f3626", "IPY_MODEL_c790807e86834b179977f96147dcf971", "IPY_MODEL_8091fcf6dc744d4493862c5305abb88f" ], "layout": "IPY_MODEL_443acd343074493b86920f997720da88" } }, "a57589c4ca0c4209b3d54a4cc6881c01": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "a618e922fe32409d976d347d645784cf": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_beaa8f136ad04571977f7219051db06c", "style": "IPY_MODEL_1aed82889b8b4ebe9c0031795b0301ff", "value": "Downloading data: 100%" } }, "a651a0a0fb6347fd91b222c959d7bfbb": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_c2eac32f98824383b8b0ab19c72cc665", "style": "IPY_MODEL_8636976e646844c6aeeb86573b9823a5", "value": "Downloading collection: 100%" } }, "a78ee857ec404162a77cbf2e1406523b": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "a80ef67cae5143b1b7c1c49b24f3687d": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "a8597269c2be45a5910de45f6703f8d6": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "aa0a18f5be414518ab99f9dd8a45c9eb": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_2b9a100c0994413591e5127428219f66", "style": "IPY_MODEL_5a8503c9cee84b2f807c452e588a3e44", "value": "Downloading collection: 100%" } }, "ab30761189ae4295a5b6fbc032b2dc75": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "aba57f4c55234bf8bba6a61a9591a122": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "adb722e110684e70a7839222ed949749": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_3ca57f3f2fdc4aadb198fedaf98fbc9c", "style": "IPY_MODEL_2cfd2d0feda2475a96fb0e6d6e81396e", "value": " 12/12 [01:03<00:00, 6.48s/it]" } }, "ae0cc4bc4d6242859f2399573e679a89": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "ae6733d754674138999203cd6566cd32": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_4e51ba1e406741d280bdbba1954cb4b8", "style": "IPY_MODEL_6533005e2bbe49c8b149af09b88c57fa", "value": "Requesting data: 100%" } }, "af9e96c07ee547dda3f99dc6b2e7f1df": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "b0574241ca2e403d828ed12e26973948": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "b0e63eac35324b66a9726ec0697f17f1": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_217d8c4cf2444480a1e21aa7c1a37659", "IPY_MODEL_cdacb0afee274b3fbd9532dd3a894171", "IPY_MODEL_3d6e73e09142458181c88a073f66d9fc" ], "layout": "IPY_MODEL_d9cac0bfee4743cdaffb9b543236f4c5" } }, "b1525fc3944e4416a750800e22d2c599": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "b1ebaca4cd0e4ef38648e8419776cf00": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "b30c0243629d44ae8611cfec0ca2c1ae": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "b3208ac4bd4b449c8e70007212f0709f": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_66c7a0827f664c019248c0ce2e8e4107", "style": "IPY_MODEL_91e8efa8b0ac476dba0dd92a5dba4cf2", "value": " 12/12 [00:32<00:00, 1.67s/it]" } }, "b36801a5ecd7465bb0aebcc481fe79ec": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_d6f268aab2ae42c09dbafef47c36d3dd", "style": "IPY_MODEL_b60ddc983e614c189c354f3733190614", "value": " 11/151 [00:03<00:18, 7.69it/s]" } }, "b57dd9f412ea431ea610006641d8d39e": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_e3ab007fe22a4d69969098f11d93c146", "style": "IPY_MODEL_5976dc80a58c417e90cacd8e1b07d373", "value": " 12/12 [00:52<00:00, 3.94s/it]" } }, "b5e8f7e5f9f14b25b0bdc160e51e79a4": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_aa0a18f5be414518ab99f9dd8a45c9eb", "IPY_MODEL_98c3bf2629d34ab78dce0024016c192e", "IPY_MODEL_570a974b70764970a290a0cc84cd876b" ], "layout": "IPY_MODEL_e05882cad6c244a588b63b08871226b1" } }, "b60ddc983e614c189c354f3733190614": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "b673e92095584c099922e05f76a19e9d": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "b7fbee4ab66f4d6fa55ac79409b6f7a5": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_4e8548c3579b4c5fa0ef05877fab202a", "IPY_MODEL_8486babeefdc44e6a7f4666614b7bc64", "IPY_MODEL_adb722e110684e70a7839222ed949749" ], "layout": "IPY_MODEL_fdaa635c2dde4dc8a0ab7a9609890547" } }, "bb21371dfa7544cdb0314b7213f7df15": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "bc104c0ec492427a875b722ea0c59f45": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "be9a6f33f71841619cceb51b28a569e3": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "beaa8f136ad04571977f7219051db06c": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "bf0c9f1076ec4842ac7b98f9d4f3f23d": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "c004e118a489464f8c716cb126c412fa": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_7bbe4a587b224864af6a67fbdae5eeae", "style": "IPY_MODEL_958e5a1140d94d9c98ee9aba1fd9cf0f", "value": " 12/12 [00:29<00:00, 1.11s/it]" } }, "c17326b27a8547118ef14ad43628914e": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "c2eac32f98824383b8b0ab19c72cc665": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "c380e3ba1ed04f088ce714371406745a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_2748cec5cb1f45c6b0157f9b6ce9ac65", "style": "IPY_MODEL_5517bed0648b4cc0923795b2809648d6", "value": " 12/12 [00:58<00:00, 7.71s/it]" } }, "c3a44e05e692471988f22dc71b494693": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "c406eeba30074a8a883b3d5b7e3041d3": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_ae6733d754674138999203cd6566cd32", "IPY_MODEL_fd19346778e446819c10a946012d1e79", "IPY_MODEL_49c18587a42b4ae791cc86b494170c88" ], "layout": "IPY_MODEL_65a01341949747efa603189c526b0912" } }, "c547fda8362140348109df38f3786282": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HBoxModel", "state": { "children": [ "IPY_MODEL_37f087acb09d4fcc889e53ecb93f6f78", "IPY_MODEL_82f5ddc1663a4087bc9814167915939a", "IPY_MODEL_6997454413b24b048696008a5ccf65de" ], "layout": "IPY_MODEL_0dfb7849ee4b43e99a288f8d545b09b6" } }, "c58421d8599b40d4903e6a36d2f7b79d": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "c75f39b203354f9080d8cd4c44799e9f": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "c790807e86834b179977f96147dcf971": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "danger", "layout": "IPY_MODEL_a80ef67cae5143b1b7c1c49b24f3687d", "max": 12, "style": "IPY_MODEL_a397f629fc09408e95696e92887d5c37" } }, "c7df0793a15c4f85ab0f75872bece8e7": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "c845b2870678476495e277f9785ffec1": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "ca75ee51ffc445858f528be0de1837cb": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "cb1fd55acbba464db435cd6e43209aad": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "cc237d0f4e104a2eb95ff438ed0c867b": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "cdacb0afee274b3fbd9532dd3a894171": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_d054c800a3124a019de07bc713fe4d03", "max": 12, "style": "IPY_MODEL_2ddf42d3ca17417f89fce536396f5a0b", "value": 12 } }, "d054c800a3124a019de07bc713fe4d03": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "d30c2347f0ac4a84bbdbdd74ea997bd5": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "d39c16f1ed6a449b94a7643ee5406ad6": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "d58e4f3731794816b4dae52c45975e52": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "d6f268aab2ae42c09dbafef47c36d3dd": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "d6fccf6a112e4779b7f0a73434292867": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "d7fe1e26a00b4f608876bfecf0ee9ee9": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_8e5e7fc6140143f6a5f54a7dfef4be35", "style": "IPY_MODEL_95c595b2bcc645998f4a87395babaec2", "value": "Downloading data: 100%" } }, "d839553ce5ae41309f354eff8b2fe791": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "d9cac0bfee4743cdaffb9b543236f4c5": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "db72865d25904618b665383508884314": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "dd4d1f11f75548809549d5b7ef97d107": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "dd90f7c73a6f476b83f91b72081ea397": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_bc104c0ec492427a875b722ea0c59f45", "max": 12, "style": "IPY_MODEL_eba5da53838045d9a6b6f2872aa89a95", "value": 12 } }, "de679d8c01d84b5785e91358d6f6f04c": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "de68ba05ed6d4bba92e19f62c293d398": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "dff3b5047fa446c885525ba50f95029c": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_3b70db564fa347dead16adb2f9b41235", "style": "IPY_MODEL_a3636031b81d45eb9ef283a4e4ec99d4", "value": "Downloading data: 100%" } }, "e05882cad6c244a588b63b08871226b1": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "e2801d284e4b44d8a8a64058bbcd42b7": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_4898ccef6d10410eb261caae7fe74b74", "max": 12, "style": "IPY_MODEL_2a788265166e4a7fa389ae9245db74f9", "value": 12 } }, "e38472d3ea934396ba654163c2c0359e": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "danger", "layout": "IPY_MODEL_65d6ceb2b0c0470292452cd2e72e063e", "max": 151, "style": "IPY_MODEL_1f7e087fdc314ae7af0e1ba06df794b2", "value": 11 } }, "e3ab007fe22a4d69969098f11d93c146": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "e589d859c7fe4a7a93f84bfa606c0523": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_5bce57b9288847b88ca08cf30d05b7e7", "style": "IPY_MODEL_de68ba05ed6d4bba92e19f62c293d398", "value": "Downloading collection: 100%" } }, "e8301dc3b24f4c588c44b9e86d9f3626": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_6a7cd7a5bde54e1c9c3c8555d550cb80", "style": "IPY_MODEL_355fd7f9a3544b1a91b8fcfa1978354e", "value": "Requesting data: 0%" } }, "e95dfd530fd0427bb4d2b844dd976993": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "danger", "layout": "IPY_MODEL_604ece9d499f4e5880771d3eff243f20", "max": 366, "style": "IPY_MODEL_10ca112ce222454d87c111f2ac559caa", "value": 12 } }, "eba5da53838045d9a6b6f2872aa89a95": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "ProgressStyleModel", "state": { "description_width": "" } }, "edc515f8f6d74434b857d56d46778a64": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_512a8535fbb542839c8dc482bb9b1231", "style": "IPY_MODEL_148045615c414655a3bdd3e42456770b", "value": " 12/12 [00:32<00:00, 1.46s/it]" } }, "ef253182abcc4726ad023a161db32392": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "ef782dafe3244d85a444706bc2ecc656": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_d58e4f3731794816b4dae52c45975e52", "max": 12, "style": "IPY_MODEL_47232b9f0f7f402fa2898726a818779a", "value": 12 } }, "efd06ec268d344cd92c9f1afa904bb6f": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_ef253182abcc4726ad023a161db32392", "style": "IPY_MODEL_0d61818f9e3d4ab7ba6e0ce5a5ebbeb9", "value": " 5/5 [00:07<00:00, 1.17it/s]" } }, "f2850d88b68d46f299c22c5a4ff21b12": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "DescriptionStyleModel", "state": { "description_width": "" } }, "f71b04cb4b05432aacf643ed8639e46a": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "HTMLModel", "state": { "layout": "IPY_MODEL_0b54464a9d6045269607be0c130aae23", "style": "IPY_MODEL_94a23f02b6484a63b840846d90636df0", "value": " 53/53 [08:14<00:00, 9.31s/it]" } }, "f8c184ba98674a3b9e2d91a43d091aee": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "f962814ef3014b8aba4ac740b1185ac0": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "fc25374c3337406699a8a9464cf82f8a": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} }, "fd19346778e446819c10a946012d1e79": { "model_module": "@jupyter-widgets/controls", "model_module_version": "1.5.0", "model_name": "FloatProgressModel", "state": { "bar_style": "success", "layout": "IPY_MODEL_5956156439954429b1b21d3874b3dfe6", "max": 12, "style": "IPY_MODEL_331da779ea1f47ac9545619baedc9ab8", "value": 12 } }, "fdaa635c2dde4dc8a0ab7a9609890547": { "model_module": "@jupyter-widgets/base", "model_module_version": "1.2.0", "model_name": "LayoutModel", "state": {} } }, "version_major": 2, "version_minor": 0 } } }, "nbformat": 4, "nbformat_minor": 5 }