From 912b047cc3159c07b77ec31982791a8c873f885c Mon Sep 17 00:00:00 2001 From: RondeauG Date: Wed, 9 Oct 2024 16:18:05 -0400 Subject: [PATCH 1/4] less computation --- docs/notebooks/climate_change.ipynb | 2 +- docs/notebooks/hydrological_modelling.ipynb | 176 +- docs/notebooks/local_frequency_analysis.ipynb | 6416 +---------------- docs/notebooks/optimal_interpolation.ipynb | 2360 +----- .../regional_frequency_analysis.ipynb | 37 +- 5 files changed, 140 insertions(+), 8851 deletions(-) diff --git a/docs/notebooks/climate_change.ipynb b/docs/notebooks/climate_change.ipynb index 1de136a7..51884f3c 100644 --- a/docs/notebooks/climate_change.ipynb +++ b/docs/notebooks/climate_change.ipynb @@ -676,7 +676,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.12.2" + "version": "3.12.3" } }, "nbformat": 4, diff --git a/docs/notebooks/hydrological_modelling.ipynb b/docs/notebooks/hydrological_modelling.ipynb index cb3a7598..f4391773 100644 --- a/docs/notebooks/hydrological_modelling.ipynb +++ b/docs/notebooks/hydrological_modelling.ipynb @@ -96,8 +96,8 @@ "- `.get_inputs()` to retrieve the meteorological inputs.\n", "- `.get_streamflow()` to retrieve the simulated streamflow.\n", "\n", - "## Acquiring meteorological data\n", - "The acquisition of raw meteorological and elevation data using the GIS module and libraries such as `xdatasets` is covered in the [GIS notebook](gis.ipynb)." + "## Acquiring and formatting meteorological data\n", + "The acquisition of raw meteorological and elevation data using the GIS module and libraries such as `xdatasets` is covered in the [GIS notebook](gis.ipynb). Therefore, this notebook will use a test dataset." ] }, { @@ -107,133 +107,36 @@ "metadata": {}, "outputs": [], "source": [ - "# For this example, we'll use a very small watershed in Eastern Quebec\n", - "import leafmap\n", - "import numpy as np\n", - "import xdatasets as xd\n", + "import pooch\n", + "import xarray as xr\n", "\n", - "import xhydro.gis as xhgis\n", + "# This notebook will use ERA5 data for a small watershed in Eastern Quebec, along with faked elevation data.\n", + "GITHUB_URL = \"https://github.com/hydrologie/xhydro-testdata\"\n", + "BRANCH_OR_COMMIT_HASH = \"for_nb\"\n", "\n", - "# Get the watershed delieanation\n", - "m = leafmap.Map(center=(48.7, -64.5), zoom=8, basemap=\"USGS Hydrography\")\n", - "lng_lat = [(-64.51410670781502, 48.766612642281046)]\n", - "gdf = xhgis.watershed_delineation(coordinates=lng_lat, map=m)\n", - "m" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "id": "6", - "metadata": {}, - "outputs": [], - "source": [ - "# Get spatial meteorological data from ERA5 using xdatasets\n", - "datasets = {\n", - " \"era5_reanalysis_single_levels\": {\"variables\": [\"t2m\", \"tp\"]},\n", - "}\n", - "space = {\n", - " \"clip\": \"polygon\", # bbox, point or polygon\n", - " \"averaging\": False,\n", - " \"geometry\": gdf, # select the 2 first polygons\n", - " \"unique_id\": \"HYBAS_ID\",\n", - "}\n", - "time = {\n", - " \"timestep\": \"D\",\n", - " \"aggregation\": {\"tp\": np.nansum, \"t2m\": [np.nanmax, np.nanmin]},\n", - " \"start\": \"1981-01-01\",\n", - " \"end\": \"1982-01-01\",\n", - " \"timezone\": \"America/Montreal\",\n", - "}\n", - "\n", - "ds = xd.Query(datasets=datasets, space=space, time=time).data.squeeze()\n", - "# Standardize the dataset to bring it to CF standards\n", - "ds = ds.rename(\n", - " {\n", - " \"longitude\": \"lon\",\n", - " \"latitude\": \"lat\",\n", - " \"t2m_nanmax\": \"tasmax\",\n", - " \"t2m_nanmin\": \"tasmin\",\n", - " \"tp_nansum\": \"pr\",\n", - " }\n", + "# Streamflow file (1 file - Hydrotel driven by BCC-CSM-1.1(m))\n", + "meteo_file = pooch.retrieve(\n", + " url=f\"{GITHUB_URL}/raw/{BRANCH_OR_COMMIT_HASH}/data/hydro_modelling/ERA5_testdata.nc\",\n", + " known_hash=\"md5:784db17edf68d9e38c3e9d0aa18297a6\",\n", ")\n", - "ds[\"lon\"].attrs[\"axis\"] = \"X\"\n", - "ds[\"lat\"].attrs[\"axis\"] = \"Y\"\n", - "ds[\"HYBAS_ID\"].attrs.pop(\"cf_role\")\n", - "\n", + "ds = xr.open_dataset(meteo_file)\n", "ds" ] }, - { - "cell_type": "code", - "execution_count": null, - "id": "7", - "metadata": {}, - "outputs": [], - "source": [ - "# Elevation data is not yet available through xdatasets, but we can use a hack to approximate that information\n", - "import pystac_client\n", - "import stackstac\n", - "import xscen as xs\n", - "\n", - "# Acquire the Copernicus DEM for the area covered by the watershed\n", - "catalog = pystac_client.Client.open(\n", - " \"https://planetarycomputer.microsoft.com/api/stac/v1\",\n", - ")\n", - "search = catalog.search(\n", - " collections=[\"cop-dem-glo-90\"],\n", - " bbox=gdf.total_bounds,\n", - ")\n", - "items = list(search.get_items())\n", - "da = stackstac.stack(items)\n", - "\n", - "\n", - "def _flatten(x, dim=\"time\"):\n", - " if len(x[dim].values) > len(set(x[dim].values)):\n", - " x = x.groupby(dim).map(stackstac.mosaic)\n", - "\n", - " return x\n", - "\n", - "\n", - "ds_elev = _flatten(da, dim=\"time\").squeeze().to_dataset(name=\"elevation\")\n", - "ds_elev = ds_elev.rename({\"x\": \"lon\", \"y\": \"lat\"})\n", - "ds_elev[\"lon\"].attrs = {\n", - " \"standard_name\": \"longitude\",\n", - " \"units\": \"degrees_east\",\n", - " \"axis\": \"X\",\n", - "}\n", - "ds_elev[\"lat\"].attrs = {\n", - " \"standard_name\": \"latitude\",\n", - " \"units\": \"degrees_north\",\n", - " \"axis\": \"Y\",\n", - "}\n", - "\n", - "# Use xscen to reproject the DEM onto ERA5's grid\n", - "ds_elev = xs.regrid_dataset(\n", - " ds_elev,\n", - " ds,\n", - " weights_location=notebook_folder / \"_data\",\n", - " regridder_kwargs={\"method\": \"conservative\", \"skipna\": True},\n", - ")\n", - "\n", - "# Assign the elevation data to the dataset\n", - "ds = ds.assign_coords({\"z\": ds_elev[\"elevation\"].reset_coords(drop=True)})\n", - "ds[\"z\"].attrs = {\"standard_name\": \"surface_altitude\", \"units\": \"m\"}" - ] - }, { "cell_type": "markdown", - "id": "8", + "id": "6", "metadata": {}, "source": [ - "## Formatting meteorological data\n", - "Every hydrological model has different requirements when it comes to their input data. The function `xh.modelling.format_input` can be used to reformat CF-compliant datasets for use in hydrological models. Note that this function currently only supports 'Hydrotel'." + "Every hydrological model has different requirements when it comes to their input data. In this example, the data variables have units (temperatures in `°K` and precipitation in `m`) that would not be compatible with the requirements for the Hydrotel model.\n", + "\n", + "Thus, the function `xh.modelling.format_input` can be used to reformat CF-compliant datasets for use in hydrological models. Note that this function currently only supports 'Hydrotel'." ] }, { "cell_type": "code", "execution_count": null, - "id": "9", + "id": "7", "metadata": {}, "outputs": [], "source": [ @@ -243,7 +146,7 @@ { "cell_type": "code", "execution_count": null, - "id": "10", + "id": "8", "metadata": { "editable": true, "nbsphinx": "hidden", @@ -267,7 +170,7 @@ { "cell_type": "code", "execution_count": null, - "id": "11", + "id": "9", "metadata": {}, "outputs": [], "source": [ @@ -285,7 +188,7 @@ { "cell_type": "code", "execution_count": null, - "id": "12", + "id": "10", "metadata": {}, "outputs": [], "source": [ @@ -295,17 +198,17 @@ { "cell_type": "code", "execution_count": null, - "id": "13", + "id": "11", "metadata": {}, "outputs": [], "source": [ - "# Hydrotel also requires a configuration file, which will be produced by this function.\n", + "# Hydrotel also requires a configuration file, which will also be produced by this function.\n", "config" ] }, { "cell_type": "markdown", - "id": "14", + "id": "12", "metadata": {}, "source": [ "## Initializing the model\n", @@ -317,7 +220,7 @@ { "cell_type": "code", "execution_count": null, - "id": "15", + "id": "13", "metadata": {}, "outputs": [], "source": [ @@ -349,7 +252,7 @@ }, { "cell_type": "markdown", - "id": "16", + "id": "14", "metadata": {}, "source": [ "For HYDROTEL, `DATE DEBUT (start date), DATE FIN (end date), and PAS DE TEMPS (timestep frequency)` will always need to be specified, so these need to be added to `simulation_config` if they don't already exist in `simulation.csv`. Additionally, either `FICHIER STATIONS METEO (meteorological stations file)` or `FICHIER GRILLE METEO (meteorological grid file)` need to be specified to guide the model towards the meteorological data.\n", @@ -360,7 +263,7 @@ { "cell_type": "code", "execution_count": null, - "id": "17", + "id": "15", "metadata": {}, "outputs": [], "source": [ @@ -375,7 +278,7 @@ }, { "cell_type": "markdown", - "id": "18", + "id": "16", "metadata": { "editable": true, "slideshow": { @@ -393,7 +296,7 @@ { "cell_type": "code", "execution_count": null, - "id": "19", + "id": "17", "metadata": {}, "outputs": [], "source": [ @@ -426,7 +329,7 @@ { "cell_type": "code", "execution_count": null, - "id": "20", + "id": "18", "metadata": {}, "outputs": [], "source": [ @@ -438,13 +341,12 @@ " ds_in[\"pr\"]\n", ") # Hydrotel-to-xclim compatibility. Precipitation in xclim needs to be a flux.\n", "\n", - "# This example will raise warnings, this is normal since we're using fake data.\n", "xh.utils.health_checks(ds_in, **health_checks)" ] }, { "cell_type": "markdown", - "id": "21", + "id": "19", "metadata": {}, "source": [ "## Executing the model\n", @@ -468,7 +370,7 @@ { "cell_type": "code", "execution_count": null, - "id": "22", + "id": "20", "metadata": {}, "outputs": [], "source": [ @@ -480,7 +382,7 @@ { "cell_type": "code", "execution_count": null, - "id": "23", + "id": "21", "metadata": {}, "outputs": [], "source": [ @@ -491,7 +393,7 @@ }, { "cell_type": "markdown", - "id": "24", + "id": "22", "metadata": {}, "source": [ "## Model calibration\n", @@ -513,7 +415,7 @@ { "cell_type": "code", "execution_count": null, - "id": "25", + "id": "23", "metadata": {}, "outputs": [], "source": [ @@ -523,7 +425,7 @@ { "cell_type": "code", "execution_count": null, - "id": "26", + "id": "24", "metadata": {}, "outputs": [], "source": [ @@ -548,7 +450,7 @@ { "cell_type": "code", "execution_count": null, - "id": "27", + "id": "25", "metadata": {}, "outputs": [], "source": [ @@ -568,7 +470,7 @@ { "cell_type": "code", "execution_count": null, - "id": "28", + "id": "26", "metadata": {}, "outputs": [], "source": [ @@ -579,7 +481,7 @@ { "cell_type": "code", "execution_count": null, - "id": "29", + "id": "27", "metadata": {}, "outputs": [], "source": [ @@ -590,7 +492,7 @@ { "cell_type": "code", "execution_count": null, - "id": "30", + "id": "28", "metadata": {}, "outputs": [], "source": [ diff --git a/docs/notebooks/local_frequency_analysis.ipynb b/docs/notebooks/local_frequency_analysis.ipynb index 1a6a1f7e..74d7bc78 100644 --- a/docs/notebooks/local_frequency_analysis.ipynb +++ b/docs/notebooks/local_frequency_analysis.ipynb @@ -9,1797 +9,9 @@ }, { "cell_type": "code", - "execution_count": 1, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "application/javascript": [ - "(function(root) {\n", - " function now() {\n", - " return new Date();\n", - " }\n", - "\n", - " var force = true;\n", - " var py_version = '3.1.1'.replace('rc', '-rc.');\n", - " var is_dev = py_version.indexOf(\"+\") !== -1 || py_version.indexOf(\"-\") !== -1;\n", - " var reloading = false;\n", - " var Bokeh = root.Bokeh;\n", - " var bokeh_loaded = Bokeh != null && (Bokeh.version === py_version || (Bokeh.versions !== undefined && Bokeh.versions.has(py_version)));\n", - "\n", - " if (typeof (root._bokeh_timeout) === \"undefined\" || force) {\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, js_exports, callback) {\n", - " if (css_urls == null) css_urls = [];\n", - " if (js_urls == null) js_urls = [];\n", - " if (js_modules == null) js_modules = [];\n", - " if (js_exports == null) js_exports = {};\n", - "\n", - " root._bokeh_onload_callbacks.push(callback);\n", - "\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 && Object.keys(js_exports).length === 0) {\n", - " run_callbacks();\n", - " return null;\n", - " }\n", - " if (!reloading) {\n", - " console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n", - " }\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", - " window._bokeh_on_load = on_load\n", - "\n", - " function on_error() {\n", - " console.error(\"failed to load \" + url);\n", - " }\n", - "\n", - " var skip = [];\n", - " if (window.requirejs) {\n", - " window.requirejs.config({'packages': {}, 'paths': {'jspanel': 'https://cdn.jsdelivr.net/npm/jspanel4@4.12.0/dist/jspanel', 'jspanel-modal': 'https://cdn.jsdelivr.net/npm/jspanel4@4.12.0/dist/extensions/modal/jspanel.modal', 'jspanel-tooltip': 'https://cdn.jsdelivr.net/npm/jspanel4@4.12.0/dist/extensions/tooltip/jspanel.tooltip', 'jspanel-hint': 'https://cdn.jsdelivr.net/npm/jspanel4@4.12.0/dist/extensions/hint/jspanel.hint', 'jspanel-layout': 'https://cdn.jsdelivr.net/npm/jspanel4@4.12.0/dist/extensions/layout/jspanel.layout', 'jspanel-contextmenu': 'https://cdn.jsdelivr.net/npm/jspanel4@4.12.0/dist/extensions/contextmenu/jspanel.contextmenu', 'jspanel-dock': 'https://cdn.jsdelivr.net/npm/jspanel4@4.12.0/dist/extensions/dock/jspanel.dock', 'gridstack': 'https://cdn.jsdelivr.net/npm/gridstack@7.2.3/dist/gridstack-all', 'notyf': 'https://cdn.jsdelivr.net/npm/notyf@3/notyf.min'}, 'shim': {'jspanel': {'exports': 'jsPanel'}, 'gridstack': {'exports': 'GridStack'}}});\n", - " require([\"jspanel\"], function(jsPanel) {\n", - "\twindow.jsPanel = jsPanel\n", - "\ton_load()\n", - " })\n", - " require([\"jspanel-modal\"], function() {\n", - "\ton_load()\n", - " })\n", - " require([\"jspanel-tooltip\"], function() {\n", - "\ton_load()\n", - " })\n", - " require([\"jspanel-hint\"], function() {\n", - "\ton_load()\n", - " })\n", - " require([\"jspanel-layout\"], function() {\n", - "\ton_load()\n", - " })\n", - " require([\"jspanel-contextmenu\"], function() {\n", - "\ton_load()\n", - " })\n", - " require([\"jspanel-dock\"], function() {\n", - "\ton_load()\n", - " })\n", - " require([\"gridstack\"], function(GridStack) {\n", - "\twindow.GridStack = GridStack\n", - "\ton_load()\n", - " })\n", - " require([\"notyf\"], function() {\n", - "\ton_load()\n", - " })\n", - " root._bokeh_is_loading = css_urls.length + 9;\n", - " } else {\n", - " root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length + Object.keys(js_exports).length;\n", - " }\n", - "\n", - " var existing_stylesheets = []\n", - " var links = document.getElementsByTagName('link')\n", - " for (var i = 0; i < links.length; i++) {\n", - " var link = links[i]\n", - " if (link.href != null) {\n", - "\texisting_stylesheets.push(link.href)\n", - " }\n", - " }\n", - " for (var i = 0; i < css_urls.length; i++) {\n", - " var url = css_urls[i];\n", - " if (existing_stylesheets.indexOf(url) !== -1) {\n", - "\ton_load()\n", - "\tcontinue;\n", - " }\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", - " } if (((window['jsPanel'] !== undefined) && (!(window['jsPanel'] instanceof HTMLElement))) || window.requirejs) {\n", - " var urls = ['https://cdn.holoviz.org/panel/1.0.4/dist/bundled/floatpanel/jspanel4@4.12.0/dist/jspanel.js', 'https://cdn.holoviz.org/panel/1.0.4/dist/bundled/floatpanel/jspanel4@4.12.0/dist/extensions/modal/jspanel.modal.js', 'https://cdn.holoviz.org/panel/1.0.4/dist/bundled/floatpanel/jspanel4@4.12.0/dist/extensions/tooltip/jspanel.tooltip.js', 'https://cdn.holoviz.org/panel/1.0.4/dist/bundled/floatpanel/jspanel4@4.12.0/dist/extensions/hint/jspanel.hint.js', 'https://cdn.holoviz.org/panel/1.0.4/dist/bundled/floatpanel/jspanel4@4.12.0/dist/extensions/layout/jspanel.layout.js', 'https://cdn.holoviz.org/panel/1.0.4/dist/bundled/floatpanel/jspanel4@4.12.0/dist/extensions/contextmenu/jspanel.contextmenu.js', 'https://cdn.holoviz.org/panel/1.0.4/dist/bundled/floatpanel/jspanel4@4.12.0/dist/extensions/dock/jspanel.dock.js'];\n", - " for (var i = 0; i < urls.length; i++) {\n", - " skip.push(urls[i])\n", - " }\n", - " } if (((window['GridStack'] !== undefined) && (!(window['GridStack'] instanceof HTMLElement))) || window.requirejs) {\n", - " var urls = ['https://cdn.holoviz.org/panel/1.0.4/dist/bundled/gridstack/gridstack@7.2.3/dist/gridstack-all.js'];\n", - " for (var i = 0; i < urls.length; i++) {\n", - " skip.push(urls[i])\n", - " }\n", - " } if (((window['Notyf'] !== undefined) && (!(window['Notyf'] instanceof HTMLElement))) || window.requirejs) {\n", - " var urls = ['https://cdn.holoviz.org/panel/1.0.4/dist/bundled/notificationarea/notyf@3/notyf.min.js'];\n", - " for (var i = 0; i < urls.length; i++) {\n", - " skip.push(urls[i])\n", - " }\n", - " } var existing_scripts = []\n", - " var scripts = document.getElementsByTagName('script')\n", - " for (var i = 0; i < scripts.length; i++) {\n", - " var script = scripts[i]\n", - " if (script.src != null) {\n", - "\texisting_scripts.push(script.src)\n", - " }\n", - " }\n", - " for (var i = 0; i < js_urls.length; i++) {\n", - " var url = js_urls[i];\n", - " if (skip.indexOf(url) !== -1 || existing_scripts.indexOf(url) !== -1) {\n", - "\tif (!window.requirejs) {\n", - "\t on_load();\n", - "\t}\n", - "\tcontinue;\n", - " }\n", - " var element = document.createElement('script');\n", - " element.onload = on_load;\n", - " element.onerror = on_error;\n", - " element.async = false;\n", - " element.src = url;\n", - " console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n", - " document.head.appendChild(element);\n", - " }\n", - " for (var i = 0; i < js_modules.length; i++) {\n", - " var url = js_modules[i];\n", - " if (skip.indexOf(url) !== -1 || existing_scripts.indexOf(url) !== -1) {\n", - "\tif (!window.requirejs) {\n", - "\t on_load();\n", - "\t}\n", - "\tcontinue;\n", - " }\n", - " var element = document.createElement('script');\n", - " element.onload = on_load;\n", - " element.onerror = on_error;\n", - " element.async = false;\n", - " element.src = url;\n", - " element.type = \"module\";\n", - " console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n", - " document.head.appendChild(element);\n", - " }\n", - " for (const name in js_exports) {\n", - " var url = js_exports[name];\n", - " if (skip.indexOf(url) >= 0 || root[name] != null) {\n", - "\tif (!window.requirejs) {\n", - "\t on_load();\n", - "\t}\n", - "\tcontinue;\n", - " }\n", - " var element = document.createElement('script');\n", - " element.onerror = on_error;\n", - " element.async = false;\n", - " element.type = \"module\";\n", - " console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n", - " element.textContent = `\n", - " import ${name} from \"${url}\"\n", - " window.${name} = ${name}\n", - " window._bokeh_on_load()\n", - " `\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 js_exports = {};\n", - " var css_urls = [];\n", - " var inline_js = [ function(Bokeh) {\n", - " /* BEGIN bokeh.min.js */\n", - " /*!\n", - " * Copyright (c) 2012 - 2023, Anaconda, Inc., and Bokeh Contributors\n", - " * All rights reserved.\n", - " * \n", - " * Redistribution and use in source and binary forms, with or without modification,\n", - " * are permitted provided that the following conditions are met:\n", - " * \n", - " * Redistributions of source code must retain the above copyright notice,\n", - " * this list of conditions and the following disclaimer.\n", - " * \n", - " * Redistributions in binary form must reproduce the above copyright notice,\n", - " * this list of conditions and the following disclaimer in the documentation\n", - " * and/or other materials provided with the distribution.\n", - " * \n", - " * Neither the name of Anaconda nor the names of any contributors\n", - " * may be used to endorse or promote products derived from this software\n", - " * without specific prior written permission.\n", - " * \n", - " * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n", - " * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n", - " * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n", - " * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE\n", - " * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n", - " * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n", - " * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\n", - " * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\n", - " * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n", - " * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\n", - " * THE POSSIBILITY OF SUCH DAMAGE.\n", - " */\n", - " (function(root, factory) {\n", - " const bokeh = factory();\n", - " bokeh.__bokeh__ = true;\n", - " if (typeof root.Bokeh === \"undefined\" || typeof root.Bokeh.__bokeh__ === \"undefined\") {\n", - " root.Bokeh = bokeh;\n", - " }\n", - " const Bokeh = root.Bokeh;\n", - " Bokeh[bokeh.version] = bokeh;\n", - " })(this, function() {\n", - " let define;\n", - " const parent_require = typeof require === \"function\" && require\n", - " return (function(modules, entry, aliases, externals) {\n", - " if (aliases === undefined) aliases = {};\n", - " if (externals === undefined) externals = {};\n", - "\n", - " const cache = {};\n", - "\n", - " const normalize = function(name) {\n", - " if (typeof name === \"number\")\n", - " return name;\n", - "\n", - " if (name === \"bokehjs\")\n", - " return entry;\n", - "\n", - " if (!externals[name]) {\n", - " const prefix = \"@bokehjs/\"\n", - " if (name.slice(0, prefix.length) === prefix)\n", - " name = name.slice(prefix.length)\n", - " }\n", - "\n", - " const alias = aliases[name]\n", - " if (alias != null)\n", - " return alias;\n", - "\n", - " const trailing = name.length > 0 && name[name.lenght-1] === \"/\";\n", - " const index = aliases[name + (trailing ? \"\" : \"/\") + \"index\"];\n", - " if (index != null)\n", - " return index;\n", - "\n", - " return name;\n", - " }\n", - "\n", - " const require = function(name) {\n", - " let mod = cache[name];\n", - " if (!mod) {\n", - " const id = normalize(name);\n", - "\n", - " mod = cache[id];\n", - " if (!mod) {\n", - " if (!modules[id]) {\n", - " if (externals[id] === false || (externals[id] == true && parent_require)) {\n", - " try {\n", - " mod = {exports: externals[id] ? parent_require(id) : {}};\n", - " cache[id] = cache[name] = mod;\n", - " return mod.exports;\n", - " } catch (e) {}\n", - " }\n", - "\n", - " const err = new Error(\"Cannot find module '\" + name + \"'\");\n", - " err.code = 'MODULE_NOT_FOUND';\n", - " throw err;\n", - " }\n", - "\n", - " mod = {exports: {}};\n", - " cache[id] = cache[name] = mod;\n", - "\n", - " function __esModule() {\n", - " Object.defineProperty(mod.exports, \"__esModule\", {value: true});\n", - " }\n", - "\n", - " function __esExport(name, value) {\n", - " Object.defineProperty(mod.exports, name, {\n", - " enumerable: true, get: function () { return value; }\n", - " });\n", - " }\n", - "\n", - " modules[id].call(mod.exports, require, mod, mod.exports, __esModule, __esExport);\n", - " } else {\n", - " cache[name] = mod;\n", - " }\n", - " }\n", - "\n", - " return mod.exports;\n", - " }\n", - " require.resolve = function(name) {\n", - " return \"\"\n", - " }\n", - "\n", - " const main = require(entry);\n", - " main.require = require;\n", - "\n", - " if (typeof Proxy !== \"undefined\") {\n", - " // allow Bokeh.loader[\"@bokehjs/module/name\"] syntax\n", - " main.loader = new Proxy({}, {\n", - " get: function(_obj, module) {\n", - " return require(module);\n", - " }\n", - " });\n", - " }\n", - "\n", - " main.register_plugin = function(plugin_modules, plugin_entry, plugin_aliases, plugin_externals) {\n", - " if (plugin_aliases === undefined) plugin_aliases = {};\n", - " if (plugin_externals === undefined) plugin_externals = {};\n", - "\n", - " for (let name in plugin_modules) {\n", - " modules[name] = plugin_modules[name];\n", - " }\n", - "\n", - " for (let name in plugin_aliases) {\n", - " aliases[name] = plugin_aliases[name];\n", - " }\n", - "\n", - " for (let name in plugin_externals) {\n", - " externals[name] = plugin_externals[name];\n", - " }\n", - "\n", - " const plugin = require(plugin_entry);\n", - "\n", - " for (let name in plugin) {\n", - " main[name] = plugin[name];\n", - " }\n", - "\n", - " return plugin;\n", - " }\n", - "\n", - " return main;\n", - " })\n", - " ([\n", - " function _(t,_,n,o,r){o();t(1).__exportStar(t(2),n),t(70)},\n", - " function _(e,t,r,n,o){n();var a=function(e,t){return a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])},a(e,t)};r.__extends=function(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Class extends value \"+String(t)+\" is not a constructor or null\");function r(){this.constructor=e}a(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)};function i(e){var t=\"function\"==typeof Symbol&&Symbol.iterator,r=t&&e[t],n=0;if(r)return r.call(e);if(e&&\"number\"==typeof e.length)return{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?\"Object is not iterable.\":\"Symbol.iterator is not defined.\")}function c(e,t){var r=\"function\"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,o,a=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=a.next()).done;)i.push(n.value)}catch(e){o={error:e}}finally{try{n&&!n.done&&(r=a.return)&&r.call(a)}finally{if(o)throw o.error}}return i}function u(e){return this instanceof u?(this.v=e,this):new u(e)}r.__assign=function(){return r.__assign=Object.assign||function(e){for(var t,r=1,n=arguments.length;r=0;c--)(o=e[c])&&(i=(a<3?o(i):a>3?o(t,r,i):o(t,r))||i);return a>3&&i&&Object.defineProperty(t,r,i),i},r.__param=function(e,t){return function(r,n){t(r,n,e)}},r.__esDecorate=function(e,t,r,n,o,a){function i(e){if(void 0!==e&&\"function\"!=typeof e)throw new TypeError(\"Function expected\");return e}for(var c,u=n.kind,f=\"getter\"===u?\"get\":\"setter\"===u?\"set\":\"value\",l=!t&&e?n.static?e:e.prototype:null,s=t||(l?Object.getOwnPropertyDescriptor(l,n.name):{}),p=!1,y=r.length-1;y>=0;y--){var d={};for(var h in n)d[h]=\"access\"===h?{}:n[h];for(var h in n.access)d.access[h]=n.access[h];d.addInitializer=function(e){if(p)throw new TypeError(\"Cannot add initializers after decoration has completed\");a.push(i(e||null))};var _=(0,r[y])(\"accessor\"===u?{get:s.get,set:s.set}:s[f],d);if(\"accessor\"===u){if(void 0===_)continue;if(null===_||\"object\"!=typeof _)throw new TypeError(\"Object expected\");(c=i(_.get))&&(s.get=c),(c=i(_.set))&&(s.set=c),(c=i(_.init))&&o.push(c)}else(c=i(_))&&(\"field\"===u?o.push(c):s[f]=c)}l&&Object.defineProperty(l,n.name,s),p=!0},r.__runInitializers=function(e,t,r){for(var n=arguments.length>2,o=0;o0&&o[o.length-1])||6!==c[0]&&2!==c[0])){i=0;continue}if(3===c[0]&&(!o||c[1]>o[0]&&c[1]1||c(e,t)}))})}function c(e,t){try{(r=o[e](t)).value instanceof u?Promise.resolve(r.value.v).then(f,l):s(a[0][2],r)}catch(e){s(a[0][3],e)}var r}function f(e){c(\"next\",e)}function l(e){c(\"throw\",e)}function s(e,t){e(t),a.shift(),a.length&&c(a[0][0],a[0][1])}},r.__asyncDelegator=function(e){var t,r;return t={},n(\"next\"),n(\"throw\",(function(e){throw e})),n(\"return\"),t[Symbol.iterator]=function(){return this},t;function n(n,o){t[n]=e[n]?function(t){return(r=!r)?{value:u(e[n](t)),done:!1}:o?o(t):t}:o}},r.__asyncValues=function(e){if(!Symbol.asyncIterator)throw new TypeError(\"Symbol.asyncIterator is not defined.\");var t,r=e[Symbol.asyncIterator];return r?r.call(e):(e=i(e),t={},n(\"next\"),n(\"throw\"),n(\"return\"),t[Symbol.asyncIterator]=function(){return this},t);function n(r){t[r]=e[r]&&function(t){return new Promise((function(n,o){(function(e,t,r,n){Promise.resolve(n).then((function(t){e({value:t,done:r})}),t)})(n,o,(t=e[r](t)).done,t.value)}))}}},r.__makeTemplateObject=function(e,t){return Object.defineProperty?Object.defineProperty(e,\"raw\",{value:t}):e.raw=t,e};var f=Object.create?function(e,t){Object.defineProperty(e,\"default\",{enumerable:!0,value:t})}:function(e,t){e.default=t};r.__importStar=function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)\"default\"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&(0,r.__createBinding)(t,e,n);return f(t,e),t},r.__importDefault=function(e){return e&&e.__esModule?e:{default:e}},r.__classPrivateFieldGet=function(e,t,r,n){if(\"a\"===r&&!n)throw new TypeError(\"Private accessor was defined without a getter\");if(\"function\"==typeof t?e!==t||!n:!t.has(e))throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");return\"m\"===r?n:\"a\"===r?n.call(e):n?n.value:t.get(e)},r.__classPrivateFieldSet=function(e,t,r,n,o){if(\"m\"===n)throw new TypeError(\"Private method is not writable\");if(\"a\"===n&&!o)throw new TypeError(\"Private accessor was defined without a setter\");if(\"function\"==typeof t?e!==t||!o:!t.has(e))throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");return\"a\"===n?o.call(e,r):o?o.value=r:t.set(e,r),r},r.__classPrivateFieldIn=function(e,t){if(null===t||\"object\"!=typeof t&&\"function\"!=typeof t)throw new TypeError(\"Cannot use 'in' operator on non-object\");return\"function\"==typeof e?t===e:e.has(t)}},\n", - " function _(e,t,o,s,l){s();const r=e(1);l(\"version\",e(3).version),l(\"index\",e(4).index),o.embed=r.__importStar(e(4)),o.protocol=r.__importStar(e(67)),o._testing=r.__importStar(e(68));var _=e(18);l(\"logger\",_.logger),l(\"set_log_level\",_.set_log_level),l(\"settings\",e(28).settings),l(\"Models\",e(7).default_resolver),l(\"documents\",e(5).documents),l(\"safely\",e(69).safely)},\n", - " function _(n,i,o,c,e){c(),o.version=\"3.1.1\"},\n", - " function _(e,o,n,t,s){t();const r=e(5),d=e(18),i=e(38),_=e(9),c=e(8),a=e(16),u=e(53),l=e(60),m=e(65);var f=e(53);s(\"add_document_standalone\",f.add_document_standalone),s(\"index\",f.index),s(\"add_document_from_session\",e(60).add_document_from_session);var w=e(66);async function g(e,o,n,t){(0,c.isString)(e)&&(e=JSON.parse((0,i.unescape)(e)));const s={};for(const[o,n]of(0,_.entries)(e))s[o]=r.Document.from_json(n);const a=[];for(const e of o){const o=(0,m._resolve_element)(e),r=(0,m._resolve_root_elements)(e);if(null!=e.docid)a.push(await(0,u.add_document_standalone)(s[e.docid],o,r,e.use_for_title));else{if(null==e.token)throw new Error(\"Error rendering Bokeh items: either 'docid' or 'token' was expected.\");{const s=(0,l._get_ws_url)(n,t);d.logger.debug(`embed: computed ws url: ${s}`);try{a.push(await(0,l.add_document_from_session)(s,e.token,o,r,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\",w.embed_items_notebook),s(\"kernels\",w.kernels),n.embed_item=async function(e,o){const n={},t=(0,i.uuid4)();n[t]=e.doc,null==o&&(o=e.target_id);const s={roots:{[e.root_id]:o},root_ids:[e.root_id],docid:t};await(0,a.defer)();const[r]=await g(n,[s]);return r},n.embed_items=async function(e,o,n,t){return await(0,a.defer)(),g(e,o,n,t)}},\n", - " function _(t,_,o,r,n){r();const a=t(1);a.__exportStar(t(6),o),a.__exportStar(t(39),o)},\n", - " function _(e,t,s,o,n){o();const i=e(1),_=e(7),l=e(3),r=e(18),a=e(45),c=e(30),d=e(46),h=e(49),m=e(15),u=e(8),f=e(25),v=e(10),g=e(9),p=i.__importStar(e(43)),w=e(50),b=e(51),k=e(52),y=e(39);d.Deserializer.register(\"model\",b.decode_def);class z{constructor(e){this.subscribed_models=new Set,this.document=e}send_event(e){if(e.publish){const t=new y.MessageSentEvent(this.document,\"bokeh_event\",e);this.document._trigger_on_change(t)}this.document._trigger_on_event(e)}trigger(e){for(const t of this.subscribed_models)null!=e.origin&&e.origin!=t||t._process_event(e)}}s.EventManager=z,z.__name__=\"EventManager\",s.documents=[],s.DEFAULT_TITLE=\"Bokeh Application\";class S{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 a.ModelResolver(_.default_resolver),this._title=s.DEFAULT_TITLE,this._roots=[],this._all_models=new Map,this._new_models=new Set,this._all_models_freeze_count=0,this._callbacks=new Map,this._document_callbacks=new Map,this._message_callbacks=new Map,this.event_manager=new z(this),this.idle=new m.Signal0(this,\"idle\"),this._idle_roots=new WeakSet,this._interactive_timestamp=null,this._interactive_plot=null}[f.equals](e,t){return this==e}get is_idle(){for(const e of this._roots)if(!this._idle_roots.has(e))return!1;return!0}notify_idle(e){this._idle_roots.add(e),this.is_idle&&(r.logger.info(`document idle at ${Date.now()-this._init_timestamp} ms`),this.event_manager.send_event(new k.DocumentReady),this.idle.emit())}clear(){this._push_all_models_freeze();try{for(;this._roots.length>0;)this.remove_root(this._roots[0])}finally{this._pop_all_models_freeze()}}interactive_start(e,t=null){null==this._interactive_plot&&(this._interactive_plot=e,this._interactive_plot.trigger_event(new k.LODStart)),this._interactive_finalize=t,this._interactive_timestamp=Date.now()}interactive_stop(){null!=this._interactive_plot&&(this._interactive_plot.trigger_event(new k.LODEnd),null!=this._interactive_finalize&&this._interactive_finalize()),this._interactive_plot=null,this._interactive_timestamp=null,this._interactive_finalize=null}interactive_duration(){return null==this._interactive_timestamp?-1:Date.now()-this._interactive_timestamp}destructively_move(e){if(e===this)throw new Error(\"Attempted to overwrite a document with itself\");e.clear();const t=(0,v.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(){r.logger.debug(\"invalidating document models\"),0===this._all_models_freeze_count&&this._recompute_all_models()}_recompute_all_models(){let e=new Set;for(const t of this._roots)e=p.union(e,t.references());const t=new Set(this._all_models.values()),s=p.difference(t,e),o=p.difference(e,t),n=new Map;for(const t of e)n.set(t.id,t);for(const e of s)e.detach_document();for(const e of o)e.attach_document(this),this._new_models.add(e);this._all_models=n}roots(){return this._roots}_add_root(e){if((0,v.includes)(this._roots,e))return!1;this._push_all_models_freeze();try{this._roots.push(e)}finally{this._pop_all_models_freeze()}return!0}_remove_root(e){const t=this._roots.indexOf(e);if(t<0)return!1;this._push_all_models_freeze();try{this._roots.splice(t,1)}finally{this._pop_all_models_freeze()}return!0}_set_title(e){const t=e!=this._title;return t&&(this._title=e),t}add_root(e){this._add_root(e)&&this._trigger_on_change(new y.RootAddedEvent(this,e))}remove_root(e){this._remove_root(e)&&this._trigger_on_change(new y.RootRemovedEvent(this,e))}set_title(e){this._set_title(e)&&this._trigger_on_change(new y.TitleChangedEvent(this,e))}title(){return this._title}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 w.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 y.DocumentEventBatch)for(const s of e.events)t(s);else t(e)}_trigger_on_event(e){const t=this._document_callbacks.get(e.event_name);if(null!=t)for(const s of t)s.execute(this,e)}on_event(e,...t){var s;const o=(0,u.isString)(e)?e:e.prototype.event_name,n=null!==(s=this._document_callbacks.get(o))&&void 0!==s?s:[],i=t.map((e=>(0,u.isFunction)(e)?{execute:e}:e));this._document_callbacks.set(o,[...n,...i])}to_json_string(e=!0){return JSON.stringify(this.to_json(e))}to_json(e=!0){const t=new c.Serializer({include_defaults:e}).encode(this._roots);return{version:l.version,title:this._title,roots:t}}static from_json_string(e,t){const s=JSON.parse(e);return S.from_json(s,t)}static _handle_version(e){if(null!=e.version){const t=e.version,s=-1!==t.indexOf(\"+\")||-1!==t.indexOf(\"-\"),o=`Library versions: JS (${l.version}) / Python (${t})`;s||(0,h.pyify_version)(l.version)==t?r.logger.debug(o):(r.logger.warn(\"JS/Python version mismatch\"),r.logger.warn(o))}else r.logger.warn(\"'version' field is missing\")}static from_json(e,t){r.logger.debug(\"Creating Document from JSON\"),S._handle_version(e);const s=new a.ModelResolver(_.default_resolver);if(null!=e.defs){new d.Deserializer(s).decode(e.defs)}const o=new S({resolver:s});o._push_all_models_freeze();const n=e=>null==t?void 0:t.push(e);o.on_change(n,!0);const i=new d.Deserializer(s,o._all_models,(e=>e.attach_document(o))),l=i.decode(e.roots),c=null!=e.callbacks?i.decode(e.callbacks):{};o.remove_on_change(n);for(const[e,t]of(0,g.entries)(c))o.on_event(e,...t);for(const e of l)o.add_root(e);return null!=e.title&&o.set_title(e.title),o._pop_all_models_freeze(),o}replace_with_json(e){S.from_json(e).destructively_move(this)}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 Map;for(const e of this._all_models.values())this._new_models.has(e)||t.set(e,e.ref());const s={events:new c.Serializer({references:t,binary:!0}).encode(e)};return this._new_models.clear(),s}apply_json_patch(e,t=new Map){this._push_all_models_freeze();const s=new d.Deserializer(this._resolver,this._all_models,(e=>e.attach_document(this))).decode(e.events,t);for(const e of s)switch(e.kind){case\"MessageSent\":{const{msg_type:t,msg_data:s}=e;this._trigger_on_message(t,s);break}case\"ModelChanged\":{const{model:t,attr:s,new:o}=e;t.setv({[s]:o},{sync:!1});break}case\"ColumnDataChanged\":{const{model:t,attr:s,cols:o,data:n}=e;if(null!=o){const e=t.property(s).get_value();for(const t in e)t in n||(n[t]=e[t])}t.setv({data:n},{sync:!1,check_eq:!1});break}case\"ColumnsStreamed\":{const{model:t,attr:s,data:o,rollover:n}=e,i=t.property(s);t.stream_to(i,o,n,{sync:!1});break}case\"ColumnsPatched\":{const{model:t,attr:s,patches:o}=e,n=t.property(s);t.patch_to(n,o,{sync:!1});break}case\"RootAdded\":this._add_root(e.model);break;case\"RootRemoved\":this._remove_root(e.model);break;case\"TitleChanged\":this._set_title(e.title);break;default:throw new Error(`unknown patch event type '${e.kind}'`)}this._pop_all_models_freeze()}}s.Document=S,S.__name__=\"Document\"},\n", - " function _(e,o,r,s,t){s();const l=e(8),n=e(9),a=e(14),f=e(45);r.default_resolver=new f.ModelResolver(null),r.register_models=function(e,o=!1){for(const t of(0,l.isArray)(e)?e:(0,n.values)(e))s=t,(0,l.isObject)(s)&&s.prototype instanceof a.HasProps&&r.default_resolver.register(t,o);var s}},\n", - " function _(n,t,r,i,o){i();\n", - " // (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n", - " // Underscore may be freely distributed under the MIT license.\n", - " const u=Object.prototype.toString;function e(n){return null==n}function c(n){return!0===n||!1===n||\"[object Boolean]\"===u.call(n)}function f(n){return\"[object Number]\"===u.call(n)}function s(n){return\"[object String]\"===u.call(n)}function l(n){return\"symbol\"==typeof n}function a(n){const t=typeof n;return\"function\"===t||\"object\"===t&&!!n}function b(n){return a(n)&&Symbol.iterator in n}r.is_undefined=function(n){return void 0===n},r.is_defined=function(n){return void 0!==n},r.is_nullish=e,r.isNull=function(n){return null==n},r.isNotNull=function(n){return null!=n},r.isBoolean=c,r.isNumber=f,r.isInteger=function(n){return f(n)&&Number.isInteger(n)},r.isString=s,r.isSymbol=l,r.isPrimitive=function(n){return null===n||c(n)||f(n)||s(n)||l(n)},r.isFunction=function(n){const t=u.call(n);return\"[object Function]\"===t||\"[object AsyncFunction]\"===t},r.isArray=function(n){return Array.isArray(n)},r.isArrayOf=function(n,t){for(const r of n)if(!t(r))return!1;return!0},r.isArrayableOf=function(n,t){for(const r of n)if(!t(r))return!1;return!0},r.isTypedArray=function(n){return ArrayBuffer.isView(n)&&!(n instanceof DataView)},r.isObject=a,r.isBasicObject=function(n){return a(n)&&e(n.constructor)},r.isPlainObject=function(n){return a(n)&&(e(n.constructor)||n.constructor===Object)},r.isIterable=b,r.isArrayable=function(n){return b(n)&&\"length\"in n}},\n", - " function _(t,e,s,n,i){var o;n();const r=t(10),{hasOwnProperty:c}=Object.prototype;function b(t){return Object.keys(t).length}s.keys=Object.keys,s.values=Object.values,s.entries=Object.entries,s.assign=Object.assign,s.to_object=Object.fromEntries,s.extend=s.assign,s.fields=function(t){return(0,s.keys)(t)},s.clone=function(t){return Object.assign({},t)},s.merge=function(t,e){const s=Object.create(Object.prototype),n=(0,r.concat)([Object.keys(t),Object.keys(e)]);for(const i of n){const n=c.call(t,i)?t[i]:[],o=c.call(e,i)?e[i]:[];s[i]=(0,r.union)(n,o)}return s},s.size=b,s.is_empty=function(t){return 0==b(t)};class u{constructor(t){this[o]=\"Dict\",this.obj=t}clear(){for(const t of(0,s.keys)(this.obj))delete this.obj[t]}delete(t){const e=t in this;return delete this.obj[t],e}get(t){return t in this.obj?this.obj[t]:void 0}has(t){return t in this.obj}set(t,e){return this.obj[t]=e,this}get size(){return b(this.obj)}get is_empty(){return 0==this.size}[(o=Symbol.toStringTag,Symbol.iterator)](){return this.entries()}*keys(){yield*(0,s.keys)(this.obj)}*values(){yield*(0,s.values)(this.obj)}*entries(){yield*(0,s.entries)(this.obj)}forEach(t,e){for(const[s,n]of this.entries())t.call(e,n,s,this)}}s.Dict=u,u.__name__=\"Dict\",s.dict=function(t){return new u(t)}},\n", - " function _(n,t,e,r,o){r();\n", - " // (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n", - " // Underscore may be freely distributed under the MIT license.\n", - " const i=n(11),c=n(12),u=n(8),s=n(13);var f=n(13);o(\"map\",f.map),o(\"reduce\",f.reduce),o(\"min\",f.min),o(\"min_by\",f.min_by),o(\"max\",f.max),o(\"max_by\",f.max_by),o(\"sum\",f.sum),o(\"cumsum\",f.cumsum),o(\"every\",f.every),o(\"some\",f.some),o(\"find\",f.find),o(\"find_last\",f.find_last),o(\"find_index\",f.find_index),o(\"find_last_index\",f.find_last_index),o(\"sorted_index\",f.sorted_index),o(\"is_empty\",f.is_empty),o(\"includes\",f.includes),o(\"contains\",f.contains),o(\"sort_by\",f.sort_by);const l=Array.prototype.slice;function a(n){return l.call(n)}function m(n,t,e=1){(0,c.assert)(e>0,\"'step' must be a positive number\"),null==t&&(t=n,n=0);const{max:r,ceil:o,abs:i}=Math,u=n<=t?e:-e,s=r(o(i(t-n)/e),0),f=new Array(s);for(let t=0;t=0?t:n.length+t]},e.zip=function(...n){if(0==n.length)return[];const t=(0,s.min)(n.map((n=>n.length))),e=n.length,r=new Array(t);for(let o=0;on.length))),r=Array(e);for(let n=0;nn[t]))},e.argmax=function(n){return(0,s.max_by)(m(n.length),(t=>n[t]))},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);(0,s.includes)(r,n)||(r.push(n),e.push(o))}return e},e._union=d,e.union=function(...n){return[...d(n)]},e.intersection=function(n,...t){const e=[];n:for(const r of n)if(!(0,s.includes)(e,r)){for(const n of t)if(!(0,s.includes)(n,r))continue n;e.push(r)}return e},e.difference=function(n,...t){const e=d(t);return(0,s.filter)(n,(n=>!e.has(n)))},e.remove_at=function(n,t){(0,c.assert)((0,u.isInteger)(t)&&t>=0);const e=a(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 s(n,t){return l(n-t)}function h(n){switch(n){case\"deg\":return u/180;case\"rad\":return 1;case\"grad\":return u/200;case\"turn\":return 2*u}}function g(n,t){for(n=Math.abs(n),t=Math.abs(t);0!=t;)[n,t]=[t,n%t];return n}r.angle_norm=l,r.angle_dist=s,r.angle_between=function(n,t,r,o=!1){const e=s(t,r);if(0==e)return!1;if(e==2*u)return!0;const a=l(n),c=s(t,a)<=e&&s(a,r)<=e;return o?!c:c},r.randomIn=function(n,t){return null==t&&(t=n,n=0),n+Math.floor(Math.random()*(t-n+1))},r.atan2=function(n,t){return Math.atan2(t[1]-n[1],t[0]-n[0])},r.radians=function(n){return n*(u/180)},r.degrees=function(n){return n/(u/180)},r.compute_angle=function(n,t,r=\"anticlock\"){return-(\"anticlock\"==r?1:-1)*n*h(t)},r.invert_angle=function(n,t,r=\"anticlock\"){return-(\"anticlock\"==r?1:-1)*n/h(t)},r.to_radians_coeff=h,r.clamp=function(n,t,r){return nr?r:n},r.log=function(n,t=Math.E){return Math.log(n)/Math.log(t)},r.gcd=g,r.lcm=function(n,...t){for(const r of t)n=Math.floor(n*r/g(n,r));return n},r.float=Symbol(\"float\"),r.is_Floating=function(n){return(0,a.isObject)(n)&&r.float in n};class m{constructor(n,t){(0,c.assert)(0!=t,\"Zero divisor\");const r=g(n,t),o=f(n)*f(t);this.numer=o*i(n)/r,this.denom=i(t)/r}[r.float](){return this.numer/this.denom}toString(){return`${this.numer}/${this.denom}`}}function _(n){let t=1;for(let r=2;r<=n;r++)t*=r;return t}r.Fraction=m,m.__name__=\"Fraction\",r.float32_epsilon=1.1920928955078125e-7,r.factorial=_,r.hermite=function(n){const t=new Array(n+1);t.fill(0);const r=_(n);for(let o=0;o<=Math.floor(n/2);o++){const e=(-1)**o*r/(_(o)*_(n-2*o))*2**(n-2*o);t[2*o]=e}return t},r.eval_poly=function(n,t){let r=0,o=1;for(let e=n.length-1;e>=0;e--)r+=o*n[e],o*=t;return 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(11);function u(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,u=new n.constructor(i);let c=0;for(;c0?0:r-1;for(;o>=0&&ot[t.length-1])return t.length;if(1==t.length)return 0;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=u,e.head=c,e.insert=function(n,t,e){return u(n,e,0,t)},e.append=function(n,t){return u(n,n.length,0,t)},e.prepend=function(n,t){return u(n,0,0,t)},e.index_of=function(n,t){return n.indexOf(t)},e.includes=l,e.contains=l,e.subselect=function(n,t){const e=t.length,r=new n.constructor(e);for(let o=0;o({index:e,key:t(n)})));return e.sort(((n,t)=>{const e=n.key,r=t.key;if(e!==r){if(e>r)return 1;if(en[e[r].index]))},e.min=function(n){let t,e=1/0;for(let r=0,o=n.length;re&&(e=t);return e},e.minmax=function(n){let t,e=1/0,r=-1/0;for(let o=0,i=n.length;or&&(r=t));return[e,r]},e.minmax2=function(n,t){let e,r,o=1/0,i=-1/0,u=1/0,c=-1/0;const l=Math.min(n.length,t.length);for(let f=0;fi&&(i=e),rc&&(c=r));return[o,i,u,c]},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=u)}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(const e of n)if(!t(e))return!1;return!0},e.some=function(n,t){for(const e of n)if(t(e))return!0;return!1},e.find_index=a(1),e.find_last_index=a(-1),e.find=function(n,t){const r=(0,e.find_index)(n,t);return-1==r?void 0:n[r]},e.find_last=function(n,t){const r=(0,e.find_last_index)(n,t);return-1==r?void 0:n[r]},e.sorted_index=h,e.bin_counts=function(n,t){const e=t.length-1,r=Array(e).fill(0);for(let o=0;o(n-t)/r))}},\n", - " function _(t,e,s,n,i){var r;n();const o=t(1),c=t(15),a=o.__importStar(t(17)),h=o.__importStar(t(20)),_=t(12),l=t(38),u=t(9),f=t(8),p=t(25),d=t(30),g=t(39),y=t(25),m=t(40),v=t(41),w=o.__importStar(t(20)),b=t(27),S=t(42),$=new WeakMap;class j extends((0,c.Signalable)()){get is_syncable(){return!0}get type(){return this.constructor.__qualified__}static get __qualified__(){let t=$.get(this);if(null==t){const{__module__:e,__name__:s}=this;t=null!=e?`${e}.${s}`:s,$.set(this,t)}return t}static set __qualified__(t){$.set(this,t)}get[Symbol.toStringTag](){return this.constructor.__qualified__}static _fix_default(t,e){if(void 0===t||t===a.unset)return()=>a.unset;if((0,f.isFunction)(t))return t;if((0,f.isPrimitive)(t))return()=>t;{const e=new v.Cloner;return()=>e.clone(t)}}static define(t){for(const[e,s]of(0,u.entries)((0,f.isFunction)(t)?t(w):t)){if(e in this.prototype._props)throw new Error(`attempted to redefine property '${this.prototype.type}.${e}'`);if(e in this.prototype)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,i={}]=s,r={type:t,default_value:this._fix_default(n,e),options:i};this.prototype._props=Object.assign(Object.assign({},this.prototype._props),{[e]:r})}}static internal(t){const e={};for(const[s,n]of(0,u.entries)((0,f.isFunction)(t)?t(w):t)){const[t,i,r={}]=n;e[s]=[t,i,Object.assign(Object.assign({},r),{internal:!0})]}this.define(e)}static mixins(t){function e(t,e){const s={};for(const[n,i]of(0,u.entries)(e))s[t+n]=i;return s}const s={},n=[];for(const i of(0,f.isArray)(t)?t:[t])if((0,f.isArray)(i)){const[t,r]=i;(0,u.extend)(s,e(t,r)),n.push([t,r])}else{const t=i;(0,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(0,u.entries)(t)){const t=this._fix_default(s,e);if(!(e in this.prototype._props))throw new Error(`attempted to override nonexistent '${this.prototype.type}.${e}'`);const n=this.prototype._props[e],i=Object.assign({},this.prototype._props);i[e]=Object.assign(Object.assign({},n),{default_value:t}),this.prototype._props=i}}static toString(){return this.__qualified__}toString(){return`${this.type}(${this.id})`}property(t){if(t in this.properties)return this.properties[t];throw new Error(`unknown property ${this.type}.${t}`)}get attributes(){const t={};for(const e of this)e.is_unset||(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)}[y.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}[m.pretty](t){const e=t.token,s=[];for(const n of this)if(n.dirty){const i=n.get_value();s.push(`${n.attr}${e(\":\")} ${t.to_string(i)}`)}return`${this.constructor.__qualified__}${e(\"(\")}${e(\"{\")}${s.join(`${e(\",\")} `)}${e(\"}\")}${e(\")\")}`}[d.serialize](t){const e=this.ref();t.add_ref(this,e);const s={};for(const e of this)if(e.syncable&&(t.include_defaults||e.dirty)){const n=e.get_value();s[e.attr]=t.encode(n)}const{type:n,id:i}=this,r={type:\"object\",name:n,id:i};return(0,u.is_empty)(s)?r:Object.assign(Object.assign({},r),{attributes:s})}constructor(t={}){super(),this.document=null,this.destroyed=new c.Signal0(this,\"destroyed\"),this.change=new c.Signal0(this,\"change\"),this.transformchange=new c.Signal0(this,\"transformchange\"),this.exprchange=new c.Signal0(this,\"exprchange\"),this.streaming=new c.Signal0(this,\"streaming\"),this.patching=new c.Signal(this,\"patching\"),this.properties={},this._watchers=new WeakMap,this._pending=!1,this._changing=!1;const e=(0,f.isPlainObject)(t)&&\"id\"in t;this.id=e?t.id:(0,l.unique_id)();for(const[t,{type:e,default_value:s,options:n}]of(0,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 h.Kind?new a.PrimitiveProperty(this,t,e,s,n):new e(this,t,h.Any,s,n),this.properties[t]=i)}if(e)(0,_.assert)(1==(0,u.keys)(t).length,\"'id' cannot be used together with property initializers\");else{const e=t instanceof Map?t:new u.Dict(t);this.initialize_props(e),this.finalize(),this.connect_signals()}}initialize_props(t){const e=new Set;for(const s of this){const n=t.get(s.attr);s.initialize(n),e.add(s.attr)}for(const s of t.keys())e.has(s)||this.property(s)}finalize(){this.initialize()}initialize(){}assert_initialized(){for(const t of this)t.syncable&&!t.readonly&&t.get_value()}connect_signals(){for(const t of this){if(!(t instanceof a.VectorSpec||t instanceof a.ScalarSpec))continue;if(t.is_unset)continue;const e=t.get_value();null!=e.transform&&this.connect(e.transform.change,(()=>this.transformchange.emit())),(0,b.isExpr)(e)&&this.connect(e.expr.change,(()=>this.exprchange.emit()))}}disconnect_signals(){c.Signal.disconnect_receiver(this)}destroy(){this.disconnect_signals(),this.destroyed.emit()}clone(){return(new v.Cloner).clone(this)}_clear_watchers(){this._watchers=new WeakMap}changed_for(t){const e=this._watchers.get(t);return this._watchers.set(t,!1),null==e||e}_setv(t,e){var s;const n=e.check_eq,i=new Set,r=this._changing;this._changing=!0;for(const[e,s]of t)!1!==n&&!e.is_unset&&(0,p.is_equal)(e.get_value(),s)||(e.set_value(s),i.add(e));i.size>0&&(this._clear_watchers(),this._pending=!0);for(const t of i)t.change.emit();if(!r){if(null===(s=e.no_change)||void 0===s||!s)for(;this._pending;)this._pending=!1,this.change.emit();this._pending=!1,this._changing=!1}return i}setv(t,e={}){var s,n;const i=(0,u.entries)(t);if(0==i.length)return;if(null!==(s=e.silent)&&void 0!==s&&s){this._clear_watchers();for(const[t,e]of i)this.properties[t].set_value(e);return}const r=new Map,o=new Map;for(const[t,e]of i){const s=this.properties[t];r.set(s,e),o.set(s,s.is_unset?void 0:s.get_value())}const c=this._setv(r,e),{document:a}=this;if(null!=a){const t=[];for(const[e,s]of o)c.has(e)&&t.push([e,s,e.get_value()]);for(const[,e,s]of t)if(this._needs_invalidate(e,s)){a._invalidate_all_models();break}(null===(n=e.sync)||void 0===n||n)&&this._push_changes(t)}}ref(){return{id:this.id}}*[Symbol.iterator](){yield*(0,u.values)(this.properties)}*syncable_properties(){for(const t of this)t.syncable&&(yield t)}static _value_record_references(t,e,s){const{recursive:n}=s;if((0,f.isObject)(t))if(t instanceof j){if(!e.has(t)&&(e.add(t),n))for(const s of t.syncable_properties())if(!s.is_unset){const t=s.get_value();j._value_record_references(t,e,{recursive:n})}}else if((0,f.isIterable)(t))for(const s of t)j._value_record_references(s,e,{recursive:n});else if((0,f.isPlainObject)(t))for(const s of(0,u.values)(t))j._value_record_references(s,e,{recursive:n})}references(){const t=new Set;return j._value_record_references(this,t,{recursive:!0}),t}_doc_attached(){}_doc_detached(){}attach_document(t){if(null!=this.document){if(this.document==t)return;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;j._value_record_references(e,s,{recursive:!1});const n=new Set;j._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){if(!this.is_syncable)return;const{document:e}=this;if(null==e)return;const s=[];for(const[n,,i]of t)n.syncable&&s.push(new g.ModelChangedEvent(e,this,n.attr,i));if(0!=s.length){let t;1==s.length?[t]=s:t=new g.DocumentEventBatch(e,s),e._trigger_on_change(t)}}on_change(t,e){for(const s of(0,f.isArray)(t)?t:[t])this.connect(s.change,e)}stream_to(t,e,s,{sync:n}={}){const i=t.get_value();if((0,S.stream_to_columns)(i,e,s),this._clear_watchers(),t.set_value(i),this.streaming.emit(),null!=this.document&&(null==n||n)){const n=new g.ColumnsStreamedEvent(this.document,this,t.attr,e,s);this.document._trigger_on_change(n)}}patch_to(t,e,{sync:s}={}){const n=t.get_value(),i=(0,S.patch_to_columns)(n,e);if(this._clear_watchers(),t.set_value(n),this.patching.emit([...i]),null!=this.document&&(null==s||s)){const s=new g.ColumnsPatchedEvent(this.document,this,t.attr,e);this.document._trigger_on_change(s)}}}s.HasProps=j,(r=j).prototype._props={},r.prototype._mixins=[]},\n", - " function _(n,e,t,s,l){s();const r=n(16),i=n(10);class o{constructor(n,e){this.sender=n,this.name=e}connect(n,e=null){t.receivers_for_sender.has(this.sender)||t.receivers_for_sender.set(this.sender,[]);const s=t.receivers_for_sender.get(this.sender);if(null!=f(s,this,n,e))return!1;const l=null!=e?e:n;u.has(l)||u.set(l,[]);const r=u.get(l),i={signal:this,slot:n,context:e};return s.push(i),r.push(i),!0}disconnect(n,e=null){const s=t.receivers_for_sender.get(this.sender);if(null==s||0===s.length)return!1;const l=f(s,this,n,e);if(null==l)return!1;const r=null!=e?e:n,i=u.get(r);return l.signal=null,g(s),g(i),!0}emit(n){var e;const s=null!==(e=t.receivers_for_sender.get(this.sender))&&void 0!==e?e:[];for(const{signal:e,slot:t,context:l}of s)e===this&&t.call(l,n,this.sender)}}t.Signal=o,o.__name__=\"Signal\";class c extends o{emit(){super.emit(void 0)}}t.Signal0=c,c.__name__=\"Signal0\",function(n){n.disconnect_between=function(n,e){const s=t.receivers_for_sender.get(n);if(null==s||0===s.length)return;const l=u.get(e);if(null!=l&&0!==l.length){for(const e of l){if(null==e.signal)return;e.signal.sender===n&&(e.signal=null)}g(s),g(l)}},n.disconnect_sender=function(n){var e;const s=t.receivers_for_sender.get(n);if(null!=s&&0!==s.length){for(const n of s){if(null==n.signal)return;const t=null!==(e=n.context)&&void 0!==e?e:n.slot;n.signal=null,g(u.get(t))}g(s)}},n.disconnect_receiver=function(n,e,s){const l=u.get(n);if(null!=l&&0!==l.length){for(const n of l){if(null==n.signal)return;if(null!=e&&n.slot!=e)continue;const l=n.signal.sender;null!=s&&s.has(l)||(n.signal=null,g(t.receivers_for_sender.get(l)))}g(l)}},n.disconnect_all=function(n){const e=t.receivers_for_sender.get(n);if(null!=e&&0!==e.length){for(const n of e)n.signal=null;g(e)}const s=u.get(n);if(null!=s&&0!==s.length){for(const n of s)n.signal=null;g(s)}}}(o||(t.Signal=o={})),t.Signalable=function(){return class{connect(n,e){return n.connect(e,this)}disconnect(n,e){return n.disconnect(e,this)}}},t.receivers_for_sender=new WeakMap;const u=new WeakMap;function f(n,e,t,s){return(0,i.find)(n,(n=>n.signal===e&&n.slot===t&&n.context===s))}const a=new Set;function g(n){0===a.size&&(async()=>{await(0,r.defer)(),function(){for(const n of a)(0,i.remove_by)(n,(n=>null==n.signal));a.clear()}()})(),a.add(n)}},\n", - " function _(e,n,t,r,o){r();const s=new MessageChannel,i=new Map;s.port1.onmessage=e=>{const n=e.data,t=i.get(n);if(null!=t)try{t()}finally{i.delete(n)}};let a=1;t.defer=function(){return new Promise((e=>{const n=a++;i.set(n,e),s.port2.postMessage(n)}))},t.delay=function(e){return new Promise((n=>setTimeout(n,e)))},t.paint=function(){return new Promise((e=>{requestAnimationFrame((()=>e()))}))},t.idle=function(){return new Promise((e=>{requestIdleCallback((()=>e()))}))}},\n", - " function _(e,t,r,n,a){n(),r.TextBaselineSpec=r.TextAlignSpec=r.FontStyleSpec=r.FontSizeSpec=r.FontSpec=r.LineDashSpec=r.LineCapSpec=r.LineJoinSpec=r.MarkerSpec=r.ArraySpec=r.NullStringSpec=r.StringSpec=r.AnySpec=void 0;const s=e(1),i=e(15),l=e(18),_=s.__importStar(e(19)),o=e(23),c=e(10),u=e(13),d=e(11),S=e(21),p=e(26),h=e(8),m=e(27),v=e(28),f=e(29),y=e(36),x=e(12),g=e(30),A=e(37);function w(e){try{return JSON.stringify(e)}catch(t){return e.toString()}}function z(e){return(0,h.isPlainObject)(e)&&(void 0===e.value?0:1)+(void 0===e.field?0:1)+(void 0===e.expr?0:1)==1}a(\"Uniform\",A.Uniform),a(\"UniformScalar\",A.UniformScalar),a(\"UniformVector\",A.UniformVector),r.isSpec=z;let b=null;r.use_theme=function(e=null){b=e},r.unset=Symbol(\"unset\");class C extends Error{}r.UnsetValueError=C,C.__name__=\"UnsetValueError\";class F{get syncable(){return!this.internal}get is_unset(){return this._value===r.unset}get initialized(){return this._initialized}initialize(e=r.unset){if(this._initialized)throw new Error(\"already initialized\");let t=r.unset;if(e!==r.unset)t=e,this._dirty=!0;else{const e=this._default_override();if(e!==r.unset)t=e;else{let e=!1;if(null!=b){const r=b.get(this.obj,this.attr);void 0!==r&&(t=r,e=!0)}e||(t=this.default_value(this.obj))}}t!==r.unset?this._update(t):this._value=r.unset,this._initialized=!0}get_value(){if(this._value!==r.unset)return this._value;throw new C(`${this.obj}.${this.attr} is unset`)}set_value(e){this._initialized?(this._update(e),this._dirty=!0):this.initialize(e),y.diagnostics.report(this)}_default_override(){return r.unset}get dirty(){return this._dirty}constructor(e,t,n,a,s={}){var l,_;this._value=r.unset,this._initialized=!1,this._dirty=!1,this.obj=e,this.attr=t,this.kind=n,this.default_value=a,this.change=new i.Signal0(this.obj,\"change\"),this.internal=null!==(l=s.internal)&&void 0!==l&&l,this.readonly=null!==(_=s.readonly)&&void 0!==_&&_,this.convert=s.convert,this.on_update=s.on_update}_update(e){var t;if(this.validate(e),null!=this.convert){const t=this.convert(e);void 0!==t&&(e=t)}this._value=e,null===(t=this.on_update)||void 0===t||t.call(this,e,this.obj)}toString(){return`Prop(${this.obj}.${this.attr}, value: ${w(this._value)})`}normalize(e){return e}validate(e){if(!this.valid(e))throw new Error(`${this.obj}.${this.attr} given invalid value: ${w(e)}`)}valid(e){return this.kind.valid(e)}}r.Property=F,F.__name__=\"Property\";class q{constructor(e){this.attr=e}}r.PropertyAlias=q,q.__name__=\"PropertyAlias\",r.Alias=function(e){return new q(e)};class N extends F{}r.PrimitiveProperty=N,N.__name__=\"PrimitiveProperty\";class U extends N{_default_override(){return v.settings.dev?\"Bokeh\":r.unset}}r.Font=U,U.__name__=\"Font\";class $ extends F{constructor(){super(...arguments),this._value=r.unset}get_value(){if(this._value!==r.unset)return this._value;throw new Error(`${this.obj}.${this.attr} is unset`)}_update(e){if(z(e)?this._value=e:this._value={value:e},(0,h.isPlainObject)(this._value)){const{_value:e}=this;this._value[g.serialize]=t=>{const{value:r,field:n,expr:a,transform:s,units:i}=e;return t.encode_struct(void 0!==r?{type:\"value\",value:r,transform:s,units:i}:void 0!==n?{type:\"field\",field:n,transform:s,units:i}:{type:\"expr\",expr:a,transform:s,units:i})}}(0,m.isValue)(this._value)&&this.validate(this._value.value)}materialize(e){return e}scalar(e,t){return new A.UniformScalar(e,t)}uniform(e){var t;const r=this.get_value(),n=null!==(t=e.get_length())&&void 0!==t?t:1;if((0,m.isExpr)(r)){const{expr:t,transform:a}=r;let s=t.compute(e);return null!=a&&(s=a.compute(s)),s=this.materialize(s),this.scalar(s,n)}{const{value:e,transform:t}=r;let a=e;return null!=t&&(a=t.compute(a)),a=this.materialize(a),this.scalar(a,n)}}}r.ScalarSpec=$,$.__name__=\"ScalarSpec\";class j extends ${}r.AnyScalar=j,j.__name__=\"AnyScalar\";class B extends ${}r.ColorScalar=B,B.__name__=\"ColorScalar\";class L extends ${}r.NumberScalar=L,L.__name__=\"NumberScalar\";class D extends ${}r.StringScalar=D,D.__name__=\"StringScalar\";class E extends ${}r.NullStringScalar=E,E.__name__=\"NullStringScalar\";class P extends ${}r.ArrayScalar=P,P.__name__=\"ArrayScalar\";class T extends ${}r.LineJoinScalar=T,T.__name__=\"LineJoinScalar\";class V extends ${}r.LineCapScalar=V,V.__name__=\"LineCapScalar\";class k extends ${}r.LineDashScalar=k,k.__name__=\"LineDashScalar\";class J extends ${_default_override(){return v.settings.dev?\"Bokeh\":r.unset}}r.FontScalar=J,J.__name__=\"FontScalar\";class X extends ${}r.FontSizeScalar=X,X.__name__=\"FontSizeScalar\";class Y extends ${}r.FontStyleScalar=Y,Y.__name__=\"FontStyleScalar\";class G extends ${}r.TextAlignScalar=G,G.__name__=\"TextAlignScalar\";class I extends ${}r.TextBaselineScalar=I,I.__name__=\"TextBaselineScalar\";class O extends F{constructor(){super(...arguments),this._value=r.unset}get_value(){if(this._value!==r.unset)return this._value;throw new Error(`${this.obj}.${this.attr} is unset`)}_update(e){if(z(e)?this._value=e:this._value={value:e},(0,h.isPlainObject)(this._value)){const{_value:e}=this;this._value[g.serialize]=t=>{const{value:r,field:n,expr:a,transform:s,units:i}=e;return t.encode_struct(void 0!==r?{type:\"value\",value:r,transform:s,units:i}:void 0!==n?{type:\"field\",field:n,transform:s,units:i}:{type:\"expr\",expr:a,transform:s,units:i})}}(0,m.isValue)(this._value)&&this.validate(this._value.value)}materialize(e){return e}v_materialize(e){return e}scalar(e,t){return new A.UniformScalar(e,t)}vector(e){return new A.UniformVector(e)}uniform(e){var t;const r=this.get_value(),n=null!==(t=e.get_length())&&void 0!==t?t:1;if((0,m.isField)(r)){const{field:t,transform:a}=r;let s=e.get_column(t);return null!=s?(null!=a&&(s=a.v_compute(s)),s=this.v_materialize(s),this.vector(s)):(l.logger.warn(`attempted to retrieve property array for nonexistent field '${t}'`),this.scalar(null,n))}if((0,m.isExpr)(r)){const{expr:t,transform:n}=r;let a=t.v_compute(e);return null!=n&&(a=n.v_compute(a)),a=this.v_materialize(a),this.vector(a)}if((0,m.isValue)(r)){const{value:e,transform:t}=r;let a=e;return null!=t&&(a=t.compute(a)),a=this.materialize(a),this.scalar(a,n)}(0,x.unreachable)()}array(e){var t;let r;const n=null!==(t=e.get_length())&&void 0!==t?t:1,a=this.get_value();if((0,m.isField)(a)){const{field:t}=a,s=e.get_column(t);if(null!=s)r=this.normalize(s);else{l.logger.warn(`attempted to retrieve property array for nonexistent field '${t}'`);const e=new Float64Array(n);e.fill(NaN),r=e}}else if((0,m.isExpr)(a)){const{expr:t}=a;r=this.normalize(t.v_compute(e))}else{const e=this.normalize([a.value])[0];if((0,h.isNumber)(e)){const t=new Float64Array(n);t.fill(e),r=t}else r=(0,c.repeat)(e,n)}const{transform:s}=a;return null!=s&&(r=s.v_compute(r)),r}}r.VectorSpec=O,O.__name__=\"VectorSpec\";class R extends O{}r.DataSpec=R,R.__name__=\"DataSpec\";class M extends O{constructor(){super(...arguments),this._value=r.unset}_update(e){if(super._update(e),this._value!==r.unset){const{units:e}=this._value;if(null!=e&&!(0,c.includes)(this.valid_units,e))throw new Error(`units must be one of ${this.valid_units.join(\", \")}; got: ${e}`)}}get units(){var e;return this._value!==r.unset&&null!==(e=this._value.units)&&void 0!==e?e:this.default_units}set units(e){if(this._value===r.unset)throw new Error(`${this.obj}.${this.attr} is unset`);e!=this.default_units?this._value.units=e:delete this._value.units}}r.UnitsSpec=M,M.__name__=\"UnitsSpec\";class H extends M{array(e){return new Float64Array(super.array(e))}}r.NumberUnitsSpec=H,H.__name__=\"NumberUnitsSpec\";class K extends R{}r.BaseCoordinateSpec=K,K.__name__=\"BaseCoordinateSpec\";class Q extends K{}r.CoordinateSpec=Q,Q.__name__=\"CoordinateSpec\";class W extends K{}r.CoordinateSeqSpec=W,W.__name__=\"CoordinateSeqSpec\";class Z extends K{}r.CoordinateSeqSeqSeqSpec=Z,Z.__name__=\"CoordinateSeqSeqSeqSpec\";class ee extends Q{constructor(){super(...arguments),this.dimension=\"x\"}}r.XCoordinateSpec=ee,ee.__name__=\"XCoordinateSpec\";class te extends Q{constructor(){super(...arguments),this.dimension=\"y\"}}r.YCoordinateSpec=te,te.__name__=\"YCoordinateSpec\";class re extends W{constructor(){super(...arguments),this.dimension=\"x\"}}r.XCoordinateSeqSpec=re,re.__name__=\"XCoordinateSeqSpec\";class ne extends W{constructor(){super(...arguments),this.dimension=\"y\"}}r.YCoordinateSeqSpec=ne,ne.__name__=\"YCoordinateSeqSpec\";class ae extends Z{constructor(){super(...arguments),this.dimension=\"x\"}}r.XCoordinateSeqSeqSeqSpec=ae,ae.__name__=\"XCoordinateSeqSeqSeqSpec\";class se extends Z{constructor(){super(...arguments),this.dimension=\"y\"}}r.YCoordinateSeqSeqSeqSpec=se,se.__name__=\"YCoordinateSeqSeqSeqSpec\";class ie extends H{get default_units(){return\"rad\"}get valid_units(){return[..._.AngleUnits]}materialize(e){return e*-(0,d.to_radians_coeff)(this.units)}v_materialize(e){const t=-(0,d.to_radians_coeff)(this.units),r=new Float32Array(e.length);return(0,u.mul)(e,t,r),r}array(e){throw new Error(\"not supported\")}}r.AngleSpec=ie,ie.__name__=\"AngleSpec\";class le extends H{get default_units(){return\"data\"}get valid_units(){return[..._.SpatialUnits]}}r.DistanceSpec=le,le.__name__=\"DistanceSpec\";class _e extends le{materialize(e){return null!=e?e:NaN}}r.NullDistanceSpec=_e,_e.__name__=\"NullDistanceSpec\";class oe extends R{v_materialize(e){return new Uint8Array(e)}array(e){return new Uint8Array(super.array(e))}}r.BooleanSpec=oe,oe.__name__=\"BooleanSpec\";class ce extends R{v_materialize(e){return(0,h.isTypedArray)(e)?e:new Int32Array(e)}array(e){return new Int32Array(super.array(e))}}r.IntSpec=ce,ce.__name__=\"IntSpec\";class ue extends R{v_materialize(e){return(0,h.isTypedArray)(e)?e:new Float64Array(e)}array(e){return new Float64Array(super.array(e))}}r.NumberSpec=ue,ue.__name__=\"NumberSpec\";class de extends ue{valid(e){return(0,h.isNumber)(e)&&e>=0}}r.ScreenSizeSpec=de,de.__name__=\"ScreenSizeSpec\";class Se extends R{materialize(e){return(0,S.encode_rgba)((0,S.color2rgba)(e))}v_materialize(e){if(!(0,f.is_NDArray)(e))return this._from_css_array(e);if(\"uint32\"==e.dtype&&1==e.dimension)return(0,p.to_big_endian)(e);if(\"uint8\"==e.dtype&&1==e.dimension){const[t]=e.shape,r=new o.RGBAArray(4*t);let n=0;for(const t of e)r[n++]=t,r[n++]=t,r[n++]=t,r[n++]=255;return new o.ColorArray(r.buffer)}if(\"uint8\"==e.dtype&&2==e.dimension){const[t,r]=e.shape;if(4==r)return new o.ColorArray(e.buffer);if(3==r){const n=new o.RGBAArray(4*t);for(let a=0,s=0;a0)return e in r?r[e]:r[e]=new v(e,l);throw new TypeError(\"Logger.get() expects a non-empty string name and an optional log-level\")}constructor(e,l=v.INFO){this._name=e,this.set_level(l)}get level(){return this.get_level()}get_level(){return this._log_level}set_level(e){if(e instanceof i)this._log_level=e;else{if(!(0,s.isString)(e)||!(e in v.log_levels))throw new Error(\"Logger.set_level() expects a log-level object or a string name of a log-level\");this._log_level=v.log_levels[e]}const l=`[${this._name}]`;for(const[e,o]of(0,g.entries)(v.log_levels))o.level\",\"*\"),n.HTTPMethod=(0,a.Enum)(\"POST\",\"GET\"),n.HexTileOrientation=(0,a.Enum)(\"pointytop\",\"flattop\"),n.HoverMode=(0,a.Enum)(\"mouse\",\"hline\",\"vline\"),n.ImageOrigin=(0,a.Enum)(\"bottom_left\",\"top_left\",\"bottom_right\",\"top_right\"),n.LatLon=(0,a.Enum)(\"lat\",\"lon\"),n.LegendClickPolicy=(0,a.Enum)(\"none\",\"hide\",\"mute\"),n.LegendLocation=n.Anchor,n.LineCap=(0,a.Enum)(\"butt\",\"round\",\"square\"),n.LineDash=(0,a.Enum)(\"solid\",\"dashed\",\"dotted\",\"dotdash\",\"dashdot\"),n.LineJoin=(0,a.Enum)(\"miter\",\"round\",\"bevel\"),n.LinePolicy=(0,a.Enum)(\"prev\",\"next\",\"nearest\",\"interp\",\"none\"),n.Location=(0,a.Enum)(\"above\",\"below\",\"left\",\"right\"),n.Logo=(0,a.Enum)(\"normal\",\"grey\"),n.MapType=(0,a.Enum)(\"satellite\",\"roadmap\",\"terrain\",\"hybrid\"),n.MarkerType=(0,a.Enum)(\"asterisk\",\"circle\",\"circle_cross\",\"circle_dot\",\"circle_x\",\"circle_y\",\"cross\",\"dash\",\"diamond\",\"diamond_cross\",\"diamond_dot\",\"dot\",\"hex\",\"hex_dot\",\"inverted_triangle\",\"plus\",\"square\",\"square_cross\",\"square_dot\",\"square_pin\",\"square_x\",\"star\",\"star_dot\",\"triangle\",\"triangle_dot\",\"triangle_pin\",\"x\",\"y\"),n.MutedPolicy=(0,a.Enum)(\"show\",\"ignore\"),n.Orientation=(0,a.Enum)(\"vertical\",\"horizontal\"),n.OutputBackend=(0,a.Enum)(\"canvas\",\"svg\",\"webgl\"),n.PaddingUnits=(0,a.Enum)(\"percent\",\"absolute\"),n.Place=(0,a.Enum)(\"above\",\"below\",\"left\",\"right\",\"center\"),n.PointPolicy=(0,a.Enum)(\"snap_to_data\",\"follow_mouse\",\"none\"),n.RadiusDimension=(0,a.Enum)(\"x\",\"y\",\"max\",\"min\"),n.RenderLevel=(0,a.Enum)(\"image\",\"underlay\",\"glyph\",\"guide\",\"annotation\",\"overlay\"),n.ResetPolicy=(0,a.Enum)(\"standard\",\"event_only\"),n.RoundingFunction=(0,a.Enum)(\"round\",\"nearest\",\"floor\",\"rounddown\",\"ceil\",\"roundup\"),n.ScrollbarPolicy=(0,a.Enum)(\"auto\",\"visible\",\"hidden\"),n.SelectionMode=(0,a.Enum)(\"replace\",\"append\",\"intersect\",\"subtract\"),n.Side=(0,a.Enum)(\"above\",\"below\",\"left\",\"right\"),n.SizingMode=(0,a.Enum)(\"stretch_width\",\"stretch_height\",\"stretch_both\",\"scale_width\",\"scale_height\",\"scale_both\",\"fixed\",\"inherit\"),n.Sort=(0,a.Enum)(\"ascending\",\"descending\"),n.SpatialUnits=(0,a.Enum)(\"screen\",\"data\"),n.StartEnd=(0,a.Enum)(\"start\",\"end\"),n.StepMode=(0,a.Enum)(\"after\",\"before\",\"center\"),n.TapBehavior=(0,a.Enum)(\"select\",\"inspect\"),n.TapGesture=(0,a.Enum)(\"tap\",\"doubletap\"),n.TextAlign=(0,a.Enum)(\"left\",\"right\",\"center\"),n.TextBaseline=(0,a.Enum)(\"top\",\"middle\",\"bottom\",\"alphabetic\",\"hanging\",\"ideographic\"),n.TextureRepetition=(0,a.Enum)(\"repeat\",\"repeat_x\",\"repeat_y\",\"no_repeat\"),n.TickLabelOrientation=(0,a.Enum)(\"vertical\",\"horizontal\",\"parallel\",\"normal\"),n.TooltipAttachment=(0,a.Enum)(\"horizontal\",\"vertical\",\"left\",\"right\",\"above\",\"below\"),n.UpdateMode=(0,a.Enum)(\"replace\",\"append\"),n.VerticalAlign=(0,a.Enum)(\"top\",\"middle\",\"bottom\"),n.ToolIcon=(0,a.Enum)(\"append_mode\",\"box_edit\",\"box_select\",\"box_zoom\",\"clear_selection\",\"copy\",\"crosshair\",\"freehand_draw\",\"help\",\"hover\",\"intersect_mode\",\"lasso_select\",\"line_edit\",\"pan\",\"point_draw\",\"poly_draw\",\"poly_edit\",\"polygon_select\",\"range\",\"redo\",\"replace_mode\",\"reset\",\"save\",\"subtract_mode\",\"tap_select\",\"undo\",\"wheel_pan\",\"wheel_zoom\",\"xpan\",\"ypan\",\"zoom_in\",\"zoom_out\")},\n", - " function _(t,e,n,r,s){r();const i=t(1).__importStar(t(8)),a=t(21),o=t(9),u=globalThis.Map,_=globalThis.Set,{hasOwnProperty:l}=Object.prototype;class c{}n.Kind=c,c.__name__=\"Kind\",function(t){class e extends c{valid(t){return void 0!==t}toString(){return\"Any\"}}e.__name__=\"Any\",t.Any=e;class n extends c{valid(t){return void 0!==t}toString(){return\"Unknown\"}}n.__name__=\"Unknown\",t.Unknown=n;class r extends c{valid(t){return i.isBoolean(t)}toString(){return\"Boolean\"}}r.__name__=\"Boolean\",t.Boolean=r;class s extends c{constructor(t){super(),this.obj_type=t}valid(t){return t instanceof this.obj_type}toString(){var t;const e=this.obj_type;return`Ref(${null!==(t=e.__name__)&&void 0!==t?t:e.toString()})`}}s.__name__=\"Ref\",t.Ref=s;class d extends c{valid(t){return i.isObject(t)}toString(){return\"AnyRef\"}}d.__name__=\"AnyRef\",t.AnyRef=d;class p extends c{valid(t){return i.isNumber(t)}toString(){return\"Number\"}}p.__name__=\"Number\",t.Number=p;class y extends p{valid(t){return super.valid(t)&&i.isInteger(t)}toString(){return\"Int\"}}y.__name__=\"Int\",t.Int=y;class S extends p{valid(t){return super.valid(t)&&0<=t&&t<=1}toString(){return\"Percent\"}}S.__name__=\"Percent\",t.Percent=S;class g extends c{constructor(t){super(),this.types=t,this.types=t}valid(t){return this.types.some((e=>e.valid(t)))}toString(){return`Or(${this.types.map((t=>t.toString())).join(\", \")})`}}g.__name__=\"Or\",t.Or=g;class m extends c{constructor(t){super(),this.types=t,this.types=t}valid(t){if(!i.isArray(t))return!1;for(let e=0;et.toString())).join(\", \")})`}}m.__name__=\"Tuple\",t.Tuple=m;class h extends c{constructor(t){super(),this.struct_type=t}valid(t){if(!i.isPlainObject(t))return!1;const{struct_type:e}=this;for(const n of(0,o.keys)(t))if(!l.call(e,n))return!1;for(const n in e)if(l.call(e,n)){const r=e[n],s=t[n];if(!r.valid(s))return!1}return!0}toString(){return`Struct({${(0,o.entries)(this.struct_type).map((([t,e])=>`${t}: ${e}`)).join(\", \")}})`}}h.__name__=\"Struct\",t.Struct=h;class v extends c{constructor(t){super(),this.struct_type=t}valid(t){if(!i.isPlainObject(t))return!1;const{struct_type:e}=this;for(const n of(0,o.keys)(t))if(!l.call(e,n))return!1;for(const n in e)if(l.call(t,n)&&l.call(e,n)){const r=e[n],s=t[n];if(!r.valid(s))return!1}return!0}toString(){return`Struct({${(0,o.entries)(this.struct_type).map((([t,e])=>`${t}?: ${e}`)).join(\", \")}})`}}v.__name__=\"PartialStruct\",t.PartialStruct=v;class f extends c{constructor(t){super(),this.item_type=t}valid(t){return i.isArray(t)||i.isTypedArray(t)}toString(){return`Arrayable(${this.item_type.toString()})`}}f.__name__=\"Arrayable\",t.Arrayable=f;class b extends c{constructor(t){super(),this.item_type=t}valid(t){return i.isArray(t)&&t.every((t=>this.item_type.valid(t)))}toString(){return`Array(${this.item_type.toString()})`}}b.__name__=\"Array\",t.Array=b;class x extends c{valid(t){return null===t}toString(){return\"Null\"}}x.__name__=\"Null\",t.Null=x;class w extends c{constructor(t){super(),this.base_type=t}valid(t){return null===t||this.base_type.valid(t)}toString(){return`Nullable(${this.base_type.toString()})`}}w.__name__=\"Nullable\",t.Nullable=w;class K extends c{constructor(t){super(),this.base_type=t}valid(t){return void 0===t||this.base_type.valid(t)}toString(){return`Opt(${this.base_type.toString()})`}}K.__name__=\"Opt\",t.Opt=K;class N extends c{valid(t){return t instanceof ArrayBuffer}toString(){return\"Bytes\"}}N.__name__=\"Bytes\",t.Bytes=N;class A extends c{valid(t){return i.isString(t)}toString(){return\"String\"}}A.__name__=\"String\",t.String=A;class O extends A{constructor(t){super(),this.regex=t}valid(t){return super.valid(t)&&this.regex.test(t)}toString(){return`Regex(${this.regex.toString()})`}}O.__name__=\"Regex\",t.Regex=O;class $ extends c{constructor(t){super(),this.values=new _(t)}valid(t){return this.values.has(t)}*[Symbol.iterator](){yield*this.values}toString(){return`Enum(${[...this.values].map((t=>t.toString())).join(\", \")})`}}$.__name__=\"Enum\",t.Enum=$;class P extends c{constructor(t){super(),this.item_type=t}valid(t){if(!i.isPlainObject(t))return!1;for(const e in t)if(l.call(t,e)){const n=t[e];if(!this.item_type.valid(n))return!1}return!0}toString(){return`Dict(${this.item_type.toString()})`}}P.__name__=\"Dict\",t.Dict=P;class R extends c{constructor(t,e){super(),this.key_type=t,this.item_type=e}valid(t){if(!(t instanceof u))return!1;for(const[e,n]of t.entries())if(!this.key_type.valid(e)||!this.item_type.valid(n))return!1;return!0}toString(){return`Map(${this.key_type.toString()}, ${this.item_type.toString()})`}}R.__name__=\"Map\",t.Map=R;class j extends c{constructor(t){super(),this.item_type=t}valid(t){if(!(t instanceof _))return!1;for(const e of t)if(!this.item_type.valid(e))return!1;return!0}toString(){return`Set(${this.item_type.toString()})`}}j.__name__=\"Set\",t.Set=j;class B extends c{valid(t){return(0,a.is_Color)(t)}toString(){return\"Color\"}}B.__name__=\"Color\",t.Color=B;class C extends A{toString(){return\"CSSLength\"}}C.__name__=\"CSSLength\",t.CSSLength=C;class M extends c{valid(t){return i.isFunction(t)}toString(){return\"Function(...)\"}}M.__name__=\"Function\",t.Function=M;class k extends c{constructor(t){super(),this.base_type=t}valid(t){return this.base_type.valid(t)&&t>=0}toString(){return`NonNegative(${this.base_type.toString()})`}}k.__name__=\"NonNegative\",t.NonNegative=k;class D extends c{constructor(t){super(),this.base_type=t}valid(t){return this.base_type.valid(t)&&t>0}toString(){return`Positive(${this.base_type.toString()})`}}D.__name__=\"Positive\",t.Positive=D;class F extends c{valid(t){return t instanceof Node}toString(){return\"DOMNode\"}}F.__name__=\"DOMNode\",t.DOMNode=F}(n.Kinds||(n.Kinds={})),n.Any=new n.Kinds.Any,n.Unknown=new n.Kinds.Unknown,n.Boolean=new n.Kinds.Boolean,n.Number=new n.Kinds.Number,n.Int=new n.Kinds.Int,n.Bytes=new n.Kinds.Bytes,n.String=new n.Kinds.String;n.Regex=t=>new n.Kinds.Regex(t),n.Null=new n.Kinds.Null;n.Nullable=t=>new n.Kinds.Nullable(t);n.Opt=t=>new n.Kinds.Opt(t);n.Or=(...t)=>new n.Kinds.Or(t);n.Tuple=(...t)=>new n.Kinds.Tuple(t);n.Struct=t=>new n.Kinds.Struct(t);n.PartialStruct=t=>new n.Kinds.PartialStruct(t);n.Arrayable=t=>new n.Kinds.Arrayable(t);n.Array=t=>new n.Kinds.Array(t);n.Dict=t=>new n.Kinds.Dict(t);n.Map=(t,e)=>new n.Kinds.Map(t,e);n.Set=t=>new n.Kinds.Set(t);n.Enum=(...t)=>new n.Kinds.Enum(t);n.Ref=t=>new n.Kinds.Ref(t);n.AnyRef=()=>new n.Kinds.AnyRef;n.Function=()=>new n.Kinds.Function,n.DOMNode=new n.Kinds.DOMNode;n.NonNegative=t=>new n.Kinds.NonNegative(t);n.Positive=t=>new n.Kinds.Positive(t),n.Percent=new n.Kinds.Percent,n.Alpha=n.Percent,n.Color=new n.Kinds.Color,n.Auto=(0,n.Enum)(\"auto\"),n.CSSLength=new n.Kinds.CSSLength,n.FontSize=n.String,n.Font=n.String,n.Angle=n.Number},\n", - " function _(n,r,t,e,s){e();const u=n(22),i=n(11),c=n(8),{round:o,sqrt:l}=Math;function a(n){return(0,i.clamp)(o(n),0,255)}function f(){return[0,0,0,0]}function g(n){return[n>>24&255,n>>16&255,n>>8&255,255&n]}function b(n,r=1){const[t,e,s,u]=(()=>{var r;if(null==n)return[0,0,0,0];if((0,c.isInteger)(n))return g(n);if((0,c.isString)(n))return null!==(r=_(n))&&void 0!==r?r:[0,0,0,0];if(2==n.length){const[r,t]=n;return b(r,t)}{const[r,t,e,s=1]=n;return[r,t,e,a(255*s)]}})();return[t,e,s,a(r*u)]}t.byte=a,t.transparent=f,t.encode_rgba=function([n,r,t,e]){return n<<24|r<<16|t<<8|e},t.decode_rgba=g,t.color2rgba=b;const d={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 h(n){return d[n>>4]+d[15&n]}t.color2css=function(n,r){const[t,e,s,u]=b(n,r);return`rgba(${t}, ${e}, ${s}, ${u/255})`},t.color2hex=function(n,r){const[t,e,s,u]=b(n,r),i=`#${h(t)}${h(e)}${h(s)}`;return 255==u?i:`${i}${h(u)}`},t.color2hexrgb=function(n){const[r,t,e]=b(n);return`#${h(r)}${h(t)}${h(e)}`};const $=/^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*\\)$/,N=(()=>{const n=document.createElement(\"canvas\");n.width=1,n.height=1;const r=n.getContext(\"2d\"),t=r.createLinearGradient(0,0,1,1);return n=>{r.fillStyle=t,r.fillStyle=n;const e=r.fillStyle;return e!=t?e:null}})();function _(n){var r;if(\"\"==(n=n.trim().toLowerCase()))return null;if(\"transparent\"==n)return[0,0,0,0];if((0,u.is_named_color)(n))return g(u.named_colors[n]);if(\"#\"==n[0]){const r=Number(`0x${n.substring(1)}`);if(isNaN(r))return null;switch(n.length-1){case 3:{const n=r>>8&15,t=r>>4&15,e=r>>0&15;return[n<<4|n,t<<4|t,e<<4|e,255]}case 4:{const n=r>>12&15,t=r>>8&15,e=r>>4&15,s=r>>0&15;return[n<<4|n,t<<4|t,e<<4|e,s<<4|s]}case 6:return[r>>16&255,r>>8&255,r>>0&255,255];case 8:return[r>>24&255,r>>16&255,r>>8&255,r>>0&255]}}else if(n.startsWith(\"rgb\")){const t=null!==(r=n.match($))&&void 0!==r?r:n.match(m);if(null!=(null==t?void 0:t.groups)){let{r:n,g:r,b:e,a:s=\"1\"}=t.groups;const u=n.endsWith(\"%\"),i=r.endsWith(\"%\"),c=e.endsWith(\"%\"),o=s.endsWith(\"%\");if(!(u&&i&&c)&&(u||i||c))return null;u&&(n=n.slice(0,-1)),i&&(r=r.slice(0,-1)),c&&(e=e.slice(0,-1)),o&&(s=s.slice(0,-1));let l=Number(n),f=Number(r),g=Number(e),b=Number(s);return isNaN(l+f+g+b)?null:(u&&(l=l/100*255),i&&(f=f/100*255),c&&(g=g/100*255),b=255*(o?b/100:b),l=a(l),f=a(f),g=a(g),b=a(b),[l,f,g,b])}}else{const r=N(n);if(null!=r)return _(r)}return null}t.css4_parse=_,t.is_Color=function(n){return!!(0,c.isInteger)(n)||(!(!(0,c.isString)(n)||null==_(n))||!(!(0,c.isArray)(n)||3!=n.length&&4!=n.length))},t.is_dark=function([n,r,t]){return 1-(.299*n+.587*r+.114*t)/255>=.6},t.brightness=function(n){const[r,t,e]=b(n);return l(.299*r**2+.587*t**2+.114*e**2)/255}},\n", - " function _(e,r,l,a,i){a();l.named_colors={aliceblue:4042850303,antiquewhite:4209760255,aqua:16777215,aquamarine:2147472639,azure:4043309055,beige:4126530815,bisque:4293182719,black:255,blanchedalmond:4293643775,blue:65535,blueviolet:2318131967,brown:2771004159,burlywood:3736635391,cadetblue:1604231423,chartreuse:2147418367,chocolate:3530104575,coral:4286533887,cornflowerblue:1687547391,cornsilk:4294499583,crimson:3692313855,cyan:16777215,darkblue:35839,darkcyan:9145343,darkgoldenrod:3095792639,darkgray:2846468607,darkgreen:6553855,darkgrey:2846468607,darkkhaki:3182914559,darkmagenta:2332068863,darkolivegreen:1433087999,darkorange:4287365375,darkorchid:2570243327,darkred:2332033279,darksalmon:3918953215,darkseagreen:2411499519,darkslateblue:1211993087,darkslategray:793726975,darkslategrey:793726975,darkturquoise:13554175,darkviolet:2483082239,deeppink:4279538687,deepskyblue:12582911,dimgray:1768516095,dimgrey:1768516095,dodgerblue:512819199,firebrick:2988581631,floralwhite:4294635775,forestgreen:579543807,fuchsia:4278255615,gainsboro:3705462015,ghostwhite:4177068031,gold:4292280575,goldenrod:3668254975,gray:2155905279,green:8388863,greenyellow:2919182335,grey:2155905279,honeydew:4043305215,hotpink:4285117695,indianred:3445382399,indigo:1258324735,ivory:4294963455,khaki:4041641215,lavender:3873897215,lavenderblush:4293981695,lawngreen:2096890111,lemonchiffon:4294626815,lightblue:2916673279,lightcoral:4034953471,lightcyan:3774873599,lightgoldenrodyellow:4210742015,lightgray:3553874943,lightgreen:2431553791,lightgrey:3553874943,lightpink:4290167295,lightsalmon:4288707327,lightseagreen:548580095,lightskyblue:2278488831,lightslategray:2005441023,lightslategrey:2005441023,lightsteelblue:2965692159,lightyellow:4294959359,lime:16711935,limegreen:852308735,linen:4210091775,magenta:4278255615,maroon:2147483903,mediumaquamarine:1724754687,mediumblue:52735,mediumorchid:3126187007,mediumpurple:2473647103,mediumseagreen:1018393087,mediumslateblue:2070474495,mediumspringgreen:16423679,mediumturquoise:1221709055,mediumvioletred:3340076543,midnightblue:421097727,mintcream:4127193855,mistyrose:4293190143,moccasin:4293178879,navajowhite:4292783615,navy:33023,oldlace:4260751103,olive:2155872511,olivedrab:1804477439,orange:4289003775,orangered:4282712319,orchid:3664828159,palegoldenrod:4008225535,palegreen:2566625535,paleturquoise:2951671551,palevioletred:3681588223,papayawhip:4293907967,peachpuff:4292524543,peru:3448061951,pink:4290825215,plum:3718307327,powderblue:2967529215,purple:2147516671,rebeccapurple:1714657791,red:4278190335,rosybrown:3163525119,royalblue:1097458175,saddlebrown:2336560127,salmon:4202722047,sandybrown:4104413439,seagreen:780883967,seashell:4294307583,sienna:2689740287,silver:3233857791,skyblue:2278484991,slateblue:1784335871,slategray:1887473919,slategrey:1887473919,snow:4294638335,springgreen:16744447,steelblue:1182971135,tan:3535047935,teal:8421631,thistle:3636451583,tomato:4284696575,turquoise:1088475391,violet:4001558271,wheat:4125012991,white:4294967295,whitesmoke:4126537215,yellow:4294902015,yellowgreen:2597139199},l.is_named_color=function(e){return e in l.named_colors}},\n", - " function _(r,t,n,a,o){a(),n.GeneratorFunction=Object.getPrototypeOf((function*(){})).constructor,n.ColorArray=Uint32Array,n.RGBAArray=Uint8ClampedArray,n.infer_type=function(r,t){return r instanceof Float64Array||r instanceof Array||t instanceof Float64Array||t instanceof Array?Float64Array:Float32Array},n.ScreenArray=Float32Array,n.to_screen=function(r){return r instanceof Float32Array?r:Float32Array.from(r)},o(\"Indices\",r(24).BitSet)},\n", - " function _(t,s,r,e,i){var n;e();const o=t(25),_=t(12);class h{constructor(t,s=0){this[n]=\"BitSet\",this._count=null,this.size=t,this._nwords=Math.ceil(t/h._word_length),0==s||1==s?(this._array=new Uint32Array(this._nwords),1==s&&this._array.fill(4294967295)):((0,_.assert)(s.length==this._nwords,\"Initializer size mismatch\"),this._array=s)}clone(){return new h(this.size,new Uint32Array(this._array))}[(n=Symbol.toStringTag,o.equals)](t,s){if(!s.eq(this.size,t.size))return!1;const{_nwords:r}=this,e=this.size%h._word_length,i=0==e?r:r-1;for(let s=0;s>>5,r=31&t;return 1==(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+=h._word_length}}*zeros(){const{_array:t,_nwords:s,size:r}=this;for(let e=0,i=0;i>>t&1)&&(yield e);else e+=h._word_length}}_check_size(t){(0,_.assert)(this.size==t.size,`Size mismatch (${this.size} != ${t.size})`)}invert(){for(let t=0;t>>0}add(t){this._check_size(t);for(let s=0;s0;)if(n[c]===t)return o[c]===e;n.push(t),o.push(e);const u=(()=>{if(a(t)&&a(e))return t[r.equals](e,this);switch(s){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(\"undefined\"!=typeof Node&&t instanceof Node)return this.nodes(t,e);throw Error(`can't compare objects of type ${s}`)})();return n.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 s=0;s0,i.is_little_endian=(()=>{const n=new ArrayBuffer(4),t=new Uint8Array(n);new Uint32Array(n)[1]=168496141;let i=!0;return 10==t[4]&&11==t[5]&&12==t[6]&&13==t[7]&&(i=!1),i})(),i.BYTE_ORDER=i.is_little_endian?\"little\":\"big\",i.to_big_endian=function(n){if(i.is_little_endian){const t=new Uint32Array(n.length),i=new DataView(t.buffer);let e=0;for(const t of n)i.setUint32(e,t),e+=4;return t}return n}},\n", - " function _(i,n,e,t,u){t();const c=i(8);e.isValue=function(i){return(0,c.isPlainObject)(i)&&\"value\"in i},e.isField=function(i){return(0,c.isPlainObject)(i)&&\"field\"in i},e.isExpr=function(i){return(0,c.isPlainObject)(i)&&\"expr\"in i}},\n", - " function _(e,t,r,s,_){s();class i{constructor(){this._dev=!1,this._wireframe=!1,this._force_webgl=!1}set dev(e){this._dev=e}get dev(){return this._dev}set wireframe(e){this._wireframe=e}get wireframe(){return this._wireframe}set force_webgl(e){this._force_webgl=e}get force_webgl(){return this._force_webgl}}r.Settings=i,i.__name__=\"Settings\",r.settings=new i},\n", - " function _(t,e,s,r,n){var a,i,h,u,l,o,p,c,y,_;r();const A=t(8),d=t(26),g=t(25),f=t(30),m=Symbol(\"__ndarray__\");function N(t,e){return{type:\"ndarray\",array:e.encode(\"object\"==t.dtype?Array.from(t):t.buffer),order:d.BYTE_ORDER,dtype:t.dtype,shape:t.shape}}class D extends Uint8Array{constructor(t,e){super(t),this[a]=!0,this.dtype=\"bool\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(a=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return 1==this[t]}}s.BoolNDArray=D,D.__name__=\"BoolNDArray\";class q extends Uint8Array{constructor(t,e){super(t),this[i]=!0,this.dtype=\"uint8\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(i=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Uint8NDArray=q,q.__name__=\"Uint8NDArray\";class b extends Int8Array{constructor(t,e){super(t),this[h]=!0,this.dtype=\"int8\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(h=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Int8NDArray=b,b.__name__=\"Int8NDArray\";class w extends Uint16Array{constructor(t,e){super(t),this[u]=!0,this.dtype=\"uint16\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(u=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Uint16NDArray=w,w.__name__=\"Uint16NDArray\";class U extends Int16Array{constructor(t,e){super(t),this[l]=!0,this.dtype=\"int16\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(l=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Int16NDArray=U,U.__name__=\"Int16NDArray\";class I extends Uint32Array{constructor(t,e){super(t),this[o]=!0,this.dtype=\"uint32\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(o=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Uint32NDArray=I,I.__name__=\"Uint32NDArray\";class x extends Int32Array{constructor(t,e){super(t),this[p]=!0,this.dtype=\"int32\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(p=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Int32NDArray=x,x.__name__=\"Int32NDArray\";class z extends Float32Array{constructor(t,e){super(t),this[c]=!0,this.dtype=\"float32\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(c=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Float32NDArray=z,z.__name__=\"Float32NDArray\";class F extends Float64Array{constructor(t,e){super(t),this[y]=!0,this.dtype=\"float64\",this.shape=null!=e?e:B(t)?t.shape:[this.length],this.dimension=this.shape.length}[(y=m,g.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[f.serialize](t){return N(this,t)}get(t){return this[t]}}s.Float64NDArray=F,F.__name__=\"Float64NDArray\";class j extends Array{get shape(){var t;return null!==(t=this._shape)&&void 0!==t?t:[this.length]}get dimension(){return this.shape.length}constructor(t,e){const s=t instanceof ArrayBuffer?new Float64Array(t):t;if(super((0,A.isNumber)(s)?s:s.length),this[_]=!0,this.dtype=\"object\",!(0,A.isNumber)(s))for(let t=0;t{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 ArrayBuffer:case t instanceof Float64Array:return\"float64\";default:return\"object\"}})()),e){case\"bool\":return new D(t,s);case\"uint8\":return new q(t,s);case\"int8\":return new b(t,s);case\"uint16\":return new w(t,s);case\"int16\":return new U(t,s);case\"uint32\":return new I(t,s);case\"int32\":return new x(t,s);case\"float32\":return new z(t,s);case\"float64\":return new F(t,s);case\"object\":return new j(t,s)}}},\n", - " function _(r,e,i,a,f){a();const o=r(1);var l=r(31);f(\"Serializer\",l.Serializer),f(\"SerializationError\",l.SerializationError),f(\"serialize\",l.serialize);var t=r(33);f(\"Buffer\",t.Buffer),f(\"Base64Buffer\",t.Base64Buffer),o.__exportStar(r(35),i)},\n", - " function _(e,r,t,n,i){n();const s=e(12),a=e(9),o=e(8),c=e(32),l=e(26),u=e(33);t.serialize=Symbol(\"serialize\");class f extends Error{}t.SerializationError=f,f.__name__=\"SerializationError\";class y{constructor(e){this.value=e}to_json(){return JSON.stringify(this.value)}}y.__name__=\"Serialized\";class d{constructor(e){var r,t;this._circular=new WeakSet,this.binary=null!==(r=null==e?void 0:e.binary)&&void 0!==r&&r,this.include_defaults=null!==(t=null==e?void 0:e.include_defaults)&&void 0!==t&&t;const n=null==e?void 0:e.references;this._references=null!=n?new Map(n):new Map}get_ref(e){return this._references.get(e)}add_ref(e,r){(0,s.assert)(!this._references.has(e)),this._references.set(e,r)}to_serializable(e){return new y(this.encode(e))}encode(e){const r=this.get_ref(e);if(null!=r)return r;if(!(0,o.isObject)(e))return this._encode(e);this._circular.has(e)&&this.error(\"circular reference\"),this._circular.add(e);try{return this._encode(e)}finally{this._circular.delete(e)}}_encode(e){if(function(e){return(0,o.isObject)(e)&&t.serialize in e}(e))return e[t.serialize](this);if((0,o.isArray)(e)){const r=e.length,t=new Array(r);for(let n=0;n[this.encode(e),this.encode(r)]))]}}if(null===e||(0,o.isBoolean)(e)||(0,o.isString)(e))return e;if((0,o.isNumber)(e))return isNaN(e)?{type:\"number\",value:\"nan\"}:isFinite(e)?e:{type:\"number\",value:(e<0?\"-\":\"+\")+\"inf\"};if(e instanceof Date){return{type:\"date\",iso:e.toISOString()}}if(e instanceof Set)return 0==e.size?{type:\"set\"}:{type:\"set\",entries:[...(0,c.map)(e.values(),(e=>this.encode(e)))]};if(e instanceof Map)return 0==e.size?{type:\"map\"}:{type:\"map\",entries:[...(0,c.map)(e.entries(),(([e,r])=>[this.encode(e),this.encode(r)]))]};if((0,o.isSymbol)(e)&&null!=e.description)return{type:\"symbol\",name:e.description};throw new f(`${Object.prototype.toString.call(e)} is not serializable`)}encode_struct(e){const r={};for(const[t,n]of(0,a.entries)(e))void 0!==n&&(r[t]=this.encode(n));return r}error(e){throw new f(e)}_encode_typed_array(e){const r=this.encode(e.buffer),t=(()=>{switch(e.constructor){case Uint8Array:return\"uint8\";case Int8Array:return\"int8\";case Uint16Array:return\"uint16\";case Int16Array:return\"int16\";case Uint32Array:return\"uint32\";case Int32Array:return\"int32\";case Float32Array:return\"float32\";case Float64Array:return\"float64\";default:this.error(`can't serialize typed array of type '${e[Symbol.toStringTag]}'`)}})();return{type:\"typed_array\",array:r,order:l.BYTE_ORDER,dtype:t}}}t.Serializer=d,d.__name__=\"Serializer\"},\n", - " function _(n,o,t,e,f){e();const i=n(10),r=n(12),{abs:l,ceil:c,max:s}=Math;function*u(n){const o=n.length;for(let t=0;t=0);for(const t of n)0==o?yield t:o-=1}function*y(n,o){const t=n.length;if(o>t)return;const e=(0,i.range)(o);for(yield e.map((o=>n[o]));;){let f;for(const n of u((0,i.range)(o)))if(e[n]!=n+t-o){f=n;break}if(null==f)return;e[f]+=1;for(const n of(0,i.range)(f+1,o))e[n]=e[n-1]+1;yield e.map((o=>n[o]))}}t.range=function*(n,o,t=1){(0,r.assert)(t>0),null==o&&(o=n,n=0);const e=n<=o?t:-t,f=s(c(l(o-n)/t),0);for(let o=0;o=0);let t=0;for(const e of n){if(!(t++String.fromCharCode(t)));return btoa(e.join(\"\"))},e.base64_to_buffer=function(t){const n=atob(t),e=n.length,r=new Uint8Array(e);for(let t=0,o=e;t\"'`])/g,(e=>{switch(e){case\"&\":return\"&\";case\"<\":return\"<\";case\">\":return\">\";case'\"':return\""\";case\"'\":return\"'\";case\"`\":return\"`\";default:return e}}))},r.unescape=function(e){return e.replace(/&(amp|lt|gt|quot|#x27|#x60);/g,((e,t)=>{switch(t){case\"amp\":return\"&\";case\"lt\":return\"<\";case\"gt\":return\">\";case\"quot\":return'\"';case\"#x27\":return\"'\";case\"#x60\":return\"`\";default:return t}}))},r.use_strict=function(e){return`'use strict';\\n${e}`},r.to_fixed=function(e,t){return e.toFixed(t).replace(/(\\.[0-9]*?)0+$/,\"$1\").replace(/\\.$/,\"\")},r.insert_text_on_position=function(e,t,r){const n=[];return n.push(e.slice(0,t)),n.push(r),n.push(e.slice(t)),n.join(\"\")}},\n", - " function _(e,t,s,n,a){n();const i=e(25),r=e(30);class d{constructor(e){this.document=e}get[Symbol.toStringTag](){return this.constructor.__name__}[i.equals](e,t){return t.eq(this.document,e.document)}}s.DocumentEvent=d,d.__name__=\"DocumentEvent\";class o extends d{constructor(e,t){super(e),this.events=t}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.events,e.events)}}s.DocumentEventBatch=o,o.__name__=\"DocumentEventBatch\";class l extends d{}s.DocumentChangedEvent=l,l.__name__=\"DocumentChangedEvent\";class h extends l{constructor(e,t,s){super(e),this.kind=\"MessageSent\",this.msg_type=t,this.msg_data=s}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.msg_type,e.msg_type)&&t.eq(this.msg_data,e.msg_data)}[r.serialize](e){return{kind:this.kind,msg_type:this.msg_type,msg_data:e.encode(this.msg_data)}}}s.MessageSentEvent=h,h.__name__=\"MessageSentEvent\";class u extends l{constructor(e,t,s,n){super(e),this.kind=\"ModelChanged\",this.model=t,this.attr=s,this.value=n}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.model,e.model)&&t.eq(this.attr,e.attr)&&t.eq(this.value,e.value)}[r.serialize](e){return{kind:this.kind,model:this.model.ref(),attr:this.attr,new:e.encode(this.value)}}}s.ModelChangedEvent=u,u.__name__=\"ModelChangedEvent\";class m extends l{constructor(e,t,s,n,a){super(e),this.kind=\"ColumnDataChanged\",this.model=t,this.attr=s,this.data=n,this.cols=a}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.model,e.model)&&t.eq(this.attr,e.attr)&&t.eq(this.data,e.data)&&t.eq(this.cols,e.cols)}[r.serialize](e){return{kind:this.kind,model:this.model.ref(),attr:this.attr,data:e.encode(this.data),cols:this.cols}}}s.ColumnDataChangedEvent=m,m.__name__=\"ColumnDataChangedEvent\";class c extends l{constructor(e,t,s,n,a){super(e),this.kind=\"ColumnsStreamed\",this.model=t,this.attr=s,this.data=n,this.rollover=a}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.model,e.model)&&t.eq(this.attr,e.attr)&&t.eq(this.data,e.data)&&t.eq(this.rollover,e.rollover)}[r.serialize](e){return{kind:this.kind,model:this.model.ref(),attr:this.attr,data:e.encode(this.data),rollover:this.rollover}}}s.ColumnsStreamedEvent=c,c.__name__=\"ColumnsStreamedEvent\";class _ extends l{constructor(e,t,s,n){super(e),this.kind=\"ColumnsPatched\",this.model=t,this.attr=s,this.patches=n}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.model,e.model)&&t.eq(this.attr,e.attr)&&t.eq(this.patches,e.patches)}[r.serialize](e){return{kind:this.kind,attr:this.attr,model:this.model.ref(),patches:e.encode(this.patches)}}}s.ColumnsPatchedEvent=_,_.__name__=\"ColumnsPatchedEvent\";class q extends l{constructor(e,t){super(e),this.kind=\"TitleChanged\",this.title=t}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.title,e.title)}[r.serialize](e){return{kind:this.kind,title:this.title}}}s.TitleChangedEvent=q,q.__name__=\"TitleChangedEvent\";class v extends l{constructor(e,t){super(e),this.kind=\"RootAdded\",this.model=t}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.model,e.model)}[r.serialize](e){return{kind:this.kind,model:e.encode(this.model)}}}s.RootAddedEvent=v,v.__name__=\"RootAddedEvent\";class p extends l{constructor(e,t){super(e),this.kind=\"RootRemoved\",this.model=t}[i.equals](e,t){return super[i.equals](e,t)&&t.eq(this.model,e.model)}[r.serialize](e){return{kind:this.kind,model:this.model.ref()}}}s.RootRemovedEvent=p,p.__name__=\"RootRemovedEvent\"},\n", - " function _(t,r,i,n,e){n();const s=t(8),o=t(9);i.pretty=Symbol(\"pretty\");class u{constructor(t){this.visited=new Set,this.precision=null==t?void 0:t.precision}to_string(t){if((0,s.isObject)(t)){if(this.visited.has(t))return\"\";this.visited.add(t)}return function(t){return(0,s.isObject)(t)&&i.pretty in t}(t)?t[i.pretty](this):(0,s.isBoolean)(t)?this.boolean(t):(0,s.isNumber)(t)?this.number(t):(0,s.isString)(t)?this.string(t):(0,s.isArray)(t)?this.array(t):(0,s.isIterable)(t)?this.iterable(t):(0,s.isPlainObject)(t)?this.object(t):(0,s.isSymbol)(t)?this.symbol(t):t instanceof ArrayBuffer?this.array_buffer(t):`${t}`}token(t){return t}boolean(t){return`${t}`}number(t){return null!=this.precision?t.toFixed(this.precision):`${t}`}string(t){const r=t.includes(\"'\"),i=t.includes('\"');return r&&i?`\\`${t.replace(/`/g,\"\\\\`\")}\\``:i?`'${t}'`:`\"${t}\"`}symbol(t){return t.toString()}array(t){const r=this.token,i=[];for(const r of t)i.push(this.to_string(r));return`${r(\"[\")}${i.join(`${r(\",\")} `)}${r(\"]\")}`}iterable(t){var r;const i=this.token,n=null!==(r=Object(t)[Symbol.toStringTag])&&void 0!==r?r:\"Object\",e=this.array(t);return`${n}${i(\"(\")}${e}${i(\")\")}`}object(t){const r=this.token,i=[];for(const[n,e]of(0,o.entries)(t))i.push(`${n}${r(\":\")} ${this.to_string(e)}`);return`${r(\"{\")}${i.join(`${r(\",\")} `)}${r(\"}\")}`}array_buffer(t){return`ArrayBuffer(#${t.byteLength})`}}i.Printer=u,u.__name__=\"Printer\",i.to_string=function(t,r){return new u(r).to_string(t)}},\n", - " function _(n,e,t,o,r){o();const i=n(9),c=n(8);function l(n){return(0,c.isObject)(n)&&t.clone in n}t.clone=Symbol(\"clone\"),t.is_Cloneable=l;class s extends Error{}t.CloningError=s,s.__name__=\"CloningError\";class a{constructor(){}clone(n){if(l(n))return n[t.clone](this);if((0,c.isPrimitive)(n))return n;if((0,c.isArray)(n)){const e=n.length,t=new Array(e);for(let o=0;o[this.clone(n),this.clone(e)])));if(n instanceof Set)return new Set([...n].map((n=>this.clone(n))));throw new s(`${Object.prototype.toString.call(n)} is not cloneable`)}}t.Cloner=a,a.__name__=\"Cloner\"},\n", - " function _(t,r,n,e,o){e();const s=t(1),u=t(8),c=t(9),l=t(43),i=s.__importStar(t(44));function a(t,r,n){if((0,u.isArray)(t)&&(0,u.isArray)(r)){const e=t.concat(r);return null!=n&&e.length>n?e.slice(-n):e}const e=t.length+r.length;if(null!=n&&e>n){const o=e-n,s=t.length,c=(()=>{if(t.length{if((0,u.isTypedArray)(t))return t.constructor;if((0,u.isTypedArray)(r))return r.constructor;throw new Error(\"unsupported array types\")})())(n);return e.set(t,0),e}return t})();for(let t=o,r=s;t{if((0,u.isTypedArray)(t))return t;if((0,u.isTypedArray)(r))return new r.constructor(t);throw new Error(\"unsupported array types\")})();return i.concat(n,r)}}function f(t,r){let n,e,o;return(0,u.isNumber)(t)?(n=t,o=t+1,e=1):(n=null!=t.start?t.start:0,o=null!=t.stop?t.stop:r,e=null!=t.step?t.step:1),[n,o,e]}function p(t,r){const n=new Set;let e=!1;for(const[o,s]of r){let r,c,l,i;if((0,u.isArray)(o)){const[e]=o;n.add(e),r=t[e].shape,c=t[e],i=s,2===o.length?(r=[1,r[0]],l=[o[0],0,o[1]]):l=o}else(0,u.isNumber)(o)?(i=[s],n.add(o)):(i=s,e=!0),l=[0,0,o],r=[1,t.length],c=t;let a=0;const[p,y,h]=f(l[1],r[0]),[d,_,m]=f(l[2],r[1]);for(let t=p;t{try{return this._decode(e)}finally{n=new Set(this._finalizable),this._decoding=!1,this._buffers.clear(),this._finalizable.clear()}})();for(const e of n)null===(t=this.finalize)||void 0===t||t.call(this,e),e.finalize(),e.assert_initialized();for(const e of n)e.connect_signals();return s}_decode(e){if((0,l.isArray)(e))return this._decode_plain_array(e);if(!(0,l.isPlainObject)(e))return e;if(!(0,l.isString)(e.type))return(0,l.isString)(e.id)?this._decode_ref(e):this._decode_plain_object(e);{const r=h.get(e.type);if(null!=r)return r(e,this);switch(e.type){case\"ref\":return this._decode_ref(e);case\"symbol\":return this._decode_symbol(e);case\"number\":return this._decode_number(e);case\"array\":return this._decode_array(e);case\"set\":return this._decode_set(e);case\"map\":return this._decode_map(e);case\"bytes\":return this._decode_bytes(e);case\"slice\":return this._decode_slice(e);case\"date\":return this._decode_date(e);case\"value\":return this._decode_value(e);case\"field\":return this._decode_field(e);case\"expr\":return this._decode_expr(e);case\"typed_array\":return this._decode_typed_array(e);case\"ndarray\":return this._decode_ndarray(e);case\"object\":return(0,l.isString)(e.id)?this._decode_object_ref(e):this._decode_object(e);default:this.error(`unable to decode an object of type '${e.type}'`)}}}_decode_symbol(e){this.error(`can't resolve named symbol '${e.name}'`)}_decode_number(e){if(\"value\"in e){const{value:r}=e;if((0,l.isString)(r))switch(r){case\"nan\":return NaN;case\"+inf\":return 1/0;case\"-inf\":return-1/0}else if((0,l.isNumber)(r))return r}this.error(`invalid number representation '${e}'`)}_decode_plain_array(e){return(0,c.map)(e,(e=>this._decode(e)))}_decode_plain_object(e){const r={};for(const[t,n]of(0,a.entries)(e))r[t]=this._decode(n);return r}_decode_array(e){var r;const t=[];for(const n of null!==(r=e.entries)&&void 0!==r?r:[])t.push(this._decode(n));return t}_decode_set(e){var r;const t=new Set;for(const n of null!==(r=e.entries)&&void 0!==r?r:[])t.add(this._decode(n));return t}_decode_map(e){var r;const t=(0,c.map)(null!==(r=e.entries)&&void 0!==r?r:[],(([e,r])=>[this._decode(e),this._decode(r)]));if((0,c.every)(t,(([e])=>(0,l.isString)(e)))){const e={};for(const[r,n]of t)e[r]=n;return e}return new Map(t)}_decode_bytes(e){const{data:r}=e;if(!(0,d.is_ref)(r))return(0,l.isString)(r)?(0,u.base64_to_buffer)(r):r.buffer;{const e=this._buffers.get(r.id);if(null!=e)return e;this.error(`buffer for id=${r.id} not found`)}}_decode_slice(e){const r=this._decode(e.start),t=this._decode(e.stop),n=this._decode(e.step);return new f.Slice({start:r,stop:t,step:n})}_decode_date(e){const r=this._decode(e.iso);return new Date(r)}_decode_value(e){return{value:this._decode(e.value),transform:null!=e.transform?this._decode(e.transform):void 0,units:null!=e.units?this._decode(e.units):void 0}}_decode_field(e){return{field:this._decode(e.field),transform:null!=e.transform?this._decode(e.transform):void 0,units:null!=e.units?this._decode(e.units):void 0}}_decode_expr(e){return{expr:this._decode(e.expr),transform:null!=e.transform?this._decode(e.transform):void 0,units:null!=e.units?this._decode(e.units):void 0}}_decode_typed_array(e){const{array:r,order:t,dtype:n}=e,s=this._decode(r);switch(t!=_.BYTE_ORDER&&(0,u.swap)(s,n),n){case\"uint8\":return new Uint8Array(s);case\"int8\":return new Int8Array(s);case\"uint16\":return new Uint16Array(s);case\"int16\":return new Int16Array(s);case\"uint32\":return new Uint32Array(s);case\"int32\":return new Int32Array(s);case\"float32\":return new Float32Array(s);case\"float64\":return new Float64Array(s);default:this.error(`unsupported dtype '${n}'`)}}_decode_ndarray(e){const{array:r,order:t,dtype:n,shape:s}=e,i=this._decode(r);return i instanceof ArrayBuffer&&t!=_.BYTE_ORDER&&(0,u.swap)(i,n),(0,o.ndarray)(i,{dtype:n,shape:s})}_decode_object(e){const{type:r,attributes:t}=e,n=this._resolve_type(r);return null!=t?new n(this._decode(t)):new n}_decode_ref(e){const r=this.references.get(e.id);if(null!=r)return r;this.error(`reference ${e.id} isn't known`)}_decode_object_ref(e){const r=this.references.get(e.id);if(null!=r)return this.warning(`reference already known '${e.id}'`),r;const{id:t,name:n,attributes:s}=e,i=new(this._resolve_type(n))({id:t});this.references.set(t,i);const d=this._decode(null!=s?s:{});return i.initialize_props(new a.Dict(d)),this._finalizable.add(i),i}error(e){throw new y(e)}warning(e){i.logger.warn(e)}_resolve_type(e){const r=this.resolver.get(e);if(null!=r)return r;this.error(`could not resolve type '${e}', which could be due to a widget or a custom model not being registered before first usage`)}}t.Deserializer=p,p.__name__=\"Deserializer\"},\n", - " function _(n,i,t,c,e){c();const f=n(8);t.is_ref=function(n){return(0,f.isPlainObject)(n)&&\"id\"in n&&!(\"type\"in n)}},\n", - " function _(t,s,e,l,n){l();const i=t(30);class c{constructor({start:t,stop:s,step:e}={}){this.start=null!=t?t:null,this.stop=null!=s?s:null,this.step=null!=e?e:null}[i.serialize](t){return{type:\"slice\",start:t.encode(this.start),stop:t.encode(this.stop),step:t.encode(this.step)}}}e.Slice=c,c.__name__=\"Slice\"},\n", - " function _(n,e,r,c,i){c(),r.pyify_version=function(n){return n.replace(/-(dev|rc)\\./,\".$1\")}},\n", - " function _(e,t,s,n,c){var i;n();const a=e(14),r=e(8),l=e(9),o=e(25),_=e(18);class h extends a.HasProps{get is_syncable(){return this.syncable}[o.equals](e,t){return(!!t.structural||t.eq(this.id,e.id))&&super[o.equals](e,t)}constructor(e){super(e)}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=(0,l.dict)(this.js_event_callbacks).get(e.event_name))&&void 0!==t?t:[])s.execute(e);null!=this.document&&this.subscribed_events.has(e.event_name)&&this.document.event_manager.send_event(e)}trigger_event(e){null!=this.document&&(e.origin=this,this.document.event_manager.trigger(e))}_update_event_callbacks(){null!=this.document?this.document.event_manager.subscribed_models.add(this):_.logger.warn(\"WARNING: Document not defined for updating event callbacks\")}_update_property_callbacks(){const e=e=>{const[t,s=null]=e.split(\":\");return null!=s?this.properties[s][t]:this[t]};for(const[t,s]of this._js_callbacks){const n=e(t);for(const e of s)this.disconnect(n,e)}this._js_callbacks.clear();for(const[t,s]of(0,l.dict)(this.js_property_callbacks)){const n=s.map((e=>()=>e.execute(this)));this._js_callbacks.set(t,n);const c=e(t);for(const e of n)this.connect(c,e)}}_doc_attached(){(0,l.dict)(this.js_event_callbacks).is_empty&&0==this.subscribed_events.size||this._update_event_callbacks()}_doc_detached(){this.document.event_manager.subscribed_models.delete(this)}select(e){if((0,r.isString)(e))return[...this.references()].filter((t=>t instanceof h&&t.name===e));if((0,r.isPlainObject)(e)&&\"type\"in e)return[...this.references()].filter((t=>t.type==e.type));if(e.prototype instanceof a.HasProps)return[...this.references()].filter((t=>t instanceof e));throw new Error(`invalid selector ${e}`)}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 ${e}`)}}on_event(e,t){var s;const n=(0,r.isString)(e)?e:e.prototype.event_name;this.js_event_callbacks[n]=[...null!==(s=(0,l.dict)(this.js_event_callbacks).get(n))&&void 0!==s?s:[],(0,r.isFunction)(t)?{execute:t}:t]}}s.Model=h,i=h,h.__name__=\"Model\",i.define((({Any:e,Unknown:t,Boolean:s,String:n,Array:c,Set:i,Dict:a,Nullable:r})=>({tags:[c(t),[]],name:[r(n),null],js_property_callbacks:[a(c(e)),{}],js_event_callbacks:[a(c(e)),{}],subscribed_events:[i(n),new globalThis.Set],syncable:[s,!0]})))},\n", - " function _(e,n,r,t,o){t();const s=e(1),c=e(50),u=s.__importStar(e(20)),a=e(8),i=e(9);r.decode_def=function(e,n){var r,t,o;function s(e){if((0,a.isString)(e))switch(e){case\"Any\":return u.Any;case\"Unknown\":return u.Unknown;case\"Boolean\":return u.Boolean;case\"Number\":return u.Number;case\"Int\":return u.Int;case\"Bytes\":return u.Bytes;case\"String\":return u.String;case\"Null\":return u.Null}else switch(e[0]){case\"Regex\":{const[,n,r]=e;return u.Regex(new RegExp(n,r))}case\"Nullable\":{const[,n]=e;return u.Nullable(s(n))}case\"Or\":{const[,n,...r]=e;return u.Or(s(n),...r.map(s))}case\"Tuple\":{const[,n,...r]=e;return u.Tuple(s(n),...r.map(s))}case\"Array\":{const[,n]=e;return u.Array(s(n))}case\"Struct\":{const[,...n]=e,r=n.map((([e,n])=>[e,s(n)]));return u.Struct((0,i.to_object)(r))}case\"Dict\":{const[,n]=e;return u.Dict(s(n))}case\"Map\":{const[,n,r]=e;return u.Map(s(n),s(r))}case\"Enum\":{const[,...n]=e;return u.Enum(...n)}case\"Ref\":{const[,r]=e,t=n.resolver.get(r.id);if(null!=t)return u.Ref(t);throw new Error(`${r.id} wasn't defined before referencing it`)}case\"AnyRef\":return u.AnyRef()}}const l=(()=>{var r,t;const o=null!==(t=null===(r=e.extends)||void 0===r?void 0:r.id)&&void 0!==t?t:\"Model\";if(\"Model\"==o)return c.Model;const s=n.resolver.get(o);if(null!=s)return s;throw new Error(`base model ${o} of ${e.name} is not defined`)})(),d=((o=class extends l{}).__qualified__=e.name,o);function f(e){return void 0===e?e:n.decode(e)}for(const n of null!==(r=e.properties)&&void 0!==r?r:[]){const e=s(n.kind);d.define({[n.name]:[e,f(n.default)]})}for(const n of null!==(t=e.overrides)&&void 0!==t?t:[])d.override({[n.name]:f(n.default)});return n.resolver.register(d),d}},\n", - " function _(e,t,s,n,a){var _,l,o,c,r,u,i,v,d,m,p,h,x,g,y,b,P,E,O,j,R,M,S,D,f,L,k,C;n();var U=this&&this.__decorate||function(e,t,s,n){var a,_=arguments.length,l=_<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,s):n;if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.decorate)l=Reflect.decorate(e,t,s,n);else for(var o=e.length-1;o>=0;o--)(a=e[o])&&(l=(_<3?a(l):_>3?a(t,s,l):a(t,s))||l);return _>3&&l&&Object.defineProperty(t,s,l),l};const T=e(30),B=e(25);function I(e){return t=>{t.prototype.event_name=e}}class w{[T.serialize](e){const{event_name:t,event_values:s}=this;return{type:\"event\",name:t,values:e.encode(s)}}[B.equals](e,t){return this.event_name==e.event_name&&t.eq(this.event_values,e.event_values)}}s.BokehEvent=w,_=w,w.__name__=\"BokehEvent\",_.prototype.publish=!0;class G extends w{constructor(){super(...arguments),this.origin=null}get event_values(){return{model:this.origin}}}s.ModelEvent=G,G.__name__=\"ModelEvent\";class V extends w{}s.DocumentEvent=V,V.__name__=\"DocumentEvent\";let W=((l=class extends V{get event_values(){return{}}}).__name__=\"DocumentReady\",l);s.DocumentReady=W,s.DocumentReady=W=U([I(\"document_ready\")],W);class q extends V{}s.ConnectionEvent=q,q.__name__=\"ConnectionEvent\";class z extends q{constructor(){super(...arguments),this.timestamp=new Date}get event_values(){const{timestamp:e}=this;return{timestamp:e}}}s.ConnectionLost=z,o=z,z.__name__=\"ConnectionLost\",o.prototype.event_name=\"connection_lost\",o.prototype.publish=!1;let A=((c=class extends G{}).__name__=\"ButtonClick\",c);s.ButtonClick=A,s.ButtonClick=A=U([I(\"button_click\")],A);let F=((r=class extends G{constructor(e){super(),this.item=e}get event_values(){const{item:e}=this;return Object.assign(Object.assign({},super.event_values),{item:e})}}).__name__=\"MenuItemClick\",r);s.MenuItemClick=F,s.MenuItemClick=F=U([I(\"menu_item_click\")],F);let H=((u=class extends G{constructor(e){super(),this.value=e}get event_values(){const{value:e}=this;return Object.assign(Object.assign({},super.event_values),{value:e})}}).__name__=\"ValueSubmit\",u);s.ValueSubmit=H,s.ValueSubmit=H=U([I(\"value_submit\")],H);class J extends G{}s.UIEvent=J,J.__name__=\"UIEvent\";let K=((i=class extends J{}).__name__=\"LODStart\",i);s.LODStart=K,s.LODStart=K=U([I(\"lodstart\")],K);let N=((v=class extends J{}).__name__=\"LODEnd\",v);s.LODEnd=N,s.LODEnd=N=U([I(\"lodend\")],N);let Q=((d=class extends J{constructor(e,t,s,n){super(),this.x0=e,this.x1=t,this.y0=s,this.y1=n}get event_values(){const{x0:e,x1:t,y0:s,y1:n}=this;return Object.assign(Object.assign({},super.event_values),{x0:e,x1:t,y0:s,y1:n})}}).__name__=\"RangesUpdate\",d);s.RangesUpdate=Q,s.RangesUpdate=Q=U([I(\"rangesupdate\")],Q);let X=((m=class extends J{constructor(e,t){super(),this.geometry=e,this.final=t}get event_values(){const{geometry:e,final:t}=this;return Object.assign(Object.assign({},super.event_values),{geometry:e,final:t})}}).__name__=\"SelectionGeometry\",m);s.SelectionGeometry=X,s.SelectionGeometry=X=U([I(\"selectiongeometry\")],X);let Y=((p=class extends J{}).__name__=\"Reset\",p);s.Reset=Y,s.Reset=Y=U([I(\"reset\")],Y);class Z extends J{constructor(e,t,s,n){super(),this.sx=e,this.sy=t,this.x=s,this.y=n}get event_values(){const{sx:e,sy:t,x:s,y:n}=this;return Object.assign(Object.assign({},super.event_values),{sx:e,sy:t,x:s,y:n})}}s.PointEvent=Z,Z.__name__=\"PointEvent\";let $=((h=class extends Z{constructor(e,t,s,n,a,_){super(e,t,s,n),this.delta_x=a,this.delta_y=_}get event_values(){const{delta_x:e,delta_y:t}=this;return Object.assign(Object.assign({},super.event_values),{delta_x:e,delta_y:t})}}).__name__=\"Pan\",h);s.Pan=$,s.Pan=$=U([I(\"pan\")],$);let ee=((x=class extends Z{constructor(e,t,s,n,a){super(e,t,s,n),this.scale=a}get event_values(){const{scale:e}=this;return Object.assign(Object.assign({},super.event_values),{scale:e})}}).__name__=\"Pinch\",x);s.Pinch=ee,s.Pinch=ee=U([I(\"pinch\")],ee);let te=((g=class extends Z{constructor(e,t,s,n,a){super(e,t,s,n),this.rotation=a}get event_values(){const{rotation:e}=this;return Object.assign(Object.assign({},super.event_values),{rotation:e})}}).__name__=\"Rotate\",g);s.Rotate=te,s.Rotate=te=U([I(\"rotate\")],te);let se=((y=class extends Z{constructor(e,t,s,n,a){super(e,t,s,n),this.delta=a}get event_values(){const{delta:e}=this;return Object.assign(Object.assign({},super.event_values),{delta:e})}}).__name__=\"MouseWheel\",y);s.MouseWheel=se,s.MouseWheel=se=U([I(\"wheel\")],se);let ne=((b=class extends Z{}).__name__=\"MouseMove\",b);s.MouseMove=ne,s.MouseMove=ne=U([I(\"mousemove\")],ne);let ae=((P=class extends Z{}).__name__=\"MouseEnter\",P);s.MouseEnter=ae,s.MouseEnter=ae=U([I(\"mouseenter\")],ae);let _e=((E=class extends Z{}).__name__=\"MouseLeave\",E);s.MouseLeave=_e,s.MouseLeave=_e=U([I(\"mouseleave\")],_e);let le=((O=class extends Z{}).__name__=\"Tap\",O);s.Tap=le,s.Tap=le=U([I(\"tap\")],le);let oe=((j=class extends Z{}).__name__=\"DoubleTap\",j);s.DoubleTap=oe,s.DoubleTap=oe=U([I(\"doubletap\")],oe);let ce=((R=class extends Z{}).__name__=\"Press\",R);s.Press=ce,s.Press=ce=U([I(\"press\")],ce);let re=((M=class extends Z{}).__name__=\"PressUp\",M);s.PressUp=re,s.PressUp=re=U([I(\"pressup\")],re);let ue=((S=class extends Z{}).__name__=\"PanStart\",S);s.PanStart=ue,s.PanStart=ue=U([I(\"panstart\")],ue);let ie=((D=class extends Z{}).__name__=\"PanEnd\",D);s.PanEnd=ie,s.PanEnd=ie=U([I(\"panend\")],ie);let ve=((f=class extends Z{}).__name__=\"PinchStart\",f);s.PinchStart=ve,s.PinchStart=ve=U([I(\"pinchstart\")],ve);let de=((L=class extends Z{}).__name__=\"PinchEnd\",L);s.PinchEnd=de,s.PinchEnd=de=U([I(\"pinchend\")],de);let me=((k=class extends Z{}).__name__=\"RotateStart\",k);s.RotateStart=me,s.RotateStart=me=U([I(\"rotatestart\")],me);let pe=((C=class extends Z{}).__name__=\"RotateEnd\",C);s.RotateEnd=pe,s.RotateEnd=pe=U([I(\"rotateend\")],pe)},\n", - " function _(n,e,t,o,i){o();const d=n(5),a=n(54),c=n(55),l=n(59);t.index={},t.add_document_standalone=async function(n,e,o=[],i=!1){const s=new a.ViewManager;async function f(i){null!=i.default_view?await async function(i){var d;const a=await(0,l.build_view)(i,{parent:null,owner:s});if(a instanceof c.DOMView){const t=n.roots().indexOf(i),c=null!==(d=o[t])&&void 0!==d?d:e;a.render_to(c)}s.add(a),t.index[i.id]=a}(i):n.notify_idle(i)}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=s.get(n);null!=e&&(e.remove(),s.delete(e),delete t.index[n.id])}(n.model):i&&n instanceof d.TitleChangedEvent&&(window.document.title=n.title)})),s}},\n", - " function _(t,e,i,s,n){s();const o=t(15),r=t(8);class h{get ready(){return this._ready}*children(){}connect(t,e){let i=this._slots.get(e);return null==i&&(i=(t,i)=>{const s=Promise.resolve(e.call(this,t,i));this._ready=this._ready.then((()=>s)),this.root!=this&&(this.root._ready=this.root._ready.then((()=>this._ready)))},this._slots.set(e,i)),t.connect(i,this)}disconnect(t,e){return t.disconnect(e,this)}constructor(t){this.removed=new o.Signal0(this,\"removed\"),this._ready=Promise.resolve(void 0),this._slots=new WeakMap,this._removed=!1,this._idle_notified=!1;const{model:e,parent:i,owner:s}=t;this.model=e,this.parent=i,null==i?(this.root=this,this.owner=null!=s?s:new d([this])):(this.root=i.root,this.owner=this.root.owner)}initialize(){this._has_finished=!1}async lazy_initialize(){}remove(){this.disconnect_signals(),this.removed.emit(),this._removed=!0}toString(){return`${this.model.type}View(${this.model.id})`}serializable_state(){return{type:this.model.type}}get is_root(){return null==this.parent}has_finished(){return this._has_finished}get is_idle(){return this.has_finished()}connect_signals(){}disconnect_signals(){o.Signal.disconnect_receiver(this)}on_change(t,e){for(const i of(0,r.isArray)(t)?t:[t])this.connect(i.change,e)}cursor(t,e){return null}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()}}i.View=h,h.__name__=\"View\";class d{constructor(t=[]){this.roots=new Set(t)}get(t){for(const e of this.roots)if(e.model==t)return e;return null}add(t){this.roots.add(t)}delete(t){this.roots.delete(t)}*[Symbol.iterator](){yield*this.roots}*query(t){function*e(i){if(t(i))yield i;else for(const t of i.children())yield*e(t)}for(const t of this.roots)yield*e(t)}*find(t){yield*this.query((e=>e.model==t))}get_one(t){const e=this.find_one(t);if(null!=e)return e;throw new Error(`cannot find a view for ${t}`)}find_one(t){for(const e of this.find(t))return e;return null}find_all(t){return[...this.find(t)]}}i.ViewManager=d,d.__name__=\"ViewManager\"},\n", - " function _(s,e,t,i,l){i();const _=s(1),a=s(54),h=s(56),c=s(8),n=_.__importDefault(s(58));class p extends a.View{get children_el(){var s;return null!==(s=this.shadow_el)&&void 0!==s?s:this.el}initialize(){super.initialize(),this.el=this._createElement()}remove(){(0,h.remove)(this.el),super.remove()}stylesheets(){return[]}css_classes(){return[]}render_to(s){s.appendChild(this.el),this.render()}finish(){this._has_finished=!0,this.notify_finished()}_createElement(){return(0,h.createElement)(this.constructor.tag_name,{class:this.css_classes()})}}t.DOMView=p,p.__name__=\"DOMView\",p.tag_name=\"div\";class r extends p{initialize(){super.initialize(),this.class_list=new h.ClassList(this.el.classList)}}t.DOMElementView=r,r.__name__=\"DOMElementView\";class d extends r{constructor(){super(...arguments),this._applied_stylesheets=[],this._applied_css_classes=[]}initialize(){super.initialize(),this.shadow_el=this.el.attachShadow({mode:\"open\"})}stylesheets(){return[...super.stylesheets(),n.default]}empty(){(0,h.empty)(this.shadow_el),this.class_list.clear(),this._applied_css_classes=[],this._applied_stylesheets=[]}render(){this.empty(),this._update_stylesheets(),this._update_css_classes()}*_stylesheets(){for(const s of this.stylesheets())yield(0,c.isString)(s)?new h.InlineStyleSheet(s):s}*_css_classes(){yield`bk-${this.model.type.replace(/\\./g,\"-\")}`,yield*this.css_classes()}_apply_stylesheets(s){this._applied_stylesheets.push(...s),s.forEach((s=>s.install(this.shadow_el)))}_apply_css_classes(s){this._applied_css_classes.push(...s),this.class_list.add(...s)}_update_stylesheets(){this._applied_stylesheets.forEach((s=>s.uninstall())),this._applied_stylesheets=[],this._apply_stylesheets([...this._stylesheets()])}_update_css_classes(){this.class_list.remove(this._applied_css_classes),this._applied_css_classes=[],this._apply_css_classes([...this._css_classes()])}}t.DOMComponentView=d,d.__name__=\"DOMComponentView\"},\n", - " function _(t,e,n,o,i){o(),n.supports_adopted_stylesheets=n.px=n.dom_ready=void 0;const s=t(8),l=t(9),r=t(57),c=t=>(e={},...n)=>{const o=document.createElement(t);(0,s.isPlainObject)(e)||(n=[e,...n],e={});for(let[t,n]of(0,l.entries)(e))if(null!=n&&(!(0,s.isBoolean)(n)||n))if(\"class\"===t&&((0,s.isString)(n)&&(n=n.split(/\\s+/)),(0,s.isArray)(n)))for(const t of n)null!=t&&o.classList.add(t);else if(\"style\"===t&&(0,s.isPlainObject)(n))for(const[t,e]of(0,l.entries)(n))o.style[t]=e;else if(\"data\"===t&&(0,s.isPlainObject)(n))for(const[t,e]of(0,l.entries)(n))o.dataset[t]=e;else o.setAttribute(t,n);function i(t){if((0,s.isString)(t))o.appendChild(document.createTextNode(t));else if(t instanceof Node)o.appendChild(t);else if(t instanceof NodeList||t instanceof HTMLCollection)for(const e of t)o.appendChild(e);else if(null!=t&&!1!==t)throw new Error(`expected a DOM element, string, false or null, got ${JSON.stringify(t)}`)}for(const t of n)if((0,s.isArray)(t))for(const e of t)i(e);else i(t);return o};function a(t){return document.createTextNode(t)}function d(t){const e=t.parentNode;null!=e&&e.removeChild(t)}function h(t){const e=parseFloat(t);return isFinite(e)?e: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 c(t)(e,...n)},n.div=c(\"div\"),n.span=c(\"span\"),n.canvas=c(\"canvas\"),n.link=c(\"link\"),n.style=c(\"style\"),n.a=c(\"a\"),n.p=c(\"p\"),n.i=c(\"i\"),n.pre=c(\"pre\"),n.button=c(\"button\"),n.label=c(\"label\"),n.legend=c(\"legend\"),n.fieldset=c(\"fieldset\"),n.input=c(\"input\"),n.select=c(\"select\"),n.option=c(\"option\"),n.optgroup=c(\"optgroup\"),n.textarea=c(\"textarea\"),n.createSVGElement=function(t,e=null,...n){const o=document.createElementNS(\"http://www.w3.org/2000/svg\",t);for(const[t,n]of(0,l.entries)(null!=e?e:{}))null!=n&&!1!==n&&o.setAttribute(t,n);function i(t){if((0,s.isString)(t))o.appendChild(document.createTextNode(t));else if(t instanceof Node)o.appendChild(t);else if(t instanceof NodeList||t instanceof HTMLCollection)for(const e of t)o.appendChild(e);else if(null!=t&&!1!==t)throw new Error(`expected a DOM element, string, false or null, got ${JSON.stringify(t)}`)}for(const t of n)if((0,s.isArray)(t))for(const e of t)i(e);else i(t);return o},n.text=a,n.nbsp=function(){return a(\"\\xa0\")},n.append=function(t,...e){for(const n of e)t.appendChild(n)},n.remove=d,n.replaceWith=function(t,e){const n=t.parentNode;null!=n&&n.replaceChild(e,t)},n.prepend=function(t,...e){const n=t.firstChild;for(const o of e)t.insertBefore(o,n)},n.empty=function(t,e=!1){let n;for(;null!=(n=t.firstChild);)t.removeChild(n);if(e&&t instanceof Element)for(const e of t.attributes)t.removeAttributeNode(e)},n.contains=function(t,e){let n=e;for(;null!=n.parentNode;){const e=n.parentNode;if(e==t)return!0;n=e instanceof ShadowRoot?e.host:e}return!1},n.display=function(t,e=!0){t.style.display=e?\"\":\"none\"},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_bbox=function(t){const{top:e,left:n,width:o,height:i}=t.getBoundingClientRect();return new r.BBox({left:n+scrollX-document.documentElement.clientLeft,top:e+scrollY-document.documentElement.clientTop,width:o,height:i})},n.parent=function(t,e){let n=t;for(;null!=(n=n.parentElement);)if(n.matches(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:o,bottom:i}}=u(t),{width:s,height:l}=f(t);return{width:Math.ceil(s+e+n),height:Math.ceil(l+o+i)}},n.content_size=function(t){var e;const{left:n,top:o}=t.getBoundingClientRect(),{padding:i}=u(t);let s=0,l=0;for(const r of(null!==(e=t.shadowRoot)&&void 0!==e?e:t).children){const t=r.getBoundingClientRect();s=Math.max(s,Math.ceil(t.left-n-i.left+t.width)),l=Math.max(l,Math.ceil(t.top-o-i.top+t.height))}return{width:s,height:l}},n.bounding_box=function(t){const{x:e,y:n,width:o,height:i}=t.getBoundingClientRect();return new r.BBox({x:e,y:n,width:o,height:i})},n.position=function(t,e,n){const{style:o}=t;if(o.left=`${e.x}px`,o.top=`${e.y}px`,o.width=`${e.width}px`,o.height=`${e.height}px`,null==n)o.margin=\"\";else{const{top:t,right:e,bottom:i,left:s}=n;o.margin=`${t}px ${e}px ${i}px ${s}px`}};class p{constructor(t){this.class_list=t}get values(){const t=[];for(let e=0;ethis.class_list.remove(t))):this.class_list.remove(e);return this}clear(){for(const t of this.values)this.class_list.remove(t);return this}toggle(t,e){return(null!=e?e:!this.has(t))?this.add(t):this.remove(t),this}}var g;n.ClassList=p,p.__name__=\"ClassList\",n.classes=function(t){return new p(t.classList)},n.toggle_attribute=function(t,e,n){null==n&&(n=!t.hasAttribute(e)),n?t.setAttribute(e,\"true\"):t.removeAttribute(e)},(g=n.MouseButton||(n.MouseButton={}))[g.None=0]=\"None\",g[g.Primary=1]=\"Primary\",g[g.Secondary=2]=\"Secondary\",g[g.Auxiliary=4]=\"Auxiliary\",g[g.Left=1]=\"Left\",g[g.Right=2]=\"Right\",g[g.Middle=4]=\"Middle\";class m{install(t){t.append(this.el)}uninstall(){this.el.remove()}}n.StyleSheet=m,m.__name__=\"StyleSheet\";class _ extends m{constructor(t){super(),this.el=(0,n.style)({type:\"text/css\"},t)}clear(){this.replace(\"\")}*_to_rules(t){for(const[e,n]of(0,l.entries)(t))if(null!=n){const t=e.replace(/_/g,\"-\");yield`${t}: ${n};`}}_to_css(t,e){return null==e?t:`${t}{${[...this._to_rules(e)].join(\"\")}}`}replace(t,e){this.el.textContent=this._to_css(t,e)}prepend(t,e){var n;const o=null!==(n=this.el.textContent)&&void 0!==n?n:\"\";this.el.textContent=`${this._to_css(t,e)}\\n${o}`}append(t,e){var n;const o=null!==(n=this.el.textContent)&&void 0!==n?n:\"\";this.el.textContent=`${o}\\n${this._to_css(t,e)}`}remove(){d(this.el)}}n.InlineStyleSheet=_,_.__name__=\"InlineStyleSheet\";class y extends _{install(){this.el.isConnected||document.head.appendChild(this.el)}}n.GlobalInlineStyleSheet=y,y.__name__=\"GlobalInlineStyleSheet\";class x extends m{constructor(t){super(),this.el=(0,n.link)({rel:\"stylesheet\",href:t})}replace(t){this.el.href=t}remove(){d(this.el)}}n.ImportedStyleSheet=x,x.__name__=\"ImportedStyleSheet\";class b extends x{install(){this.el.isConnected||document.head.appendChild(this.el)}}n.GlobalImportedStyleSheet=b,b.__name__=\"GlobalImportedStyleSheet\",n.dom_ready=async function(){if(\"loading\"==document.readyState)return new Promise(((t,e)=>{document.addEventListener(\"DOMContentLoaded\",(()=>t()),{once:!0})}))},n.px=function(t){return`${t}px`},n.supports_adopted_stylesheets=\"adoptedStyleSheets\"in ShadowRoot.prototype},\n", - " function _(t,e,i,r,n){r();const h=t(23),s=t(25),o=t(13),{min:x,max:y,round:u}=Math;function g(t,e){return isNaN(t)?e:isNaN(e)?t:x(t,e)}function a(t,e){return isNaN(t)?e:isNaN(e)?t:y(t,e)}i.empty=function(){return{x0:1/0,y0:1/0,x1:-1/0,y1:-1/0}},i.positive_x=function(){return{x0:Number.MIN_VALUE,y0:-1/0,x1:1/0,y1:1/0}},i.positive_y=function(){return{x0:-1/0,y0:Number.MIN_VALUE,x1:1/0,y1:1/0}},i.union=function(t,e){return{x0:g(t.x0,e.x0),x1:a(t.x1,e.x1),y0:g(t.y0,e.y0),y1:a(t.y1,e.y1)}};class c{constructor(t,e=!1){if(null==t)this.x0=0,this.y0=0,this.x1=0,this.y1=0;else if(\"x0\"in t){const{x0:e,y0:i,x1:r,y1:n}=t;if(isFinite(e+i+r+n)){if(!(e<=r&&i<=n))throw new Error(`invalid bbox {x0: ${e}, y0: ${i}, x1: ${r}, y1: ${n}}`);this.x0=e,this.y0=i,this.x1=r,this.y1=n}else this.x0=NaN,this.y0=NaN,this.x1=NaN,this.y1=NaN}else if(\"x\"in t){const{x:e,y:i,width:r,height:n}=t;if(!(r>=0&&n>=0))throw new Error(`invalid bbox {x: ${e}, y: ${i}, width: ${r}, height: ${n}}`);this.x0=e,this.y0=i,this.x1=e+r,this.y1=i+n}else{let i,r,n,h;if(\"width\"in t)if(\"left\"in t)i=t.left,r=i+t.width;else if(\"right\"in t)r=t.right,i=r-t.width;else{const e=t.width/2;i=t.hcenter-e,r=t.hcenter+e}else i=t.left,r=t.right;if(\"height\"in t)if(\"top\"in t)n=t.top,h=n+t.height;else if(\"bottom\"in t)h=t.bottom,n=h-t.height;else{const e=t.height/2;n=t.vcenter-e,h=t.vcenter+e}else n=t.top,h=t.bottom;if(i>r||n>h){if(!e)throw new Error(`invalid bbox {left: ${i}, top: ${n}, right: ${r}, bottom: ${h}}`);i>r&&(i=r),n>h&&(n=h)}this.x0=i,this.y0=n,this.x1=r,this.y1=h}}static from_lrtb({left:t,right:e,top:i,bottom:r}){return new c({x0:Math.min(t,e),y0:Math.min(i,r),x1:Math.max(t,e),y1:Math.max(i,r)})}clone(){return new c(this)}equals(t){return this.x0==t.x0&&this.y0==t.y0&&this.x1==t.x1&&this.y1==t.y1}[s.equals](t,e){return e.eq(this.x0,t.x0)&&e.eq(this.y0,t.y0)&&e.eq(this.x1,t.x1)&&e.eq(this.y1,t.y1)}toString(){return`BBox({left: ${this.left}, top: ${this.top}, width: ${this.width}, height: ${this.height}})`}get is_valid(){const{x0:t,x1:e,y0:i,y1:r}=this;return isFinite(t+e+i+r)}get is_empty(){const{x0:t,x1:e,y0:i,y1:r}=this;return 0==t&&0==e&&0==i&&0==r}get left(){return this.x0}get top(){return this.y0}get right(){return this.x1}get bottom(){return this.y1}get p0(){return{x:this.x0,y:this.y0}}get p1(){return{x:this.x1,y: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:e,x1:i,y1:r}=this;return{p0:{x:t,y:e},p1:{x:i,y:e},p2:{x:i,y:r},p3:{x:t,y:r}}}get box(){const{x:t,y:e,width:i,height:r}=this;return{x:t,y:e,width:i,height:r}}get lrtb(){const{left:t,right:e,top:i,bottom:r}=this;return{left:t,right:e,top:i,bottom:r}}get x_range(){return{start:this.x0,end:this.x1}}get y_range(){return{start:this.y0,end:this.y1}}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}round(){return new c({x0:u(this.x0),x1:u(this.x1),y0:u(this.y0),y1:u(this.y1)})}relative(){const{width:t,height:e}=this;return new c({x:0,y:0,width:t,height:e})}translate(t,e){const{x:i,y:r,width:n,height:h}=this;return new c({x:t+i,y:e+r,width:n,height:h})}relativize(t,e){return[t-this.x,e-this.y]}contains(t,e){return this.x0<=t&&t<=this.x1&&this.y0<=e&&e<=this.y1}clip(t,e){return tthis.x1&&(t=this.x1),ethis.y1&&(e=this.y1),[t,e]}grow_by(t){return new c({left:this.left-t,right:this.right+t,top:this.top-t,bottom:this.bottom+t})}shrink_by(t){return new c({left:this.left+t,right:this.right-t,top:this.top+t,bottom:this.bottom-t},!0)}union(t){return new c({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 c({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 x_screen(){var t;const e=this;return null!==(t=this._x_screen)&&void 0!==t?t:this._x_screen={compute:t=>e.left+t,invert:t=>t-e.left,v_compute(t){const{left:i}=e;return new h.ScreenArray((0,o.map)(t,(t=>i+t)))},v_invert(t){const{left:i}=e;return(0,o.map)(t,(t=>t-i))},get source_range(){return e.x_range},get target_range(){return e.x_range}}}get y_screen(){var t;const e=this;return null!==(t=this._y_screen)&&void 0!==t?t:this._y_screen={compute:t=>e.top+t,invert:t=>t-e.top,v_compute(t){const{top:i}=e;return new h.ScreenArray((0,o.map)(t,(t=>i+t)))},v_invert(t){const{top:i}=e;return(0,o.map)(t,(t=>t-i))},get source_range(){return e.y_range},get target_range(){return e.y_range}}}get x_view(){var t;const e=this;return null!==(t=this._x_view)&&void 0!==t?t:this._x_view={compute:t=>e.left+t,invert:t=>t-e.left,v_compute(t){const{left:i}=e;return new h.ScreenArray((0,o.map)(t,(t=>i+t)))},v_invert(t){const{left:i}=e;return(0,o.map)(t,(t=>t-i))},get source_range(){return e.x_range},get target_range(){return e.x_range}}}get y_view(){var t;const e=this;return null!==(t=this._y_view)&&void 0!==t?t:this._y_view={compute:t=>e.bottom-t,invert:t=>e.bottom-t,v_compute(t){const{bottom:i}=e;return new h.ScreenArray((0,o.map)(t,(t=>i-t)))},v_invert(t){const{bottom:i}=e;return(0,o.map)(t,(t=>i-t))},get source_range(){return e.y_range},get target_range(){return{start:e.bottom,end:e.top}}}}get xview(){return this.x_view}get yview(){return this.y_view}}i.BBox=c,c.__name__=\"BBox\"},\n", - " function _(o,e,i,n,t){n(),i.default=\":host{--base-font:var(--bokeh-base-font, Helvetica, Arial, sans-serif);--mono-font:var(--bokeh-mono-font, monospace);--font-size:12px;--line-height:calc(20 / 14);--line-height-computed:calc(var(--font-size) * var(--line-height));--border-radius:4px;--padding-vertical:6px;--padding-horizontal:12px;}:host{box-sizing:border-box;font-family:var(--base-font);font-size:13px;line-height:var(--line-height);}*,*:before,*:after{box-sizing:inherit;font-family:inherit;}pre,code{font-family:var(--mono-font);margin:0;}\"},\n", - " function _(e,n,t,o,s){o();const i=e(10),c=e(12);async function a(e,n,t){(0,c.assert)(null!=e,\"model doesn't implement a view\");const o=new e(Object.assign(Object.assign({},t),{model:n}));return o.initialize(),await o.lazy_initialize(),o}t.build_view=async function(e,n={parent:null},t=(e=>e.default_view)){const o=await a(t(e),e,n);return o.connect_signals(),o},t.build_views=async function(e,n,t={parent:null},o=(e=>e.default_view)){const s=(0,i.difference)([...e.keys()],n),c=[];for(const n of s){const t=e.get(n);null!=t&&(e.delete(n),c.push(t),t.remove())}const l=[],r=n.filter((n=>!e.has(n)));for(const n of r){const s=await a(o(n),n,t);e.set(n,s),l.push(s)}for(const e of l)e.connect_signals();return{created:l,removed:c}},t.remove_views=function(e){for(const[n,t]of e)t.remove(),e.delete(n)}},\n", - " function _(n,t,o,e,s){e();const a=n(61),c=n(18),r=n(53);o._get_ws_url=function(n,t){let o,e=\"ws:\";return\"https:\"==window.location.protocol&&(e=\"wss:\"),null!=t?(o=document.createElement(\"a\"),o.href=t):o=window.location,null!=n?\"/\"==n&&(n=\"\"):n=o.pathname.replace(/\\/+$/,\"\"),`${e}//${o.host}${n}/ws`};const i=new Map;o.add_document_from_session=async function(n,t,o,e=[],s=!1){const l=window.location.search.substring(1);let d;try{d=await function(n,t,o){const e=(0,a.parse_token)(t).session_id;i.has(n)||i.set(n,new Map);const s=i.get(n);return s.has(e)||s.set(e,(0,a.pull_session)(n,t,o)),s.get(e)}(n,t,l)}catch(n){const o=(0,a.parse_token)(t).session_id;throw c.logger.error(`Failed to load Bokeh session ${o}: ${n}`),n}return(0,r.add_document_standalone)(d.document,o,e,s)}},\n", - " function _(e,s,n,t,o){t();const r=e(18),i=e(5),l=e(62),c=e(63),_=e(64);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._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 c.Receiver,this.url=e,this.token=s,this.args_string=t,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((()=>{var e;this.closed_permanently||(r.logger.info(`Websocket connection ${this._number} disconnected, will not attempt to reconnect`),null===(e=this.session)||void 0===e||e.notify_connection_lost())}),e)}send(e){null!=this.socket?e.send(this.socket):r.logger.error(\"not connected so cannot send\",e)}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=l.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){r.logger.debug(null!=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=[],t=i.Document.from_json(n,s);this.session=new _.ClientSession(this,t);for(const e of s)t._trigger_on_change(e);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){console.trace(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);null!=n?(this._pending_replies.delete(s),n.resolve(e)):null!=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(30),a=e(38),h=e(12);class f{get buffers(){return this._buffers}constructor(e,s,t){this._buffers=new Map,this.header=e,this.metadata=s,this.content=t}static assemble(e,s,t){const r=JSON.parse(e),n=JSON.parse(s),i=JSON.parse(t);return new f(r,n,i)}assemble_buffer(e,s){var t;const r=null!==(t=this.header.num_buffers)&&void 0!==t?t:0;if(r<=this._buffers.size)throw new Error(`too many buffers received, expecting ${r}`);const{id:n}=JSON.parse(e);this._buffers.set(n,s)}static create(e,s,t){const r=f.create_header(e);return new f(r,s,t)}static create_header(e){return{msgid:(0,a.unique_id)(),msgtype:e}}complete(){const{num_buffers:e}=this.header;return null==e||this._buffers.size==e}send(e){(0,h.assert)(null==this.header.num_buffers);const s=[],t=JSON.stringify(this.content,((e,t)=>{if(t instanceof i.Buffer){const e={id:`${s.length}`};return s.push([e,t.buffer]),e}return t})),r=s.length;r>0&&(this.header.num_buffers=r);const n=JSON.stringify(this.header),a=JSON.stringify(this.metadata);e.send(n),e.send(a),e.send(t);for(const[t,r]of s)e.send(JSON.stringify(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=f,f.__name__=\"Message\"},\n", - " function _(t,e,s,_,r){_();const i=t(62),h=t(8),a=t(12);class n{constructor(){this.message=null,this._partial=null,this._fragments=[],this._buf_header=null,this._current_consumer=this._HEADER}consume(t){this._current_consumer(t)}_HEADER(t){this._assume_text(t),this.message=null,this._partial=null,this._fragments=[t],this._buf_header=null,this._current_consumer=this._METADATA}_METADATA(t){this._assume_text(t),this._fragments.push(t),this._current_consumer=this._CONTENT}_CONTENT(t){this._assume_text(t),this._fragments.push(t);const[e,s,_]=this._fragments;(0,a.assert)(null!=e&&null!=s&&null!=_),this._partial=i.Message.assemble(e,s,_),this._check_complete()}_BUFFER_HEADER(t){this._assume_text(t),this._buf_header=t,this._current_consumer=this._BUFFER_PAYLOAD}_BUFFER_PAYLOAD(t){this._assume_binary(t),(0,a.assert)(null!=this._partial&&null!=this._buf_header),this._partial.assemble_buffer(this._buf_header,t),this._check_complete()}_assume_text(t){if(!(0,h.isString)(t))throw new Error(\"Expected text fragment but received binary fragment\")}_assume_binary(t){if(!(t 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=n,n.__name__=\"Receiver\"},\n", - " function _(e,n,t,o,s){o();const c=e(5),_=e(52),i=e(62),r=e(18);class a{constructor(e,n){this._document_listener=e=>{this._document_changed(e)},this._connection=e,this.document=n,this.document.on_change(this._document_listener,!0)}get id(){return this._connection.id}handle(e){const n=e.msgtype();switch(n){case\"PATCH-DOC\":this._handle_patch(e);break;case\"OK\":this._handle_ok(e);break;case\"ERROR\":this._handle_error(e);break;default:r.logger.debug(`Doing nothing with message '${n}'`)}}notify_connection_lost(){this.document.event_manager.send_event(new _.ConnectionLost)}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){const n=e instanceof c.DocumentEventBatch?e.events:[e],t=this.document.create_json_patch(n),o=i.Message.create(\"PATCH-DOC\",{},t);this._connection.send(o)}_handle_patch(e){this.document.apply_json_patch(e.content,e.buffers)}_handle_ok(e){r.logger.trace(`Unhandled OK reply to ${e.reqid()}`)}_handle_error(e){r.logger.error(`Unhandled ERROR reply to ${e.reqid()}: ${e.content.text}`)}}t.ClientSession=a,a.__name__=\"ClientSession\"},\n", - " function _(n,e,o,t,r){t();const i=n(56),l=n(8);function s(n){let e=(0,l.isString)(n)?document.getElementById(n):n;if(null==e)throw new Error(`Error rendering Bokeh model: could not find ${(0,l.isString)(n)?`#${n}`:n} HTML tag`);if(!(0,i.contains)(document.body,e))throw new Error(`Error rendering Bokeh model: element ${(0,l.isString)(n)?`#${n}`:n} must be under `);if(e instanceof HTMLElement&&\"SCRIPT\"==e.tagName){const n=(0,i.div)();(0,i.replaceWith)(e,n),e=n}return e}o._resolve_element=function(n){const{elementid:e}=n;return null!=e?s(e):document.body},o._resolve_root_elements=function(n){const e=[];if(null!=n.root_ids&&null!=n.roots)for(const o of n.root_ids)e.push(s(n.roots[o]));return e}},\n", - " function _(e,o,t,n,r){n();const s=e(1),i=e(5),l=e(63),a=e(18),c=e(9),g=e(53),f=e(65);function u(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 m(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 l.Receiver;t.on_msg(u.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 l.Receiver;t.onMsg=u.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,i,c,g;a.logger.info(`Registering Google Colab comms for target ${e}`);const f=new l.Receiver;try{for(var m,b=!0,d=s.__asyncValues(t.messages);!(n=(m=await d.next()).done);){c=m.value,b=!1;try{const e=c,t={data:e.data},n=[];for(const o of null!==(g=e.buffers)&&void 0!==g?g:[])n.push(new DataView(o));const r={content:t,buffers:n};u.bind(o)(f,r)}finally{b=!0}}}catch(e){r={error:e}}finally{try{b||n||!(i=d.return)||await i.call(d)}finally{if(r)throw r.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.\")}t.kernels={},t.embed_items_notebook=function(e,o){if(1!=(0,c.size)(e))throw new Error(\"embed_items_notebook expects exactly one document in docs_json\");const t=i.Document.from_json((0,c.values)(e)[0]);for(const e of o){null!=e.notebook_comms_target&&m(e.notebook_comms_target,t);const o=(0,f._resolve_element)(e),n=(0,f._resolve_root_elements)(e);(0,g.add_document_standalone)(t,o,n);for(const e of n)e instanceof HTMLElement&&e.removeAttribute(\"id\")}}},\n", - " function _(t,_,o,r,n){r();const a=t(1);a.__exportStar(t(62),o),a.__exportStar(t(63),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,l,n){l(),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 l=document.createElement(\"h3\");l.style.color=\"#a94442\",l.style.margin=\"8px 0px 0px 0px\",l.style.padding=\"0px\",l.appendChild(document.createTextNode(\"Bokeh Error\"));const n=document.createElement(\"pre\");n.style.whiteSpace=\"unset\",n.style.overflowX=\"auto\",n.appendChild(document.createTextNode(e)),t.appendChild(o),t.appendChild(l),t.appendChild(n);const s=document.getElementsByTagName(\"body\")[0];s.insertBefore(t,s.firstChild)}(e instanceof Error&&null!=e.stack?e.stack:`${e}`),t)return;throw e}}},\n", - " function _(t,r,o,_,e){_();const s=t(1),i=t(7),m=s.__importStar(t(71));(0,i.register_models)(m);const n=s.__importStar(t(496));(0,i.register_models)(n)},\n", - " function _(t,_,r,o,a){o();const e=t(1);e.__exportStar(t(72),r),e.__exportStar(t(158),r),e.__exportStar(t(285),r),e.__exportStar(t(290),r),e.__exportStar(t(296),r),e.__exportStar(t(297),r),e.__exportStar(t(306),r),e.__exportStar(t(219),r),e.__exportStar(t(315),r),e.__exportStar(t(350),r),e.__exportStar(t(351),r),e.__exportStar(t(355),r),e.__exportStar(t(357),r),e.__exportStar(t(237),r),e.__exportStar(t(376),r),e.__exportStar(t(382),r),e.__exportStar(t(383),r),e.__exportStar(t(392),r),e.__exportStar(t(404),r),e.__exportStar(t(405),r),e.__exportStar(t(225),r),e.__exportStar(t(407),r),e.__exportStar(t(223),r),e.__exportStar(t(410),r),e.__exportStar(t(411),r),e.__exportStar(t(417),r),e.__exportStar(t(192),r),e.__exportStar(t(422),r),e.__exportStar(t(432),r),e.__exportStar(t(436),r),e.__exportStar(t(451),r)},\n", - " function _(o,e,a,n,r){n();const t=o(1);r(\"Annotation\",o(73).Annotation),r(\"Arrow\",o(97).Arrow),r(\"ArrowHead\",o(139).ArrowHead),r(\"OpenHead\",o(139).OpenHead),r(\"NormalHead\",o(139).NormalHead),r(\"TeeHead\",o(139).TeeHead),r(\"VeeHead\",o(139).VeeHead),r(\"BaseColorBar\",o(141).BaseColorBar),r(\"Band\",o(230).Band),r(\"BoxAnnotation\",o(232).BoxAnnotation),r(\"ColorBar\",o(236).ColorBar),r(\"ContourColorBar\",o(247).ContourColorBar),r(\"Label\",o(248).Label),r(\"LabelSet\",o(249).LabelSet),r(\"Legend\",o(250).Legend),r(\"LegendItem\",o(251).LegendItem),r(\"PolyAnnotation\",o(252).PolyAnnotation),r(\"Slope\",o(253).Slope),r(\"Span\",o(254).Span),r(\"TextAnnotation\",o(143).TextAnnotation),r(\"Title\",o(142).Title),r(\"ToolbarPanel\",o(255).ToolbarPanel),r(\"Whisker\",o(279).Whisker),t.__exportStar(o(280),a)},\n", - " function _(t,e,i,n,s){var o;n();const l=t(74);class r extends l.RendererView{get_size(){if(this.displayed){const{width:t,height:e}=this._get_size();return{width:Math.round(t),height:Math.round(e)}}return{width:0,height:0}}_get_size(){throw new Error(\"not implemented\")}connect_signals(){super.connect_signals();const t=this.model.properties;this.on_change(t.visible,(()=>{null!=this.layout&&(this.layout.visible=this.model.visible,this.plot_view.request_layout())}))}get needs_clip(){return null==this.layout}serializable_state(){var t,e,i;const n=super.serializable_state(),s=null!==(e=null===(t=this.bbox)||void 0===t?void 0:t.round())&&void 0!==e?e:null===(i=this.layout)||void 0===i?void 0:i.bbox;return null==s?n:Object.assign(Object.assign({},n),{bbox:s})}}i.AnnotationView=r,r.__name__=\"AnnotationView\";class a extends l.Renderer{constructor(t){super(t)}}i.Annotation=a,o=a,a.__name__=\"Annotation\",o.override({level:\"annotation\"})},\n", - " function _(e,t,i,n,s){var r,o;n();const a=e(1),_=e(54),l=a.__importStar(e(75)),d=e(19),h=e(50),u=e(84);class c extends h.Model{constructor(e){super(e)}}i.RendererGroup=c,r=c,c.__name__=\"RendererGroup\",r.define((({Boolean:e})=>({visible:[e,!0]})));class p extends _.View{get coordinates(){const{_coordinates:e}=this;return null!=e?e:this._coordinates=this._initialize_coordinates()}initialize(){super.initialize(),this.visuals=new l.Visuals(this),this.needs_webgl_blit=!1}connect_signals(){super.connect_signals();const{group:e}=this.model;null!=e&&this.on_change(e.properties.visible,(()=>{this.model.visible=e.visible}));const{x_range_name:t,y_range_name:i}=this.model.properties;this.on_change([t,i],(()=>delete this._coordinates)),this.connect(this.plot_view.frame.change,(()=>delete this._coordinates))}_initialize_coordinates(){const{coordinates:e}=this.model,{frame:t}=this.plot_view;if(null!=e)return e.get_transform(t);{const{x_range_name:e,y_range_name:i}=this.model,n=t.x_scales.get(e),s=t.y_scales.get(i);return new u.CoordinateTransform(n,s)}}get plot_view(){return this.parent}get plot_model(){return this.parent.model}get layer(){const{overlays:e,primary:t}=this.canvas;return\"overlay\"==this.model.level?e:t}get canvas(){return this.plot_view.canvas_view}request_render(){this.request_paint()}request_paint(){this.plot_view.request_paint(this)}request_layout(){this.plot_view.request_layout()}notify_finished(){this.plot_view.notify_finished()}notify_finished_after_paint(){this.plot_view.notify_finished_after_paint()}get needs_clip(){return!1}get has_webgl(){return!1}get displayed(){return this.model.visible}render(){this.displayed&&this._render(),this._has_finished=!0}renderer_view(e){}update_geometry(){}compute_geometry(){}}i.RendererView=p,p.__name__=\"RendererView\";class g extends h.Model{constructor(e){super(e)}}i.Renderer=g,o=g,g.__name__=\"Renderer\",o.define((({Boolean:e,String:t,Ref:i,Nullable:n})=>({group:[n(i(c)),null],level:[d.RenderLevel,\"image\"],visible:[e,!0],x_range_name:[t,\"default\"],y_range_name:[t,\"default\"],coordinates:[n(i(u.CoordinateMapping)),null],propagate_hover:[e,!1]})))},\n", - " function _(e,a,r,t,c){t();const n=e(1),l=e(76);c(\"Line\",l.Line),c(\"LineScalar\",l.LineScalar),c(\"LineVector\",l.LineVector);const s=e(79);c(\"Fill\",s.Fill),c(\"FillScalar\",s.FillScalar),c(\"FillVector\",s.FillVector);const i=e(80);c(\"Text\",i.Text),c(\"TextScalar\",i.TextScalar),c(\"TextVector\",i.TextVector);const o=e(81);c(\"Hatch\",o.Hatch),c(\"HatchScalar\",o.HatchScalar),c(\"HatchVector\",o.HatchVector);const u=e(83);c(\"Image\",u.Image),c(\"ImageScalar\",u.ImageScalar),c(\"ImageVector\",u.ImageVector);const V=n.__importStar(e(78)),S=e(77);c(\"VisualProperties\",S.VisualProperties),c(\"VisualUniforms\",S.VisualUniforms);class m{*[Symbol.iterator](){yield*this._visuals}constructor(e){this._visuals=[];for(const[a,r]of e.model._mixins){const t=(()=>{switch(r){case V.Line:return new l.Line(e,a);case V.LineScalar:return new l.LineScalar(e,a);case V.LineVector:return new l.LineVector(e,a);case V.Fill:return new s.Fill(e,a);case V.FillScalar:return new s.FillScalar(e,a);case V.FillVector:return new s.FillVector(e,a);case V.Text:return new i.Text(e,a);case V.TextScalar:return new i.TextScalar(e,a);case V.TextVector:return new i.TextVector(e,a);case V.Hatch:return new o.Hatch(e,a);case V.HatchScalar:return new o.HatchScalar(e,a);case V.HatchVector:return new o.HatchVector(e,a);case V.Image:return new u.Image(e,a);case V.ImageScalar:return new u.ImageScalar(e,a);case V.ImageVector:return new u.ImageVector(e,a);default:throw new Error(\"unknown visual\")}})();t instanceof S.VisualProperties&&t.update(),this._visuals.push(t),Object.defineProperty(this,a+t.type,{get:()=>t,configurable:!1,enumerable:!0})}}}r.Visuals=m,m.__name__=\"Visuals\"},\n", - " function _(e,t,i,l,s){l();const a=e(1),n=e(77),h=a.__importStar(e(78)),o=e(21),_=e(8);function r(e){if((0,_.isArray)(e))return e;switch(e){case\"solid\":return[];case\"dashed\":return[6];case\"dotted\":return[2,4];case\"dotdash\":return[2,4,6,4];case\"dashdot\":return[6,4,2,4];default:return e.split(\" \").map(Number).filter(_.isInteger)}}i.resolve_line_dash=r;class u extends n.VisualProperties{get doit(){const e=this.line_color.get_value(),t=this.line_alpha.get_value(),i=this.line_width.get_value();return!(null==e||0==t||0==i)}apply(e){const{doit:t}=this;return t&&(this.set_value(e),e.stroke()),t}values(){return{color:this.line_color.get_value(),alpha:this.line_alpha.get_value(),width:this.line_width.get_value(),join:this.line_join.get_value(),cap:this.line_cap.get_value(),dash:this.line_dash.get_value(),offset:this.line_dash_offset.get_value()}}set_value(e){const t=this.line_color.get_value(),i=this.line_alpha.get_value();e.strokeStyle=(0,o.color2css)(t,i),e.lineWidth=this.line_width.get_value(),e.lineJoin=this.line_join.get_value(),e.lineCap=this.line_cap.get_value(),e.setLineDash(r(this.line_dash.get_value())),e.lineDashOffset=this.line_dash_offset.get_value()}}i.Line=u,u.__name__=\"Line\";class c extends n.VisualUniforms{get doit(){const e=this.line_color.value,t=this.line_alpha.value,i=this.line_width.value;return!(0==e||0==t||0==i)}apply(e){const{doit:t}=this;return t&&(this.set_value(e),e.stroke()),t}values(){return{color:this.line_color.value,alpha:this.line_alpha.value,width:this.line_width.value,join:this.line_join.value,cap:this.line_cap.value,dash:this.line_dash.value,offset:this.line_dash_offset.value}}set_value(e){const t=this.line_color.value,i=this.line_alpha.value;e.strokeStyle=(0,o.color2css)(t,i),e.lineWidth=this.line_width.value,e.lineJoin=this.line_join.value,e.lineCap=this.line_cap.value,e.setLineDash(r(this.line_dash.value)),e.lineDashOffset=this.line_dash_offset.value}}i.LineScalar=c,c.__name__=\"LineScalar\";class d extends n.VisualUniforms{get doit(){const{line_color:e}=this;if(e.is_Scalar()&&0==e.value)return!1;const{line_alpha:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{line_width:i}=this;return!i.is_Scalar()||0!=i.value}v_doit(e){return 0!=this.line_color.get(e)&&(0!=this.line_alpha.get(e)&&0!=this.line_width.get(e))}apply(e,t){const i=this.v_doit(t);return i&&(this.set_vectorize(e,t),e.stroke()),i}values(e){return{color:this.line_color.get(e),alpha:this.line_alpha.get(e),width:this.line_width.get(e),join:this.line_join.get(e),cap:this.line_cap.get(e),dash:this.line_dash.get(e),offset:this.line_dash_offset.get(e)}}set_vectorize(e,t){const i=this.line_color.get(t),l=this.line_alpha.get(t),s=this.line_width.get(t),a=this.line_join.get(t),n=this.line_cap.get(t),h=this.line_dash.get(t),_=this.line_dash_offset.get(t);e.strokeStyle=(0,o.color2css)(i,l),e.lineWidth=s,e.lineJoin=a,e.lineCap=n,e.setLineDash(r(h)),e.lineDashOffset=_}}i.LineVector=d,d.__name__=\"LineVector\",u.prototype.type=\"line\",u.prototype.attrs=Object.keys(h.Line),c.prototype.type=\"line\",c.prototype.attrs=Object.keys(h.LineScalar),d.prototype.type=\"line\",d.prototype.attrs=Object.keys(h.LineVector)},\n", - " function _(t,s,o,i,r){i();class e{*[Symbol.iterator](){yield*this._props}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)}}update(){}}o.VisualProperties=e,e.__name__=\"VisualProperties\";class p{*[Symbol.iterator](){for(const t of this.attrs)yield this.obj.model.properties[this.prefix+t]}constructor(t,s=\"\"){this.obj=t,this.prefix=s;for(const o of this.attrs)Object.defineProperty(this,o,{get:()=>t[s+o]})}update(){}}o.VisualUniforms=p,p.__name__=\"VisualUniforms\"},\n", - " function _(l,e,a,t,r){t();const c=l(1),o=c.__importStar(l(17)),n=l(19),_=c.__importStar(l(20)),i=l(9);a.Line={line_color:[_.Nullable(_.Color),\"black\"],line_alpha:[_.Alpha,1],line_width:[_.Number,1],line_join:[n.LineJoin,\"bevel\"],line_cap:[n.LineCap,\"butt\"],line_dash:[_.Or(n.LineDash,_.Array(_.Number)),[]],line_dash_offset:[_.Number,0]},a.Fill={fill_color:[_.Nullable(_.Color),\"gray\"],fill_alpha:[_.Alpha,1]},a.Image={global_alpha:[_.Alpha,1]},a.Hatch={hatch_color:[_.Nullable(_.Color),\"black\"],hatch_alpha:[_.Alpha,1],hatch_scale:[_.Number,12],hatch_pattern:[_.Nullable(_.Or(n.HatchPatternType,_.String)),null],hatch_weight:[_.Number,1],hatch_extra:[_.Dict(_.AnyRef()),{}]},a.Text={text_color:[_.Nullable(_.Color),\"#444444\"],text_outline_color:[_.Nullable(_.Color),null],text_alpha:[_.Alpha,1],text_font:[o.Font,\"helvetica\"],text_font_size:[_.FontSize,\"16px\"],text_font_style:[n.FontStyle,\"normal\"],text_align:[n.TextAlign,\"left\"],text_baseline:[n.TextBaseline,\"bottom\"],text_line_height:[_.Number,1.2]},a.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]},a.FillScalar={fill_color:[o.ColorScalar,\"gray\"],fill_alpha:[o.NumberScalar,1]},a.ImageScalar={global_alpha:[o.NumberScalar,1]},a.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,{}]},a.TextScalar={text_color:[o.ColorScalar,\"#444444\"],text_outline_color:[o.ColorScalar,null],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]},a.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]},a.FillVector={fill_color:[o.ColorSpec,\"gray\"],fill_alpha:[o.NumberSpec,1]},a.ImageVector={global_alpha:[o.NumberSpec,1]},a.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,{}]},a.TextVector={text_color:[o.ColorSpec,\"#444444\"],text_outline_color:[o.ColorSpec,null],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]},a.attrs_of=function(l,e,a,t=!1){const r={};for(const c of(0,i.keys)(a)){const a=`${e}${c}`,o=l[a];r[t?a:c]=o}return r}},\n", - " function _(l,t,e,i,s){i();const a=l(1),o=l(77),r=a.__importStar(l(78)),_=l(21);class c extends o.VisualProperties{get doit(){const l=this.fill_color.get_value(),t=this.fill_alpha.get_value();return!(null==l||0==t)}apply(l,t){const{doit:e}=this;return e&&(this.set_value(l),l.fill(t)),e}values(){return{color:this.fill_color.get_value(),alpha:this.fill_alpha.get_value()}}set_value(l){const t=this.fill_color.get_value(),e=this.fill_alpha.get_value();l.fillStyle=(0,_.color2css)(t,e)}}e.Fill=c,c.__name__=\"Fill\";class h extends o.VisualUniforms{get doit(){const l=this.fill_color.value,t=this.fill_alpha.value;return!(0==l||0==t)}apply(l,t){const{doit:e}=this;return e&&(this.set_value(l),l.fill(t)),e}values(){return{color:this.fill_color.value,alpha:this.fill_alpha.value}}set_value(l){const t=this.fill_color.value,e=this.fill_alpha.value;l.fillStyle=(0,_.color2css)(t,e)}}e.FillScalar=h,h.__name__=\"FillScalar\";class u extends o.VisualUniforms{get doit(){const{fill_color:l}=this;if(l.is_Scalar()&&0==l.value)return!1;const{fill_alpha:t}=this;return!t.is_Scalar()||0!=t.value}v_doit(l){return 0!=this.fill_color.get(l)&&0!=this.fill_alpha.get(l)}apply(l,t,e){const i=this.v_doit(t);return i&&(this.set_vectorize(l,t),l.fill(e)),i}values(l){return{color:this.fill_color.get(l),alpha:this.fill_alpha.get(l)}}set_vectorize(l,t){const e=this.fill_color.get(t),i=this.fill_alpha.get(t);l.fillStyle=(0,_.color2css)(e,i)}}e.FillVector=u,u.__name__=\"FillVector\",c.prototype.type=\"fill\",c.prototype.attrs=Object.keys(r.Fill),h.prototype.type=\"fill\",h.prototype.attrs=Object.keys(r.FillScalar),u.prototype.type=\"fill\",u.prototype.attrs=Object.keys(r.FillVector)},\n", - " function _(t,e,l,s,o){s();const i=t(1),_=t(77),a=i.__importStar(t(78)),n=t(21),h=new Map;function r(t,e){const l=h.get(t);if(null==l){const l=new WeakSet([e]);h.set(t,l)}else{if(l.has(e))return;l.add(e)}const{fonts:s}=document;s.check(t)||s.load(t).then((()=>e.request_render()))}class u extends _.VisualProperties{get doit(){const t=this.text_color.get_value(),e=this.text_alpha.get_value();return!(null==t||0==e)}update(){if(!this.doit)return;r(this.font_value(),this.obj)}values(){return{color:this.text_color.get_value(),outline_color:this.text_outline_color.get_value(),alpha:this.text_alpha.get_value(),font:this.text_font.get_value(),font_size:this.text_font_size.get_value(),font_style:this.text_font_style.get_value(),align:this.text_align.get_value(),baseline:this.text_baseline.get_value(),line_height:this.text_line_height.get_value()}}set_value(t){const e=this.text_color.get_value(),l=this.text_outline_color.get_value(),s=this.text_alpha.get_value();t.fillStyle=(0,n.color2css)(e,s),t.strokeStyle=(0,n.color2css)(l,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()}`}}l.Text=u,u.__name__=\"Text\";class x extends _.VisualUniforms{get doit(){const t=this.text_color.value,e=this.text_alpha.value;return!(0==t||0==e)}update(){if(!this.doit)return;r(this.font_value(),this.obj)}values(){return{color:this.text_color.value,outline_color:this.text_outline_color.value,alpha:this.text_alpha.value,font:this.text_font.value,font_size:this.text_font_size.value,font_style:this.text_font_style.value,align:this.text_align.value,baseline:this.text_baseline.value,line_height:this.text_line_height.value}}set_value(t){const e=this.text_color.value,l=this.text_alpha.value,s=this.text_outline_color.value,o=this.font_value(),i=this.text_align.value,_=this.text_baseline.value;t.fillStyle=(0,n.color2css)(e,l),t.strokeStyle=(0,n.color2css)(s,l),t.font=o,t.textAlign=i,t.textBaseline=_}font_value(){return`${this.text_font_style.value} ${this.text_font_size.value} ${this.text_font.value}`}}l.TextScalar=x,x.__name__=\"TextScalar\";class c extends _.VisualUniforms{_assert_font(t){r(this.font_value(t),this.obj)}values(t){return this._assert_font(t),{color:this.text_color.get(t),outline_color:this.text_outline_color.get(t),alpha:this.text_alpha.get(t),font:this.text_font.get(t),font_size:this.text_font_size.get(t),font_style:this.text_font_style.get(t),align:this.text_align.get(t),baseline:this.text_baseline.get(t),line_height:this.text_line_height.get(t)}}get doit(){const{text_color:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{text_alpha:e}=this;return!e.is_Scalar()||0!=e.value}v_doit(t){return 0!=this.text_color.get(t)&&0!=this.text_alpha.get(t)}apply(t,e){const l=this.v_doit(e);return l&&this.set_vectorize(t,e),l}set_vectorize(t,e){this._assert_font(e);const l=this.text_color.get(e),s=this.text_outline_color.get(e),o=this.text_alpha.get(e),i=this.font_value(e),_=this.text_align.get(e),a=this.text_baseline.get(e);t.fillStyle=(0,n.color2css)(l,o),t.strokeStyle=(0,n.color2css)(s,o),t.font=i,t.textAlign=_,t.textBaseline=a}font_value(t){return`${this.text_font_style.get(t)} ${this.text_font_size.get(t)} ${this.text_font.get(t)}`}}l.TextVector=c,c.__name__=\"TextVector\",u.prototype.type=\"text\",u.prototype.attrs=Object.keys(a.Text),x.prototype.type=\"text\",x.prototype.attrs=Object.keys(a.TextScalar),c.prototype.type=\"text\",c.prototype.attrs=Object.keys(a.TextVector)},\n", - " function _(t,e,a,r,h){r();const i=t(1),s=t(77),n=t(82),c=i.__importStar(t(17)),_=i.__importStar(t(78));class l extends s.VisualProperties{constructor(){super(...arguments),this._update_iteration=0}update(){if(this._update_iteration++,this._hatch_image=null,!this.doit)return;const t=this.hatch_color.get_value(),e=this.hatch_alpha.get_value(),a=this.hatch_scale.get_value(),r=this.hatch_pattern.get_value(),h=this.hatch_weight.get_value(),i=t=>{this._hatch_image=t},s=this.hatch_extra.get_value()[r];if(null!=s){const r=s.get_pattern(t,e,a,h);if(r instanceof Promise){const{_update_iteration:t}=this;r.then((e=>{this._update_iteration==t&&(i(e),this.obj.request_render())}))}else i(r)}else{const s=this.obj.canvas.create_layer(),c=(0,n.get_pattern)(s,r,t,e,a,h);i(c)}}get doit(){const t=this.hatch_color.get_value(),e=this.hatch_alpha.get_value(),a=this.hatch_pattern.get_value();return!(null==t||0==e||\" \"==a||\"blank\"==a||null==a)}apply(t,e){const{doit:a}=this;return a&&(this.set_value(t),t.layer.undo_transform((()=>t.fill(e)))),a}set_value(t){const e=this.pattern(t);t.fillStyle=null!=e?e:\"transparent\"}pattern(t){const e=this._hatch_image;return null==e?null:t.createPattern(e,this.repetition())}repetition(){const t=this.hatch_pattern.get_value(),e=this.hatch_extra.get_value()[t];if(null==e)return\"repeat\";switch(e.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.Hatch=l,l.__name__=\"Hatch\";class o extends s.VisualUniforms{constructor(){super(...arguments),this._static_doit=!1,this._update_iteration=0}_compute_static_doit(){const t=this.hatch_color.value,e=this.hatch_alpha.value,a=this.hatch_pattern.value;return!(null==t||0==e||\" \"==a||\"blank\"==a||null==a)}update(){this._update_iteration++;const t=this.hatch_color.length;if(this._hatch_image=new c.UniformScalar(null,t),this._static_doit=this._compute_static_doit(),!this._static_doit)return;const e=this.hatch_color.value,a=this.hatch_alpha.value,r=this.hatch_scale.value,h=this.hatch_pattern.value,i=this.hatch_weight.value,s=e=>{this._hatch_image=new c.UniformScalar(e,t)},_=this.hatch_extra.value[h];if(null!=_){const t=_.get_pattern(e,a,r,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(),c=(0,n.get_pattern)(t,h,e,a,r,i);s(c)}}get doit(){return this._static_doit}apply(t,e){const{doit:a}=this;return a&&(this.set_value(t),t.layer.undo_transform((()=>t.fill(e)))),a}set_value(t){var e;t.fillStyle=null!==(e=this.pattern(t))&&void 0!==e?e:\"transparent\"}pattern(t){const e=this._hatch_image.value;return null==e?null:t.createPattern(e,this.repetition())}repetition(){const t=this.hatch_pattern.value,e=this.hatch_extra.value[t];if(null==e)return\"repeat\";switch(e.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.HatchScalar=o,o.__name__=\"HatchScalar\";class u extends s.VisualUniforms{constructor(){super(...arguments),this._static_doit=!1,this._update_iteration=0}_compute_static_doit(){const{hatch_color:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{hatch_alpha:e}=this;if(e.is_Scalar()&&0==e.value)return!1;const{hatch_pattern:a}=this;if(a.is_Scalar()){const t=a.value;if(\" \"==t||\"blank\"==t||null==t)return!1}return!0}update(){this._update_iteration++;const t=this.hatch_color.length;if(this._hatch_image=new c.UniformScalar(null,t),this._static_doit=this._compute_static_doit(),!this._static_doit)return;const e=(t,e,a,r,h,i)=>{const s=this.hatch_extra.value[t];if(null!=s){const t=s.get_pattern(e,a,r,h);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(),c=(0,n.get_pattern)(s,t,e,a,r,h);i(c)}};if(this.hatch_color.is_Scalar()&&this.hatch_alpha.is_Scalar()&&this.hatch_scale.is_Scalar()&&this.hatch_pattern.is_Scalar()&&this.hatch_weight.is_Scalar()){const a=this.hatch_color.value,r=this.hatch_alpha.value,h=this.hatch_scale.value;e(this.hatch_pattern.value,a,r,h,this.hatch_weight.value,(e=>{this._hatch_image=new c.UniformScalar(e,t)}))}else{const a=new Array(t);a.fill(null),this._hatch_image=new c.UniformVector(a);for(let r=0;r{a[r]=t}))}}}get doit(){return this._static_doit}v_doit(t){if(!this.doit)return!1;if(0==this.hatch_color.get(t))return!1;if(0==this.hatch_alpha.get(t))return!1;const e=this.hatch_pattern.get(t);return\" \"!=e&&\"blank\"!=e&&null!=e}apply(t,e,a){const r=this.v_doit(e);return r&&(this.set_vectorize(t,e),t.layer.undo_transform((()=>t.fill(a)))),r}set_vectorize(t,e){var a;t.fillStyle=null!==(a=this.pattern(t,e))&&void 0!==a?a:\"transparent\"}pattern(t,e){const a=this._hatch_image.get(e);return null==a?null:t.createPattern(a,this.repetition(e))}repetition(t){const e=this.hatch_pattern.get(t),a=this.hatch_extra.value[e];if(null==a)return\"repeat\";switch(a.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.HatchVector=u,u.__name__=\"HatchVector\",l.prototype.type=\"hatch\",l.prototype.attrs=Object.keys(_.Hatch),o.prototype.type=\"hatch\",o.prototype.attrs=Object.keys(_.HatchScalar),u.prototype.type=\"hatch\",u.prototype.attrs=Object.keys(_.HatchVector)},\n", - " function _(e,o,a,r,s){r();const i=e(18),n=e(21);function l(e,o,a){e.moveTo(0,a+.5),e.lineTo(o,a+.5),e.stroke()}function t(e,o,a){e.moveTo(a+.5,0),e.lineTo(a+.5,o),e.stroke()}function c(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,r,s,k,_){return e.resize(k,k),e.prepare(),function(e,o,r,s,k,_){var T;const h=k,v=h/2,d=v/2,b=(0,n.color2css)(r,s);switch(e.strokeStyle=b,e.fillStyle=b,e.lineCap=\"square\",e.lineWidth=_,null!==(T=a.hatch_aliases[o])&&void 0!==T?T: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,h,v);break;case\"vertical_line\":t(e,h,v);break;case\"cross\":l(e,h,v),t(e,h,v);break;case\"horizontal_dash\":l(e,v,v);break;case\"vertical_dash\":t(e,v,v);break;case\"spiral\":{const o=h/30;e.moveTo(v,v);for(let a=0;a<360;a++){const r=.1*a,s=v+o*r*Math.cos(r),i=v+o*r*Math.sin(r);e.lineTo(s,i)}e.stroke();break}case\"right_diagonal_line\":e.moveTo(.5-d,h),e.lineTo(d+.5,0),e.stroke(),e.moveTo(d+.5,h),e.lineTo(3*d+.5,0),e.stroke(),e.moveTo(3*d+.5,h),e.lineTo(5*d+.5,0),e.stroke();break;case\"left_diagonal_line\":e.moveTo(d+.5,h),e.lineTo(.5-d,0),e.stroke(),e.moveTo(3*d+.5,h),e.lineTo(d+.5,0),e.stroke(),e.moveTo(5*d+.5,h),e.lineTo(3*d+.5,0),e.stroke();break;case\"diagonal_cross\":c(e,h);break;case\"right_diagonal_dash\":e.moveTo(d+.5,3*d+.5),e.lineTo(3*d+.5,d+.5),e.stroke();break;case\"left_diagonal_dash\":e.moveTo(d+.5,d+.5),e.lineTo(3*d+.5,3*d+.5),e.stroke();break;case\"horizontal_wave\":e.moveTo(0,d),e.lineTo(v,3*d),e.lineTo(h,d),e.stroke();break;case\"vertical_wave\":e.moveTo(d,0),e.lineTo(3*d,v),e.lineTo(d,h),e.stroke();break;case\"criss_cross\":c(e,h),l(e,h,v),t(e,h,v);break;default:i.logger.warn(`unknown hatch pattern: ${o}`)}}(e.ctx,o,r,s,k,_),e.canvas}},\n", - " function _(a,t,e,l,s){l();const o=a(1),r=a(77),p=o.__importStar(a(78));class _ extends r.VisualProperties{get doit(){return!(0==this.global_alpha.get_value())}apply(a){const{doit:t}=this;return t&&this.set_value(a),t}values(){return{global_alpha:this.global_alpha.get_value()}}set_value(a){const t=this.global_alpha.get_value();a.globalAlpha=t}}e.Image=_,_.__name__=\"Image\";class i extends r.VisualUniforms{get doit(){return!(0==this.global_alpha.value)}apply(a){const{doit:t}=this;return t&&this.set_value(a),t}values(){return{global_alpha:this.global_alpha.value}}set_value(a){const t=this.global_alpha.value;a.globalAlpha=t}}e.ImageScalar=i,i.__name__=\"ImageScalar\";class g extends r.VisualUniforms{get doit(){const{global_alpha:a}=this;return!a.is_Scalar()||0!=a.value}v_doit(a){return 0!=this.global_alpha.get(a)}apply(a,t){const e=this.v_doit(t);return e&&this.set_vectorize(a,t),e}values(a){return{alpha:this.global_alpha.get(a)}}set_vectorize(a,t){const e=this.global_alpha.get(t);a.globalAlpha=e}}e.ImageVector=g,g.__name__=\"ImageVector\",_.prototype.type=\"image\",_.prototype.attrs=Object.keys(p.Image),i.prototype.type=\"image\",i.prototype.attrs=Object.keys(p.ImageScalar),g.prototype.type=\"image\",g.prototype.attrs=Object.keys(p.ImageVector)},\n", - " function _(e,t,s,a,r){var c,n;a();const _=e(13),o=e(50),i=e(85),l=e(89),u=e(91),g=e(92),h=e(87),p=e(93),m=e(96);class x{constructor(e,t){this.x_scale=e,this.y_scale=t,this.x_source=this.x_scale.source_range,this.y_source=this.y_scale.source_range,this.ranges=[this.x_source,this.y_source],this.scales=[this.x_scale,this.y_scale]}map_to_screen(e,t){return[this.x_scale.v_compute(e),this.y_scale.v_compute(t)]}map_from_screen(e,t){return[this.x_scale.v_invert(e),this.y_scale.v_invert(t)]}}s.CoordinateTransform=x,x.__name__=\"CoordinateTransform\";class y extends o.Model{constructor(e){super(e)}get x_ranges(){return new Map([[\"default\",this.x_source]])}get y_ranges(){return new Map([[\"default\",this.y_source]])}_get_scale(e,t,s){if(e instanceof m.FactorRange!=t instanceof g.CategoricalScale)throw new Error(`Range ${e.type} is incompatible is Scale ${t.type}`);t instanceof u.LogScale&&e instanceof p.DataRange1d&&(e.scale_hint=\"log\");const a=t.clone();return a.setv({source_range:e,target_range:s}),a}get_transform(e){const{x_source:t,x_scale:s,x_target:a}=this,r=this._get_scale(t,s,a),{y_source:c,y_scale:n,y_target:_}=this,o=this._get_scale(c,n,_),i=new v({source_scale:r,source_range:r.source_range,target_scale:e.x_scale,target_range:e.x_target}),l=new v({source_scale:o,source_range:o.source_range,target_scale:e.y_scale,target_range:e.y_target});return new x(i,l)}}s.CoordinateMapping=y,c=y,y.__name__=\"CoordinateMapping\",c.define((({Ref:e})=>({x_source:[e(h.Range),()=>new p.DataRange1d],y_source:[e(h.Range),()=>new p.DataRange1d],x_scale:[e(i.Scale),()=>new l.LinearScale],y_scale:[e(i.Scale),()=>new l.LinearScale],x_target:[e(h.Range)],y_target:[e(h.Range)]})));class v extends i.Scale{constructor(e){super(e)}get s_compute(){const e=this.source_scale.s_compute,t=this.target_scale.s_compute;return s=>t(e(s))}get s_invert(){const e=this.source_scale.s_invert,t=this.target_scale.s_invert;return s=>e(t(s))}compute(e){return this.s_compute(e)}v_compute(e){const{s_compute:t}=this;return(0,_.map)(e,t)}invert(e){return this.s_invert(e)}v_invert(e){const{s_invert:t}=this;return(0,_.map)(e,t)}}s.CompositeScale=v,n=v,v.__name__=\"CompositeScale\",n.internal((({Ref:e})=>({source_scale:[e(i.Scale)],target_scale:[e(i.Scale)]})))},\n", - " function _(e,t,r,n,s){var _;n();const a=e(86),c=e(87),o=e(88),i=e(23);class u extends a.Transform{constructor(e){super(e)}compute(e){return this.s_compute(e)}v_compute(e){const t=new i.ScreenArray(e.length),{s_compute:r}=this;for(let n=0;n({source_range:[e(c.Range)],target_range:[e(o.Range1d)]})))},\n", - " function _(n,s,o,r,c){r();const e=n(50);class t extends e.Model{constructor(n){super(n)}}o.Transform=t,t.__name__=\"Transform\"},\n", - " function _(t,e,n,i,s){var a;i();const r=t(50);class l extends r.Model{constructor(t){super(t),this.have_updated_interactively=!1,this.plots=new Set}get is_reversed(){return this.start>this.end}get is_valid(){return isFinite(this.min)&&isFinite(this.max)}get span(){return Math.abs(this.end-this.start)}}n.Range=l,a=l,l.__name__=\"Range\",a.define((({Number:t,Tuple:e,Or:n,Auto:i,Nullable:s})=>({bounds:[s(n(e(s(t),s(t)),i)),null],min_interval:[s(t),null],max_interval:[s(t),null]})))},\n", - " function _(t,e,s,n,r){var a;n();const i=t(87);class _ extends i.Range{constructor(t){super(t)}_set_auto_bounds(){if(\"auto\"==this.bounds){const t=Math.min(this._reset_start,this._reset_end),e=Math.max(this._reset_start,this._reset_end);this.setv({bounds:[t,e]},{silent:!0})}}initialize(){super.initialize(),this._set_auto_bounds()}get min(){return Math.min(this.start,this.end)}get max(){return Math.max(this.start,this.end)}reset(){this._set_auto_bounds();const{_reset_start:t,_reset_end:e}=this;this.start!=t||this.end!=e?this.setv({start:t,end:e}):this.change.emit()}map(t){return new _({start:t(this.start),end:t(this.end)})}widen(t){let{start:e,end:s}=this;return this.is_reversed?(e+=t,s-=t):(e-=t,s+=t),new _({start:e,end:s})}}s.Range1d=_,a=_,_.__name__=\"Range1d\",a.define((({Number:t,Nullable:e})=>({start:[t,0],end:[t,1],reset_start:[e(t),null,{on_update(t,e){e._reset_start=null!=t?t:e.start}}],reset_end:[e(t),null,{on_update(t,e){e._reset_end=null!=t?t:e.end}}]})))},\n", - " function _(t,e,n,r,s){r();const a=t(90);class _ extends a.ContinuousScale{constructor(t){super(t)}get s_compute(){const[t,e]=this._linear_compute_state();return n=>t*n+e}get s_invert(){const[t,e]=this._linear_compute_state();return n=>(n-e)/t}_linear_compute_state(){const t=this.source_range.start,e=this.source_range.end,n=this.target_range.start,r=(this.target_range.end-n)/(e-t);return[r,-r*t+n]}}n.LinearScale=_,_.__name__=\"LinearScale\"},\n", - " function _(n,c,o,s,e){s();const t=n(85);class u extends t.Scale{constructor(n){super(n)}}o.ContinuousScale=u,u.__name__=\"ContinuousScale\"},\n", - " function _(t,e,s,a,r){a();const o=t(90);class n extends o.ContinuousScale{constructor(t){super(t)}get s_compute(){const[t,e,s,a]=this._compute_state();return r=>{if(0==s)return 0;{const o=(Math.log(r)-a)/s;return isFinite(o)?o*t+e:NaN}}}get s_invert(){const[t,e,s,a]=this._compute_state();return r=>{const o=(r-e)/t;return Math.exp(s*o+a)}}_get_safe_factor(t,e){let s=t<0?0:t,a=e<0?0:e;if(s==a)if(0==s)[s,a]=[1,10];else{const t=Math.log10(s);s=10**Math.floor(t),a=Math.ceil(t)!=Math.floor(t)?10**Math.ceil(t):10**(Math.ceil(t)+1)}return[s,a]}_compute_state(){const t=this.source_range.start,e=this.source_range.end,s=this.target_range.start,a=this.target_range.end-s,[r,o]=this._get_safe_factor(t,e);let n,c;0==r?(n=Math.log(o),c=0):(n=Math.log(o/r),c=Math.log(r));return[a,s,n,c]}}s.LogScale=n,n.__name__=\"LogScale\"},\n", - " function _(t,e,c,a,s){a();const n=t(85),r=t(89),{_linear_compute_state:o}=r.LinearScale.prototype;class l extends n.Scale{constructor(t){super(t)}get s_compute(){const[t,e]=o.call(this),c=this.source_range;return a=>t*c.synthetic(a)+e}get s_invert(){const[t,e]=o.call(this);return c=>(c-e)/t}}c.CategoricalScale=l,l.__name__=\"CategoricalScale\"},\n", - " function _(t,i,n,e,a){var s;e();const l=t(1),_=t(94),o=t(19),r=t(32),d=t(18),h=l.__importStar(t(57)),u=t(95);n.auto_ranged=Symbol(\"auto_ranged\"),n.is_auto_ranged=function(t){return n.auto_ranged in t};class g extends _.DataRange{constructor(t){super(t),this.have_updated_interactively=!1}initialize(){super.initialize(),this._initial_start=isNaN(this.start)?null:this.start,this._initial_end=isNaN(this.end)?null: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}=this,i=(0,r.flat_map)(this.plots,(t=>t.auto_ranged_renderers.map((t=>t.model))));return(0,u.compute_renderers)(0==t.length?\"auto\":t,[...i])}_compute_plot_bounds(t,i){let n=h.empty();for(const e of t){const t=i.get(e);null==t||!e.visible&&this.only_visible||(n=h.union(n,t))}return n}adjust_bounds_for_aspect(t,i){const n=h.empty();let e=t.x1-t.x0;e<=0&&(e=1);let a=t.y1-t.y0;a<=0&&(a=1);const s=.5*(t.x1+t.x0),l=.5*(t.y1+t.y0);return el&&(\"start\"==this.follow?a=e+s*l:\"end\"==this.follow&&(e=a-s*l)),[e,a]}update(t,i,n,e){if(this.have_updated_interactively)return;const a=this.computed_renderers();let s=this._compute_plot_bounds(a,t);null!=e&&(s=this.adjust_bounds_for_aspect(s,e)),this._plot_bounds.set(n,s);const[l,_]=this._compute_min_max(this._plot_bounds.entries(),i);let[o,r]=this._compute_range(l,_);null!=this._initial_start&&(\"log\"==this.scale_hint?this._initial_start>0&&(o=this._initial_start):o=this._initial_start),null!=this._initial_end&&(\"log\"==this.scale_hint?this._initial_end>0&&(r=this._initial_end):r=this._initial_end);let d=!1;\"auto\"==this.bounds&&(this.setv({bounds:[o,r]},{silent:!0}),d=!0);const[h,u]=[this.start,this.end];if(o!=h||r!=u){const t={};o!=h&&(t.start=o),r!=u&&(t.end=r),this.setv(t),d=!1}d&&this.change.emit()}reset(){this.have_updated_interactively=!1,this.setv({range_padding:this._initial_range_padding,range_padding_units:this._initial_range_padding_units,follow:this._initial_follow,follow_interval:this._initial_follow_interval,default_span:this._initial_default_span},{silent:!0}),this.change.emit()}}n.DataRange1d=g,s=g,g.__name__=\"DataRange1d\",s.define((({Boolean:t,Number:i,Nullable:n})=>({start:[i,NaN],end:[i,NaN],range_padding:[i,.1],range_padding_units:[o.PaddingUnits,\"percent\"],flipped:[t,!1],follow:[n(o.StartEnd),null],follow_interval:[n(i),null],default_span:[i,2],only_visible:[t,!1]}))),s.internal((({Enum:t})=>({scale_hint:[t(\"log\",\"auto\"),\"auto\"]})))},\n", - " function _(e,n,a,r,t){var s;r();const c=e(87);class o extends c.Range{constructor(e){super(e)}}a.DataRange=o,s=o,o.__name__=\"DataRange\",s.define((({Array:e,AnyRef:n,Or:a,Auto:r})=>({renderers:[a(e(n()),r),[]]})))},\n", - " function _(n,u,e,r,t){r(),e.compute_renderers=function(n,u){return\"auto\"==n?u:null!=n?n:[]}},\n", - " function _(t,n,e,i,s){var r;i();const a=t(1),o=t(87),g=t(19),p=a.__importStar(t(17)),c=t(20),l=t(23),u=t(10),h=t(8),d=t(12);function _(t,n,e=0){const i=new Map;for(let s=0;sa.get(t).value)));r.set(t,{value:c/s,mapping:a}),o+=s+n+p}return[r,(a.size-1)*n+g]}function m(t,n,e,i,s=0){var r;const a=new Map,o=new Map;for(const[n,e,i]of t){const t=null!==(r=o.get(n))&&void 0!==r?r:[];o.set(n,[...t,[e,i]])}let g=s,p=0;for(const[t,s]of o){const r=s.length,[o,c]=f(s,e,i,g);p+=c;const l=(0,u.sum)(s.map((([t])=>o.get(t).value)));a.set(t,{value:l/r,mapping:o}),g+=r+n+c}return[a,(o.size-1)*n+p]}e.Factor=(0,c.Or)(c.String,(0,c.Tuple)(c.String,c.String),(0,c.Tuple)(c.String,c.String,c.String)),e.FactorSeq=(0,c.Or)((0,c.Array)(c.String),(0,c.Array)((0,c.Tuple)(c.String,c.String)),(0,c.Array)((0,c.Tuple)(c.String,c.String,c.String))),e.map_one_level=_,e.map_two_levels=f,e.map_three_levels=m;class v extends o.Range{constructor(t){super(t)}get min(){return this.start}get max(){return this.end}initialize(){super.initialize(),this._init(!0)}connect_signals(){super.connect_signals(),this.connect(this.properties.factors.change,(()=>this.reset())),this.connect(this.properties.factor_padding.change,(()=>this.reset())),this.connect(this.properties.group_padding.change,(()=>this.reset())),this.connect(this.properties.subgroup_padding.change,(()=>this.reset())),this.connect(this.properties.range_padding.change,(()=>this.reset())),this.connect(this.properties.range_padding_units.change,(()=>this.reset()))}reset(){this._init(!1),this.change.emit()}_lookup(t){switch(t.length){case 1:{const[n]=t,e=this._mapping.get(n);return null!=e?e.value:NaN}case 2:{const[n,e]=t,i=this._mapping.get(n);if(null!=i){const t=i.mapping.get(e);if(null!=t)return t.value}return NaN}case 3:{const[n,e,i]=t,s=this._mapping.get(n);if(null!=s){const t=s.mapping.get(e);if(null!=t){const n=t.mapping.get(i);if(null!=n)return n.value}}return NaN}default:(0,d.unreachable)()}}synthetic(t){if((0,h.isNumber)(t))return t;if((0,h.isString)(t))return this._lookup([t]);let n=0;const e=t[t.length-1];return(0,h.isNumber)(e)&&(n=e,t=t.slice(0,-1)),this._lookup(t)+n}v_synthetic(t){const n=t.length,e=new l.ScreenArray(n);for(let i=0;i{if((0,u.every)(this.factors,h.isString)){const t=this.factors,[n,e]=_(t,this.factor_padding);return{levels:1,mapping:n,tops:null,mids:null,inside_padding:e}}if((0,u.every)(this.factors,(t=>(0,h.isArray)(t)&&2==t.length&&(0,h.isString)(t[0])&&(0,h.isString)(t[1])))){const t=this.factors,[n,e]=f(t,this.group_padding,this.factor_padding),i=[...n.keys()];return{levels:2,mapping:n,tops:i,mids:null,inside_padding:e}}if((0,u.every)(this.factors,(t=>(0,h.isArray)(t)&&3==t.length&&(0,h.isString)(t[0])&&(0,h.isString)(t[1])&&(0,h.isString)(t[2])))){const t=this.factors,[n,e]=m(t,this.group_padding,this.subgroup_padding,this.factor_padding),i=[...n.keys()],s=[];for(const[t,e]of n)for(const n of e.mapping.keys())s.push([t,n]);return{levels:3,mapping:n,tops:i,mids:s,inside_padding:e}}(0,d.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=v,r=v,v.__name__=\"FactorRange\",r.define((({Number:t})=>({factors:[e.FactorSeq,[]],factor_padding:[t,0],subgroup_padding:[t,.8],group_padding:[t,1.4],range_padding:[t,0],range_padding_units:[g.PaddingUnits,\"percent\"],start:[t,p.unset,{readonly:!0}],end:[t,p.unset,{readonly:!0}]}))),r.internal((({Number:t,String:n,Array:e,Tuple:i,Nullable:s})=>({levels:[t],mids:[s(e(i(n,n))),null],tops:[s(e(n)),null]})))},\n", - " function _(t,e,s,a,n){var r;a();const i=t(1),_=t(98),o=t(139),l=t(78),d=t(19),c=t(23),h=t(59),u=t(23),v=i.__importStar(t(17)),p=t(11);class y extends _.DataAnnotationView{*children(){yield*super.children();const{start:t,end:e}=this;null!=t&&(yield t),null!=e&&(yield e)}async lazy_initialize(){await super.lazy_initialize();const{start:t,end:e}=this.model;null!=t&&(this.start=await(0,h.build_view)(t,{parent:this})),null!=e&&(this.end=await(0,h.build_view)(e,{parent:this}))}set_data(t){var e,s;super.set_data(t);const a=u.Indices.all_set(this._x_start.length);null===(e=this.start)||void 0===e||e.set_data(t,a),null===(s=this.end)||void 0===s||s.set_data(t,a)}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,[e,s]=(()=>{switch(this.model.start_units){case\"canvas\":return[new c.ScreenArray(this._x_start),new c.ScreenArray(this._y_start)];case\"screen\":return[t.bbox.xview.v_compute(this._x_start),t.bbox.yview.v_compute(this._y_start)];case\"data\":return[this.coordinates.x_scale.v_compute(this._x_start),this.coordinates.y_scale.v_compute(this._y_start)]}})(),[a,n]=(()=>{switch(this.model.end_units){case\"canvas\":return[new c.ScreenArray(this._x_end),new c.ScreenArray(this._y_end)];case\"screen\":return[t.bbox.xview.v_compute(this._x_end),t.bbox.yview.v_compute(this._y_end)];case\"data\":return[this.coordinates.x_scale.v_compute(this._x_end),this.coordinates.y_scale.v_compute(this._y_end)]}})();this._sx_start=e,this._sy_start=s,this._sx_end=a,this._sy_end=n;const r=e.length,i=this._angles=new c.ScreenArray(r);for(let t=0;t({x_start:[v.XCoordinateSpec,{field:\"x_start\"}],y_start:[v.YCoordinateSpec,{field:\"y_start\"}],start_units:[d.CoordinateUnits,\"data\"],start:[e(t(o.ArrowHead)),null],x_end:[v.XCoordinateSpec,{field:\"x_end\"}],y_end:[v.YCoordinateSpec,{field:\"y_end\"}],end_units:[d.CoordinateUnits,\"data\"],end:[e(t(o.ArrowHead)),()=>new o.OpenHead]})))},\n", - " function _(t,e,n,s,a){var o;s();const i=t(1),c=t(73),r=t(99),_=t(104),l=t(105),h=i.__importStar(t(17));class d extends c.AnnotationView{constructor(){super(...arguments),this._initial_set_data=!1}connect_signals(){super.connect_signals();const t=()=>{this.set_data(this.model.source),this._rerender()};this.connect(this.model.change,t),this.connect(this.model.source.streaming,t),this.connect(this.model.source.patching,t),this.connect(this.model.source.change,t)}_rerender(){this.request_render()}set_data(t){const e=this;for(const n of this.model)if(n instanceof h.VectorSpec||n instanceof h.ScalarSpec)if(n instanceof h.BaseCoordinateSpec){const s=n.array(t);e[`_${n.attr}`]=s}else{const s=n.uniform(t);e[`${n.attr}`]=s}this.plot_model.use_map&&(null!=e._x&&l.inplace.project_xy(e._x,e._y),null!=e._xs&&l.inplace.project_xsys(e._xs,e._ys));for(const t of this.visuals)t.update()}_render(){this._initial_set_data||(this.set_data(this.model.source),this._initial_set_data=!0),this.map_data(),this.paint(this.layer.ctx)}}n.DataAnnotationView=d,d.__name__=\"DataAnnotationView\";class u extends c.Annotation{constructor(t){super(t)}}n.DataAnnotation=u,o=u,u.__name__=\"DataAnnotation\",o.define((({Ref:t})=>({source:[t(r.ColumnarDataSource),()=>new _.ColumnDataSource]})))},\n", - " function _(t,e,n,a,s){var r;a();const i=t(18),l=t(100),o=t(15),c=t(10),u=t(29),h=t(9),g=t(8),d=t(102),_=t(101),f=t(103);class m extends f.DataSource{get_array(t){let e=this.data[t];return null==e?this.data[t]=e=[]:(0,g.isArray)(e)||(this.data[t]=e=Array.from(e)),e}constructor(t){super(t),this.selection_manager=new l.SelectionManager(this)}initialize(){super.initialize(),this._select=new o.Signal0(this,\"select\"),this.inspect=new o.Signal(this,\"inspect\")}get_column(t){return t in this.data?this.data[t]:null}columns(){return(0,h.keys)(this.data)}get_length(t=!0){const e=(0,c.uniq)((0,h.values)(this.data).map((t=>(0,u.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 i.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,r=m,m.__name__=\"ColumnarDataSource\",r.define((({Ref:t})=>({selection_policy:[t(d.SelectionPolicy),()=>new d.UnionRenderers]}))),r.internal((({AnyRef:t})=>({inspected:[t(),()=>new _.Selection]})))},\n", - " function _(e,t,o,s,c){s();const n=e(101);function i(e){return\"GlyphRenderer\"==e.model.type}function l(e){return\"GraphRenderer\"==e.model.type}class r{constructor(e){this.inspectors=new Map,this.source=e}select(e,t,o,s=\"replace\"){const c=[],n=[];for(const t of e)i(t)?c.push(t):l(t)&&n.push(t);let r=!1;for(const e of n){const c=e.model.selection_policy.hit_test(t,e);r=r||e.model.selection_policy.do_selection(c,e.model,o,s)}if(c.length>0){const e=this.source.selection_policy.hit_test(t,c);r=r||this.source.selection_policy.do_selection(e,this.source,o,s)}return r}inspect(e,t){let o=!1;if(i(e)){const s=e.hit_test(t);if(null!=s){o=!s.is_empty();const c=this.get_or_create_inspector(e.model);c.update(s,!0,\"replace\"),this.source.setv({inspected:c},{silent:!0}),this.source.inspect.emit([e.model,{geometry:t}])}}else if(l(e)){const s=e.model.inspection_policy.hit_test(t,e);o=e.model.inspection_policy.do_inspection(s,t,e,!1,\"replace\")}return o}clear(e){this.source.selected.clear(),null!=e&&this.get_or_create_inspector(e.model).clear()}get_or_create_inspector(e){let t=this.inspectors.get(e);return null==t&&(t=new n.Selection,this.inspectors.set(e,t)),t}}o.SelectionManager=r,r.__name__=\"SelectionManager\"},\n", - " function _(i,e,s,t,n){var c;t();const l=i(50),d=i(10),h=i(9),_=i(20),u=i(13);s.OpaqueIndices=(0,_.Arrayable)(_.Int);class a extends l.Model{constructor(i){super(i)}get_view(){return this.view}get selected_glyph(){return this.selected_glyphs.length>0?this.selected_glyphs[0]:null}add_to_selected_glyphs(i){this.selected_glyphs.push(i)}update(i,e=!0,s=\"replace\"){switch(s){case\"replace\":this.indices=i.indices,this.line_indices=i.line_indices,this.multiline_indices=i.multiline_indices,this.image_indices=i.image_indices,this.view=i.view,this.selected_glyphs=i.selected_glyphs;break;case\"append\":this.update_through_union(i);break;case\"intersect\":this.update_through_intersection(i);break;case\"subtract\":this.update_through_subtraction(i)}}clear(){this.indices=[],this.line_indices=[],this.multiline_indices={},this.image_indices=[],this.view=null,this.selected_glyphs=[]}map(i){return new a(Object.assign(Object.assign({},this.attributes),{indices:(0,u.map)(this.indices,i),multiline_indices:(0,h.to_object)((0,h.entries)(this.multiline_indices).map((([e,s])=>[i(Number(e)),s]))),image_indices:this.image_indices.map((e=>Object.assign(Object.assign({},e),{index:i(e.index)})))}))}is_empty(){return 0==this.indices.length&&0==this.line_indices.length&&0==this.image_indices.length}update_through_union(i){this.indices=(0,d.union)(this.indices,i.indices),this.selected_glyphs=(0,d.union)(i.selected_glyphs,this.selected_glyphs),this.line_indices=(0,d.union)(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=(0,h.merge)(i.multiline_indices,this.multiline_indices)}update_through_intersection(i){this.indices=(0,d.intersection)(this.indices,i.indices),this.selected_glyphs=(0,d.union)(i.selected_glyphs,this.selected_glyphs),this.line_indices=(0,d.union)(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=(0,h.merge)(i.multiline_indices,this.multiline_indices)}update_through_subtraction(i){this.indices=(0,d.difference)(this.indices,i.indices),this.selected_glyphs=(0,d.union)(i.selected_glyphs,this.selected_glyphs),this.line_indices=(0,d.union)(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=(0,h.merge)(i.multiline_indices,this.multiline_indices)}}s.Selection=a,c=a,a.__name__=\"Selection\",c.define((({Int:i,Array:e,Dict:t,Struct:n})=>({indices:[s.OpaqueIndices,[]],line_indices:[s.OpaqueIndices,[]],multiline_indices:[t(s.OpaqueIndices),{}],image_indices:[e(n({index:i,i,j:i,flat_index:i})),[]]}))),c.internal((({Array:i,AnyRef:e,Nullable:s})=>({selected_glyphs:[i(e()),[]],view:[s(e()),null]})))},\n", - " function _(e,t,n,s,o){s();const r=e(50);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 _(e,n,c,o,t){var a;o();const r=e(50),s=e(101);class l extends r.Model{constructor(e){super(e)}}c.DataSource=l,a=l,l.__name__=\"DataSource\",a.define((({Ref:e})=>({selected:[e(s.Selection),()=>new s.Selection,{readonly:!0}]})))},\n", - " function _(t,a,s,e,r){var c;e();const n=t(99);class o extends n.ColumnarDataSource{constructor(t){super(t)}stream(t,a,{sync:s}={}){this.stream_to(this.properties.data,t,a,{sync:s})}patch(t,{sync:a}={}){this.patch_to(this.properties.data,t,{sync:a})}}s.ColumnDataSource=o,c=o,o.__name__=\"ColumnDataSource\",c.define((({Any:t,Dict:a,Arrayable:s})=>({data:[a(s(t)),{}]})))},\n", - " function _(n,t,e,o,r){o();const c=n(1),l=c.__importDefault(n(106)),i=c.__importDefault(n(107)),u=n(23),a=new i.default(\"GOOGLE\"),s=new i.default(\"WGS84\"),f=(0,l.default)(s,a);e.wgs84_mercator={compute:(n,t)=>isFinite(n)&&isFinite(t)?f.forward([n,t]):[NaN,NaN],invert:(n,t)=>isFinite(n)&&isFinite(t)?f.inverse([n,t]):[NaN,NaN]};const _={lon:[-20026376.39,20026376.39],lat:[-20048966.1,20048966.1]},p={lon:[-180,180],lat:[-85.06,85.06]},{min:g,max:h}=Math;function m(n,t){const o=g(n.length,t.length),r=(0,u.infer_type)(n,t),c=new r(o),l=new r(o);return e.inplace.project_xy(n,t,c,l),[c,l]}e.clip_mercator=function(n,t,e){const[o,r]=_[e];return[h(n,o),g(t,r)]},e.in_bounds=function(n,t){const[e,o]=p[t];return e2?void 0!==e.name&&\"geocent\"===e.name||void 0!==n.name&&\"geocent\"===n.name?\"number\"==typeof o.z?[o.x,o.y,o.z].concat(t.splice(3)):[o.x,o.y,t[2]].concat(t.splice(3)):[o.x,o.y].concat(t.splice(2)):[o.x,o.y]):(a=(0,c.default)(e,n,t,r),2===(i=Object.keys(t)).length||i.forEach((function(r){if(void 0!==e.name&&\"geocent\"===e.name||void 0!==n.name&&\"geocent\"===n.name){if(\"x\"===r||\"y\"===r||\"z\"===r)return}else if(\"x\"===r||\"y\"===r)return;a[r]=t[r]})),a)}function l(e){return e instanceof i.default?e:e.oProj?e.oProj:(0,i.default)(e)}t.default=function(e,n,t){e=l(e);var r,o=!1;return void 0===n?(n=e,e=u,o=!0):(void 0!==n.x||Array.isArray(n))&&(t=n,n=e,e=u,o=!0),n=l(n),t?f(e,n,t):(r={forward:function(t,r){return f(e,n,t,r)},inverse:function(t,r){return f(n,e,t,r)}},o&&(r.oProj=n),r)}},\n", - " function _(t,e,a,s,i){s();const l=t(1),u=l.__importDefault(t(108)),r=l.__importDefault(t(119)),d=l.__importDefault(t(120)),o=t(128),f=l.__importDefault(t(130)),p=l.__importDefault(t(131)),m=l.__importDefault(t(115)),n=t(132);function h(t,e){if(!(this instanceof h))return new h(t);e=e||function(t){if(t)throw t};var a=(0,u.default)(t);if(\"object\"==typeof a){var s=h.projections.get(a.projName);if(s){if(a.datumCode&&\"none\"!==a.datumCode){var i=(0,m.default)(f.default,a.datumCode);i&&(a.datum_params=a.datum_params||(i.towgs84?i.towgs84.split(\",\"):null),a.ellps=i.ellipse,a.datumName=i.datumName?i.datumName:a.datumCode)}a.k0=a.k0||1,a.axis=a.axis||\"enu\",a.ellps=a.ellps||\"wgs84\",a.lat1=a.lat1||a.lat0;var l=(0,o.sphere)(a.a,a.b,a.rf,a.ellps,a.sphere),d=(0,o.eccentricity)(l.a,l.b,l.rf,a.R_A),_=(0,n.getNadgrids)(a.nadgrids),c=a.datum||(0,p.default)(a.datumCode,a.datum_params,l.a,l.b,d.es,d.ep2,_);(0,r.default)(this,a),(0,r.default)(this,s),this.a=l.a,this.b=l.b,this.rf=l.rf,this.sphere=l.sphere,this.es=d.es,this.e=d.e,this.ep2=d.ep2,this.datum=c,this.init(),e(null,this)}else e(t)}else e(t)}h.projections=d.default,h.projections.start(),a.default=h},\n", - " function _(t,r,n,u,e){u();const f=t(1),i=f.__importDefault(t(109)),a=f.__importDefault(t(116)),o=f.__importDefault(t(111)),l=f.__importDefault(t(115));var C=[\"PROJECTEDCRS\",\"PROJCRS\",\"GEOGCS\",\"GEOCCS\",\"PROJCS\",\"LOCAL_CS\",\"GEODCRS\",\"GEODETICCRS\",\"GEODETICDATUM\",\"ENGCRS\",\"ENGINEERINGCRS\"];var d=[\"3857\",\"900913\",\"3785\",\"102113\"];n.default=function(t){if(!function(t){return\"string\"==typeof t}(t))return t;if(function(t){return t in i.default}(t))return i.default[t];if(function(t){return C.some((function(r){return t.indexOf(r)>-1}))}(t)){var r=(0,a.default)(t);if(function(t){var r=(0,l.default)(t,\"authority\");if(r){var n=(0,l.default)(r,\"epsg\");return n&&d.indexOf(n)>-1}}(r))return i.default[\"EPSG:3857\"];var n=function(t){var r=(0,l.default)(t,\"extension\");if(r)return(0,l.default)(r,\"proj4\")}(r);return n?(0,o.default)(n):r}return function(t){return\"+\"===t[0]}(t)?(0,o.default)(t):void 0}},\n", - " function _(t,r,i,e,n){e();const f=t(1),a=f.__importDefault(t(110)),l=f.__importDefault(t(111)),u=f.__importDefault(t(116));function o(t){var r=this;if(2===arguments.length){var i=arguments[1];\"string\"==typeof i?\"+\"===i.charAt(0)?o[t]=(0,l.default)(arguments[1]):o[t]=(0,u.default)(arguments[1]):o[t]=i}else if(1===arguments.length){if(Array.isArray(t))return t.map((function(t){Array.isArray(t)?o.apply(r,t):o(t)}));if(\"string\"==typeof t){if(t in o)return o[t]}else\"EPSG\"in t?o[\"EPSG:\"+t.EPSG]=t:\"ESRI\"in t?o[\"ESRI:\"+t.ESRI]=t:\"IAU2000\"in t?o[\"IAU2000:\"+t.IAU2000]=t:console.log(t);return}}(0,a.default)(o),i.default=o},\n", - " function _(t,l,G,S,e){S(),G.default=function(t){t(\"EPSG:4326\",\"+title=WGS 84 (long/lat) +proj=longlat +ellps=WGS84 +datum=WGS84 +units=degrees\"),t(\"EPSG:4269\",\"+title=NAD83 (long/lat) +proj=longlat +a=6378137.0 +b=6356752.31414036 +ellps=GRS80 +datum=NAD83 +units=degrees\"),t(\"EPSG:3857\",\"+title=WGS 84 / Pseudo-Mercator +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs\"),t.WGS84=t[\"EPSG:4326\"],t[\"EPSG:3785\"]=t[\"EPSG:3857\"],t.GOOGLE=t[\"EPSG:3857\"],t[\"EPSG:900913\"]=t[\"EPSG:3857\"],t[\"EPSG:102113\"]=t[\"EPSG:3857\"]}},\n", - " function _(t,n,o,a,u){a();const e=t(1),r=t(112),i=e.__importDefault(t(113)),f=e.__importDefault(t(114)),l=e.__importDefault(t(115));o.default=function(t){var n,o,a,u={},e=t.split(\"+\").map((function(t){return t.trim()})).filter((function(t){return t})).reduce((function(t,n){var o=n.split(\"=\");return o.push(!0),t[o[0].toLowerCase()]=o[1],t}),{}),c={proj:\"projName\",datum:\"datumCode\",rf:function(t){u.rf=parseFloat(t)},lat_0:function(t){u.lat0=t*r.D2R},lat_1:function(t){u.lat1=t*r.D2R},lat_2:function(t){u.lat2=t*r.D2R},lat_ts:function(t){u.lat_ts=t*r.D2R},lon_0:function(t){u.long0=t*r.D2R},lon_1:function(t){u.long1=t*r.D2R},lon_2:function(t){u.long2=t*r.D2R},alpha:function(t){u.alpha=parseFloat(t)*r.D2R},gamma:function(t){u.rectified_grid_angle=parseFloat(t)},lonc:function(t){u.longc=t*r.D2R},x_0:function(t){u.x0=parseFloat(t)},y_0:function(t){u.y0=parseFloat(t)},k_0:function(t){u.k0=parseFloat(t)},k:function(t){u.k0=parseFloat(t)},a:function(t){u.a=parseFloat(t)},b:function(t){u.b=parseFloat(t)},r_a:function(){u.R_A=!0},zone:function(t){u.zone=parseInt(t,10)},south:function(){u.utmSouth=!0},towgs84:function(t){u.datum_params=t.split(\",\").map((function(t){return parseFloat(t)}))},to_meter:function(t){u.to_meter=parseFloat(t)},units:function(t){u.units=t;var n=(0,l.default)(f.default,t);n&&(u.to_meter=n.to_meter)},from_greenwich:function(t){u.from_greenwich=t*r.D2R},pm:function(t){var n=(0,l.default)(i.default,t);u.from_greenwich=(n||parseFloat(t))*r.D2R},nadgrids:function(t){\"@null\"===t?u.datumCode=\"none\":u.nadgrids=t},axis:function(t){var n=\"ewnsud\";3===t.length&&-1!==n.indexOf(t.substr(0,1))&&-1!==n.indexOf(t.substr(1,1))&&-1!==n.indexOf(t.substr(2,1))&&(u.axis=t)},approx:function(){u.approx=!0}};for(n in e)o=e[n],n in c?\"function\"==typeof(a=c[n])?a(o):u[a]=o:u[n]=o;return\"string\"==typeof u.datumCode&&\"WGS84\"!==u.datumCode&&(u.datumCode=u.datumCode.toLowerCase()),u}},\n", - " function _(S,_,P,R,I){R(),P.PJD_3PARAM=1,P.PJD_7PARAM=2,P.PJD_GRIDSHIFT=3,P.PJD_WGS84=4,P.PJD_NODATUM=5,P.SRS_WGS84_SEMIMAJOR=6378137,P.SRS_WGS84_SEMIMINOR=6356752.314,P.SRS_WGS84_ESQUARED=.0066943799901413165,P.SEC_TO_RAD=484813681109536e-20,P.HALF_PI=Math.PI/2,P.SIXTH=.16666666666666666,P.RA4=.04722222222222222,P.RA6=.022156084656084655,P.EPSLN=1e-10,P.D2R=.017453292519943295,P.R2D=57.29577951308232,P.FORTPI=Math.PI/4,P.TWO_PI=2*Math.PI,P.SPI=3.14159265359},\n", - " function _(o,r,a,e,s){e();var n={};a.default=n,n.greenwich=0,n.lisbon=-9.131906111111,n.paris=2.337229166667,n.bogota=-74.080916666667,n.madrid=-3.687938888889,n.rome=12.452333333333,n.bern=7.439583333333,n.jakarta=106.807719444444,n.ferro=-17.666666666667,n.brussels=4.367975,n.stockholm=18.058277777778,n.athens=23.7163375,n.oslo=10.722916666667},\n", - " function _(t,e,f,o,u){o(),f.default={ft:{to_meter:.3048},\"us-ft\":{to_meter:1200/3937}}},\n", - " function _(e,r,t,a,n){a();var o=/[\\s_\\-\\/\\(\\)]/g;t.default=function(e,r){if(e[r])return e[r];for(var t,a=Object.keys(e),n=r.toLowerCase().replace(o,\"\"),f=-1;++f0?90:-90),e.lat_ts=e.lat1)}(n),n}},\n", - " function _(t,e,r,i,s){i(),r.default=function(t){return new c(t).output()};var h=1,o=/\\s/,n=/[A-Za-z]/,a=/[A-Za-z84_]/,u=/[,\\]]/,d=/[\\d\\.E\\-\\+]/;function c(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=h}c.prototype.readCharicter=function(){var t=this.text[this.place++];if(4!==this.state)for(;o.test(t);){if(this.place>=this.text.length)return;t=this.text[this.place++]}switch(this.state){case h: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}},c.prototype.afterquote=function(t){if('\"'===t)return this.word+='\"',void(this.state=4);if(u.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)},c.prototype.afterItem=function(t){return\",\"===t?(null!==this.word&&this.currentObject.push(this.word),this.word=null,void(this.state=h)):\"]\"===t?(this.level--,null!==this.word&&(this.currentObject.push(this.word),this.word=null),this.state=h,this.currentObject=this.stack.pop(),void(this.currentObject||(this.state=-1))):void 0},c.prototype.number=function(t){if(!d.test(t)){if(u.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},c.prototype.quoted=function(t){'\"'!==t?this.word+=t:this.state=5},c.prototype.keyword=function(t){if(a.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=h)}if(!u.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in keyword yet, index '+this.place);this.afterItem(t)}},c.prototype.neutral=function(t){if(n.test(t))return this.word=t,void(this.state=2);if('\"'===t)return this.word=\"\",void(this.state=4);if(d.test(t))return this.word=t,void(this.state=3);if(!u.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in neutral yet, index '+this.place);this.afterItem(t)},c.prototype.output=function(){for(;this.place90&&a*o.R2D<-90&&h*o.R2D>180&&h*o.R2D<-180)return null;if(Math.abs(Math.abs(a)-o.HALF_PI)<=o.EPSLN)return null;if(this.sphere)i=this.x0+this.a*this.k0*(0,n.default)(h-this.long0),s=this.y0+this.a*this.k0*Math.log(Math.tan(o.FORTPI+.5*a));else{var e=Math.sin(a),r=(0,l.default)(this.e,a,e);i=this.x0+this.a*this.k0*(0,n.default)(h-this.long0),s=this.y0-this.a*this.k0*Math.log(r)}return t.x=i,t.y=s,t}function M(t){var i,s,h=t.x-this.x0,a=t.y-this.y0;if(this.sphere)s=o.HALF_PI-2*Math.atan(Math.exp(-a/(this.a*this.k0)));else{var e=Math.exp(-a/(this.a*this.k0));if(-9999===(s=(0,u.default)(this.e,e)))return null}return i=(0,n.default)(this.long0+h/(this.a*this.k0)),t.x=i,t.y=s,t}s.init=f,s.forward=_,s.inverse=M,s.names=[\"Mercator\",\"Popular Visualisation Pseudo Mercator\",\"Mercator_1SP\",\"Mercator_Auxiliary_Sphere\",\"merc\"],s.default={init:f,forward:_,inverse:M,names:s.names}},\n", - " function _(t,n,r,u,a){u(),r.default=function(t,n,r){var u=t*n;return r/Math.sqrt(1-u*u)}},\n", - " function _(t,n,u,a,f){a();const e=t(1),o=t(112),_=e.__importDefault(t(124));u.default=function(t){return Math.abs(t)<=o.SPI?t:t-(0,_.default)(t)*o.TWO_PI}},\n", - " function _(n,t,u,f,c){f(),u.default=function(n){return n<0?-1:1}},\n", - " function _(t,n,a,o,u){o();const c=t(112);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(112);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(112),u=f.__importStar(t(129)),c=f.__importDefault(t(115));e.eccentricity=function(t,r,e,a){var n=t*t,f=r*r,u=(n-f)/n,c=0;return a?(n=(t*=1-u*(i.SIXTH+u*(i.RA4+u*i.RA6)))*t,u=0):c=Math.sqrt(u),{es:u,e:c,ep2:(n-f)/f}},e.sphere=function(t,r,e,a,n){if(!t){var f=(0,c.default)(u.default,a);f||(f=u.WGS84),t=f.a,r=f.b,e=f.rf}return e&&!r&&(r=(1-1/e)*t),(0===e||Math.abs(t-r)3&&(0===s.datum_params[3]&&0===s.datum_params[4]&&0===s.datum_params[5]&&0===s.datum_params[6]||(s.datum_type=d.PJD_7PARAM,s.datum_params[3]*=d.SEC_TO_RAD,s.datum_params[4]*=d.SEC_TO_RAD,s.datum_params[5]*=d.SEC_TO_RAD,s.datum_params[6]=s.datum_params[6]/1e6+1))),r&&(s.datum_type=d.PJD_GRIDSHIFT,s.grids=r),s.a=_,s.b=t,s.es=u,s.ep2=p,s}},\n", - " function _(t,e,n,r,i){r();var u={};function l(t){if(0===t.length)return null;var e=\"@\"===t[0];return e&&(t=t.slice(1)),\"null\"===t?{name:\"null\",mandatory:!e,grid:null,isNull:!0}:{name:t,mandatory:!e,grid:u[t]||null,isNull:!1}}function o(t){return t/3600*Math.PI/180}function a(t,e,n){return String.fromCharCode.apply(null,new Uint8Array(t.buffer.slice(e,n)))}function d(t){return t.map((function(t){return[o(t.longitudeShift),o(t.latitudeShift)]}))}function g(t,e,n){return{name:a(t,e+8,e+16).trim(),parent:a(t,e+24,e+24+8).trim(),lowerLatitude:t.getFloat64(e+72,n),upperLatitude:t.getFloat64(e+88,n),lowerLongitude:t.getFloat64(e+104,n),upperLongitude:t.getFloat64(e+120,n),latitudeInterval:t.getFloat64(e+136,n),longitudeInterval:t.getFloat64(e+152,n),gridNodeCount:t.getInt32(e+168,n)}}function s(t,e,n,r){for(var i=e+176,u=[],l=0;l1&&console.log(\"Only single NTv2 subgrids are currently supported, subsequent sub grids are ignored\");var l=function(t,e,n){for(var r=176,i=[],u=0;ua.y||f>a.x||N1e-12&&Math.abs(n.y)>1e-12);if(d<0)return console.log(\"Inverse grid shift iterator failed to converge.\"),a;a.x=(0,u.default)(l.x+t.ll[0]),a.y=l.y+t.ll[1]}else isNaN(l.x)||(a.x=r.x+l.x,a.y=r.y+l.y);return a}function f(r,e){var t,a={x:r.x/e.del[0],y:r.y/e.del[1]},i=Math.floor(a.x),l=Math.floor(a.y),n=a.x-1*i,o=a.y-1*l,u={x:Number.NaN,y:Number.NaN};if(i<0||i>=e.lim[0])return u;if(l<0||l>=e.lim[1])return u;t=l*e.lim[0]+i;var d=e.cvs[t][0],s=e.cvs[t][1];t++;var y=e.cvs[t][0],f=e.cvs[t][1];t+=e.lim[0];var x=e.cvs[t][0],m=e.cvs[t][1];t--;var N=e.cvs[t][0],c=e.cvs[t][1],_=n*o,g=n*(1-o),v=(1-n)*(1-o),S=(1-n)*o;return u.x=v*d+g*y+S*N+_*x,u.y=v*s+g*f+S*c+_*m,u}t.default=function(r,e,t){if((0,o.compareDatums)(r,e))return t;if(r.datum_type===n.PJD_NODATUM||e.datum_type===n.PJD_NODATUM)return t;var a=r.a,i=r.es;if(r.datum_type===n.PJD_GRIDSHIFT){if(0!==s(r,!1,t))return;a=n.SRS_WGS84_SEMIMAJOR,i=n.SRS_WGS84_ESQUARED}var l=e.a,u=e.b,y=e.es;if(e.datum_type===n.PJD_GRIDSHIFT&&(l=n.SRS_WGS84_SEMIMAJOR,u=n.SRS_WGS84_SEMIMINOR,y=n.SRS_WGS84_ESQUARED),i===y&&a===l&&!d(r.datum_type)&&!d(e.datum_type))return t;if(t=(0,o.geodeticToGeocentric)(t,i,a),d(r.datum_type)&&(t=(0,o.geocentricToWgs84)(t,r.datum_type,r.datum_params)),d(e.datum_type)&&(t=(0,o.geocentricFromWgs84)(t,e.datum_type,e.datum_params)),t=(0,o.geocentricToGeodetic)(t,y,l,u),e.datum_type===n.PJD_GRIDSHIFT&&0!==s(e,!0,t))return;return t},t.applyGridShift=s},\n", - " function _(a,t,r,m,s){m();const u=a(112);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,s,n){s(),i.default=function(e,a,i){var s,n,r,c=i.x,d=i.y,f=i.z||0,u={};for(r=0;r<3;r++)if(!a||2!==r||void 0!==i.z)switch(0===r?(s=c,n=-1!==\"ew\".indexOf(e.axis[r])?\"x\":\"y\"):1===r?(s=d,n=-1!==\"ns\".indexOf(e.axis[r])?\"y\":\"x\"):(s=f,n=\"z\"),e.axis[r]){case\"e\":case\"n\":u[n]=s;break;case\"w\":case\"s\":u[n]=-s;break;case\"u\":void 0!==i[n]&&(u.z=s);break;case\"d\":void 0!==i[n]&&(u.z=-s);break;default:return null}return u}},\n", - " function _(n,t,e,u,f){u(),e.default=function(n){var t={x:n[0],y:n[1]};return n.length>2&&(t.z=n[2]),n.length>3&&(t.m=n[3]),t}},\n", - " function _(e,i,n,t,r){function o(e){if(\"function\"==typeof Number.isFinite){if(Number.isFinite(e))return;throw new TypeError(\"coordinates must be finite numbers\")}if(\"number\"!=typeof e||e!=e||!isFinite(e))throw new TypeError(\"coordinates must be finite numbers\")}t(),n.default=function(e){o(e.x),o(e.y)}},\n", - " function _(e,i,s,o,n){var l,t,a,r,_;o();const c=e(1),d=e(140),p=e(78),T=c.__importStar(e(17));class m extends d.MarkingView{}s.ArrowHeadView=m,m.__name__=\"ArrowHeadView\";class v extends d.Marking{constructor(e){super(e)}}s.ArrowHead=v,l=v,v.__name__=\"ArrowHead\",l.define((()=>({size:[T.NumberSpec,25]})));class u extends m{clip(e,i){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.moveTo(.5*s,s),e.lineTo(.5*s,-2),e.lineTo(-.5*s,-2),e.lineTo(-.5*s,s),e.lineTo(0,0),e.lineTo(.5*s,s)}render(e,i){const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,s),e.lineTo(0,0),e.lineTo(-.5*s,s),this.visuals.line.apply(e,i)}}s.OpenHeadView=u,u.__name__=\"OpenHeadView\";class h extends v{constructor(e){super(e)}}s.OpenHead=h,t=h,h.__name__=\"OpenHead\",t.prototype.default_view=u,t.mixins(p.LineVector);class V extends m{clip(e,i){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.moveTo(.5*s,s),e.lineTo(.5*s,-2),e.lineTo(-.5*s,-2),e.lineTo(-.5*s,s),e.lineTo(.5*s,s)}render(e,i){const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,s),e.lineTo(0,0),e.lineTo(-.5*s,s),e.closePath(),this.visuals.fill.apply(e,i),this.visuals.line.apply(e,i)}}s.NormalHeadView=V,V.__name__=\"NormalHeadView\";class H extends v{constructor(e){super(e)}}s.NormalHead=H,a=H,H.__name__=\"NormalHead\",a.prototype.default_view=V,a.mixins([p.LineVector,p.FillVector]),a.override({fill_color:\"black\"});class w extends m{clip(e,i){this.visuals.line.set_vectorize(e,i);const s=this.size.get(i);e.moveTo(.5*s,s),e.lineTo(.5*s,-2),e.lineTo(-.5*s,-2),e.lineTo(-.5*s,s),e.lineTo(0,.5*s),e.lineTo(.5*s,s)}render(e,i){const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,s),e.lineTo(0,0),e.lineTo(-.5*s,s),e.lineTo(0,.5*s),e.closePath(),this.visuals.fill.apply(e,i),this.visuals.line.apply(e,i)}}s.VeeHeadView=w,w.__name__=\"VeeHeadView\";class x extends v{constructor(e){super(e)}}s.VeeHead=x,r=x,x.__name__=\"VeeHead\",r.prototype.default_view=w,r.mixins([p.LineVector,p.FillVector]),r.override({fill_color:\"black\"});class g extends m{render(e,i){const s=this.size.get(i);e.beginPath(),e.moveTo(.5*s,0),e.lineTo(-.5*s,0),this.visuals.line.apply(e,i)}clip(e,i){}}s.TeeHeadView=g,g.__name__=\"TeeHeadView\";class z extends v{constructor(e){super(e)}}s.TeeHead=z,_=z,z.__name__=\"TeeHead\",_.prototype.default_view=g,_.mixins(p.LineVector)},\n", - " function _(e,t,n,i,s){var a;i();const r=e(1),c=e(50),o=e(54),_=r.__importStar(e(75)),u=r.__importStar(e(17));class l extends o.View{initialize(){super.initialize(),this.visuals=new _.Visuals(this)}request_render(){this.parent.request_render()}get canvas(){return this.parent.canvas}set_data(e,t){const n=this;for(const i of this.model){if(!(i instanceof u.VectorSpec||i instanceof u.ScalarSpec))continue;const s=i.uniform(e).select(t);n[`${i.attr}`]=s}}}n.MarkingView=l,l.__name__=\"MarkingView\";class d extends c.Model{constructor(e){super(e)}}n.Marking=d,a=d,d.__name__=\"Marking\",a.define((({})=>({})))},\n", - " function _(t,e,i,r,o){var a;r();const n=t(1),s=t(73),_=t(142),l=t(157),h=t(158),c=t(161),u=t(192),d=t(162),p=t(219),m=t(163),f=t(223),g=t(225),w=t(147),b=t(19),y=n.__importStar(t(78)),x=t(226),v=t(227),j=t(229),k=t(144),z=t(59),B=t(57),L=t(8),T=t(9);class S extends s.AnnotationView{get orientation(){return this._orientation}*children(){yield*super.children(),yield this._axis_view,yield this._title_view}initialize(){super.initialize();const{ticker:t,formatter:e}=this.model;this._ticker=\"auto\"!=t?t:this._create_ticker(),this._formatter=\"auto\"!=e?e:this._create_formatter(),this._major_range=this._create_major_range(),this._major_scale=this._create_major_scale(),this._minor_range=new g.Range1d({start:0,end:1}),this._minor_scale=new f.LinearScale,this._frame=new l.CartesianFrame(this._major_scale,this._minor_scale,this._major_range,this._minor_range),this._axis=this._create_axis(),this._apply_axis_properties(),this._title=new _.Title,this._apply_title_properties()}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()},request_paint(){t.parent.request_paint(t)},request_render(){t.request_paint()}};this._axis_view=await(0,z.build_view)(this._axis,{parent:e}),this._title_view=await(0,z.build_view)(this._title,{parent:e})}remove(){this._title_view.remove(),this._axis_view.remove(),super.remove()}_apply_axis_properties(){const t=Object.assign(Object.assign(Object.assign({ticker:this._ticker,formatter:this._formatter,major_label_standoff:this.model.label_standoff,axis_line_color:null,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_overrides:this.model.major_label_overrides,major_label_policy:this.model.major_label_policy},y.attrs_of(this.model,\"major_label_\",y.Text,!0)),y.attrs_of(this.model,\"major_tick_\",y.Line,!0)),y.attrs_of(this.model,\"minor_tick_\",y.Line,!0));this._axis.setv(t)}_apply_title_properties(){var t;const e=Object.assign({text:null!==(t=this.model.title)&&void 0!==t?t:\"\",standoff:this.model.title_standoff},y.attrs_of(this.model,\"title_\",y.Text,!1));this._title.setv(e)}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>{this._apply_title_properties(),this._apply_axis_properties()})),this.connect(this._ticker.change,(()=>this.request_render())),this.connect(this._formatter.change,(()=>this.request_render()))}_update_frame(){const[t,e,i,r]=(()=>\"horizontal\"==this.orientation?[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.in_x_scale=t,this._frame.in_y_scale=e,this._frame.x_range=i,this._frame.y_range=r,this._frame.configure_scales()}update_layout(){const{location:t,width:e,height:i,padding:r,margin:o}=this.model,[a,n]=(()=>{if(!(0,L.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\"==n||\"end\"==n||\"center\"==a?\"vertical\":\"horizontal\":t})();this._update_frame();const _=new v.NodeLayout,l=new v.VStack,h=new v.VStack,c=new v.HStack,u=new v.HStack;_.absolute=!0,l.absolute=!0,h.absolute=!0,c.absolute=!0,u.absolute=!0,_.on_resize((t=>this._frame.set_geometry(t)));const d=new j.BorderLayout;this._inner_layout=d,d.absolute=!0,d.center_panel=_,d.top_panel=l,d.bottom_panel=h,d.left_panel=c,d.right_panel=u;const p={left:r,right:r,top:r,bottom:r},m=(()=>{if(null==this.panel){if((0,L.isString)(t))return{left:o,right:o,top:o,bottom:o};{const[e,i]=t;return{left:e,right:o,top:o,bottom:i}}}if(!(0,L.isString)(t)){const[e,i]=t;return d.fixup_geometry=(t,r)=>{const o=t,a=this.layout.bbox,{width:n,height:s}=t;if(t=new B.BBox({left:a.left+e,bottom:a.bottom-i,width:n,height:s}),null!=r){const e=t.left-o.left,i=t.top-o.top,{left:a,top:n,width:s,height:_}=r;r=new B.BBox({left:a+e,top:n+i,width:s,height:_})}return[t,r]},{left:e,right:0,top:0,bottom:i}}d.fixup_geometry=(t,e)=>{const i=t;if(\"horizontal\"==s){const{top:e,width:i,height:r}=t;if(\"end\"==n){const{right:o}=this.layout.bbox;t=new B.BBox({right:o,top:e,width:i,height:r})}else if(\"center\"==n){const{hcenter:o}=this.layout.bbox;t=new B.BBox({hcenter:Math.round(o),top:e,width:i,height:r})}}else{const{left:e,width:i,height:r}=t;if(\"end\"==a){const{bottom:o}=this.layout.bbox;t=new B.BBox({left:e,bottom:o,width:i,height:r})}else if(\"center\"==a){const{vcenter:o}=this.layout.bbox;t=new B.BBox({left:e,vcenter:Math.round(o),width:i,height:r})}}if(null!=e){const r=t.left-i.left,o=t.top-i.top,{left:a,top:n,width:s,height:_}=e;e=new B.BBox({left:a+r,top:n+o,width:s,height:_})}return[t,e]}})();let f,g,w,b;if(d.padding=p,null!=this.panel)f=\"max\",g=void 0,w=void 0,b=void 0;else if(\"auto\"==(\"horizontal\"==s?e:i)){f=\"fixed\";const t=this._get_major_size_factor();null!=t&&(g=25*t),w={percent:.3},b={percent:.8}}else f=\"fit\",g=void 0;if(\"horizontal\"==s){const t=\"auto\"==e?void 0:e,r=\"auto\"==i?25:i;d.set_sizing({width_policy:f,height_policy:\"min\",width:g,min_width:w,max_width:b,halign:n,valign:a,margin:m}),d.center_panel.set_sizing({width_policy:\"auto\"==e?\"fit\":\"fixed\",height_policy:\"fixed\",width:t,height:r})}else{const t=\"auto\"==e?25:e,r=\"auto\"==i?void 0:i;d.set_sizing({width_policy:\"min\",height_policy:f,height:g,min_height:w,max_height:b,halign:n,valign:a,margin:m}),d.center_panel.set_sizing({width_policy:\"fixed\",height_policy:\"auto\"==i?\"fit\":\"fixed\",width:t,height:r})}l.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),h.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),c.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),u.set_sizing({width_policy:\"min\",height_policy:\"fit\"});const{_title_view:y}=this;\"horizontal\"==s?(y.panel=new k.Panel(\"above\"),y.update_layout(),l.children.push(y.layout)):(y.panel=new k.Panel(\"left\"),y.update_layout(),c.children.push(y.layout));const{panel:z}=this,T=null!=z&&s==z.orientation?z.side:\"horizontal\"==s?\"below\":\"right\",S=(()=>{switch(T){case\"above\":return l;case\"below\":return h;case\"left\":return c;case\"right\":return u}})(),{_axis_view:O}=this;if(O.panel=new k.Panel(T),O.update_layout(),S.children.push(O.layout),null!=this.panel){const t=new x.Grid([{layout:d,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:q}=this.model;this.layout.sizing.visible=q}_create_axis(){return new h.LinearAxis}_create_formatter(){return new p.BasicTickFormatter}_create_major_range(){return new g.Range1d({start:0,end:1})}_create_major_scale(){return new f.LinearScale}_create_ticker(){return new u.BasicTicker}_get_major_size_factor(){return null}_render(){const{ctx:t}=this.layer;t.save(),this._paint_bbox(t,this._inner_layout.bbox),this._paint_colors(t,this._inner_layout.center_panel.bbox),this._title_view.render(),this._axis_view.render(),t.restore()}_paint_bbox(t,e){const{x:i,y:r}=e;let{width:o,height:a}=e;i+o>=this.parent.canvas_view.bbox.width&&(o-=1),r+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,r,o,a)),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(t),t.strokeRect(i,r,o,a)),t.restore()}serializable_state(){const t=super.serializable_state(),{children:e=[]}=t,i=n.__rest(t,[\"children\"]);return e.push(this._title_view.serializable_state()),e.push(this._axis_view.serializable_state()),Object.assign(Object.assign({},i),{children:e})}}i.BaseColorBarView=S,S.__name__=\"BaseColorBarView\";class O extends s.Annotation{constructor(t){super(t)}}i.BaseColorBar=O,a=O,O.__name__=\"BaseColorBar\",a.mixins([[\"major_label_\",y.Text],[\"title_\",y.Text],[\"major_tick_\",y.Line],[\"minor_tick_\",y.Line],[\"border_\",y.Line],[\"bar_\",y.Line],[\"background_\",y.Fill]]),a.define((({Alpha:t,Number:e,String:i,Tuple:r,Map:o,Or:a,Ref:n,Auto:s,Nullable:_})=>({location:[a(b.Anchor,r(e,e)),\"top_right\"],orientation:[a(b.Orientation,s),\"auto\"],title:[_(i),null],title_standoff:[e,2],width:[a(e,s),\"auto\"],height:[a(e,s),\"auto\"],scale_alpha:[t,1],ticker:[a(n(c.Ticker),s),\"auto\"],formatter:[a(n(d.TickFormatter),s),\"auto\"],major_label_overrides:[o(a(i,e),a(i,n(w.BaseText))),new globalThis.Map,{convert:t=>(0,L.isPlainObject)(t)?new T.Dict(t):t}],major_label_policy:[n(m.LabelingPolicy),()=>new m.NoOverlap],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]}))),a.override({background_fill_color:\"#ffffff\",background_fill_alpha:.95,bar_line_color:null,border_line_color:null,major_label_text_font_size:\"11px\",major_tick_line_color:\"#ffffff\",minor_tick_line_color:null,title_text_font_size:\"13px\",title_text_font_style:\"italic\"})},\n", - " function _(e,t,i,s,a){var c;s();const o=e(143),r=e(19);class n extends o.TextAnnotationView{_get_position(){const e=this.model.offset,t=this.model.standoff/2,{align:i,vertical_align:s}=this.model;let a,c;const{bbox:o}=this.layout;switch(this.panel.side){case\"above\":case\"below\":switch(s){case\"top\":c=o.top+t;break;case\"middle\":c=o.vcenter;break;case\"bottom\":c=o.bottom-t}switch(i){case\"left\":a=o.left+e;break;case\"center\":a=o.hcenter;break;case\"right\":a=o.right-e}break;case\"left\":switch(s){case\"top\":a=o.left+t;break;case\"middle\":a=o.hcenter;break;case\"bottom\":a=o.right-t}switch(i){case\"left\":c=o.bottom-e;break;case\"center\":c=o.vcenter;break;case\"right\":c=o.top+e}break;case\"right\":switch(s){case\"top\":a=o.right-t;break;case\"middle\":a=o.hcenter;break;case\"bottom\":a=o.left+t}switch(i){case\"left\":c=o.top+e;break;case\"center\":c=o.vcenter;break;case\"right\":c=o.bottom-e}}return{sx:a,sy:c,x_anchor:i,y_anchor:\"middle\"==s?\"center\":s}}_render(){const e=this._get_position(),t=this.panel.get_label_angle_heuristic(\"parallel\");this._paint(this.layer.ctx,e,t)}_get_size(){if(!this.displayed)return{width:0,height:0};const e=this._text_view.graphics();e.visuals=this.visuals.text.values();const{width:t,height:i}=e._size();return{width:t,height:0==i?0:2+i+this.model.standoff}}}i.TitleView=n,n.__name__=\"TitleView\";class l extends o.TextAnnotation{constructor(e){super(e)}}i.Title=l,c=l,l.__name__=\"Title\",c.prototype.default_view=n,c.define((({Number:e})=>({vertical_align:[r.VerticalAlign,\"bottom\"],align:[r.TextAlign,\"left\"],offset:[e,0],standoff:[e,10]}))),c.override({text_font_size:\"13px\",text_font_style:\"bold\",text_line_height:1})},\n", - " function _(t,i,e,n,s){var a;n();const o=t(1),l=t(73),_=t(144),r=t(147),d=t(59),h=t(8),c=t(148),u=o.__importStar(t(78));class x extends l.AnnotationView{*children(){yield*super.children(),yield this._text_view}async lazy_initialize(){await super.lazy_initialize(),await this._init_text()}async _init_text(){const{text:t}=this.model,i=(0,h.isString)(t)?(0,c.parse_delimited_string)(t):t;this._text_view=await(0,d.build_view)(i,{parent:this})}update_layout(){const{panel:t}=this;this.layout=null!=t?new _.SideLayout(t,(()=>this.get_size()),!0):void 0}connect_signals(){super.connect_signals();const{text:t}=this.model.properties;this.on_change(t,(async()=>{this._text_view.remove(),await this._init_text()})),this.connect(this.model.change,(()=>this.request_render()))}remove(){this._text_view.remove(),super.remove()}has_finished(){return!!super.has_finished()&&!!this._text_view.has_finished()}get displayed(){return super.displayed&&\"\"!=this._text_view.model.text&&this.visuals.text.doit}_paint(t,i,e){const n=this._text_view.graphics();n.angle=e,n.position=i,n.align=\"auto\",n.visuals=this.visuals.text.values();const{background_fill:s,border_line:a}=this.visuals;if(s.doit||a.doit){const{p0:i,p1:e,p2:s,p3:a}=n.rect();t.beginPath(),t.moveTo(i.x,i.y),t.lineTo(e.x,e.y),t.lineTo(s.x,s.y),t.lineTo(a.x,a.y),t.closePath(),this.visuals.background_fill.apply(t),this.visuals.border_line.apply(t)}this.visuals.text.doit&&n.paint(t)}}e.TextAnnotationView=x,x.__name__=\"TextAnnotationView\";class p extends l.Annotation{constructor(t){super(t)}}e.TextAnnotation=p,a=p,p.__name__=\"TextAnnotation\",a.mixins([u.Text,[\"border_\",u.Line],[\"background_\",u.Fill]]),a.define((({String:t,Or:i,Ref:e})=>({text:[i(t,e(r.BaseText)),\"\"]}))),a.override({background_fill_color:null,border_line_color:null})},\n", - " function _(t,e,i,l,r){l();const a=t(145),o=t(146),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(0,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(0,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(20),{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=(0,n.Enum)(\"fixed\",\"fit\",\"min\",\"max\")},\n", - " function _(i,t,h,e,s){e();const n=i(145),g=i(57),r=i(8),l=i(12),{abs:o,min:_,max:d,round:a}=Math;class u{constructor(){this.absolute=!1,this.position={left:0,top:0},this._bbox=new g.BBox,this._inner_bbox=new g.BBox,this._sizing=null,this._dirty=!1,this._handlers=[]}*[Symbol.iterator](){}get bbox(){return this._bbox}get inner_bbox(){return this._inner_bbox}get sizing(){return(0,l.assert)(null!=this._sizing),this._sizing}get visible(){return this.sizing.visible}set visible(i){this.sizing.visible!=i&&(this.sizing.visible=i,this._dirty=!0)}set_sizing(i={}){var t,h,e,s,n,g;const r=null!==(t=i.width_policy)&&void 0!==t?t:\"fit\",l=i.width,o=i.min_width,_=i.max_width,d=null!==(h=i.height_policy)&&void 0!==h?h:\"fit\",a=i.height,u=i.min_height,c=i.max_height,w=i.aspect,b=null!==(e=i.margin)&&void 0!==e?e:{top:0,right:0,bottom:0,left:0},x=null===(s=i.visible)||void 0===s||s,m=null!==(n=i.halign)&&void 0!==n?n:\"start\",z=null!==(g=i.valign)&&void 0!==g?g:\"start\";this._sizing={width_policy:r,min_width:o,width:l,max_width:_,height_policy:d,min_height:u,height:a,max_height:c,aspect:w,margin:b,visible:x,halign:m,valign:z,size:{width:l,height:a}},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:s,height_policy:n}=this.sizing,g=(i,t)=>{const h={max:4,fit:3,min:2,fixed:1};return h[i]>h[t]};if(\"fixed\"!=s&&\"fixed\"!=n)if(s==n){const s=t,n=a(t/e),g=a(h*e),r=h;o(i.width-s)+o(i.height-n)<=o(i.width-g)+o(i.height-r)?(t=s,h=n):(t=g,h=r)}else g(s,n)?h=a(t/e):t=a(h*e);else\"fixed\"==s?h=a(t/e):\"fixed\"==n&&(t=a(h*e))}return{width:t,height:h}}measure(i){if(null==this._sizing&&this.set_sizing(),!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 n.Sizeable(i).shrink_by(this.sizing.margin).map(t,h),s=this._measure(e),g=this.clip_size(s,e),r=t(g.width),l=h(g.height),o=this.apply_aspect(e,{width:r,height:l});return Object.assign(Object.assign({},s),o)}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,{left:s,top:n}=this.position,r=new g.BBox({left:s,top:n,width:h,height:e});let l;if(null!=t.inner){const{left:i,top:s,right:n,bottom:r}=t.inner;l=new g.BBox({left:i,top:s,right:h-n,bottom:e-r})}this.set_geometry(r,l)}get xview(){return this.bbox.xview}get yview(){return this.bbox.yview}clip_size(i,t){function h(i,t,h,e){return null==h?h=0:(0,r.isNumber)(h)||(h=a(h.percent*t)),null==e?e=1/0:(0,r.isNumber)(e)||(e=a(e.percent*t)),d(h,_(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=u,u.__name__=\"Layoutable\";class c extends u{_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 d(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 d(t.height,h.height)}})()}}}h.ContentLayoutable=c,c.__name__=\"ContentLayoutable\"},\n", - " function _(e,s,t,n,a){var _;n();const x=e(50),c=e(54);class i extends c.View{}t.BaseTextView=i,i.__name__=\"BaseTextView\";class o extends x.Model{constructor(e){super(e)}}t.BaseText=o,_=o,o.__name__=\"BaseText\",_.define((({String:e})=>({text:[e]})))},\n", - " function _(n,e,t,i,r){i();const s=n(149),l=n(156),d=[{start:\"$$\",end:\"$$\",inline:!1},{start:\"\\\\[\",end:\"\\\\]\",inline:!1},{start:\"\\\\(\",end:\"\\\\)\",inline:!0}];t.parse_delimited_string=function(n){for(const e of d){const t=n.indexOf(e.start),i=t+e.start.length;if(0==t){const t=n.indexOf(e.end,i),r=t;if(t==n.length-e.end.length)return new s.TeX({text:n.slice(i,r),inline:e.inline});break}}return new l.PlainText({text:n})}},\n", - " function _(t,e,i,s,n){var h,o,r;s();const a=t(8),l=t(150),_=t(21),c=t(151),d=t(152),u=t(38),g=t(153),x=t(57),p=t(147),f=t(154);class m extends p.BaseTextView{constructor(){super(...arguments),this._position={sx:0,sy:0},this.align=\"left\",this._x_anchor=\"left\",this._y_anchor=\"center\",this._base_font_size=13,this.font_size_scale=1,this.svg_image=null}graphics(){return this}infer_text_height(){return\"ascent_descent\"}set base_font_size(t){null!=t&&(this._base_font_size=t)}get base_font_size(){return this._base_font_size}_rect(){const{width:t,height:e}=this._size(),{x:i,y:s}=this._computed_position();return new x.BBox({x:i,y:s,width:t,height:e}).rect}set position(t){this._position=t}get position(){return this._position}get text(){return this.model.text}get provider(){return f.default_provider}async lazy_initialize(){await super.lazy_initialize(),\"not_started\"==this.provider.status&&await this.provider.fetch()}connect_signals(){super.connect_signals(),this.on_change(this.model.properties.text,(()=>this.load_image()))}set visuals(t){const e=t.color,i=t.alpha,s=t.font_style;let n=t.font_size;const h=t.font,{font_size_scale:o,_base_font_size:r}=this,a=(0,d.parse_css_font_size)(n);if(null!=a){let{value:t,unit:e}=a;t*=o,\"em\"==e&&0!=r&&(t*=r,e=\"px\"),n=`${t}${e}`}const l=`${s} ${n} ${h}`;this.font=l,this.color=(0,_.color2css)(e,i);const c=t.align;this._x_anchor=c;const u=t.baseline;this._y_anchor=(()=>{switch(u){case\"top\":return\"top\";case\"middle\":return\"center\";case\"bottom\":return\"bottom\";default:return\"baseline\"}})()}_computed_position(){const{width:t,height:e}=this._size(),{sx:i,sy:s,x_anchor:n=this._x_anchor,y_anchor:h=this._y_anchor}=this.position,o=(0,d.font_metrics)(this.font);return{x:i-(()=>{if((0,a.isNumber)(n))return n*t;switch(n){case\"left\":return 0;case\"center\":return.5*t;case\"right\":return t}})(),y:s-(()=>{if((0,a.isNumber)(h))return h*e;switch(h){case\"top\":return o.height>e?e-(-this.valign-o.descent)-o.height:0;case\"center\":case\"baseline\":return.5*e;case\"bottom\":return o.height>e?e+o.descent+this.valign:e}})()}}size(){const{width:t,height:e}=this._size(),{angle:i}=this;if(null==i||0==i)return{width:t,height:e};{const s=Math.cos(Math.abs(i)),n=Math.sin(Math.abs(i));return{width:Math.abs(t*s+e*n),height:Math.abs(t*n+e*s)}}}get_image_dimensions(){var t;const e=(0,d.font_metrics)(this.font),i=null===(t=this.svg_element.getAttribute(\"style\"))||void 0===t?void 0:t.split(\";\");if(null!=i){const t=new Map;i.forEach((e=>{const[i,s]=e.split(\":\");\"\"!=i.trim()&&t.set(i.trim(),s.trim())}));const s=(0,d.parse_css_length)(t.get(\"vertical-align\"));\"ex\"==(null==s?void 0:s.unit)?this.valign=s.value*e.x_height:\"px\"==(null==s?void 0:s.unit)&&(this.valign=s.value)}const s=(()=>{const t=this.svg_element.getAttribute(\"width\"),e=this.svg_element.getAttribute(\"height\");return{width:null!=t&&t.endsWith(\"ex\")?parseFloat(t):1,height:null!=e&&e.endsWith(\"ex\")?parseFloat(e):1}})();return{width:e.x_height*s.width,height:e.x_height*s.height}}get truncated_text(){return this.model.text.length>6?`${this.model.text.substring(0,6)}...`:this.model.text}_size(){var t,e;if(null==this.svg_image)return\"failed\"==this.provider.status||\"not_started\"==this.provider.status?{width:(0,c.text_width)(this.truncated_text,this.font),height:(0,d.font_metrics)(this.font).height}:{width:this._base_font_size,height:this._base_font_size};const i=(0,d.font_metrics)(this.font);let{width:s,height:n}=this.get_image_dimensions();n=Math.max(n,i.height);return{width:s*(\"%\"==(null===(t=this.width)||void 0===t?void 0:t.unit)?this.width.value:1),height:n*(\"%\"==(null===(e=this.height)||void 0===e?void 0:e.unit)?this.height.value:1)}}bbox(){const{p0:t,p1:e,p2:i,p3:s}=this.rect(),n=Math.min(t.x,e.x,i.x,s.x),h=Math.min(t.y,e.y,i.y,s.y),o=Math.max(t.x,e.x,i.x,s.x),r=Math.max(t.y,e.y,i.y,s.y);return new x.BBox({left:n,right:o,top:h,bottom:r})}rect(){const t=this._rect(),{angle:e}=this;if(null==e||0==e)return t;{const{sx:i,sy:s}=this.position,n=new g.AffineTransform;return n.translate(i,s),n.rotate(e),n.translate(-i,-s),n.apply_rect(t)}}paint_rect(t){const{p0:e,p1:i,p2:s,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(i.x),h(i.y)),t.lineTo(h(s.x),h(s.y)),t.lineTo(h(n.x),h(n.y)),t.closePath(),t.stroke(),t.restore()}paint_bbox(t){const{x:e,y:i,width:s,height:n}=this.bbox();t.save(),t.strokeStyle=\"blue\",t.lineWidth=1,t.beginPath();const{round:h}=Math;t.moveTo(h(e),h(i)),t.lineTo(h(e),h(i+n)),t.lineTo(h(e+s),h(i+n)),t.lineTo(h(e+s),h(i)),t.closePath(),t.stroke(),t.restore()}async load_image(){if(null==this.provider.MathJax)return null;const t=this._process_text();if(null==t)return this._has_finished=!0,null;const e=t.children[0];this.svg_element=e,e.setAttribute(\"font\",this.font),e.setAttribute(\"stroke\",this.color);const i=e.outerHTML,s=`data:image/svg+xml;utf-8,${encodeURIComponent(i)}`;return this.svg_image=await(0,l.load_image)(s),this.parent.request_layout(),this.svg_image}paint(t){null==this.svg_image&&(\"not_started\"!=this.provider.status&&\"loading\"!=this.provider.status||this.provider.ready.connect((()=>this.load_image())),\"loaded\"==this.provider.status&&this.load_image()),t.save();const{sx:e,sy:i}=this.position,{angle:s}=this;null!=s&&0!=s&&(t.translate(e,i),t.rotate(s),t.translate(-e,-i));const{x:n,y:h}=this._computed_position();if(null!=this.svg_image){const{width:e,height:i}=this.get_image_dimensions();t.drawImage(this.svg_image,n,h,e,i)}else\"failed\"!=this.provider.status&&\"not_started\"!=this.provider.status||(t.fillStyle=this.color,t.font=this.font,t.textAlign=\"left\",t.textBaseline=\"alphabetic\",t.fillText(this.truncated_text,n,h+(0,d.font_metrics)(this.font).ascent));t.restore(),this._has_finished||\"failed\"!=this.provider.status&&null==this.svg_image||(this._has_finished=!0,this.parent.notify_finished_after_paint())}}i.MathTextView=m,m.__name__=\"MathTextView\";class v extends p.BaseText{constructor(t){super(t)}}i.MathText=v,v.__name__=\"MathText\";class y extends m{get styled_text(){return this.text}_process_text(){}_size(){return{width:(0,c.text_width)(this.text,this.font),height:(0,d.font_metrics)(this.font).height}}paint(t){t.save();const{sx:e,sy:i}=this.position,{angle:s}=this;null!=s&&0!=s&&(t.translate(e,i),t.rotate(s),t.translate(-e,-i));const{x:n,y:h}=this._computed_position();t.fillStyle=this.color,t.font=this.font,t.textAlign=\"left\",t.textBaseline=\"alphabetic\",t.fillText(this.text,n,h+(0,d.font_metrics)(this.font).ascent),t.restore(),this._has_finished=!0,this.parent.notify_finished_after_paint()}}i.AsciiView=y,y.__name__=\"AsciiView\";class b extends v{constructor(t){super(t)}}i.Ascii=b,h=b,b.__name__=\"Ascii\",h.prototype.default_view=y;class w extends m{get styled_text(){let t=this.text.trim(),e=t.match(//s);return null==e?this.text.trim():(t=(0,u.insert_text_on_position)(t,t.indexOf(e[0])+e[0].length,``),e=t.match(/<\\/[^>]*?math.*?>/s),null==e?this.text.trim():(0,u.insert_text_on_position)(t,t.indexOf(e[0]),\"\"))}_process_text(){var t;const e=(0,d.font_metrics)(this.font);return null===(t=this.provider.MathJax)||void 0===t?void 0:t.mathml2svg(this.styled_text,{em:this.base_font_size,ex:e.x_height})}}i.MathMLView=w,w.__name__=\"MathMLView\";class M extends v{constructor(t){super(t)}}i.MathML=M,o=M,M.__name__=\"MathML\",o.prototype.default_view=w;class z extends m{get styled_text(){const[t,e,i]=(0,_.color2rgba)(this.color);return`\\\\color[RGB]{${t}, ${e}, ${i}} ${this.font.includes(\"bold\")?`\\\\pmb{${this.text}}`:this.text}`}_process_text(){var t;const e=(0,d.font_metrics)(this.font);return null===(t=this.provider.MathJax)||void 0===t?void 0:t.tex2svg(this.styled_text,{display:!this.model.inline,em:this.base_font_size,ex:e.x_height},this.model.macros)}}i.TeXView=z,z.__name__=\"TeXView\";class T extends v{constructor(t){super(t)}}i.TeX=T,r=T,T.__name__=\"TeX\",r.prototype.default_view=z,r.define((({Boolean:t,Number:e,String:i,Dict:s,Tuple:n,Or:h})=>({macros:[s(h(i,n(i,e))),{}],inline:[t,!1]})))},\n", - " function _(i,e,t,s,a){s();const o=i(18);t.load_image=async function(i,e){return new n(i,e).promise};class n{constructor(i,e={}){this.image=new Image,this._finished=!1;const{attempts:t=1,timeout:s=1}=e;this.promise=new Promise(((a,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(o.logger.warn(s),null==this.image.crossOrigin)return void(null!=e.failed&&e.failed());o.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),a(this.image)},this.image.src=i}))}get finished(){return this._finished}}t.ImageLoader=n,n.__name__=\"ImageLoader\"},\n", - " function _(t,e,s,i,n){i();const h=t(57),o=t(152),a=t(10),r=t(8),c=t(153),_=t(21);s.text_width=(()=>{const t=document.createElement(\"canvas\").getContext(\"2d\");let e=\"\";return(s,i)=>(i!=e&&(e=i,t.font=i),t.measureText(s).width)})();class l{constructor(){this._position={sx:0,sy:0},this.font_size_scale=1,this.align=\"left\",this._base_font_size=13,this._x_anchor=\"left\",this._y_anchor=\"center\"}set base_font_size(t){null!=t&&(this._base_font_size=t)}get base_font_size(){return this._base_font_size}set position(t){this._position=t}get position(){return this._position}infer_text_height(){return\"ascent_descent\"}bbox(){const{p0:t,p1:e,p2:s,p3:i}=this.rect(),n=Math.min(t.x,e.x,s.x,i.x),o=Math.min(t.y,e.y,s.y,i.y),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(null==s||0==s)return{width:t,height:e};{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)}}}rect(){const t=this._rect(),{angle:e}=this;if(null==e||0==e)return t;{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)}}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 u extends l{set visuals(t){const e=t.color,s=t.alpha,i=t.outline_color,n=t.font_style;let h=t.font_size;const a=t.font,{font_size_scale:r,base_font_size:c}=this,l=(0,o.parse_css_font_size)(h);if(null!=l){let{value:t,unit:e}=l;t*=r,\"em\"==e&&0!=c&&(t*=c,e=\"px\"),h=`${t}${e}`}const u=`${n} ${h} ${a}`;this.font=u,this.color=(0,_.color2css)(e,s),this.outline_color=(0,_.color2css)(i,s),this.line_height=t.line_height;const x=t.align;this._visual_align=x,this._x_anchor=x;const p=t.baseline;this._y_anchor=(()=>{switch(p){case\"top\":return\"top\";case\"middle\":return\"center\";case\"bottom\":return\"bottom\";default:return\"baseline\"}})()}constructor({text:t}){super(),this._visual_align=\"left\",this.text=t}infer_text_height(){if(this.text.includes(\"\\n\"))return\"ascent_descent\";{function t(t){for(const e of new Set(t))if(!(\"0\"<=e&&e<=\"9\"))switch(e){case\",\":case\".\":case\"+\":case\"-\":case\"\\u2212\":case\"e\":continue;default:return!1}return!0}return t(this.text)?\"cap\":\"ascent_descent\"}}_text_line(t){var e;const s=null!==(e=this.text_height_metric)&&void 0!==e?e:this.infer_text_height(),i=(()=>{switch(s){case\"x\":case\"x_descent\":return t.x_height;case\"cap\":case\"cap_descent\":return t.cap_height;case\"ascent\":case\"ascent_descent\":return t.ascent}})(),n=(()=>{switch(s){case\"x\":case\"cap\":case\"ascent\":return 0;case\"x_descent\":case\"cap_descent\":case\"ascent_descent\":return t.descent}})();return{height:i+n,ascent:i,descent:n}}get nlines(){return this.text.split(\"\\n\").length}_size(){var t,e;const{font:i}=this,n=(0,o.font_metrics)(i),h=(this.line_height-1)*n.height,r=\"\"==this.text,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>(0,s.text_width)(t,i))),u=this._text_line(n).height*_,x=\"%\"==(null===(t=this.width)||void 0===t?void 0:t.unit)?this.width.value:1,p=\"%\"==(null===(e=this.height)||void 0===e?void 0:e.unit)?this.height.value:1;return{width:(0,a.max)(l)*x,height:r?0:(u+h*(_-1))*p,metrics:n}}_computed_position(t,e,s){const{width:i,height:n}=t,{sx:h,sy:o,x_anchor:a=this._x_anchor,y_anchor:c=this._y_anchor}=this.position;return{x:h-(()=>{if((0,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((0,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=(0,o.font_metrics)(n),r=(this.line_height-1)*h.height,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>(0,s.text_width)(t,n))),u=this._text_line(h),x=u.height*_,p=\"%\"==(null===(e=this.width)||void 0===e?void 0:e.unit)?this.width.value:1,f=\"%\"==(null===(i=this.height)||void 0===i?void 0:i.unit)?this.height.value:1,g=(0,a.max)(l)*p,d=(x+r*(_-1))*f;t.save(),t.fillStyle=this.color,t.strokeStyle=this.outline_color,t.font=this.font,t.textAlign=\"left\",t.textBaseline=\"alphabetic\";const{sx:b,sy:m}=this.position,{align:y}=this,{angle:w}=this;null!=w&&0!=w&&(t.translate(b,m),t.rotate(w),t.translate(-b,-m));let{x:v,y:z}=this._computed_position({width:g,height:d},h,_);if(\"justify\"==y)for(let e=0;e<_;e++){let i=v;const h=c[e].split(\" \"),o=h.length,_=h.map((t=>(0,s.text_width)(t,n))),l=(g-(0,a.sum)(_))/(o-1);for(let e=0;e{switch(\"auto\"==y?this._visual_align:y){case\"left\":return 0;case\"center\":return.5*(g-l[e]);case\"right\":return g-l[e]}})(),i=c[e],n=z+u.ascent;t.fillText(i,s,n),t.strokeText(i,s,n),z+=u.height+r}t.restore()}}s.TextBox=u,u.__name__=\"TextBox\";class x 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 u&&1==this.base.nlines){const{x_height:t,cap_height:e}=(0,o.font_metrics)(this.base.font);return t/e}return 2/3}infer_text_height(){return this.base.infer_text_height()}_rect(){const t=this.base.bbox(),e=this.expo.bbox(),s=t.union(e),{x:i,y:n}=this._computed_position();return s.translate(i,n).rect}_size(){const t=this.base.size(),e=this.expo.size();return{width:t.width+e.width,height:Math.max(t.height,this._shift_scale()*t.height+e.height)}}paint(t){t.save();const{angle:e}=this;if(null!=e&&0!=e){const{sx:s,sy:i}=this.position;t.translate(s,i),t.rotate(e),t.translate(-s,-i)}const{x:s,y:i}=this._computed_position();t.translate(s,i),this.base.paint(t),this.expo.paint(t),t.restore()}paint_bbox(t){super.paint_bbox(t);const{x:e,y:s}=this._computed_position();t.save(),t.translate(e,s);for(const e of this.children)e.paint_bbox(t);t.restore()}_computed_position(){const{width:t,height:e}=this._size(),{sx:s,sy:i,x_anchor:n=this._x_anchor,y_anchor:h=this._y_anchor}=this.position;return{x:s-(()=>{if((0,r.isNumber)(n))return n*t;switch(n){case\"left\":return 0;case\"center\":return.5*t;case\"right\":return t}})(),y:i-(()=>{if((0,r.isNumber)(h))return h*e;switch(h){case\"top\":return 0;case\"center\":case\"baseline\":return.5*e;case\"bottom\":return e}})()}}}s.BaseExpo=x,x.__name__=\"BaseExpo\";class p{constructor(t){this.items=t}set base_font_size(t){for(const e of this.items)e.base_font_size=t}get length(){return this.items.length}set visuals(t){for(const e of this.items)e.visuals=t;const e={x:0,cap:1,ascent:2,x_descent:3,cap_descent:4,ascent_descent:5},s=(0,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,e,n,c,s){c();const a=t(12),o=t(8),r=(()=>{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},i=(()=>{const t=r(0,0).getContext(\"2d\");return(0,a.assert)(null!=t,\"can't obtain 2d context\"),e=>{t.font=e;const n=t.measureText(\"M\"),c=t.measureText(\"x\"),s=t.measureText(\"\\xc5\\u015ag|\"),r=s.fontBoundingBoxAscent,i=s.fontBoundingBoxDescent;if((0,o.is_defined)(r)&&(0,o.is_defined)(i))return{height:r+i,ascent:r,descent:i,cap_height:n.actualBoundingBoxAscent,x_height:c.actualBoundingBoxAscent};const u=s.actualBoundingBoxAscent,l=s.actualBoundingBoxDescent;if((0,o.is_defined)(u)&&(0,o.is_defined)(l))return{height:u+l,ascent:u,descent:l,cap_height:n.actualBoundingBoxAscent,x_height:c.actualBoundingBoxAscent};(0,a.unreachable)()}})(),u=(()=>{const t=document.createElement(\"canvas\"),e=t.getContext(\"2d\");let n=-1,c=-1;return(s,a=1)=>{e.font=s;const{width:o}=e.measureText(\"M\"),r=o*a,i=Math.ceil(r),u=Math.ceil(2*r),l=Math.ceil(1.5*r);n{let e=0;for(let n=0;n<=l;n++)for(let c=0;c{let e=t.length-4;for(let n=u;n>=l;n--)for(let c=0;c{try{return i(\"normal 10px sans-serif\"),i}catch(t){return u}})(),f=new Map;n.font_metrics=function(t){let e=f.get(t);if(null==e){const n=document.fonts.check(t);e={font:l(t)},n&&f.set(t,e)}return e.font},n.parse_css_font_size=function(t){const e=t.match(/^\\s*(\\d+(\\.\\d+)?)(\\w+)\\s*$/);if(null!=e){const[,t,,n]=e,c=Number(t);if(isFinite(c))return{value:c,unit:n}}return null},n.parse_css_length=function(t){const e=t.match(/^\\s*(-?\\d+(\\.\\d+)?)(\\w+)\\s*$/);if(null!=e){const[,t,,n]=e,c=Number(t);if(isFinite(c))return{value:c,unit:n}}return null}},\n", - " function _(t,s,r,e,i){e();const n=t(25),{sin:a,cos:h}=Math;class o{constructor(t=1,s=0,r=0,e=1,i=0,n=0){this.a=t,this.b=s,this.c=r,this.d=e,this.e=i,this.f=n}toString(){const{a:t,b:s,c:r,d:e,e:i,f:n}=this;return`matrix(${t}, ${s}, ${r}, ${e}, ${i}, ${n})`}static from_DOMMatrix(t){const{a:s,b:r,c:e,d:i,e:n,f:a}=t;return new o(s,r,e,i,n,a)}to_DOMMatrix(){const{a:t,b:s,c:r,d:e,e:i,f:n}=this;return new DOMMatrix([t,s,r,e,i,n])}clone(){const{a:t,b:s,c:r,d:e,e:i,f:n}=this;return new o(t,s,r,e,i,n)}[n.equals](t,s){return s.eq(this.a,t.a)&&s.eq(this.b,t.b)&&s.eq(this.c,t.c)&&s.eq(this.d,t.d)&&s.eq(this.e,t.e)&&s.eq(this.f,t.f)}reset(){this.a=1,this.b=0,this.c=0,this.d=1,this.e=0,this.f=0}get is_identity(){const{a:t,b:s,c:r,d:e,e:i,f:n}=this;return 1==t&&0==s&&0==r&&1==e&&0==i&&0==n}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:e,c:i,d:n,e:a,f:h}=this;return[r*t+i*s+a,e*t+n*s+h]}iv_apply(t,s){const{a:r,b:e,c:i,d:n,e:a,f:h}=this,o=t.length;for(let c=0;c{this.status=\"loaded\",this.ready.emit()},t.onerror=()=>{this.status=\"failed\"},this.status=\"loading\",document.head.appendChild(t)}}a.CDNProvider=h,h.__name__=\"CDNProvider\";class _ extends c{get MathJax(){return this._mathjax}async fetch(){this.status=\"loading\";try{const e=await(0,u.load_module)(Promise.resolve().then((()=>o(t(647)))));this._mathjax=e,this.status=\"loaded\",this.ready.emit()}catch(t){this.status=\"failed\"}}}a.BundleProvider=_,_.__name__=\"BundleProvider\",a.default_provider=new _},\n", - " function _(n,r,o,t,c){t(),o.load_module=async function(n){try{return await n}catch(n){if((r=n)instanceof Error&&\"code\"in r&&\"MODULE_NOT_FOUND\"===n.code)return null;throw n}var r}},\n", - " function _(e,t,i,n,s){var a;n();const x=e(147),_=e(151);class l extends x.BaseTextView{initialize(){super.initialize(),this._has_finished=!0}graphics(){return new _.TextBox({text:this.model.text})}}i.PlainTextView=l,l.__name__=\"PlainTextView\";class r extends x.BaseText{constructor(e){super(e)}}i.PlainText=r,a=r,r.__name__=\"PlainText\",a.prototype.default_view=l},\n", - " function _(e,s,t,a,_){a();const r=e(92),n=e(91),i=e(88),g=e(93),c=e(96),h=e(57),l=e(9),o=e(12),u=e(15);class x{get bbox(){return this._bbox}constructor(e,s,t,a,_={},r={},n={},i={}){this._bbox=new h.BBox,this.change=new u.Signal0(this,\"change\"),this.in_x_scale=e,this.in_y_scale=s,this.x_range=t,this.y_range=a,this.extra_x_ranges=_,this.extra_y_ranges=r,this.extra_x_scales=n,this.extra_y_scales=i,(0,o.assert)(e.properties.source_range.is_unset&&e.properties.target_range.is_unset),(0,o.assert)(s.properties.source_range.is_unset&&s.properties.target_range.is_unset),this._configure_scales()}_get_ranges(e,s){return new Map((0,l.entries)(Object.assign(Object.assign({},s),{default:e})))}_get_scales(e,s,t,a){var _;const i=new Map((0,l.entries)(Object.assign(Object.assign({},s),{default:e}))),h=new Map;for(const[s,l]of t){if(l instanceof c.FactorRange!=e instanceof r.CategoricalScale)throw new Error(`Range ${l.type} is incompatible is Scale ${e.type}`);e instanceof n.LogScale&&l instanceof g.DataRange1d&&(l.scale_hint=\"log\");const t=(null!==(_=i.get(s))&&void 0!==_?_:e).clone();t.setv({source_range:l,target_range:a}),h.set(s,t)}return h}_configure_frame_ranges(){const{bbox:e}=this;this._x_target=new i.Range1d({start:e.left,end:e.right}),this._y_target=new i.Range1d({start:e.bottom,end:e.top})}_configure_scales(){this._configure_frame_ranges(),this._x_ranges=this._get_ranges(this.x_range,this.extra_x_ranges),this._y_ranges=this._get_ranges(this.y_range,this.extra_y_ranges),this._x_scales=this._get_scales(this.in_x_scale,this.extra_x_scales,this._x_ranges,this._x_target),this._y_scales=this._get_scales(this.in_y_scale,this.extra_y_scales,this._y_ranges,this._y_target)}configure_scales(){this._configure_scales(),this.change.emit()}_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 ranges(){return new Set([...this.x_ranges.values(),...this.y_ranges.values()])}get x_scales(){return this._x_scales}get y_scales(){return this._y_scales}get scales(){return new Set([...this.x_scales.values(),...this.y_scales.values()])}get x_scale(){return this._x_scales.get(\"default\")}get y_scale(){return this._y_scales.get(\"default\")}}t.CartesianFrame=x,x.__name__=\"CartesianFrame\"},\n", - " function _(i,s,x,A,o){A(),o(\"Axis\",i(159).Axis),o(\"CategoricalAxis\",i(164).CategoricalAxis),o(\"ContinuousAxis\",i(167).ContinuousAxis),o(\"DatetimeAxis\",i(168).DatetimeAxis),o(\"LinearAxis\",i(184).LinearAxis),o(\"LogAxis\",i(186).LogAxis),o(\"MercatorAxis\",i(189).MercatorAxis)},\n", - " function _(t,e,i,s,a){var l;s();const o=t(1),n=t(160),_=t(161),r=t(162),h=t(163),c=o.__importStar(t(78)),b=t(19),u=t(23),m=t(144),d=t(10),x=t(9),f=t(8),g=t(151),p=t(96),v=t(147),w=t(59),j=t(12),k=t(8),y=t(148),{abs:z}=Math;class M extends n.GuideRendererView{constructor(){super(...arguments),this._axis_label_view=null,this._major_label_views=new Map}*children(){yield*super.children(),null!=this._axis_label_view&&(yield this._axis_label_view),yield*this._major_label_views.values()}async lazy_initialize(){await super.lazy_initialize(),await this._init_axis_label(),await this._init_major_labels()}async _init_axis_label(){const{axis_label:t}=this.model;if(null!=t){const e=(0,k.isString)(t)?(0,y.parse_delimited_string)(t):t;this._axis_label_view=await(0,w.build_view)(e,{parent:this})}else this._axis_label_view=null}async _init_major_labels(){for(const[t,e]of this.model.major_label_overrides){const i=(0,k.isString)(e)?(0,y.parse_delimited_string)(e):e;this._major_label_views.set(t,await(0,w.build_view)(i,{parent:this}))}}update_layout(){this.layout=new m.SideLayout(this.panel,(()=>this.get_size()),!0),this.layout.on_resize((()=>this._coordinates=void 0))}get_size(){const{visible:t,fixed_location:e}=this.model;if(t&&null==e&&this.is_renderable){const{extents:t}=this;return{width:0,height:Math.round(t.tick+t.tick_label+t.axis_label)}}return{width:0,height:0}}get is_renderable(){const[t,e]=this.ranges;return t.is_valid&&e.is_valid&&t.span>0&&e.span>0}_render(){var t;if(!this.is_renderable)return;const{tick_coords:e,extents:i}=this,s=this.layer.ctx;s.save(),this._draw_rule(s,i),this._draw_major_ticks(s,i,e),this._draw_minor_ticks(s,i,e),this._draw_major_labels(s,i,e),this._draw_axis_label(s,i,e),null===(t=this._paint)||void 0===t||t.call(this,s,i,e),s.restore()}connect_signals(){super.connect_signals();const{axis_label:t,major_label_overrides:e}=this.model.properties;this.on_change(t,(async()=>{var t;null===(t=this._axis_label_view)||void 0===t||t.remove(),await this._init_axis_label()})),this.on_change(e,(async()=>{for(const t of this._major_label_views.values())t.remove();await this._init_major_labels()})),this.connect(this.model.change,(()=>this.plot_view.request_layout()))}get needs_clip(){return null!=this.model.fixed_location}_draw_rule(t,e){if(!this.visuals.axis_line.doit)return;const[i,s]=this.rule_coords,[a,l]=this.coordinates.map_to_screen(i,s),[o,n]=this.normals,[_,r]=this.offsets;this.visuals.axis_line.set_value(t),t.beginPath();for(let e=0;e0?s+i+3:0}_draw_axis_label(t,e,i){if(null==this._axis_label_view||null!=this.model.fixed_location)return;const[s,a]=(()=>{const{bbox:t}=this.layout;switch(this.panel.side){case\"above\":return[t.hcenter,t.bottom];case\"below\":return[t.hcenter,t.top];case\"left\":return[t.right,t.vcenter];case\"right\":return[t.left,t.vcenter]}})(),[l,o]=this.normals,n=e.tick+e.tick_label+this.model.axis_label_standoff,{vertical_align:_,align:r}=this.panel.get_label_text_heuristics(\"parallel\"),h={sx:s+l*n,sy:a+o*n,x_anchor:r,y_anchor:_},c=this._axis_label_view.graphics();c.visuals=this.visuals.axis_label_text.values(),c.angle=this.panel.get_label_angle_heuristic(\"parallel\"),null!=this.plot_view.base_font_size&&(c.base_font_size=this.plot_view.base_font_size),c.position=h,c.align=r,c.paint(t)}_draw_ticks(t,e,i,s,a){if(!a.doit)return;const[l,o]=e,[n,_]=this.coordinates.map_to_screen(l,o),[r,h]=this.normals,[c,b]=this.offsets,[u,m]=[r*(c-i),h*(b-i)],[d,x]=[r*(c+s),h*(b+s)];a.set_value(t),t.beginPath();for(let e=0;et.bbox())),M=(()=>{const[t]=this.ranges;return t.is_reversed?0==this.dimension?(t,e)=>z[t].left-z[e].right:(t,e)=>z[e].top-z[t].bottom:0==this.dimension?(t,e)=>z[e].left-z[t].right:(t,e)=>z[t].top-z[e].bottom})(),{major_label_policy:O}=this.model,T=O.filter(k,z,M),A=[...T.ones()];if(0!=A.length){const t=this.parent.canvas_view.bbox,e=e=>{const i=z[e];if(i.left<0){const t=-i.left,{position:s}=y[e];y[e].position=Object.assign(Object.assign({},s),{sx:s.sx+t})}else if(i.right>t.width){const s=i.right-t.width,{position:a}=y[e];y[e].position=Object.assign(Object.assign({},a),{sx:a.sx-s})}},i=e=>{const i=z[e];if(i.top<0){const t=-i.top,{position:s}=y[e];y[e].position=Object.assign(Object.assign({},s),{sy:s.sy+t})}else if(i.bottom>t.height){const s=i.bottom-t.height,{position:a}=y[e];y[e].position=Object.assign(Object.assign({},a),{sy:a.sy-s})}},s=A[0],a=A[A.length-1];0==this.dimension?(e(s),e(a)):(i(s),i(a))}for(const e of T){y[e].paint(t)}}_tick_extent(){return this.model.major_tick_out}_tick_label_extents(){const t=this.tick_coords.major,e=this.compute_labels(t[this.dimension]),i=this.model.major_label_orientation,s=this.model.major_label_standoff,a=this.visuals.major_label_text;return[this._oriented_labels_extent(e,i,s,a)]}get extents(){const t=this._tick_label_extents();return{tick:this._tick_extent(),tick_labels:t,tick_label:(0,d.sum)(t),axis_label:this._axis_label_extent()}}_oriented_labels_extent(t,e,i,s){if(0==t.length||!s.doit)return 0;const a=this.panel.get_label_angle_heuristic(e);t.visuals=s.values(),t.angle=a,t.base_font_size=this.plot_view.base_font_size;const l=t.max_size(),o=0==this.dimension?l.height:l.width;return o>0?i+o+3:0}get normals(){return this.panel.normals}get dimension(){return this.panel.dimension}compute_labels(t){const e=this.model.formatter.format_graphics(t,this),{_major_label_views:i}=this,s=new Set;for(let a=0;az(o-n)?(t=r(_(a,l),o),s=_(r(a,l),n)):(t=_(a,l),s=r(a,l)),[t,s]}}get rule_coords(){const t=this.dimension,e=1-t,[i]=this.ranges,[s,a]=this.computed_bounds,l=[new Array(2),new Array(2)];return l[t][0]=Math.max(s,i.min),l[t][1]=Math.min(a,i.max),l[t][0]>l[t][1]&&(l[t][0]=l[t][1]=NaN),l[e][0]=this.loc,l[e][1]=this.loc,l}get tick_coords(){const t=this.dimension,e=1-t,[i]=this.ranges,[s,a]=this.computed_bounds,l=this.model.ticker.get_ticks(s,a,i,this.loc),o=l.major,n=l.minor,_=[[],[]],r=[[],[]],[h,c]=[i.min,i.max];for(let i=0;ic||(_[t].push(o[i]),_[e].push(this.loc));for(let i=0;ic||(r[t].push(n[i]),r[e].push(this.loc));return{major:_,minor:r}}get loc(){const{fixed_location:t}=this.model;if(null!=t){if((0,f.isNumber)(t))return t;const[,e]=this.ranges;if(e instanceof p.FactorRange)return e.synthetic(t);(0,j.unreachable)()}const[,e]=this.ranges;switch(this.panel.side){case\"left\":case\"below\":return e.start;case\"right\":case\"above\":return e.end}}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.layout.bbox})}remove(){var t;null===(t=this._axis_label_view)||void 0===t||t.remove();for(const t of this._major_label_views.values())t.remove();super.remove()}has_finished(){if(!super.has_finished())return!1;if(null!=this._axis_label_view&&!this._axis_label_view.has_finished())return!1;for(const t of this._major_label_views.values())if(!t.has_finished())return!1;return!0}}i.AxisView=M,M.__name__=\"AxisView\";class O extends n.GuideRenderer{constructor(t){super(t)}}i.Axis=O,l=O,O.__name__=\"Axis\",l.prototype.default_view=M,l.mixins([[\"axis_\",c.Line],[\"major_tick_\",c.Line],[\"minor_tick_\",c.Line],[\"major_label_\",c.Text],[\"axis_label_\",c.Text]]),l.define((({Any:t,Int:e,Number:i,String:s,Ref:a,Map:l,Tuple:o,Or:n,Nullable:c,Auto:u})=>({bounds:[n(o(i,i),u),\"auto\"],ticker:[a(_.Ticker)],formatter:[a(r.TickFormatter)],axis_label:[c(n(s,a(v.BaseText))),null],axis_label_standoff:[e,5],major_label_standoff:[e,5],major_label_orientation:[n(b.TickLabelOrientation,i),\"horizontal\"],major_label_overrides:[l(n(s,i),n(s,a(v.BaseText))),new globalThis.Map,{convert:t=>(0,f.isPlainObject)(t)?new x.Dict(t):t}],major_label_policy:[a(h.LabelingPolicy),()=>new h.AllLabels],major_tick_in:[i,2],major_tick_out:[i,6],minor_tick_in:[i,0],minor_tick_out:[i,4],fixed_location:[c(n(i,t)),null]}))),l.override({axis_line_color:\"black\",major_tick_line_color:\"black\",minor_tick_line_color:\"black\",major_label_text_font_size:\"11px\",major_label_text_align:\"center\",major_label_text_baseline:\"alphabetic\",axis_label_text_font_size:\"13px\",axis_label_text_font_style:\"italic\"})},\n", - " function _(e,r,d,n,i){var s;n();const _=e(74);class u extends _.RendererView{}d.GuideRendererView=u,u.__name__=\"GuideRendererView\";class c extends _.Renderer{constructor(e){super(e)}}d.GuideRenderer=c,s=c,c.__name__=\"GuideRenderer\",s.override({level:\"guide\"})},\n", - " function _(c,e,n,s,o){s();const r=c(50);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(50),a=t(151);class m extends n.Model{constructor(t){super(t)}format_graphics(t,o){return this.doFormat(t,o).map((t=>new a.TextBox({text:t})))}compute(t,o){return this.doFormat([t],null!=o?o:{loc:0})[0]}v_compute(t,o){return this.doFormat(t,null!=o?o:{loc:0})}}r.TickFormatter=m,m.__name__=\"TickFormatter\"},\n", - " function _(e,n,s,t,i){var l,r;t();const c=e(50),o=e(9),a=e(38),u=e(8),d=e(23);class _ extends c.Model{constructor(e){super(e)}}s.LabelingPolicy=_,_.__name__=\"LabelingPolicy\";class f extends _{constructor(e){super(e)}filter(e,n,s){return e}}s.AllLabels=f,f.__name__=\"AllLabels\";class v extends _{constructor(e){super(e)}filter(e,n,s){const{min_distance:t}=this;let i=null;for(const n of e)null!=i&&s(i,n)({min_distance:[e,5]})));class m extends _{constructor(e){super(e)}get names(){return(0,o.keys)(this.args)}get values(){return(0,o.values)(this.args)}get func(){const e=(0,a.use_strict)(this.code);return new d.GeneratorFunction(\"indices\",\"bboxes\",\"distance\",...this.names,e)}filter(e,n,s){var t,i;const l=Object.create(null),r=this.func.call(l,e,n,s,...this.values);let c=r.next();if(null!==(t=c.done)&&void 0!==t&&t&&void 0!==c.value){const{value:n}=c;return n instanceof d.Indices?n:void 0===n?e:(0,u.isIterable)(n)?d.Indices.from_indices(e.size,n):d.Indices.all_unset(e.size)}{const n=[];do{n.push(c.value),c=r.next()}while(null===(i=c.done)||void 0===i||!i);return d.Indices.from_indices(e.size,n)}}}s.CustomLabelingPolicy=m,r=m,m.__name__=\"CustomLabelingPolicy\",r.define((({Unknown:e,String:n,Dict:s})=>({args:[s(e),{}],code:[n,\"\"]})))},\n", - " function _(t,s,e,o,i){var r;o();const a=t(1),l=t(159),_=t(165),n=t(166),p=a.__importStar(t(78)),c=t(19),h=t(151),m=t(8);class u extends l.AxisView{_paint(t,s,e){this._draw_group_separators(t,s,e)}_draw_group_separators(t,s,e){const[o]=this.ranges,[i,r]=this.computed_bounds;if(null==o.tops||o.tops.length<2||!this.visuals.separator_line.doit)return;const a=this.dimension,l=1-a,_=[[],[]];let n=0;for(let t=0;ti&&pnew h.GraphicsBoxes(t.map((t=>(0,m.isString)(t)?new h.TextBox({text:t}):t))),_=t=>l(this.model.formatter.doFormat(t,this));if(1==t.levels){const t=_(i.major);a.push([t,r.major,this.model.major_label_orientation,this.visuals.major_label_text])}else if(2==t.levels){const t=_(i.major.map((t=>t[1])));a.push([t,r.major,this.model.major_label_orientation,this.visuals.major_label_text]),a.push([l(i.tops),r.tops,this.model.group_label_orientation,this.visuals.group_text])}else if(3==t.levels){const t=_(i.major.map((t=>t[2]))),s=i.mids.map((t=>t[1]));a.push([t,r.major,this.model.major_label_orientation,this.visuals.major_label_text]),a.push([l(s),r.mids,this.model.subgroup_label_orientation,this.visuals.subgroup_text]),a.push([l(i.tops),r.tops,this.model.group_label_orientation,this.visuals.group_text])}return a}get tick_coords(){const t=this.dimension,s=1-t,[e]=this.ranges,[o,i]=this.computed_bounds,r=this.model.ticker.get_ticks(o,i,e,this.loc),a={major:[[],[]],mids:[[],[]],tops:[[],[]],minor:[[],[]]};return a.major[t]=r.major,a.major[s]=r.major.map((()=>this.loc)),3==e.levels&&(a.mids[t]=r.mids,a.mids[s]=r.mids.map((()=>this.loc))),e.levels>1&&(a.tops[t]=r.tops,a.tops[s]=r.tops.map((()=>this.loc))),a}}e.CategoricalAxisView=u,u.__name__=\"CategoricalAxisView\";class d extends l.Axis{constructor(t){super(t)}}e.CategoricalAxis=d,r=d,d.__name__=\"CategoricalAxis\",r.prototype.default_view=u,r.mixins([[\"separator_\",p.Line],[\"group_\",p.Text],[\"subgroup_\",p.Text]]),r.define((({Number:t,Or:s})=>({group_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"],subgroup_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"]}))),r.override({ticker:()=>new _.CategoricalTicker,formatter:()=>new n.CategoricalTickFormatter,separator_line_color:\"lightgrey\",separator_line_width:2,group_text_font_style:\"bold\",group_text_font_size:\"11px\",group_text_color:\"grey\",subgroup_text_font_style:\"bold\",subgroup_text_font_size:\"11px\"})},\n", - " function _(t,c,o,s,e){s();const r=t(161);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})},\n", - " function _(t,e,o,n,r){var s;n();const i=t(1),c=t(19),_=t(32),u=t(170),l=t(8),m=t(162),a=t(174),d=i.__importDefault(t(173));o.resolution_order=[\"microseconds\",\"milliseconds\",\"seconds\",\"minsec\",\"minutes\",\"hourmin\",\"hours\",\"days\",\"months\",\"years\"],o.tm_index_for_resolution=new Map;for(const t of o.resolution_order)o.tm_index_for_resolution.set(t,0);function h(t,e){const o=1.1*t*1e3,n=1e3*e;return o=a.ONE_MINUTE?\"minsec\":\"seconds\":o=a.ONE_HOUR?\"hourmin\":\"minutes\":oparseInt(t,10)))}function x(t,e){const o=(0,u.sprintf)(\"$1%06d\",N(t));return-1==(e=e.replace(/((^|[^%])(%%)*)%f/,o)).indexOf(\"%\")?e:(0,d.default)(t,e)}function N(t){return Math.round(t/1e3%1*1e6)}o.tm_index_for_resolution.set(\"seconds\",5),o.tm_index_for_resolution.set(\"minsec\",4),o.tm_index_for_resolution.set(\"minutes\",4),o.tm_index_for_resolution.set(\"hourmin\",3),o.tm_index_for_resolution.set(\"hours\",3),o._get_resolution=h,o._mktime=f,o._strftime=x,o._us=N;class O extends m.TickFormatter{constructor(t){super(t)}doFormat(t,e,o){if(0==t.length)return[];const n=Math.abs(t[t.length-1]-t[0])/1e3,r=n/(t.length-1),s=(0,l.is_undefined)(o)?h(r,n):o,i=[];for(const[e,o]of(0,_.enumerate)(t)){const n=this._compute_label(e,s),r=this._add_context(e,n,o,t.length,s);i.push(r)}return i}_compute_label(t,e){const n=x(t,this[e]),r=f(t),s=o.resolution_order.indexOf(e);let i,c=n,_=!1,u=s;for(;0==r[o.tm_index_for_resolution.get(o.resolution_order[u])]&&(u+=1,u!=o.resolution_order.length);){if((\"minsec\"==e||\"hourmin\"==e)&&!_){if(\"minsec\"==e&&0==r[4]&&0!=r[5]||\"hourmin\"==e&&0==r[3]&&0!=r[4]){i=o.resolution_order[s-1],c=x(t,this[i]);break}_=!0}i=o.resolution_order[u],c=x(t,this[i])}if(this.strip_leading_zeros){const t=c.replace(/^0+/g,\"\");return t!=c&&isNaN(parseInt(t))?`0${t}`:t}return c}_add_context(t,e,o,n,r){const s=this.context_location,i=this.context_which;if(null==this.context)return e;if(\"start\"==i&&0==o||\"end\"==i&&o==n-1||\"center\"==i&&o==Math.floor(n/2)||\"all\"==i){const o=(0,l.isString)(this.context)?x(t,this.context):this.context.doFormat([t],{loc:0},r)[0];if(\"\"==o)return e;switch(s){case\"above\":return`${o}\\n${e}`;case\"below\":return`${e}\\n${o}`;case\"left\":return`${o} ${e}`;case\"right\":return`${e} ${o}`}}return e}}o.DatetimeTickFormatter=O,s=O,O.__name__=\"DatetimeTickFormatter\",s.define((({Boolean:t,Nullable:e,Or:o,Ref:n,String:r})=>({microseconds:[r,\"%fus\"],milliseconds:[r,\"%3Nms\"],seconds:[r,\"%Ss\"],minsec:[r,\":%M:%S\"],minutes:[r,\":%M\"],hourmin:[r,\"%H:%M\"],hours:[r,\"%Hh\"],days:[r,\"%m/%d\"],months:[r,\"%m/%Y\"],years:[r,\"%Y\"],strip_leading_zeros:[t,!0],context:[e(o(r,n(O))),null],context_which:[c.ContextWhich,\"start\"],context_location:[c.Location,\"below\"]})))},\n", - " function _(r,n,t,e,u){e();const i=r(1),l=i.__importStar(r(171)),a=r(172),f=i.__importDefault(r(173)),o=r(20),s=r(8);function c(r,...n){return(0,a.sprintf)(r,...n)}function m(r,n,t){if((0,s.isNumber)(r)){return c((()=>{switch(!1){case Math.floor(r)!=r:return\"%d\";case!(Math.abs(r)>.1&&Math.abs(r)<1e3):return\"%0.3f\";default:return\"%0.3e\"}})(),r)}return`${r}`}function _(r,n,e){if(null==n)return m;if(null!=e&&r in e){const n=e[r];if((0,s.isString)(n)){if(n in t.DEFAULT_FORMATTERS)return t.DEFAULT_FORMATTERS[n];throw new Error(`Unknown tooltip field formatter type '${n}'`)}return function(r,t,e){return n.format(r,t,e)}}return t.DEFAULT_FORMATTERS.numeral}function p(r,n,t){const e=n.get_column(r);if(null==e)return null;if(null==t)return null;if((0,s.isNumber)(t))return e[t];const u=e[t.index];if((0,s.isTypedArray)(u)||(0,s.isArray)(u)){if((0,s.isArray)(u[0])){return u[t.j][t.i]}return u[t.flat_index]}return u}function T(r,n,t,e){if(\"$\"==r[0]){return function(r,n){if(r in n)return n[r];throw new Error(`Unknown special variable '$${r}'`)}(r.substring(1),e)}return p(r.substring(1).replace(/[{}]/g,\"\"),n,t)}t.FormatterType=(0,o.Enum)(\"numeral\",\"printf\",\"datetime\"),t.DEFAULT_FORMATTERS={numeral:(r,n,t)=>l.format(r,n),datetime:(r,n,t)=>(0,f.default)(r,n),printf:(r,n,t)=>c(n,r)},t.sprintf=c,t.basic_formatter=m,t.get_formatter=_,t._get_column_value=p,t.get_value=T,t.replace_placeholders=function(r,n,t,e,u={},i){let l,a;if((0,s.isString)(r)?(l=r,a=!1):(l=r.html,a=!0),l=l.replace(/@\\$name/g,(r=>`@{${u.name}}`)),l=l.replace(/((?:\\$\\w+)|(?:@\\w+)|(?:@{(?:[^{}]+)}))(?:{([^{}]+)})?/g,((r,l,f)=>{const o=T(l,n,t,u);if(null==o)return null!=i?i(\"???\"):\"???\";if(\"safe\"==f)return a=!0,`${o}`;const s=`${_(l,f,e)(o,f,u)}`;return null!=i?i(s):s})),a){return[...(new DOMParser).parseFromString(l,\"text/html\").body.childNodes]}return l}},\n", - " function _(e,n,t,r,i){\n", - " /*!\n", - " * numbro.js\n", - " * version : 1.6.2\n", - " * author : Företagsplatsen AB\n", - " * license : MIT\n", - " * http://www.foretagsplatsen.se\n", - " */\n", - " var a,o={},l=o,u=\"en-US\",c=null,s=\"0,0\";void 0!==n&&n.exports;function f(e){this._value=e}function d(e){var n,t=\"\";for(n=0;n-1?function(e,n){var t,r,i,a;return t=(a=e.toString()).split(\"e\")[0],i=a.split(\"e\")[1],a=t.split(\".\")[0]+(r=t.split(\".\")[1]||\"\")+d(i-r.length),n>0&&(a+=\".\"+d(n)),a}(e,n):(t(e*o)/o).toFixed(n),r&&(i=new RegExp(\"0{1,\"+r+\"}$\"),a=a.replace(i,\"\")),a}function p(e,n,t){var r;return r=n.indexOf(\"$\")>-1?function(e,n,t){var r,i,a=n,l=a.indexOf(\"$\"),c=a.indexOf(\"(\"),s=a.indexOf(\"+\"),f=a.indexOf(\"-\"),d=\"\",h=\"\";-1===a.indexOf(\"$\")?\"infix\"===o[u].currency.position?(h=o[u].currency.symbol,o[u].currency.spaceSeparated&&(h=\" \"+h+\" \")):o[u].currency.spaceSeparated&&(d=\" \"):a.indexOf(\" $\")>-1?(d=\" \",a=a.replace(\" $\",\"\")):a.indexOf(\"$ \")>-1?(d=\" \",a=a.replace(\"$ \",\"\")):a=a.replace(\"$\",\"\");if(i=m(e,a,t,h),-1===n.indexOf(\"$\"))switch(o[u].currency.position){case\"postfix\":i.indexOf(\")\")>-1?((i=i.split(\"\")).splice(-1,0,d+o[u].currency.symbol),i=i.join(\"\")):i=i+d+o[u].currency.symbol;break;case\"infix\":break;case\"prefix\":i.indexOf(\"(\")>-1||i.indexOf(\"-\")>-1?(i=i.split(\"\"),r=Math.max(c,f)+1,i.splice(r,0,o[u].currency.symbol+d),i=i.join(\"\")):i=o[u].currency.symbol+d+i;break;default:throw Error('Currency position should be among [\"prefix\", \"infix\", \"postfix\"]')}else l<=1?i.indexOf(\"(\")>-1||i.indexOf(\"+\")>-1||i.indexOf(\"-\")>-1?(r=1,(l-1?((i=i.split(\"\")).splice(-1,0,d+o[u].currency.symbol),i=i.join(\"\")):i=i+d+o[u].currency.symbol;return i}(e,n,t):n.indexOf(\"%\")>-1?function(e,n,t){var r,i=\"\";e*=100,n.indexOf(\" %\")>-1?(i=\" \",n=n.replace(\" %\",\"\")):n=n.replace(\"%\",\"\");r=m(e,n,t),r.indexOf(\")\")>-1?((r=r.split(\"\")).splice(-1,0,i+\"%\"),r=r.join(\"\")):r=r+i+\"%\";return r}(e,n,t):n.indexOf(\":\")>-1?function(e){var n=Math.floor(e/60/60),t=Math.floor((e-60*n*60)/60),r=Math.round(e-60*n*60-60*t);return n+\":\"+(t<10?\"0\"+t:t)+\":\"+(r<10?\"0\"+r:r)}(e):m(e,n,t),r}function m(e,n,t,r){var i,a,l,s,f,d,p,m,x,g,O,b,w,y,M,v,$,B=!1,E=!1,F=!1,k=\"\",U=!1,N=!1,S=!1,j=!1,D=!1,C=\"\",L=\"\",T=Math.abs(e),K=[\"B\",\"KiB\",\"MiB\",\"GiB\",\"TiB\",\"PiB\",\"EiB\",\"ZiB\",\"YiB\"],G=[\"B\",\"KB\",\"MB\",\"GB\",\"TB\",\"PB\",\"EB\",\"ZB\",\"YB\"],I=\"\",P=!1,R=!1;if(0===e&&null!==c)return c;if(!isFinite(e))return\"\"+e;if(0===n.indexOf(\"{\")){var W=n.indexOf(\"}\");if(-1===W)throw Error('Format should also contain a \"}\"');b=n.slice(1,W),n=n.slice(W+1)}else b=\"\";if(n.indexOf(\"}\")===n.length-1){var Y=n.indexOf(\"{\");if(-1===Y)throw Error('Format should also contain a \"{\"');w=n.slice(Y+1,-1),n=n.slice(0,Y+1)}else w=\"\";if(v=null===($=-1===n.indexOf(\".\")?n.match(/([0-9]+).*/):n.match(/([0-9]+)\\..*/))?-1:$[1].length,-1!==n.indexOf(\"-\")&&(P=!0),n.indexOf(\"(\")>-1?(B=!0,n=n.slice(1,-1)):n.indexOf(\"+\")>-1&&(E=!0,n=n.replace(/\\+/g,\"\")),n.indexOf(\"a\")>-1){if(g=n.split(\".\")[0].match(/[0-9]+/g)||[\"0\"],g=parseInt(g[0],10),U=n.indexOf(\"aK\")>=0,N=n.indexOf(\"aM\")>=0,S=n.indexOf(\"aB\")>=0,j=n.indexOf(\"aT\")>=0,D=U||N||S||j,n.indexOf(\" a\")>-1?(k=\" \",n=n.replace(\" a\",\"\")):n=n.replace(\"a\",\"\"),p=0===(p=(f=Math.floor(Math.log(T)/Math.LN10)+1)%3)?3:p,g&&0!==T&&(d=Math.floor(Math.log(T)/Math.LN10)+1-g,m=3*~~((Math.min(g,f)-p)/3),T/=Math.pow(10,m),-1===n.indexOf(\".\")&&g>3))for(n+=\"[.]\",M=(M=0===d?0:3*~~(d/3)-d)<0?M+3:M,i=0;i=Math.pow(10,12)&&!D||j?(k+=o[u].abbreviations.trillion,e/=Math.pow(10,12)):T=Math.pow(10,9)&&!D||S?(k+=o[u].abbreviations.billion,e/=Math.pow(10,9)):T=Math.pow(10,6)&&!D||N?(k+=o[u].abbreviations.million,e/=Math.pow(10,6)):(T=Math.pow(10,3)&&!D||U)&&(k+=o[u].abbreviations.thousand,e/=Math.pow(10,3)))}if(n.indexOf(\"b\")>-1)for(n.indexOf(\" b\")>-1?(C=\" \",n=n.replace(\" b\",\"\")):n=n.replace(\"b\",\"\"),s=0;s<=K.length;s++)if(a=Math.pow(1024,s),l=Math.pow(1024,s+1),e>=a&&e0&&(e/=a);break}if(n.indexOf(\"d\")>-1)for(n.indexOf(\" d\")>-1?(C=\" \",n=n.replace(\" d\",\"\")):n=n.replace(\"d\",\"\"),s=0;s<=G.length;s++)if(a=Math.pow(1e3,s),l=Math.pow(1e3,s+1),e>=a&&e0&&(e/=a);break}if(n.indexOf(\"o\")>-1&&(n.indexOf(\" o\")>-1?(L=\" \",n=n.replace(\" o\",\"\")):n=n.replace(\"o\",\"\"),o[u].ordinal&&(L+=o[u].ordinal(e))),n.indexOf(\"[.]\")>-1&&(F=!0,n=n.replace(\"[.]\",\".\")),x=e.toString().split(\".\")[0],O=n.split(\".\")[1],y=n.indexOf(\",\"),O){if(x=(I=-1!==O.indexOf(\"*\")?h(e,e.toString().split(\".\")[1].length,t):O.indexOf(\"[\")>-1?h(e,(O=(O=O.replace(\"]\",\"\")).split(\"[\"))[0].length+O[1].length,t,O[1].length):h(e,O.length,t)).split(\".\")[0],I.split(\".\")[1].length)I=(r?k+r:o[u].delimiters.decimal)+I.split(\".\")[1];else I=\"\";F&&0===Number(I.slice(1))&&(I=\"\")}else x=h(e,null,t);return x.indexOf(\"-\")>-1&&(x=x.slice(1),R=!0),x.length-1&&(x=x.toString().replace(/(\\d)(?=(\\d{3})+(?!\\d))/g,\"$1\"+o[u].delimiters.thousands)),0===n.indexOf(\".\")&&(x=\"\"),b+(n.indexOf(\"(\")2)&&(o.length<2?!!o[0].match(/^\\d+.*\\d$/)&&!o[0].match(u):1===o[0].length?!!o[0].match(/^\\d+$/)&&!o[0].match(u)&&!!o[1].match(/^\\d+$/):!!o[0].match(/^\\d+.*\\d$/)&&!o[0].match(u)&&!!o[1].match(/^\\d+$/)))))},n.exports={format:function(e,n,t,r){return null!=t&&t!==a.culture()&&a.setCulture(t),p(Number(e),null!=n?n:s,null==r?Math.round:r)}}},\n", - " function _(e,n,t,r,i){!function(){\"use strict\";var e={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\\x25]+/,modulo:/^\\x25{2}/,placeholder:/^\\x25(?:([1-9]\\d*)\\$|\\(([^)]+)\\))?(\\+)?(0|'[^$])?(-)?(\\d+)?(?:\\.(\\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\\d]*)/i,key_access:/^\\.([a-z_][a-z_\\d]*)/i,index_access:/^\\[(\\d+)\\]/,sign:/^[+-]/};function n(t){return function(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}(function(n){if(i[n])return i[n];var t,r=n,s=[],a=0;for(;r;){if(null!==(t=e.text.exec(r)))s.push(t[0]);else if(null!==(t=e.modulo.exec(r)))s.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\");s.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 i[n]=s}(t),arguments)}function r(e,t){return n.apply(null,[e].concat(t||[]))}var i=Object.create(null);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,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 _(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 _(e,n,i,a,s){var r;a();const t=e(10),c=e(176),m=e(178),_=e(179),k=e(181),o=e(182),T=e(174);class w extends m.CompositeTicker{constructor(e){super(e)}}i.DatetimeTicker=w,r=w,w.__name__=\"DatetimeTicker\",r.override({num_minor_ticks:0,tickers:()=>[new c.AdaptiveTicker({mantissas:[1,2,5],base:10,min_interval:0,max_interval:500*T.ONE_MILLI,num_minor_ticks:0}),new c.AdaptiveTicker({mantissas:[1,2,5,10,15,20,30],base:60,min_interval:T.ONE_SECOND,max_interval:30*T.ONE_MINUTE,num_minor_ticks:0}),new c.AdaptiveTicker({mantissas:[1,2,4,6,8,12],base:24,min_interval:T.ONE_HOUR,max_interval:12*T.ONE_HOUR,num_minor_ticks:0}),new _.DaysTicker({days:(0,t.range)(1,32)}),new _.DaysTicker({days:(0,t.range)(1,31,3)}),new _.DaysTicker({days:[1,8,15,22]}),new _.DaysTicker({days:[1,15]}),new k.MonthsTicker({months:(0,t.range)(0,12,1)}),new k.MonthsTicker({months:(0,t.range)(0,12,2)}),new k.MonthsTicker({months:(0,t.range)(0,12,4)}),new k.MonthsTicker({months:(0,t.range)(0,12,6)}),new o.YearsTicker({})]})},\n", - " function _(t,i,a,s,e){var n;s();const r=t(177),_=t(10),l=t(11);class h extends r.ContinuousTicker{constructor(t){super(t)}get_min_interval(){return this.min_interval}get_max_interval(){var t;return null!==(t=this.max_interval)&&void 0!==t?t:1/0}initialize(){super.initialize();const t=(0,_.nth)(this.mantissas,-1)/this.base,i=(0,_.nth)(this.mantissas,0)*this.base;this.extended_mantissas=[t,...this.mantissas,i],this.base_factor=0===this.get_min_interval()?1:this.get_min_interval()}get_interval(t,i,a){const s=i-t,e=this.get_ideal_interval(t,i,a),n=Math.floor((0,l.log)(e/this.base_factor,this.base)),r=this.base**n*this.base_factor,h=this.extended_mantissas,m=h.map((t=>Math.abs(a-s/(t*r)))),v=h[(0,_.argmin)(m)]*r;return(0,l.clamp)(v,this.get_min_interval(),this.get_max_interval())}}a.AdaptiveTicker=h,n=h,h.__name__=\"AdaptiveTicker\",n.define((({Number:t,Array:i,Nullable:a})=>({base:[t,10],mantissas:[i(t),[1,2,5]],min_interval:[t,0],max_interval:[a(t),null]})))},\n", - " function _(t,n,i,s,e){var o;s();const r=t(161),c=t(10);class _ extends r.Ticker{constructor(t){super(t)}get_ticks(t,n,i,s){return this.get_ticks_no_defaults(t,n,s,this.desired_num_ticks)}get_ticks_no_defaults(t,n,i,s){const e=this.get_interval(t,n,s),o=Math.floor(t/e),r=Math.ceil(n/e);let _;_=isFinite(o)&&isFinite(r)?(0,c.range)(o,r+1):[];const u=_.map((t=>t*e)).filter((i=>t<=i&&i<=n)),a=this.num_minor_ticks,f=[];if(a>0&&u.length>0){const i=e/a,s=(0,c.range)(0,a).map((t=>t*i));for(const i of s.slice(1)){const s=u[0]-i;t<=s&&s<=n&&f.push(s)}for(const i of u)for(const e of s){const s=i+e;t<=s&&s<=n&&f.push(s)}}return{major:u,minor:f}}get_ideal_interval(t,n,i){return(n-t)/i}}i.ContinuousTicker=_,o=_,_.__name__=\"ContinuousTicker\",o.define((({Int:t})=>({num_minor_ticks:[t,5],desired_num_ticks:[t,6]})))},\n", - " function _(t,e,i,r,s){var n;r();const _=t(177),a=t(10);class l extends _.ContinuousTicker{constructor(t){super(t)}get min_intervals(){return this.tickers.map((t=>t.get_min_interval()))}get max_intervals(){return this.tickers.map((t=>t.get_max_interval()))}get_min_interval(){return this.min_intervals[0]}get_max_interval(){return this.max_intervals[0]}get_best_ticker(t,e,i){const r=e-t,s=this.get_ideal_interval(t,e,i),n=[(0,a.sorted_index)(this.min_intervals,s)-1,(0,a.sorted_index)(this.max_intervals,s)],_=[this.min_intervals[n[0]],this.max_intervals[n[1]]].map((t=>Math.abs(i-r/t)));let l;if((0,a.is_empty)(_.filter((t=>!isNaN(t)))))l=this.tickers[0];else{const t=n[(0,a.argmin)(_)];l=this.tickers[t]}return l}get_interval(t,e,i){return this.get_best_ticker(t,e,i).get_interval(t,e,i)}get_ticks_no_defaults(t,e,i,r){return this.get_best_ticker(t,e,r).get_ticks_no_defaults(t,e,i,r)}}i.CompositeTicker=l,n=l,l.__name__=\"CompositeTicker\",n.define((({Array:t,Ref:e})=>({tickers:[t(e(_.ContinuousTicker)),[]]})))},\n", - " function _(t,e,n,s,a){var o;s();const i=t(180),r=t(174),c=t(10);class _ extends i.BaseSingleIntervalTicker{constructor(t){super(t)}initialize(){super.initialize();const t=this.days;t.length>1?this.interval=(t[1]-t[0])*r.ONE_DAY:this.interval=31*r.ONE_DAY}get_ticks_no_defaults(t,e,n,s){const a=function(t,e){const n=(0,r.last_month_no_later_than)(new Date(t)),s=(0,r.last_month_no_later_than)(new Date(e));s.setUTCMonth(s.getUTCMonth()+1);const a=[],o=n;for(;a.push((0,r.copy_date)(o)),o.setUTCMonth(o.getUTCMonth()+1),!(o>s););return a}(t,e),o=this.days;return{major:(0,c.concat)(a.map((t=>((t,e)=>{const n=t.getUTCMonth(),s=[];for(const a of o){const o=(0,r.copy_date)(t);o.setUTCDate(a),new Date(o.getTime()+e/2).getUTCMonth()==n&&s.push(o)}return s})(t,this.interval)))).map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.DaysTicker=_,o=_,_.__name__=\"DaysTicker\",o.define((({Int:t,Array:e})=>({days:[e(t),[]]}))),o.override({num_minor_ticks:0})},\n", - " function _(e,n,r,t,i){var a;t();const l=e(177);class s extends l.ContinuousTicker{constructor(e){super(e)}get_interval(e,n,r){return this.interval}get_min_interval(){return this.interval}get_max_interval(){return this.interval}}r.BaseSingleIntervalTicker=s,s.__name__=\"BaseSingleIntervalTicker\";class _ extends s{constructor(e){super(e)}}r.SingleIntervalTicker=_,a=_,_.__name__=\"SingleIntervalTicker\",a.define((({Number:e})=>({interval:[e]})))},\n", - " function _(t,e,n,a,r){var s;a();const i=t(180),o=t(174),l=t(10);class _ extends i.BaseSingleIntervalTicker{constructor(t){super(t)}initialize(){super.initialize();const t=this.months;t.length>1?this.interval=(t[1]-t[0])*o.ONE_MONTH:this.interval=12*o.ONE_MONTH}get_ticks_no_defaults(t,e,n,a){const r=function(t,e){const n=(0,o.last_year_no_later_than)(new Date(t)),a=(0,o.last_year_no_later_than)(new Date(e));a.setUTCFullYear(a.getUTCFullYear()+1);const r=[],s=n;for(;r.push((0,o.copy_date)(s)),s.setUTCFullYear(s.getUTCFullYear()+1),!(s>a););return r}(t,e),s=this.months;return{major:(0,l.concat)(r.map((t=>s.map((e=>{const n=(0,o.copy_date)(t);return n.setUTCMonth(e),n}))))).map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.MonthsTicker=_,s=_,_.__name__=\"MonthsTicker\",s.define((({Int:t,Array:e})=>({months:[e(t),[]]})))},\n", - " function _(e,t,a,r,_){r();const n=e(183),s=e(180),i=e(174);class c extends s.BaseSingleIntervalTicker{constructor(e){super(e),this.interval=i.ONE_YEAR,this.basic_ticker=new n.BasicTicker({num_minor_ticks:0})}get_ticks_no_defaults(e,t,a,r){const _=(0,i.last_year_no_later_than)(new Date(e)).getUTCFullYear(),n=(0,i.last_year_no_later_than)(new Date(t)).getUTCFullYear();return{major:this.basic_ticker.get_ticks_no_defaults(_,n,a,r).major.map((e=>Date.UTC(e,0,1))).filter((a=>e<=a&&a<=t)),minor:[]}}}a.YearsTicker=c,c.__name__=\"YearsTicker\"},\n", - " function _(c,e,s,i,n){i();const r=c(176);class t extends r.AdaptiveTicker{constructor(c){super(c)}}s.BasicTicker=t,t.__name__=\"BasicTicker\"},\n", - " function _(e,i,s,n,r){var t;n();const a=e(167),o=e(185),c=e(183);class _ extends a.ContinuousAxisView{}s.LinearAxisView=_,_.__name__=\"LinearAxisView\";class u extends a.ContinuousAxis{constructor(e){super(e)}}s.LinearAxis=u,t=u,u.__name__=\"LinearAxis\",t.prototype.default_view=_,t.override({ticker:()=>new c.BasicTicker,formatter:()=>new o.BasicTickFormatter})},\n", - " function _(i,t,e,n,o){var r;n();const s=i(162),c=i(38);function _(i){let t=\"\";for(const e of i)t+=\"-\"==e?\"\\u2212\":e;return t}e.unicode_replace=_;class a extends s.TickFormatter{constructor(i){super(i),this.last_precision=3}get scientific_limit_low(){return 10**this.power_limit_low}get scientific_limit_high(){return 10**this.power_limit_high}_need_sci(i){if(!this.use_scientific)return!1;const{scientific_limit_high:t}=this,{scientific_limit_low:e}=this,n=i.length<2?0:Math.abs(i[1]-i[0])/1e4;for(const o of i){const i=Math.abs(o);if(!(i<=n)&&(i>=t||i<=e))return!0}return!1}_format_with_precision(i,t,e){return t?i.map((i=>_(i.toExponential(e)))):i.map((i=>_((0,c.to_fixed)(i,e))))}_auto_precision(i,t){const e=new Array(i.length),n=this.last_precision<=15;i:for(let o=this.last_precision;n?o<=15:o>=1;n?o++:o--){if(t){e[0]=i[0].toExponential(o);for(let t=1;t({precision:[n(t,e),\"auto\"],use_scientific:[i,!0],power_limit_high:[t,5],power_limit_low:[t,-3]})))},\n", - " function _(e,o,i,s,t){var n;s();const r=e(167),_=e(187),c=e(188);class a extends r.ContinuousAxisView{}i.LogAxisView=a,a.__name__=\"LogAxisView\";class u extends r.ContinuousAxis{constructor(e){super(e)}}i.LogAxis=u,n=u,u.__name__=\"LogAxis\",n.prototype.default_view=a,n.override({ticker:()=>new c.LogTicker,formatter:()=>new _.LogTickFormatter})},\n", - " function _(e,t,n,o,r){var i;o();const a=e(162),s=e(185),c=e(188),l=e(151),{abs:u,log:x,round:_}=Math;class p extends a.TickFormatter{constructor(e){super(e)}initialize(){super.initialize(),this.basic_formatter=new s.BasicTickFormatter}format_graphics(e,t){var n,o;if(0==e.length)return[];const r=null!==(o=null===(n=this.ticker)||void 0===n?void 0:n.base)&&void 0!==o?o:10,i=this._exponents(e,r);return null==i?this.basic_formatter.format_graphics(e,t):i.map((e=>{if(u(e)u(e)({ticker:[n(t(c.LogTicker)),null],min_exponent:[e,0]})))},\n", - " function _(t,o,e,s,n){var r;s();const i=t(176),a=t(10);class c extends i.AdaptiveTicker{constructor(t){super(t)}get_ticks_no_defaults(t,o,e,s){const n=this.num_minor_ticks,r=[],i=this.base,c=Math.log(t)/Math.log(i),f=Math.log(o)/Math.log(i),l=f-c;let h;if(isFinite(l)&&0!=l)if(l<2){const e=this.get_interval(t,o,s),i=Math.floor(t/e),c=Math.ceil(o/e);if(h=(0,a.range)(i,c+1).filter((t=>0!=t)).map((t=>t*e)).filter((e=>t<=e&&e<=o)),n>0&&h.length>0){const t=e/n,o=(0,a.range)(0,n).map((o=>o*t));for(const t of o.slice(1))r.push(h[0]-t);for(const t of h)for(const e of o)r.push(t+e)}}else{const t=Math.ceil(.999999*c),o=Math.floor(1.000001*f),e=Math.ceil((o-t)/9);if(h=(0,a.range)(t-1,o+1,e).map((t=>i**t)),n>0&&h.length>0){const t=i**e/n,o=(0,a.range)(1,n+1).map((o=>o*t));for(const t of o)r.push(h[0]/t);r.push(h[0]);for(const t of h)for(const e of o)r.push(t*e)}}else h=[];return{major:h.filter((e=>t<=e&&e<=o)),minor:r.filter((e=>t<=e&&e<=o))}}}e.LogTicker=c,r=c,c.__name__=\"LogTicker\",r.override({mantissas:[1,5]})},\n", - " function _(e,r,t,i,a){var o;i();const s=e(159),c=e(184),n=e(190),_=e(191);class x extends s.AxisView{}t.MercatorAxisView=x,x.__name__=\"MercatorAxisView\";class d extends c.LinearAxis{constructor(e){super(e)}}t.MercatorAxis=d,o=d,d.__name__=\"MercatorAxis\",o.prototype.default_view=x,o.override({ticker:()=>new _.MercatorTicker({dimension:\"lat\"}),formatter:()=>new n.MercatorTickFormatter({dimension:\"lat\"})})},\n", - " function _(r,t,e,o,n){var i;o();const c=r(185),s=r(19),a=r(105);class l extends c.BasicTickFormatter{constructor(r){super(r)}doFormat(r,t){if(null==this.dimension)throw new Error(\"MercatorTickFormatter.dimension not configured\");if(0==r.length)return[];const e=r.length,o=new Array(e);if(\"lon\"==this.dimension)for(let n=0;n({dimension:[r(s.LatLon),null]})))},\n", - " function _(t,o,n,s,r){var e;s();const i=t(183),c=t(19),_=t(105);class a extends i.BasicTicker{constructor(t){super(t)}get_ticks_no_defaults(t,o,n,s){if(null==this.dimension)throw new Error(`${this}.dimension wasn't configured`);return[t,o]=(0,_.clip_mercator)(t,o,this.dimension),\"lon\"==this.dimension?this._get_ticks_lon(t,o,n,s):this._get_ticks_lat(t,o,n,s)}_get_ticks_lon(t,o,n,s){const[r]=_.wgs84_mercator.invert(t,n),[e,i]=_.wgs84_mercator.invert(o,n),c=super.get_ticks_no_defaults(r,e,n,s),a=[];for(const t of c.major)if((0,_.in_bounds)(t,\"lon\")){const[o]=_.wgs84_mercator.compute(t,i);a.push(o)}const m=[];for(const t of c.minor)if((0,_.in_bounds)(t,\"lon\")){const[o]=_.wgs84_mercator.compute(t,i);m.push(o)}return{major:a,minor:m}}_get_ticks_lat(t,o,n,s){const[,r]=_.wgs84_mercator.invert(n,t),[e,i]=_.wgs84_mercator.invert(n,o),c=super.get_ticks_no_defaults(r,i,n,s),a=[];for(const t of c.major)if((0,_.in_bounds)(t,\"lat\")){const[,o]=_.wgs84_mercator.compute(e,t);a.push(o)}const m=[];for(const t of c.minor)if((0,_.in_bounds)(t,\"lat\")){const[,o]=_.wgs84_mercator.compute(e,t);m.push(o)}return{major:a,minor:m}}}n.MercatorTicker=a,e=a,a.__name__=\"MercatorTicker\",e.define((({Nullable:t})=>({dimension:[t(c.LatLon),null]})))},\n", - " function _(e,i,r,c,k){c(),k(\"AdaptiveTicker\",e(176).AdaptiveTicker),k(\"BasicTicker\",e(183).BasicTicker),k(\"CategoricalTicker\",e(165).CategoricalTicker),k(\"CompositeTicker\",e(178).CompositeTicker),k(\"ContinuousTicker\",e(177).ContinuousTicker),k(\"DatetimeTicker\",e(175).DatetimeTicker),k(\"DaysTicker\",e(179).DaysTicker),k(\"FixedTicker\",e(193).FixedTicker),k(\"LogTicker\",e(188).LogTicker),k(\"MercatorTicker\",e(191).MercatorTicker),k(\"MonthsTicker\",e(181).MonthsTicker),k(\"SingleIntervalTicker\",e(180).SingleIntervalTicker),k(\"Ticker\",e(161).Ticker),k(\"YearsTicker\",e(182).YearsTicker),k(\"BinnedTicker\",e(194).BinnedTicker)},\n", - " function _(e,r,t,i,n){var s;i();const _=e(177);class c extends _.ContinuousTicker{constructor(e){super(e)}get_ticks_no_defaults(e,r,t,i){return{major:[...this.ticks],minor:[...this.minor_ticks]}}get_interval(e,r,t){return 0}get_min_interval(){return 0}get_max_interval(){return 0}}t.FixedTicker=c,s=c,c.__name__=\"FixedTicker\",s.define((({Number:e,Arrayable:r})=>({ticks:[r(e),[]],minor_ticks:[r(e),[]]})))},\n", - " function _(e,n,t,r,i){var o;r();const a=e(161),s=e(195),c=e(13);class m extends a.Ticker{constructor(e){super(e)}get_ticks(e,n,t,r){const{binning:i}=this.mapper.metrics,o=Math.max(0,(0,c.left_edge_index)(e,i)),a=Math.min((0,c.left_edge_index)(n,i)+1,i.length-1),s=[];for(let e=o;e<=a;e++)s.push(i[e]);const{num_major_ticks:m}=this,_=[],h=\"auto\"==m?s.length:m,l=Math.max(1,Math.floor(s.length/h));for(let e=0;e({mapper:[n(s.ScanningColorMapper)],num_major_ticks:[t(e,r),8]})))},\n", - " function _(n,i,e,t,a){t();const o=n(196),_=n(13);class r extends o.ContinuousColorMapper{constructor(n){super(n)}index_to_value(n){return this._scan_data.binning[n]}value_to_index(n,i){const e=this._scan_data;return ne.binning[e.binning.length-1]?i:(0,_.left_edge_index)(n,e.binning)}}e.ScanningColorMapper=r,r.__name__=\"ScanningColorMapper\"},\n", - " function _(t,e,o,n,s){var l;n();const i=t(197),c=t(199),a=t(10),h=t(8);class r extends i.ColorMapper{constructor(t){super(t),this._scan_data=null}connect_signals(){super.connect_signals();const t=()=>{for(const[t]of this.domain)this.connect(t.view.change,(()=>this.update_data())),this.connect(t.data_source.selected.change,(()=>this.update_data()))},{high:e,low:o,high_color:n,low_color:s,palette:l,nan_color:i}=this.properties;this.on_change([e,o,n,s,l,i],(()=>this.update_data())),this.connect(this.properties.domain.change,(()=>t())),t()}update_data(){const{domain:t,palette:e}=this,o=[...this._collect(t)];this._scan_data=this.scan(o,e.length),this.metrics_change.emit(),this.change.emit()}get metrics(){return null==this._scan_data&&this.update_data(),this._scan_data}*_collect(t){for(const[e,o]of t)for(const t of(0,h.isArray)(o)?o:[o]){if(e.view.properties.indices.is_unset)continue;const o=e.data_source.get_column(t);if(null==o)continue;let n=e.view.indices.select(o);const s=e.view.masked,l=e.data_source.selected.indices;let i;if(null!=s&&l.length>0?i=(0,a.intersection)([...s],l):null!=s?i=[...s]:l.length>0&&(i=l),null!=i&&(n=(0,a.map)(i,(t=>n[t]))),n.length>0&&!(0,h.isNumber)(n[0]))for(const t of n)yield*t;else yield*n}}_v_compute(t,e,o,n){const{nan_color:s}=n;let{low_color:l,high_color:i}=n;null==l&&(l=o[0]),null==i&&(i=o[o.length-1]);const{domain:c}=this,h=(0,a.is_empty)(c)?t:[...this._collect(c)];this._scan_data=this.scan(h,o.length),this.metrics_change.emit();for(let n=0,c=t.length;n=e.length?n:e[s]}}o.ContinuousColorMapper=r,l=r,r.__name__=\"ContinuousColorMapper\",l.define((({Number:t,String:e,Ref:o,Color:n,Or:s,Tuple:l,Array:i,Nullable:a})=>({high:[a(t),null],low:[a(t),null],high_color:[a(n),null],low_color:[a(n),null],domain:[i(l(o(c.GlyphRenderer),s(e,i(e)))),[]]})))},\n", - " function _(t,e,r,n,o){var i;n();const _=t(198),a=t(15),c=t(23),s=t(21),l=t(26),p=t(29);function u(t){return(0,s.encode_rgba)((0,s.color2rgba)(t))}function h(t){const e=new Uint32Array(t.length);for(let r=0,n=t.length;rt))),e}get rgba_mapper(){const t=this,e=h(this.palette),r=this._colors(u);return{v_compute(n){const o=(0,p.is_NDArray)(n)&&3==n.dimension?n.shape[2]:1,i=new c.ColorArray(n.length/o);return t._v_compute_uint32(n,i,e,r),new Uint8ClampedArray((0,l.to_big_endian)(i).buffer)}}}_colors(t){return{nan_color:t(this.nan_color)}}_v_compute_uint32(t,e,r,n){this._v_compute(t,e,r,n)}}r.ColorMapper=g,i=g,g.__name__=\"ColorMapper\",i.define((({Color:t,Array:e})=>({palette:[e(t)],nan_color:[t,\"gray\"]})))},\n", - " function _(r,e,n,s,o){s();const p=r(86);class t extends p.Transform{constructor(r){super(r)}compute(r){throw new Error(\"mapping single values is not supported\")}}n.Mapper=t,t.__name__=\"Mapper\"},\n", - " function _(e,t,i,s,l){var h;s();const n=e(200),o=e(201),c=e(211),a=e(212),d=e(214),_=e(203),r=e(99),p=e(215),g=e(23),y=e(13),u=e(9),m=e(59),v=e(25),w=e(96),f=e(208),b={fill:{},line:{}},V={fill:{fill_alpha:.3,fill_color:\"grey\"},line:{line_alpha:.3,line_color:\"grey\"}},G={fill:{fill_alpha:.2},line:{}},x={fill:{fill_alpha:.2},line:{}};class R extends n.DataRendererView{get glyph_view(){return this.glyph}*children(){yield*super.children(),yield this.cds_view,yield this.glyph,yield this.selection_glyph,yield this.nonselection_glyph,null!=this.hover_glyph&&(yield this.hover_glyph),yield this.muted_glyph,yield this.decimated_glyph}get data_source(){return this.model.properties.data_source}async lazy_initialize(){var e;await super.lazy_initialize(),this.cds_view=await(0,m.build_view)(this.model.view,{parent:this});const t=this.model.glyph;this.glyph=await this.build_glyph_view(t);const i=\"fill\"in this.glyph.visuals,s=\"line\"in this.glyph.visuals,l=Object.assign({},t.attributes);function h(e){const h=(0,u.clone)(l);return i&&(0,u.extend)(h,e.fill),s&&(0,u.extend)(h,e.line),new t.constructor(h)}function n(e,t){return t instanceof _.Glyph?t:h(\"auto\"==t?e:{fill:{},line:{}})}delete l.id;let{selection_glyph:o,nonselection_glyph:c,hover_glyph:a,muted_glyph:d}=this.model;o=n(b,o),this.selection_glyph=await this.build_glyph_view(o),c=n(G,c),this.nonselection_glyph=await this.build_glyph_view(c),null!=a&&(this.hover_glyph=await this.build_glyph_view(a)),d=n(x,d),this.muted_glyph=await this.build_glyph_view(d);const r=n(V,\"auto\");this.decimated_glyph=await this.build_glyph_view(r),this.selection_glyph.set_base(this.glyph),this.nonselection_glyph.set_base(this.glyph),null===(e=this.hover_glyph)||void 0===e||e.set_base(this.glyph),this.muted_glyph.set_base(this.glyph),this.decimated_glyph.set_base(this.glyph),this.set_data()}async build_glyph_view(e){return(0,m.build_view)(e,{parent:this})}remove(){var e;this.cds_view.remove(),this.glyph.remove(),this.selection_glyph.remove(),this.nonselection_glyph.remove(),null===(e=this.hover_glyph)||void 0===e||e.remove(),this.muted_glyph.remove(),this.decimated_glyph.remove(),super.remove()}connect_signals(){super.connect_signals();const e=()=>this.request_render(),t=()=>this.update_data();this.connect(this.model.change,e),this.connect(this.glyph.model.change,t),this.connect(this.selection_glyph.model.change,t),this.connect(this.nonselection_glyph.model.change,t),null!=this.hover_glyph&&this.connect(this.hover_glyph.model.change,t),this.connect(this.muted_glyph.model.change,t),this.connect(this.decimated_glyph.model.change,t),this.connect(this.model.data_source.change,t),this.connect(this.model.data_source.streaming,t),this.connect(this.model.data_source.patching,(e=>this.update_data(e))),this.connect(this.model.data_source.selected.change,e),this.connect(this.model.data_source._select,e),null!=this.hover_glyph&&this.connect(this.model.data_source.inspect,(()=>{const{inspected:t}=this.model.data_source,i={indices:t.indices,line_indices:t.line_indices,multiline_indices:t.multiline_indices,image_indices:t.image_indices,selected_glyphs:t.selected_glyphs};(0,v.is_equal)(this._previous_inspected,i)||(this._previous_inspected=i,e())})),this.connect(this.model.properties.view.change,(async()=>{this.cds_view.remove(),this.cds_view=await(0,m.build_view)(this.model.view,{parent:this}),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 w.FactorRange&&this.connect(e.change,t);for(const[,e]of s)e instanceof w.FactorRange&&this.connect(e.change,t);const{transformchange:l,exprchange:h}=this.model.glyph;this.connect(l,t),this.connect(h,t)}_update_masked_indices(){const e=this.glyph.mask_data();return this.model.view.masked=e,e}update_data(e){this.set_data(e),this.request_render()}set_data(e){const t=this.model.data_source;this.all_indices=this.model.view.indices;const{all_indices:i}=this;this.glyph.set_data(t,i,e),this.set_visuals(),this._update_masked_indices();const{lod_factor:s}=this.plot_model,l=this.all_indices.count;this.decimated=new g.Indices(l);for(let e=0;el.is_empty()?[]:this.glyph instanceof o.LineView&&l.selected_glyph===this.glyph.model?this.model.view.convert_indices_from_subset(i):l.indices)(),{inspected:n}=this.model.data_source;this._previous_inspected={indices:n.indices,line_indices:n.line_indices,multiline_indices:n.multiline_indices,image_indices:n.image_indices,selected_glyphs:n.selected_glyphs};const _=new Set((()=>n.is_empty()?[]:null!=n.selected_glyph?this.model.view.convert_indices_from_subset(i):n.indices.length>0?n.indices:Object.keys(n.multiline_indices).map((e=>parseInt(e))))()),r=(0,y.filter)(i,(e=>_.has(t[e]))),{lod_threshold:p}=this.plot_model;let g,u,m;if(null!=this.model.document&&this.model.document.interactive_duration()>0&&!e&&null!=p&&t.length>p?(i=[...this.decimated],g=this.decimated_glyph,u=this.decimated_glyph,m=this.selection_glyph):(g=this.model.muted?this.muted_glyph:this.glyph,u=this.nonselection_glyph,m=this.selection_glyph),null!=this.hover_glyph&&0!=r.length){const e=new Set(i);for(const t of r)e.delete(t);i=[...e]}if(0==h.length)if(this.glyph instanceof o.LineView)null!=this.hover_glyph&&0!=r.length?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(r)):g.render(s,t);else if(this.glyph instanceof c.PatchView||this.glyph instanceof a.HAreaView||this.glyph instanceof d.VAreaView)if(0==n.selected_glyphs.length||null==this.hover_glyph)g.render(s,t);else for(const e of n.selected_glyphs)e==this.glyph.model&&this.hover_glyph.render(s,t);else g.render(s,i),null!=this.hover_glyph&&0!=r.length&&this.hover_glyph.render(s,r);else{const e=new Set(h),l=new Array,n=new Array;if(this.glyph instanceof o.LineView)for(const i of t)e.has(i)?l.push(i):n.push(i);else for(const s of i)e.has(t[s])?l.push(s):n.push(s);u.render(s,n),m.render(s,l),null!=this.hover_glyph&&(this.glyph instanceof o.LineView?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(r)):this.hover_glyph.render(s,r))}s.restore()}get_reference_point(e,t){if(null!=e){const i=this.model.data_source.get_column(e);if(null!=i)for(const[e,s]of(0,u.entries)(this.model.view.indices_map))if(i[parseInt(e)]==t)return s}return 0}draw_legend(e,t,i,s,l,h,n,o){0!=this.glyph.data_size&&(null==o&&(o=this.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=R,R.__name__=\"GlyphRendererView\";class k extends n.DataRenderer{constructor(e){super(e)}get_selection_manager(){return this.data_source.selection_manager}add_decoration(e,t){const i=new f.Decoration({marking:e,node:t}),s=[this.glyph,this.selection_glyph,this.nonselection_glyph,this.hover_glyph,this.muted_glyph];for(const e of s)e instanceof _.Glyph&&(e.decorations=[...e.decorations,i]);return i}}i.GlyphRenderer=k,h=k,k.__name__=\"GlyphRenderer\",h.prototype.default_view=R,h.define((({Boolean:e,Auto:t,Or:i,Ref:s,Null:l,Nullable:h})=>({data_source:[s(r.ColumnarDataSource)],view:[s(p.CDSView),()=>new p.CDSView],glyph:[s(_.Glyph)],hover_glyph:[h(s(_.Glyph)),null],nonselection_glyph:[i(s(_.Glyph),t,l),\"auto\"],selection_glyph:[i(s(_.Glyph),t,l),\"auto\"],muted_glyph:[i(s(_.Glyph),t,l),\"auto\"],muted:[e,!1]})))},\n", - " function _(e,r,t,n,s){var a,o;n();const _=e(74),i=e(93);class c extends _.RendererView{constructor(){super(...arguments),this[a]=!0}get xscale(){return this.coordinates.x_scale}get yscale(){return this.coordinates.y_scale}bounds(){return this.glyph_view.bounds()}log_bounds(){return this.glyph_view.log_bounds()}}t.DataRendererView=c,a=i.auto_ranged,c.__name__=\"DataRendererView\";class d extends _.Renderer{constructor(e){super(e)}get selection_manager(){return this.get_selection_manager()}}t.DataRenderer=d,o=d,d.__name__=\"DataRenderer\",o.override({level:\"glyph\"})},\n", - " function _(e,i,t,n,s){var l;n();const o=e(1),_=e(202),r=e(209),h=o.__importStar(e(78)),a=o.__importStar(e(210)),c=e(101);class d extends _.XYGlyphView{async lazy_initialize(){await super.lazy_initialize();const{webgl:i}=this.renderer.plot_view.canvas_view;if(null!=i&&i.regl_wrapper.has_webgl){const{LineGL:t}=await Promise.resolve().then((()=>o.__importStar(e(521))));this.glglyph=new t(i.regl_wrapper,this)}}_render(e,i,t){const{sx:n,sy:s}=null!=t?t:this,l=this.parent.nonselection_glyph==this;let o=null;const _=e=>null!=o&&e-o!=1;let r=!0;e.beginPath();for(const t of i){const i=n[t],h=s[t];l&&!r&&null!=o&&t-o>1&&isFinite(n[o+1]+s[o+1])&&e.lineTo(n[o+1],s[o+1]),isFinite(i+h)?(r||_(t)?(l&&t>0&&isFinite(n[t-1]+s[t-1])?(e.moveTo(n[t-1],s[t-1]),e.lineTo(i,h)):e.moveTo(i,h),r=!1):e.lineTo(i,h),o=t):r=!0}if(l&&!r&&null!=o){const i=n.length;o({x:[c.XCoordinateSpec,{field:\"x\"}],y:[c.YCoordinateSpec,{field:\"y\"}]})))},\n", - " function _(e,t,i,s,n){var a;s();const r=e(1),o=r.__importStar(e(17)),_=r.__importStar(e(57)),l=r.__importStar(e(75)),c=e(54),d=e(50),h=e(59),u=e(18),f=e(23),p=e(8),g=e(204),y=e(13),v=e(25),x=e(205),m=e(96),w=e(101),b=e(208),{abs:S,ceil:z}=Math;class $ extends c.View{constructor(){super(...arguments),this._index=null,this._data_size=null,this._nohit_warned=new Set,this.decorations=new Map}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 l.Visuals(this)}*children(){yield*super.children(),yield*this.decorations.values()}async lazy_initialize(){await super.lazy_initialize(),await(0,h.build_views)(this.decorations,this.model.decorations,{parent:this.parent})}request_render(){this.parent.request_render()}get canvas(){return this.renderer.parent.canvas_view}render(e,t,i){var s;null!=this.glglyph&&(this.renderer.needs_webgl_blit=this.glglyph.render(e,t,null!==(s=this.base)&&void 0!==s?s:this),this.renderer.needs_webgl_blit)||this._render(e,t,null!=i?i: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(_.positive_x()),{y0:i,y1:s}=this.index.bounds(_.positive_y());return this._bounds({x0:e,y0:i,x1:t,y1:s})}get_anchor_point(e,t,[i,s]){switch(e){case\"center\":case\"center_center\":{const[e,n]=this.scenterxy(t,i,s);return{x:e,y:n}}default:return null}}sdist(e,t,i,s=\"edge\",n=!1){const a=t.length,r=new f.ScreenArray(a),o=e.s_compute;if(\"center\"==s)for(let e=0;ez(e))),r}draw_legend_for_index(e,t,i){}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)||(u.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:i,sy0:s,sy1:n}=e,[a,r]=this.renderer.coordinates.x_scale.r_invert(t,i),[o,_]=this.renderer.coordinates.y_scale.r_invert(s,n),l=[...this.index.indices({x0:a,x1:r,y0:o,y1:_})];return new w.Selection({indices:l})}_project_data(){}*_iter_visuals(){for(const e of this.visuals)for(const t of e)(t instanceof o.VectorSpec||t instanceof o.ScalarSpec)&&(yield t)}set_base(e){e!=this&&e instanceof this.constructor&&(this.base=e)}_configure(e,t){Object.defineProperty(this,(0,p.isString)(e)?e:e.attr,Object.assign({configurable:!0,enumerable:!0},t))}set_visuals(e,t){var i;for(const i of this._iter_visuals()){const{base:s}=this;if(null!=s){const e=s.model.properties[i.attr];if(null!=e&&(0,v.is_equal)(i.get_value(),e.get_value())){this._configure(i,{get:()=>s[`${i.attr}`]});continue}}const n=i.uniform(e).select(t);this._configure(i,{value:n})}for(const e of this.visuals)e.update();null===(i=this.glglyph)||void 0===i||i.set_visuals_changed()}set_data(e,t,i){var s;const{x_source:n,y_source:a}=this.renderer.coordinates,r=new Set(this._iter_visuals());this._data_size=t.count;for(const i of this.model)if((i instanceof o.VectorSpec||i instanceof o.ScalarSpec)&&!r.has(i))if(i instanceof o.BaseCoordinateSpec){const s=i.array(e);let r=t.select(s);const _=\"x\"==i.dimension?n:a;if(_ instanceof m.FactorRange)if(i instanceof o.CoordinateSpec)r=_.v_synthetic(r);else if(i instanceof o.CoordinateSeqSpec)for(let e=0;e({decorations:[e(t(b.Decoration)),[]]})))},\n", - " function _(t,s,r,e,a){var n;e();const o=t(25),h=t(12);class i{constructor(t,s){this.offsets=t,this.array=s}[(n=Symbol.toStringTag,o.equals)](t,s){return s.arrays(this.offsets,t.offsets)&&s.arrays(this.array,t.array)}get length(){return this.offsets.length}clone(){return new i(this.offsets.slice(),this.array.slice())}static from(t,s){const r=t.length;let e=0;const a=(()=>{const s=new Uint32Array(r);for(let a=0;a>1;t[s]>i?e=s:n=s+1}return t[n]}class r extends d.default{get boxes(){return this._boxes}search_indices(i,t,n,e){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let s=this._boxes.length-4;const d=[],x=new o.Indices(this.numItems);for(;void 0!==s;){const o=Math.min(s+4*this.nodeSize,h(s,this._levelBounds));for(let h=s;h>2],r=this._boxes[h+0],l=this._boxes[h+1],a=this._boxes[h+2],_=this._boxes[h+3];na||t>_||(s<4*this.numItems?x.set(o):d.push(o)))}s=d.pop()}return x}}r.__name__=\"_FlatBush\";class l{constructor(i){this.index=null,i>0&&(this.index=new r(i))}add_rect(i,t,n,e){var s;isFinite(i+t+n+e)?null===(s=this.index)||void 0===s||s.add(i,t,n,e):this.add_empty()}add_point(i,t){var n;isFinite(i+t)?null===(n=this.index)||void 0===n||n.add(i,t,i,t):this.add_empty()}add_empty(){var i;null===(i=this.index)||void 0===i||i.add(1/0,1/0,-1/0,-1/0)}finish(){var i;null===(i=this.index)||void 0===i||i.finish()}_normalize(i){let{x0:t,y0:n,x1:e,y1:s}=i;return t>e&&([t,e]=[e,t]),n>s&&([n,s]=[s,n]),{x0:t,y0:n,x1:e,y1:s}}get bbox(){if(null==this.index)return(0,x.empty)();{const{minX:i,minY:t,maxX:n,maxY:e}=this.index;return{x0:i,y0:t,x1:n,y1:e}}}indices(i){if(null==this.index)return new o.Indices(0);{const{x0:t,y0:n,x1:e,y1:s}=this._normalize(i);return this.index.search_indices(t,n,e,s)}}bounds(i){const t=(0,x.empty)();if(null==this.index)return t;const{boxes:n}=this.index;for(const e of this.indices(i)){const s=n[4*e+0],d=n[4*e+1],o=n[4*e+2],x=n[4*e+3];s>=i.x0&&st.x1&&(t.x1=o),d>=i.y0&&dt.y1&&(t.y1=x)}return t}}n.SpatialIndex=l,l.__name__=\"SpatialIndex\"},\n", - " function _(t,s,i,e,h){e();const n=t(1).__importDefault(t(207)),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||1,s=this.maxY-this.minY||1,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;_this._boxes[_+2])continue;if(s>this._boxes[_+3])continue;const a=0|this._indices[_>>2];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(1+(e<<1),x):o.push(e<<1,x)}for(;o.length&&1&o.peek();){if(o.peekValue()>x)return o.clear(),r;if(r.push(o.pop()>>1),r.length===i)return o.clear(),r}n=o.pop()>>1}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(;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]}shrink(){this.ids.length=this.values.length=this.length}}},\n", - " function _(e,i,n,a,t){var r;a();const o=e(140),s=e(50),d=e(54),l=e(59);class c extends d.View{*children(){yield*super.children(),yield this.marking}async lazy_initialize(){await super.lazy_initialize(),this.marking=await(0,l.build_view)(this.model.marking,{parent:this.parent})}}n.DecorationView=c,c.__name__=\"DecorationView\";class _ extends s.Model{constructor(e){super(e)}}n.Decoration=_,r=_,_.__name__=\"Decoration\",r.prototype.default_view=c,r.define((({Enum:e,Ref:i})=>({marking:[i(o.Marking)],node:[e(\"start\",\"middle\",\"end\")]})))},\n", - " function _(e,n,a,t,i){t();const l=e(1).__importStar(e(210));function r(e,n,{x0:a,x1:t,y0:i,y1:l},r){n.save(),n.beginPath(),n.moveTo(a,(i+l)/2),n.lineTo(t,(i+l)/2),e.line.apply(n,r),n.restore()}function c(e,n,{x0:a,x1:t,y0:i,y1:l},r){var c,o;const _=.1*Math.abs(t-a),s=.1*Math.abs(l-i),y=a+_,p=t-_,g=i+s,h=l-s;n.beginPath(),n.rect(y,g,p-y,h-g),e.fill.apply(n,r),null===(c=e.hatch)||void 0===c||c.apply(n,r),null===(o=e.line)||void 0===o||o.apply(n,r)}a.generic_line_scalar_legend=function(e,n,{x0:a,x1:t,y0:i,y1:l}){n.save(),n.beginPath(),n.moveTo(a,(i+l)/2),n.lineTo(t,(i+l)/2),e.line.apply(n),n.restore()},a.generic_line_vector_legend=r,a.generic_line_legend=r,a.generic_area_scalar_legend=function(e,n,{x0:a,x1:t,y0:i,y1:l}){var r,c;const o=.1*Math.abs(t-a),_=.1*Math.abs(l-i),s=a+o,y=t-o,p=i+_,g=l-_;n.beginPath(),n.rect(s,p,y-s,g-p),e.fill.apply(n),null===(r=e.hatch)||void 0===r||r.apply(n),null===(c=e.line)||void 0===c||c.apply(n)},a.generic_area_vector_legend=c,a.generic_area_legend=c,a.line_interpolation=function(e,n,a,t,i,r){const{sx:c,sy:o}=n;let _,s,y,p;\"point\"==n.type?([y,p]=e.yscale.r_invert(o-1,o+1),[_,s]=e.xscale.r_invert(c-1,c+1)):\"v\"==n.direction?([y,p]=e.yscale.r_invert(o,o),[_,s]=[Math.min(a-1,i-1),Math.max(a+1,i+1)]):([_,s]=e.xscale.r_invert(c,c),[y,p]=[Math.min(t-1,r-1),Math.max(t+1,r+1)]);const{x:g,y:h}=l.check_2_segments_intersect(_,y,s,p,a,t,i,r);return[g,h]}},\n", - " function _(t,n,e,i,r){function s(t,n){return(t.x-n.x)**2+(t.y-n.y)**2}function o(t,n,e){const i=s(n,e);if(0==i)return s(t,n);const r=((t.x-n.x)*(e.x-n.x)+(t.y-n.y)*(e.y-n.y))/i;if(r<0)return s(t,n);if(r>1)return s(t,e);return s(t,{x:n.x+r*(e.x-n.x),y:n.y+r*(e.y-n.y)})}i(),e.point_in_poly=function(t,n,e,i){let r=!1,s=e[e.length-1],o=i[i.length-1];for(let u=0;u0&&_<1&&h>0&&h<1,x:t+_*(e-t),y:n+_*(i-n)}}}},\n", - " function _(t,s,e,i,a){var l;i();const n=t(1),_=t(202),o=t(209),c=n.__importStar(t(210)),h=n.__importStar(t(78)),r=t(101);class p extends _.XYGlyphView{_render(t,s,e){const{sx:i,sy:a}=null!=e?e:this;let l=!0;t.beginPath();for(const e of s){const s=i[e],n=a[e];isFinite(s+n)?l?(t.moveTo(s,n),l=!1):t.lineTo(s,n):(t.closePath(),l=!0)}t.closePath(),this.visuals.fill.apply(t),this.visuals.hatch.apply(t),this.visuals.line.apply(t)}draw_legend_for_index(t,s,e){(0,o.generic_area_scalar_legend)(this.visuals,t,s)}_hit_point(t){const s=new r.Selection;return c.point_in_poly(t.sx,t.sy,this.sx,this.sy)&&(s.add_to_selected_glyphs(this.model),s.view=this),s}}e.PatchView=p,p.__name__=\"PatchView\";class d extends _.XYGlyph{constructor(t){super(t)}}e.Patch=d,l=d,d.__name__=\"Patch\",l.prototype.default_view=p,l.mixins([h.LineScalar,h.FillScalar,h.HatchScalar])},\n", - " function _(t,s,e,i,h){var n;i();const r=t(1),a=t(213),_=r.__importStar(t(210)),o=r.__importStar(t(17)),l=t(101);class c extends a.AreaView{_index_data(t){const{min:s,max:e}=Math,{data_size:i}=this;for(let h=0;h=0;s--)t.lineTo(h[s],n[s]);t.closePath(),this.visuals.fill.apply(t),this.visuals.hatch.apply(t)}_hit_point(t){const s=this.sy.length,e=new l.Selection;for(let i=0,h=s-1;i({x1:[o.XCoordinateSpec,{field:\"x1\"}],x2:[o.XCoordinateSpec,{field:\"x2\"}],y:[o.YCoordinateSpec,{field:\"y\"}]})))},\n", - " function _(e,a,r,_,s){var n;_();const i=e(1),l=e(203),c=e(209),t=i.__importStar(e(78));class d extends l.GlyphView{draw_legend_for_index(e,a,r){(0,c.generic_area_scalar_legend)(this.visuals,e,a)}}r.AreaView=d,d.__name__=\"AreaView\";class o extends l.Glyph{constructor(e){super(e)}}r.Area=o,n=o,o.__name__=\"Area\",n.mixins([t.FillScalar,t.HatchScalar])},\n", - " function _(t,s,e,i,h){var n;i();const r=t(1),a=t(213),_=r.__importStar(t(210)),o=r.__importStar(t(17)),l=t(101);class c extends a.AreaView{_index_data(t){const{min:s,max:e}=Math,{data_size:i}=this;for(let h=0;h=0;s--)t.lineTo(i[s],n[s]);t.closePath(),this.visuals.fill.apply(t),this.visuals.hatch.apply(t)}scenterxy(t){return[this.sx[t],(this.sy1[t]+this.sy2[t])/2]}_hit_point(t){const s=this.sx.length,e=new l.Selection;for(let i=0,h=s-1;i({x:[o.XCoordinateSpec,{field:\"x\"}],y1:[o.YCoordinateSpec,{field:\"y1\"}],y2:[o.YCoordinateSpec,{field:\"y2\"}]})))},\n", - " function _(e,i,t,s,n){var c;s();const o=e(50),_=e(54),r=e(23),l=e(216),a=e(217),d=e(218);class h extends _.View{initialize(){super.initialize(),this.compute_indices()}connect_signals(){super.connect_signals();const{filter:e}=this.model.properties;this.on_change(e,(()=>this.compute_indices()));const i=()=>{const e=()=>this.compute_indices(),i=this.parent.data_source.get_value();this.connect(i.change,e),this.connect(i.streaming,e),this.connect(i.patching,e),this.connect(i.properties.data.change,e)};i();const{data_source:t}=this.parent;this.on_change(t,(()=>{i()}))}compute_indices(){var e;const i=this.parent.data_source.get_value(),t=null!==(e=i.get_length())&&void 0!==e?e:1,s=r.Indices.all_set(t),n=this.model.filter.compute_indices(i);s.intersect(n),this.model.indices=s,this.model._indices_map_to_subset()}}t.CDSViewView=h,h.__name__=\"CDSViewView\";class p extends o.Model{constructor(e){super(e)}_indices_map_to_subset(){this._indices=[...this.indices],this.indices_map={};for(let e=0;ethis._indices[e]))}convert_selection_to_subset(e){return e.map((e=>this.indices_map[e]))}convert_indices_from_subset(e){return e.map((e=>this._indices[e]))}get filters(){const{filter:e}=this;return e instanceof d.IntersectionFilter?e.operands:e instanceof a.AllIndices?[]:[e]}set filters(e){0==e.length?this.filter=new a.AllIndices:1==e.length?this.filter=e[0]:this.filter=new d.IntersectionFilter({operands:e})}}t.CDSView=p,c=p,p.__name__=\"CDSView\",c.prototype.default_view=h,c.define((({Ref:e})=>({filter:[e(l.Filter),()=>new a.AllIndices]}))),c.internal((({Int:e,Dict:i,Ref:t,Nullable:s})=>({indices:[t(r.Indices)],indices_map:[i(e),{}],masked:[s(t(r.Indices)),null]})))},\n", - " function _(e,t,n,s,c){s();const o=e(50);class r extends o.Model{constructor(e){super(e)}}n.Filter=r,r.__name__=\"Filter\"},\n", - " function _(e,n,s,t,c){t();const l=e(216),i=e(23);class _ extends l.Filter{constructor(e){super(e)}compute_indices(e){var n;const s=null!==(n=e.get_length())&&void 0!==n?n:1;return i.Indices.all_set(s)}}s.AllIndices=_,_.__name__=\"AllIndices\"},\n", - " function _(e,t,n,r,s){var c;r();const i=e(216),o=e(23);class l extends i.Filter{constructor(e){super(e)}compute_indices(e){var t;const{operands:n}=this;if(0==n.length){const n=null!==(t=e.get_length())&&void 0!==t?t:1;return o.Indices.all_set(n)}{const[t,...r]=n.map((t=>t.compute_indices(e)));for(const e of r)t.intersect(e);return t}}}n.IntersectionFilter=l,c=l,l.__name__=\"IntersectionFilter\",c.define((({Array:e,Ref:t})=>({operands:[e(t(i.Filter))]})))},\n", - " function _(t,r,a,e,i){e(),i(\"BasicTickFormatter\",t(185).BasicTickFormatter),i(\"CategoricalTickFormatter\",t(166).CategoricalTickFormatter),i(\"DatetimeTickFormatter\",t(169).DatetimeTickFormatter),i(\"CustomJSTickFormatter\",t(220).CustomJSTickFormatter),i(\"LogTickFormatter\",t(187).LogTickFormatter),i(\"MercatorTickFormatter\",t(190).MercatorTickFormatter),i(\"NumeralTickFormatter\",t(221).NumeralTickFormatter),i(\"PrintfTickFormatter\",t(222).PrintfTickFormatter),i(\"TickFormatter\",t(162).TickFormatter)},\n", - " function _(t,e,s,n,r){var c;n();const i=t(162),a=t(9),o=t(38);class u extends i.TickFormatter{constructor(t){super(t)}get names(){return(0,a.keys)(this.args)}get values(){return(0,a.values)(this.args)}_make_func(){const t=(0,o.use_strict)(this.code);return new Function(\"tick\",\"index\",\"ticks\",...this.names,t)}doFormat(t,e){const s=this._make_func().bind({});return t.map(((t,e,n)=>`${s(t,e,n,...this.values)}`))}}s.CustomJSTickFormatter=u,c=u,u.__name__=\"CustomJSTickFormatter\",c.define((({Unknown:t,String:e,Dict:s})=>({args:[s(t),{}],code:[e,\"\"]})))},\n", - " function _(r,n,t,o,e){var a;o();const u=r(1).__importStar(r(171)),c=r(162),i=r(19);class s extends c.TickFormatter{constructor(r){super(r)}get _rounding_fn(){switch(this.rounding){case\"round\":case\"nearest\":return Math.round;case\"floor\":case\"rounddown\":return Math.floor;case\"ceil\":case\"roundup\":return Math.ceil}}doFormat(r,n){const{format:t,language:o,_rounding_fn:e}=this;return r.map((r=>u.format(r,t,o,e)))}}t.NumeralTickFormatter=s,a=s,s.__name__=\"NumeralTickFormatter\",a.define((({String:r})=>({format:[r,\"0,0\"],language:[r,\"en\"],rounding:[i.RoundingFunction,\"round\"]})))},\n", - " function _(t,r,n,o,a){var e;o();const i=t(162),s=t(170);class c extends i.TickFormatter{constructor(t){super(t)}doFormat(t,r){return t.map((t=>(0,s.sprintf)(this.format,t)))}}n.PrintfTickFormatter=c,e=c,c.__name__=\"PrintfTickFormatter\",e.define((({String:t})=>({format:[t,\"%s\"]})))},\n", - " function _(a,e,l,c,n){c(),n(\"CategoricalScale\",a(92).CategoricalScale),n(\"ContinuousScale\",a(90).ContinuousScale),n(\"LinearScale\",a(89).LinearScale),n(\"LinearInterpolationScale\",a(224).LinearInterpolationScale),n(\"LogScale\",a(91).LogScale),n(\"Scale\",a(85).Scale)},\n", - " function _(e,r,n,t,a){var i;t();const s=e(85),o=e(89),c=e(13);class _ extends s.Scale{constructor(e){super(e)}initialize(){super.initialize();const{source_range:e,target_range:r}=this.properties;e.is_unset||r.is_unset||(this.linear_scale=new o.LinearScale({source_range:e.get_value(),target_range:r.get_value()}))}connect_signals(){super.connect_signals();const{source_range:e,target_range:r}=this.properties;this.on_change([e,r],(()=>{this.linear_scale=new o.LinearScale({source_range:this.source_range,target_range:this.target_range})}))}get s_compute(){throw new Error(\"not implemented\")}get s_invert(){throw new Error(\"not implemented\")}compute(e){return e}v_compute(e){const{binning:r}=this,{start:n,end:t}=this.source_range,a=n,i=t,s=r.length,o=(t-n)/(s-1),_=new Float64Array(s);for(let e=0;e{if(ei)return i;const n=(0,c.left_edge_index)(e,r);if(-1==n)return a;if(n>=s-1)return i;const t=r[n],o=(e-t)/(r[n+1]-t),l=_[n];return l+o*(_[n+1]-l)}));return this.linear_scale.v_compute(l)}invert(e){return e}v_invert(e){return new Float64Array(e)}}n.LinearInterpolationScale=_,i=_,_.__name__=\"LinearInterpolationScale\",i.internal((({Number:e,Arrayable:r,Ref:n})=>({binning:[r(e)],linear_scale:[n(o.LinearScale)]})))},\n", - " function _(a,n,e,g,R){g(),R(\"DataRange\",a(94).DataRange),R(\"DataRange1d\",a(93).DataRange1d),R(\"FactorRange\",a(96).FactorRange),R(\"Range\",a(87).Range),R(\"Range1d\",a(88).Range1d)},\n", - " function _(a,o,t,i,e){i();var l=a(145);e(\"Sizeable\",l.Sizeable),e(\"SizingPolicy\",l.SizingPolicy);var n=a(146);e(\"Layoutable\",n.Layoutable),e(\"ContentLayoutable\",n.ContentLayoutable);var S=a(227);e(\"HStack\",S.HStack),e(\"VStack\",S.VStack);var c=a(228);e(\"Grid\",c.Grid),e(\"Row\",c.Row),e(\"Column\",c.Column)},\n", - " function _(t,e,h,i,r){i();const n=t(146),s=t(57),{max:o,round:c}=Math;class l extends n.Layoutable{constructor(){super(...arguments),this.children=[]}*[Symbol.iterator](){yield*this.children}}h.Stack=l,l.__name__=\"Stack\";class a extends l{_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=o(h,i.height)}return{width:e,height:h}}_set_geometry(t,e){if(super._set_geometry(t,e),t.is_empty)for(const t of this.children)t.set_geometry(new s.BBox);else{const e=this.absolute?t.top:0;let h=this.absolute?t.left:0;const{height:i}=t;for(const t of this.children){const{width:r}=t.measure({width:0,height:0});t.set_geometry(new s.BBox({left:h,width:r,top:e,height:i})),h+=r}}}}h.HStack=a,a.__name__=\"HStack\";class d extends l{_measure(t){let e=0,h=0;for(const t of this.children){const i=t.measure({width:0,height:0});e=o(e,i.width),h+=i.height}return{width:e,height:h}}_set_geometry(t,e){if(super._set_geometry(t,e),t.is_empty)for(const t of this.children)t.set_geometry(new s.BBox);else{const e=this.absolute?t.left:0;let h=this.absolute?t.top:0;const{width:i}=t;for(const t of this.children){const{height:r}=t.measure({width:0,height:0});t.set_geometry(new s.BBox({top:h,height:r,left:e,width:i})),h+=r}}}}h.VStack=d,d.__name__=\"VStack\";class g 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,s=0;for(const e of this.children){const{width:h,height:i}=e.measure(t);n=r(n,h),s=r(s,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:s;switch(h){case\"fixed\":return null!=e?e:s;case\"min\":return s;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){if(super._set_geometry(t,e),t.is_empty)for(const t of this.children)t.set_geometry(new s.BBox);else{const e=this.absolute?t:t.relative(),{left:h,right:i,top:r,bottom:n}=e,o=c(e.vcenter),l=c(e.hcenter);for(const e of this.children){const{margin:c,halign:a=\"start\",valign:d=\"start\"}=e.sizing,{width:g,height:u,inner:_}=e.measure(t),w=(()=>{switch(`${d}_${a}`){case\"start_start\":return new s.BBox({left:h+c.left,top:r+c.top,width:g,height:u});case\"start_center\":return new s.BBox({hcenter:l,top:r+c.top,width:g,height:u});case\"start_end\":return new s.BBox({right:i-c.right,top:r+c.top,width:g,height:u});case\"center_start\":return new s.BBox({left:h+c.left,vcenter:o,width:g,height:u});case\"center_center\":return new s.BBox({hcenter:l,vcenter:o,width:g,height:u});case\"center_end\":return new s.BBox({right:i-c.right,vcenter:o,width:g,height:u});case\"end_start\":return new s.BBox({left:h+c.left,bottom:n-c.bottom,width:g,height:u});case\"end_center\":return new s.BBox({hcenter:l,bottom:n-c.bottom,width:g,height:u});case\"end_end\":return new s.BBox({right:i-c.right,bottom:n-c.bottom,width:g,height:u})}})(),m=null==_?w:new s.BBox({left:w.left+_.left,top:w.top+_.top,right:w.right-_.right,bottom:w.bottom-_.bottom});e.set_geometry(w,m)}}}}h.NodeLayout=g,g.__name__=\"NodeLayout\"},\n", - " function _(t,i,s,e,o){e();const n=t(145),r=t(146),l=t(8),h=t(57),c=t(10),{max:a,round:g}=Math;class p{constructor(t){this._map=new Map,this.def=t}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))}}s.DefaultMap=p,p.__name__=\"DefaultMap\";class _{constructor(){this._items=[],this._nrows=0,this._ncols=0}get size(){return this._items.length}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))}*[Symbol.iterator](){yield*this._items}foreach(t){for(const{span:i,data:s}of this._items)t(i,s)}map(t){const i=new _;for(const{span:s,data:e}of this._items)i.add(s,t(s,e));return i}}s.Container=_,_.__name__=\"Container\";class f extends r.Layoutable{*[Symbol.iterator](){for(const{layout:t}of this.items)yield t}constructor(t=[]){super(),this.rows=\"auto\",this.cols=\"auto\",this.spacing=0,this.items=t}is_width_expanding(){if(super.is_width_expanding())return!0;if(\"fixed\"==this.sizing.width_policy)return!1;const{cols:t}=this._state;return(0,c.some)(t,(t=>\"max\"==t.policy))}is_height_expanding(){if(super.is_height_expanding())return!0;if(\"fixed\"==this.sizing.height_policy)return!1;const{rows:t}=this._state;return(0,c.some)(t,(t=>\"max\"==t.policy))}_init(){var t,i,s,e;super._init();const o=new _;for(const{layout:t,row:i,col:s,row_span:e=1,col_span:n=1}of this.items)if(t.sizing.visible){const r=i,l=s,h=i+e-1,c=s+n-1;o.add({r0:r,c0:l,r1:h,c1:c},t)}const{nrows:n,ncols:r}=o,h=new Array(n);for(let s=0;s{var t;const i=(0,l.isPlainObject)(this.rows)?null!==(t=this.rows[s])&&void 0!==t?t:this.rows[\"*\"]:this.rows;return null==i?{policy:\"auto\"}:(0,l.isNumber)(i)?{policy:\"fixed\",height:i}:(0,l.isString)(i)?{policy:i}:i})(),n=null!==(t=e.align)&&void 0!==t?t:\"auto\";\"fixed\"==e.policy?h[s]={policy:\"fixed\",height:e.height,align:n}:\"min\"==e.policy?h[s]={policy:\"min\",align:n}:\"fit\"==e.policy||\"max\"==e.policy?h[s]={policy:e.policy,flex:null!==(i=e.flex)&&void 0!==i?i:1,align:n}:(0,c.some)(o.row(s),(t=>t.is_height_expanding()))?h[s]={policy:\"max\",flex:1,align:n}:h[s]={policy:\"min\",align:n}}const a=new Array(r);for(let t=0;t{var i;const s=(0,l.isPlainObject)(this.cols)?null!==(i=this.cols[t])&&void 0!==i?i:this.cols[\"*\"]:this.cols;return null==s?{policy:\"auto\"}:(0,l.isNumber)(s)?{policy:\"fixed\",width:s}:(0,l.isString)(s)?{policy:s}:s})(),n=null!==(s=i.align)&&void 0!==s?s:\"auto\";\"fixed\"==i.policy?a[t]={policy:\"fixed\",width:i.width,align:n}:\"min\"==i.policy?a[t]={policy:\"min\",align:n}:\"fit\"==i.policy||\"max\"==i.policy?a[t]={policy:i.policy,flex:null!==(e=i.flex)&&void 0!==e?e:1,align:n}:(0,c.some)(o.col(t),(t=>t.is_width_expanding()))?a[t]={policy:\"max\",flex:1,align:n}:a[t]={policy:\"min\",align:n}}const[g,p]=(0,l.isNumber)(this.spacing)?[this.spacing,this.spacing]:this.spacing;this._state={items:o,nrows:n,ncols:r,rows:h,cols:a,rspacing:g,cspacing:p}}_measure_totals(t,i){const{nrows:s,ncols:e,rspacing:o,cspacing:n}=this._state;return{height:(0,c.sum)(t)+(s-1)*o,width:(0,c.sum)(i)+(e-1)*n}}_measure_cells(t){const{items:i,nrows:s,ncols:e,rows:o,cols:r,rspacing:l,cspacing:h}=this._state,c=new Array(s);for(let t=0;t{const{r0:e,c0:_,r1:d,c1:u}=i,w=(d-e)*l,m=(u-_)*h;let y=0;for(let i=e;i<=d;i++)y+=t(i,_).height;y+=w;let x=0;for(let i=_;i<=u;i++)x+=t(e,i).width;x+=m;const b=s.measure({width:x,height:y});f.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=_;t<=u;t++){const i=r[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:f}}_measure_grid(t){const{nrows:i,ncols:s,rows:e,cols:o,rspacing:n,cspacing:r}=this._state,l=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:l.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:l.size.width;let _=0;for(let t=0;t0)for(let t=0;ts?s:o,t--}}}const{row_heights:f,col_widths:d,size_hints:u}=this._measure_cells(((t,i)=>({width:l.col_widths[i],height:l.row_heights[t]})));return{size:this._measure_totals(f,d),row_heights:f,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:r,col_widths:l,size_hints:c}=this._measure_grid(t),_=this._state.rows.map(((t,i)=>Object.assign(Object.assign({},t),{top:0,height:r[i],get bottom(){return this.top+this.height}}))),f=this._state.cols.map(((t,i)=>Object.assign(Object.assign({},t),{left:0,width:l[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:this.position.top;i{const{layout:l,size_hint:c}=r,{sizing:a}=l,{width:p,height:d}=c,u=function(t,i){let s=(i-t)*n;for(let e=t;e<=i;e++)s+=f[e].width;return s}(i,e),w=function(t,i){let s=(i-t)*o;for(let e=t;e<=i;e++)s+=_[e].height;return s}(t,s),m=i==e&&\"auto\"!=f[i].align?f[i].align:a.halign,y=t==s&&\"auto\"!=_[t].align?_[t].align:a.valign;let x=f[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=_[t].top;\"start\"==y?b+=a.margin.top:\"center\"==y?b+=g((w-d)/2):\"end\"==y&&(b+=w-a.margin.bottom-d),r.outer=new h.BBox({left:x,top:b,width:p,height:d})}));const u=_.map((()=>({start:new p((()=>0)),end:new p((()=>0))}))),w=f.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:r}=o;null!=r&&(u[t].start.apply(n.top,(t=>a(t,r.top))),u[s].end.apply(_[s].bottom-n.bottom,(t=>a(t,r.bottom))),w[i].start.apply(n.left,(t=>a(t,r.left))),w[e].end.apply(f[e].right-n.right,(t=>a(t,r.right))))})),d.foreach((({r0:t,c0:i,r1:s,c1:e},o)=>{const{size_hint:n,outer:r}=o,l=t=>{const i=this.absolute?r:r.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=l(n.inner);const c=u[t].start.get(r.top),a=u[s].end.get(_[s].bottom-r.bottom),g=w[i].start.get(r.left),p=w[e].end.get(f[e].right-r.right);try{h=l({top:c,bottom:a,left:g,right:p})}catch(t){}o.inner=h}else o.inner=r})),d.foreach(((t,{layout:i,outer:s,inner:e})=>{i.set_geometry(s,e)}))}}s.Grid=f,f.__name__=\"Grid\";class d extends f{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 f{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 _(t,e,i,h,o){h();const n=t(145),s=t(146),r=t(57);class l extends s.Layoutable{constructor(){super(...arguments),this.aligns={left:!0,right:!0,top:!0,bottom:!0},this.min_border={left:0,top:0,right:0,bottom:0},this.padding={left:0,top:0,right:0,bottom:0},this.center_border_width=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 n.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,s=this.top_panel.measure({width:t.width,height:0}),r=Math.max(s.height,this.min_border.top)+this.padding.top,l=this.bottom_panel.measure({width:t.width,height:0}),_=Math.max(l.height,this.min_border.bottom)+this.padding.bottom,g=new n.Sizeable(t).shrink_by({left:i,right:o,top:r,bottom:_}),a=this.center_panel.measure(g);return{width:i+a.width+o,height:r+a.height+_,inner:{left:i,right:o,top:r,bottom:_},align:(()=>{const{width_policy:t,height_policy:e}=this.center_panel.sizing;return Object.assign(Object.assign({},this.aligns),{fixed_width:\"fixed\"==t,fixed_height:\"fixed\"==e})})()}}_set_geometry(t,e){var i,h,o,n;if(super._set_geometry(t,e),this.sizing.visible){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}),n=this.bottom_panel.measure({width:t.width,height:0}),{left:s,top:l,right:_,bottom:g}=e;this.top_panel.set_geometry(new r.BBox({left:s,right:_,bottom:l,height:o.height})),this.bottom_panel.set_geometry(new r.BBox({left:s,right:_,top:g,height:n.height})),this.left_panel.set_geometry(new r.BBox({top:l,bottom:g,right:s,width:i.width})),this.right_panel.set_geometry(new r.BBox({top:l,bottom:g,left:_,width:h.width}));const a=e.shrink_by(this.center_border_width);if(null!=this.inner_top_panel){const{left:t,right:e,top:i,width:h}=a,o=this.inner_top_panel.measure({width:h,height:0});this.inner_top_panel.set_geometry(new r.BBox({left:t,right:e,top:i,height:o.height}))}if(null!=this.inner_bottom_panel){const{left:t,right:e,bottom:i,width:h}=a,o=this.inner_bottom_panel.measure({width:h,height:0});this.inner_bottom_panel.set_geometry(new r.BBox({left:t,right:e,bottom:i,height:o.height}))}if(null!=this.inner_left_panel){const{top:t,bottom:e,left:i,height:h}=a,o=this.inner_left_panel.measure({width:0,height:h});this.inner_left_panel.set_geometry(new r.BBox({top:t,bottom:e,left:i,width:o.width}))}if(null!=this.inner_right_panel){const{top:t,bottom:e,right:i,height:h}=a,o=this.inner_right_panel.measure({width:0,height:h});this.inner_right_panel.set_geometry(new r.BBox({top:t,bottom:e,right:i,width:o.width}))}}else this.center_panel.set_geometry(new r.BBox),this.top_panel.set_geometry(new r.BBox),this.bottom_panel.set_geometry(new r.BBox),this.left_panel.set_geometry(new r.BBox),this.right_panel.set_geometry(new r.BBox),null===(i=this.inner_top_panel)||void 0===i||i.set_geometry(new r.BBox),null===(h=this.inner_bottom_panel)||void 0===h||h.set_geometry(new r.BBox),null===(o=this.inner_left_panel)||void 0===o||o.set_geometry(new r.BBox),null===(n=this.inner_right_panel)||void 0===n||n.set_geometry(new r.BBox)}}i.BorderLayout=l,l.__name__=\"BorderLayout\"},\n", - " function _(e,s,_,i,l){var t;i();const o=e(1),r=e(231),p=o.__importStar(e(78));class h extends r.UpperLowerView{paint(e){e.beginPath(),e.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let s=0,_=this._lower_sx.length;s<_;s++)e.lineTo(this._lower_sx[s],this._lower_sy[s]);for(let s=this._upper_sx.length-1;s>=0;s--)e.lineTo(this._upper_sx[s],this._upper_sy[s]);e.closePath(),this.visuals.fill.apply(e),e.beginPath(),e.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let s=0,_=this._lower_sx.length;s<_;s++)e.lineTo(this._lower_sx[s],this._lower_sy[s]);this.visuals.line.apply(e),e.beginPath(),e.moveTo(this._upper_sx[0],this._upper_sy[0]);for(let s=0,_=this._upper_sx.length;s<_;s++)e.lineTo(this._upper_sx[s],this._upper_sy[s]);this.visuals.line.apply(e)}}_.BandView=h,h.__name__=\"BandView\";class n extends r.UpperLower{constructor(e){super(e)}}_.Band=n,t=n,n.__name__=\"Band\",t.prototype.default_view=h,t.mixins([p.Line,p.Fill]),t.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})},\n", - " function _(e,t,s,r,i){var n;r();const a=e(1),o=e(98),_=e(23),c=e(19),p=a.__importStar(e(17));class u extends o.DataAnnotationView{map_data(){const{frame:e}=this.plot_view,t=this.model.dimension,s=this.coordinates.x_scale,r=this.coordinates.y_scale,i=\"height\"==t?r:s,n=\"height\"==t?s:r,a=\"height\"==t?e.bbox.yview:e.bbox.xview,o=\"height\"==t?e.bbox.xview:e.bbox.yview,c=(()=>{switch(this.model.properties.lower.units){case\"canvas\":return new _.ScreenArray(this._lower);case\"screen\":return a.v_compute(this._lower);case\"data\":return i.v_compute(this._lower)}})(),p=(()=>{switch(this.model.properties.upper.units){case\"canvas\":return new _.ScreenArray(this._upper);case\"screen\":return a.v_compute(this._upper);case\"data\":return i.v_compute(this._upper)}})(),u=(()=>{switch(this.model.properties.base.units){case\"canvas\":return new _.ScreenArray(this._base);case\"screen\":return o.v_compute(this._base);case\"data\":return n.v_compute(this._base)}})(),[h,d]=\"height\"==t?[1,0]:[0,1],w=[c,u],l=[p,u];this._lower_sx=w[h],this._lower_sy=w[d],this._upper_sx=l[h],this._upper_sy=l[d]}}s.UpperLowerView=u,u.__name__=\"UpperLowerView\";class h extends p.CoordinateSpec{constructor(){super(...arguments),this._value=p.unset}get dimension(){return\"width\"==this.obj.dimension?\"x\":\"y\"}get units(){var e;return this._value===p.unset?\"data\":null!==(e=this._value.units)&&void 0!==e?e:\"data\"}}s.XOrYCoordinateSpec=h,h.__name__=\"XOrYCoordinateSpec\";class d extends o.DataAnnotation{constructor(e){super(e)}}s.UpperLower=d,n=d,d.__name__=\"UpperLower\",n.define((()=>({dimension:[c.Dimension,\"height\"],lower:[h,{field:\"lower\"}],upper:[h,{field:\"upper\"}],base:[h,{field:\"base\"}]})))},\n", - " function _(t,e,o,i,r){var s,n;i();const l=t(1),a=t(73),h=t(93),_=l.__importStar(t(78)),u=t(19),c=t(57),b=t(20),m=t(15),d=t(12),p=t(233),f=t(234),v=l.__importStar(t(235));o.EDGE_TOLERANCE=2.5;const{abs:g}=Math,x=(0,b.Enum)(\"none\",\"left\",\"right\",\"top\",\"bottom\",\"x\",\"y\",\"all\"),w=(0,b.Enum)(\"none\",\"x\",\"y\",\"both\");class y extends a.AnnotationView{constructor(){super(...arguments),this.bbox=new c.BBox,this[s]=!0,this._pan_state=null,this._pinch_state=null,this._is_hovered=!1}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.bbox.round()})}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}bounds(){const{left:t,left_units:e,right:o,right_units:i,top:r,top_units:s,bottom:n,bottom_units:l}=this.model,a=\"data\"==e&&null!=t,h=\"data\"==i&&null!=o,_=\"data\"==s&&null!=r,u=\"data\"==l&&null!=n,[c,b]=a&&h?t<=o?[t,o]:[o,t]:a?[t,t]:h?[o,o]:[NaN,NaN],[m,d]=_&&u?r<=n?[r,n]:[n,r]:_?[r,r]:u?[n,n]:[NaN,NaN];return{x0:c,x1:b,y0:m,y1:d}}log_bounds(){return(0,c.empty)()}get mappers(){function t(t,e,o,i){switch(t){case\"canvas\":return i;case\"screen\":return o;case\"data\":return e}}const e=this.model,{x_scale:o,y_scale:i}=this.coordinates,{x_view:r,y_view:s}=this.plot_view.frame.bbox,{x_screen:n,y_screen:l}=this.plot_view.canvas.bbox;return{left:t(e.left_units,o,r,n),right:t(e.right_units,o,r,n),top:t(e.top_units,i,s,l),bottom:t(e.bottom_units,i,s,l)}}_render(){function t(t,e,o){return null==t?o:e.compute(t)}const{left:e,right:o,top:i,bottom:r}=this.model,{frame:s}=this.plot_view,{mappers:n}=this;this.bbox=c.BBox.from_lrtb({left:t(e,n.left,s.bbox.left),right:t(o,n.right,s.bbox.right),top:t(i,n.top,s.bbox.top),bottom:t(r,n.bottom,s.bbox.bottom)}),this.bbox.is_valid&&this._paint_box()}get border_radius(){return v.border_radius(this.model.border_radius)}_paint_box(){const{ctx:t}=this.layer;t.save(),t.beginPath(),(0,f.round_rect)(t,this.bbox,this.border_radius);const{_is_hovered:e,visuals:o}=this,i=e&&o.hover_fill.doit?o.hover_fill:o.fill,r=e&&o.hover_hatch.doit?o.hover_hatch:o.hatch,s=e&&o.hover_line.doit?o.hover_line:o.line;i.apply(t),r.apply(t),s.apply(t),t.restore()}interactive_bbox(){const t=this.model.line_width+o.EDGE_TOLERANCE;return this.bbox.grow_by(t)}interactive_hit(t,e){if(!this.model.visible||!this.model.editable)return!1;return this.interactive_bbox().contains(t,e)}_hit_test(t,e){const{left:i,right:r,bottom:s,top:n}=this.bbox,l=Math.max(o.EDGE_TOLERANCE,this.model.line_width/2),a=g(i-t),h=g(r-t),_=g(n-e),u=g(s-e),c=a{const{dx:e,dy:o}=t,{bbox:i,target:r}=this._pan_state,{left:s,top:n,right:l,bottom:a}=i,{symmetric:h}=this.model,[_,u]=h?[-e,-o]:[0,0],[b,m,d,p]=(()=>{switch(r){case\"top_left\":return[e,_,o,u];case\"top_right\":return[_,e,o,u];case\"bottom_left\":return[e,_,u,o];case\"bottom_right\":return[_,e,u,o];case\"left\":return[e,_,0,0];case\"right\":return[_,e,0,0];case\"top\":return[0,0,o,u];case\"bottom\":return[0,0,u,o];case\"area\":switch(this.model.movable){case\"both\":return[e,e,o,o];case\"x\":return[e,e,0,0];case\"y\":return[0,0,o,o];case\"none\":return[0,0,0,0]}}})();return c.BBox.from_lrtb({left:s+b,right:l+m,top:n+d,bottom:a+p})})(),{mappers:o}=this,i={left:null==this.model.left?null:o.left.invert(e.left),right:null==this.model.right?null:o.right.invert(e.right),top:null==this.model.top?null:o.top.invert(e.top),bottom:null==this.model.bottom?null:o.bottom.invert(e.bottom)};this.model.update(i),this.model.pan.emit([\"pan\",t])}_pan_end(t){this._pan_state=null,this.model.pan.emit([\"pan:end\",t])}_pinch_start(t){if(this.model.visible&&this.model.editable&&\"none\"!=this.model.resizable){const{sx:e,sy:o}=t;if(this.bbox.contains(e,o))return this._pinch_state={bbox:this.bbox.clone()},this.model.pan.emit([\"pan:start\",t]),!0}return!1}_pinch(t){(0,d.assert)(null!=this._pinch_state);const e=(()=>{const{scale:e}=t,{bbox:o}=this._pinch_state,{left:i,top:r,right:s,bottom:n,width:l,height:a}=o,h=l*(e-1),_=a*(e-1),{resizable:u}=this,b=u.left?-h/2:0,m=u.right?h/2:0,d=u.top?-_/2:0,p=u.bottom?_/2:0;return c.BBox.from_lrtb({left:i+b,right:s+m,top:r+d,bottom:n+p})})(),{mappers:o}=this,i={left:null==this.model.left?null:o.left.invert(e.left),right:null==this.model.right?null:o.right.invert(e.right),top:null==this.model.top?null:o.top.invert(e.top),bottom:null==this.model.bottom?null:o.bottom.invert(e.bottom)};this.model.update(i),this.model.pan.emit([\"pan\",t])}_pinch_end(t){this._pinch_state=null,this.model.pan.emit([\"pan:end\",t])}get _has_hover(){const{hover_line:t,hover_fill:e,hover_hatch:o}=this.visuals;return t.doit||e.doit||o.doit}_move_start(t){const{_has_hover:e}=this;return e&&(this._is_hovered=!0,this.request_paint()),e}_move(t){}_move_end(t){this._has_hover&&(this._is_hovered=!1,this.request_paint())}cursor(t,e){var o,i;const r=null!==(i=null===(o=this._pan_state)||void 0===o?void 0:o.target)&&void 0!==i?i:this._hit_test(t,e);if(null==r||!this._can_hit(r))return null;switch(r){case\"top_left\":return this.model.tl_cursor;case\"top_right\":return this.model.tr_cursor;case\"bottom_left\":return this.model.bl_cursor;case\"bottom_right\":return this.model.br_cursor;case\"left\":case\"right\":return this.model.ew_cursor;case\"top\":case\"bottom\":return this.model.ns_cursor;case\"area\":switch(this.model.movable){case\"both\":return this.model.in_cursor;case\"x\":return this.model.ew_cursor;case\"y\":return this.model.ns_cursor;case\"none\":return null}}}}o.BoxAnnotationView=y,s=h.auto_ranged,y.__name__=\"BoxAnnotationView\";class z extends a.Annotation{constructor(t){super(t),this.pan=new m.Signal(this,\"pan\")}update({left:t,right:e,top:o,bottom:i}){this.setv({left:t,right:e,top:o,bottom:i,visible:!0})}clear(){this.visible=!1}}o.BoxAnnotation=z,n=z,z.__name__=\"BoxAnnotation\",n.prototype.default_view=y,n.mixins([_.Line,_.Fill,_.Hatch,[\"hover_\",_.Line],[\"hover_\",_.Fill],[\"hover_\",_.Hatch]]),n.define((({Boolean:t,Number:e,Nullable:o})=>({top:[o(e),null],bottom:[o(e),null],left:[o(e),null],right:[o(e),null],top_units:[u.CoordinateUnits,\"data\"],bottom_units:[u.CoordinateUnits,\"data\"],left_units:[u.CoordinateUnits,\"data\"],right_units:[u.CoordinateUnits,\"data\"],border_radius:[p.BorderRadius,0],editable:[t,!1],resizable:[x,\"all\"],movable:[w,\"both\"],symmetric:[t,!1]}))),n.internal((({String:t})=>({tl_cursor:[t,\"nwse-resize\"],tr_cursor:[t,\"nesw-resize\"],bl_cursor:[t,\"nesw-resize\"],br_cursor:[t,\"nwse-resize\"],ew_cursor:[t,\"ew-resize\"],ns_cursor:[t,\"ns-resize\"],in_cursor:[t,\"move\"]}))),n.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3,hover_fill_color:null,hover_fill_alpha:.4,hover_line_color:null,hover_line_alpha:.3})},\n", - " function _(t,n,e,r,i){r();const g=t(1),a=t(20),h=g.__importStar(t(19));e.Length=(0,a.NonNegative)(a.Int);var c;e.Anchor=(0,a.Or)(h.Anchor,(0,a.Tuple)((0,a.Or)(h.Align,h.HAlign,a.Percent),(0,a.Or)(h.Align,h.VAlign,a.Percent))),e.TextAnchor=(0,a.Or)(e.Anchor,a.Auto),e.Padding=(0,a.Or)(e.Length,(0,a.Tuple)(e.Length,e.Length),(c=e.Length,(0,a.PartialStruct)({x:c,y:c})),(0,a.Tuple)(e.Length,e.Length,e.Length,e.Length),(t=>(0,a.PartialStruct)({left:t,right:t,top:t,bottom:t}))(e.Length)),e.BorderRadius=(0,a.Or)(e.Length,(0,a.Tuple)(e.Length,e.Length,e.Length,e.Length),(0,a.PartialStruct)({top_left:e.Length,top_right:e.Length,bottom_right:e.Length,bottom_left:e.Length})),e.Index=(0,a.NonNegative)(a.Int),e.Span=(0,a.NonNegative)(a.Int);e.GridChild=t=>(0,a.Tuple)((0,a.Ref)(t),e.Index,e.Index,(0,a.Opt)(e.Span),(0,a.Opt)(e.Span)),e.GridSpacing=(0,a.Or)(e.Length,(0,a.Tuple)(e.Length,e.Length)),e.TrackAlign=(0,a.Enum)(\"start\",\"center\",\"end\",\"auto\"),e.TrackSize=a.String,e.TrackSizing=(0,a.PartialStruct)({size:e.TrackSize,align:e.TrackAlign}),e.TrackSizingLike=(0,a.Or)(e.TrackSize,e.TrackSizing),e.TracksSizing=(0,a.Or)(e.TrackSizingLike,(0,a.Array)(e.TrackSizingLike),(0,a.Map)(a.Int,e.TrackSizingLike))},\n", - " function _(t,o,e,i,n){i(),e.round_rect=function(t,o,e){let{top_left:i,top_right:n,bottom_right:c,bottom_left:h}=e;if(0!=i||0!=n||0!=c||0!=h){const{left:e,right:l,top:r,bottom:T,width:f,height:a}=o,_=Math.min(f/(i+n),a/(n+c),f/(c+h),a/(i+h));_<1&&(i*=_,n*=_,c*=_,h*=_),t.moveTo(e+i,r),t.lineTo(l-n,r),t.arcTo(l,r,l,r+n,n),t.lineTo(l,T-c),t.arcTo(l,T,l-c,T,c),t.lineTo(e+h,T),t.arcTo(e,T,e,T-h,h),t.lineTo(e,r+i),t.arcTo(e,r,e+i,r,i),t.closePath()}else{const{left:e,top:i,width:n,height:c}=o;t.rect(e,i,n,c)}}},\n", - " function _(t,e,r,n,o){n();const c=t(8),i=t(12);function s(t){if(!(0,c.isString)(t)){return{x:(()=>{const[e]=t;switch(e){case\"start\":case\"left\":return 0;case\"center\":return.5;case\"end\":case\"right\":return 1;default:return e}})(),y:(()=>{const[,e]=t;switch(e){case\"start\":case\"top\":return 0;case\"center\":return.5;case\"end\":case\"bottom\":return 1;default:return e}})()}}switch(t){case\"top_left\":return{x:0,y:0};case\"top\":case\"top_center\":return{x:.5,y:0};case\"top_right\":return{x:1,y:0};case\"right\":case\"center_right\":return{x:1,y:.5};case\"bottom_right\":return{x:1,y:1};case\"bottom\":case\"bottom_center\":return{x:.5,y:1};case\"bottom_left\":return{x:0,y:1};case\"left\":case\"center_left\":return{x:0,y:.5};case\"center\":case\"center_center\":return{x:.5,y:.5}}}r.anchor=s,r.text_anchor=function(t,e,r){return s(\"auto\"!=t?t:[(()=>{switch(e){case\"left\":return\"start\";case\"center\":return\"center\";case\"right\":return\"end\"}})(),(()=>{switch(r){case\"alphabetic\":case\"ideographic\":case\"hanging\":case\"middle\":return\"center\";case\"top\":return\"start\";case\"bottom\":return\"end\"}})()])},r.padding=function(t){if((0,c.isNumber)(t))return{left:t,right:t,top:t,bottom:t};if(!(0,c.isPlainObject)(t)){if(2==t.length){const[e=0,r=0]=t;return{left:e,right:e,top:r,bottom:r}}{const[e=0,r=0,n=0,o=0]=t;return{left:e,right:r,top:n,bottom:o}}}if(\"x\"in t||\"y\"in t){const{x:e=0,y:r=0}=t;return{left:e,right:e,top:r,bottom:r}}if(\"left\"in t||\"right\"in t||\"top\"in t||\"bottom\"in t){const{left:e=0,right:r=0,top:n=0,bottom:o=0}=t;return{left:e,right:r,top:n,bottom:o}}(0,i.unreachable)()},r.border_radius=function(t){var e,r,n,o;if((0,c.isNumber)(t))return{top_left:t,top_right:t,bottom_right:t,bottom_left:t};if((0,c.isPlainObject)(t))return{top_left:null!==(e=t.top_left)&&void 0!==e?e:0,top_right:null!==(r=t.top_right)&&void 0!==r?r:0,bottom_right:null!==(n=t.bottom_right)&&void 0!==n?n:0,bottom_left:null!==(o=t.bottom_left)&&void 0!==o?o:0};{const[e=0,r=0,n=0,o=0]=t;return{top_left:e,top_right:r,bottom_right:n,bottom_left:o}}}},\n", - " function _(e,i,n,t,a){var o;t();const l=e(141),r=e(158),s=e(219),_=e(197),c=e(237),h=e(225),p=e(223),g=e(192),m=e(10),u=e(12);class d extends l.BaseColorBarView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.color_mapper.change,(async()=>{this._title_view.remove(),this._axis_view.remove(),this.initialize(),await this.lazy_initialize(),this.plot_view.invalidate_layout()})),this.connect(this.model.color_mapper.metrics_change,(()=>this._metrics_changed())),this.connect(this.model.properties.display_low.change,(()=>this._metrics_changed())),this.connect(this.model.properties.display_high.change,(()=>this._metrics_changed()))}get color_mapper(){let e=this.model.color_mapper;return e instanceof c.WeightedStackColorMapper&&(e=e.alpha_mapper),e}update_layout(){super.update_layout(),this._set_canvas_image()}_create_axis(){const{color_mapper:e}=this;return e instanceof c.CategoricalColorMapper?new r.CategoricalAxis:e instanceof c.LogColorMapper?new r.LogAxis:new r.LinearAxis}_create_formatter(){const{color_mapper:e}=this;return this._ticker instanceof g.LogTicker?new s.LogTickFormatter:e instanceof c.CategoricalColorMapper?new s.CategoricalTickFormatter:new s.BasicTickFormatter}_create_major_range(){const{color_mapper:e}=this;if(e instanceof c.CategoricalColorMapper)return new h.FactorRange({factors:e.factors});if(e instanceof c.ContinuousColorMapper){const{min:i,max:n}=this._continuous_metrics(e);return new h.Range1d({start:i,end:n})}(0,u.unreachable)()}_create_major_scale(){const{color_mapper:e}=this;return e instanceof c.LinearColorMapper?new p.LinearScale:e instanceof c.LogColorMapper?new p.LogScale:e instanceof c.ScanningColorMapper?new p.LinearInterpolationScale({binning:this._scanning_binning(e)}):e instanceof c.CategoricalColorMapper?new p.CategoricalScale:void(0,u.unreachable)()}_create_ticker(){const{color_mapper:e}=this;return e instanceof c.LogColorMapper?new g.LogTicker:e instanceof c.ScanningColorMapper?new g.BinnedTicker({mapper:e}):e instanceof c.CategoricalColorMapper?new g.CategoricalTicker:new g.BasicTicker}_continuous_metrics(e){const{display_low:i,display_high:n}=this.model;let{min:t,max:a}=e.metrics;if(null!=n&&null!=i&&n0&&(this._index_low=n,t=e.index_to_value(n))}return{min:t,max:a}}_get_major_size_factor(){return this.color_mapper.palette.length}_metrics_changed(){const e=this._major_range,i=this._major_scale,{color_mapper:n}=this;if(n instanceof c.ScanningColorMapper&&i instanceof p.LinearInterpolationScale){const e=this._scanning_binning(n);i.binning=e;const t=\"vertical\"==this.orientation,a=t?this._frame.y_scale:this._frame.x_scale;if(a instanceof p.LinearInterpolationScale){a.binning=e;const i=t?this._frame.y_range:this._frame.x_range;i instanceof h.Range1d&&(i.start=e[0],i.end=e[e.length-1])}}else if(n instanceof c.ContinuousColorMapper&&e instanceof h.Range1d){const{min:i,max:t}=this._continuous_metrics(n);e.setv({start:i,end:t})}this._set_canvas_image(),this.plot_view.request_layout()}_paint_colors(e,i){const{x:n,y:t,width:a,height:o}=i;e.save(),e.globalAlpha=this.model.scale_alpha,null!=this._image&&(e.imageSmoothingEnabled=!1,e.drawImage(this._image,n,t,a,o)),this.visuals.bar_line.doit&&(this.visuals.bar_line.set_value(e),e.strokeRect(n,t,a,o)),e.restore()}_scanning_binning(e){let{binning:i,force_low_cutoff:n}=e.metrics;const{display_high:t}=this.model;let{display_low:a}=this.model;if(n&&(null==a||e.metrics.min>a)&&(a=e.metrics.min),null!=t&&null!=a&&t0&&(this._index_low=n)}if(null!=this._index_low||null!=this._index_high){const e=null!=this._index_low?this._index_low:0,n=(null!=this._index_high?this._index_high+1:i.length-1)-e+1;if(n>0){const t=new Array(n);for(let a=0;a({color_mapper:[n(_.ColorMapper)],display_low:[e(i),null],display_high:[e(i),null]})))},\n", - " function _(r,o,a,p,e){p(),e(\"CategoricalColorMapper\",r(238).CategoricalColorMapper),e(\"CategoricalMarkerMapper\",r(240).CategoricalMarkerMapper),e(\"CategoricalPatternMapper\",r(241).CategoricalPatternMapper),e(\"ContinuousColorMapper\",r(196).ContinuousColorMapper),e(\"ColorMapper\",r(197).ColorMapper),e(\"LinearColorMapper\",r(242).LinearColorMapper),e(\"LogColorMapper\",r(243).LogColorMapper),e(\"ScanningColorMapper\",r(195).ScanningColorMapper),e(\"EqHistColorMapper\",r(244).EqHistColorMapper),e(\"StackColorMapper\",r(245).StackColorMapper),e(\"WeightedStackColorMapper\",r(246).WeightedStackColorMapper)},\n", - " function _(t,o,r,a,e){var c;a();const s=t(239),l=t(197),n=t(96);class _ extends l.ColorMapper{constructor(t){super(t)}_v_compute(t,o,r,{nan_color:a}){(0,s.cat_v_compute)(t,this.factors,r,o,this.start,this.end,a)}}r.CategoricalColorMapper=_,c=_,_.__name__=\"CategoricalColorMapper\",c.define((({Number:t,Nullable:o})=>({factors:[n.FactorSeq],start:[t,0],end:[o(t),null]})))},\n", - " function _(n,t,e,i,l){i();const o=n(13),f=n(8);function c(n,t){if(n.length!=t.length)return!1;for(let e=0,i=n.length;ec(n,d)))),h=_<0||_>=e.length?u:e[_],i[g]=h}}},\n", - " function _(e,r,a,t,s){var c;t();const l=e(239),n=e(96),u=e(198),o=e(19);class p extends u.Mapper{constructor(e){super(e)}v_compute(e){const r=new Array(e.length);return(0,l.cat_v_compute)(e,this.factors,this.markers,r,this.start,this.end,this.default_value),r}}a.CategoricalMarkerMapper=p,c=p,p.__name__=\"CategoricalMarkerMapper\",c.define((({Number:e,Array:r,Nullable:a})=>({factors:[n.FactorSeq],markers:[r(o.MarkerType)],start:[e,0],end:[a(e),null],default_value:[o.MarkerType,\"circle\"]})))},\n", - " function _(t,e,a,r,n){var s;r();const c=t(239),l=t(96),p=t(198),u=t(19);class o extends p.Mapper{constructor(t){super(t)}v_compute(t){const e=new Array(t.length);return(0,c.cat_v_compute)(t,this.factors,this.patterns,e,this.start,this.end,this.default_value),e}}a.CategoricalPatternMapper=o,s=o,o.__name__=\"CategoricalPatternMapper\",s.define((({Number:t,Array:e,Nullable:a})=>({factors:[l.FactorSeq],patterns:[e(u.HatchPatternType)],start:[t,0],end:[a(t),null],default_value:[u.HatchPatternType,\" \"]})))},\n", - " function _(n,r,o,t,a){t();const e=n(196),i=n(13),s=n(11);class _ extends e.ContinuousColorMapper{constructor(n){super(n)}scan(n,r){const o=null!=this.low?this.low:(0,i.min)(n),t=null!=this.high?this.high:(0,i.max)(n);return{max:t,min:o,norm_factor:1/(t-o),normed_interval:1/r}}index_to_value(n){const r=this._scan_data;return r.min+r.normed_interval*n/r.norm_factor}value_to_index(n,r){const o=this._scan_data;if(n==o.max)return r-1;const t=(n-o.min)*o.norm_factor,a=Math.floor(t/o.normed_interval);return(0,s.clamp)(a,-1,r)}}o.LinearColorMapper=_,_.__name__=\"LinearColorMapper\"},\n", - " function _(n,t,a,o,s){o();const r=n(196),e=n(13),i=n(11);class l extends r.ContinuousColorMapper{constructor(n){super(n)}scan(n,t){const a=null!=this.low?this.low:(0,e.min)(n),o=null!=this.high?this.high:(0,e.max)(n);return{max:o,min:a,scale:t/Math.log(o/a)}}index_to_value(n){const t=this._scan_data;return t.min*Math.exp(n/t.scale)}value_to_index(n,t){const a=this._scan_data;if(n==a.max)return t-1;if(n>a.max)return t;if(n1?d=1-n:m=!1}const g=(0,c.linspace)(d,1,n+1),w=(0,r.interpolate)(g,f,h);let b=!1;if(m){const e=(0,r.sorted_index)(w,s);s0&&(w[e-1]=s),b=!0}else w[0]=s;return w[w.length-1]=t,{min:s,max:t,binning:w,force_low_cutoff:b}}}s.EqHistColorMapper=a,o=a,a.__name__=\"EqHistColorMapper\",o.define((({Boolean:e,Int:n})=>({bins:[n,65536],rescale_discrete_levels:[e,!1]})))},\n", - " function _(o,r,a,c,e){c();const p=o(197);class t extends p.ColorMapper{constructor(o){super(o)}}a.StackColorMapper=t,t.__name__=\"StackColorMapper\"},\n", - " function _(e,t,o,n,r){var l;n();const a=e(197),c=e(196),s=e(245),i=e(23),_=e(13),p=e(12),u=e(21);class h extends s.StackColorMapper{constructor(e){super(e)}_mix_colors(e,t,o,n){if(isNaN(n))return t;let r=0,l=0,a=0,c=0;const s=o.length;if(0!=n)for(let t=0;t({alpha_mapper:[o(c.ContinuousColorMapper)],color_baseline:[e(t),null]})))},\n", - " function _(e,t,r,i,l){var n;i();const o=e(141),s=e(225),a=e(199),_=e(59),h=e(12);class d extends o.BaseColorBarView{*children(){yield*super.children(),yield this._fill_view,yield this._line_view}async lazy_initialize(){await super.lazy_initialize();const{fill_renderer:e,line_renderer:t}=this.model;this._fill_view=await(0,_.build_view)(e,{parent:this.parent}),this._line_view=await(0,_.build_view)(t,{parent:this.parent})}remove(){this._fill_view.remove(),this._line_view.remove(),super.remove()}_create_major_range(){const e=this.model.levels;return e.length>0?new s.Range1d({start:e[0],end:e[e.length-1]}):new s.Range1d({start:0,end:1})}_paint_colors(e,t){const r=\"vertical\"==this.orientation,i=this.model.levels,l=this._major_scale;l.source_range=this._major_range,l.target_range=r?new s.Range1d({start:t.bottom,end:t.top}):new s.Range1d({start:t.left,end:t.right});const n=l.v_compute(i),o=this._fill_view.glyph,a=o.data_size;if(a>0){(0,h.assert)(i.length==a+1,\"Inconsistent number of filled contour levels\"),e.save();for(let i=0;i0){(0,h.assert)(i.length==d,\"Inconsistent number of line contour levels\"),e.save();for(let i=0;i({fill_renderer:[r(a.GlyphRenderer)],line_renderer:[r(a.GlyphRenderer)],levels:[e(t),[]]})))},\n", - " function _(e,t,s,i,n){var a;i();const o=e(143),l=e(11),h=e(19),u=e(144);class c extends o.TextAnnotationView{update_layout(){const{panel:e}=this;this.layout=null!=e?new u.SideLayout(e,(()=>this.get_size()),!1):void 0}_get_size(){if(!this.displayed)return{width:0,height:0};const e=this._text_view.graphics(),{angle:t,angle_units:s}=this.model;e.angle=(0,l.compute_angle)(t,s),e.visuals=this.visuals.text.values();const{width:i,height:n}=e.size();return{width:i,height:n}}_render(){const{angle:e,angle_units:t}=this.model,s=(0,l.compute_angle)(e,t),i=null!=this.layout?this.layout:this.plot_view.frame,n=this.coordinates.x_scale,a=this.coordinates.y_scale;let o=(()=>{switch(this.model.x_units){case\"canvas\":return this.model.x;case\"screen\":return i.bbox.xview.compute(this.model.x);case\"data\":return n.compute(this.model.x)}})(),h=(()=>{switch(this.model.y_units){case\"canvas\":return this.model.y;case\"screen\":return i.bbox.yview.compute(this.model.y);case\"data\":return a.compute(this.model.y)}})();o+=this.model.x_offset,h-=this.model.y_offset,this._paint(this.layer.ctx,{sx:o,sy:h},s)}}s.LabelView=c,c.__name__=\"LabelView\";class d extends o.TextAnnotation{constructor(e){super(e)}}s.Label=d,a=d,d.__name__=\"Label\",a.prototype.default_view=c,a.define((({Number:e,Angle:t})=>({x:[e],x_units:[h.CoordinateUnits,\"data\"],y:[e],y_units:[h.CoordinateUnits,\"data\"],angle:[t,0],angle_units:[h.AngleUnits,\"rad\"],x_offset:[e,0],y_offset:[e,0]})))},\n", - " function _(t,e,i,s,a){var n;s();const o=t(1),l=t(98),r=o.__importStar(t(78)),c=t(19),_=t(151),u=o.__importStar(t(17)),x=t(23);class h extends l.DataAnnotationView{map_data(){const{x_scale:t,y_scale:e}=this.coordinates,i=null!=this.layout?this.layout:this.plot_view.frame;this.sx=(()=>{switch(this.model.x_units){case\"canvas\":return new x.ScreenArray(this._x);case\"screen\":return i.bbox.xview.v_compute(this._x);case\"data\":return t.v_compute(this._x)}})(),this.sy=(()=>{switch(this.model.y_units){case\"canvas\":return new x.ScreenArray(this._y);case\"screen\":return i.bbox.yview.v_compute(this._y);case\"data\":return e.v_compute(this._y)}})()}paint(){const{ctx:t}=this.layer;for(let e=0,i=this.text.length;e({x:[u.XCoordinateSpec,{field:\"x\"}],y:[u.YCoordinateSpec,{field:\"y\"}],x_units:[c.CoordinateUnits,\"data\"],y_units:[c.CoordinateUnits,\"data\"],text:[u.NullStringSpec,{field:\"text\"}],angle:[u.AngleSpec,0],x_offset:[u.NumberSpec,{value:0}],y_offset:[u.NumberSpec,{value:0}]}))),n.override({background_fill_color:null,border_line_color:null})},\n", - " function _(t,e,i,s,n){var o;s();const l=t(1),r=t(73),a=t(251),_=t(19),c=l.__importStar(t(78)),h=t(15),d=t(144),u=t(57),b=t(10),g=t(32),p=t(8),m=t(151),f=t(226),{max:x,floor:w}=Math;class y extends f.ContentLayoutable{constructor(t){super(),this.text=t}_content_size(){return new f.Sizeable(this.text.size())}}y.__name__=\"TextLayout\";class v extends f.ContentLayoutable{constructor(t,e,i,s){super(),this.item=t,this.label=e,this.text=i,this.settings=s}get field(){return this.item.get_field_from_label_prop()}_content_size(){const t=this.text.size(),{glyph_width:e,glyph_height:i,label_standoff:s,label_width:n,label_height:o}=this.settings,l=e+s+x(t.width,n),r=x(i,t.height,o);return new f.Sizeable({width:l,height:r})}}v.__name__=\"LegendEntry\";class k extends r.AnnotationView{constructor(){super(...arguments),this.bbox=new u.BBox}_get_size(){const{width:t,height:e}=this.bbox,{margin:i}=this.model;return{width:t+2*i,height:e+2*i}}update_layout(){this.update_geometry();const{panel:t}=this;this.layout=null!=t?new d.SideLayout(t,(()=>this.get_size())):void 0}connect_signals(){super.connect_signals();const t=()=>{this.update_geometry(),this.request_render()};this.connect(this.model.change,t),this.connect(this.model.item_change,t)}get padding(){return null!=this.model.border_line_color?this.model.padding:0}update_geometry(){super.update_geometry();const{spacing:t,orientation:e}=this.model,i=\"vertical\"==e,{padding:s}=this,n=s,o=s,{title:l}=this.model,r=new m.TextBox({text:null!=l?l:\"\"});r.position={sx:0,sy:0,x_anchor:\"left\",y_anchor:\"top\"},r.visuals=this.visuals.title_text.values();const a=new d.Panel(this.model.title_location);r.angle=a.get_label_angle_heuristic(\"parallel\");const _=[];for(const t of this.model.items){t.legend=this.model;const e=t.get_labels_list_from_label_prop();for(const i of e){const e=new m.TextBox({text:`${i}`});e.position={sx:0,sy:0,x_anchor:\"left\",y_anchor:\"center\"},e.visuals=this.visuals.label_text.values();const s=new v(t,i,e,this.model);s.set_sizing({visible:t.visible}),_.push({layout:s,row:0,col:0})}}const{ncols:c,nrows:h}=(()=>{let{ncols:t,nrows:e}=this.model;const s=_.length;return i?(\"auto\"!=e||(e=\"auto\"!=t?w(s/t):1/0),t=1/0):(\"auto\"!=t||(t=\"auto\"!=e?w(s/e):1/0),e=1/0),{ncols:t,nrows:e}})();let b=0,g=0;for(const t of _)t.row=b,t.col=g,i?(b+=1,b>=h&&(b=0,g+=1)):(g+=1,g>=c&&(g=0,b+=1));const p=new f.Grid(_);this.grid=p,p.spacing=t,p.set_sizing();const x=new y(r);this.title_panel=x;const k=\"\"!=r.text&&this.visuals.title_text.doit;x.set_sizing({visible:k});const z=(()=>{if(!k)return new f.Column([p]);switch(this.model.title_location){case\"above\":return new f.Column([x,p]);case\"below\":return new f.Column([p,x]);case\"left\":return new f.Row([x,p]);case\"right\":return new f.Row([p,x])}})();this.border_box=z,z.position={left:n,top:o},z.spacing=this.model.title_standoff,z.set_sizing(),z.compute();const L=s+z.bbox.width+s,B=s+z.bbox.height+s;this.bbox=new u.BBox({left:0,top:0,width:L,height:B})}compute_geometry(){super.compute_geometry();const{margin:t,location:e}=this.model,{width:i,height:s}=this.bbox,n=null!=this.layout?this.layout:this.plot_view.frame,[o,l]=n.bbox.ranges;let r,a;if((0,p.isString)(e))switch(e){case\"top_left\":r=o.start+t,a=l.start+t;break;case\"top\":case\"top_center\":r=(o.end+o.start)/2-i/2,a=l.start+t;break;case\"top_right\":r=o.end-t-i,a=l.start+t;break;case\"bottom_right\":r=o.end-t-i,a=l.end-t-s;break;case\"bottom\":case\"bottom_center\":r=(o.end+o.start)/2-i/2,a=l.end-t-s;break;case\"bottom_left\":r=o.start+t,a=l.end-t-s;break;case\"left\":case\"center_left\":r=o.start+t,a=(l.end+l.start)/2-s/2;break;case\"center\":case\"center_center\":r=(o.end+o.start)/2-i/2,a=(l.end+l.start)/2-s/2;break;case\"right\":case\"center_right\":r=o.end-t-i,a=(l.end+l.start)/2-s/2}else{const[t,i]=e;r=n.bbox.xview.compute(t),a=n.bbox.yview.compute(i)-s}this.bbox=new u.BBox({left:r,top:a,width:i,height:s})}interactive_hit(t,e){return this.bbox.contains(t,e)}_hit_test(t,e){const{left:i,top:s}=this.bbox;t-=i+this.grid.bbox.left,e-=s+this.grid.bbox.top;for(const i of this.grid)if(i.bbox.contains(t,e))return{type:\"entry\",entry:i};return null}cursor(t,e){return\"none\"==this.model.click_policy?null:null!=this._hit_test(t,e)?\"pointer\":null}on_hit(t,e){const i=(()=>{switch(this.model.click_policy){case\"hide\":return t=>t.visible=!t.visible;case\"mute\":return t=>t.muted=!t.muted;case\"none\":return t=>{}}})(),s=this._hit_test(t,e);if(null!=s){const{renderers:t}=s.entry.item;for(const e of t)i(e);return!0}return!1}_render(){if(this.compute_geometry(),0==this.model.items.length)return;if(!(0,b.some)(this.model.items,(t=>t.visible)))return;const{ctx:t}=this.layer;t.save(),this._draw_legend_box(t),this._draw_legend_items(t),this._draw_title(t),t.restore()}_draw_legend_box(t){const{x:e,y:i,width:s,height:n}=this.bbox;t.beginPath(),t.rect(e,i,s,n),this.visuals.background_fill.apply(t),this.visuals.border_line.apply(t)}_draw_title(t){const{title:e}=this.model;if(null==e||0==e.length||!this.visuals.title_text.doit)return;const{left:i,top:s}=this.bbox;switch(t.save(),t.translate(i,s),t.translate(this.title_panel.bbox.left,this.title_panel.bbox.top),this.model.title_location){case\"left\":t.translate(0,this.title_panel.bbox.height);break;case\"right\":t.translate(this.title_panel.bbox.width,0)}this.title_panel.text.paint(t),t.restore()}_draw_legend_items(t){const e=(()=>{switch(this.model.click_policy){case\"none\":return t=>!0;case\"hide\":return t=>(0,b.every)(t.renderers,(t=>t.visible));case\"mute\":return t=>(0,b.every)(t.renderers,(t=>!t.muted))}})(),i=(t,e,i)=>{if(!this.visuals.item_background_fill.doit)return!1;switch(this.model.item_background_policy){case\"every\":return!0;case\"even\":return e%2==0==(i%2==0);case\"odd\":return e%2==0!=(i%2==0);case\"none\":return!1}},{left:s,top:n}=this.bbox;t.translate(s,n),t.translate(this.grid.bbox.left,this.grid.bbox.top);for(const[{layout:s,row:n,col:o},l]of(0,g.enumerate)(this.grid.items)){const{bbox:l,text:r,item:a,label:_,field:c,settings:h}=s,{glyph_width:d,glyph_height:u,label_standoff:b}=h,{left:g,top:p,width:m,height:f}=l;t.translate(g,p),i(0,n,o)&&(t.beginPath(),t.rect(0,0,m,f),this.visuals.item_background_fill.apply(t));const x=f/2,w=0,y=x-u/2,v=w+d,k=y+u;for(const e of a.renderers){const i=this.plot_view.renderer_view(e);null==i||i.draw_legend(t,w,v,y,k,c,_,a.index)}t.translate(v+b,x),r.paint(t),t.translate(-v-b,-x),e(a)||(t.beginPath(),t.rect(0,0,m,f),this.visuals.inactive_fill.set_value(t),t.fill()),t.translate(-g,-p)}t.translate(-this.grid.bbox.left,-this.grid.bbox.top),t.translate(-s,-n)}}i.LegendView=k,k.__name__=\"LegendView\";class z extends r.Annotation{constructor(t){super(t)}initialize(){super.initialize(),this.item_change=new h.Signal0(this,\"item_change\")}get_legend_names(){const t=[];for(const e of this.items){const i=e.get_labels_list_from_label_prop();t.push(...i)}return t}}i.Legend=z,o=z,z.__name__=\"Legend\",o.prototype.default_view=k,o.mixins([[\"label_\",c.Text],[\"title_\",c.Text],[\"inactive_\",c.Fill],[\"border_\",c.Line],[\"background_\",c.Fill],[\"item_background_\",c.Fill]]),o.define((({Number:t,Int:e,String:i,Array:s,Tuple:n,Or:o,Ref:l,Nullable:r,Positive:c,Auto:h})=>({orientation:[_.Orientation,\"vertical\"],ncols:[o(c(e),h),\"auto\"],nrows:[o(c(e),h),\"auto\"],location:[o(_.LegendLocation,n(t,t)),\"top_right\"],title:[r(i),null],title_location:[_.Location,\"above\"],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:[s(l(a.LegendItem)),[]],click_policy:[_.LegendClickPolicy,\"none\"],item_background_policy:[_.AlternationPolicy,\"none\"]}))),o.override({border_line_color:\"#e5e5e5\",border_line_alpha:.5,border_line_width:1,background_fill_color:\"#ffffff\",background_fill_alpha:.95,item_background_fill_color:\"#f1f1f1\",item_background_fill_alpha:.8,inactive_fill_color:\"white\",inactive_fill_alpha:.7,label_text_font_size:\"13px\",label_text_baseline:\"middle\",title_text_font_size:\"13px\",title_text_font_style:\"italic\"})},\n", - " function _(e,r,l,n,t){var i;n();const s=e(1),o=e(50),_=e(199),a=e(99),u=e(27),d=s.__importStar(e(17)),c=e(18),f=e(10);class h extends o.Model{constructor(e){super(e)}_check_data_sources_on_renderers(){if(null!=this.get_field_from_label_prop()){if(this.renderers.length<1)return!1;const e=this.renderers[0].data_source;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(!(0,f.includes)(r.columns(),e))return!1}return!0}initialize(){super.initialize(),this.legend=null,this.connect(this.change,(()=>{var e;return null===(e=this.legend)||void 0===e?void 0:e.item_change.emit()}));this._check_data_sources_on_renderers()||c.logger.error(\"Non matching data sources on legend item renderers\");this._check_field_label_on_data_source()||c.logger.error(`Bad column name on label: ${this.label}`)}get_field_from_label_prop(){const{label:e}=this;return(0,u.isField)(e)?e.field:null}get_labels_list_from_label_prop(){if(!this.visible)return[];if((0,u.isValue)(this.label)){const{value:e}=this.label;return null!=e?[e]:[]}const e=this.get_field_from_label_prop();if(null!=e){let r;if(0==this.renderers.length)return[\"No source found\"];if(r=this.renderers[0].data_source,r instanceof a.ColumnarDataSource){const l=r.get_column(e);return null!=l?(0,f.uniq)(Array.from(l)):[\"Invalid field\"]}}return[]}}l.LegendItem=h,i=h,h.__name__=\"LegendItem\",i.define((({Boolean:e,Int:r,Array:l,Ref:n,Nullable:t})=>({label:[d.NullStringSpec,null],renderers:[l(n(_.GlyphRenderer)),[]],index:[t(r),null],visible:[e,!0]})))},\n", - " function _(t,e,s,n,i){var o,a;n();const r=t(1),l=t(73),h=t(93),_=r.__importStar(t(78)),c=t(19),u=t(210),d=t(15),y=t(57),p=t(13),v=t(12);class x{constructor(t=[],e=[]){this.xs=t,this.ys=e,(0,v.assert)(t.length==e.length)}clone(){return new x(this.xs.slice(),this.ys.slice())}[Symbol.iterator](){return this.nodes()}*nodes(){const{xs:t,ys:e,n:s}=this;for(let n=0;n=3){const n={x:t[s-1],y:e[s-1]},i={x:t[0],y:e[0]};yield[n,i,s-1]}}contains(t,e){return(0,u.point_in_poly)(t,e,this.xs,this.ys)}get bbox(){const[t,e]=(0,p.minmax)(this.xs),[s,n]=(0,p.minmax)(this.ys);return new y.BBox({x0:t,x1:e,y0:s,y1:n})}get n(){return this.xs.length}translate(t,e,...s){const n=this.clone(),{xs:i,ys:o,n:a}=n;if(0!=s.length)for(const n of s){const s=n%a;i[s]+=t,o[s]+=e}else for(let s=0;sthis.request_render()))}bounds(){const{xs_units:t,ys_units:e}=this.model;if(\"data\"==t&&\"data\"==e){const{xs:t,ys:e}=this.model,[s,n]=(0,p.minmax)(t),[i,o]=(0,p.minmax)(e);return{x0:s,x1:n,y0:i,y1:o}}return(0,y.empty)()}log_bounds(){return(0,y.empty)()}_mappers(){const t=(t,e,s,n)=>{switch(t){case\"canvas\":return n;case\"screen\":return s;case\"data\":return e}},e=this.model,{frame:s,canvas:n}=this.plot_view,{x_scale:i,y_scale:o}=s,{x_view:a,y_view:r}=s.bbox,{x_screen:l,y_screen:h}=n.bbox;return{x:t(e.xs_units,i,a,l),y:t(e.ys_units,o,r,h)}}_render(){const{xs:t,ys:e}=this.model;(0,v.assert)(t.length==e.length),this.poly=(()=>{const{x:s,y:n}=this._mappers();return new x(s.v_compute(t),n.v_compute(e))})();const{ctx:s}=this.layer;s.beginPath();for(const[t,e]of this.poly)s.lineTo(t,e);const{_is_hovered:n,visuals:i}=this,o=n&&i.hover_fill.doit?i.hover_fill:i.fill,a=n&&i.hover_hatch.doit?i.hover_hatch:i.hatch,r=n&&i.hover_line.doit?i.hover_line:i.line;this.poly.n>=3&&(s.closePath(),o.apply(s),a.apply(s)),r.apply(s)}interactive_hit(t,e){return!(!this.model.visible||!this.model.editable)&&this.poly.contains(t,e)}_hit_test(t,e){const{abs:s}=Math,n=Math.max(2.5,this.model.line_width/2);for(const[i,o,a]of this.poly)if(s(i-t){const{poly:e,target:s}=this._pan_state,{dx:n,dy:i}=t;switch(s.type){case\"node\":{const{i:t}=s;return e.translate(n,i,t)}case\"edge\":{const{i:t}=s;return e.translate(n,i,t,t+1)}case\"area\":return e.translate(n,i)}})(),{x:s,y:n}=this._mappers(),i=s.v_invert(e.xs),o=n.v_invert(e.ys);this.model.update({xs:i,ys:o}),this.model.pan.emit([\"pan\",t])}_pan_end(t){this._pan_state=null,this.model.pan.emit([\"pan:end\",t])}get _has_hover(){const{hover_line:t,hover_fill:e,hover_hatch:s}=this.visuals;return t.doit||e.doit||s.doit}_move_start(t){const{_has_hover:e}=this;return e&&(this._is_hovered=!0,this.request_paint()),e}_move(t){}_move_end(t){this._has_hover&&(this._is_hovered=!1,this.request_paint())}cursor(t,e){var s,n;const i=null!==(n=null===(s=this._pan_state)||void 0===s?void 0:s.target)&&void 0!==n?n:this._hit_test(t,e);if(null==i||!this._can_hit(i))return null;switch(i.type){case\"node\":case\"edge\":case\"area\":return\"move\"}}}s.PolyAnnotationView=m,o=h.auto_ranged,m.__name__=\"PolyAnnotationView\";class f extends l.Annotation{constructor(t){super(t),this.pan=new d.Signal(this,\"pan\")}update({xs:t,ys:e}){this.setv({xs:t.slice(),ys:e.slice(),visible:!0})}clear(){this.setv({xs:[],ys:[],visible:!1})}}s.PolyAnnotation=f,a=f,f.__name__=\"PolyAnnotation\",a.prototype.default_view=m,a.mixins([_.Line,_.Fill,_.Hatch,[\"hover_\",_.Line],[\"hover_\",_.Fill],[\"hover_\",_.Hatch]]),a.define((({Boolean:t,Number:e,Arrayable:s})=>({xs:[s(e),[]],ys:[s(e),[]],xs_units:[c.CoordinateUnits,\"data\"],ys_units:[c.CoordinateUnits,\"data\"],editable:[t,!1]}))),a.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3,hover_fill_color:null,hover_fill_alpha:.4,hover_line_color:null,hover_line_alpha:.3})},\n", - " function _(e,l,o,i,t){var n;i();const s=e(1),a=e(73),_=s.__importStar(e(78));class c extends a.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{gradient:e,y_intercept:l}=this.model;if(null==e||null==l)return;const{frame:o}=this.plot_view,i=this.coordinates.x_scale,t=this.coordinates.y_scale,[n,s,a,_]=(()=>{if(0==e){const e=t.compute(l),i=e;return[o.bbox.left,o.bbox.right,e,i]}{const n=o.bbox.top,s=o.bbox.bottom,a=t.invert(n),_=t.invert(s),c=(a-l)/e,r=(_-l)/e,h=i.compute(c),b=i.compute(r);return h<=b?[h,b,n,s]:[b,h,s,n]}})(),{ctx:c}=this.layer;if(c.save(),this.visuals.above_fill.doit||this.visuals.above_hatch.doit){const{left:e,right:l,top:i,bottom:t}=o.bbox;c.beginPath(),c.moveTo(n,a),c.lineTo(n,a),c.lineTo(s,_),c.lineTo(s,_),a<=_?(se&&c.lineTo(e,t)),c.closePath(),this.visuals.above_fill.apply(c),this.visuals.above_hatch.apply(c)}if(this.visuals.below_fill.doit||this.visuals.below_hatch.doit){const{left:e,right:l,top:i,bottom:t}=o.bbox;c.beginPath(),c.moveTo(n,a),c.lineTo(n,a),c.lineTo(s,_),a<=_?(c.lineTo(l,t),c.lineTo(e,t),n>e&&c.lineTo(e,i)):(s({gradient:[l(e),null],y_intercept:[l(e),null]}))),n.override({line_color:\"black\",above_fill_color:null,above_fill_alpha:.4,below_fill_color:null,below_fill_alpha:.4})},\n", - " function _(t,e,i,n,s){var o;n();const a=t(1),l=t(73),r=a.__importStar(t(78)),h=t(19),_=t(210),c=t(15),d=t(12);class u{constructor(t,e){this.p0=t,this.p1=e}clone(){return new u(Object.assign({},this.p0),Object.assign({},this.p1))}hit_test(t,e=2.5){return(0,_.dist_to_segment)(t,this.p0,this.p1)this.plot_view.request_paint(this)))}_render(){const{location:t,location_units:e}=this.model;if(null==t)return;function i(t,e,i,n,s){switch(e){case\"canvas\":return s.compute(t);case\"screen\":return n.compute(t);case\"data\":return i.compute(t)}}const{frame:n,canvas:s}=this.plot_view,{x_scale:o,y_scale:a}=this.coordinates;let l,r,h,_;\"width\"==this.model.dimension?(h=i(t,e,a,n.bbox.yview,s.bbox.y_screen),r=n.bbox.left,_=n.bbox.width,l=this.model.line_width):(h=n.bbox.top,r=i(t,e,o,n.bbox.xview,s.bbox.y_screen),_=this.model.line_width,l=n.bbox.height);const c={x:r,y:h},d={x:r+_,y:h+l};this.line=new u(c,d);const{_is_hovered:p,visuals:m}=this,v=p&&m.hover_line.doit?m.hover_line:m.line,{ctx:b}=this.layer;b.save(),b.beginPath(),this.visuals.line.set_value(b),b.moveTo(r,h),\"width\"==this.model.dimension?b.lineTo(r+_,h):b.lineTo(r,h+l),v.apply(b),b.restore()}interactive_hit(t,e){return!(!this.model.visible||!this.model.editable)&&null!=this._hit_test(t,e)}_hit_test(t,e){const i=Math.max(2.5,this.model.line_width/2);return this.line.hit_test({x:t,y:e},i)?\"edge\":null}_can_hit(t){return!0}_pan_start(t){if(this.model.visible&&this.model.editable){const{sx:e,sy:i}=t,n=this._hit_test(e,i);if(null!=n&&this._can_hit(n))return this._pan_state={line:this.line.clone(),target:n},this.model.pan.emit([\"pan:start\",t]),!0}return!1}_pan(t){function e(t,e,i,n,s){switch(e){case\"canvas\":return s.invert(t);case\"screen\":return n.invert(t);case\"data\":return i.invert(t)}}(0,d.assert)(null!=this._pan_state);const i=(()=>{const{dx:e,dy:i}=t,{line:n}=this._pan_state;return\"width\"==this.model.dimension?n.translate(0,i).p0.y:n.translate(e,0).p0.x})(),n=(()=>{const{location_units:t}=this.model,{frame:n,canvas:s}=this.plot_view,{x_scale:o,y_scale:a}=this.coordinates;return\"width\"==this.model.dimension?e(i,t,a,n.bbox.yview,s.bbox.y_screen):e(i,t,o,n.bbox.xview,s.bbox.y_screen)})();this.model.location=n,this.model.pan.emit([\"pan\",t])}_pan_end(t){this._pan_state=null,this.model.pan.emit([\"pan:end\",t])}get _has_hover(){const{hover_line:t}=this.visuals;return t.doit}_move_start(t){const{_has_hover:e}=this;return e&&(this._is_hovered=!0,this.request_paint()),e}_move(t){}_move_end(t){this._has_hover&&(this._is_hovered=!1,this.request_paint())}cursor(t,e){var i,n;const s=null!==(n=null===(i=this._pan_state)||void 0===i?void 0:i.target)&&void 0!==n?n:this._hit_test(t,e);return null!=s&&this._can_hit(s)?\"width\"==this.model.dimension?\"ns-resize\":\"ew-resize\":null}}i.SpanView=p,p.__name__=\"SpanView\";class m extends l.Annotation{constructor(t){super(t),this.pan=new c.Signal(this,\"pan\")}}i.Span=m,o=m,m.__name__=\"Span\",o.prototype.default_view=p,o.mixins([r.Line,[\"hover_\",r.Line]]),o.define((({Boolean:t,Number:e,Nullable:i})=>({location:[i(e),null],location_units:[h.CoordinateUnits,\"data\"],dimension:[h.Dimension,\"width\"],editable:[t,!1]}))),o.override({line_color:\"black\",hover_line_color:null,hover_line_alpha:.3})},\n", - " function _(e,i,t,o,s){var l;o();const a=e(73),n=e(256),r=e(59),h=e(56),_=e(144),v=e(57);class b extends a.AnnotationView{constructor(){super(...arguments),this.el=(0,h.div)(),this._previous_bbox=new v.BBox}update_layout(){this.layout=new _.SideLayout(this.panel,(()=>this.get_size()),!0)}has_finished(){return super.has_finished()&&this.toolbar_view.has_finished()}*children(){yield*super.children(),yield this.toolbar_view}async lazy_initialize(){await super.lazy_initialize(),this.toolbar_view=await(0,r.build_view)(this.model.toolbar,{parent:this.canvas})}connect_signals(){super.connect_signals(),this.plot_view.mouseenter.connect((()=>{this.toolbar_view.set_visibility(!0)})),this.plot_view.mouseleave.connect((()=>{this.toolbar_view.set_visibility(!1)}))}remove(){this.toolbar_view.remove(),(0,h.remove)(this.el),super.remove()}_render(){(0,h.display)(this.el);const{bbox:e}=this.layout;if(!this._previous_bbox.equals(e)){(0,h.position)(this.el,e),this._previous_bbox=e,(0,h.empty)(this.el),this.el.style.position=\"absolute\";const{style:i}=this.toolbar_view.el;this.toolbar_view.model.horizontal?(i.width=\"100%\",i.height=\"unset\"):(i.width=\"unset\",i.height=\"100%\"),this.toolbar_view.render(),this.plot_view.canvas_view.add_event(this.el),this.el.appendChild(this.toolbar_view.el),this.toolbar_view.after_render()}this.model.visible||(0,h.undisplay)(this.el)}_get_size(){const{tools:e,logo:i}=this.model.toolbar;return{width:30*e.length+(null!=i?25:0)+15,height:30}}}t.ToolbarPanelView=b,b.__name__=\"ToolbarPanelView\";class d extends a.Annotation{constructor(e){super(e)}}t.ToolbarPanel=d,l=d,d.__name__=\"ToolbarPanel\",l.prototype.default_view=b,l.define((({Ref:e})=>({toolbar:[e(n.Toolbar)]})))},\n", - " function _(t,e,o,s,i){var l;s();const n=t(1),a=t(18),r=t(56),c=t(59),h=t(257),_=t(19),u=t(10),v=t(32),p=t(9),d=t(8),f=t(264),g=t(265),b=t(266),m=t(271),w=t(273),T=t(274),y=t(276),z=t(267),x=n.__importStar(t(277)),C=x,I=n.__importStar(t(278)),A=I,L=n.__importDefault(t(269));class P extends h.UIElementView{constructor(){super(...arguments),this._tool_button_views=new Map,this._items=[],this._visible=null}get tool_buttons(){return this._tool_buttons.flat()}get overflow_el(){return this._overflow_el}get visible(){var t;return!!this.model.visible&&(!this.model.autohide||null!==(t=this._visible)&&void 0!==t&&t)}*children(){yield*super.children(),yield*this._tool_button_views.values()}has_finished(){if(!super.has_finished())return!1;for(const t of this._tool_button_views.values())if(!t.has_finished())return!1;return!0}initialize(){super.initialize();const{location:t}=this.model,e=\"left\"==t||\"above\"==t,o=this.model.horizontal?\"vertical\":\"horizontal\";this._overflow_menu=new z.ContextMenu([],{target:this.root.el,orientation:o,reversed:e,prevent_hide:t=>t.composedPath().includes(this._overflow_el)})}async lazy_initialize(){await super.lazy_initialize(),await this._build_tool_button_views()}connect_signals(){super.connect_signals();const{buttons:t,tools:e}=this.model.properties;this.on_change([t,e],(async()=>{await this._build_tool_button_views(),this.render()})),this.connect(this.model.properties.autohide.change,(()=>{this._on_visible_change()}))}stylesheets(){return[...super.stylesheets(),x.default,I.default,L.default]}remove(){(0,c.remove_views)(this._tool_button_views),super.remove()}async _build_tool_button_views(){this._tool_buttons=(()=>{const{buttons:t}=this.model;if(\"auto\"==t){return[...(0,p.values)(this.model.gestures).map((t=>t.tools)),this.model.actions,this.model.inspectors.filter((t=>t.toggleable)),this.model.auxiliaries].map((t=>t.map((t=>t.tool_button()))))}return(0,u.split)(t,null)})(),await(0,c.build_views)(this._tool_button_views,this._tool_buttons.flat(),{parent:this})}set_visibility(t){t!=this._visible&&(this._visible=t,this._on_visible_change())}_on_visible_change(){this.el.classList.toggle(C.hidden,!this.visible)}_after_resize(){super._after_resize(),this._after_render()}render(){super.render(),this.el.classList.add(C[this.model.location]),this.el.classList.toggle(C.inner,this.model.inner),this._on_visible_change();const{horizontal:t}=this.model;this._overflow_el=(0,r.div)({class:C.tool_overflow,tabIndex:0},t?\"\\u22ee\":\"\\u22ef\");const e=()=>{const t=(()=>{switch(this.model.location){case\"right\":return{left_of:this._overflow_el};case\"left\":return{right_of:this._overflow_el};case\"above\":return{below:this._overflow_el};case\"below\":return{above:this._overflow_el}}})();this._overflow_menu.toggle(t)};if(this._overflow_el.addEventListener(\"click\",(()=>{e()})),this._overflow_el.addEventListener(\"keydown\",(t=>{\"Enter\"==t.key&&e()})),this._items=[],null!=this.model.logo){const t=\"grey\"===this.model.logo?A.grey:null,e=(0,r.a)({href:\"https://bokeh.org/\",target:\"_blank\",class:[A.logo,A.logo_small,t]});this._items.push(e),this.shadow_el.appendChild(e)}for(const[,t]of this._tool_button_views)t.render(),t.after_render();const o=this._tool_buttons.map((t=>t.map((t=>this._tool_button_views.get(t).el)))).filter((t=>0!=t.length)),s=()=>(0,r.div)({class:C.divider});for(const t of(0,v.join)(o,s))this._items.push(t),this.shadow_el.appendChild(t)}_after_render(){super._after_render(),(0,u.clear)(this._overflow_menu.items),this.shadow_el.contains(this._overflow_el)&&this.shadow_el.removeChild(this._overflow_el);for(const t of this._items)this.shadow_el.contains(t)||this.shadow_el.append(t);const{horizontal:t}=this.model,{bbox:e}=this,o=t?C.right:C.above;let s=0,i=!1;for(const l of this._items)if(i)this.shadow_el.removeChild(l),this._overflow_menu.items.push({content:l,class:o});else{const{width:n,height:a}=l.getBoundingClientRect();s+=t?n:a,i=t?s>e.width-15:s>e.height-15,i&&(this.shadow_el.removeChild(l),this.shadow_el.appendChild(this._overflow_el),this._overflow_menu.items.push({content:l,class:o}))}}}function S(){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}}}o.ToolbarView=P,P.__name__=\"ToolbarView\",o.Drag=f.Tool,o.Inspection=f.Tool,o.Scroll=f.Tool,o.Tap=f.Tool;class k extends h.UIElement{constructor(t){super(t)}get horizontal(){return\"above\"==this.location||\"below\"==this.location}get vertical(){return\"left\"==this.location||\"right\"==this.location}connect_signals(){super.connect_signals();const{tools:t,active_drag:e,active_inspect:o,active_scroll:s,active_tap:i,active_multi:l}=this.properties;this.on_change([t,e,o,s,i,l],(()=>{this._init_tools(),this._activate_tools()}))}initialize(){super.initialize(),this._init_tools(),this._activate_tools()}_init_tools(){const t=new Set;function e(e,o){const s=(e instanceof g.ToolProxy?e.underlying:e)instanceof o;return s&&t.add(e),s}const o=this.tools.filter((t=>e(t,w.InspectTool)));this.inspectors=o;const s=this.tools.filter((t=>e(t,y.HelpTool)));this.help=s;const i=this.tools.filter((t=>e(t,T.ActionTool)));this.actions=i;const 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)e(t,m.GestureTool)&&l[t.event_role].tools.push(t);for(const t of(0,p.fields)(l)){const e=this.gestures[t];e.tools=(0,u.sort_by)(l[t].tools,(t=>t.default_order)),null!=e.active&&(0,u.every)(e.tools,(t=>{var o;return t.id!=(null===(o=e.active)||void 0===o?void 0:o.id)}))&&(e.active=null)}const n=this.tools.filter((e=>!t.has(e)));this.auxiliaries=n}_activate_tools(){if(\"auto\"==this.active_inspect);else if(null==this.active_inspect)for(const t of this.inspectors)t.active=!1;else if((0,d.isArray)(this.active_inspect)){const t=(0,u.intersection)(this.active_inspect,this.inspectors);t.length!=this.active_inspect.length&&(this.active_inspect=t);for(const t of this.inspectors)(0,u.includes)(this.active_inspect,t)||(t.active=!1)}else{let t=!1;for(const e of this.inspectors)e!=this.active_inspect?e.active=!1:t=!0;t||(this.active_inspect=null)}const t=t=>{t.active?this._active_change(t):t.active=!0};for(const t of(0,p.values)(this.gestures))for(const e of t.tools)this.connect(e.properties.active.change,(()=>this._active_change(e)));function e(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\";default:return null}}function o(t){return\"tap\"==t||\"pan\"==t}for(const[s,i]of(0,p.entries)(this.gestures)){const l=s,n=e(l);if(null!=n){const e=this[n];if(\"auto\"==e)0!=i.tools.length&&o(l)&&t(i.tools[0]);else if(null!=e)(0,u.includes)(this.tools,e)?t(e):this[n]=null;else{this.gestures[l].active=null;for(const t of this.gestures[l].tools)t.active=!1}}}}_active_change(t){const{event_types:e}=t;for(const o of e)if(t.active){const e=this.gestures[o].active;null!=e&&t!=e&&(a.logger.debug(`Toolbar: deactivating tool: ${e} for event type '${o}'`),e.active=!1),this.gestures[o].active=t,a.logger.debug(`Toolbar: activating tool: ${t} for event type '${o}'`)}else this.gestures[o].active=null}}o.Toolbar=k,l=k,k.__name__=\"Toolbar\",l.prototype.default_view=P,l.define((({Boolean:t,Array:e,Or:s,Ref:i,Nullable:l,Auto:n})=>({tools:[e(s(i(f.Tool),i(g.ToolProxy))),[]],logo:[l(_.Logo),\"normal\"],autohide:[t,!1],active_drag:[l(s(i(o.Drag),n)),\"auto\"],active_inspect:[l(s(i(o.Inspection),e(i(o.Inspection)),n)),\"auto\"],active_scroll:[l(s(i(o.Scroll),n)),\"auto\"],active_tap:[l(s(i(o.Tap),n)),\"auto\"],active_multi:[l(s(i(m.GestureTool),n)),\"auto\"]}))),l.internal((({Array:t,Boolean:e,Ref:o,Or:s,Struct:i,Nullable:l,Null:n,Auto:a})=>{const r=i({tools:t(o(m.GestureTool)),active:l(o(m.GestureTool))}),c=i({pan:r,scroll:r,pinch:r,tap:r,doubletap:r,press:r,pressup:r,rotate:r,move:r,multi:r});return{buttons:[s(t(s(o(b.ToolButton),n)),a),\"auto\"],location:[_.Location,\"right\"],inner:[e,!1],gestures:[c,S],actions:[t(s(o(T.ActionTool),o(g.ToolProxy))),[]],inspectors:[t(s(o(w.InspectTool),o(g.ToolProxy))),[]],auxiliaries:[t(s(o(f.Tool),o(g.ToolProxy))),[]],help:[t(s(o(y.HelpTool),o(g.ToolProxy))),[]]}}))},\n", - " function _(e,t,s,i,l){var n;i();const r=e(1),o=e(50),_=e(258),h=e(259),a=e(18),p=e(55),d=e(56),y=e(260),c=e(9),u=e(57),b=e(8),f=r.__importDefault(e(263)),{round:g,floor:x}=Math;function*S(e){if(e instanceof _.Styles){const t=new Set((0,c.keys)(o.Model.prototype._props));for(const s of e)t.has(s.attr)||(yield[s.attr,s.get_value()])}else yield*(0,c.entries)(e)}class m extends p.DOMComponentView{constructor(){super(...arguments),this._display=new d.InlineStyleSheet,this.style=new d.InlineStyleSheet,this._bbox=new u.BBox,this._is_displayed=!1}*_css_classes(){yield*super._css_classes(),yield*this.model.css_classes}*_stylesheets(){yield*super._stylesheets(),yield this.style,yield this._display,yield*this._computed_stylesheets()}*_computed_stylesheets(){for(const e of this.model.stylesheets)if((0,b.isString)(e))yield new d.InlineStyleSheet(e);else if(e instanceof h.StyleSheet)yield e.underlying();else{const t=[];for(const[s,i]of(0,c.entries)(e)){t.push(`${s} {`);for(const[e,s]of S(i)){const i=e.replace(/_/g,\"-\");(0,b.isString)(s)&&0!=s.length&&t.push(` ${i}: ${s};`)}t.push(\"}\")}const s=t.join(\"\\n\");yield new d.InlineStyleSheet(s)}}stylesheets(){return[...super.stylesheets(),f.default]}update_style(){this.style.clear()}box_sizing(){return{width_policy:\"auto\",height_policy:\"auto\",width:null,height:null,aspect_ratio:null}}get bbox(){return this._bbox}update_bbox(){return this._update_bbox()}_update_bbox(){const e=(()=>{if(this.el.isConnected){if(null!=this.el.offsetParent)return!0;{const{position:e,display:t}=getComputedStyle(this.el);return\"fixed\"==e&&\"none\"!=t}}return!1})(),t=e?(()=>{const e=this.el.getBoundingClientRect(),{left:t,top:s}=(()=>{if(null!=this.parent){const t=this.parent.el.getBoundingClientRect();return{left:e.left-t.left,top:e.top-t.top}}return{left:0,top:0}})();return new u.BBox({left:g(t),top:g(s),width:x(e.width),height:x(e.height)})})():new u.BBox,s=!this._bbox.equals(t);return this._bbox=t,this._is_displayed=e,s}initialize(){super.initialize(),this._resize_observer=new ResizeObserver((e=>this.after_resize())),this._resize_observer.observe(this.el,{box:\"border-box\"})}connect_signals(){super.connect_signals();const{visible:e,styles:t,css_classes:s,stylesheets:i}=this.model.properties;this.on_change(e,(()=>this._update_visible())),this.on_change(t,(()=>this._update_styles())),this.on_change(s,(()=>this._update_css_classes())),this.on_change(i,(()=>this._update_stylesheets()))}remove(){this._resize_observer.disconnect(),super.remove()}_after_resize(){}after_resize(){this.update_bbox()&&this._after_resize(),this.finish()}render_to(e){super.render_to(e),this.after_render()}render(){super.render(),this._apply_styles(),this._apply_visible()}_after_render(){}after_render(){this.update_style(),this.update_bbox(),this._after_render(),this.is_displayed||this.finish()}get is_displayed(){return this._is_displayed}_apply_visible(){this.model.visible?this._display.clear():this._display.replace(\":host { display: none !important; }\")}_apply_styles(){const{styles:e}=this.model,t=(e,t)=>{const s=e in this.el.style;return s&&(0,b.isString)(t)&&(this.el.style[e]=t),s};for(const[s,i]of S(e)){const e=s.replace(/_/g,\"-\");t(e,i)||t(`-webkit-${e}`,i)||t(`-moz-${e}`,i)||a.logger.trace(`unknown CSS property '${e}'`)}}_update_visible(){this._apply_visible()}_update_styles(){this.el.removeAttribute(\"style\"),this._apply_styles()}export(e=\"auto\",t=!0){const s=\"auto\"==e||\"png\"==e?\"canvas\":\"svg\",i=new y.CanvasLayer(s,t),{width:l,height:n}=this.bbox;return i.resize(l,n),i}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.bbox})}}s.UIElementView=m,m.__name__=\"UIElementView\";class v extends o.Model{constructor(e){super(e)}}s.UIElement=v,n=v,v.__name__=\"UIElement\",n.define((({Boolean:e,Array:t,Dict:s,String:i,Ref:l,Or:n,Nullable:r})=>{const o=n(s(r(i)),l(_.Styles));return{visible:[e,!0],css_classes:[t(i),[]],styles:[o,{}],stylesheets:[t(n(l(h.StyleSheet),i,s(o))),[]]}}))},\n", - " function _(l,n,u,_,e){var t;_();const o=l(50);class r extends o.Model{constructor(l){super(l)}}u.Styles=r,t=r,r.__name__=\"Styles\",t.define((({String:l,Nullable:n})=>({align_content:[n(l),null],align_items:[n(l),null],align_self:[n(l),null],alignment_baseline:[n(l),null],all:[n(l),null],animation:[n(l),null],animation_delay:[n(l),null],animation_direction:[n(l),null],animation_duration:[n(l),null],animation_fill_mode:[n(l),null],animation_iteration_count:[n(l),null],animation_name:[n(l),null],animation_play_state:[n(l),null],animation_timing_function:[n(l),null],aspect_ratio:[n(l),null],backface_visibility:[n(l),null],background:[n(l),null],background_attachment:[n(l),null],background_clip:[n(l),null],background_color:[n(l),null],background_image:[n(l),null],background_origin:[n(l),null],background_position:[n(l),null],background_position_x:[n(l),null],background_position_y:[n(l),null],background_repeat:[n(l),null],background_size:[n(l),null],baseline_shift:[n(l),null],block_size:[n(l),null],border:[n(l),null],border_block_end:[n(l),null],border_block_end_color:[n(l),null],border_block_end_style:[n(l),null],border_block_end_width:[n(l),null],border_block_start:[n(l),null],border_block_start_color:[n(l),null],border_block_start_style:[n(l),null],border_block_start_width:[n(l),null],border_bottom:[n(l),null],border_bottom_color:[n(l),null],border_bottom_left_radius:[n(l),null],border_bottom_right_radius:[n(l),null],border_bottom_style:[n(l),null],border_bottom_width:[n(l),null],border_collapse:[n(l),null],border_color:[n(l),null],border_image:[n(l),null],border_image_outset:[n(l),null],border_image_repeat:[n(l),null],border_image_slice:[n(l),null],border_image_source:[n(l),null],border_image_width:[n(l),null],border_inline_end:[n(l),null],border_inline_end_color:[n(l),null],border_inline_end_style:[n(l),null],border_inline_end_width:[n(l),null],border_inline_start:[n(l),null],border_inline_start_color:[n(l),null],border_inline_start_style:[n(l),null],border_inline_start_width:[n(l),null],border_left:[n(l),null],border_left_color:[n(l),null],border_left_style:[n(l),null],border_left_width:[n(l),null],border_radius:[n(l),null],border_right:[n(l),null],border_right_color:[n(l),null],border_right_style:[n(l),null],border_right_width:[n(l),null],border_spacing:[n(l),null],border_style:[n(l),null],border_top:[n(l),null],border_top_color:[n(l),null],border_top_left_radius:[n(l),null],border_top_right_radius:[n(l),null],border_top_style:[n(l),null],border_top_width:[n(l),null],border_width:[n(l),null],bottom:[n(l),null],box_shadow:[n(l),null],box_sizing:[n(l),null],break_after:[n(l),null],break_before:[n(l),null],break_inside:[n(l),null],caption_side:[n(l),null],caret_color:[n(l),null],clear:[n(l),null],clip:[n(l),null],clip_path:[n(l),null],clip_rule:[n(l),null],color:[n(l),null],color_interpolation:[n(l),null],color_interpolation_filters:[n(l),null],column_count:[n(l),null],column_fill:[n(l),null],column_gap:[n(l),null],column_rule:[n(l),null],column_rule_color:[n(l),null],column_rule_style:[n(l),null],column_rule_width:[n(l),null],column_span:[n(l),null],column_width:[n(l),null],columns:[n(l),null],content:[n(l),null],counter_increment:[n(l),null],counter_reset:[n(l),null],cursor:[n(l),null],direction:[n(l),null],display:[n(l),null],dominant_baseline:[n(l),null],empty_cells:[n(l),null],fill:[n(l),null],fill_opacity:[n(l),null],fill_rule:[n(l),null],filter:[n(l),null],flex:[n(l),null],flex_basis:[n(l),null],flex_direction:[n(l),null],flex_flow:[n(l),null],flex_grow:[n(l),null],flex_shrink:[n(l),null],flex_wrap:[n(l),null],float:[n(l),null],flood_color:[n(l),null],flood_opacity:[n(l),null],font:[n(l),null],font_family:[n(l),null],font_feature_settings:[n(l),null],font_kerning:[n(l),null],font_size:[n(l),null],font_size_adjust:[n(l),null],font_stretch:[n(l),null],font_style:[n(l),null],font_synthesis:[n(l),null],font_variant:[n(l),null],font_variant_caps:[n(l),null],font_variant_east_asian:[n(l),null],font_variant_ligatures:[n(l),null],font_variant_numeric:[n(l),null],font_variant_position:[n(l),null],font_weight:[n(l),null],gap:[n(l),null],glyph_orientation_vertical:[n(l),null],grid:[n(l),null],grid_area:[n(l),null],grid_auto_columns:[n(l),null],grid_auto_flow:[n(l),null],grid_auto_rows:[n(l),null],grid_column:[n(l),null],grid_column_end:[n(l),null],grid_column_gap:[n(l),null],grid_column_start:[n(l),null],grid_gap:[n(l),null],grid_row:[n(l),null],grid_row_end:[n(l),null],grid_row_gap:[n(l),null],grid_row_start:[n(l),null],grid_template:[n(l),null],grid_template_areas:[n(l),null],grid_template_columns:[n(l),null],grid_template_rows:[n(l),null],height:[n(l),null],hyphens:[n(l),null],image_orientation:[n(l),null],image_rendering:[n(l),null],inline_size:[n(l),null],justify_content:[n(l),null],justify_items:[n(l),null],justify_self:[n(l),null],left:[n(l),null],letter_spacing:[n(l),null],lighting_color:[n(l),null],line_break:[n(l),null],line_height:[n(l),null],list_style:[n(l),null],list_style_image:[n(l),null],list_style_position:[n(l),null],list_style_type:[n(l),null],margin:[n(l),null],margin_block_end:[n(l),null],margin_block_start:[n(l),null],margin_bottom:[n(l),null],margin_inline_end:[n(l),null],margin_inline_start:[n(l),null],margin_left:[n(l),null],margin_right:[n(l),null],margin_top:[n(l),null],marker:[n(l),null],marker_end:[n(l),null],marker_mid:[n(l),null],marker_start:[n(l),null],mask:[n(l),null],mask_composite:[n(l),null],mask_image:[n(l),null],mask_position:[n(l),null],mask_repeat:[n(l),null],mask_size:[n(l),null],mask_type:[n(l),null],max_block_size:[n(l),null],max_height:[n(l),null],max_inline_size:[n(l),null],max_width:[n(l),null],min_block_size:[n(l),null],min_height:[n(l),null],min_inline_size:[n(l),null],min_width:[n(l),null],object_fit:[n(l),null],object_position:[n(l),null],opacity:[n(l),null],order:[n(l),null],orphans:[n(l),null],outline:[n(l),null],outline_color:[n(l),null],outline_offset:[n(l),null],outline_style:[n(l),null],outline_width:[n(l),null],overflow:[n(l),null],overflow_anchor:[n(l),null],overflow_wrap:[n(l),null],overflow_x:[n(l),null],overflow_y:[n(l),null],overscroll_behavior:[n(l),null],overscroll_behavior_block:[n(l),null],overscroll_behavior_inline:[n(l),null],overscroll_behavior_x:[n(l),null],overscroll_behavior_y:[n(l),null],padding:[n(l),null],padding_block_end:[n(l),null],padding_block_start:[n(l),null],padding_bottom:[n(l),null],padding_inline_end:[n(l),null],padding_inline_start:[n(l),null],padding_left:[n(l),null],padding_right:[n(l),null],padding_top:[n(l),null],page_break_after:[n(l),null],page_break_before:[n(l),null],page_break_inside:[n(l),null],paint_order:[n(l),null],perspective:[n(l),null],perspective_origin:[n(l),null],place_content:[n(l),null],place_items:[n(l),null],place_self:[n(l),null],pointer_events:[n(l),null],position:[n(l),null],quotes:[n(l),null],resize:[n(l),null],right:[n(l),null],rotate:[n(l),null],row_gap:[n(l),null],ruby_align:[n(l),null],ruby_position:[n(l),null],scale:[n(l),null],scroll_behavior:[n(l),null],shape_rendering:[n(l),null],stop_color:[n(l),null],stop_opacity:[n(l),null],stroke:[n(l),null],stroke_dasharray:[n(l),null],stroke_dashoffset:[n(l),null],stroke_linecap:[n(l),null],stroke_linejoin:[n(l),null],stroke_miterlimit:[n(l),null],stroke_opacity:[n(l),null],stroke_width:[n(l),null],tab_size:[n(l),null],table_layout:[n(l),null],text_align:[n(l),null],text_align_last:[n(l),null],text_anchor:[n(l),null],text_combine_upright:[n(l),null],text_decoration:[n(l),null],text_decoration_color:[n(l),null],text_decoration_line:[n(l),null],text_decoration_style:[n(l),null],text_emphasis:[n(l),null],text_emphasis_color:[n(l),null],text_emphasis_position:[n(l),null],text_emphasis_style:[n(l),null],text_indent:[n(l),null],text_justify:[n(l),null],text_orientation:[n(l),null],text_overflow:[n(l),null],text_rendering:[n(l),null],text_shadow:[n(l),null],text_transform:[n(l),null],text_underline_position:[n(l),null],top:[n(l),null],touch_action:[n(l),null],transform:[n(l),null],transform_box:[n(l),null],transform_origin:[n(l),null],transform_style:[n(l),null],transition:[n(l),null],transition_delay:[n(l),null],transition_duration:[n(l),null],transition_property:[n(l),null],transition_timing_function:[n(l),null],translate:[n(l),null],unicode_bidi:[n(l),null],user_select:[n(l),null],vertical_align:[n(l),null],visibility:[n(l),null],white_space:[n(l),null],widows:[n(l),null],width:[n(l),null],will_change:[n(l),null],word_break:[n(l),null],word_spacing:[n(l),null],word_wrap:[n(l),null],writing_mode:[n(l),null],z_index:[n(l),null]})))},\n", - " function _(e,n,t,l,r){var s,i;l();const u=e(1),S=e(50),_=u.__importStar(e(56));class h extends S.Model{constructor(e){super(e)}}t.StyleSheet=h,h.__name__=\"StyleSheet\";class y extends h{constructor(e){super(e)}underlying(){return new _.InlineStyleSheet(this.css)}}t.InlineStyleSheet=y,s=y,y.__name__=\"InlineStyleSheet\",s.define((({String:e})=>({css:[e]})));class d extends h{constructor(e){super(e)}underlying(){return new _.ImportedStyleSheet(this.url)}}t.ImportedStyleSheet=d,i=d,d.__name__=\"ImportedStyleSheet\",i.define((({String:e})=>({url:[e]})));class o extends y{constructor(e){super(e),this._underlying=null}underlying(){return null==this._underlying&&(this._underlying=new _.GlobalInlineStyleSheet(this.css)),this._underlying}}t.GlobalInlineStyleSheet=o,o.__name__=\"GlobalInlineStyleSheet\";class c extends d{constructor(e){super(e),this._underlying=null}underlying(){return null==this._underlying&&(this._underlying=new _.GlobalInlineStyleSheet(this.url)),this._underlying}}t.GlobalImportedStyleSheet=c,c.__name__=\"GlobalImportedStyleSheet\"},\n", - " function _(t,e,s,i,a){i();const n=t(261),r=t(57),h=t(56);class o{get canvas(){return this._canvas}get ctx(){return this._ctx}get el(){return this._el}constructor(t,e){switch(this.pixel_ratio=1,this.bbox=new r.BBox,this.backend=t,this.hidpi=e,t){case\"webgl\":case\"canvas\":{this._el=this._canvas=(0,h.canvas)({class:\"bk-layer\"});const t=this.canvas.getContext(\"2d\");if(null==t)throw new Error(\"unable to obtain 2D rendering context\");this._ctx=t,e&&(this.pixel_ratio=devicePixelRatio);break}case\"svg\":{const t=new n.SVGRenderingContext2D;this._ctx=t,this._canvas=t.get_svg(),this._el=(0,h.div)({class:\"bk-layer\"});this._el.attachShadow({mode:\"open\"}).appendChild(this._canvas);break}}this._ctx.layer=this}resize(t,e){if(this.bbox.width==t&&this.bbox.height==e)return;this.bbox=new r.BBox({left:0,top:0,width:t,height:e});const{target:s}=this;s.width=t*this.pixel_ratio,s.height=e*this.pixel_ratio}get target(){return this._ctx instanceof n.SVGRenderingContext2D?this._ctx:this.canvas}undo_transform(t){const{ctx:e}=this,s=e.getTransform();e.resetTransform();try{t(e)}finally{e.setTransform(s)}}prepare(){const{ctx:t,hidpi:e,pixel_ratio:s}=this;t.save(),e&&(t.scale(s,s),t.translate(.5,.5)),this.clear()}clear(){const{x:t,y:e,width:s,height:i}=this.bbox;this.ctx.clearRect(t,e,s,i)}finish(){this.ctx.restore()}to_blob(){const{_canvas:t}=this;if(t instanceof HTMLCanvasElement)return new Promise(((e,s)=>{t.toBlob((t=>null!=t?e(t):s()),\"image/png\")}));{const t=this._ctx.get_serialized_svg(!0),e=new Blob([t],{type:\"image/svg+xml\"});return Promise.resolve(e)}}}s.CanvasLayer=o,o.__name__=\"CanvasLayer\"},\n", - " function _(t,e,i,s,r){s();const n=t(153),a=t(8),o=t(262),l=t(11),h=t(56);function _(t){const e={left:\"start\",right:\"end\",center:\"middle\",start:\"start\",end:\"end\"};return t in e?e[t]:e.start}function c(t){const e={alphabetic:\"alphabetic\",hanging:\"hanging\",top:\"text-before-edge\",bottom:\"text-after-edge\",middle:\"central\"};return t in e?e[t]:e.alphabetic}const p=function(t,e){const i=new Map,s=t.split(\",\");e=null!=e?e:10;for(let t=0;t=0?Math.acos(e):-Math.acos(e)}const v=b(f),A=b(g);this.lineTo(d+f[0]*r,m+f[1]*r),this.arc(d,m,r,v,A)}stroke(){\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"fill\"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"stroke\"),null!=this._clip_path&&this.__currentElement.setAttribute(\"clip-path\",this._clip_path)}fill(t,e){let i=null;if(t instanceof Path2D)i=t;else{if(null!=e)throw new Error(\"invalid arguments\");e=t}if(null!=i)throw new Error(\"not implemented\");\"none\"!=this.__currentElement.getAttribute(\"fill\")&&this.__init_element(),\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"stroke\"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"fill\"),null!=e&&this.__currentElement.setAttribute(\"fill-rule\",e),null!=this._clip_path&&this.__currentElement.setAttribute(\"clip-path\",this._clip_path)}rect(t,e,i,s){isFinite(t+e+i+s)&&(this.moveTo(t,e),this.lineTo(t+i,e),this.lineTo(t+i,e+s),this.lineTo(t,e+s),this.lineTo(t,e),this.closePath())}fillRect(t,e,i,s){isFinite(t+e+i+s)&&(this.beginPath(),this.rect(t,e,i,s),this.fill())}strokeRect(t,e,i,s){isFinite(t+e+i+s)&&(this.beginPath(),this.rect(t,e,i,s),this.stroke())}__clearCanvas(){(0,h.empty)(this.__defs),(0,h.empty)(this.__root),this.__root.appendChild(this.__defs),this.__currentElement=this.__root}clearRect(t,e,i,s){if(!isFinite(t+e+i+s))return;if(0===t&&0===e&&i===this.width&&s===this.height)return void this.__clearCanvas();const r=this.__createElement(\"rect\",{x:t,y:e,width:i,height:s,fill:\"#FFFFFF\"},!0);this._apply_transform(r),this.__root.appendChild(r)}roundRect(t,e,i,s,r){throw new Error(\"not implemented\")}createLinearGradient(t,e,i,s){if(!isFinite(t+e+i+s))throw new Error(\"The provided double value is non-finite\");const[r,n]=this._transform.apply(t,e),[a,o]=this._transform.apply(i,s),l=this.__createElement(\"linearGradient\",{id:this._random_string(),x1:`${r}px`,x2:`${a}px`,y1:`${n}px`,y2:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(l),new d(l,this)}createRadialGradient(t,e,i,s,r,n){if(!isFinite(t+e+i+s+r+n))throw new Error(\"The provided double value is non-finite\");const[a,o]=this._transform.apply(t,e),[l,h]=this._transform.apply(s,r),_=this.__createElement(\"radialGradient\",{id:this._random_string(),cx:`${l}px`,cy:`${h}px`,r:`${n}px`,r0:`${i}px`,fx:`${a}px`,fy:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(_),new d(_,this)}createConicGradient(t,e,i){throw Error(\"not implemented\")}__parseFont(){const[,t,e,i,s,,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);return{style:null!=t?t:\"normal\",size:null!=s?s:\"10px\",family:null!=r?r:\"sans-serif\",weight:null!=i?i:\"normal\",decoration:null!=e?e:\"normal\"}}__applyText(t,e,i,s){const r=this.__parseFont(),n=this.__createElement(\"text\",{\"font-family\":r.family,\"font-size\":r.size,\"font-style\":r.style,\"font-weight\":r.weight,\"text-decoration\":r.decoration,x:e,y:i,\"text-anchor\":_(this.textAlign),\"dominant-baseline\":c(this.textBaseline)},!0);n.appendChild(this.__document.createTextNode(t)),this._apply_transform(n),this.__currentElement=n,this.__applyStyleToCurrentElement(s);const a=(()=>{if(null!=this._clip_path){const t=this.__createElement(\"g\");return t.setAttribute(\"clip-path\",this._clip_path),t.appendChild(n),t}return n})();this.__root.appendChild(a)}fillText(t,e,i){isFinite(e+i)&&this.__applyText(t,e,i,\"fill\")}strokeText(t,e,i){isFinite(e+i)&&this.__applyText(t,e,i,\"stroke\")}measureText(t){return this.__ctx.font=this.font,this.__ctx.measureText(t)}arc(t,e,i,s,r,n=!1){this.ellipse(t,e,i,i,0,s,r,n)}ellipse(t,e,i,s,r,a,o,h=!1){if(!isFinite(t+e+i+s+r+a+o))return;if(i<0||s<0)throw new DOMException(\"IndexSizeError, radius can't be negative\");const _=h?o-a:a-o;a%=2*Math.PI,o%=2*Math.PI;const c=(new n.AffineTransform).translate(t,e).rotate(r),p=i*Math.cos(a),u=s*Math.sin(a),[d,m]=c.apply(p,u);this.lineTo(d,m);const f=180*r/Math.PI,g=h?0:1;if(Math.abs(a-o)<2*l.float32_epsilon&&!(Math.abs(_)<2*l.float32_epsilon&&_<0)){const[t,e]=this._transform.apply(d,m),r=i*Math.cos(a+Math.PI),n=s*Math.sin(a+Math.PI),[o,l]=c.apply(r,n),[h,_]=this._transform.apply(o,l);this.__addPathCommand(t,e,`A ${i} ${s} ${f} 0 ${g} ${h} ${_} A ${i} ${s} ${f} 0 ${g} ${t} ${e}`)}else{const t=i*Math.cos(o),e=s*Math.sin(o),[r,n]=c.apply(t,e);let l=o-a;l<0&&(l+=2*Math.PI);const _=h!==l>Math.PI?1:0,[p,u]=this._transform.apply(r,n);this.__addPathCommand(p,u,`A ${i} ${s} ${f} ${_} ${g} ${p} ${u}`)}}clip(){const t=this.__createElement(\"clipPath\"),e=this._random_string();this.__applyCurrentDefaultPath(),t.setAttribute(\"id\",e),t.appendChild(this.__currentElement),this.__defs.appendChild(t),this._clip_path=`url(#${e})`}drawImage(t,...e){let i,s,r,n,a,o,l,h;if(2==e.length){if([i,s]=e,!isFinite(i+s))return;a=0,o=0,l=t.width,h=t.height,r=l,n=h}else if(4==e.length){if([i,s,r,n]=e,!isFinite(i+s+r+n))return;a=0,o=0,l=t.width,h=t.height}else{if(8!==e.length)throw new Error(`Inavlid number of arguments passed to drawImage: ${arguments.length}`);if([a,o,l,h,i,s,r,n]=e,!isFinite(a+o+l+h+i+s+r+n))return}const _=this.__root,c=this._transform.clone().translate(i,s);if(t instanceof f||t instanceof SVGSVGElement){const e=(t instanceof SVGSVGElement?t:t.get_svg()).cloneNode(!0);let i;c.is_identity&&1==this.globalAlpha&&null==this._clip_path?i=_:(i=this.__createElement(\"g\"),c.is_identity||this._apply_transform(i,c),1!=this.globalAlpha&&i.setAttribute(\"opacity\",`${this.globalAlpha}`),null!=this._clip_path&&i.setAttribute(\"clip-path\",this._clip_path),_.appendChild(i));for(const t of[...e.childNodes])if(t instanceof SVGDefsElement){for(const e of[...t.childNodes])if(e instanceof Element){const t=e.getAttribute(\"id\");this.__ids.add(t),this.__defs.appendChild(e.cloneNode(!0))}}else i.appendChild(t.cloneNode(!0))}else if(t instanceof HTMLImageElement||t instanceof SVGImageElement){const e=this.__createElement(\"image\");if(e.setAttribute(\"width\",`${r}`),e.setAttribute(\"height\",`${n}`),e.setAttribute(\"preserveAspectRatio\",\"none\"),1!=this.globalAlpha&&e.setAttribute(\"opacity\",`${this.globalAlpha}`),0!=a||0!=o||l!==t.width||h!==t.height){const e=this.__document.createElement(\"canvas\");e.width=r,e.height=n;e.getContext(\"2d\").drawImage(t,a,o,l,h,0,0,r,n),t=e}this._apply_transform(e,c);const i=t instanceof HTMLCanvasElement?t.toDataURL():t.getAttribute(\"src\");if(e.setAttribute(\"href\",i),null!=this._clip_path){const t=this.__createElement(\"g\");t.setAttribute(\"clip-path\",this._clip_path),t.appendChild(e),_.appendChild(t)}else _.appendChild(e)}else if(t instanceof HTMLCanvasElement){const e=this.__createElement(\"image\");e.setAttribute(\"width\",`${r}`),e.setAttribute(\"height\",`${n}`),e.setAttribute(\"preserveAspectRatio\",\"none\"),1!=this.globalAlpha&&e.setAttribute(\"opacity\",`${this.globalAlpha}`);const i=this.__document.createElement(\"canvas\");i.width=r,i.height=n;const s=i.getContext(\"2d\");if(s.imageSmoothingEnabled=!1,s.drawImage(t,a,o,l,h,0,0,r,n),t=i,this._apply_transform(e,c),e.setAttribute(\"href\",t.toDataURL()),null!=this._clip_path){const t=this.__createElement(\"g\");t.setAttribute(\"clip-path\",this._clip_path),t.appendChild(e),_.appendChild(t)}else _.appendChild(e)}}createPattern(t,e){const i=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"pattern\"),s=this._random_string();if(i.setAttribute(\"id\",s),i.setAttribute(\"width\",`${this._to_number(t.width)}`),i.setAttribute(\"height\",`${this._to_number(t.height)}`),i.setAttribute(\"patternUnits\",\"userSpaceOnUse\"),t instanceof HTMLCanvasElement||t instanceof HTMLImageElement||t instanceof SVGImageElement){const e=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"image\"),s=t instanceof HTMLCanvasElement?t.toDataURL():t.getAttribute(\"src\");e.setAttribute(\"href\",s),i.appendChild(e),this.__defs.appendChild(i)}else if(t instanceof f){for(const e of[...t.__root.childNodes])e instanceof SVGDefsElement||i.appendChild(e.cloneNode(!0));this.__defs.appendChild(i)}else{if(!(t instanceof SVGSVGElement))throw new Error(\"unsupported\");for(const e of[...t.childNodes])e instanceof SVGDefsElement||i.appendChild(e.cloneNode(!0));this.__defs.appendChild(i)}return new m(i,this)}getLineDash(){const{lineDash:t}=this;return(0,a.isString)(t)?t.split(\",\").map((t=>parseInt(t))):null==t?[]:t}setLineDash(t){t.length>0?this.lineDash=t.join(\",\"):this.lineDash=null}_to_number(t){return(0,a.isNumber)(t)?t:t.baseVal.value}getTransform(){return this._transform.to_DOMMatrix()}setTransform(...t){let e;e=(0,a.isNumber)(t[0])?new DOMMatrix(t):t[0]instanceof DOMMatrix?t[0]:new DOMMatrix(Object.values(null==t[0])),this._transform=n.AffineTransform.from_DOMMatrix(e)}resetTransform(){this._transform=new n.AffineTransform}isPointInPath(...t){throw new Error(\"not implemented\")}isPointInStroke(...t){throw new Error(\"not implemented\")}createImageData(...t){throw new Error(\"not implemented\")}getImageData(t,e,i,s){throw new Error(\"not implemented\")}putImageData(...t){throw new Error(\"not implemented\")}drawFocusIfNeeded(...t){throw new Error(\"not implemented\")}scrollPathIntoView(...t){throw new Error(\"not implemented\")}}i.SVGRenderingContext2D=f,f.__name__=\"SVGRenderingContext2D\",f.__random=o.random},\n", - " function _(t,e,n,s,r){s();const{PI:o,log:a,sin:_,cos:i,sqrt:m,floor:l}=Math;n.MAX_INT32=2147483647;class d{float(){return(this.integer()-1)/(n.MAX_INT32-1)}floats(t,e=0,n=1){const s=new Array(t);for(let r=0;rthis.uniform(t,e)))}normal(t,e){return this.normals(t,e,1)[0]}normals(t,e,n){const[s,r]=[t,e],l=new Float64Array(n);for(let t=0;t{this.model.active?this.activate():this.deactivate()}))}get overlays(){return[]}activate(){}deactivate(){}}n.ToolView=u,u.__name__=\"ToolView\";class d extends _.Model{constructor(t){super(t)}get event_role(){const{event_type:t}=this;return(0,c.isString)(t)?t:\"multi\"}get event_types(){const{event_type:t}=this;return null==t?[]:(0,c.isString)(t)?[t]:t}get tooltip(){var t;return null!==(t=this.description)&&void 0!==t?t:this.tool_name}get computed_icon(){const{icon:t,tool_icon:e}=this;return null!=t?t:null!=e?`.${e}`:void 0}get menu(){return null}_get_dim_limits([t,e],[n,o],i,s){const a=i.bbox.h_range;let r;\"width\"==s||\"both\"==s?(r=[(0,l.min)([t,n]),(0,l.max)([t,n])],r=[(0,l.max)([r[0],a.start]),(0,l.min)([r[1],a.end])]):r=[a.start,a.end];const c=i.bbox.v_range;let _;return\"height\"==s||\"both\"==s?(_=[(0,l.min)([e,o]),(0,l.max)([e,o])],_=[(0,l.max)([_[0],c.start]),(0,l.min)([_[1],c.end])]):_=[c.start,c.end],[r,_]}_get_dim_tooltip(t){const{description:e,tool_name:n}=this;return null!=e?e:\"both\"==t?n:\"auto\"==t?`${n} (either x, y or both dimensions)`:`${n} (${\"width\"==t?\"x\":\"y\"}-axis)`}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=d,s=d,d.__name__=\"Tool\",s.prototype._known_aliases=new Map,s.define((({String:t,Regex:e,Nullable:n,Or:o})=>({icon:[n(o(r.ToolIcon,e(/^--/),e(/^\\./),e(/^data:image/))),null],description:[n(t),null]}))),s.internal((({Boolean:t})=>({active:[t,!1],disabled:[t,!1]})))},\n", - " function _(t,o,e,s,n){var i;s();const l=t(15),r=t(50),c=t(264),a=t(32);class u extends r.Model{constructor(t){super(t)}get underlying(){return this.tools[0]}tool_button(){const t=this.tools[0].tool_button();return t.tool=this,t}get event_type(){return this.tools[0].event_type}get event_role(){return this.tools[0].event_role}get event_types(){return this.tools[0].event_types}get default_order(){return this.tools[0].default_order}get tooltip(){return this.tools[0].tooltip}get tool_name(){return this.tools[0].tool_name}get computed_icon(){return this.tools[0].computed_icon}get toggleable(){const t=this.tools[0];return\"toggleable\"in t&&t.toggleable}initialize(){super.initialize(),this.do=new l.Signal0(this,\"do\")}connect_signals(){super.connect_signals(),this.connect(this.do,(()=>this.doit())),this.connect(this.properties.active.change,(()=>this.set_active()));for(const t of this.tools)this.connect(t.properties.active.change,(()=>{this.active=t.active}))}doit(){for(const t of this.tools)t.do.emit()}set_active(){for(const t of this.tools)t.active=this.active}get menu(){const{menu:t}=this.tools[0];if(null==t)return null;const o=[];for(const[e,s]of(0,a.enumerate)(t))if(null==e)o.push(null);else{const t=()=>{var t,o,e;for(const n of this.tools)null===(e=null===(o=null===(t=n.menu)||void 0===t?void 0:t[s])||void 0===o?void 0:o.handler)||void 0===e||e.call(o)};o.push(Object.assign(Object.assign({},e),{handler:t}))}return o}}e.ToolProxy=u,i=u,u.__name__=\"ToolProxy\",i.define((({Boolean:t,Array:o,Ref:e})=>({tools:[o(e(c.Tool)),[]],active:[t,t=>(0,a.some)(t.tools,(t=>t.active))],disabled:[t,!1]})))},\n", - " function _(e,t,s,o,l){var i;o();const n=e(1),a=e(257),r=e(264),d=e(265),c=e(56),h=e(19),u=e(267),m=e(10),_=n.__importStar(e(270)),p=_,v=n.__importDefault(e(269));class f extends a.UIElementView{initialize(){var e;super.initialize();const{location:t}=this.parent.model,s=\"left\"==t||\"above\"==t,o=this.parent.model.horizontal?\"vertical\":\"horizontal\",l=null!==(e=this.model.tool.menu)&&void 0!==e?e:[];this._menu=new u.ContextMenu(s?(0,m.reversed)(l):l,{target:this.root.el,orientation:o,prevent_hide:e=>e.composedPath().includes(this.el)});let i=null,n=null;this.el.addEventListener(\"pointerdown\",(e=>{e.buttons==c.MouseButton.Left&&(i=e.timeStamp,n=setTimeout((()=>{i=null,n=null,this._pressed()}),250))})),this.el.addEventListener(\"pointerup\",(e=>{if(null!=n&&(clearTimeout(n),n=null),null!=i){if(e.timeStamp-i>=250)this._pressed();else{if(this._menu.is_open)return void this._menu.hide();e.composedPath().includes(this.el)&&this._clicked()}i=null}})),this.el.addEventListener(\"keydown\",(e=>{switch(e.key){case\"Enter\":this._clicked();break;case\" \":this._pressed()}}))}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.render())),this.connect(this.model.tool.change,(()=>this.render()))}remove(){this._menu.remove(),super.remove()}stylesheets(){return[...super.stylesheets(),_.default,v.default]}render(){var e,t;super.render(),this.class_list.add(p[this.parent.model.location]),this.model.tool.disabled&&this.class_list.add(p.disabled);const s=(0,c.div)({class:p.tool_icon});this.shadow_el.appendChild(s);const o=null!==(e=this.model.icon)&&void 0!==e?e:this.model.tool.computed_icon;if(null!=o)if(o.startsWith(\"data:image\")){const e=`url(\"${encodeURI(o)}\")`;s.style.backgroundImage=e}else if(o.startsWith(\"--\"))s.style.backgroundImage=`var(${o})`;else if(o.startsWith(\".\")){const e=o.substring(1);s.classList.add(e)}else if(h.ToolIcon.valid(o)){const e=`bk-tool-icon-${o.replace(/_/g,\"-\")}`;s.classList.add(e)}if(null!=this.model.tool.menu){const e=(0,c.div)({class:p.tool_chevron});this.shadow_el.appendChild(e)}const l=null!==(t=this.model.tooltip)&&void 0!==t?t:this.model.tool.tooltip;this.el.title=l,this.el.tabIndex=0}_pressed(){const e=(()=>{switch(this.parent.model.location){case\"right\":return{left_of:this.el};case\"left\":return{right_of:this.el};case\"above\":return{below:this.el};case\"below\":return{above:this.el}}})();this._menu.toggle(e)}}s.ToolButtonView=f,f.__name__=\"ToolButtonView\";class g extends a.UIElement{constructor(e){super(e)}}s.ToolButton=g,i=g,g.__name__=\"ToolButton\",i.define((({String:e,Regex:t,Ref:s,Nullable:o,Or:l})=>({tool:[l(s(r.Tool),s(d.ToolProxy))],icon:[o(l(h.ToolIcon,t(/^--/),t(/^\\./),t(/^data:image/))),null],tooltip:[o(e),null]})))},\n", - " function _(t,e,i,n,o){n();const s=t(1),l=t(56),h=t(10),r=t(8),d=s.__importStar(t(268)),a=d,u=s.__importDefault(t(269)),_=s.__importDefault(t(58));class c{get is_open(){return this._open}get can_open(){return 0!=this.items.length}constructor(t,e){var i,n,o;this.el=(0,l.div)(),this._open=!1,this._item_click=t=>{var e;null===(e=t.handler)||void 0===e||e.call(t),this.hide()},this._on_mousedown=t=>{var e,i;t.composedPath().includes(this.el)||null!==(i=null===(e=this.prevent_hide)||void 0===e?void 0:e.call(this,t))&&void 0!==i&&i||this.hide()},this._on_keydown=t=>{\"Escape\"==t.key&&this.hide()},this._on_blur=()=>{this.hide()},this.items=t,this.target=e.target,this.orientation=null!==(i=e.orientation)&&void 0!==i?i:\"vertical\",this.reversed=null!==(n=e.reversed)&&void 0!==n&&n,this.prevent_hide=e.prevent_hide,this.extra_styles=null!==(o=e.extra_styles)&&void 0!==o?o:[],this.shadow_el=this.el.attachShadow({mode:\"open\"}),this.class_list=new l.ClassList(this.el.classList)}remove(){this._unlisten(),(0,l.remove)(this.el)}_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){var e;const i=(()=>{if(\"left_of\"in t){const{left:e,top:i}=t.left_of.getBoundingClientRect();return{right:e,top:i}}if(\"right_of\"in t){const{top:e,right:i}=t.right_of.getBoundingClientRect();return{left:i,top:e}}if(\"below\"in t){const{left:e,bottom:i}=t.below.getBoundingClientRect();return{left:e,top:i}}if(\"above\"in t){const{left:e,top:i}=t.above.getBoundingClientRect();return{left:e,bottom:i}}return t})(),n=null!==(e=this.el.offsetParent)&&void 0!==e?e:document.body,o=(()=>{const t=n.getBoundingClientRect(),e=getComputedStyle(n);return{left:t.left-parseFloat(e.marginLeft),right:t.right+parseFloat(e.marginRight),top:t.top-parseFloat(e.marginTop),bottom:t.bottom+parseFloat(e.marginBottom)}})(),{style:s}=this.el;s.left=null!=i.left?i.left-o.left+\"px\":\"auto\",s.top=null!=i.top?i.top-o.top+\"px\":\"auto\",s.right=null!=i.right?o.right-i.right+\"px\":\"auto\",s.bottom=null!=i.bottom?o.bottom-i.bottom+\"px\":\"auto\"}stylesheets(){return[_.default,d.default,u.default,...this.extra_styles]}empty(){(0,l.empty)(this.shadow_el),this.class_list.clear()}render(){var t,e;this.empty();for(const t of this.stylesheets()){((0,r.isString)(t)?new l.InlineStyleSheet(t):t).install(this.shadow_el)}this.class_list.add(a[this.orientation]);const i=this.reversed?(0,h.reversed)(this.items):this.items;for(const n of i){let i;if(null==n)i=(0,l.div)({class:a.divider});else{if(null!=n.if&&!n.if())continue;if(null!=n.content)i=n.content;else{const o=null!=n.icon?(0,l.div)({class:[a.menu_icon,n.icon]}):null,s=[null!==(e=null===(t=n.active)||void 0===t?void 0:t.call(n))&&void 0!==e&&e?a.active:null,n.class];i=(0,l.div)({class:s,title:n.tooltip,tabIndex:0},o,n.label,n.content),i.addEventListener(\"click\",(()=>{this._item_click(n)})),i.addEventListener(\"keydown\",(t=>{\"Enter\"==t.key&&this._item_click(n)}))}}this.shadow_el.appendChild(i)}}show(t){var e;if(0!=this.items.length&&!this._open){if(this.render(),0==this.shadow_el.children.length)return;(null!==(e=this.target.shadowRoot)&&void 0!==e?e:this.target).appendChild(this.el),this._position(null!=t?t:{left:0,top:0}),this._listen(),this._open=!0}}hide(){this._open&&(this._open=!1,this._unlisten(),(0,l.remove)(this.el))}toggle(t){this._open?this.hide():this.show(t)}}i.ContextMenu=c,c.__name__=\"ContextMenu\"},\n", - " function _(r,o,i,e,t){e(),i.menu_icon=\"bk-menu-icon\",i.horizontal=\"bk-horizontal\",i.vertical=\"bk-vertical\",i.divider=\"bk-divider\",i.active=\"bk-active\",i.default=\".bk-menu-icon{width:28px;height:28px;mask-size:60% 60%;mask-position:center center;mask-repeat:no-repeat;-webkit-mask-size:60% 60%;-webkit-mask-position:center center;-webkit-mask-repeat:no-repeat;background-size:60%;background-color:transparent;background-repeat:no-repeat;background-position:center center;}:host{position:absolute;display:inline-flex;flex-wrap:nowrap;user-select:none;-webkit-user-select:none;width:auto;height:auto;z-index:100;cursor:pointer;font-size:var(--font-size);background-color:#fff;border:1px solid #ccc;border-radius:var(--border-radius);box-shadow:0 6px 12px rgba(0, 0, 0, 0.175);}:host(.bk-horizontal){flex-direction:row;}:host(.bk-vertical){flex-direction:column;}.bk-divider{cursor:default;overflow:hidden;background-color:#e5e5e5;}:host(.bk-horizontal) > .bk-divider{width:1px;margin:5px 0;}:host(.bk-vertical) > .bk-divider{height:1px;margin:0 5px;}:host > :not(.bk-divider){border:1px solid transparent;--active-tool-highlight:#26aae1;}:host > :not(.bk-divider).bk-active{border-color:var(--active-tool-highlight);}:host > :not(.bk-divider):hover{background-color:#f9f9f9;}:host > :not(.bk-divider):focus,:host > :not(.bk-divider):focus-visible{outline:1px dotted var(--active-tool-highlight);outline-offset:-1px;}:host > :not(.bk-divider)::-moz-focus-inner{border:0;}:host(.bk-horizontal) > :not(.bk-divider):first-child{border-top-left-radius:var(--border-radius);border-bottom-left-radius:var(--border-radius);}:host(.bk-horizontal) > :not(.bk-divider):last-child{border-top-right-radius:var(--border-radius);border-bottom-right-radius:var(--border-radius);}:host(.bk-vertical) > :not(.bk-divider):first-child{border-top-left-radius:var(--border-radius);border-top-right-radius:var(--border-radius);}:host(.bk-vertical) > :not(.bk-divider):last-child{border-bottom-left-radius:var(--border-radius);border-bottom-right-radius:var(--border-radius);}\"},\n", - " function _(o,A,e,t,n){t(),e.tool_icon_copy=\"bk-tool-icon-copy\",e.tool_icon_replace_mode=\"bk-tool-icon-replace-mode\",e.tool_icon_append_mode=\"bk-tool-icon-append-mode\",e.tool_icon_intersect_mode=\"bk-tool-icon-intersect-mode\",e.tool_icon_subtract_mode=\"bk-tool-icon-subtract-mode\",e.tool_icon_clear_selection=\"bk-tool-icon-clear-selection\",e.tool_icon_box_select=\"bk-tool-icon-box-select\",e.tool_icon_x_box_select=\"bk-tool-icon-x-box-select\",e.tool_icon_y_box_select=\"bk-tool-icon-y-box-select\",e.tool_icon_box_zoom=\"bk-tool-icon-box-zoom\",e.tool_icon_x_box_zoom=\"bk-tool-icon-x-box-zoom\",e.tool_icon_y_box_zoom=\"bk-tool-icon-y-box-zoom\",e.tool_icon_auto_box_zoom=\"bk-tool-icon-auto-box-zoom\",e.tool_icon_zoom_in=\"bk-tool-icon-zoom-in\",e.tool_icon_zoom_out=\"bk-tool-icon-zoom-out\",e.tool_icon_help=\"bk-tool-icon-help\",e.tool_icon_hover=\"bk-tool-icon-hover\",e.tool_icon_crosshair=\"bk-tool-icon-crosshair\",e.tool_icon_lasso_select=\"bk-tool-icon-lasso-select\",e.tool_icon_pan=\"bk-tool-icon-pan\",e.tool_icon_x_pan=\"bk-tool-icon-x-pan\",e.tool_icon_y_pan=\"bk-tool-icon-y-pan\",e.tool_icon_range=\"bk-tool-icon-range\",e.tool_icon_polygon_select=\"bk-tool-icon-polygon-select\",e.tool_icon_redo=\"bk-tool-icon-redo\",e.tool_icon_reset=\"bk-tool-icon-reset\",e.tool_icon_save=\"bk-tool-icon-save\",e.tool_icon_tap_select=\"bk-tool-icon-tap-select\",e.tool_icon_undo=\"bk-tool-icon-undo\",e.tool_icon_wheel_pan=\"bk-tool-icon-wheel-pan\",e.tool_icon_wheel_zoom=\"bk-tool-icon-wheel-zoom\",e.tool_icon_box_edit=\"bk-tool-icon-box-edit\",e.tool_icon_freehand_draw=\"bk-tool-icon-freehand-draw\",e.tool_icon_poly_draw=\"bk-tool-icon-poly-draw\",e.tool_icon_point_draw=\"bk-tool-icon-point-draw\",e.tool_icon_poly_edit=\"bk-tool-icon-poly-edit\",e.tool_icon_line_edit=\"bk-tool-icon-line-edit\",e.tool_icon_settings=\"bk-tool-icon-settings\",e.tool_icon_unknown=\"bk-tool-icon-unknown\",e.tool_icon_fullscreen=\"bk-tool-icon-fullscreen\",e.tool_icon_chevron_up=\"bk-tool-icon-chevron-up\",e.tool_icon_chevron_down=\"bk-tool-icon-chevron-down\",e.tool_icon_chevron_left=\"bk-tool-icon-chevron-left\",e.tool_icon_chevron_right=\"bk-tool-icon-chevron-right\",e.tool_icon_caret_up=\"bk-tool-icon-caret-up\",e.tool_icon_caret_down=\"bk-tool-icon-caret-down\",e.tool_icon_caret_left=\"bk-tool-icon-caret-left\",e.tool_icon_caret_right=\"bk-tool-icon-caret-right\",e.tool_icon_see_on=\"bk-tool-icon-see-on\",e.tool_icon_see_off=\"bk-tool-icon-see-off\",e.default=':host{--bokeh-icon-color:#a1a6a9;--bokeh-icon-color-disabled:#d4d9db;}.bk-tool-icon-copy{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-copy);-webkit-mask-image:var(--bokeh-icon-copy);}.bk-tool-icon-replace-mode{background-image:var(--bokeh-icon-replace-mode, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH5AUFFxokK3gniQAAAHpJREFUWMNjXLhsJcNAAiaGAQajDhhwB7DgEP+PxmeksvjgDwFcLmYkUh2hkBj8IcBIZXsYh1w2/I8v3sgAOM0bLYhGc8GgrwuICgldfQO88pcvXvg/aOuCUQeM5oLRuoCFCJcTbOMh5XOiW0JDNhdQS3y0IBp1ABwAAF8KGrhC1Eg6AAAAAElFTkSuQmCC\"));}.bk-tool-icon-append-mode{background-image:var(--bokeh-icon-append-mode, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH5AUFFxkZWD04WwAAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTVBkLmUHAAAAoUlEQVRYw+1WQQ6AIAwrhO8Y/bIXEz9jIMSDr8ETCUEPQzA4pMeFLKNbu4l5WR0CDOMEALBGIzMuQIBEZQjPgP9JLjwTfBjY9sO9lZsFA9IafZng3BlIyVefgd8XQFZBAWe8jfNxwsDhir6rzoCiPiy1K+J8/FRQemv2XfAdFcQ9znU4Viqg9ta1qYJ+D1BnAIBrkgGVOrXNqUA9rbyZm/AEzFh4jEeY/soAAAAASUVORK5CYII=\"));}.bk-tool-icon-intersect-mode{background-image:var(--bokeh-icon-intersect-mode, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH5AUFFxkrkOpp2wAAAPhJREFUWMPtV1EKwjAMTUavI3oawR/vtn5srJdREfzwMvHHQlcT2mpdMzFfWxiP5r2+JMN+mAiCOB72CABgR1cln4oOGocJnuMTSxWk8jMm7OggYkYXA9gPE3uyd8NXHONJ+eYMdE/NqCJmEZ5ZqlJJ4sUksKN7cYSaPoCZFWR1QI+Xm1fBACU63Cw22x0AAJxudwrffVwvZ+JmQdAHZkw0d4EpAMCw8k87pMdbnwtizQumJYv3nwV6XOA1qbUT/oQLUJgFRbsiNwFVucBIlyR3p0tdMp+XmFjfLKi1LatyAXtCRjPWBdL3Ke3VuACJKFfDr/xFN2fgAR/Go0qaLlmEAAAAAElFTkSuQmCC\"));}.bk-tool-icon-subtract-mode{background-image:var(--bokeh-icon-subtract-mode, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH5AUFFxgsF5XNOQAAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTVBkLmUHAAABFUlEQVRYw9VWUQqDMAxNpWfxQxD1MoP97G7zQ5mH2RTZYLtM9lWoMbXtxLXNX4OG9r28l4hrd0PQoqxqAACYpxH25C/nkwCHyCBwSPoS09k1T5Fo+4EiExcC4v584xGFmyIXHBLRISAVZyZufUPVa4rcrwmPDgr93ylo+2GliLRUYHK6th/o/6r7nfLpqaCsagEA8Hh9FmcNKeRmgeYDC+SCq0B6FFi8/BcV6BdR9cL3gCv3ijPKOacsn3rBEcjmaVxpfGcg4wHxzgJJnc6241Hn23DERFRAu1bNcWa3Q0uXi62XR6sCaWoSejbtdLYmU3kTEunNgj0bUbQqYG/IcMaqwPS9jftoVCAQ0ZVDJwf0zQdH4AsyW6fpQu4YegAAAABJRU5ErkJggg==\"));}.bk-tool-icon-clear-selection{background-image:var(--bokeh-icon-clear-selection, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH5AUGEhcuan3d3wAAAoRJREFUWMPtlzFP3EAQhd+b3TNSzg0N5TWXLkJQUUaKhIQ4fgP/g5ArrriE/I3opEgRrZtIVJR0FJQ010SioUmEZHtnUpwN9gWHGA5BJCy58MraffvmfZ41v3z9hqe8BE98vQh4cgG+Ydzmnrng8efvQJNi/uN7dznx/B3ggtfhf4ehNdUttRzBDIm/2VTiiWCG1HK0nc+3UWtq8BQIiEEakEQOADBIA4QCQmBqoHBhFNR27ikQSmGdYCdTqCpEHMDZmEKRWUBEv1gBDg5SzRJnpopILWICgWuRYflLamuzxB2BmtYqSRIka5VWU8QduXO+1hRc5YZu5GAwmP2ZJzND0IBu5HCV2+NQcAhAVRsnC2IbPzPdSjzd6to6VtfWkXi6YLaVWr7xoAwkfpb8MnC3SH7rKSMBe4M0jA/OTicFIbtCGRIyNbURhcf3ErCd6YwA1m0HgAxhw1NGQnlXBHG4kylVlSJuH0RfIP2CkL2I/qS1gIAAQiBl1QwFggIHtyxgrxK5PgyfC0JWKoT0HLh8LwoietB4TYKaIl7yeNURxB05UtMxDOcVQlZIrlRKdK6m47gjR/fuBRQihyLArtNeJD50Izcx2Eczu7iFkIug4VM3cpOr3MKDekFED0fWUHv9Zq0kpLnridjhY3XDg7NTN0jDrhO3X7O9Wg7wwyANu4mnayNg3gmbu0tCNoUyBNGv2l4rB9EXynA7082FOxAQLhU6rQVO9T2AvWowFToNCJcPORGxIRcnpjZSKATSU9NxvOQnAPArDSaQoUKnNI4iufkGtD4P3EHIcWZhz4HLceSOyrR3Izf5memPAL2cX3yhAkonysZVaWLBkd9dw1Ivv2a/AYPkK+ty1U1DAAAAAElFTkSuQmCC\"));}.bk-tool-icon-box-select{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-box-select);-webkit-mask-image:var(--bokeh-icon-box-select);}.bk-tool-icon-x-box-select{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-x-box-select);-webkit-mask-image:var(--bokeh-icon-x-box-select);}.bk-tool-icon-y-box-select{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-y-box-select);-webkit-mask-image:var(--bokeh-icon-y-box-select);}.bk-tool-icon-box-zoom{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-box-zoom);-webkit-mask-image:var(--bokeh-icon-box-zoom);}.bk-tool-icon-x-box-zoom{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-x-box-zoom);-webkit-mask-image:var(--bokeh-icon-x-box-zoom);}.bk-tool-icon-y-box-zoom{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-y-box-zoom);-webkit-mask-image:var(--bokeh-icon-y-box-zoom);}.bk-tool-icon-auto-box-zoom{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-auto-box-zoom);-webkit-mask-image:var(--bokeh-icon-auto-box-zoom);}.bk-tool-icon-zoom-in{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-zoom-in);-webkit-mask-image:var(--bokeh-icon-zoom-in);}.bk-tool-icon-zoom-out{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-zoom-out);-webkit-mask-image:var(--bokeh-icon-zoom-out);}.bk-tool-icon-help{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-help);-webkit-mask-image:var(--bokeh-icon-help);}.bk-tool-icon-hover{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-hover);-webkit-mask-image:var(--bokeh-icon-hover);}.bk-tool-icon-crosshair{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-crosshair);-webkit-mask-image:var(--bokeh-icon-crosshair);}.bk-tool-icon-lasso-select{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-lasso-select);-webkit-mask-image:var(--bokeh-icon-lasso-select);}.bk-tool-icon-pan{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-pan);-webkit-mask-image:var(--bokeh-icon-pan);}.bk-tool-icon-x-pan{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-x-pan);-webkit-mask-image:var(--bokeh-icon-x-pan);}.bk-tool-icon-y-pan{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-y-pan);-webkit-mask-image:var(--bokeh-icon-y-pan);}.bk-tool-icon-range{background-image:var(--bokeh-icon-range, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAAlwSFlzAAALEwAACxMBAJqcGAAABCJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IlhNUCBDb3JlIDUuNC4wIj4KICAgPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICAgICAgPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIKICAgICAgICAgICAgeG1sbnM6dGlmZj0iaHR0cDovL25zLmFkb2JlLmNvbS90aWZmLzEuMC8iCiAgICAgICAgICAgIHhtbG5zOmV4aWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vZXhpZi8xLjAvIgogICAgICAgICAgICB4bWxuczpkYz0iaHR0cDovL3B1cmwub3JnL2RjL2VsZW1lbnRzLzEuMS8iCiAgICAgICAgICAgIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyI+CiAgICAgICAgIDx0aWZmOlJlc29sdXRpb25Vbml0PjI8L3RpZmY6UmVzb2x1dGlvblVuaXQ+CiAgICAgICAgIDx0aWZmOkNvbXByZXNzaW9uPjU8L3RpZmY6Q29tcHJlc3Npb24+CiAgICAgICAgIDx0aWZmOlhSZXNvbHV0aW9uPjcyPC90aWZmOlhSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpPcmllbnRhdGlvbj4xPC90aWZmOk9yaWVudGF0aW9uPgogICAgICAgICA8dGlmZjpZUmVzb2x1dGlvbj43MjwvdGlmZjpZUmVzb2x1dGlvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjMyPC9leGlmOlBpeGVsWERpbWVuc2lvbj4KICAgICAgICAgPGV4aWY6Q29sb3JTcGFjZT4xPC9leGlmOkNvbG9yU3BhY2U+CiAgICAgICAgIDxleGlmOlBpeGVsWURpbWVuc2lvbj4zMjwvZXhpZjpQaXhlbFlEaW1lbnNpb24+CiAgICAgICAgIDxkYzpzdWJqZWN0PgogICAgICAgICAgICA8cmRmOkJhZy8+CiAgICAgICAgIDwvZGM6c3ViamVjdD4KICAgICAgICAgPHhtcDpNb2RpZnlEYXRlPjIwMTgtMDQtMjhUMTQ6MDQ6NDk8L3htcDpNb2RpZnlEYXRlPgogICAgICAgICA8eG1wOkNyZWF0b3JUb29sPlBpeGVsbWF0b3IgMy43PC94bXA6Q3JlYXRvclRvb2w+CiAgICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogICA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgrsrWBhAAAD60lEQVRYCcVWv2scRxSemZ097SHbSeWkcYwwclDhzr1Q5T6QE1LghP6BGNIYJGRWNlaZItiFK1mr+JAu4HQu0kjpU8sgF3ITAsaFg0hOvt2Zyfvmdsa7a610Unx44Zgf773vvfneezPHNzrbhn3CT3xC3wPXYOC8LDzqdi8YY/gwh4BeknS/2th6dr2kf94AOp3OFyWgMyziOPbMDxV9FTtJnl1ut795Xd0/YQ0/vtYQwMT1KXWCfr2IjOWwtNehwN4xL9ykTrm6Pzl58yLn3J+mKh9mXbT3uRjGEDph+O8/TjfP5dBp7Ha7AX7O3o5nZeD/0E/OGyXntDgzA0X6qmCnrVutVlrUWV9f/3xo+pwhGDhvEPHOjoxnZjJggXmMHzBQ7NGNp9vxk61fr0HR7e/u7pZzCGHlc7qwBYYTT7tJYSx1AQzppyFPft5apta9w7SKcn0b7P7+/jCsDQ5mbc0dCmIJGDN0ehdcjsmkm6A6KUeKFOTE11PLxrC7Ukqh3ylL2fT0NAP9q6ur6rRCJJYsbKB0JsbCKMuy+xREePDyxQPCz+Crlw062QcA5wBOOt1l6vIl2WiI9F1fN6Q+BBqit6hEC4Hk08GQJMn4myjSP7RavVxgdaVUh/3U6HCMsPr9pYnJKRziHtWQ+un58+hGs6nsjQSjpuTyKGN3CX+FBwHXSiEVgjP+O8X6N12kIePES+GzTKAkGbNp8yJsGUMVzz8jPKReiyAQRimy5/cjye5RpF8utFp/+nwmT7d/NMzcFkS7yjJNGDaPURQxIQThEQy0SyF4l5WJYYhBa816vZ6dU7A6CAhbZVow/pDe0O9hVOoCi13r4BgBAvJHqMSQL2vE/iH6IAXEwgrRVUmBoRRwnwJQT98xEeVeSUyB4dJ5nwJBKdCFFGRmUCcu7rwIYypCTblaChuNBhWODrman5ub+4v0rMNBt8z6Ezh7GksJQpCbm79cMQE7QBFm/X6f0rjWnv8WRYg/QdbUpwDAEBy8vPyA8rNGzg3a8MiElwiM7dAtRqNoNptjGPM1laVxP9umWEMGLOKhKUOJDtBwDmzsw9fC/CzHr9SGuCTi2LbbKvVtmqXpCjMihBFa79Wrt5fGx9PDzc3fmu32Lf8qFliwU9emKhBSp+kRKn/hu9k1COEDbFdt/BoKWOAkuEbdVYyoIXv8+I/QK9dMHEb1Knb7MHOv8LFFOsjzCVHWOD7Ltn+MXCRF4729vWMDK+p8rLkvwjLg4N4v741m5YuwCI9CvHp1Ha8gFdBoPnQAkGsYYGxxcfEI7QQlFCTGUXwjAz4tWF+EpymOWu7fglE7qsOvrYE6g4+9/x/vhRbMdLOCFgAAAABJRU5ErkJggg==\"));}.bk-tool-icon-polygon-select{background-image:var(--bokeh-icon-polygon-select, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEMEjc1OfiVKAAAAe1JREFUWMPt1r9rU1EUB/DPK0XbqphFHETo4OCiFhwF0V1KHbRSROLqon+AUMVRRFBwEbRFMBiV+mMW/wIxi5OD1kERRVKRJHUwLvfBTZrU5OWBGXLgQu7Jfe98z/ec7z0vKa88b2q1BDtRHdAPBaylm1NzsxsOjPnPNt6WSWprbft+/c3I3zOAjhT1Y4+fvcjEQJIXnVECSa+AhqIHqlHH5lWCZoe+Gk4GRgDG86j9SAUdlDBSQaZhlOkuHyoVdJmsw98D1S5fM4NYM1LCpqM+Lwa240oLgmZzpVZvzKT75VLZcqksSZKWlQeAy/iORVwIvh31xvotvK7VG3Px4aWHj3Jl4C2uYSvq+Bn8v6LLbaVWb9zsBiKLCvbiNG7gLm7jAYqbPHMJMziZ9lsKoh8GtqCEVVzHftwJn+TFHp4/hg8BSCYVfMOZoPEv2NZGdy9WCGUr9toDR3E2/H4V6nwRe/BmgN65H1ZhvMuB3XiKIyFoGefwO6ysVkUlrNUNsyAK/jli533Q+Y8cJFvAeXyMS1CI/jiMr/gUtD2LQwMGr4R3p7bY3oQHQ5b38CT4D2AXXg6YcQXHpyYnlqKsi5iOAVSwL9zd7zJ09r+Cpwq72omFMazjT9Dnibym0dTkRDUKrrgwH7MwXVyYB38BstaGDfLUTsgAAAAASUVORK5CYII=\"));}.bk-tool-icon-redo{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-redo);-webkit-mask-image:var(--bokeh-icon-redo);}.bk-tool-icon-reset{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-reset);-webkit-mask-image:var(--bokeh-icon-reset);}.bk-tool-icon-save{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-save);-webkit-mask-image:var(--bokeh-icon-save);}.bk-tool-icon-tap-select{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-tap-select);-webkit-mask-image:var(--bokeh-icon-tap-select);}.bk-tool-icon-undo{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-undo);-webkit-mask-image:var(--bokeh-icon-undo);}.bk-tool-icon-wheel-pan{background-image:var(--bokeh-icon-wheel-pan, url(\"data:image/png;base64,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\"));}.bk-tool-icon-wheel-zoom{background-image:var(--bokeh-icon-wheel-zoom, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEMEgskILvMJQAABTtJREFUWMPdl1+MXVUVxn/fPvf2zrSFmUKnoBCUdjRoVaIxEpO2JhilMYBCtBQS2hejpg1Uo2NUrIFAoyGmtiE+GHwQGtvQJhqDmKYRBv+URFsFDNCSptH60DJTO3dKnX/33rM/H7rvsDu9M20fDMaVnGTvtb69z7fWXmvtc/TEzqd4OyXwNsv/FwFJQVI/sA14SZKRLOlPkr5TrVYXHz70quYkEEK4TtI2YAgYkrQthHDdhV5uuw+43/ZrwCbgRttgY/tjtrc0m83X3/f+D6ydnJhYcB4BSZcBA7aP2d4ELAGW2N5k+xgwkDB0IH19CGGH7R8B1aQeAf4KvAw0ku4K2zu7uru3ApdPEyiKohd4TNKjtjt5h6RHgccSNrddbvuHtm9Jqoak7xVF8WFgdavV+pSk5cCObNmXgK++85prCj3z28HKqZMnH7D9YAY4BvwujT8BvCuL1INX9vVt+dfwcCvNb7f9q2RuSfrGvWu/sL2Nf3LX7pzvj4ENSGBPVarVd4fRkZFltjdmoMGiKO4IIWwIIWwoiuIOYDDzeOPoyMiyFLkum7WJCMDztrcrTTrIRuAQZ6NcK1utL4dWq/VZoC8BhqvV6l1lWb4YYxyLMY6VZflitVq9CxhOmL60hhCKeYiV7WMKIXw9jT1HpXw3c+bOAKzOjJubzebJrKQCQLPZPClpc7bP6rMYKtjXth2OMf7tIkr11Wz8oQDc1Fb09vY+kQw1YAuwJY2nbUluAnCWpKkaFl6IQIzxivaR2SYA89sJVK/Xp2x32R6w/a30DNjuqtfrU0ArYecDCEqgLqm94T0dEm9mBG7PxkdDlkBnkhebgIezNQ8nHcCZPL9ijE1Jf/bZZoPtzbavmqNZLbf9tSxq+yoduuJ+SZ+zXSZyBXCqU+d8fvC5yRUrV+0G2j3g2hDCLyXd/+Su3QdnvP/zCuH72LWsgf2k0oHlH2c2odlkxcpVEdgr6aDtjyb8x20/J+mA7T9I6rL9SWA5dne2/GdXLl58qNJh398An85yTMA+4DOz8Dgu6Zu2dwJXJ91ltm8Gbp7Fgb+EEB4aHhpq5CEtACqVyr3AC0AlPS8k3TSmQ2YPhhBuS/1/LpmS9JTtNTHGfwBU2uUALARotVqniqJYH2Pck85pfavVaufAwnQvnHc0McaDKVptebN94QAnJB0EdtjekydyZXqjs/0ZgLIs/w6sy8bnYGYJ63pgERKC05JutT1kOwITwL9tvzlzUQUYB+Zjs2DBgu6xsbGJZHstByZbezregcBXeCsEz1bnzXt5anLyzLq71zDLxTRdVgemdx0fv2e2w5thO5DbiqL4oKT3ZKpnpyYnz+SY2ZpTAPZmJfdIrVZbNBNUq9UW2X4kU+2dcf53Aj1pj2PA7y/6m1DS00A9za9uNBq7iqJYBuoGdRdFsazRaOzKSqye1rTbaa/tlbYrqXQP2X4FIA9/J1l39xrC0v7+w5IeB8XkwS1lWe6TGJAYKMty31tfO4qSHl/a3384I3CDpI+kzC4lnRfrue6GytEjR8oQwlY73gC0L4qlth/q0M1/LYWtR48cKQF6enrC6dOnVwGLEpnxnp7en4+O1i/tszzGOCTpPmB7ahb57QUwBWyXdF+McWg6MScmuoA8OX8xOlpvXGz422XYTsB/SnpA0h7bX5R0WzI9HUL4qe2XbI+dk3xl+V7gxoztD5jRI+YK/zkEEokx2/uB/RdzIfUtueqVN04cXwF8G3iHY3z9Urw/j8ClyhsnjrcS2Vv/J/8NLxT+/zqBTkcxU/cfEkyEAu3kmjAAAAAASUVORK5CYII=\"));}.bk-tool-icon-box-edit{background-image:var(--bokeh-icon-box-edit, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEMEg4QfHjM1QAAAGRJREFUWMNjXLhsJcNAAiaGAQYsDAwM/+lsJ+OgCwGsLqMB+D8o08CoA0YdMOqAUQewDFQdMBoFIyoN/B/U7YFRB7DQIc7xyo9GwbBMA4xDqhxgISH1klXbDYk0QOseEeOgDgEAIS0JQleje6IAAAAASUVORK5CYII=\"));}.bk-tool-icon-freehand-draw{background-image:var(--bokeh-icon-freehand-draw, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAADTElEQVRYCeWWTWwMYRjH/88721X1lZJIGxJxcEE4OOiBgzjXWh8TJKR76kWacOBGxdEJIdk4VChZI/phidRBHMRRIr7DSUiaSCRFRM3u88gz+o7Z6bBTdjmYZPf9eJ55fv/5zzvvDPC/H9QsA66Olo9Ga+/MdR+Ljm2/KQIULsz9FqItGdOfJKLhApLgVkiSCGODjWit7QpKWy+TNrFeXvzKVUT8NiTVaIgDcbiCFJ7GiT8WkARXAdYBK0Lbhi/CenArRNskuM7/tgNp4ArQ42dwjf3WY5gWTqC7O/NbNn2Xkfw/YwdSw/We14HP2IEZwX+y9cZ9SH0LmgFP7UCz4KkENBNeV0Cz4b8U8DfgKiDxMWwUXETqLvJpCQpXZfawbzS7t9v5pL19cHBwfja7YA0y/lyCM0+E5hv5+piZXwKYcF23as+37bTXsQVqgkL0p/34fHR7DcBtbetFsBmGDwMOJCggYG55yw7dMlk6DuC1Bdu2RsCU9TYWQq2IoGbsreZ5NzvEqfSBsIsIy8OTbcdgiRHeh4o8AFAEwDakbY2AaCCpH7V9aGhoUUUy3UyVbkPYFuYLDlUZH8XBpwxkK0Dbgxg5HcVi0ent7a0RULMIozaHBSMfF9b2SzdutFcFB2FkwMIJOG6qfteXOa1nHZ48tyefuwyfT9s6wtzZ3t7eZse2DR2I228TtHXzuWCx9g8MtK5cuHCZTH4tiHEOa4xFngvTyS8f35d6enomiCi4/foEXBkZaQuukChL4FYA2Whd7YcC4gEdW3CpdL3LtGAVCVYJywEyTpAuJKeMOKXZs/Bw947C50KhUFOG4cwz35cjWNBlHGeD53n3xsfHP/T19U1qciggar8Fa4I3PHobIotBWBtc2hSiChyZxVzM53Pv7FVH6Tp3uVy+g0r1ImD2GjIrQGYIxjnfuXTZGICS5k/bBwJoubwEFX4TLah9EXomJGMA3za+f9913Yl4TnzsDQ+vE6YTZOjHh4ngibstt1pzQwd04F0bPStEBpXqRoBeQ/AKghfBnOEKgS+Q7z91Xfdz/HGKg8Ox7z8iYD9z6wqTkZFgnvhMGP9VZ2or1XVkPM9z0mytSfVsHa1RLBZbLoyNzUnK+ydz3wC6I9x+lwbngwAAAABJRU5ErkJggg==\"));}.bk-tool-icon-poly-draw{background-image:var(--bokeh-icon-poly-draw, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEMEjglo9eZgwAAAc5JREFUWMPt1zFrU1EUB/DfS4OmVTGDIChCP4BgnQXRxVHqIJUupp9AB8VBQcRBQUXIB9DWQoMRiXZzcnQSA34A7aAuHSJKkgo2LvfBrU3aJnlYkBy4vHcP557zP/9z3r33JdXa647N0kHSZd5Nn0rSxc8G3cXp85sMcnZZ8vge3osZ+l3vB8CWFA0iL14t79h210swAjACMAIwAjACkB90D/8/GchI9ve4nPwTBh5E9ws7OepzGWb9EddSn51Op9ZstadSg4VK1UKlKkmSDSMLALewiuNh/hVJq71Wxttmqz0dG88vPc+MgWP4grvYG3SLOBrZFFFrttqPe4HIDxh4GSei+98iSlusuYopXEAjBtEPA3tQwUpwluAbDm4TPJUz+BTW9l2Ce6G7L0X/Bw8D3T/7SKKIDzHg7QCcxjvcQAEtXAnrrg/RP0/DKPbqgcN4iVOR7gcO4dcQgRuoh7HSqwlP4n20m63jJu5n8MkWMYfP3UowhzdR8FU8w9iQwevBdyq3/27CMRzAE5yLuvsRLg+ZcR1nJ8YL81HWJUzGAPaFZwe/Q5MdyYDyNHgjzO90YyGHtVDncuiJchaHw8R4oREFV5qdiVmYLM3OgD9k5209/atmIAAAAABJRU5ErkJggg==\"));}.bk-tool-icon-point-draw{background-image:var(--bokeh-icon-point-draw, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gEMEiERGWPELgAAA4RJREFUWMO1lr1uG1cQhb9ztdRSP7AF1QxgwKlcuZSqRC9gWUUUINWqTh5AnaFOnVPEteQmRuhCURqWsSqqc9IolREXdEvQBElxtdw7KURSFEVKu4w8wAKLxdw9Z+bMnRmZGXfZ29//II8th4WwGVNyIoQLYB5vxA9Caq04iUd9A+7ZlsNC2I7TdSd2hZXMJKlnTqp9jtl/GBaqoyQ0noFKpUIzBicYYc+DEFpxkglc4oVJa5gvDn8v1xV2irG3FM4NSVwjUKlUaMcpJhCGmSEJQ6QGD8M5WnHCd8+f3QCXpPLx8WNwv0j6Bm9FMK7FJ3WBE+R/2t7c/GBmFvSBrzRTCsyTDjXrxUgEMtpxynJYmJoBJ4VAybwVARgvL7Oik0okCodnKpVKX7P0leiVMb0VvbJT+upznK4vh0GIeQwwQStJkHQD3MwsCALTJRG7Qrdrj5m/djgYaIa0hlkRdJk26XEgC9txurccBtVW3IudBImmZuACUP+ZlIDBt9FKcubYNTcAH/X0RYM1E7utJPlqe+uZzPxUcEkiSS4sTT95n15Mud0xWC0o2PAWOCdK3KYZlFxfM+tHOcnMzNr1es18ug+cgsVjP4yBU/Ppfrter1m/+l0+zYygML1xRVHU7TSb1cSzBzoBzszsH+AMdJJ49jrNZjWKou6wBnwOzcyndBpNbuueURR1Dw8Pq35p9cc5p/Dy9Dypt7jXrtdGwQECS9NPhr6Gq6txUzNigE6zydLK6lTw12/KT4FGFEUfJX2YJNONq5tVs4ODA7sD/DnwJ/BoADZuE3tHFs12dna6d4C/BI6AlbyzI8ii2TTw12/KK33gb2cdXsNZoAntbZC2SeO4c9592k/5eNQbiwvFd1kJuFGwLJr1wSPg/SwpvyFBHufOeXcFeAlE97U/uCxOY+P3b+Bn4B3Q+L8EdJfD4a+/AbC4UBzPxiPg3wlHZquB28Cn2IuR9x3gr3uV4DbwfvSDOvi4uFA8BDZmIRHkjHpS9Ht9iRqd8+5G3g05mAGcQbsdiX5QJ428G7Kygo8XYdb1/K4NWVmjzkNge2sz84bs+ELmpDDLtqWsNZBXgvmw8CTtpWVMT7x5YWBjLARnwZfKQNYN2U2LPvrh+5nBt7c2M2/It9bArCTKR8eZN+SJ13AScPnoODeRdqNenH+wul5w2gUr2WUjMFAt8bZ/0axX/wNnv4H8vTFb1QAAAABJRU5ErkJggg==\"));}.bk-tool-icon-poly-edit{background-image:var(--bokeh-icon-poly-edit, url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4gELFi46qJmxxAAABV9JREFUWMOdl19vFFUYxn9n9u9sCyylUIzWUoMQBAWCMdEEIt6xIRQSLIEKtvHe6AcA4yeQb7CAUNJy0daLeomJN8SEULAC2kBBapBKoLvbmdl/c14vdmY7u91tF95kknPOnHmf95znPc97Ro2OTeBbdjFDT3c32ZxVHUOE9kSMB0/m6ExuoJn1H+ur6Y+OTfD50SMN5168OgrAlyf7CfuD+z7+iDs3p8hkLUQ0iFQ/yFl5Nm/qonfHVva+s32Zw9GxCYILsZ08tpNfBhbs+1YN4OH9+7huGdECSBVfqUosbsllfmauBqiR+cCNwOr7AEo8pPHJnymXykhg5fUWjoQpl0vVvhZhbSzGoUOHqgBlt6B6uruj2Zy1E9jo0fhfeyL2x4Mnc8VErK0KUEOB64JSyptfG4RSytsJjUJVxw2lsFy3urL9nx1Qd25ObctkrVMi+jQivd7U2ZyV/3Hzpq7h3h1b/7p9Y0o8v8rwAbTWrGpSocN/FGDlbAI0Rl23PCBan0Ok158H9Ipwzi25A/Mzc9Gl/BYx/E4kYqC1NKRARNAaDCNUM27Z+Zr+ouXs0q4+LSLBHPYCFkTkC6uU39kwCdsS7WRKmaYUiAhdnZ3MPX2K4+QjQI+C94A93rMzm8ltMwyDeDzWjMZeEb2pYQDdW3vITU2jtUZ5QThOPgm8C7wP7J15OPsBsB3oWpGnVWisCeDS1VHj4vBI92+/3tgB7Ab2AruAXiDBK5oIOkhtkEYRNRuJhObrd8Dl9ewf4D5wG7hVLpen29vb5wzD+BrkbBMaL3d1dk5nsrnlFDTTFWAWmAZueWD3gCemGde2k2fw1Al1YXhEvjozoO49eczdqekrWmsc2zlrmvEKOGoW1GUjFLqSk2KpJrCLwyMCPAP+BO54QL8DM6YZX/ClsP9YnwKkXnIBP4jdIpJRpdJTCYdMwwi98KU0Hjc/dDILNyUcwTCWdOSMJ0TRmBktGRhLugu0xyLk7CIqVNm+0bGJptl1YXikD0grpY4Rjc4a8Fbgdab/6OGbAJeCUuyJnnHmZH9pbSyGuBXV8NUwlUpR1EWyixmSyTWEwqGlJ2Swbo2JXbAAfgDGgGQA9I1A9t1tlq0AxrXxn0ilUpw4fhQqYkH/sT41OTnJJwf2s6FjI5mshdYa7bqVR2uezr9MJmJt14FvGrh/O9D+e6UkM/xyCuCqEKCYnJyUTKFQrZDHjxzGshwWLQcRsOz8Hi85P23id0ug/XilAMLBmm4tPGdoaKjSH5+oAGrhwvBI9SjZTn4QSK9yenoD7dlrExPoJlXW8G8ytpNHxRKk02lGxsdRKFwXLNvx5yY94HQLGhGk4LFCYQSqaE0AwWM1eOoEbR0dKBSW7bC4mKuffxs4D/wCLKwQQPAUzIkslfp6cVomROWSolh0GjldAM4nzDi2k9/i5UAzC9aKfwNJ3zgJg9YEvN6+C7SHgKm69+sD7RfNnKTTaZRPQfAut4oFV//IS7gkcB34VlVo8kGzphlfB+DU+TfNGBpZtRastvrvARJmfMF28ge9sc2B9/PNnCilMIDwK6y8/ow/Ai4kvILTljAXvDvEvrqKSUs60KolzPjBxspavQD2tKqCAGF/Ba+xE/Wbilu54wZV8NEKF5fXzQHl/bh4hUsE0WAXSlDMYcQSrQXgCmsTseXHsJkNnjqBFGwKJaHsKlxtUHYVhbLCzr1kaOA4bcn1y1Swmb+iLpJKpVrfgdpfsiVVCYcgluwgnU7jEgJ4s5UkLFtWYyHyEg0/N1q1tmQH+YXnAMFr97Nmv3p+0QsHQRsF8qpBOE5+rb9Nkaj50tVQKjqh4OU3GNL/1/So3vuUgbAAAAAASUVORK5CYII=\"));}.bk-tool-icon-line-edit{background-image:var(--bokeh-icon-line-edit, url(\"data:image/png;base64,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\"));}.bk-tool-icon-settings{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-settings);-webkit-mask-image:var(--bokeh-icon-settings);}.bk-tool-icon-unknown{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-unknown);-webkit-mask-image:var(--bokeh-icon-unknown);}.bk-tool-icon-fullscreen{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-fullscreen);-webkit-mask-image:var(--bokeh-icon-fullscreen);}.bk-tool-icon-chevron-up{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-up);-webkit-mask-image:var(--bokeh-icon-chevron-up);}.bk-tool-icon-chevron-down{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-down);-webkit-mask-image:var(--bokeh-icon-chevron-down);}.bk-tool-icon-chevron-left{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-left);-webkit-mask-image:var(--bokeh-icon-chevron-left);}.bk-tool-icon-chevron-right{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-right);-webkit-mask-image:var(--bokeh-icon-chevron-right);}.bk-tool-icon-caret-up{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-caret-up);-webkit-mask-image:var(--bokeh-icon-caret-up);}.bk-tool-icon-caret-down{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-caret-down);-webkit-mask-image:var(--bokeh-icon-caret-down);}.bk-tool-icon-caret-left{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-caret-left);-webkit-mask-image:var(--bokeh-icon-caret-left);}.bk-tool-icon-caret-right{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-caret-right);-webkit-mask-image:var(--bokeh-icon-caret-right);}.bk-tool-icon-see-on{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-see-on);-webkit-mask-image:var(--bokeh-icon-see-on);}.bk-tool-icon-see-off{background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-see-off);-webkit-mask-image:var(--bokeh-icon-see-off);}:host{--bokeh-icon-question-mark:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M8%208a3.5%203%200%200%201%203.5%20-3h1a3.5%203%200%200%201%203.5%203a3%203%200%200%201%20-2%203a3%204%200%200%200%20-2%204%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2212%22%20y1%3D%2219%22%20x2%3D%2212%22%20y2%3D%2219.01%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-help:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%229%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2212%22%20y1%3D%2217%22%20x2%3D%2212%22%20y2%3D%2217.01%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2013.5a1.5%201.5%200%200%201%201%20-1.5a2.6%202.6%200%201%200%20-3%20-4%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-x:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M18%206l-12%2012%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M6%206l12%2012%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-settings:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M10.325%204.317c.426%20-1.756%202.924%20-1.756%203.35%200a1.724%201.724%200%200%200%202.573%201.066c1.543%20-.94%203.31%20.826%202.37%202.37a1.724%201.724%200%200%200%201.065%202.572c1.756%20.426%201.756%202.924%200%203.35a1.724%201.724%200%200%200%20-1.066%202.573c.94%201.543%20-.826%203.31%20-2.37%202.37a1.724%201.724%200%200%200%20-2.572%201.065c-.426%201.756%20-2.924%201.756%20-3.35%200a1.724%201.724%200%200%200%20-2.573%20-1.066c-1.543%20.94%20-3.31%20-.826%20-2.37%20-2.37a1.724%201.724%200%200%200%20-1.065%20-2.572c-1.756%20-.426%20-1.756%20-2.924%200%20-3.35a1.724%201.724%200%200%200%201.066%20-2.573c-.94%20-1.543%20.826%20-3.31%202.37%20-2.37c1%20.608%202.296%20.07%202.572%20-1.065z%22%3E%3C%2Fpath%3E%0A%20%20%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%223%22%3E%3C%2Fcircle%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-unknown:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M14%203v4a1%201%200%200%200%201%201h4%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M17%2021h-10a2%202%200%200%201%20-2%20-2v-14a2%202%200%200%201%202%20-2h7l5%205v11a2%202%200%200%201%20-2%202z%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2017v.01%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2014a1.5%201.5%200%201%200%20-1.14%20-2.474%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-fullscreen:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Crect%20x%3D%223%22%20y%3D%2216%22%20width%3D%225%22%20height%3D%225%22%20rx%3D%221%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M4%2012v-6a2%202%200%200%201%202%20-2h12a2%202%200%200%201%202%202v12a2%202%200%200%201%20-2%202h-6%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%208h4v4%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M16%208l-5%205%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-save:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M4%2017v2a2%202%200%200%200%202%202h12a2%202%200%200%200%202%20-2v-2%22%20%2F%3E%0A%20%20%3Cpolyline%20points%3D%227%2011%2012%2016%2017%2011%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2212%22%20y1%3D%224%22%20x2%3D%2212%22%20y2%3D%2216%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-copy:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Crect%20x%3D%228%22%20y%3D%228%22%20width%3D%2212%22%20height%3D%2212%22%20rx%3D%222%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M16%208v-2a2%202%200%200%200%20-2%20-2h-8a2%202%200%200%200%20-2%202v8a2%202%200%200%200%202%202h2%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-tap-select:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cline%20x1%3D%223%22%20y1%3D%2212%22%20x2%3D%226%22%20y2%3D%2212%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2212%22%20y1%3D%223%22%20x2%3D%2212%22%20y2%3D%226%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%227.8%22%20y1%3D%227.8%22%20x2%3D%225.6%22%20y2%3D%225.6%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2216.2%22%20y1%3D%227.8%22%20x2%3D%2218.4%22%20y2%3D%225.6%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%227.8%22%20y1%3D%2216.2%22%20x2%3D%225.6%22%20y2%3D%2218.4%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2012l9%203l-4%202l-2%204l-3%20-9%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-lasso-select:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M4.028%2013.252c-.657%20-.972%20-1.028%20-2.078%20-1.028%20-3.252c0%20-3.866%204.03%20-7%209%20-7s9%203.134%209%207s-4.03%207%20-9%207c-1.913%200%20-3.686%20-.464%20-5.144%20-1.255%22%20%2F%3E%0A%20%20%3Ccircle%20cx%3D%225%22%20cy%3D%2215%22%20r%3D%222%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M5%2017c0%201.42%20.316%202.805%201%204%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-pan:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M18%209l3%203l-3%203%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M6%209l-3%203l3%203%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M9%2018l3%203l3%20-3%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%206l-3%20-3l-3%203%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2012h9%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%2012h9%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2012v9%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%203v9%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-x-pan:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M18%209l3%203l-3%203%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M6%209l-3%203l3%203%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2012h9%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%2012h9%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-y-pan:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M9%2018l3%203l3%20-3%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%206l-3%20-3l-3%203%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2012v9%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%203v9%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-box-select:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M4%206v-1a1%201%200%200%201%201%20-1h1m5%200h2m5%200h1a1%201%200%200%201%201%201v1m0%205v2m0%205v1a1%201%200%200%201%20-1%201h-1m-5%200h-2m-5%200h-1a1%201%200%200%201%20-1%20-1v-1m0%20-5v-2%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-x-box-select:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M17%2013l-4%204%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M13%2013l4%204%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M4%206v-1a1%201%200%200%201%201%20-1h1m5%200h2m5%200h1a1%201%200%200%201%201%201v1m0%205v2m0%205v1a1%201%200%200%201%20-1%201h-1m-5%200h-2m-5%200h-1a1%201%200%200%201%20-1%20-1v-1m0%20-5v-2%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-y-box-select:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M13%2013l2%202l2%20-2%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%2015v2.5%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M4%206v-1a1%201%200%200%201%201%20-1h1m5%200h2m5%200h1a1%201%200%200%201%201%201v1m0%205v2m0%205v1a1%201%200%200%201%20-1%201h-1m-5%200h-2m-5%200h-1a1%201%200%200%201%20-1%20-1v-1m0%20-5v-2%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-box-zoom:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Ccircle%20cx%3D%2215%22%20cy%3D%2215%22%20r%3D%225%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M22%2022l-3%20-3%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M6%2018h-1a2%202%200%200%201%20-2%20-2v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%2011v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%206v-1a2%202%200%200%201%202%20-2h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M10%203h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%203h1a2%202%200%200%201%202%202v1%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-x-box-zoom:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M17%2013l-4%204%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M13%2013l4%204%22%20%2F%3E%0A%20%20%3Ccircle%20cx%3D%2215%22%20cy%3D%2215%22%20r%3D%225%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M22%2022l-3%20-3%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M6%2018h-1a2%202%200%200%201%20-2%20-2v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%2011v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%206v-1a2%202%200%200%201%202%20-2h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M10%203h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%203h1a2%202%200%200%201%202%202v1%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-y-box-zoom:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M13%2013l2%202l2%20-2%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%2015v2.5%22%20%2F%3E%0A%20%20%3Ccircle%20cx%3D%2215%22%20cy%3D%2215%22%20r%3D%225%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M22%2022l-3%20-3%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M6%2018h-1a2%202%200%200%201%20-2%20-2v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%2011v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%206v-1a2%202%200%200%201%202%20-2h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M10%203h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%203h1a2%202%200%200%201%202%202v1%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-auto-box-zoom:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Ccircle%20cx%3D%2215%22%20cy%3D%2215%22%20r%3D%225%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M22%2022l-3%20-3%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M6%2018h-1a2%202%200%200%201%20-2%20-2v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%2011v-1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M3%206v-1a2%202%200%200%201%202%20-2h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M10%203h1%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M15%203h1a2%202%200%200%201%202%202v1%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-zoom-in:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Ccircle%20cx%3D%2210%22%20cy%3D%2210%22%20r%3D%227%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%227%22%20y1%3D%2210%22%20x2%3D%2213%22%20y2%3D%2210%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2210%22%20y1%3D%227%22%20x2%3D%2210%22%20y2%3D%2213%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2215%22%20y2%3D%2215%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-zoom-out:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Ccircle%20cx%3D%2210%22%20cy%3D%2210%22%20r%3D%227%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%227%22%20y1%3D%2210%22%20x2%3D%2213%22%20y2%3D%2210%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2215%22%20y2%3D%2215%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-undo:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M9%2013l-4%20-4l4%20-4m-4%204h11a4%204%200%200%201%200%208h-1%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-redo:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M15%2013l4%20-4l-4%20-4m4%204h-11a4%204%200%200%200%200%208h1%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-reset:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M20%2011a8.1%208.1%200%200%200%20-15.5%20-2m-.5%20-4v4h4%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M4%2013a8.1%208.1%200%200%200%2015.5%202m.5%204v-4h-4%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-hover:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M12%2020l-3%20-3h-2a3%203%200%200%201%20-3%20-3v-6a3%203%200%200%201%203%20-3h10a3%203%200%200%201%203%203v6a3%203%200%200%201%20-3%203h-2l-3%203%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%228%22%20y1%3D%229%22%20x2%3D%2216%22%20y2%3D%229%22%20%2F%3E%0A%20%20%3Cline%20x1%3D%228%22%20y1%3D%2213%22%20x2%3D%2214%22%20y2%3D%2213%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-crosshair:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%229%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M20%2012h-4%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M4%2012h4%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%2020v-4%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M12%204v4%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-chevron-up:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpolyline%20points%3D%226%2015%2012%209%2018%2015%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-chevron-down:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpolyline%20points%3D%226%209%2012%2015%2018%209%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-chevron-left:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpolyline%20points%3D%2215%206%209%2012%2015%2018%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-chevron-right:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpolyline%20points%3D%229%206%2015%2012%209%2018%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-caret-up:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22currentColor%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M18%2015l-6%20-6l-6%206h12%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-caret-down:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22currentColor%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M18%2015l-6%20-6l-6%206h12%22%20transform%3D%22rotate(180%2012%2012)%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-caret-left:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22currentColor%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M18%2015l-6%20-6l-6%206h12%22%20transform%3D%22rotate(270%2012%2012)%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-caret-right:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22currentColor%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cpath%20d%3D%22M18%2015l-6%20-6l-6%206h12%22%20transform%3D%22rotate(90%2012%2012)%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-see-on:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%222%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M22%2012c-2.667%204.667%20-6%207%20-10%207s-7.333%20-2.333%20-10%20-7c2.667%20-4.667%206%20-7%2010%20-7s7.333%202.333%2010%207%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");--bokeh-icon-see-off:url(\"data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%222%22%20stroke%3D%22currentColor%22%20fill%3D%22none%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%0A%20%20%3Cline%20x1%3D%223%22%20y1%3D%223%22%20x2%3D%2221%22%20y2%3D%2221%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M10.584%2010.587a2%202%200%200%200%202.828%202.83%22%20%2F%3E%0A%20%20%3Cpath%20d%3D%22M9.363%205.365a9.466%209.466%200%200%201%202.637%20-.365c4%200%207.333%202.333%2010%207c-.778%201.361%20-1.612%202.524%20-2.503%203.488m-2.14%201.861c-1.631%201.1%20-3.415%201.651%20-5.357%201.651c-4%200%20-7.333%20-2.333%20-10%20-7c1.369%20-2.395%202.913%20-4.175%204.632%20-5.341%22%20%2F%3E%0A%3C%2Fsvg%3E%0A\");}'},\n", - " function _(o,t,e,r,i){r(),e.tool_icon=\"bk-tool-icon\",e.disabled=\"bk-disabled\",e.tool_chevron=\"bk-tool-chevron\",e.above=\"bk-above\",e.below=\"bk-below\",e.left=\"bk-left\",e.right=\"bk-right\",e.active=\"bk-active\",e.default=\":host{--button-width:30px;--button-height:30px;--button-color:lightgray;--button-border:2px;--active-tool-highlight:#26aae1;--active-tool-border:var(--button-border) solid transparent;}:host{position:relative;width:var(--button-width);height:var(--button-height);cursor:pointer;user-select:none;-webkit-user-select:none;}.bk-tool-icon{position:relative;top:calc(var(--button-border)/2);width:calc(var(--button-width) - var(--button-border));height:calc(var(--button-height) - var(--button-border));mask-size:60% 60%;mask-position:center center;mask-repeat:no-repeat;-webkit-mask-size:60% 60%;-webkit-mask-position:center center;-webkit-mask-repeat:no-repeat;background-size:60% 60%;background-origin:border-box;background-position:center center;background-repeat:no-repeat;}:host(.bk-disabled) .bk-tool-icon{background-color:var(--bokeh-icon-color-disabled);cursor:not-allowed;}.bk-tool-chevron{position:absolute;visibility:hidden;width:8px;height:8px;mask-size:100% 100%;mask-position:center center;mask-repeat:no-repeat;-webkit-mask-size:100% 100%;-webkit-mask-position:center center;-webkit-mask-repeat:no-repeat;}:host(:hover) .bk-tool-chevron{visibility:visible;}:host(.bk-above) .bk-tool-chevron{right:0;bottom:0;background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-down);-webkit-mask-image:var(--bokeh-icon-chevron-down);}:host(.bk-below) .bk-tool-chevron{right:0;top:0;background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-up);-webkit-mask-image:var(--bokeh-icon-chevron-up);}:host(.bk-left) .bk-tool-chevron{right:0;bottom:0;background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-right);-webkit-mask-image:var(--bokeh-icon-chevron-right);}:host(.bk-right) .bk-tool-chevron{left:0;bottom:0;background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-chevron-left);-webkit-mask-image:var(--bokeh-icon-chevron-left);}:host(:hover){background-color:rgba(192, 192, 192, 0.15);}:host(:focus),:host(:focus-visible){outline:1px dotted var(--active-tool-highlight);outline-offset:-1px;}:host::-moz-focus-inner{border:0;}:host(.bk-above){border-bottom:var(--active-tool-border);}:host(.bk-above.bk-active){border-bottom-color:var(--active-tool-highlight);}:host(.bk-below){border-top:var(--active-tool-border);}:host(.bk-below.bk-active){border-top-color:var(--active-tool-highlight);}:host(.bk-right){border-left:var(--active-tool-border);}:host(.bk-right.bk-active){border-left-color:var(--active-tool-highlight);}:host(.bk-left){border-right:var(--active-tool-border);}:host(.bk-left.bk-active){border-right-color:var(--active-tool-highlight);}\"},\n", - " function _(e,o,t,n,s){n();const r=e(264),l=e(272);class u extends r.ToolView{get plot_view(){return this.parent}}t.GestureToolView=u,u.__name__=\"GestureToolView\";class _ extends r.Tool{constructor(e){super(e)}tool_button(){return new l.OnOffButton({tool:this})}}t.GestureTool=_,_.__name__=\"GestureTool\"},\n", - " function _(t,e,o,n,s){var i;n();const c=t(1),_=t(266),l=c.__importStar(t(270));class a extends _.ToolButtonView{_toggle_active(){this.class_list.toggle(l.active,this.model.tool.active)}connect_signals(){super.connect_signals();const{active:t}=this.model.tool.properties;this.on_change(t,(()=>{this._toggle_active()}))}render(){super.render(),this._toggle_active()}_clicked(){const{active:t}=this.model.tool;this.model.tool.active=!t}}o.OnOffButtonView=a,a.__name__=\"OnOffButtonView\";class r extends _.ToolButton{constructor(t){super(t)}}o.OnOffButton=r,i=r,r.__name__=\"OnOffButton\",i.prototype.default_view=a},\n", - " function _(e,o,t,n,s){var l;n();const _=e(264),c=e(272);class i extends _.ToolView{get plot_view(){return this.parent}}t.InspectToolView=i,i.__name__=\"InspectToolView\";class r extends _.Tool{constructor(e){super(e),this.event_type=\"move\"}tool_button(){return new c.OnOffButton({tool:this})}}t.InspectTool=r,l=r,r.__name__=\"InspectTool\",l.define((({Boolean:e})=>({toggleable:[e,!0]}))),l.override({active:!0})},\n", - " function _(o,t,n,s,i){s();const e=o(264),c=o(275),l=o(15);class _ extends e.ToolView{connect_signals(){super.connect_signals(),this.connect(this.model.do,(o=>this.doit(o)))}}n.ActionToolView=_,_.__name__=\"ActionToolView\";class a extends e.Tool{constructor(o){super(o),this.do=new l.Signal(this,\"do\")}tool_button(){return new c.ClickButton({tool:this})}}n.ActionTool=a,a.__name__=\"ActionTool\"},\n", - " function _(t,o,e,n,i){var c;n();const l=t(266);class _ extends l.ToolButtonView{_clicked(){this.model.tool.do.emit(void 0)}}e.ClickButtonView=_,_.__name__=\"ClickButtonView\";class s extends l.ToolButton{constructor(t){super(t)}}e.ClickButton=s,c=s,s.__name__=\"ClickButton\",c.prototype.default_view=_},\n", - " function _(o,e,t,i,l){var n;i();const s=o(274),r=o(269);class c extends s.ActionToolView{doit(){window.open(this.model.redirect)}}t.HelpToolView=c,c.__name__=\"HelpToolView\";class _ extends s.ActionTool{constructor(o){super(o),this.tool_name=\"Help\",this.tool_icon=r.tool_icon_help}}t.HelpTool=_,n=_,_.__name__=\"HelpTool\",n.prototype.default_view=c,n.define((({String:o})=>({redirect:[o,\"https://docs.bokeh.org/en/latest/docs/user_guide/interaction/tools.html\"]}))),n.override({description:\"Click the question mark to learn more about Bokeh plot tools.\"}),n.register_alias(\"help\",(()=>new _))},\n", - " function _(o,t,e,i,l){i(),e.inner=\"bk-inner\",e.hidden=\"bk-hidden\",e.logo=\"bk-logo\",e.above=\"bk-above\",e.below=\"bk-below\",e.left=\"bk-left\",e.right=\"bk-right\",e.divider=\"bk-divider\",e.tool_overflow=\"bk-tool-overflow\",e.horizontal=\"bk-horizontal\",e.vertical=\"bk-vertical\",e.default=':host{--button-width:30px;--button-height:30px;--button-color:lightgray;}:host{display:flex;flex-wrap:nowrap;align-items:center;user-select:none;-webkit-user-select:none;}:host(.bk-inner){background-color:white;opacity:0.8;}:host(.bk-hidden){visibility:hidden;opacity:0;transition:visibility 0.3s linear, opacity 0.3s linear;}.bk-logo{flex-shrink:0;}:host(.bk-above),:host(.bk-below){flex-direction:row;justify-content:flex-end;}:host(.bk-above) .bk-logo,:host(.bk-below) .bk-logo{order:1;margin-left:5px;margin-right:0px;}:host(.bk-left),:host(.bk-right){flex-direction:column;justify-content:flex-start;}:host(.bk-left) .bk-logo,:host(.bk-right) .bk-logo{order:0;margin-bottom:5px;margin-top:0px;}.bk-divider{content:\" \";display:inline-block;background-color:var(--button-color);}:host(.bk-above) .bk-divider,:host(.bk-below) .bk-divider{height:10px;width:1px;}:host(.bk-left) .bk-divider,:host(.bk-right) .bk-divider{height:1px;width:10px;}.bk-tool-overflow{color:gray;display:flex;align-items:center;}.bk-tool-overflow:hover{background-color:rgba(192, 192, 192, 0.15);}.bk-tool-overflow:focus,.bk-tool-overflow:focus-visible{outline:1px dotted var(--active-tool-highlight);outline-offset:-1px;}.bk-tool-overflow::-moz-focus-inner{border:0;}:host(.bk-above) .bk-tool-overflow,:host(.bk-below) .bk-tool-overflow,:host(.bk-horizontal) .bk-tool-overflow{width:calc(var(--button-width)/2);height:var(--button-height);flex-direction:row;}:host(.bk-left) .bk-tool-overflow,:host(.bk-right) .bk-tool-overflow,:host(.bk-vertical) .bk-tool-overflow{width:var(--button-width);height:calc(var(--button-height)/2);flex-direction:column;}'},\n", - " function _(A,l,g,o,d){o(),g.logo=\"bk-logo\",g.grey=\"bk-grey\",g.logo_small=\"bk-logo-small\",g.default=\".bk-logo{margin:5px;position:relative;display:block;background-repeat:no-repeat;}.bk-logo.bk-grey{filter:grayscale(100%);}.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==);}\"},\n", - " function _(e,i,t,s,r){var l;s();const a=e(231),h=e(139),_=e(23),n=e(59),o=e(78);class d extends a.UpperLowerView{*children(){yield*super.children();const{lower_head:e,upper_head:i}=this;null!=e&&(yield e),null!=i&&(yield i)}async lazy_initialize(){await super.lazy_initialize();const{lower_head:e,upper_head:i}=this.model;null!=e&&(this.lower_head=await(0,n.build_view)(e,{parent:this})),null!=i&&(this.upper_head=await(0,n.build_view)(i,{parent:this}))}set_data(e){var i,t;super.set_data(e);const s=_.Indices.all_set(this._lower.length);null===(i=this.lower_head)||void 0===i||i.set_data(e,s),null===(t=this.upper_head)||void 0===t||t.set_data(e,s)}paint(e){if(this.visuals.line.doit)for(let i=0,t=this._lower_sx.length;i({lower_head:[i(e(h.ArrowHead)),()=>new h.TeeHead({size:10})],upper_head:[i(e(h.ArrowHead)),()=>new h.TeeHead({size:10})]}))),l.override({level:\"underlay\"})},\n", - " function _(L,e,T,l,H){l(),H(\"HTMLLabel\",L(281).HTMLLabel),H(\"HTMLLabelSet\",L(283).HTMLLabelSet),H(\"HTMLTitle\",L(284).HTMLTitle)},\n", - " function _(e,t,s,i,n){var o;i();const a=e(1),l=e(282),r=e(11),u=e(19),_=e(151),d=e(144),c=a.__importStar(e(78));class h extends l.TextAnnotationView{update_layout(){const{panel:e}=this;this.layout=null!=e?new d.SideLayout(e,(()=>this.get_size()),!1):void 0}_get_size(){const{text:e}=this.model,t=new _.TextBox({text:e}),{angle:s,angle_units:i}=this.model;t.angle=(0,r.compute_angle)(s,i),t.visuals=this.visuals.text.values();const{width:n,height:o}=t.size();return{width:n,height:o}}_render(){const{angle:e,angle_units:t}=this.model,s=(0,r.compute_angle)(e,t),i=null!=this.layout?this.layout:this.plot_view.frame,n=this.coordinates.x_scale,o=this.coordinates.y_scale;let a=(()=>{switch(this.model.x_units){case\"canvas\":return this.model.x;case\"screen\":return i.bbox.xview.compute(this.model.x);case\"data\":return n.compute(this.model.x)}})(),l=(()=>{switch(this.model.y_units){case\"canvas\":return this.model.y;case\"screen\":return i.bbox.yview.compute(this.model.y);case\"data\":return o.compute(this.model.y)}})();a+=this.model.x_offset,l-=this.model.y_offset,this._paint(this.layer.ctx,this.model.text,a,l,s)}}s.HTMLLabelView=h,h.__name__=\"HTMLLabelView\";class m extends l.TextAnnotation{constructor(e){super(e)}}s.HTMLLabel=m,o=m,m.__name__=\"HTMLLabel\",o.prototype.default_view=h,o.mixins([c.Text,[\"border_\",c.Line],[\"background_\",c.Fill]]),o.define((({Number:e,String:t,Angle:s})=>({x:[e],x_units:[u.CoordinateUnits,\"data\"],y:[e],y_units:[u.CoordinateUnits,\"data\"],text:[t,\"\"],angle:[s,0],angle_units:[u.AngleUnits,\"rad\"],x_offset:[e,0],y_offset:[e,0]}))),o.override({background_fill_color:null,border_line_color:null})},\n", - " function _(t,e,s,i,l){i();const n=t(73),o=t(56),a=t(144);class r extends n.AnnotationView{update_layout(){const{panel:t}=this;this.layout=null!=t?new a.SideLayout(t,(()=>this.get_size()),!0):void 0}initialize(){super.initialize(),this.el=(0,o.div)(),this.plot_view.canvas_view.add_overlay(this.el)}remove(){(0,o.remove)(this.el),super.remove()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.render()))}render(){this.model.visible||(0,o.undisplay)(this.el),super.render()}_paint(t,e,s,i,l){const{el:n}=this;(0,o.undisplay)(n),n.textContent=e,this.visuals.text.set_value(t),n.style.position=\"absolute\",n.style.left=`${s}px`,n.style.top=`${i}px`,n.style.color=t.fillStyle,n.style.webkitTextStroke=`1px ${t.strokeStyle}`,n.style.font=t.font,n.style.lineHeight=\"normal\",n.style.whiteSpace=\"pre\";const[a,r]=(()=>{switch(this.visuals.text.text_align.get_value()){case\"left\":return[\"left\",\"0%\"];case\"center\":return[\"center\",\"-50%\"];case\"right\":return[\"right\",\"-100%\"]}})(),[u,d]=(()=>{switch(this.visuals.text.text_baseline.get_value()){case\"top\":return[\"top\",\"0%\"];case\"middle\":default:return[\"center\",\"-50%\"];case\"bottom\":return[\"bottom\",\"-100%\"]}})();let c=`translate(${r}, ${d})`;0!=l&&(c+=`rotate(${l}rad)`),n.style.transformOrigin=`${a} ${u}`,n.style.transform=c,this.layout,this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(t),n.style.backgroundColor=t.fillStyle),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(t),n.style.borderStyle=t.getLineDash().length<2?\"solid\":\"dashed\",n.style.borderWidth=`${t.lineWidth}px`,n.style.borderColor=t.strokeStyle),(0,o.display)(n)}}s.TextAnnotationView=r,r.__name__=\"TextAnnotationView\";class u extends n.Annotation{constructor(t){super(t)}}s.TextAnnotation=u,u.__name__=\"TextAnnotation\"},\n", - " function _(t,e,s,i,r){var o;i();const l=t(1),a=t(98),n=l.__importStar(t(78)),c=t(19),h=t(56),_=l.__importStar(t(17)),u=t(23),d=t(12);class y extends a.DataAnnotationView{constructor(){super(...arguments),this.els=[]}set_data(t){super.set_data(t),this.els.forEach((t=>(0,h.remove)(t))),this.els=[];for(const t of this.text){const t=(0,h.div)({style:{display:\"none\"}});this.plot_view.canvas_view.add_overlay(t),this.els.push(t)}}remove(){this.els.forEach((t=>(0,h.remove)(t))),this.els=[],super.remove()}_rerender(){this.render()}map_data(){const{x_scale:t,y_scale:e}=this.coordinates,s=null!=this.layout?this.layout:this.plot_view.frame;this.sx=(()=>{switch(this.model.x_units){case\"canvas\":return new u.ScreenArray(this._x);case\"screen\":return s.bbox.xview.v_compute(this._x);case\"data\":return t.v_compute(this._x)}})(),this.sy=(()=>{switch(this.model.y_units){case\"canvas\":return new u.ScreenArray(this._y);case\"screen\":return s.bbox.yview.v_compute(this._y);case\"data\":return e.v_compute(this._y)}})()}paint(){const{ctx:t}=this.layer;for(let e=0,s=this.text.length;e{switch(this.visuals.text.text_align.get(e)){case\"left\":return[\"left\",\"0%\"];case\"center\":return[\"center\",\"-50%\"];case\"right\":return[\"right\",\"-100%\"]}})(),[c,_]=(()=>{switch(this.visuals.text.text_baseline.get(e)){case\"top\":return[\"top\",\"0%\"];case\"middle\":default:return[\"center\",\"-50%\"];case\"bottom\":return[\"bottom\",\"-100%\"]}})();let u=`translate(${n}, ${_})`;0!=o&&(u+=`rotate(${o}rad)`),l.style.transformOrigin=`${a} ${c}`,l.style.transform=u,this.layout,this.visuals.background_fill.doit&&(this.visuals.background_fill.set_vectorize(t,e),l.style.backgroundColor=t.fillStyle),this.visuals.border_line.doit&&(this.visuals.border_line.set_vectorize(t,e),l.style.borderStyle=t.getLineDash().length<2?\"solid\":\"dashed\",l.style.borderWidth=`${t.lineWidth}px`,l.style.borderColor=t.strokeStyle),(0,h.display)(l)}}s.HTMLLabelSetView=y,y.__name__=\"HTMLLabelSetView\";class p extends a.DataAnnotation{constructor(t){super(t)}}s.HTMLLabelSet=p,o=p,p.__name__=\"HTMLLabelSet\",o.prototype.default_view=y,o.mixins([n.TextVector,[\"border_\",n.LineVector],[\"background_\",n.FillVector]]),o.define((()=>({x:[_.XCoordinateSpec,{field:\"x\"}],y:[_.YCoordinateSpec,{field:\"y\"}],x_units:[c.CoordinateUnits,\"data\"],y_units:[c.CoordinateUnits,\"data\"],text:[_.NullStringSpec,{field:\"text\"}],angle:[_.AngleSpec,0],x_offset:[_.NumberSpec,{value:0}],y_offset:[_.NumberSpec,{value:0}]}))),o.override({background_fill_color:null,border_line_color:null})},\n", - " function _(e,t,i,l,s){var o;l();const a=e(1),n=e(282),r=e(19),c=e(151),h=a.__importStar(e(78));class _ extends n.TextAnnotationView{_get_location(){const e=this.model.offset,t=this.model.standoff/2;let i,l;const{bbox:s}=this.layout;switch(this.panel.side){case\"above\":case\"below\":switch(this.model.vertical_align){case\"top\":l=s.top+t;break;case\"middle\":l=s.vcenter;break;case\"bottom\":l=s.bottom-t}switch(this.model.align){case\"left\":i=s.left+e;break;case\"center\":i=s.hcenter;break;case\"right\":i=s.right-e}break;case\"left\":switch(this.model.vertical_align){case\"top\":i=s.left+t;break;case\"middle\":i=s.hcenter;break;case\"bottom\":i=s.right-t}switch(this.model.align){case\"left\":l=s.bottom-e;break;case\"center\":l=s.vcenter;break;case\"right\":l=s.top+e}break;case\"right\":switch(this.model.vertical_align){case\"top\":i=s.right-t;break;case\"middle\":i=s.hcenter;break;case\"bottom\":i=s.left+t}switch(this.model.align){case\"left\":l=s.top+e;break;case\"center\":l=s.vcenter;break;case\"right\":l=s.bottom-e}}return[i,l]}_render(){const{text:e}=this.model;if(0==e.length)return;this.model.text_baseline=this.model.vertical_align,this.model.text_align=this.model.align;const[t,i]=this._get_location(),l=this.panel.get_label_angle_heuristic(\"parallel\");this._paint(this.layer.ctx,e,t,i,l)}_get_size(){const{text:e}=this.model,t=new c.TextBox({text:e});t.visuals=this.visuals.text.values();const{width:i,height:l}=t.size();return{width:i,height:0==l?0:2+l+this.model.standoff}}}i.HTMLTitleView=_,_.__name__=\"HTMLTitleView\";class d extends n.TextAnnotation{constructor(e){super(e)}}i.HTMLTitle=d,o=d,d.__name__=\"HTMLTitle\",o.prototype.default_view=_,o.mixins([h.Text,[\"border_\",h.Line],[\"background_\",h.Fill]]),o.define((({Number:e,String:t})=>({text:[t,\"\"],vertical_align:[r.VerticalAlign,\"bottom\"],align:[r.TextAlign,\"left\"],offset:[e,0],standoff:[e,10]}))),o.prototype._props.text_align.options.internal=!0,o.prototype._props.text_baseline.options.internal=!0,o.override({text_font_size:\"13px\",text_font_style:\"bold\",text_line_height:1,background_fill_color:null,border_line_color:null})},\n", - " function _(e,t,u,n,S){n(),S(\"CustomJS\",e(286).CustomJS),S(\"OpenURL\",e(288).OpenURL),S(\"SetValue\",e(289).SetValue)},\n", - " function _(t,e,s,n,c){var a;n();const r=t(287),u=t(9),o=t(38);class i extends r.Callback{constructor(t){super(t)}get names(){return(0,u.keys)(this.args)}get values(){return(0,u.values)(this.args)}get func(){const t=(0,o.use_strict)(this.code);return new Function(...this.names,\"cb_obj\",\"cb_data\",t)}execute(t,e={}){return this.func.apply(t,this.values.concat(t,e))}}s.CustomJS=i,a=i,i.__name__=\"CustomJS\",a.define((({Unknown:t,String:e,Dict:s})=>({args:[s(t),{}],code:[e,\"\"]})))},\n", - " function _(c,a,l,n,s){n();const e=c(50);class o extends e.Model{constructor(c){super(c)}}l.Callback=o,o.__name__=\"Callback\"},\n", - " function _(e,t,n,o,i){var s;o();const c=e(287),r=e(170),a=e(8);class d extends c.Callback{constructor(e){super(e)}navigate(e){this.same_tab?window.location.href=e:window.open(e)}execute(e,{source:t}){const n=e=>{const n=(0,r.replace_placeholders)(this.url,t,e,void 0,void 0,encodeURI);if(!(0,a.isString)(n))throw new Error(\"HTML output is not supported in this context\");this.navigate(n)},{selected:o}=t;for(const e of o.indices)n(e);for(const e of o.line_indices)n(e)}}n.OpenURL=d,s=d,d.__name__=\"OpenURL\",s.define((({Boolean:e,String:t})=>({url:[t,\"http://\"],same_tab:[e,!1]})))},\n", - " function _(e,t,r,n,o){var a;n();const s=e(287),c=e(14),l=e(18);class u extends s.Callback{constructor(e){super(e)}execute(){const{obj:e,attr:t,value:r}=this;t in e.properties?e.setv({[t]:r}):l.logger.error(`${e.type}.${t} is not a property`)}}r.SetValue=u,a=u,u.__name__=\"SetValue\",a.define((({String:e,Unknown:t,Ref:r})=>({obj:[r(c.HasProps)],attr:[e],value:[t]})))},\n", - " function _(a,n,e,r,s){r(),s(\"Canvas\",a(291).Canvas),s(\"CartesianFrame\",a(157).CartesianFrame)},\n", - " function _(e,t,s,i,r){var a;i();const l=e(1),n=e(28),o=e(18),h=e(56),_=e(19),p=e(292),c=e(155),u=e(260),d=e(257),b=e(56),v=l.__importDefault(e(295));const w=(()=>{let t;return async()=>void 0!==t?t:t=await async function(){const t=document.createElement(\"canvas\"),s=t.getContext(\"webgl\",{premultipliedAlpha:!0});if(null!=s){const i=await(0,c.load_module)(Promise.resolve().then((()=>l.__importStar(e(504)))));if(null!=i){const e=i.get_regl(s);if(e.has_webgl)return{canvas:t,regl_wrapper:e};o.logger.trace(\"WebGL is supported, but not the required extensions\")}else o.logger.trace(\"WebGL is supported, but bokehjs(.min).js bundle is not available\")}else o.logger.trace(\"WebGL is not supported\");return null}()})();class g extends d.UIElementView{constructor(){super(...arguments),this.webgl=null,this._size=new b.InlineStyleSheet,this.plot_views=[]}initialize(){super.initialize(),this.underlays_el=(0,h.div)({class:\"bk-layer\"}),this.primary=this.create_layer(),this.overlays=this.create_layer(),this.overlays_el=(0,h.div)({class:\"bk-layer\"}),this.events_el=(0,h.div)({class:[\"bk-layer\",\"bk-events\"]}),this.ui_event_bus=new p.UIEventBus(this)}get layers(){return[this.underlays_el,this.primary,this.overlays,this.overlays_el,this.events_el]}async lazy_initialize(){if(await super.lazy_initialize(),\"webgl\"==this.model.output_backend&&(this.webgl=await w(),n.settings.force_webgl&&null==this.webgl))throw new Error(\"webgl is not available\")}remove(){this.ui_event_bus.destroy(),super.remove()}stylesheets(){return[...super.stylesheets(),v.default,this._size]}render(){super.render();const e=[this.underlays_el,this.primary.el,this.overlays.el,this.overlays_el,this.events_el];(0,h.append)(this.shadow_el,...e)}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}_update_bbox(){const e=super._update_bbox();if(e){const{width:e,height:t}=this.bbox;this._size.replace(`\\n .bk-layer {\\n width: ${e}px;\\n height: ${t}px;\\n }\\n `),this.primary.resize(e,t),this.overlays.resize(e,t)}return e}after_resize(){0==this.plot_views.length&&super.after_resize()}_after_resize(){super._after_resize();const{width:e,height:t}=this.bbox;this.primary.resize(e,t),this.overlays.resize(e,t)}resize(){this._update_bbox(),this._after_resize()}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[r,a,l,n]=e,{xview:o,yview:h}=this.bbox,_=o.compute(r),p=h.compute(a+n),c=this.pixel_ratio;t.regl_wrapper.set_scissor(c*_,c*p,c*l,c*n),this._clear_webgl()}}blit_webgl(e){const{webgl:t}=this;if(null!=t){if(o.logger.debug(\"Blitting WebGL canvas\"),e.restore(),e.drawImage(t.canvas,0,0),e.save(),this.model.hidpi){const t=this.pixel_ratio;e.scale(t,t),e.translate(.5,.5)}this._clear_webgl()}}_clear_webgl(){const{webgl:e}=this;if(null!=e){const{regl_wrapper:t,canvas:s}=e;t.clear(s.width,s.height)}}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 u.CanvasLayer(e,t)}to_blob(){return this.compose().to_blob()}}s.CanvasView=g,g.__name__=\"CanvasView\";class y extends d.UIElement{constructor(e){super(e)}}s.Canvas=y,a=y,y.__name__=\"Canvas\",a.prototype.default_view=g,a.define((({Boolean:e})=>({hidpi:[e,!0],output_backend:[_.OutputBackend,\"canvas\"]})))},\n", - " function _(t,e,n,s,i){s();const r=t(1),_=r.__importDefault(t(293)),a=t(15),h=t(18),o=t(56),l=r.__importStar(t(52)),c=t(294),p=t(10),u=t(8),v=t(26);function d(t){return(0,u.isObject)(t)&&\"_move_start\"in t&&\"_move\"in t&&\"_move_end\"in t}function y(t){return(0,u.isObject)(t)&&\"_pan_start\"in t&&\"_pan\"in t&&\"_pan_end\"in t}function m(t){return(0,u.isObject)(t)&&\"_pinch_start\"in t&&\"_pinch\"in t&&\"_pinch_end\"in t}function g(t){return(0,u.isObject)(t)&&\"_rotate_start\"in t&&\"_rotate\"in t&&\"_rotate_end\"in t}n.is_Moveable=d,n.is_Pannable=y,n.is_Pinchable=m,n.is_Rotatable=g,n.is_Scrollable=function(t){return(0,u.isObject)(t)&&\"_scroll\"in t},n.is_Keyable=function(t){return(0,u.isObject)(t)&&\"_keydown\"in t&&\"_keyup\"in t},n.is_Tapable=function(t){return(0,u.isObject)(t)&&\"_tap\"in t};class w{get hit_area(){return this.canvas_view.events_el}constructor(t){this.pan_start=new a.Signal(this,\"pan:start\"),this.pan=new a.Signal(this,\"pan\"),this.pan_end=new a.Signal(this,\"pan:end\"),this.pinch_start=new a.Signal(this,\"pinch:start\"),this.pinch=new a.Signal(this,\"pinch\"),this.pinch_end=new a.Signal(this,\"pinch:end\"),this.rotate_start=new a.Signal(this,\"rotate:start\"),this.rotate=new a.Signal(this,\"rotate\"),this.rotate_end=new a.Signal(this,\"rotate:end\"),this.tap=new a.Signal(this,\"tap\"),this.doubletap=new a.Signal(this,\"doubletap\"),this.press=new a.Signal(this,\"press\"),this.pressup=new a.Signal(this,\"pressup\"),this.move_enter=new a.Signal(this,\"move:enter\"),this.move=new a.Signal(this,\"move\"),this.move_exit=new a.Signal(this,\"move:exit\"),this.scroll=new a.Signal(this,\"scroll\"),this.keydown=new a.Signal(this,\"keydown\"),this.keyup=new a.Signal(this,\"keyup\"),this._prev_move=null,this._curr_pan=null,this._curr_pinch=null,this._curr_rotate=null,this._current_pan_view=null,this._current_pinch_view=null,this._current_rotate_view=null,this._current_move_view=null,this.canvas_view=t,this.hammer=new _.default(this.hit_area,{cssProps:{},touchAction:\"auto\",inputClass:v.is_mobile?_.default.TouchMouseInput:_.default.PointerEventInput}),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)}destroy(){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:_.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){let e=!0;for(const n of t.model.event_types)this._register_tool(t,n,e),e=!1}_register_tool(t,e,n=!0){const s=t,{id:i}=s.model,r=t=>e=>{e.id==i&&t(e.e)},_=t=>e=>{t(e.e)};switch(e){case\"pan\":null!=s._pan_start&&s.connect(this.pan_start,r(s._pan_start.bind(s))),null!=s._pan&&s.connect(this.pan,r(s._pan.bind(s))),null!=s._pan_end&&s.connect(this.pan_end,r(s._pan_end.bind(s)));break;case\"pinch\":null!=s._pinch_start&&s.connect(this.pinch_start,r(s._pinch_start.bind(s))),null!=s._pinch&&s.connect(this.pinch,r(s._pinch.bind(s))),null!=s._pinch_end&&s.connect(this.pinch_end,r(s._pinch_end.bind(s)));break;case\"rotate\":null!=s._rotate_start&&s.connect(this.rotate_start,r(s._rotate_start.bind(s))),null!=s._rotate&&s.connect(this.rotate,r(s._rotate.bind(s))),null!=s._rotate_end&&s.connect(this.rotate_end,r(s._rotate_end.bind(s)));break;case\"move\":null!=s._move_enter&&s.connect(this.move_enter,r(s._move_enter.bind(s))),null!=s._move&&s.connect(this.move,r(s._move.bind(s))),null!=s._move_exit&&s.connect(this.move_exit,r(s._move_exit.bind(s)));break;case\"tap\":null!=s._tap&&s.connect(this.tap,r(s._tap.bind(s)));case\"doubletap\":null!=s._doubletap&&s.connect(this.doubletap,r(s._doubletap.bind(s)));break;case\"press\":null!=s._press&&s.connect(this.press,r(s._press.bind(s)));break;case\"pressup\":null!=s._pressup&&s.connect(this.pressup,r(s._pressup.bind(s)));break;case\"scroll\":null!=s._scroll&&s.connect(this.scroll,r(s._scroll.bind(s)))}n&&(null!=s._keydown&&s.connect(this.keydown,_(s._keydown.bind(s))),null!=s._keyup&&s.connect(this.keyup,_(s._keyup.bind(s))),v.is_mobile&&null!=s._scroll&&\"pinch\"==e&&(h.logger.debug(\"Registering scroll on touch screen\"),s.connect(this.scroll,r(s._scroll.bind(s)))))}_hit_test_renderers(t,e,n){var s,i;const r=t.get_renderer_views();for(const t of(0,p.reversed)(r))if(null!==(i=null===(s=t.interactive_hit)||void 0===s?void 0:s.call(t,e,n))&&void 0!==i&&i)return t;return null}set_cursor(t=\"default\"){this.hit_area.style.cursor=t}_hit_test_frame(t,e,n){return t.frame.bbox.contains(e,n)}_hit_test_plot(t,e){for(const n of this.canvas_view.plot_views)if(n.bbox.relative().contains(t,e))return n;return null}_trigger(t,e,n){var s;if(!this.hit_area.isConnected)return;const{sx:i,sy:r}=e,_=this._hit_test_plot(i,r),a=t=>{const[n,s]=[i,r];return Object.assign(Object.assign({},e),{sx:n,sy:s})};if(\"panstart\"==e.type||\"pan\"==e.type||\"panend\"==e.type){let s;if(\"panstart\"==e.type&&null!=_?(this._curr_pan={plot_view:_},s=_):\"pan\"==e.type&&null!=this._curr_pan?s=this._curr_pan.plot_view:\"panend\"==e.type&&null!=this._curr_pan?(s=this._curr_pan.plot_view,this._curr_pan=null):s=null,null!=s){const e=a();this.__trigger(s,t,e,n)}}else if(\"pinchstart\"==e.type||\"pinch\"==e.type||\"pinchend\"==e.type){let s;if(\"pinchstart\"==e.type&&null!=_?(this._curr_pinch={plot_view:_},s=_):\"pinch\"==e.type&&null!=this._curr_pinch?s=this._curr_pinch.plot_view:\"pinchend\"==e.type&&null!=this._curr_pinch?(s=this._curr_pinch.plot_view,this._curr_pinch=null):s=null,null!=s){const e=a();this.__trigger(s,t,e,n)}}else if(\"rotatestart\"==e.type||\"rotate\"==e.type||\"rotateend\"==e.type){let s;if(\"rotatestart\"==e.type&&null!=_?(this._curr_rotate={plot_view:_},s=_):\"rotate\"==e.type&&null!=this._curr_rotate?s=this._curr_rotate.plot_view:\"rotateend\"==e.type&&null!=this._curr_rotate?(s=this._curr_rotate.plot_view,this._curr_rotate=null):s=null,null!=s){const e=a();this.__trigger(s,t,e,n)}}else if(\"mouseenter\"==e.type||\"mousemove\"==e.type||\"mouseleave\"==e.type){const h=null===(s=this._prev_move)||void 0===s?void 0:s.plot_view;if(null!=h&&(\"mouseleave\"==e.type||h!=_)){const{sx:t,sy:e}=a();this.__trigger(h,this.move_exit,{type:\"mouseleave\",sx:t,sy:e,shift_key:!1,ctrl_key:!1,alt_key:!1},n)}if(null!=_&&(\"mouseenter\"==e.type||h!=_)){const{sx:t,sy:e}=a();this.__trigger(_,this.move_enter,{type:\"mouseenter\",sx:t,sy:e,shift_key:!1,ctrl_key:!1,alt_key:!1},n)}if(null!=_&&\"mousemove\"==e.type){const e=a();this.__trigger(_,t,e,n)}this._prev_move={sx:i,sy:r,plot_view:_}}else if(null!=_){const e=a();this.__trigger(_,t,e,n)}}__trigger(t,e,n,s){var i,r,_,a,h,o;const l=t.model.toolbar.gestures,c=e.name,u=c.split(\":\")[0],w=this._hit_test_renderers(t,n.sx,n.sy);if(\"pan\"==u){if(null!=this._current_pan_view)return\"pan\"==c?this._current_pan_view._pan(n):\"pan:end\"==c&&(this._current_pan_view._pan_end(n),this._current_pan_view=null),void s.preventDefault();if(null!=w&&\"pan:start\"==c&&y(w)&&w._pan_start(n))return this._current_pan_view=w,void s.preventDefault()}else if(\"pinch\"==u){if(null!=this._current_pinch_view)return\"pinch\"==c?this._current_pinch_view._pinch(n):\"pinch:end\"==c&&(this._current_pinch_view._pinch_end(n),this._current_pinch_view=null),void s.preventDefault();if(null!=w&&\"pinch:start\"==c&&m(w)&&w._pinch_start(n))return this._current_pinch_view=w,void s.preventDefault()}else if(\"rotate\"==u){if(null!=this._current_rotate_view)return\"rotate\"==c?this._current_rotate_view._rotate(n):\"rotate:end\"==c&&(this._current_rotate_view._rotate_end(n),this._current_rotate_view=null),void s.preventDefault();if(null!=w&&\"rotate:start\"==c&&g(w)&&w._rotate_start(n))return this._current_rotate_view=w,void s.preventDefault()}else\"move\"==u&&(this._current_move_view==w?null===(i=this._current_move_view)||void 0===i||i._move(n):(null===(r=this._current_move_view)||void 0===r||r._move_end(n),this._current_move_view=null,null!=w&&d(w)&&w._move_start(n)&&(this._current_move_view=w)));switch(u){case\"move\":{const s=l.move.active;null!=s&&this.trigger(e,n,s.id);const i=t.model.toolbar.inspectors.filter((t=>t.active));let r=\"default\";null!=w?(r=null!==(_=w.cursor(n.sx,n.sy))&&void 0!==_?_:r,w.model.propagate_hover||(0,p.is_empty)(i)||(e=this.move_exit)):this._hit_test_frame(t,n.sx,n.sy)&&((0,p.is_empty)(i)||(r=\"crosshair\")),this.set_cursor(r),i.map((t=>this.trigger(e,n,t.id)));break}case\"tap\":{const i=null!==(a=s.path)&&void 0!==a?a:s.composedPath();if(0!=i.length&&i[0]!=this.hit_area)return;if(null===(h=null==w?void 0:w.on_hit)||void 0===h||h.call(w,n.sx,n.sy),this._hit_test_frame(t,n.sx,n.sy)){const t=l.tap.active;null!=t&&this.trigger(e,n,t.id)}break}case\"doubletap\":if(this._hit_test_frame(t,n.sx,n.sy)){const t=null!==(o=l.doubletap.active)&&void 0!==o?o:l.tap.active;null!=t&&this.trigger(e,n,t.id)}break;case\"scroll\":{const t=l[v.is_mobile?\"pinch\":\"scroll\"].active;null!=t&&(s.preventDefault(),s.stopPropagation(),this.trigger(e,n,t.id));break}case\"pan\":{const t=l.pan.active;null!=t&&(s.preventDefault(),this.trigger(e,n,t.id));break}default:{const t=l[u].active;null!=t&&this.trigger(e,n,t.id)}}this._trigger_bokeh_event(t,n)}trigger(t,e,n=null){t.emit({id:n,e})}_trigger_bokeh_event(t,e){const n=(()=>{const{sx:n,sy:s}=e,i=t.frame.x_scale.invert(n),r=t.frame.y_scale.invert(s);switch(e.type){case\"wheel\":return new l.MouseWheel(n,s,i,r,e.delta);case\"mousemove\":return new l.MouseMove(n,s,i,r);case\"mouseenter\":return new l.MouseEnter(n,s,i,r);case\"mouseleave\":return new l.MouseLeave(n,s,i,r);case\"tap\":return new l.Tap(n,s,i,r);case\"doubletap\":return new l.DoubleTap(n,s,i,r);case\"press\":return new l.Press(n,s,i,r);case\"pressup\":return new l.PressUp(n,s,i,r);case\"pan\":return new l.Pan(n,s,i,r,e.dx,e.dy);case\"panstart\":return new l.PanStart(n,s,i,r);case\"panend\":return new l.PanEnd(n,s,i,r);case\"pinch\":return new l.Pinch(n,s,i,r,e.scale);case\"pinchstart\":return new l.PinchStart(n,s,i,r);case\"pinchend\":return new l.PinchEnd(n,s,i,r);case\"rotate\":return new l.Rotate(n,s,i,r,e.rotation);case\"rotatestart\":return new l.RotateStart(n,s,i,r);case\"rotateend\":return new l.RotateEnd(n,s,i,r);default:return}})();null!=n&&t.model.trigger_event(n)}_get_sxy(t){const{pageX:e,pageY:n}=function(t){return\"undefined\"!=typeof TouchEvent&&t instanceof TouchEvent}(t)?(0!=t.touches.length?t.touches:t.changedTouches)[0]:t,{left:s,top:i}=(0,o.offset_bbox)(this.hit_area);return{sx:e-s,sy:n-i}}_pan_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{dx:t.deltaX,dy:t.deltaY,shift_key:t.srcEvent.shiftKey,ctrl_key:t.srcEvent.ctrlKey,alt_key:t.srcEvent.altKey})}_pinch_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{scale:t.scale,shift_key:t.srcEvent.shiftKey,ctrl_key:t.srcEvent.ctrlKey,alt_key:t.srcEvent.altKey})}_rotate_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{rotation:t.rotation,shift_key:t.srcEvent.shiftKey,ctrl_key:t.srcEvent.ctrlKey,alt_key:t.srcEvent.altKey})}_tap_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{shift_key:t.srcEvent.shiftKey,ctrl_key:t.srcEvent.ctrlKey,alt_key:t.srcEvent.altKey})}_move_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t)),{shift_key:t.shiftKey,ctrl_key:t.ctrlKey,alt_key:t.altKey})}_scroll_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t)),{delta:(0,c.getDeltaY)(t),shift_key:t.shiftKey,ctrl_key:t.ctrlKey,alt_key:t.altKey})}_key_event(t){return{type:t.type,key:t.key,shift_key:t.shiftKey,ctrl_key:t.ctrlKey,alt_key:t.altKey}}_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){}_key_down(t){this.trigger(this.keydown,this._key_event(t))}_key_up(t){this.trigger(this.keyup,this._key_event(t))}}n.UIEventBus=w,w.__name__=\"UIEventBus\"},\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=\"function\",u=Math.round,c=Math.abs,l=Date.now;function p(t,e,i){return setTimeout(y(t,i),e)}function f(t,e,i){return!!Array.isArray(t)&&(v(t,i[e],i),!0)}function v(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 b(t){return t.trim().split(/\\s+/g)}function P(t,e,i){if(t.indexOf&&!i)return t.indexOf(e);for(var n=0;ni[e]})):n.sort()),n}function w(t,e){for(var i,n,s=e[0].toUpperCase()+e.slice(1),a=0;a1&&!i.firstMultiple?i.firstMultiple=et(e):1===s&&(i.firstMultiple=!1);var o=i.firstInput,a=i.firstMultiple,h=a?a.center:o.center,u=e.center=it(n);e.timeStamp=l(),e.deltaTime=e.timeStamp-o.timeStamp,e.angle=ot(h,u),e.distance=st(h,u),function(t,e){var i=e.center,n=t.offsetDelta||{},r=t.prevDelta||{},s=t.prevInput||{};e.eventType!==W&&s.eventType!==k||(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=rt(e.deltaX,e.deltaY);var p=nt(e.deltaTime,e.deltaX,e.deltaY);e.overallVelocityX=p.x,e.overallVelocityY=p.y,e.overallVelocity=c(p.x)>c(p.y)?p.x:p.y,e.scale=a?(f=a.pointers,v=n,st(v[0],v[1],K)/st(f[0],f[1],K)):1,e.rotation=a?function(t,e){return ot(e[1],e[0],K)+ot(t[1],t[0],K)}(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(e.eventType!=H&&(h>F||a.velocity===r)){var u=e.deltaX-a.deltaX,l=e.deltaY-a.deltaY,p=nt(h,u,l);n=p.x,s=p.y,i=c(p.x)>c(p.y)?p.x:p.y,o=rt(u,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;C(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 et(t){for(var e=[],i=0;i=c(e)?t<0?U:V:e<0?j:G}function st(t,e,i){i||(i=J);var n=e[i[0]]-t[i[0]],r=e[i[1]]-t[i[1]];return Math.sqrt(n*n+r*r)}function ot(t,e,i){i||(i=J);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&&A(this.element,this.evEl,this.domHandler),this.evTarget&&A(this.target,this.evTarget,this.domHandler),this.evWin&&A(R(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&_(this.element,this.evEl,this.domHandler),this.evTarget&&_(this.target,this.evTarget,this.domHandler),this.evWin&&_(R(this.element),this.evWin,this.domHandler)}};var at={mousedown:W,mousemove:q,mouseup:k},ht=\"mousedown\",ut=\"mousemove mouseup\";function ct(){this.evEl=ht,this.evWin=ut,this.pressed=!1,Q.apply(this,arguments)}T(ct,Q,{handler:function(t){var e=at[t.type];e&W&&0===t.button&&(this.pressed=!0),e&q&&1!==t.which&&(e=k),this.pressed&&(e&k&&(this.pressed=!1),this.callback(this.manager,e,{pointers:[t],changedPointers:[t],pointerType:Y,srcEvent:t}))}});var lt={pointerdown:W,pointermove:q,pointerup:k,pointercancel:H,pointerout:H},pt={2:X,3:\"pen\",4:Y,5:\"kinect\"},ft=\"pointerdown\",vt=\"pointermove pointerup pointercancel\";function dt(){this.evEl=ft,this.evWin=vt,Q.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}t.MSPointerEvent&&!t.PointerEvent&&(ft=\"MSPointerDown\",vt=\"MSPointerMove MSPointerUp MSPointerCancel\"),T(dt,Q,{handler:function(t){var e=this.store,i=!1,n=t.type.toLowerCase().replace(\"ms\",\"\"),r=lt[n],s=pt[t.pointerType]||t.pointerType,o=s==X,a=P(e,t.pointerId,\"pointerId\");r&W&&(0===t.button||o)?a<0&&(e.push(t),a=e.length-1):r&(k|H)&&(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 mt={touchstart:W,touchmove:q,touchend:k,touchcancel:H},gt=\"touchstart\",Tt=\"touchstart touchmove touchend touchcancel\";function yt(){this.evTarget=gt,this.evWin=Tt,this.started=!1,Q.apply(this,arguments)}function Et(t,e){var i=D(t.touches),n=D(t.changedTouches);return e&(k|H)&&(i=x(i.concat(n),\"identifier\",!0)),[i,n]}T(yt,Q,{handler:function(t){var e=mt[t.type];if(e===W&&(this.started=!0),this.started){var i=Et.call(this,t,e);e&(k|H)&&i[0].length-i[1].length==0&&(this.started=!1),this.callback(this.manager,e,{pointers:i[0],changedPointers:i[1],pointerType:X,srcEvent:t})}}});var It={touchstart:W,touchmove:q,touchend:k,touchcancel:H},At=\"touchstart touchmove touchend touchcancel\";function _t(){this.evTarget=At,this.targetIds={},Q.apply(this,arguments)}function Ct(t,e){var i=D(t.touches),n=this.targetIds;if(e&(W|q)&&1===i.length)return n[i[0].identifier]=!0,[i,i];var r,s,o=D(t.changedTouches),a=[],h=this.target;if(s=i.filter((function(t){return C(t.target,h)})),e===W)for(r=0;r-1&&n.splice(t,1)}),St)}}function wt(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=Ut&&n(e.options.event+Bt(i))},tryEmit:function(t){if(this.canEmit())return this.emit(t);this.state=Gt},canEmit:function(){for(var t=0;te.threshold&&r&e.direction},attrTest:function(t){return Kt.prototype.attrTest.call(this,t)&&(this.state&Ht||!(this.state&Ht)&&this.directionTest(t))},emit:function(t){this.pX=t.deltaX,this.pY=t.deltaY;var e=$t(t.direction);e&&(t.additionalEvent=this.options.event+e),this._super.emit.call(this,t)}}),T(te,Kt,{defaults:{event:\"pinch\",threshold:0,pointers:2},getTouchAction:function(){return[Xt]},attrTest:function(t){return this._super.attrTest.call(this,t)&&(Math.abs(t.scale-1)>this.options.threshold||this.state&Ht)},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)}}),T(ee,Zt,{defaults:{event:\"press\",pointers:1,time:251,threshold:9},getTouchAction:function(){return[zt]},process:function(t){var e=this.options,i=t.pointers.length===e.pointers,n=t.distancee.time;if(this._input=t,!n||!i||t.eventType&(k|H)&&!r)this.reset();else if(t.eventType&W)this.reset(),this._timer=p((function(){this.state=Vt,this.tryEmit()}),e.time,this);else if(t.eventType&k)return Vt;return Gt},reset:function(){clearTimeout(this._timer)},emit:function(t){this.state===Vt&&(t&&t.eventType&k?this.manager.emit(this.options.event+\"up\",t):(this._input.timeStamp=l(),this.manager.emit(this.options.event,this._input)))}}),T(ie,Kt,{defaults:{event:\"rotate\",threshold:0,pointers:2},getTouchAction:function(){return[Xt]},attrTest:function(t){return this._super.attrTest.call(this,t)&&(Math.abs(t.rotation)>this.options.threshold||this.state&Ht)}}),T(ne,Kt,{defaults:{event:\"swipe\",threshold:10,velocity:.3,direction:Z|B,pointers:1},getTouchAction:function(){return Qt.prototype.getTouchAction.call(this)},attrTest:function(t){var e,i=this.options.direction;return i&(Z|B)?e=t.overallVelocity:i&Z?e=t.overallVelocityX:i&B&&(e=t.overallVelocityY),this._super.attrTest.call(this,t)&&i&t.offsetDirection&&t.distance>this.options.threshold&&t.maxPointers==this.options.pointers&&c(e)>this.options.velocity&&t.eventType&k},emit:function(t){var e=$t(t.offsetDirection);e&&this.manager.emit(this.options.event+e,t),this.manager.emit(this.options.event,t)}}),T(re,Zt,{defaults:{event:\"tap\",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[Nt]},process:function(t){var e=this.options,i=t.pointers.length===e.pointers,n=t.distance{this._result.clear(),this.change.emit()}))}get names(){return(0,l.keys)(this.args)}get values(){return(0,l.values)(this.args)}get func(){const e=(0,h.use_strict)(this.code);return new i.GeneratorFunction(...this.names,e)}_v_compute(e){var s,n;const t=this.func.apply(e,this.values);let r=t.next();if(null!==(s=r.done)&&void 0!==s&&s&&void 0!==r.value){const{value:s}=r;return(0,g.isArray)(s)||(0,g.isTypedArray)(s)?s:(0,g.isIterable)(s)?[...s]:(0,u.repeat)(s,e.length)}{const e=[];do{e.push(r.value),r=t.next()}while(null===(n=r.done)||void 0===n||!n);return e}}}n.CustomJSExpr=v,o=v,v.__name__=\"CustomJSExpr\",o.define((({Unknown:e,String:s,Dict:n})=>({args:[n(e),{}],code:[s,\"\"]})))},\n", - " function _(t,n,e,o,r){var s;o();const c=t(298),a=t(9);class i extends c.Expression{constructor(t){super(t)}_v_compute(t){var n;const e=null!==(n=t.get_length())&&void 0!==n?n:0,o=new Float64Array(e);for(const n of this.fields){const r=(0,a.dict)(t.data).get(n);if(null!=r){const t=Math.min(e,r.length);for(let n=0;n({fields:[n(t),[]]})))},\n", - " function _(e,n,t,o,r){var i;o();const l=e(298);class u extends l.Expression{constructor(e){super(e)}_v_compute(e){var n;const t=new Float64Array(null!==(n=e.get_length())&&void 0!==n?n:0),o=e.data[this.field],r=this.include_zero?1:0;t[0]=this.include_zero?0:o[0];for(let e=1;e({field:[n],include_zero:[e,!1]})))},\n", - " function _(i,n,t,e,a){var r;e();const s=i(298),c=i(9),m=i(10);class u extends s.ScalarExpression{constructor(i){super(i)}_compute(i){var n;const t=null!==(n=(0,c.dict)(i.data).get(this.field))&&void 0!==n?n:[];return Math.min(this.initial,(0,m.min)(t))}}t.Minimum=u,r=u,u.__name__=\"Minimum\",r.define((({Number:i,String:n})=>({field:[n],initial:[i,1/0]})))},\n", - " function _(i,t,a,n,e){var r;n();const s=i(298),c=i(9),m=i(10);class u extends s.ScalarExpression{constructor(i){super(i)}_compute(i){var t;const a=null!==(t=(0,c.dict)(i.data).get(this.field))&&void 0!==t?t:[];return Math.max(this.initial,(0,m.max)(a))}}a.Maximum=u,r=u,u.__name__=\"Maximum\",r.define((({Number:i,String:t})=>({field:[t],initial:[i,-1/0]})))},\n", - " function _(n,e,t,o,r){var s;o();const _=n(298);class m extends _.Expression{constructor(n){super(n)}get x(){return new c({transform:this})}get y(){return new u({transform:this})}}t.CoordinateTransform=m,m.__name__=\"CoordinateTransform\";class a extends _.Expression{constructor(n){super(n)}}t.XYComponent=a,s=a,a.__name__=\"XYComponent\",s.define((({Ref:n})=>({transform:[n(m)]})));class c extends a{constructor(n){super(n)}_v_compute(n){return this.transform.v_compute(n).x}}t.XComponent=c,c.__name__=\"XComponent\";class u extends a{constructor(n){super(n)}_v_compute(n){return this.transform.v_compute(n).y}}t.YComponent=u,u.__name__=\"YComponent\"},\n", - " function _(r,t,e,n,o){var i;n();const a=r(1),s=r(304),c=r(19),l=a.__importStar(r(17));class d extends s.CoordinateTransform{constructor(r){super(r)}_v_compute(r){const t=this.properties.radius.uniform(r),e=this.properties.angle.uniform(r),n=\"anticlock\"==this.direction?-1:1,o=Math.min(t.length,e.length),i=new Float64Array(o),a=new Float64Array(o);for(let r=0;r({radius:[l.DistanceSpec,{field:\"radius\"}],angle:[l.AngleSpec,{field:\"angle\"}],direction:[c.Direction,\"anticlock\"]})))},\n", - " function _(e,i,r,t,l){t(),l(\"BooleanFilter\",e(307).BooleanFilter),l(\"CustomJSFilter\",e(308).CustomJSFilter),l(\"Filter\",e(216).Filter),l(\"GroupFilter\",e(309).GroupFilter),l(\"IndexFilter\",e(310).IndexFilter),l(\"AllIndices\",e(217).AllIndices),l(\"InversionFilter\",e(311).InversionFilter),l(\"IntersectionFilter\",e(218).IntersectionFilter),l(\"UnionFilter\",e(312).UnionFilter),l(\"DifferenceFilter\",e(313).DifferenceFilter),l(\"SymmetricDifferenceFilter\",e(314).SymmetricDifferenceFilter)},\n", - " function _(e,l,n,o,s){var t;o();const a=e(216),r=e(23);class i extends a.Filter{constructor(e){super(e)}compute_indices(e){var l;const n=null!==(l=e.get_length())&&void 0!==l?l:1,{booleans:o}=this;return null==o?r.Indices.all_set(n):r.Indices.from_booleans(n,o)}}n.BooleanFilter=i,t=i,i.__name__=\"BooleanFilter\",t.define((({Boolean:e,Array:l,Nullable:n})=>({booleans:[n(l(e)),null]})))},\n", - " function _(e,n,r,s,t){var i;s();const o=e(216),u=e(23),c=e(9),a=e(8),l=e(38);class f extends o.Filter{constructor(e){super(e)}get names(){return(0,c.keys)(this.args)}get values(){return(0,c.values)(this.args)}get func(){const e=(0,l.use_strict)(this.code);return new Function(...this.names,\"source\",e)}compute_indices(e){var n;const r=null!==(n=e.get_length())&&void 0!==n?n:1,s=this.func(...this.values,e);if(null==s)return u.Indices.all_set(r);if((0,a.isArrayOf)(s,a.isInteger))return u.Indices.from_indices(r,s);if((0,a.isArrayOf)(s,a.isBoolean))return u.Indices.from_booleans(r,s);throw new Error(`expect an array of integers or booleans, or null, got ${s}`)}}r.CustomJSFilter=f,i=f,f.__name__=\"CustomJSFilter\",i.define((({Unknown:e,String:n,Dict:r})=>({args:[r(e),{}],code:[n,\"\"]})))},\n", - " function _(n,e,t,o,r){var u;o();const s=n(216),i=n(23),l=n(18);class c extends s.Filter{constructor(n){super(n)}compute_indices(n){var e;const t=n.get_column(this.column_name),o=null!==(e=n.get_length())&&void 0!==e?e:1;if(null==t)return l.logger.warn(`${this}: groupby column '${this.column_name}' not found in the data source`),i.Indices.all_set(o);{const n=new i.Indices(o,0);for(let e=0;e({column_name:[n],group:[n]})))},\n", - " function _(e,n,i,l,t){var s;l();const c=e(216),r=e(23);class d extends c.Filter{constructor(e){super(e)}compute_indices(e){var n;const i=null!==(n=e.get_length())&&void 0!==n?n:1,{indices:l}=this;return null==l?r.Indices.all_set(i):r.Indices.from_indices(i,l)}}i.IndexFilter=d,s=d,d.__name__=\"IndexFilter\",s.define((({Int:e,Array:n,Nullable:i})=>({indices:[i(n(e)),null]})))},\n", - " function _(e,n,r,t,i){var s;t();const o=e(216);class c extends o.Filter{constructor(e){super(e)}compute_indices(e){const n=this.operand.compute_indices(e);return n.invert(),n}}r.InversionFilter=c,s=c,c.__name__=\"InversionFilter\",s.define((({Ref:e})=>({operand:[e(o.Filter)]})))},\n", - " function _(n,e,t,r,o){var s;r();const i=n(216),c=n(23);class l extends i.Filter{constructor(n){super(n)}compute_indices(n){var e;const{operands:t}=this;if(0==t.length){const t=null!==(e=n.get_length())&&void 0!==e?e:1;return c.Indices.all_set(t)}{const[e,...r]=t.map((e=>e.compute_indices(n)));for(const n of r)e.add(n);return e}}}t.UnionFilter=l,s=l,l.__name__=\"UnionFilter\",s.define((({Array:n,Ref:e})=>({operands:[n(e(i.Filter))]})))},\n", - " function _(e,t,n,r,s){var c;r();const i=e(216),o=e(23);class l extends i.Filter{constructor(e){super(e)}compute_indices(e){var t;const{operands:n}=this;if(0==n.length){const n=null!==(t=e.get_length())&&void 0!==t?t:1;return o.Indices.all_set(n)}{const[t,...r]=n.map((t=>t.compute_indices(e)));for(const e of r)t.subtract(e);return t}}}n.DifferenceFilter=l,c=l,l.__name__=\"DifferenceFilter\",c.define((({Array:e,Ref:t})=>({operands:[e(t(i.Filter))]})))},\n", - " function _(e,t,r,n,c){var i;n();const s=e(216),o=e(23);class l extends s.Filter{constructor(e){super(e)}compute_indices(e){var t;const{operands:r}=this;if(0==r.length){const r=null!==(t=e.get_length())&&void 0!==t?t:1;return o.Indices.all_set(r)}{const[t,...n]=r.map((t=>t.compute_indices(e)));for(const e of n)t.symmetric_subtract(e);return t}}}r.SymmetricDifferenceFilter=l,i=l,l.__name__=\"SymmetricDifferenceFilter\",i.define((({Array:e,Ref:t})=>({operands:[e(t(s.Filter))]})))},\n", - " function _(e,a,t,l,i){l(),i(\"AnnularWedge\",e(316).AnnularWedge),i(\"Annulus\",e(317).Annulus),i(\"Arc\",e(318).Arc),i(\"Bezier\",e(319).Bezier),i(\"Block\",e(321).Block),i(\"Circle\",e(323).Circle),i(\"Ellipse\",e(324).Ellipse),i(\"Glyph\",e(203).Glyph),i(\"HArea\",e(212).HArea),i(\"HBar\",e(326).HBar),i(\"HexTile\",e(327).HexTile),i(\"Image\",e(328).Image),i(\"ImageRGBA\",e(330).ImageRGBA),i(\"ImageStack\",e(331).ImageStack),i(\"ImageURL\",e(332).ImageURL),i(\"Line\",e(201).Line),i(\"MultiLine\",e(333).MultiLine),i(\"MultiPolygons\",e(334).MultiPolygons),i(\"Patch\",e(211).Patch),i(\"Patches\",e(335).Patches),i(\"Quad\",e(336).Quad),i(\"Quadratic\",e(337).Quadratic),i(\"Ray\",e(338).Ray),i(\"Rect\",e(339).Rect),i(\"Scatter\",e(340).Scatter),i(\"Segment\",e(343).Segment),i(\"Spline\",e(344).Spline),i(\"Step\",e(346).Step),i(\"Text\",e(347).Text),i(\"VArea\",e(214).VArea),i(\"VBar\",e(348).VBar),i(\"Wedge\",e(349).Wedge)},\n", - " function _(e,s,t,i,r){var n;i();const a=e(1),_=e(202),o=e(209),d=e(78),h=e(23),l=e(19),u=a.__importStar(e(17)),c=e(11),g=e(101),p=e(13);class x extends _.XYGlyphView{_map_data(){\"data\"==this.model.properties.inner_radius.units?this.sinner_radius=this.sdist(this.renderer.xscale,this._x,this.inner_radius):this.sinner_radius=(0,h.to_screen)(this.inner_radius),\"data\"==this.model.properties.outer_radius.units?this.souter_radius=this.sdist(this.renderer.xscale,this._x,this.outer_radius):this.souter_radius=(0,h.to_screen)(this.outer_radius),this.max_souter_radius=(0,p.max)(this.souter_radius)}_render(e,s,t){const{sx:i,sy:r,start_angle:n,end_angle:a,sinner_radius:_,souter_radius:o}=null!=t?t:this,d=\"anticlock\"==this.model.direction;for(const t of s){const s=i[t],h=r[t],l=_[t],u=o[t],c=n.get(t),g=a.get(t);if(!isFinite(s+h+l+u+c+g))continue;const p=g-c;e.translate(s,h),e.rotate(c),e.beginPath(),e.moveTo(u,0),e.arc(0,0,u,0,p,d),e.rotate(p),e.lineTo(l,0),e.arc(0,0,l,0,-p,!d),e.closePath(),e.rotate(-p-c),e.translate(-s,-h),this.visuals.fill.apply(e,t),this.visuals.hatch.apply(e,t),this.visuals.line.apply(e,t)}}_hit_point(e){const{sx:s,sy:t}=e,i=this.renderer.xscale.invert(s),r=this.renderer.yscale.invert(t),n=s-this.max_souter_radius,a=s+this.max_souter_radius,[_,o]=this.renderer.xscale.r_invert(n,a),d=t-this.max_souter_radius,h=t+this.max_souter_radius,[l,u]=this.renderer.yscale.r_invert(d,h),p=[];for(const e of this.index.indices({x0:_,x1:o,y0:l,y1:u})){const s=this.souter_radius[e]**2,t=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]),d=(n-a)**2+(_-o)**2;d<=s&&d>=t&&p.push(e)}const x=\"anticlock\"==this.model.direction,m=[];for(const e of p){const i=Math.atan2(t-this.sy[e],s-this.sx[e]);(Math.abs(this.start_angle.get(e)-this.end_angle.get(e))>=2*Math.PI||(0,c.angle_between)(-i,-this.start_angle.get(e),-this.end_angle.get(e),x))&&m.push(e)}return new g.Selection({indices:m})}draw_legend_for_index(e,s,t){(0,o.generic_area_vector_legend)(this.visuals,e,s,t)}scenterxy(e){const s=(this.sinner_radius[e]+this.souter_radius[e])/2,t=(this.start_angle.get(e)+this.end_angle.get(e))/2;return[this.sx[e]+s*Math.cos(t),this.sy[e]+s*Math.sin(t)]}}t.AnnularWedgeView=x,x.__name__=\"AnnularWedgeView\";class m extends _.XYGlyph{constructor(e){super(e)}}t.AnnularWedge=m,n=m,m.__name__=\"AnnularWedge\",n.prototype.default_view=x,n.mixins([d.LineVector,d.FillVector,d.HatchVector]),n.define((({})=>({direction:[l.Direction,\"anticlock\"],inner_radius:[u.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[u.DistanceSpec,{field:\"outer_radius\"}],start_angle:[u.AngleSpec,{field:\"start_angle\"}],end_angle:[u.AngleSpec,{field:\"end_angle\"}]})))},\n", - " function _(s,e,r,i,t){var n;i();const a=s(1),u=s(202),_=s(23),o=s(78),d=a.__importStar(s(17)),h=s(101);class c extends u.XYGlyphView{_map_data(){\"data\"==this.model.properties.inner_radius.units?this.sinner_radius=this.sdist(this.renderer.xscale,this._x,this.inner_radius):this.sinner_radius=(0,_.to_screen)(this.inner_radius),\"data\"==this.model.properties.outer_radius.units?this.souter_radius=this.sdist(this.renderer.xscale,this._x,this.outer_radius):this.souter_radius=(0,_.to_screen)(this.outer_radius)}_render(s,e,r){const{sx:i,sy:t,sinner_radius:n,souter_radius:a}=null!=r?r:this;for(const r of e){const e=i[r],u=t[r],_=n[r],o=a[r];isFinite(e+u+_+o)&&(s.beginPath(),s.arc(e,u,_,0,2*Math.PI,!0),s.moveTo(e+o,u),s.arc(e,u,o,2*Math.PI,0,!1),this.visuals.fill.apply(s,r),this.visuals.hatch.apply(s,r),this.visuals.line.apply(s,r))}}_hit_point(s){const{sx:e,sy:r}=s,i=this.renderer.xscale.invert(e),t=this.renderer.yscale.invert(r);let n,a,u,_;if(\"data\"==this.model.properties.outer_radius.units)n=i-this.max_outer_radius,u=i+this.max_outer_radius,a=t-this.max_outer_radius,_=t+this.max_outer_radius;else{const s=e-this.max_outer_radius,i=e+this.max_outer_radius;[n,u]=this.renderer.xscale.r_invert(s,i);const t=r-this.max_outer_radius,o=r+this.max_outer_radius;[a,_]=this.renderer.yscale.r_invert(t,o)}const o=[];for(const s of this.index.indices({x0:n,x1:u,y0:a,y1:_})){const e=this.souter_radius[s]**2,r=this.sinner_radius[s]**2,[n,a]=this.renderer.xscale.r_compute(i,this._x[s]),[u,_]=this.renderer.yscale.r_compute(t,this._y[s]),d=(n-a)**2+(u-_)**2;d<=e&&d>=r&&o.push(s)}return new h.Selection({indices:o})}draw_legend_for_index(s,{x0:e,y0:r,x1:i,y1:t},n){const a=n+1,u=new Array(a);u[n]=(e+i)/2;const _=new Array(a);_[n]=(r+t)/2;const o=.5*Math.min(Math.abs(i-e),Math.abs(t-r)),d=new Array(a);d[n]=.4*o;const h=new Array(a);h[n]=.8*o,this._render(s,[n],{sx:u,sy:_,sinner_radius:d,souter_radius:h})}}r.AnnulusView=c,c.__name__=\"AnnulusView\";class l extends u.XYGlyph{constructor(s){super(s)}}r.Annulus=l,n=l,l.__name__=\"Annulus\",n.prototype.default_view=c,n.mixins([o.LineVector,o.FillVector,o.HatchVector]),n.define((({})=>({inner_radius:[d.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[d.DistanceSpec,{field:\"outer_radius\"}]})))},\n", - " function _(e,s,t,i,n){var r;i();const a=e(1),o=e(202),d=e(209),c=e(78),l=e(23),_=e(19),h=a.__importStar(e(17));class u extends o.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius):this.sradius=(0,l.to_screen)(this.radius)}_render(e,s,t){if(!this.visuals.line.doit)return;const{sx:i,sy:n,sradius:r,start_angle:a,end_angle:o}=null!=t?t:this,d=\"anticlock\"==this.model.direction;for(const t of s){const s=i[t],c=n[t],l=r[t],_=a.get(t),h=o.get(t);isFinite(s+c+l+_+h)&&(this._render_decorations(e,t,s,c,l,_,h,d),e.beginPath(),e.arc(s,c,l,_,h,d),this.visuals.line.apply(e,t))}}_render_decorations(e,s,t,i,n,r,a,o){const{sin:d,cos:c,PI:l}=Math;for(const o of this.decorations.values()){if(e.save(),\"start\"==o.model.node){const s=n*c(r)+t,a=n*d(r)+i;e.translate(s,a),e.rotate(r+l)}else if(\"end\"==o.model.node){const s=n*Math.cos(a)+t,r=n*Math.sin(a)+i;e.translate(s,r),e.rotate(a)}o.marking.render(e,s),e.restore()}}draw_legend_for_index(e,s,t){(0,d.generic_line_vector_legend)(this.visuals,e,s,t)}}t.ArcView=u,u.__name__=\"ArcView\";class g extends o.XYGlyph{constructor(e){super(e)}}t.Arc=g,r=g,g.__name__=\"Arc\",r.prototype.default_view=u,r.mixins(c.LineVector),r.define((({})=>({direction:[_.Direction,\"anticlock\"],radius:[h.DistanceSpec,{field:\"radius\"}],start_angle:[h.AngleSpec,{field:\"start_angle\"}],end_angle:[h.AngleSpec,{field:\"end_angle\"}]})))},\n", - " function _(e,i,t,c,s){var n;c();const o=e(1),r=e(78),_=e(203),d=e(209),a=e(105),l=e(320),x=o.__importStar(e(17));class y extends _.GlyphView{_project_data(){a.inplace.project_xy(this._x0,this._y0),a.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{data_size:i,_x0:t,_y0:c,_x1:s,_y1:n,_cx0:o,_cy0:r,_cx1:_,_cy1:d}=this;for(let a=0;a({x0:[x.XCoordinateSpec,{field:\"x0\"}],y0:[x.YCoordinateSpec,{field:\"y0\"}],x1:[x.XCoordinateSpec,{field:\"x1\"}],y1:[x.YCoordinateSpec,{field:\"y1\"}],cx0:[x.XCoordinateSpec,{field:\"cx0\"}],cy0:[x.YCoordinateSpec,{field:\"cy0\"}],cx1:[x.XCoordinateSpec,{field:\"cx1\"}],cy1:[x.YCoordinateSpec,{field:\"cy1\"}]}))),n.mixins(r.LineVector)},\n", - " function _(n,t,o,c,s){c();const r=n(13),{abs:i,sqrt:u,min:e,max:f}=Math;o.qbb=function(n,t,o,c,s,r){function i(n,t,o){if(t==(n+o)/2)return[n,o];{const c=(n-t)/(n-2*t+o),s=n*(1-c)**2+2*t*(1-c)*c+o*c**2;return[e(n,o,s),f(n,o,s)]}}const[u,a]=i(n,o,s),[x,m]=i(t,c,r);return{x0:u,x1:a,y0:x,y1:m}},o.cbb=function(n,t,o,c,s,e,f,a){const x=f,m=a;f=o,a=c;const y=s,b=e,h=[];for(let o=0;o<=2;o++){let c,s,r;if(0==o?(s=6*n-12*f+6*y,c=-3*n+9*f-9*y+3*x,r=3*f-3*n):(s=6*t-12*a+6*b,c=-3*t+9*a-9*b+3*m,r=3*a-3*t),i(c)<1e-12){if(i(s)<1e-12)continue;const n=-r/s;00;){const o=h[p],c=1-o,s=c**3*n+3*c**2*o*f+3*c*o**2*y+o**3*x,r=c**3*t+3*c**2*o*a+3*c*o**2*b+o**3*m;q[p]=s,A[p]=r}q[l]=n,A[l]=t,q[l+1]=x,A[l+1]=m;const[g,M]=(0,r.minmax)(q),[_,d]=(0,r.minmax)(A);return{x0:g,x1:M,y0:_,y1:d}}},\n", - " function _(t,e,i,s,r){var h;s();const a=t(1),n=t(322),l=t(23),o=a.__importStar(t(17));class _ extends n.LRTBView{async lazy_initialize(){await super.lazy_initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e&&e.regl_wrapper.has_webgl){const{LRTBGL:i}=await Promise.resolve().then((()=>a.__importStar(t(522))));this.glglyph=new i(e.regl_wrapper,this)}}scenterxy(t){return[this.sleft[t]/2+this.sright[t]/2,this.stop[t]/2+this.sbottom[t]/2]}_lrtb(t){const e=this._x[t],i=this._y[t],s=this.width.get(t),r=this.height.get(t);return[Math.min(e,e+s),Math.max(e,e+s),Math.max(i,i+r),Math.min(i,i+r)]}_map_data(){const t=this.renderer.xscale.v_compute(this._x),e=this.renderer.yscale.v_compute(this._y),i=this.sdist(this.renderer.xscale,this._x,this.width,\"edge\"),s=this.sdist(this.renderer.yscale,this._y,this.height,\"edge\"),r=t.length;this.stop=new l.ScreenArray(r),this.sbottom=new l.ScreenArray(r),this.sleft=new l.ScreenArray(r),this.sright=new l.ScreenArray(r);for(let h=0;h({x:[o.XCoordinateSpec,{field:\"x\"}],y:[o.YCoordinateSpec,{field:\"y\"}],width:[o.NumberSpec,{value:1}],height:[o.NumberSpec,{value:1}]})))},\n", - " function _(t,e,r,s,i){var n;s();const a=t(1),o=t(78),h=t(203),c=t(209),_=t(101),d=t(57),l=t(233),x=a.__importStar(t(235)),m=t(234);class p extends h.GlyphView{get_anchor_point(t,e,r){const s=Math.min(this.sleft[e],this.sright[e]),i=Math.max(this.sright[e],this.sleft[e]),n=Math.min(this.stop[e],this.sbottom[e]),a=Math.max(this.sbottom[e],this.stop[e]);switch(t){case\"top_left\":return{x:s,y:n};case\"top\":case\"top_center\":return{x:(s+i)/2,y:n};case\"top_right\":return{x:i,y:n};case\"bottom_left\":return{x:s,y:a};case\"bottom\":case\"bottom_center\":return{x:(s+i)/2,y:a};case\"bottom_right\":return{x:i,y:a};case\"left\":case\"center_left\":return{x:s,y:(n+a)/2};case\"center\":case\"center_center\":return{x:(s+i)/2,y:(n+a)/2};case\"right\":case\"center_right\":return{x:i,y:(n+a)/2}}}_set_data(t){super._set_data(t),this.border_radius=x.border_radius(this.model.border_radius)}_index_data(t){const{min:e,max:r}=Math,{data_size:s}=this;for(let i=0;i({border_radius:[l.BorderRadius,0]})))},\n", - " function _(s,i,e,t,r){var a;t();const n=s(1),d=s(202),h=s(78),c=s(23),_=s(19),l=n.__importStar(s(210)),u=n.__importStar(s(17)),o=s(13),x=s(101);class y extends d.XYGlyphView{async lazy_initialize(){await super.lazy_initialize();const{webgl:i}=this.renderer.plot_view.canvas_view;if(null!=i&&i.regl_wrapper.has_webgl){const{CircleGL:e}=await Promise.resolve().then((()=>n.__importStar(s(518))));this.glglyph=new e(i.regl_wrapper,this)}}get use_radius(){return!(this.radius.is_Scalar()&&isNaN(this.radius.value))}_set_data(s){super._set_data(s);const i=(()=>{if(this.use_radius)return 2*this.max_radius;{const{size:s}=this;return s.is_Scalar()?s.value:(0,o.max)(s.array)}})();this._configure(\"max_size\",{value:i})}_index_data(s){if(this.use_radius){const{_x:i,_y:e,radius:t,data_size:r}=this;for(let a=0;aMath.max(s,i[e])));break}case\"min\":{const s=this.sdist(this.renderer.xscale,this._x,this.radius),i=this.sdist(this.renderer.yscale,this._y,this.radius);this.sradius=(0,o.map)(s,((s,e)=>Math.min(s,i[e])));break}}else this.sradius=(0,c.to_screen)(this.radius);else{const s=c.ScreenArray.from(this.size);this.sradius=(0,o.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],d=a[e];isFinite(i+n+d)&&(s.beginPath(),s.arc(i,n,d,0,2*Math.PI,!1),this.visuals.fill.apply(s,e),this.visuals.hatch.apply(s,e),this.visuals.line.apply(s,e))}}_hit_point(s){const{sx:i,sy:e}=s,t=this.renderer.xscale.invert(i),r=this.renderer.yscale.invert(e),{hit_dilation:a}=this.model,[n,d,h,c]=(()=>{if(this.use_radius&&\"data\"==this.model.properties.radius.units){const s=this.max_radius*a;return[t-s,t+s,r-s,r+s]}{const s=this.max_size*a,t=i-s,r=i+s,n=e-s,d=e+s,[h,c]=this.renderer.xscale.r_invert(t,r),[_,l]=this.renderer.yscale.r_invert(n,d);return[h,c,_,l]}})(),_=this.index.indices({x0:n,x1:d,y0:h,y1:c}),l=[];if(this.use_radius&&\"data\"==this.model.properties.radius.units)for(const s of _){const i=(this.sradius[s]*a)**2,[e,n]=this.renderer.xscale.r_compute(t,this._x[s]),[d,h]=this.renderer.yscale.r_compute(r,this._y[s]);(e-n)**2+(d-h)**2<=i&&l.push(s)}else for(const s of _){const t=(this.sradius[s]*a)**2;(this.sx[s]-i)**2+(this.sy[s]-e)**2<=t&&l.push(s)}return new x.Selection({indices:l})}_hit_span(s){const{sx:i,sy:e}=s,t=this.bounds(),[r,a,n,d]=(()=>{const r=this.use_radius&&\"data\"==this.model.properties.radius.units?this.max_radius:this.max_size/2;if(\"h\"==s.direction){const s=i-r,e=i+r,[a,n]=this.renderer.xscale.r_invert(s,e),{y0:d,y1:h}=t;return[a,n,d,h]}{const s=e-r,i=e+r,{x0:a,x1:n}=t,[d,h]=this.renderer.yscale.r_invert(s,i);return[a,n,d,h]}})(),h=[...this.index.indices({x0:r,x1:a,y0:n,y1:d})];return new x.Selection({indices:h})}_hit_rect(s){const{sx0:i,sx1:e,sy0:t,sy1:r}=s,[a,n]=this.renderer.xscale.r_invert(i,e),[d,h]=this.renderer.yscale.r_invert(t,r),c=this.index.indices({x0:a,x1:n,y0:d,y1:h}),_=[];for(const s of c){const a=this.sx[s],n=this.sy[s];i<=a&&a<=e&&t<=n&&n<=r&&_.push(s)}return new x.Selection({indices:_})}_hit_poly(s){const{sx:i,sy:e}=s,[t,r]=(0,o.minmax)(i),[a,n]=(0,o.minmax)(e),[d,h]=this.renderer.xscale.r_invert(t,r),[c,_]=this.renderer.yscale.r_invert(a,n),u=this.index.indices({x0:d,x1:h,y0:c,y1:_}),y=[];for(const s of u)l.point_in_poly(this.sx[s],this.sy[s],i,e)&&y.push(s);return new x.Selection({indices:y})}draw_legend_for_index(s,{x0:i,y0:e,x1:t,y1:r},a){const n=a+1,d=new Array(n);d[a]=(i+t)/2;const h=new Array(n);h[a]=(e+r)/2;const c=new Array(n);c[a]=.2*Math.min(Math.abs(t-i),Math.abs(r-e)),this._render(s,[a],{sx:d,sy:h,sradius:c})}}e.CircleView=y,y.__name__=\"CircleView\";class p extends d.XYGlyph{constructor(s){super(s)}}e.Circle=p,a=p,p.__name__=\"Circle\",a.prototype.default_view=y,a.mixins([h.LineVector,h.FillVector,h.HatchVector]),a.define((({Number:s})=>({angle:[u.AngleSpec,0],size:[u.ScreenSizeSpec,{value:4}],radius:[u.NullDistanceSpec,null],radius_dimension:[_.RadiusDimension,\"x\"],hit_dilation:[s,1]})))},\n", - " function _(t,s,e,i,h){var r;i();const n=t(1),a=t(325),l=n.__importStar(t(210)),o=t(23),_=t(101),d=n.__importStar(t(17));class c 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=(0,o.to_screen)(this.width),\"data\"==this.model.properties.height.units?this.sh=this.sdist(this.renderer.yscale,this._y,this.height,\"center\"):this.sh=(0,o.to_screen)(this.height)}_render(t,s,e){const{sx:i,sy:h,sw:r,sh:n,angle:a}=null!=e?e:this;for(const e of s){const s=i[e],l=h[e],o=r[e],_=n[e],d=a.get(e);isFinite(s+l+o+_+d)&&(t.beginPath(),t.ellipse(s,l,o/2,_/2,d,0,2*Math.PI),this.visuals.fill.apply(t,e),this.visuals.hatch.apply(t,e),this.visuals.line.apply(t,e))}}_hit_point(t){let s,e,i,h,r,n,a,o,d;const{sx:c,sy:p}=t,w=this.renderer.xscale.invert(c),x=this.renderer.yscale.invert(p);\"data\"==this.model.properties.width.units?(s=w-this.max_width,e=w+this.max_width):(n=c-this.max_width,a=c+this.max_width,[s,e]=this.renderer.xscale.r_invert(n,a)),\"data\"==this.model.properties.height.units?(i=x-this.max_height,h=x+this.max_height):(o=p-this.max_height,d=p+this.max_height,[i,h]=this.renderer.yscale.r_invert(o,d));const y=this.index.indices({x0:s,x1:e,y0:i,y1:h}),m=[];for(const t of y)r=l.point_in_ellipse(c,p,this.angle.get(t),this.sh[t]/2,this.sw[t]/2,this.sx[t],this.sy[t]),r&&m.push(t);return new _.Selection({indices:m})}draw_legend_for_index(t,{x0:s,y0:e,x1:i,y1:h},r){const n=r+1,a=new Array(n);a[r]=(s+i)/2;const l=new Array(n);l[r]=(e+h)/2;const o=this.sw[r]/this.sh[r],_=.8*Math.min(Math.abs(i-s),Math.abs(h-e)),c=new Array(n),p=new Array(n);o>1?(c[r]=_,p[r]=_/o):(c[r]=_*o,p[r]=_);const w=new d.UniformScalar(0,n);this._render(t,[r],{sx:a,sy:l,sw:c,sh:p,angle:w})}}e.EllipseView=c,c.__name__=\"EllipseView\";class p extends a.CenterRotatable{constructor(t){super(t)}}e.Ellipse=p,r=p,p.__name__=\"Ellipse\",r.prototype.default_view=c},\n", - " function _(e,t,i,a,n){var r;a();const s=e(1),h=e(202),o=e(78),_=s.__importStar(e(17));class c extends h.XYGlyphView{get max_w2(){return\"data\"==this.model.properties.width.units?this.max_width/2:0}get max_h2(){return\"data\"==this.model.properties.height.units?this.max_height/2:0}_bounds({x0:e,x1:t,y0:i,y1:a}){const{max_w2:n,max_h2:r}=this;return{x0:e-n,x1:t+n,y0:i-r,y1:a+r}}}i.CenterRotatableView=c,c.__name__=\"CenterRotatableView\";class l extends h.XYGlyph{constructor(e){super(e)}}i.CenterRotatable=l,r=l,l.__name__=\"CenterRotatable\",r.mixins([o.LineVector,o.FillVector,o.HatchVector]),r.define((({})=>({angle:[_.AngleSpec,0],width:[_.DistanceSpec,{field:\"width\"}],height:[_.DistanceSpec,{field:\"height\"}]})))},\n", - " function _(t,e,s,i,r){var h;i();const a=t(1),n=t(322),_=t(23),l=a.__importStar(t(17));class o extends n.LRTBView{async lazy_initialize(){await super.lazy_initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e&&e.regl_wrapper.has_webgl){const{LRTBGL:s}=await Promise.resolve().then((()=>a.__importStar(t(522))));this.glglyph=new s(e.regl_wrapper,this)}}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],r=this.height.get(t)/2;return[Math.min(e,s),Math.max(e,s),i+r,i-r]}_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 _.ScreenArray(t),this.sbottom=new _.ScreenArray(t);for(let e=0;e({left:[l.XCoordinateSpec,{value:0}],y:[l.YCoordinateSpec,{field:\"y\"}],height:[l.NumberSpec,{value:1}],right:[l.XCoordinateSpec,{field:\"right\"}]})))},\n", - " function _(e,t,s,i,r){var n;i();const a=e(1),l=e(203),o=a.__importStar(e(210)),c=a.__importStar(e(17)),h=e(78),_=e(19),d=e(105),p=e(209),x=e(101);class y extends l.GlyphView{async lazy_initialize(){await super.lazy_initialize();const{webgl:t}=this.renderer.plot_view.canvas_view;if(null!=t&&t.regl_wrapper.has_webgl){const{HexTileGL:s}=await Promise.resolve().then((()=>a.__importStar(e(520))));this.glglyph=new s(t.regl_wrapper,this)}}scenterxy(e){return[this.sx[e],this.sy[e]]}_set_data(){const{orientation:e,size:t,aspect_scale:s}=this.model,{q:i,r}=this,n=this.q.length;this._x=new Float64Array(n),this._y=new Float64Array(n);const{_x:a,_y:l}=this,o=Math.sqrt(3);if(\"pointytop\"==e)for(let e=0;e({r:[c.NumberSpec,{field:\"r\"}],q:[c.NumberSpec,{field:\"q\"}],scale:[c.NumberSpec,1],size:[e,1],aspect_scale:[e,1],orientation:[_.HexTileOrientation,\"pointytop\"]}))),n.override({line_color:null})},\n", - " function _(e,a,t,_,r){var n;_();const s=e(329),o=e(197),i=e(242);class p extends s.ImageBaseView{connect_signals(){super.connect_signals(),this.connect(this.model.color_mapper.change,(()=>this._update_image()))}_update_image(){null!=this.image_data&&(this._set_data(null),this.renderer.request_render())}_flat_img_to_buf8(e){return this.model.color_mapper.rgba_mapper.v_compute(e)}}t.ImageView=p,p.__name__=\"ImageView\";class m extends s.ImageBase{constructor(e){super(e)}}t.Image=m,n=m,m.__name__=\"Image\",n.prototype.default_view=p,n.define((({Ref:e})=>({color_mapper:[e(o.ColorMapper),()=>new i.LinearColorMapper({palette:[\"#000000\",\"#252525\",\"#525252\",\"#737373\",\"#969696\",\"#bdbdbd\",\"#d9d9d9\",\"#f0f0f0\",\"#ffffff\"]})]})))},\n", - " function _(e,t,i,s,a){var h;s();const r=e(1),n=e(202),_=e(23),o=e(19),d=r.__importStar(e(17)),g=r.__importStar(e(78)),c=e(101),l=e(12),m=e(233),x=e(235);class u extends n.XYGlyphView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.global_alpha.change,(()=>this.renderer.request_render()))}get image_dimension(){return 2}get xy_scale(){switch(this.model.origin){case\"bottom_left\":return{x:1,y:-1};case\"top_left\":return{x:1,y:1};case\"bottom_right\":return{x:-1,y:-1};case\"top_right\":return{x:-1,y:1}}}get xy_offset(){switch(this.model.origin){case\"bottom_left\":return{x:0,y:1};case\"top_left\":return{x:0,y:0};case\"bottom_right\":return{x:1,y:1};case\"top_right\":return{x:1,y:0}}}get xy_anchor(){return(0,x.anchor)(this.model.anchor)}get xy_sign(){const e=this.renderer.xscale.source_range,t=this.renderer.yscale.source_range;return{x:e.is_reversed?-1:1,y:t.is_reversed?-1:1}}_render(e,t,i){const{image_data:s,sx:a,sy:h,sw:r,sh:n}=null!=i?i:this,{xy_sign:_,xy_scale:o,xy_offset:d,xy_anchor:g}=this;if(e.save(),e.imageSmoothingEnabled=!1,this.visuals.image.doit)for(const i of t){const t=s[i],c=a[i],l=h[i],m=r[i],x=n[i];if(null==t||!isFinite(c+l+m+x))continue;const u=_.x*g.x*m,y=_.y*g.y*x;e.save(),e.translate(c-u,l-y),e.scale(_.x*o.x,_.y*o.y),this.visuals.image.set_vectorize(e,i),e.drawImage(t,-d.x*m,-d.y*x,m,x),e.restore()}e.restore()}_set_data(e){this._set_width_height_data();const{image_dimension:t}=this;for(let i=0,s=this.image.length;i({image:[d.NDArraySpec,{field:\"image\"}],dw:[d.DistanceSpec,{field:\"dw\"}],dh:[d.DistanceSpec,{field:\"dh\"}],dilate:[e,!1],origin:[o.ImageOrigin,\"bottom_left\"],anchor:[m.Anchor,\"bottom_left\"]})))},\n", - " function _(e,a,t,n,r){var _;n();const s=e(329),m=e(8);class i extends s.ImageBaseView{_flat_img_to_buf8(e){const a=(0,m.isTypedArray)(e)?e:new Uint32Array(e);return new Uint8ClampedArray(a.buffer)}}t.ImageRGBAView=i,i.__name__=\"ImageRGBAView\";class o extends s.ImageBase{constructor(e){super(e)}}t.ImageRGBA=o,_=o,o.__name__=\"ImageRGBA\",_.prototype.default_view=i},\n", - " function _(e,a,t,_,n){var r;_();const s=e(329),c=e(245);class i extends s.ImageBaseView{connect_signals(){super.connect_signals(),this.connect(this.model.color_mapper.change,(()=>this._update_image()))}get image_dimension(){return 3}_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.ImageStackView=i,i.__name__=\"ImageStackView\";class o extends s.ImageBase{constructor(e){super(e)}}t.ImageStack=o,r=o,o.__name__=\"ImageStack\",r.prototype.default_view=i,r.define((({Ref:e})=>({color_mapper:[e(c.StackColorMapper)]})))},\n", - " function _(e,t,s,i,r){var a;i();const n=e(1),h=e(202),o=e(23),d=e(19),_=n.__importStar(e(17)),l=e(13),c=e(150),m=n.__importStar(e(235));class g extends h.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!=i||this.rendered.get(r)||this.renderer.request_render()},failed:()=>{this._set_data_iteration==i&&(this.image[r]=void 0)},attempts:t+1,timeout:s});this.image[r]=a.image}const r=\"data\"==this.model.properties.w.units,a=\"data\"==this.model.properties.h.units,n=this.data_size,h=new o.ScreenArray(r?2*n:n),d=new o.ScreenArray(a?2*n:n);this.anchor=m.anchor(this.model.anchor);const{x:_,y:g}=this.anchor;function u(e,t){const s=e-_*t;return[s,s+t]}function p(e,t){const s=e+g*t;return[s,s-t]}if(r)for(let e=0;e({url:[_.StringSpec,{field:\"url\"}],anchor:[d.Anchor,\"top_left\"],global_alpha:[_.NumberSpec,{value:1}],angle:[_.AngleSpec,0],w:[_.NullDistanceSpec,null],h:[_.NullDistanceSpec,null],dilate:[e,!1],retry_attempts:[t,0],retry_timeout:[t,0]})))},\n", - " function _(e,t,s,i,n){var o;i();const r=e(1),l=e(105),_=e(78),c=r.__importStar(e(210)),h=r.__importStar(e(17)),a=e(13),d=e(9),x=e(203),y=e(209),g=e(101);class p extends x.GlyphView{_project_data(){l.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(e){const{data_size:t}=this;for(let s=0;s0&&o.set(e,s)}return new g.Selection({indices:[...o.keys()],multiline_indices:(0,d.to_object)(o)})}get_interpolation_hit(e,t,s){const i=this._xs.get(e),n=this._ys.get(e),o=i[t],r=n[t],l=i[t+1],_=n[t+1];return(0,y.line_interpolation)(this.renderer,s,o,r,l,_)}draw_legend_for_index(e,t,s){(0,y.generic_line_vector_legend)(this.visuals,e,t,s)}scenterxy(){throw new Error(`${this}.scenterxy() is not implemented`)}}s.MultiLineView=p,p.__name__=\"MultiLineView\";class u extends x.Glyph{constructor(e){super(e)}}s.MultiLine=u,o=u,u.__name__=\"MultiLine\",o.prototype.default_view=p,o.define((({})=>({xs:[h.XCoordinateSeqSpec,{field:\"xs\"}],ys:[h.YCoordinateSeqSpec,{field:\"ys\"}]}))),o.mixins(_.LineVector)},\n", - " function _(t,e,s,n,i){var o;n();const r=t(1),l=t(205),h=t(203),a=t(209),_=t(13),c=t(13),d=t(78),x=r.__importStar(t(210)),y=r.__importStar(t(17)),f=t(101),g=t(12);class p extends h.GlyphView{_project_data(){}_index_data(t){const{min:e,max:s}=Math,{data_size:n}=this;for(let i=0;i1&&c.length>1)for(let s=1,n=i.length;s1){let r=!1;for(let t=1;t({xs:[y.XCoordinateSeqSeqSeqSpec,{field:\"xs\"}],ys:[y.YCoordinateSeqSeqSeqSpec,{field:\"ys\"}]}))),o.mixins([d.LineVector,d.FillVector,d.HatchVector])},\n", - " function _(e,t,s,i,n){var r;i();const a=e(1),o=e(203),_=e(209),c=e(13),h=e(78),l=a.__importStar(e(210)),d=a.__importStar(e(17)),y=e(101),p=e(12),x=e(105);class f extends o.GlyphView{_project_data(){x.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(e){const{data_size:t}=this;for(let s=0;s({xs:[d.XCoordinateSeqSpec,{field:\"xs\"}],ys:[d.YCoordinateSeqSpec,{field:\"ys\"}]}))),r.mixins([h.LineVector,h.FillVector,h.HatchVector])},\n", - " function _(t,e,i,r,o){var s;r();const a=t(1),l=t(322),n=a.__importStar(t(17));class _ extends l.LRTBView{async lazy_initialize(){await super.lazy_initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e&&e.regl_wrapper.has_webgl){const{LRTBGL:i}=await Promise.resolve().then((()=>a.__importStar(t(522))));this.glglyph=new i(e.regl_wrapper,this)}}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=_,_.__name__=\"QuadView\";class p extends l.LRTB{constructor(t){super(t)}}i.Quad=p,s=p,p.__name__=\"Quad\",s.prototype.default_view=_,s.define((({})=>({right:[n.XCoordinateSpec,{field:\"right\"}],bottom:[n.YCoordinateSpec,{field:\"bottom\"}],left:[n.XCoordinateSpec,{field:\"left\"}],top:[n.YCoordinateSpec,{field:\"top\"}]})))},\n", - " function _(e,i,t,s,n){var c;s();const o=e(1),r=e(78),a=e(105),_=e(203),d=e(209),l=e(320),x=o.__importStar(e(17));class y extends _.GlyphView{_project_data(){a.inplace.project_xy(this._x0,this._y0),a.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{_x0:i,_x1:t,_y0:s,_y1:n,_cx:c,_cy:o,data_size:r}=this;for(let a=0;a({x0:[x.XCoordinateSpec,{field:\"x0\"}],y0:[x.YCoordinateSpec,{field:\"y0\"}],x1:[x.XCoordinateSpec,{field:\"x1\"}],y1:[x.YCoordinateSpec,{field:\"y1\"}],cx:[x.XCoordinateSpec,{field:\"cx\"}],cy:[x.YCoordinateSpec,{field:\"cy\"}]}))),c.mixins(r.LineVector)},\n", - " function _(e,t,s,n,i){var l;n();const a=e(1),r=e(202),h=e(209),o=e(78),_=e(23),c=a.__importStar(e(17));class g extends r.XYGlyphView{_map_data(){\"data\"==this.model.properties.length.units?this.slength=this.sdist(this.renderer.xscale,this._x,this.length):this.slength=(0,_.to_screen)(this.length);const{width:e,height:t}=this.renderer.plot_view.frame.bbox,s=2*(e+t),{slength:n}=this;for(let e=0,t=n.length;e({length:[c.DistanceSpec,0],angle:[c.AngleSpec,0]})))},\n", - " function _(t,e,s,i,r){var a;i();const n=t(1),h=t(325),_=t(209),d=t(23),o=t(13),l=t(101),c=t(57),y=t(153),x=t(233),w=n.__importStar(t(235)),g=t(234),{abs:p,sqrt:u}=Math;class f extends h.CenterRotatableView{async lazy_initialize(){await super.lazy_initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e&&e.regl_wrapper.has_webgl){const{RectGL:s}=await Promise.resolve().then((()=>n.__importStar(t(524))));this.glglyph=new s(e.regl_wrapper,this)}}_set_data(t){super._set_data(t),this.border_radius=w.border_radius(this.model.border_radius)}_map_data(){const t=this.data_size;if(\"data\"==this.model.properties.width.units)[this.sw,this.sx0]=this._map_dist_corner_for_data_side_length(this._x,this.width,this.renderer.xscale);else{this.sw=(0,d.to_screen)(this.width),this.sx0=new d.ScreenArray(t);for(let e=0;e({border_radius:[x.BorderRadius,0],dilate:[t,!1]})))},\n", - " function _(e,t,r,a,i){var s;a();const n=e(1),l=e(341),_=e(342),c=n.__importStar(e(17));class o extends l.MarkerView{async lazy_initialize(){await super.lazy_initialize();const{webgl:t}=this.renderer.plot_view.canvas_view;if(null!=t&&t.regl_wrapper.has_webgl){const{MultiMarkerGL:r}=await Promise.resolve().then((()=>n.__importStar(e(523))));this.glglyph=new r(t.regl_wrapper,this)}}_render(e,t,r){const{sx:a,sy:i,size:s,angle:n,marker:l}=null!=r?r:this;for(const r of t){const t=a[r],c=i[r],o=s.get(r),g=n.get(r),w=l.get(r);if(!isFinite(t+c+o+g)||null==w)continue;const p=o/2;e.beginPath(),e.translate(t,c),0!=g&&e.rotate(g),_.marker_funcs[w](e,r,p,this.visuals),0!=g&&e.rotate(-g),e.translate(-t,-c)}}draw_legend_for_index(e,{x0:t,x1:r,y0:a,y1:i},s){const n=s+1,l=this.marker.get(s),_=Object.assign(Object.assign({},this._get_legend_args({x0:t,x1:r,y0:a,y1:i},s)),{marker:new c.UniformScalar(l,n)});this._render(e,[s],_)}}r.ScatterView=o,o.__name__=\"ScatterView\";class g extends l.Marker{constructor(e){super(e)}}r.Scatter=g,s=g,g.__name__=\"Scatter\",s.prototype.default_view=o,s.define((()=>({marker:[c.MarkerSpec,{value:\"circle\"}]})))},\n", - " function _(e,t,s,n,i){var r;n();const a=e(1),c=e(202),o=e(78),_=a.__importStar(e(210)),h=a.__importStar(e(17)),l=e(10),x=e(101);class d extends c.XYGlyphView{_render(e,t,s){const{sx:n,sy:i,size:r,angle:a}=null!=s?s:this;for(const s of t){const t=n[s],c=i[s],o=r.get(s),_=a.get(s);if(!isFinite(t+c+o+_))continue;const h=o/2;e.beginPath(),e.translate(t,c),0!=_&&e.rotate(_),this._render_one(e,s,h,this.visuals),0!=_&&e.rotate(-_),e.translate(-t,-c)}}_mask_data(){const{x_target:e,y_target:t}=this.renderer.plot_view.frame,s=e.widen(this.max_size).map((e=>this.renderer.xscale.invert(e))),n=t.widen(this.max_size).map((e=>this.renderer.yscale.invert(e)));return this.index.indices({x0:s.start,x1:s.end,y0:n.start,y1:n.end})}_hit_point(e){const{sx:t,sy:s}=e,{max_size:n}=this,{hit_dilation:i}=this.model,r=t-n*i,a=t+n*i,[c,o]=this.renderer.xscale.r_invert(r,a),_=s-n*i,h=s+n*i,[l,d]=this.renderer.yscale.r_invert(_,h),y=this.index.indices({x0:c,x1:o,y0:l,y1:d}),g=[];for(const e of y){const n=this.size.get(e)/2*i;Math.abs(this.sx[e]-t)<=n&&Math.abs(this.sy[e]-s)<=n&&g.push(e)}return new x.Selection({indices:g})}_hit_span(e){const{sx:t,sy:s}=e,n=this.bounds(),i=this.max_size/2;let r,a,c,o;if(\"h\"==e.direction){c=n.y0,o=n.y1;const e=t-i,s=t+i;[r,a]=this.renderer.xscale.r_invert(e,s)}else{r=n.x0,a=n.x1;const e=s-i,t=s+i;[c,o]=this.renderer.yscale.r_invert(e,t)}const _=[...this.index.indices({x0:r,x1:a,y0:c,y1:o})];return new x.Selection({indices:_})}_hit_rect(e){const{sx0:t,sx1:s,sy0:n,sy1:i}=e,[r,a]=this.renderer.xscale.r_invert(t,s),[c,o]=this.renderer.yscale.r_invert(n,i),_=[...this.index.indices({x0:r,x1:a,y0:c,y1:o})];return new x.Selection({indices:_})}_hit_poly(e){const{sx:t,sy:s}=e,n=(0,l.range)(0,this.sx.length),i=[];for(let e=0,r=n.length;e({size:[h.ScreenSizeSpec,{value:4}],angle:[h.AngleSpec,0],hit_dilation:[e,1]})))},\n", - " function _(l,n,o,i,a){i();const t=Math.sqrt(3),e=Math.sqrt(5),p=(e+1)/4,c=Math.sqrt((5-e)/8),h=(e-1)/4,u=Math.sqrt((5+e)/8);function f(l,n){l.rotate(Math.PI/4),y(l,n),l.rotate(-Math.PI/4)}function r(l,n){const o=n*t,i=o/3;l.moveTo(-o/2,-i),l.lineTo(0,0),l.lineTo(o/2,-i),l.lineTo(0,0),l.lineTo(0,n)}function y(l,n){l.moveTo(0,n),l.lineTo(0,-n),l.moveTo(-n,0),l.lineTo(n,0)}function T(l,n){l.moveTo(0,n),l.lineTo(n/1.5,0),l.lineTo(0,-n),l.lineTo(-n/1.5,0),l.closePath()}function s(l,n){const o=n*t,i=o/3;l.moveTo(-n,i),l.lineTo(n,i),l.lineTo(0,i-o),l.closePath()}function v(l,n,o,i){l.arc(0,0,o,0,2*Math.PI,!1),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)}function d(l,n,o,i){T(l,o),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)}function P(l,n,o,i){!function(l,n){l.beginPath(),l.arc(0,0,n/4,0,2*Math.PI,!1),l.closePath()}(l,o),i.line.set_vectorize(l,n),l.fillStyle=l.strokeStyle,l.fill()}function m(l,n,o,i){!function(l,n){const o=n/2,i=t*o;l.moveTo(n,0),l.lineTo(o,-i),l.lineTo(-o,-i),l.lineTo(-n,0),l.lineTo(-o,i),l.lineTo(o,i),l.closePath()}(l,o),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)}function _(l,n,o,i){const a=2*o;l.rect(-o,-o,a,a),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)}function q(l,n,o,i){!function(l,n){const o=Math.sqrt(5-2*e)*n;l.moveTo(0,-n),l.lineTo(o*h,o*u-n),l.lineTo(o*(1+h),o*u-n),l.lineTo(o*(1+h-p),o*(u+c)-n),l.lineTo(o*(1+2*h-p),o*(2*u+c)-n),l.lineTo(0,2*o*u-n),l.lineTo(-o*(1+2*h-p),o*(2*u+c)-n),l.lineTo(-o*(1+h-p),o*(u+c)-n),l.lineTo(-o*(1+h),o*u-n),l.lineTo(-o*h,o*u-n),l.closePath()}(l,o),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)}function M(l,n,o,i){s(l,o),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)}o.marker_funcs={asterisk:function(l,n,o,i){y(l,o),f(l,o),i.line.apply(l,n)},circle:v,circle_cross:function(l,n,o,i){l.arc(0,0,o,0,2*Math.PI,!1),i.fill.apply(l,n),i.hatch.apply(l,n),y(l,o),i.line.apply(l,n)},circle_dot:function(l,n,o,i){v(l,n,o,i),P(l,n,o,i)},circle_y:function(l,n,o,i){l.arc(0,0,o,0,2*Math.PI,!1),i.fill.apply(l,n),i.hatch.apply(l,n),r(l,o),i.line.apply(l,n)},circle_x:function(l,n,o,i){l.arc(0,0,o,0,2*Math.PI,!1),i.fill.apply(l,n),i.hatch.apply(l,n),f(l,o),i.line.apply(l,n)},cross:function(l,n,o,i){y(l,o),i.line.apply(l,n)},diamond:d,diamond_dot:function(l,n,o,i){d(l,n,o,i),P(l,n,o,i)},diamond_cross:function(l,n,o,i){T(l,o),i.fill.apply(l,n),i.hatch.apply(l,n),l.moveTo(0,o),l.lineTo(0,-o),l.moveTo(-o/1.5,0),l.lineTo(o/1.5,0),i.line.apply(l,n)},dot:P,hex:m,hex_dot:function(l,n,o,i){m(l,n,o,i),P(l,n,o,i)},inverted_triangle:function(l,n,o,i){l.rotate(Math.PI),s(l,o),l.rotate(-Math.PI),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)},plus:function(l,n,o,i){const a=3*o/8,t=[a,a,o,o,a,a,-a,-a,-o,-o,-a,-a],e=[o,a,a,-a,-a,-o,-o,-a,-a,a,a,o];l.beginPath();for(let n=0;n<12;n++)l.lineTo(t[n],e[n]);l.closePath(),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)},square:_,square_cross:function(l,n,o,i){const a=2*o;l.rect(-o,-o,a,a),i.fill.apply(l,n),i.hatch.apply(l,n),y(l,o),i.line.apply(l,n)},square_dot:function(l,n,o,i){_(l,n,o,i),P(l,n,o,i)},square_pin:function(l,n,o,i){const a=3*o/8;l.moveTo(-o,-o),l.quadraticCurveTo(0,-a,o,-o),l.quadraticCurveTo(a,0,o,o),l.quadraticCurveTo(0,a,-o,o),l.quadraticCurveTo(-a,0,-o,-o),l.closePath(),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)},square_x:function(l,n,o,i){const a=2*o;l.rect(-o,-o,a,a),i.fill.apply(l,n),i.hatch.apply(l,n),l.moveTo(-o,o),l.lineTo(o,-o),l.moveTo(-o,-o),l.lineTo(o,o),i.line.apply(l,n)},star:q,star_dot:function(l,n,o,i){q(l,n,o,i),P(l,n,o,i)},triangle:M,triangle_dot:function(l,n,o,i){M(l,n,o,i),P(l,n,o,i)},triangle_pin:function(l,n,o,i){const a=o*t,e=a/3,p=3*e/8;l.moveTo(-o,e),l.quadraticCurveTo(0,p,o,e),l.quadraticCurveTo(t*p/2,p/2,0,e-a),l.quadraticCurveTo(-t*p/2,p/2,-o,e),l.closePath(),i.fill.apply(l,n),i.hatch.apply(l,n),i.line.apply(l,n)},dash:function(l,n,o,i){!function(l,n){l.moveTo(-n,0),l.lineTo(n,0)}(l,o),i.line.apply(l,n)},x:function(l,n,o,i){f(l,o),i.line.apply(l,n)},y:function(l,n,o,i){r(l,o),i.line.apply(l,n)}}},\n", - " function _(e,t,s,i,n){var r;i();const o=e(1),a=o.__importStar(e(210)),_=o.__importStar(e(17)),d=e(78),h=e(105),c=e(11),x=e(203),l=e(209),y=e(101);class p extends x.GlyphView{_project_data(){h.inplace.project_xy(this._x0,this._y0),h.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{min:t,max:s}=Math,{_x0:i,_x1:n,_y0:r,_y1:o,data_size:a}=this;for(let _=0;_({x0:[_.XCoordinateSpec,{field:\"x0\"}],y0:[_.YCoordinateSpec,{field:\"y0\"}],x1:[_.XCoordinateSpec,{field:\"x1\"}],y1:[_.YCoordinateSpec,{field:\"y1\"}]}))),r.mixins(d.LineVector)},\n", - " function _(t,e,s,i,n){var o;i();const _=t(1),l=t(202),a=_.__importStar(t(78)),c=t(345);class r extends l.XYGlyphView{_set_data(){const{tension:t,closed:e}=this.model;[this._xt,this._yt]=(0,c.catmullrom_spline)(this._x,this._y,20,t,e)}_map_data(){const{x_scale:t,y_scale:e}=this.renderer.coordinates;this.sxt=t.v_compute(this._xt),this.syt=e.v_compute(this._yt)}_render(t,e,s){const{sxt:i,syt:n}=null!=s?s:this;let o=!0;t.beginPath();const _=i.length;for(let e=0;e<_;e++){const s=i[e],_=n[e];isFinite(s+_)?o?(t.moveTo(s,_),o=!1):t.lineTo(s,_):o=!0}this.visuals.line.set_value(t),t.stroke()}}s.SplineView=r,r.__name__=\"SplineView\";class h extends l.XYGlyph{constructor(t){super(t)}}s.Spline=h,o=h,h.__name__=\"Spline\",o.prototype.default_view=r,o.mixins(a.LineScalar),o.define((({Boolean:t,Number:e})=>({tension:[e,.5],closed:[t,!1]})))},\n", - " function _(n,t,e,o,s){o();const c=n(23),l=n(12);e.catmullrom_spline=function(n,t,e=10,o=.5,s=!1){(0,l.assert)(n.length==t.length);const r=n.length,f=s?r+1:r,w=(0,c.infer_type)(n,t),i=new w(f+2),u=new w(f+2);i.set(n,1),u.set(t,1),s?(i[0]=n[r-1],u[0]=t[r-1],i[f]=n[0],u[f]=t[0],i[f+1]=n[1],u[f+1]=t[1]):(i[0]=n[0],u[0]=t[0],i[f+1]=n[r-1],u[f+1]=t[r-1]);const g=new w(4*(e+1));for(let n=0,t=0;n<=e;n++){const o=n/e,s=o**2,c=o*s;g[t++]=2*c-3*s+1,g[t++]=-2*c+3*s,g[t++]=c-2*s+o,g[t++]=c-s}const h=new w((f-1)*(e+1)),_=new w((f-1)*(e+1));for(let n=1,t=0;n_.__importStar(e(525))));this.glglyph=new r(t.regl_wrapper,this)}}_render(e,t,r){const i=t.length;if(i<2)return;const{sx:n,sy:s}=null!=r?r:this,_=this.model.mode;this.visuals.line.set_value(e);let a=!1,l=!1;const o=t[0];let h=isFinite(n[o]+s[o]);\"center\"==_&&(a=this._render_xy(e,a,h?n[o]:NaN,s[o]));for(const r of t){const t=isFinite(n[r+1]+s[r+1]);switch(_){case\"before\":a=this._render_xy(e,a,h?n[r]:NaN,s[r]),r({mode:[h.StepMode,\"before\"]})))},\n", - " function _(t,e,s,a,i){var r;a();const n=t(1),o=t(202),l=n.__importStar(t(78)),_=n.__importStar(t(17)),c=t(37),h=t(101),d=t(57),u=t(32),x=t(153),f=t(151),g=t(233),p=n.__importStar(t(235)),y=t(234);class b extends _.DataSpec{}b.__name__=\"TextAnchorSpec\";class w extends o.XYGlyphView{_set_data(t){super._set_data(t),this.labels=Array.from(this.text,(t=>{if(null==t)return null;{const e=`${t}`;return new f.TextBox({text:e})}}))}after_visuals(){super.after_visuals();const t=this.data_size,{anchor:e}=this,{padding:s,border_radius:a}=this.model,{text_align:i,text_baseline:r}=this.visuals.text;if(e.is_Scalar()&&\"auto\"!=e.value)this.anchor_=new c.UniformScalar(p.anchor(e.value),t);else if(e.is_Scalar()&&i.is_Scalar()&&r.is_Scalar())this.anchor_=new c.UniformScalar(p.text_anchor(e.value,i.value,r.value),t);else{const s=new Array(t);for(let a=0;a({text:[_.NullStringSpec,{field:\"text\"}],angle:[_.AngleSpec,0],x_offset:[_.NumberSpec,0],y_offset:[_.NumberSpec,0],anchor:[b,{value:\"auto\"}],padding:[g.Padding,0],border_radius:[g.BorderRadius,0]}))),r.override({border_line_color:null,background_fill_color:null,background_hatch_color:null})},\n", - " function _(t,e,s,i,r){var h;i();const a=t(1),o=t(322),n=t(23),_=a.__importStar(t(17));class l extends o.LRTBView{async lazy_initialize(){await super.lazy_initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e&&e.regl_wrapper.has_webgl){const{LRTBGL:s}=await Promise.resolve().then((()=>a.__importStar(t(522))));this.glglyph=new s(e.regl_wrapper,this)}}scenterxy(t){return[this.sx[t],(this.stop[t]+this.sbottom[t])/2]}_lrtb(t){const e=this.width.get(t)/2,s=this._x[t],i=this._top[t],r=this._bottom[t];return[s-e,s+e,Math.max(i,r),Math.min(i,r)]}_map_data(){this.sx=this.renderer.xscale.v_compute(this._x),this.sw=this.sdist(this.renderer.xscale,this._x,this.width,\"center\"),this.stop=this.renderer.yscale.v_compute(this._top),this.sbottom=this.renderer.yscale.v_compute(this._bottom);const t=this.sx.length;this.sleft=new n.ScreenArray(t),this.sright=new n.ScreenArray(t);for(let e=0;e({x:[_.XCoordinateSpec,{field:\"x\"}],bottom:[_.YCoordinateSpec,{value:0}],width:[_.NumberSpec,{value:1}],top:[_.YCoordinateSpec,{field:\"top\"}]})))},\n", - " function _(e,s,t,i,a){var n;i();const r=e(1),d=e(202),h=e(209),c=e(78),l=e(23),o=e(19),_=r.__importStar(e(17)),u=e(11),g=e(101),x=e(13);class p extends d.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius):this.sradius=(0,l.to_screen)(this.radius),this.max_sradius=(0,x.max)(this.sradius)}_render(e,s,t){const{sx:i,sy:a,sradius:n,start_angle:r,end_angle:d}=null!=t?t:this,h=\"anticlock\"==this.model.direction;for(const t of s){const s=i[t],c=a[t],l=n[t],o=r.get(t),_=d.get(t);isFinite(s+c+l+o+_)&&(e.beginPath(),e.arc(s,c,l,o,_,h),e.lineTo(s,c),e.closePath(),this.visuals.fill.apply(e,t),this.visuals.hatch.apply(e,t),this.visuals.line.apply(e,t))}}_hit_point(e){let s,t,i,a,n;const{sx:r,sy:d}=e,h=this.renderer.xscale.invert(r),c=this.renderer.yscale.invert(d);t=r-this.max_sradius,i=r+this.max_sradius;const[l,o]=this.renderer.xscale.r_invert(t,i);a=d-this.max_sradius,n=d+this.max_sradius;const[_,x]=this.renderer.yscale.r_invert(a,n),p=[];for(const e of this.index.indices({x0:l,x1:o,y0:_,y1:x})){const r=this.sradius[e]**2;[t,i]=this.renderer.xscale.r_compute(h,this._x[e]),[a,n]=this.renderer.yscale.r_compute(c,this._y[e]),s=(t-i)**2+(a-n)**2,s<=r&&p.push(e)}const y=\"anticlock\"==this.model.direction,m=[];for(const e of p){const s=Math.atan2(d-this.sy[e],r-this.sx[e]);(Math.abs(this.start_angle.get(e)-this.end_angle.get(e))>=2*Math.PI||(0,u.angle_between)(-s,-this.start_angle.get(e),-this.end_angle.get(e),y))&&m.push(e)}return new g.Selection({indices:m})}draw_legend_for_index(e,s,t){(0,h.generic_area_vector_legend)(this.visuals,e,s,t)}scenterxy(e){const s=this.sradius[e]/2,t=(this.start_angle.get(e)+this.end_angle.get(e))/2;return[this.sx[e]+s*Math.cos(t),this.sy[e]+s*Math.sin(t)]}}t.WedgeView=p,p.__name__=\"WedgeView\";class y extends d.XYGlyph{constructor(e){super(e)}}t.Wedge=y,n=y,y.__name__=\"Wedge\",n.prototype.default_view=p,n.mixins([c.LineVector,c.FillVector,c.HatchVector]),n.define((({})=>({direction:[o.Direction,\"anticlock\"],radius:[_.DistanceSpec,{field:\"radius\"}],start_angle:[_.AngleSpec,{field:\"start_angle\"}],end_angle:[_.AngleSpec,{field:\"end_angle\"}]})))},\n", - " function _(n,i,o,a,r){a(),r(\"Decoration\",n(208).Decoration),r(\"Marking\",n(140).Marking)},\n", - " function _(t,_,r,o,a){o();const e=t(1);e.__exportStar(t(352),r),e.__exportStar(t(353),r),e.__exportStar(t(354),r)},\n", - " function _(e,t,d,n,s){n();const o=e(50),r=e(13),i=e(10),_=e(101);class a 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=a,a.__name__=\"GraphHitTestPolicy\";class c extends a{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=c,c.__name__=\"EdgesOnly\";class l extends a{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 a{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.node_view)}get_linked_edges(e,t,d){const n=(()=>{switch(d){case\"selection\":return(0,r.map)(e.selected.indices,(t=>e.data.index[t]));case\"inspection\":return(0,r.map)(e.inspected.indices,(t=>e.data.index[t]))}})(),s=[];for(let e=0;e{switch(d){case\"selection\":return t.selected.indices;case\"inspection\":return t.inspected.indices}})(),s=[];for(const e of n)s.push(t.data.start[e]),s.push(t.data.end[e]);const o=(0,i.uniq)(s).map((t=>(0,r.index_of)(e.data.index,t)));return new _.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),i=this.get_linked_nodes(d.node_view.model.data_source,d.edge_view.model.data_source,\"inspection\");return r.update(i,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\";class p extends a{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.node_view)}get_adjacent_nodes(e,t,d){const n=(()=>{switch(d){case\"selection\":return(0,r.map)(e.selected.indices,(t=>e.data.index[t]));case\"inspection\":return(0,r.map)(e.inspected.indices,(t=>e.data.index[t]))}})(),s=[],o=[];for(let e=0;e(0,r.index_of)(e.data.index,t)));return new _.Selection({indices:a})}do_selection(e,t,d,n){if(null==e)return!1;const s=t.node_renderer.data_source.selected;s.update(e,d,n);const o=this.get_adjacent_nodes(t.node_renderer.data_source,t.edge_renderer.data_source,\"selection\");return o.is_empty()||s.update(o,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 o=d.node_view.model.data_source.selection_manager.get_or_create_inspector(d.node_view.model);o.update(e,n,s),d.node_view.model.data_source.setv({inspected:o},{silent:!0});const r=this.get_adjacent_nodes(d.node_view.model.data_source,d.edge_view.model.data_source,\"inspection\");return r.is_empty()||(o.update(r,n,s),d.node_view.model.data_source.setv({inspected:o},{silent:!0})),d.node_view.model.data_source.inspect.emit([d.node_view.model,{geometry:t}]),!o.is_empty()}}d.NodesAndAdjacentNodes=p,p.__name__=\"NodesAndAdjacentNodes\"},\n", - " function _(e,o,t,r,n){var s;r();const a=e(50),d=e(304);class _ extends a.Model{constructor(e){super(e)}get node_coordinates(){return new u({layout:this})}get edge_coordinates(){return new i({layout:this})}}t.LayoutProvider=_,_.__name__=\"LayoutProvider\";class c extends d.CoordinateTransform{constructor(e){super(e)}}t.GraphCoordinates=c,s=c,c.__name__=\"GraphCoordinates\",s.define((({Ref:e})=>({layout:[e(_)]})));class u extends c{constructor(e){super(e)}_v_compute(e){const[o,t]=this.layout.get_node_coordinates(e);return{x:o,y:t}}}t.NodeCoordinates=u,u.__name__=\"NodeCoordinates\";class i extends c{constructor(e){super(e)}_v_compute(e){const[o,t]=this.layout.get_edge_coordinates(e);return{x:o,y:t}}}t.EdgeCoordinates=i,i.__name__=\"EdgeCoordinates\"},\n", - " function _(t,e,a,n,o){var l;n();const r=t(353),s=t(9);class u extends r.LayoutProvider{constructor(t){super(t)}get_node_coordinates(t){var e,a;const n=null!==(e=new s.Dict(t.data).get(\"index\"))&&void 0!==e?e:[],o=n.length,l=new Float64Array(o),r=new Float64Array(o),{graph_layout:u}=this;for(let t=0;t({graph_layout:[n(e,a(t)),new globalThis.Map]})))},\n", - " function _(i,d,n,r,G){r(),G(\"Grid\",i(356).Grid)},\n", - " function _(i,e,s,n,t){var r;n();const o=i(1),d=i(158),_=i(160),a=i(161),l=o.__importStar(i(78)),h=i(8);class u extends _.GuideRendererView{_render(){const i=this.layer.ctx;i.save(),this._draw_regions(i),this._draw_minor_grids(i),this._draw_grids(i),i.restore()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_draw_regions(i){if(!this.visuals.band_fill.doit&&!this.visuals.band_hatch.doit)return;const[e,s]=this.grid_coords(\"major\",!1);for(let n=0;ns[1]&&(t=s[1]);else{[n,t]=s;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&&([n,t]=i.computed_bounds)}return[n,t]}grid_coords(i,e=!0){const s=this.model.dimension,n=1-s,[t,r]=this.ranges(),[o,d]=(()=>{const[i,e]=this.computed_bounds();return[Math.min(i,e),Math.max(i,e)]})(),_=[[],[]],a=this.model.get_ticker();if(null==a)return _;const l=a.get_ticks(o,d,t,r.min)[i],h=t.min,u=t.max,[c,m]=(()=>{const{cross_bounds:i}=this.model;return\"auto\"==i?[r.min,r.max]:i})();e||(l[0]!=h&&l.splice(0,0,h),l[l.length-1]!=u&&l.push(u));for(let i=0;i({bounds:[r(t(i,i),e),\"auto\"],cross_bounds:[r(t(i,i),e),\"auto\"],dimension:[s(0,1),0],axis:[o(n(d.Axis)),null],ticker:[o(n(a.Ticker)),null]}))),r.override({level:\"underlay\",band_fill_color:null,band_fill_alpha:0,grid_line_color:\"#e5e5e5\",minor_grid_line_color:null})},\n", - " function _(o,x,B,a,l){a(),l(\"Column\",o(358).Column),l(\"FlexBox\",o(359).FlexBox),l(\"GridBox\",o(364).GridBox),l(\"GroupBox\",o(366).GroupBox),l(\"HBox\",o(368).HBox),l(\"LayoutDOM\",o(360).LayoutDOM),l(\"Row\",o(369).Row),l(\"ScrollBox\",o(370).ScrollBox),l(\"Spacer\",o(371).Spacer),l(\"TabPanel\",o(372).TabPanel),l(\"Tabs\",o(373).Tabs),l(\"VBox\",o(375).VBox)},\n", - " function _(e,o,n,t,s){var u;t();const _=e(359);class c extends _.FlexBoxView{constructor(){super(...arguments),this._direction=\"column\"}}n.ColumnView=c,c.__name__=\"ColumnView\";class l extends _.FlexBox{constructor(e){super(e)}}n.Column=l,u=l,l.__name__=\"Column\",u.prototype.default_view=c},\n", - " function _(e,t,i,n,o){var s;n();const a=e(360),c=e(363),r=e(228),l=e(257),h=e(56);class d extends a.LayoutDOMView{connect_signals(){super.connect_signals();const{children:e}=this.model.properties;this.on_change(e,(()=>this.update_children()))}get child_models(){return this.model.children}_intrinsic_display(){return{inner:this.model.flow_mode,outer:\"flex\"}}_update_layout(){super._update_layout(),this.style.append(\":host\",{flex_direction:this._direction,gap:(0,h.px)(this.model.spacing)});const e=new r.Container;let t=0,i=0;for(const n of this.child_views){if(!(n instanceof a.LayoutDOMView))continue;const o=n.box_sizing(),s=(()=>{const e=\"row\"==this._direction?o.width_policy:o.height_policy,t=\"row\"==this._direction?o.width:o.height,i=null!=t?(0,h.px)(t):\"auto\";switch(e){case\"auto\":case\"fixed\":return`0 0 ${i}`;case\"fit\":return\"1 1 auto\";case\"min\":return\"0 1 auto\";case\"max\":return\"1 0 0px\"}})(),c=(()=>{switch(\"row\"==this._direction?o.height_policy:o.width_policy){case\"auto\":case\"fixed\":case\"fit\":case\"min\":return\"row\"==this._direction?o.valign:o.halign;case\"max\":return\"stretch\"}})();n.style.append(\":host\",{flex:s,align_self:c}),\"row\"==this._direction?\"max\"==o.height_policy&&n.style.append(\":host\",{height:\"auto\"}):\"max\"==o.width_policy&&n.style.append(\":host\",{width:\"auto\"}),null!=n.layout&&(e.add({r0:t,c0:i,r1:t+1,c1:i+1},n),\"row\"==this._direction?i+=1:t+=1)}0!=e.size?(this.layout=new c.GridAlignmentLayout(e),this.layout.set_sizing()):delete this.layout}}i.FlexBoxView=d,d.__name__=\"FlexBoxView\";class _ extends a.LayoutDOM{constructor(e){super(e)}}i.FlexBox=_,s=_,_.__name__=\"FlexBox\",s.define((({Number:e,Array:t,Ref:i})=>({children:[t(i(l.UIElement)),[]],spacing:[e,0]})))},\n", - " function _(t,e,i,s,l){var n;s();const a=t(257),o=t(361),r=t(18),h=t(15),u=t(19),_=t(56),d=t(8),c=t(59),f=t(226),m=t(16),p=t(260),w=t(12);class y extends a.UIElementView{constructor(){super(...arguments),this._child_views=new Map,this.mouseenter=new h.Signal(this,\"mouseenter\"),this.mouseleave=new h.Signal(this,\"mouseleave\"),this.disabled=new h.Signal(this,\"disabled\"),this._resized=!1,this._auto_width=\"fit-content\",this._auto_height=\"fit-content\",this._layout_computed=!1,this._was_built=!1}get is_layout_root(){return this.is_root||!(this.parent instanceof y)}_after_resize(){this._resized=!0,super._after_resize(),this.is_layout_root&&!this._was_built?(r.logger.warn(`${this} wasn't built properly`),this.render_to(null)):this.compute_layout()}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.el.addEventListener(\"mouseenter\",(t=>{this.mouseenter.emit(t)})),this.el.addEventListener(\"mouseleave\",(t=>{this.mouseleave.emit(t)})),this.el.addEventListener(\"contextmenu\",(t=>{null!=this.model.context_menu&&(console.log(\"context menu\"),t.preventDefault())})),this.parent instanceof y&&this.connect(this.parent.disabled,(t=>{this.disabled.emit(t||this.model.disabled)}));const t=this.model.properties;this.on_change(t.disabled,(()=>{this.disabled.emit(this.model.disabled)})),this.on_change([t.css_classes,t.stylesheets,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.flow_mode,t.sizing_mode,t.aspect_ratio,t.visible],(()=>this.invalidate_layout()))}*children(){yield*super.children(),yield*this.child_views}get child_views(){return this.child_models.map((t=>this._child_views.get(t))).filter(d.isNotNull)}get layoutable_views(){return this.child_views.filter((t=>t instanceof y))}async build_child_views(){const{created:t,removed:e}=await(0,c.build_views)(this._child_views,this.child_models,{parent:this});for(const t of e)this._resize_observer.unobserve(t.el);for(const e of t)this._resize_observer.observe(e.el,{box:\"border-box\"});return t}render(){super.render();for(const t of this.child_views)t.render(),this.shadow_el.appendChild(t.el)}_update_children(){}async update_children(){const t=new Set(await this.build_child_views());if(0!=t.size){for(const t of this.child_views)(0,_.remove)(t.el);for(const e of this.child_views)this.shadow_el.append(e.el),t.has(e)&&(e.render(),e.after_render())}this._update_children(),this.invalidate_layout()}_intrinsic_display(){return{inner:this.model.flow_mode,outer:\"flow\"}}_update_layout(){function t(t,e,i,s){switch(t){case\"auto\":return null!=e?(0,_.px)(e):i;case\"fixed\":return null!=e?(0,_.px)(e):\"fit-content\";case\"fit\":return\"fit-content\";case\"min\":return\"min-content\";case\"max\":return null==s?\"100%\":`calc(100% - ${s})`}}function e(t){return(0,d.isNumber)(t)?(0,_.px)(t):`${t.percent}%`}const i={},s=this._intrinsic_display();i.display=function(t){const{inner:e,outer:i}=t;switch(`${e} ${i}`){case\"block flow\":return\"block\";case\"inline flow\":return\"inline\";case\"block flow-root\":return\"flow-root\";case\"inline flow-root\":return\"inline-block\";case\"block flex\":return\"flex\";case\"inline flex\":return\"inline-flex\";case\"block grid\":return\"grid\";case\"inline grid\":return\"inline-grid\";case\"block table\":return\"table\";case\"inline table\":return\"inline-table\";default:(0,w.unreachable)()}}(s);const l=this.box_sizing(),{width_policy:n,height_policy:a,width:o,height:r,aspect_ratio:h}=l,u=(()=>{if(\"auto\"==h){if(null!=o&&null!=r)return o/r}else if((0,d.isNumber)(h))return h;return null})();\"auto\"==h?i.aspect_ratio=null!=o&&null!=r?`${o} / ${r}`:\"auto\":(0,d.isNumber)(h)&&(i.aspect_ratio=`${h}`);const{margin:c}=this.model,f=(()=>{if(null!=c){if((0,d.isNumber)(c))return i.margin=(0,_.px)(c),{width:(0,_.px)(2*c),height:(0,_.px)(2*c)};if(2==c.length){const[t,e]=c;return i.margin=`${(0,_.px)(t)} ${(0,_.px)(e)}`,{width:(0,_.px)(2*e),height:(0,_.px)(2*t)}}{const[t,e,s,l]=c;return i.margin=`${(0,_.px)(t)} ${(0,_.px)(e)} ${(0,_.px)(s)} ${(0,_.px)(l)}`,{width:(0,_.px)(l+e),height:(0,_.px)(t+s)}}}return{width:null,height:null}})(),[m,p]=(()=>{const e=t(n,o,this._auto_width,f.width),i=t(a,r,this._auto_height,f.height);if(null!=h){if(n!=a)return\"fixed\"==n?[e,\"auto\"]:\"fixed\"==a?[\"auto\",i]:\"max\"==n?[e,\"auto\"]:\"max\"==a?[\"auto\",i]:[\"auto\",\"auto\"];if(\"fixed\"!=n&&\"fixed\"!=a&&null!=u)return u>=1?[e,\"auto\"]:[\"auto\",i]}return[e,i]})();i.width=m,i.height=p;const{min_width:y,max_width:g}=this.model,{min_height:b,max_height:x}=this.model;i.min_width=null==y?\"0px\":e(y),i.min_height=null==b?\"0px\":e(b),this.is_layout_root?(null!=g&&(i.max_width=e(g)),null!=x&&(i.max_height=e(x))):(null!=g?i.max_width=`min(${e(g)}, 100%)`:\"fixed\"!=n&&(i.max_width=\"100%\"),null!=x?i.max_height=`min(${e(x)}, 100%)`:\"fixed\"!=a&&(i.max_height=\"100%\"));const{resizable:v}=this.model;if(!1!==v){const t=(()=>{switch(v){case\"width\":return\"horizontal\";case\"height\":return\"vertical\";case!0:case\"both\":return\"both\"}})();i.resize=t,i.overflow=\"auto\"}this.style.append(\":host\",i)}update_layout(){this.update_style();for(const t of this.layoutable_views)t.update_layout();this._update_layout()}get is_managed(){return this.parent instanceof y}_measure_layout(){}measure_layout(){for(const t of this.layoutable_views)t.measure_layout();this._measure_layout()}compute_layout(){this.parent instanceof y?this.parent.compute_layout():(this.measure_layout(),this.update_bbox(),this._compute_layout(),this.after_layout()),this._layout_computed=!0}_compute_layout(){if(null!=this.layout){this.layout.compute(this.bbox.size);for(const t of this.layoutable_views)null==t.layout?t._compute_layout():t._propagate_layout()}else for(const t of this.layoutable_views)t._compute_layout()}_propagate_layout(){for(const t of this.layoutable_views)null==t.layout&&t._compute_layout()}update_bbox(){for(const t of this.layoutable_views)t.update_bbox();const t=super.update_bbox();return null!=this.layout&&(this.layout.visible=this.is_displayed),t}_after_layout(){}after_layout(){for(const t of this.layoutable_views)t.after_layout();this._after_layout()}render_to(t){if(!this.is_layout_root)throw new Error(`${this.toString()} is not a root layout`);this.render(),null!=t&&t.appendChild(this.el),this.r_after_render(),this._was_built=!0,this.notify_finished()}r_after_render(){for(const t of this.child_views)t instanceof y?t.r_after_render():t.after_render();this.after_render()}after_render(){this._after_render(),this.is_managed||this.invalidate_layout(),this._has_finished||(this.is_displayed?(0,m.defer)().then((()=>{this._resized||this.finish()})):this.finish())}async rebuild(){await this.build_child_views(),this.invalidate_render()}invalidate_layout(){this.parent instanceof y?this.parent.invalidate_layout():(this.update_layout(),this.compute_layout())}invalidate_render(){this.render(),this.invalidate_layout()}has_finished(){if(!super.has_finished())return!1;if(this.is_layout_root&&!this._layout_computed)return!1;for(const t of this.child_views)if(!t.has_finished())return!1;return!0}box_sizing(){let{width_policy:t,height_policy:e,aspect_ratio:i}=this.model;const{sizing_mode:s}=this.model;if(null!=s)if(\"inherit\"==s){if(this.parent instanceof y){const s=this.parent.box_sizing();t=s.width_policy,e=s.height_policy,null==i&&(i=s.aspect_ratio)}}else if(\"fixed\"==s)t=e=\"fixed\";else if(\"stretch_both\"==s)t=e=\"max\";else if(\"stretch_width\"==s)t=\"max\";else if(\"stretch_height\"==s)e=\"max\";else switch(null==i&&(i=\"auto\"),s){case\"scale_width\":t=\"max\",e=\"min\";break;case\"scale_height\":t=\"min\",e=\"max\";break;case\"scale_both\":t=\"max\",e=\"max\"}const[l,n]=(()=>{const{align:t}=this.model;return\"auto\"==t?[void 0,void 0]:(0,d.isArray)(t)?t:[t,t]})(),{width:a,height:o}=this.model;return{width_policy:t,height_policy:e,width:a,height:o,aspect_ratio:i,halign:l,valign:n}}export(t=\"auto\",e=!0){const i=(()=>{switch(t){case\"auto\":case\"png\":return\"canvas\";case\"svg\":return\"svg\"}})(),s=new p.CanvasLayer(i,e),{x:l,y:n,width:a,height:o}=this.bbox;s.resize(a,o);const r=getComputedStyle(this.el).backgroundColor;s.ctx.fillStyle=r,s.ctx.fillRect(l,n,a,o);for(const i of this.child_views){const l=i.export(t,e),{x:n,y:a}=i.bbox;s.ctx.drawImage(l.canvas,n,a)}return s}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{children:this.child_views.map((t=>t.serializable_state()))})}}i.LayoutDOMView=y,y.__name__=\"LayoutDOMView\";class g extends a.UIElement{constructor(t){super(t)}}i.LayoutDOM=g,n=g,g.__name__=\"LayoutDOM\",n.define((t=>{const{Boolean:e,Number:i,Auto:s,Tuple:l,Or:n,Null:a,Nullable:r,Ref:h}=t,_=l(i,i),d=l(i,i,i,i);return{width:[r(i),null],height:[r(i),null],min_width:[r(i),null],min_height:[r(i),null],max_width:[r(i),null],max_height:[r(i),null],margin:[r(n(i,_,d)),null],width_policy:[n(f.SizingPolicy,s),\"auto\"],height_policy:[n(f.SizingPolicy,s),\"auto\"],aspect_ratio:[n(i,s,a),null],flow_mode:[u.FlowMode,\"block\"],sizing_mode:[r(u.SizingMode),null],disabled:[e,!1],align:[n(u.Align,l(u.Align,u.Align),s),\"auto\"],context_menu:[r(h(o.Menu)),null],resizable:[n(e,u.Dimensions),!1]}}))},\n", - " function _(e,s,t,i,r){var n;i();const a=e(1),l=e(257),o=e(362),d=e(19),m=e(59),u=e(32),c=a.__importStar(e(268)),h=c;class _ extends l.UIElementView{constructor(){super(...arguments),this.items=new Map}stylesheets(){return[...super.stylesheets(),c.default]}*children(){yield*super.children(),yield*this.items.values()}async lazy_initialize(){await super.lazy_initialize(),await(0,m.build_views)(this.items,this.model.items)}remove(){(0,m.remove_views)(this.items),super.remove()}render(){super.render(),this.el.classList.add(h[this.model.orientation]);const e=(()=>{const{items:e,reversed:s}=this.model,t=s?(0,u.reverse)(e):e;return(0,u.map)(t,(e=>this.items.get(e)))})();for(const s of e)s.render(),this.shadow_el.appendChild(s.el)}}t.MenuView=_,_.__name__=\"MenuView\";class p extends l.UIElement{constructor(e){super(e)}}t.Menu=p,n=p,p.__name__=\"Menu\",n.define((({Boolean:e,Array:s,Ref:t})=>({items:[s(t(o.MenuItem)),[]],reversed:[e,!1],orientation:[d.Orientation,\"vertical\"]})))},\n", - " function _(e,t,s,n,u){n();const _=e(1),l=e(257),m=_.__importDefault(e(268)),a=_.__importDefault(e(269));class r extends l.UIElementView{stylesheets(){return[...super.stylesheets(),m.default,a.default]}}s.MenuItemView=r,r.__name__=\"MenuItemView\";class c extends l.UIElement{constructor(e){super(e)}}s.MenuItem=c,c.__name__=\"MenuItem\"},\n", - " function _(t,o,e,i,l){i();const n=t(146),r=t(57),h=t(12),{max:u}=Math;class s extends n.Layoutable{constructor(t){super(),this.children=t}_measure(t){return{width:0,height:0}}compute(t={}){const{width:o,height:e}=t;(0,h.assert)(null!=o&&null!=e);const i={width:o,height:e},l=new r.BBox({left:0,top:0,width:o,height:e});let n;if(null!=i.inner){const{left:t,top:l,right:h,bottom:u}=i.inner;n=new r.BBox({left:t,top:l,right:o-h,bottom:e-u})}this.set_geometry(l,n)}_set_geometry(t,o){super._set_geometry(t,o);const e=this.children.map(((t,o)=>{const{layout:e,bbox:i}=o;(0,h.assert)(null!=e);const l=e.measure(i);return{child:o,layout:e,bbox:i,size_hint:l}})),i=Array(e.nrows).fill(null).map((()=>({top:0,bottom:0}))),l=Array(e.ncols).fill(null).map((()=>({left:0,right:0})));e.foreach((({r0:t,c0:o,r1:e,c1:n},{size_hint:r})=>{const{inner:h}=r;null!=h&&(l[o].left=u(l[o].left,h.left),l[n].right=u(l[n].right,h.right),i[t].top=u(i[t].top,h.top),i[e].bottom=u(i[e].bottom,h.bottom))})),e.foreach((({r0:t,c0:o,r1:e,c1:n},{layout:h,size_hint:u,bbox:s})=>{const f=s,g=null==u.inner?void 0:(()=>{var h,s,g,m,c,d;const{inner:b,align:p}=u,a=null===(h=null==p?void 0:p.left)||void 0===h||h,_=null===(s=null==p?void 0:p.right)||void 0===s||s,v=null===(g=null==p?void 0:p.top)||void 0===g||g,w=null===(m=null==p?void 0:p.bottom)||void 0===m||m,y=null!==(c=null==p?void 0:p.fixed_width)&&void 0!==c&&c,x=null!==(d=null==p?void 0:p.fixed_height)&&void 0!==d&&d,{left:B,right:A}=(()=>{if(y){const t=f.width-b.right-b.left;if(a){const e=l[o].left;return{left:e,right:f.width-(e+t)}}if(_){const o=l[n].right;return{left:f.width-(o+t),right:o}}return{left:b.left,right:b.right}}return{left:a?l[o].left:b.left,right:_?l[n].right:b.right}})(),{top:z,bottom:L}=(()=>{if(x){const o=f.height-b.bottom-b.top;if(v){const e=i[t].top;return{top:e,bottom:f.height-(e+o)}}if(w){const t=i[e].bottom;return{top:f.height-(t+o),bottom:t}}return{top:b.top,bottom:b.bottom}}return{top:v?i[t].top:b.top,bottom:w?i[e].bottom:b.bottom}})(),{width:G,height:M}=f;return r.BBox.from_lrtb({left:B,top:z,right:G-A,bottom:M-L})})();h.set_geometry(f,g)}))}}e.GridAlignmentLayout=s,s.__name__=\"GridAlignmentLayout\"},\n", - " function _(e,i,n,r,s){var o;r();const t=e(365),l=e(233),c=e(257);class d extends t.CSSGridBoxView{connect_signals(){super.connect_signals();const{children:e,rows:i,cols:n}=this.model.properties;this.on_change(e,(()=>this.update_children())),this.on_change([i,n],(()=>this.invalidate_layout()))}get _children(){return this.model.children}get _rows(){return this.model.rows}get _cols(){return this.model.cols}}n.GridBoxView=d,d.__name__=\"GridBoxView\";class _ extends t.CSSGridBox{constructor(e){super(e)}}n.GridBox=_,o=_,_.__name__=\"GridBox\",o.prototype.default_view=d,o.define((({Array:e,Nullable:i})=>({children:[e((0,l.GridChild)(c.UIElement)),[]],rows:[i(l.TracksSizing),null],cols:[i(l.TracksSizing),null]})))},\n", - " function _(n,i,s,t,e){var o;t();const a=n(360),l=n(363),r=n(233),c=n(56),_=n(228),u=n(32),d=n(8),{max:p}=Math;class g extends a.LayoutDOMView{connect_signals(){super.connect_signals();const{spacing:n}=this.model.properties;this.on_change(n,(()=>this.invalidate_layout()))}get child_models(){return this._children.map((([n])=>n))}_intrinsic_display(){return{inner:this.model.flow_mode,outer:\"grid\"}}_update_layout(){super._update_layout();const n={},[i,s]=(()=>{const{spacing:n}=this.model;return(0,d.isNumber)(n)?[n,n]:n})();n.row_gap=(0,c.px)(i),n.column_gap=(0,c.px)(s);let t=0,e=0;const o=new _.Container;for(const[[,n,i,s=1,l=1],r]of(0,u.enumerate)(this._children)){const c=this.child_views[r];t=p(t,n+s),e=p(e,i+l);const _={};if(_.grid_row_start=`${n+1}`,_.grid_row_end=`span ${s}`,_.grid_column_start=`${i+1}`,_.grid_column_end=`span ${l}`,c.style.append(\":host\",_),c instanceof a.LayoutDOMView&&null!=c.layout){const t=n,e=i,a=n+s-1,r=i+l-1;o.add({r0:t,c0:e,r1:a,c1:r},c)}}const{_rows:r,_cols:g}=this;function h(n,i){if(n instanceof Map)for(const[s,t]of n.entries())(0,d.isString)(t)?i[s].size=t:i[s]=t;else if((0,d.isArray)(n))for(const[s,t]of(0,u.enumerate)(n))(0,d.isString)(s)?i[t].size=s:i[t]=s;else if(null!=n)for(const s of i)(0,d.isString)(n)?s.size=n:(s.size=n.size,s.align=n.align)}r instanceof Map?t=p(t,...r.keys()):(0,d.isArray)(r)&&(t=p(t,r.length)),g instanceof Map?e=p(e,...g.keys()):(0,d.isArray)(g)&&(e=p(e,g.length));const f=Array(t).fill(null).map((()=>({}))),m=Array(e).fill(null).map((()=>({})));h(r,f),h(g,m);for(const[[,n,i],s]of(0,u.enumerate)(this._children)){const t=this.child_views[s],{halign:e,valign:o}=t.box_sizing();t.style.append(\":host\",{justify_self:null!=e?e:m[i].align,align_self:null!=o?o:f[n].align})}const y=\"auto\";n.grid_template_rows=f.map((({size:n})=>null!=n?n:y)).join(\" \"),n.grid_template_columns=m.map((({size:n})=>null!=n?n:y)).join(\" \"),this.style.append(\":host\",n),0!=o.size?(this.layout=new l.GridAlignmentLayout(o),this.layout.set_sizing()):delete this.layout}}s.CSSGridBoxView=g,g.__name__=\"CSSGridBoxView\";class h extends a.LayoutDOM{constructor(n){super(n)}}s.CSSGridBox=h,o=h,h.__name__=\"CSSGridBox\",o.define((()=>({spacing:[r.GridSpacing,0]})))},\n", - " function _(e,t,s,l,i){var c;l();const h=e(1),d=e(360),o=e(257),n=e(56),a=h.__importDefault(e(367));class _ extends d.LayoutDOMView{stylesheets(){return[...super.stylesheets(),a.default]}connect_signals(){super.connect_signals();const{child:e}=this.model.properties;this.on_change(e,(()=>this.update_children()));const{checkable:t,disabled:s}=this.model.properties;this.on_change(t,(()=>{(0,n.display)(this.checkbox_el,this.model.checkable)})),this.on_change(s,(()=>{this.checkbox_el.checked=!this.model.disabled}))}get child_models(){return[this.model.child]}render(){super.render();const{checkable:e,disabled:t,title:s}=this.model;this.checkbox_el=(0,n.input)({type:\"checkbox\",checked:!t}),this.checkbox_el.addEventListener(\"change\",(()=>{this.model.disabled=!this.checkbox_el.checked})),(0,n.display)(this.checkbox_el,e);const l=(0,n.legend)({},this.checkbox_el,s),i=this.child_views.map((e=>e.el));this.fieldset_el=(0,n.fieldset)({},l,...i),this.shadow_el.appendChild(this.fieldset_el)}_update_children(){const e=this.child_views.map((e=>e.el));this.fieldset_el.append(...e)}}s.GroupBoxView=_,_.__name__=\"GroupBoxView\";class r extends d.LayoutDOM{constructor(e){super(e)}}s.GroupBox=r,c=r,r.__name__=\"GroupBox\",c.prototype.default_view=_,c.define((({Boolean:e,String:t,Nullable:s,Ref:l})=>({title:[s(t),null],child:[l(o.UIElement)],checkable:[e,!1]})))},\n", - " function _(d,a,e,l,i){l(),e.default=\"legend{display:flex;gap:0.5em;padding:0 calc(var(--padding-horizontal) / 2);}fieldset{border:1px solid #ccc;}\"},\n", - " function _(e,n,l,t,s){var i;t();const o=e(365),c=e(233),r=e(257),a=e(20),d=(0,a.Struct)({child:(0,a.Ref)(r.UIElement),col:(0,a.Opt)(c.Index),span:(0,a.Opt)(c.Span)});class _ extends o.CSSGridBoxView{connect_signals(){super.connect_signals();const{children:e,cols:n}=this.model.properties;this.on_change(e,(()=>this.update_children())),this.on_change(n,(()=>this.invalidate_layout()))}get _children(){return this.model.children.map((({child:e,col:n,span:l},t)=>[e,0,null!=n?n:t,1,null!=l?l:1]))}get _rows(){return null}get _cols(){return this.model.cols}}l.HBoxView=_,_.__name__=\"HBoxView\";class h extends o.CSSGridBox{constructor(e){super(e)}}l.HBox=h,i=h,h.__name__=\"HBox\",i.prototype.default_view=_,i.define((({Array:e,Nullable:n})=>({children:[e(d),[]],cols:[n(c.TracksSizing),null]})))},\n", - " function _(e,o,t,s,_){var n;s();const r=e(359);class c extends r.FlexBoxView{constructor(){super(...arguments),this._direction=\"row\"}}t.RowView=c,c.__name__=\"RowView\";class w extends r.FlexBox{constructor(e){super(e)}}t.Row=w,n=w,w.__name__=\"Row\",n.prototype.default_view=c},\n", - " function _(e,l,o,t,r){var s;t();const a=e(360),c=e(257),i=e(19);class n extends a.LayoutDOMView{stylesheets(){return[...super.stylesheets()]}connect_signals(){super.connect_signals();const{child:e,horizontal_scrollbar:l,vertical_scrollbar:o}=this.model.properties;this.on_change(e,(()=>this.update_children())),this.on_change([l,o],(()=>this.invalidate_layout()))}get child_models(){return[this.model.child]}_update_layout(){function e(e){switch(e){case\"auto\":return\"auto\";case\"visible\":return\"scroll\";case\"hidden\":return\"hidden\"}}super._update_layout();const{horizontal_scrollbar:l,vertical_scrollbar:o}=this.model;this.style.append(\":host\",{overflow_x:e(l),overflow_y:e(o)})}}o.ScrollBoxView=n,n.__name__=\"ScrollBoxView\";class _ extends a.LayoutDOM{constructor(e){super(e)}}o.ScrollBox=_,s=_,_.__name__=\"ScrollBox\",s.prototype.default_view=n,s.define((({Ref:e})=>({child:[e(c.UIElement)],horizontal_scrollbar:[i.ScrollbarPolicy,\"auto\"],vertical_scrollbar:[i.ScrollbarPolicy,\"auto\"]})))},\n", - " function _(t,e,a,o,_){var r;o();const s=t(360);class c extends s.LayoutDOMView{constructor(){super(...arguments),this._auto_width=\"auto\",this._auto_height=\"auto\"}get child_models(){return[]}}a.SpacerView=c,c.__name__=\"SpacerView\";class u extends s.LayoutDOM{constructor(t){super(t)}}a.Spacer=u,r=u,u.__name__=\"Spacer\",r.prototype.default_view=c},\n", - " function _(e,n,l,a,t){var o;a();const s=e(50),c=e(257);class d extends s.Model{constructor(e){super(e)}}l.TabPanel=d,o=d,d.__name__=\"TabPanel\",o.define((({Boolean:e,String:n,Ref:l})=>({title:[n,\"\"],child:[l(c.UIElement)],closable:[e,!1],disabled:[e,!1]})))},\n", - " function _(e,t,s,a,i){var o;a();const d=e(1),l=e(56),n=e(10),c=e(228),h=e(19),r=e(360),_=e(372),u=e(363),p=d.__importStar(e(374)),m=p,v=d.__importDefault(e(269));class b extends r.LayoutDOMView{connect_signals(){super.connect_signals();const{tabs:e,active:t}=this.model.properties;this.on_change(e,(()=>{this._update_headers(),this.update_children()})),this.on_change(t,(()=>{this.update_active()}))}stylesheets(){return[...super.stylesheets(),p.default,v.default]}get child_models(){return this.model.tabs.map((e=>e.child))}_intrinsic_display(){return{inner:this.model.flow_mode,outer:\"grid\"}}_update_layout(){super._update_layout();const e=this.model.tabs_location;this.class_list.remove([...h.Location].map((e=>m[e]))),this.class_list.add(m[e]);const t=new c.Container;for(const e of this.child_views)e.style.append(\":host\",{grid_area:\"stack\"}),e instanceof r.LayoutDOMView&&null!=e.layout&&t.add({r0:0,c0:0,r1:1,c1:1},e);0!=t.size?(this.layout=new u.GridAlignmentLayout(t),this.layout.set_sizing()):delete this.layout}_after_layout(){super._after_layout();const{child_views:e}=this;for(const t of e)(0,l.hide)(t.el);const{active:t}=this.model;if(t in e){const s=e[t];(0,l.show)(s.el)}}render(){super.render(),this.header_el=(0,l.div)({class:m.header}),this.shadow_el.append(this.header_el),this._update_headers()}_update_headers(){const{active:e}=this.model,t=this.model.tabs.map(((t,s)=>{const a=(0,l.div)({class:[m.tab,s==e?m.active:null],tabIndex:0},t.title);if(a.addEventListener(\"click\",(e=>{this.model.disabled||e.target==e.currentTarget&&this.change_active(s)})),t.closable){const e=(0,l.div)({class:m.close});e.addEventListener(\"click\",(e=>{if(e.target==e.currentTarget){this.model.tabs=(0,n.remove_at)(this.model.tabs,s);const e=this.model.tabs.length;this.model.active>e-1&&(this.model.active=e-1)}})),a.appendChild(e)}return(this.model.disabled||t.disabled)&&a.classList.add(m.disabled),a}));this.header_els=t,(0,l.empty)(this.header_el),this.header_el.append(...t)}change_active(e){e!=this.model.active&&(this.model.active=e)}update_active(){const e=this.model.active,{header_els:t}=this;for(const e of t)e.classList.remove(m.active);e in t&&t[e].classList.add(m.active);const{child_views:s}=this;for(const e of s)(0,l.hide)(e.el);e in s&&(0,l.show)(s[e].el)}}s.TabsView=b,b.__name__=\"TabsView\";class f extends r.LayoutDOM{constructor(e){super(e)}}s.Tabs=f,o=f,f.__name__=\"Tabs\",o.prototype.default_view=b,o.define((({Int:e,Array:t,Ref:s})=>({tabs:[t(s(_.TabPanel)),[]],tabs_location:[h.Location,\"above\"],active:[e,0]})))},\n", - " function _(e,r,o,t,a){t(),o.above=\"bk-above\",o.below=\"bk-below\",o.left=\"bk-left\",o.right=\"bk-right\",o.header=\"bk-header\",o.tab=\"bk-tab\",o.active=\"bk-active\",o.close=\"bk-close\",o.disabled=\"bk-disabled\",o.default=':host{display:grid;}:host(.bk-above){grid-template:\"header\" max-content \"stack\" 1fr / 1fr;}:host(.bk-below){grid-template:\"stack\" 1fr \"header\" max-content / 1fr;}:host(.bk-left){grid-template:\"header stack\" 1fr / max-content 1fr;}:host(.bk-right){grid-template:\"stack header\" 1fr / 1fr max-content;}.bk-header{grid-area:\"header\";display:flex;flex-wrap:nowrap;align-items:stretch;user-select:none;-webkit-user-select:none;}:host(.bk-above) .bk-header,:host(.bk-below) .bk-header{flex-direction:row;}:host(.bk-left) .bk-header,:host(.bk-right) .bk-header{flex-direction:column;}:host(.bk-above) .bk-header{border-bottom:1px solid #e6e6e6;}:host(.bk-right) .bk-header{border-left:1px solid #e6e6e6;}:host(.bk-below) .bk-header{border-top:1px solid #e6e6e6;}:host(.bk-left) .bk-header{border-right:1px solid #e6e6e6;}.bk-tab{padding:4px 8px;border:solid transparent;outline:0;outline-offset:-5px;white-space:nowrap;cursor:pointer;text-align:center;}.bk-tab:hover{background-color:#f2f2f2;}.bk-tab:focus,.bk-tab:active{outline:1px dotted #ccc;}.bk-tab.bk-active{color:#4d4d4d;background-color:white;border-color:#e6e6e6;}.bk-tab .bk-close{margin-left:10px;}.bk-tab.bk-disabled{cursor:not-allowed;pointer-events:none;opacity:0.65;}:host(.bk-above) .bk-tab{border-width:3px 1px 0px 1px;border-radius:var(--border-radius) var(--border-radius) 0 0;}:host(.bk-right) .bk-tab{border-width:1px 3px 1px 0px;border-radius:0 var(--border-radius) var(--border-radius) 0;}:host(.bk-below) .bk-tab{border-width:0px 1px 3px 1px;border-radius:0 0 var(--border-radius) var(--border-radius);}:host(.bk-left) .bk-tab{border-width:1px 0px 1px 3px;border-radius:var(--border-radius) 0 0 var(--border-radius);}.bk-close{display:inline-block;vertical-align:middle;width:14px;height:14px;cursor:pointer;background-color:gray;mask-image:var(--bokeh-icon-x);mask-size:contain;mask-repeat:no-repeat;-webkit-mask-image:var(--bokeh-icon-x);-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;}.bk-close:hover{background-color:red;}'},\n", - " function _(e,n,t,r,s){var l;r();const i=e(365),o=e(233),c=e(257),a=e(20),d=(0,a.Struct)({child:(0,a.Ref)(c.UIElement),row:(0,a.Opt)(o.Index),span:(0,a.Opt)(o.Span)});class _ extends i.CSSGridBoxView{connect_signals(){super.connect_signals();const{children:e,rows:n}=this.model.properties;this.on_change(e,(()=>this.update_children())),this.on_change(n,(()=>this.invalidate_layout()))}get _children(){return this.model.children.map((({child:e,row:n,span:t},r)=>[e,null!=n?n:r,0,null!=t?t:1,1]))}get _rows(){return this.model.rows}get _cols(){return null}}t.VBoxView=_,_.__name__=\"VBoxView\";class h extends i.CSSGridBox{constructor(e){super(e)}}t.VBox=h,l=h,h.__name__=\"VBox\",l.prototype.default_view=_,l.define((({Array:e,Nullable:n})=>({children:[e(d),[]],rows:[n(o.TracksSizing),null]})))},\n", - " function _(i,n,c,e,o){e(),o(\"Menu\",i(361).Menu),o(\"Action\",i(377).Action),o(\"CheckAction\",i(379).CheckAction),o(\"Section\",i(380).Section),o(\"Divider\",i(381).Divider)},\n", - " function _(e,n,t,i,l){var s;i();const c=e(362),d=e(361),o=e(378),r=e(56);class a extends c.MenuItemView{_click(){}render(){super.render();const{label:e,description:n}=this.model;this.el.tabIndex=0,this.el.title=null!=n?n:\"\",this.el.appendChild((0,r.span)(e)),this.el.addEventListener(\"click\",(()=>{this._click()})),this.el.addEventListener(\"keydown\",(e=>{\"Enter\"==e.key&&this._click()}))}}t.ActionView=a,a.__name__=\"ActionView\";class u extends c.MenuItem{constructor(e){super(e)}}t.Action=u,s=u,u.__name__=\"Action\",s.prototype.default_view=a,s.define((({String:e,Nullable:n,Ref:t})=>({icon:[n(t(o.Icon)),null],label:[e],description:[n(e),null],menu:[n(t(d.Menu)),null]})))},\n", - " function _(e,n,o,c,s){var _;c();const t=e(50),i=e(55);class r extends i.DOMComponentView{}o.IconView=r,r.__name__=\"IconView\";class a extends t.Model{constructor(e){super(e)}}o.Icon=a,_=a,a.__name__=\"Icon\",_.define((({Number:e,Or:n,CSSLength:o})=>({size:[n(e,o),\"1em\"]})))},\n", - " function _(e,c,n,t,o){var i;t();const _=e(377);class s extends _.ActionView{}n.CheckActionView=s,s.__name__=\"CheckActionView\";class a extends _.Action{constructor(e){super(e)}}n.CheckAction=a,i=a,a.__name__=\"CheckAction\",i.prototype.default_view=s,i.define((({Boolean:e})=>({checked:[e,!1]})))},\n", - " function _(e,n,t,r,i){var s;r();const c=e(362);class o extends c.MenuItemView{render(){super.render()}}t.SectionView=o,o.__name__=\"SectionView\";class _ extends c.MenuItem{constructor(e){super(e)}}t.Section=_,s=_,_.__name__=\"Section\",s.prototype.default_view=o,s.define((({Array:e,Ref:n})=>({items:[e(n(c.MenuItem)),[]]})))},\n", - " function _(e,i,r,t,s){var d;t();const n=e(1),_=e(362),a=n.__importStar(e(268));class c extends _.MenuItemView{render(){super.render(),this.el.classList.add(a.divider)}}r.DividerView=c,c.__name__=\"DividerView\";class o extends _.MenuItem{constructor(e){super(e)}}r.Divider=o,d=o,o.__name__=\"Divider\",d.prototype.default_view=c},\n", - " function _(t,a,i,e,M){e();var T=t(149);M(\"MathText\",T.MathText),M(\"Ascii\",T.Ascii),M(\"MathML\",T.MathML),M(\"TeX\",T.TeX),M(\"PlainText\",t(156).PlainText)},\n", - " function _(r,o,t,e,n){e(),n(\"CustomJSTransform\",r(384).CustomJSTransform),n(\"Dodge\",r(385).Dodge),n(\"Interpolator\",r(387).Interpolator),n(\"Jitter\",r(388).Jitter),n(\"LinearInterpolator\",r(390).LinearInterpolator),n(\"StepInterpolator\",r(391).StepInterpolator),n(\"Transform\",r(86).Transform)},\n", - " function _(r,t,s,n,e){var a;n();const u=r(86),o=r(9),m=r(38);class _ extends u.Transform{constructor(r){super(r)}get names(){return(0,o.keys)(this.args)}get values(){return(0,o.values)(this.args)}_make_transform(r,t){return new Function(...this.names,r,(0,m.use_strict)(t))}get scalar_transform(){return this._make_transform(\"x\",this.func)}get vector_transform(){return this._make_transform(\"xs\",this.v_func)}compute(r){return this.scalar_transform(...this.values,r)}v_compute(r){return this.vector_transform(...this.values,r)}}s.CustomJSTransform=_,a=_,_.__name__=\"CustomJSTransform\",a.define((({Unknown:r,String:t,Dict:s})=>({args:[s(r),{}],func:[t,\"\"],v_func:[t,\"\"]})))},\n", - " function _(e,n,r,o,s){var t;o();const u=e(386);class a extends u.RangeTransform{constructor(e){super(e)}_compute(e){return e+this.value}}r.Dodge=a,t=a,a.__name__=\"Dodge\",t.define((({Number:e})=>({value:[e,0]})))},\n", - " function _(e,n,t,r,a){var s;r();const c=e(86),o=e(87),i=e(96),u=e(23),h=e(8),l=e(12);class g extends c.Transform{constructor(e){super(e)}v_compute(e){let n;this.range instanceof i.FactorRange?n=this.range.v_synthetic(e):(0,h.isArrayableOf)(e,h.isNumber)?n=e:(0,l.unreachable)();const t=new((0,u.infer_type)(n))(n.length);for(let e=0;e({range:[n(e(o.Range)),null]})))},\n", - " function _(t,e,r,n,s){var o;n();const i=t(86),a=t(99),h=t(23),l=t(10),d=t(8);class c extends i.Transform{constructor(t){super(t),this._sorted_dirty=!0}connect_signals(){super.connect_signals(),this.connect(this.change,(()=>this._sorted_dirty=!0))}v_compute(t){const e=new((0,h.infer_type)(t))(t.length);for(let r=0;ro*(e[t]-e[r]))),this._x_sorted=new((0,h.infer_type)(e))(n),this._y_sorted=new((0,h.infer_type)(r))(n);for(let t=0;t({x:[o(r,s(e))],y:[o(r,s(e))],data:[i(n(a.ColumnarDataSource)),null],clip:[t,!0]})))},\n", - " function _(t,e,n,r,i){var s;r();const o=t(386),a=t(96),u=t(389),_=t(19),h=t(13),m=t(262);class l extends o.RangeTransform{constructor(t){super(t),this._previous_offsets=null}initialize(){var t,e;super.initialize(),this._generator=null!==(e=null===(t=this.random_generator)||void 0===t?void 0:t.generator())&&void 0!==e?e:new m.SystemRandom}v_compute(t){const e=(()=>this.range instanceof a.FactorRange?this.range.v_synthetic(t):t)(),n=(()=>{var t;const n=e.length;return(null===(t=this._previous_offsets)||void 0===t?void 0:t.length)!=n&&(this._previous_offsets=this._v_compute(n)),this._previous_offsets})();return(0,h.map)(n,((t,n)=>t+e[n]))}_compute(){const{mean:t,width:e}=this;switch(this.distribution){case\"uniform\":return this._generator.uniform(t,e);case\"normal\":return this._generator.normal(t,e)}}_v_compute(t){const{mean:e,width:n}=this;switch(this.distribution){case\"uniform\":return this._generator.uniforms(e,n,t);case\"normal\":return this._generator.normals(e,n,t)}}}n.Jitter=l,s=l,l.__name__=\"Jitter\",s.define((({Number:t})=>({mean:[t,0],width:[t,1],distribution:[_.Distribution,\"uniform\"]}))),s.internal((({Nullable:t,Ref:e})=>({random_generator:[t(e(u.RandomGenerator)),null]})))},\n", - " function _(n,e,o,r,t){r();const a=n(50);class s extends a.Model{constructor(n){super(n)}}o.RandomGenerator=s,s.__name__=\"RandomGenerator\"},\n", - " function _(t,s,_,r,e){r();const i=t(10),o=t(387);class n extends o.Interpolator{constructor(t){super(t)}compute(t){if(this.sort(!1),this.clip){if(tthis._x_sorted[this._x_sorted.length-1])return NaN}else{if(tthis._x_sorted[this._x_sorted.length-1])return this._y_sorted[this._y_sorted.length-1]}if(t==this._x_sorted[0])return this._y_sorted[0];const s=(0,i.find_last_index)(this._x_sorted,(s=>sthis._x_sorted[this._x_sorted.length-1])return NaN}else{if(tthis._x_sorted[this._x_sorted.length-1])return this._y_sorted[this._y_sorted.length-1]}let e;switch(this.mode){case\"after\":e=(0,d.find_last_index)(this._x_sorted,(e=>t>=e));break;case\"before\":e=(0,d.find_index)(this._x_sorted,(e=>t<=e));break;case\"center\":{const s=(0,d.map)(this._x_sorted,(e=>Math.abs(e-t))),r=(0,d.min)(s);e=(0,d.find_index)(s,(t=>r===t));break}default:throw new Error(`unknown mode: ${this.mode}`)}return-1!=e?this._y_sorted[e]:NaN}}s.StepInterpolator=h,_=h,h.__name__=\"StepInterpolator\",_.define((()=>({mode:[n.StepMode,\"after\"]})))},\n", - " function _(p,o,t,i,a){i(),a(\"MapOptions\",p(393).MapOptions),a(\"GMapOptions\",p(393).GMapOptions),a(\"GMapPlot\",p(393).GMapPlot),a(\"GMap\",p(401).GMap),a(\"Plot\",p(394).Plot),a(\"GridPlot\",p(402).GridPlot),a(\"Figure\",p(403).Figure)},\n", - " function _(e,t,a,n,o){var p,s,l;n();const _=e(394),i=e(19),r=e(50),c=e(88),d=e(400);o(\"GMapPlotView\",d.GMapPlotView);class u extends r.Model{constructor(e){super(e)}}a.MapOptions=u,p=u,u.__name__=\"MapOptions\",p.define((({Int:e,Number:t})=>({lat:[t],lng:[t],zoom:[e,12]})));class M extends u{constructor(e){super(e)}}a.GMapOptions=M,s=M,M.__name__=\"GMapOptions\",s.define((({Boolean:e,Int:t,String:a,Nullable:n})=>({map_type:[i.MapType,\"roadmap\"],scale_control:[e,!1],styles:[n(a),null],tilt:[t,45]})));class m extends _.Plot{constructor(e){super(e),this.use_map=!0}}a.GMapPlot=m,l=m,m.__name__=\"GMapPlot\",l.prototype.default_view=d.GMapPlotView,l.define((({String:e,Bytes:t,Ref:a})=>({map_options:[a(M)],api_key:[t],api_version:[e,\"weekly\"]}))),l.override({x_range:()=>new c.Range1d,y_range:()=>new c.Range1d,background_fill_alpha:0})},\n", - " function _(e,t,o,r,n){var a;r();const l=e(1),i=l.__importStar(e(78)),s=l.__importStar(e(17)),_=e(15),d=e(19),c=e(10),h=e(43),u=e(8),g=e(360),b=e(159),f=e(356),m=e(73),p=e(142),w=e(89),y=e(256),v=e(87),x=e(85),S=e(104),R=e(74),A=e(200),D=e(199),L=e(264),O=e(93),P=e(395);n(\"PlotView\",P.PlotView);class T extends g.LayoutDOM{constructor(e){super(e),this.use_map=!1,this.reset=new _.Signal0(this,\"reset\")}add_layout(e,t=\"center\"){const o=this.properties[t].get_value();this.setv({[t]:[...o,e]})}remove_layout(e){const t=t=>{(0,c.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 A.DataRenderer))}add_renderers(...e){this.renderers=[...this.renderers,...e]}add_glyph(e,t=new S.ColumnDataSource,o={}){const r=new D.GlyphRenderer(Object.assign(Object.assign({},o),{data_source:t,glyph:e}));return this.add_renderers(r),r}add_tools(...e){const t=e.map((e=>e instanceof L.Tool?e:L.Tool.from_string(e)));this.toolbar.tools=[...this.toolbar.tools,...t]}remove_tools(...e){this.toolbar.tools=[...(0,h.difference)(new Set(this.toolbar.tools),new Set(e))]}get panels(){return[...this.side_panels,...this.center]}get side_panels(){const{above:e,below:t,left:o,right:r}=this;return(0,c.concat)([e,t,o,r])}}o.Plot=T,a=T,T.__name__=\"Plot\",a.prototype.default_view=P.PlotView,a.mixins([[\"outline_\",i.Line],[\"background_\",i.Fill],[\"border_\",i.Fill]]),a.define((({Boolean:e,Number:t,String:o,Array:r,Dict:n,Or:a,Ref:l,Null:i,Nullable:_,Struct:c,Opt:h})=>({toolbar:[l(y.Toolbar),()=>new y.Toolbar],toolbar_location:[_(d.Location),\"right\"],toolbar_sticky:[e,!0],toolbar_inner:[e,!1],frame_width:[_(t),null],frame_height:[_(t),null],frame_align:[a(e,c({left:h(e),right:h(e),top:h(e),bottom:h(e)})),!0],title:[a(l(p.Title),o,i),\"\",{convert:e=>(0,u.isString)(e)?new p.Title({text:e}):e}],title_location:[_(d.Location),\"above\"],above:[r(a(l(m.Annotation),l(b.Axis))),[]],below:[r(a(l(m.Annotation),l(b.Axis))),[]],left:[r(a(l(m.Annotation),l(b.Axis))),[]],right:[r(a(l(m.Annotation),l(b.Axis))),[]],center:[r(a(l(m.Annotation),l(f.Grid))),[]],renderers:[r(l(R.Renderer)),[]],x_range:[l(v.Range),()=>new O.DataRange1d],y_range:[l(v.Range),()=>new O.DataRange1d],x_scale:[l(x.Scale),()=>new w.LinearScale],y_scale:[l(x.Scale),()=>new w.LinearScale],extra_x_ranges:[n(l(v.Range)),{}],extra_y_ranges:[n(l(v.Range)),{}],extra_x_scales:[n(l(x.Scale)),{}],extra_y_scales:[n(l(x.Scale)),{}],lod_factor:[t,10],lod_interval:[t,300],lod_threshold:[_(t),2e3],lod_timeout:[t,500],hidpi:[e,!0],output_backend:[d.OutputBackend,\"canvas\"],min_border:[_(t),5],min_border_top:[_(t),null],min_border_left:[_(t),null],min_border_bottom:[_(t),null],min_border_right:[_(t),null],inner_width:[t,s.unset,{readonly:!0}],inner_height:[t,s.unset,{readonly:!0}],outer_width:[t,s.unset,{readonly:!0}],outer_height:[t,s.unset,{readonly:!0}],match_aspect:[e,!1],aspect_scale:[t,1],reset_policy:[d.ResetPolicy,\"standard\"],hold_render:[e,!1]}))),a.override({width:600,height:600,outline_line_color:\"#e5e5e5\",border_fill_color:\"#ffffff\",background_fill_color:\"#ffffff\"})},\n", - " function _(e,t,i,s,n){s();const a=e(1),r=e(157),o=e(291),l=e(265),_=e(360),h=e(73),d=e(142),c=e(159),u=e(255),p=e(93),g=e(52),m=e(59),b=e(75),v=e(18),f=e(52),w=e(396),y=e(8),x=e(10),z=e(32),k=e(260),S=e(227),M=e(229),$=e(228),q=e(144),V=e(57),O=e(152),R=e(397),j=e(398),P=e(28),T=e(56),C=a.__importDefault(e(399)),{max:B}=Math;class A extends _.LayoutDOMView{constructor(){super(...arguments),this._computed_style=new T.InlineStyleSheet,this._outer_bbox=new V.BBox,this._inner_bbox=new V.BBox,this._needs_paint=!0,this._invalidated_painters=new Set,this._invalidate_all=!0,this.renderer_views=new Map,this.tool_views=new Map,this._needs_notify=!1}get canvas(){return this.canvas_view}stylesheets(){return[...super.stylesheets(),C.default,this._computed_style]}get toolbar_panel(){return null!=this._toolbar?this.renderer_view(this._toolbar):void 0}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 auto_ranged_renderers(){return this.model.renderers.map((e=>this.renderer_view(e))).filter(p.is_auto_ranged)}get base_font_size(){const e=getComputedStyle(this.el).fontSize,t=(0,O.parse_css_font_size)(e);if(null!=t){const{value:e,unit:i}=t;if(\"px\"==i)return e}return null}*children(){yield*super.children(),yield*this.renderer_views.values(),yield*this.tool_views.values(),yield this.canvas}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=Math.max(this._is_paused-1,0),0!=this._is_paused||e||this.request_paint(\"everything\")}notify_finished_after_paint(){this._needs_notify=!0}request_render(){this.request_paint(\"everything\")}request_paint(e){this.invalidate_painters(e),this.schedule_paint()}invalidate_painters(e){if(\"everything\"==e)this._invalidate_all=!0;else if((0,y.isArray)(e))for(const t of e)this._invalidated_painters.add(t);else this._invalidated_painters.add(e)}schedule_paint(){if(!this.is_paused){const e=this.throttled_paint();this._ready=this._ready.then((()=>e))}}request_layout(){this.request_paint(\"everything\")}reset(){\"standard\"==this.model.reset_policy&&(this.state.clear(),this.reset_range(),this.reset_selection()),this.model.trigger_event(new g.Reset)}remove(){for(const e of this.frame.ranges.values())e.plots.delete(this);(0,m.remove_views)(this.renderer_views),(0,m.remove_views)(this.tool_views),this.canvas_view.remove(),super.remove()}render(){super.render(),this.shadow_el.appendChild(this.canvas_view.el),this.canvas_view.render()}initialize(){this.pause(),super.initialize(),this.lod_started=!1,this.visuals=new b.Visuals(this),this._initial_state={selection:new Map},this.frame=new r.CartesianFrame(this.model.x_scale,this.model.y_scale,this.model.x_range,this.model.y_range,this.model.extra_x_ranges,this.model.extra_y_ranges,this.model.extra_x_scales,this.model.extra_y_scales);for(const e of this.frame.ranges.values())e.plots.add(this);this._range_manager=new R.RangeManager(this),this._state_manager=new j.StateManager(this,this._initial_state),this.throttled_paint=(0,w.throttle)((()=>{this._removed||this.repaint()}),1e3/60);const{title_location:e,title:t}=this.model;null!=e&&null!=t&&(this._title=t instanceof d.Title?t:new d.Title({text:t}));const{toolbar_location:i,toolbar_inner:s,toolbar:n}=this.model;null!=i&&(this._toolbar=new u.ToolbarPanel({toolbar:n}),n.location=i,n.inner=s)}async lazy_initialize(){await super.lazy_initialize();const{hidpi:e,output_backend:t}=this.model,i=new o.Canvas({hidpi:e,output_backend:t});this.canvas_view=await(0,m.build_view)(i,{parent:this}),this.canvas_view.plot_views=[this],await this.build_tool_views(),await this.build_renderer_views(),this._range_manager.update_dataranges()}box_sizing(){const e=super.box_sizing(),{width_policy:t,height_policy:i}=e,s=a.__rest(e,[\"width_policy\",\"height_policy\"]),{frame_width:n,frame_height:r}=this.model;return Object.assign(Object.assign({},s),{width_policy:null!=n&&\"auto\"==t?\"fit\":t,height_policy:null!=r&&\"auto\"==i?\"fit\":i})}_intrinsic_display(){return{inner:this.model.flow_mode,outer:\"grid\"}}_update_layout(){var e,t,i,s,n;super._update_layout(),this._invalidate_all=!0,this._needs_paint=!0;const a=new M.BorderLayout,{frame_align:r}=this.model;if(a.aligns=(()=>{if((0,y.isBoolean)(r))return{left:r,right:r,top:r,bottom:r};{const{left:e=!0,right:t=!0,top:i=!0,bottom:s=!0}=r;return{left:e,right:t,top:i,bottom:s}}})(),a.set_sizing({width_policy:\"max\",height_policy:\"max\"}),this.visuals.outline_line.doit){const e=this.visuals.outline_line.line_width.get_value();a.center_border_width=e}const o=(0,x.copy)(this.model.above),l=(0,x.copy)(this.model.below),_=(0,x.copy)(this.model.left),c=(0,x.copy)(this.model.right),p=[],g=[],m=[],b=[],v=(e,t=!1)=>{switch(e){case\"above\":return t?p:o;case\"below\":return t?g:l;case\"left\":return t?m:_;case\"right\":return t?b:c}},{title_location:f}=this.model;if(null!=f&&null!=this._title&&v(f).push(this._title),null!=this._toolbar){const{location:e}=this._toolbar.toolbar;if(this.model.toolbar_inner){v(e,!0).push(this._toolbar)}else{const t=v(e);let i=!0;if(this.model.toolbar_sticky)for(let s=0;s{var i;const s=this.renderer_view(t);return s.panel=new q.Panel(e),null===(i=s.update_layout)||void 0===i||i.call(s),s.layout},z=(e,t)=>{const i=\"above\"==e||\"below\"==e,s=[];for(const n of t)if((0,y.isArray)(n)){const t=n.map((t=>{const s=w(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 a;i?(a=new $.Row(t),a.set_sizing({width_policy:\"max\",height_policy:\"min\"})):(a=new $.Column(t),a.set_sizing({width_policy:\"min\",height_policy:\"max\"})),a.absolute=!0,s.push(a)}else s.push(w(e,n));return s},k=null!==(e=this.model.min_border)&&void 0!==e?e:0;a.min_border={left:null!==(t=this.model.min_border_left)&&void 0!==t?t:k,top:null!==(i=this.model.min_border_top)&&void 0!==i?i:k,right:null!==(s=this.model.min_border_right)&&void 0!==s?s:k,bottom:null!==(n=this.model.min_border_bottom)&&void 0!==n?n:k};const V=new S.NodeLayout,O=new S.VStack,R=new S.VStack,j=new S.HStack,P=new S.HStack,T=new S.VStack,C=new S.VStack,B=new S.HStack,A=new S.HStack;V.absolute=!0,O.absolute=!0,R.absolute=!0,j.absolute=!0,P.absolute=!0,T.absolute=!0,C.absolute=!0,B.absolute=!0,A.absolute=!0,V.children=this.model.center.filter((e=>e instanceof h.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:H,frame_height:L}=this.model;V.set_sizing(Object.assign(Object.assign({},null!=H?{width_policy:\"fixed\",width:H}:{width_policy:\"fit\"}),null!=L?{height_policy:\"fixed\",height:L}:{height_policy:\"fit\"})),V.on_resize((e=>this.frame.set_geometry(e))),O.children=(0,x.reversed)(z(\"above\",o)),R.children=z(\"below\",l),j.children=(0,x.reversed)(z(\"left\",_)),P.children=z(\"right\",c),T.children=z(\"above\",p),C.children=z(\"below\",g),B.children=z(\"left\",m),A.children=z(\"right\",b),O.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),R.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),j.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),P.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),T.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),C.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),B.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),A.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),a.center_panel=V,a.top_panel=O,a.bottom_panel=R,a.left_panel=j,a.right_panel=P,0!=T.children.length&&(a.inner_top_panel=T),0!=C.children.length&&(a.inner_bottom_panel=C),0!=B.children.length&&(a.inner_left_panel=B),0!=A.children.length&&(a.inner_right_panel=A),this.layout=a}_measure_layout(){const{frame_width:e,frame_height:t}=this.model,i=null==e?\"1fr\":(0,T.px)(e),s=null==t?\"1fr\":(0,T.px)(t),{layout:n}=this,a=n.top_panel.measure({width:1/0,height:1/0}),r=n.bottom_panel.measure({width:1/0,height:1/0}),o=n.left_panel.measure({width:1/0,height:1/0}),l=n.right_panel.measure({width:1/0,height:1/0}),_=B(a.height,n.min_border.top),h=B(r.height,n.min_border.bottom),d=B(o.width,n.min_border.left),c=B(l.width,n.min_border.right);this._computed_style.replace(`\\n :host {\\n grid-template-rows: ${_}px ${s} ${h}px;\\n grid-template-columns: ${d}px ${i} ${c}px;\\n }\\n `)}get axis_views(){const e=[];for(const[,t]of this.renderer_views)t instanceof c.AxisView&&e.push(t);return e}update_range(e,t){this.pause(),this._range_manager.update(e,t),this.unpause()}reset_range(){this.update_range(null),this.trigger_ranges_update_event()}trigger_ranges_update_event(){const{x_range:e,y_range:t}=this.model,i=new Set([...e.plots,...t.plots]);for(const e of i){const{x_range:t,y_range:i}=e.model;e.model.trigger_event(new f.RangesUpdate(t.start,t.end,i.start,i.end))}}get_selection(){const e=new Map;for(const t of this.model.data_renderers){const{selected:i}=t.selection_manager.source;e.set(t,i)}return e}update_selection(e){for(const t of this.model.data_renderers){const i=t.selection_manager.source;if(null!=e){const s=e.get(t);null!=s&&i.selected.update(s,!0)}else i.selection_manager.clear()}}reset_selection(){this.update_selection(null)}_invalidate_layout_if_needed(){(()=>{var e,t;for(const i of this.model.side_panels){const s=this.renderer_views.get(i);if(null!==(t=null===(e=s.layout)||void 0===e?void 0:e.has_size_changed())&&void 0!==t&&t)return this.invalidate_painters(s),!0}return!1})()&&this.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:n,renderers:a}=this.model;yield*a,yield*e,yield*t,yield*i,yield*s,yield*n,null!=this._title&&(yield this._title),null!=this._toolbar&&(yield this._toolbar);for(const[,e]of this.tool_views)yield*e.overlays}async build_renderer_views(){this.computed_renderers=[...this._compute_renderers()],await(0,m.build_views)(this.renderer_views,this.computed_renderers,{parent:this})}async build_tool_views(){const e=(0,z.flat_map)(this.model.toolbar.tools,(e=>e instanceof l.ToolProxy?e.tools:[e])),{created:t}=await(0,m.build_views)(this.tool_views,[...e],{parent:this});t.map((e=>this.canvas_view.ui_event_bus.register_tool(e)))}connect_signals(){super.connect_signals();const{extra_x_ranges:e,extra_y_ranges:t,extra_x_scales:i,extra_y_scales:s}=this.model.properties;this.on_change([e,t,i,s],(()=>{this.frame.x_range=this.model.x_range,this.frame.y_range=this.model.y_range,this.frame.in_x_scale=this.model.x_scale,this.frame.in_y_scale=this.model.y_scale,this.frame.extra_x_ranges=this.model.extra_x_ranges,this.frame.extra_y_ranges=this.model.extra_y_ranges,this.frame.extra_x_scales=this.model.extra_x_scales,this.frame.extra_y_scales=this.model.extra_y_scales,this.frame.configure_scales()}));const{above:n,below:a,left:r,right:o,center:l,renderers:_}=this.model.properties,h=[n,a,r,o,l];this.on_change(_,(async()=>{await this.build_renderer_views()})),this.on_change(h,(async()=>{await this.build_renderer_views(),this.invalidate_layout()})),this.connect(this.model.toolbar.properties.tools.change,(async()=>{await this.build_tool_views(),await this.build_renderer_views()}));const{x_ranges:d,y_ranges:c}=this.frame;for(const[,e]of d)this.connect(e.change,(()=>{this.request_paint(\"everything\")}));for(const[,e]of c)this.connect(e.change,(()=>{this.request_paint(\"everything\")}));this.connect(this.model.change,(()=>this.request_paint(\"everything\"))),this.connect(this.model.reset,(()=>this.reset()));const{toolbar_location:p}=this.model.properties;this.on_change(p,(async()=>{const{toolbar_location:e}=this.model;if(null!=this._toolbar)null!=e?this._toolbar.toolbar.location=e:(this._toolbar=void 0,await this.build_renderer_views());else if(null!=e){const{toolbar:t,toolbar_inner:i}=this.model;this._toolbar=new u.ToolbarPanel({toolbar:t}),t.location=e,t.inner=i,await this.build_renderer_views()}this.invalidate_layout()}));const{hold_render:g}=this.model.properties;this.on_change(g,(()=>this._hold_render_changed()))}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(),this.unpause(!0);const t=this.layout.left_panel.bbox,i=this.layout.right_panel.bbox,s=this.layout.center_panel.bbox,n=this.layout.top_panel.bbox,a=this.layout.bottom_panel.bbox,{bbox:r}=this,o=n.bottom,l=r.height-a.top,_=t.right,d=r.width-i.left;this.canvas.style.replace(`\\n .bk-layer.bk-events {\\n display: grid;\\n grid-template-areas:\\n \". above . \"\\n \"left center right\"\\n \". below . \";\\n grid-template-rows: ${(0,T.px)(o)} ${(0,T.px)(s.height)} ${(0,T.px)(l)};\\n grid-template-columns: ${(0,T.px)(_)} ${(0,T.px)(s.width)} ${(0,T.px)(d)};\\n }\\n `);for(const[,t]of this.renderer_views)t instanceof h.AnnotationView&&(null===(e=t.after_layout)||void 0===e||e.call(t));this.model.setv({inner_width:Math.round(this.frame.bbox.width),inner_height:Math.round(this.frame.bbox.height),outer_width:Math.round(this.bbox.width),outer_height:Math.round(this.bbox.height)},{no_change:!0}),this.model.match_aspect&&(this.pause(),this._range_manager.update_dataranges(),this.unpause(!0)),this._outer_bbox.equals(this.bbox)||(this.canvas_view.resize(),this._outer_bbox=this.bbox,this._invalidate_all=!0,this._needs_paint=!0);const{inner_bbox:c}=this.layout;this._inner_bbox.equals(c)||(this._inner_bbox=c,this._needs_paint=!0),this._needs_paint&&this.paint()}repaint(){this._invalidate_layout_if_needed(),this.paint()}paint(){this.is_paused||(this.model.visible&&(v.logger.trace(`${this.toString()}.paint()`),this._actual_paint()),this._needs_notify&&(this._needs_notify=!1,this.notify_finished()))}_actual_paint(){var e;const{document:t}=this.model;if(null!=t){const e=t.interactive_duration();e>=0&&e{t.interactive_duration()>this.model.lod_timeout&&t.interactive_stop(),this.request_paint(\"everything\")}),this.model.lod_timeout):t.interactive_stop()}this._range_manager.invalidate_dataranges&&(this._range_manager.update_dataranges(),this._invalidate_layout_if_needed());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 n=[this.frame.bbox.left,this.frame.bbox.top,this.frame.bbox.width,this.frame.bbox.height],{primary:a,overlays:r}=this.canvas_view;i&&(a.prepare(),this.canvas_view.prepare_webgl(n),this._paint_empty(a.ctx,n),this._paint_outline(a.ctx,n),this._paint_levels(a.ctx,\"image\",n,!0),this._paint_levels(a.ctx,\"underlay\",n,!0),this._paint_levels(a.ctx,\"glyph\",n,!0),this._paint_levels(a.ctx,\"guide\",n,!1),this._paint_levels(a.ctx,\"annotation\",n,!1),a.finish()),(s||P.settings.wireframe)&&(r.prepare(),this._paint_levels(r.ctx,\"overlay\",n,!1),P.settings.wireframe&&this._paint_layout(r.ctx,this.layout),r.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 n of this.computed_renderers){if(n.level!=t)continue;const a=this.renderer_views.get(n);e.save(),(s||a.needs_clip)&&(e.beginPath(),e.rect(...i),e.clip()),a.render(),e.restore(),a.has_webgl&&a.needs_webgl_blit&&this.canvas_view.blit_webgl(e)}}_paint_layout(e,t){const{x:i,y:s,width:n,height:a}=t.bbox;e.strokeStyle=\"blue\",e.strokeRect(i,s,n,a);for(const n of t)e.save(),t.absolute||e.translate(i,s),this._paint_layout(e,n),e.restore()}_paint_empty(e,t){const[i,s,n,a]=[0,0,this.bbox.width,this.bbox.height],[r,o,l,_]=t;this.visuals.border_fill.doit&&(this.visuals.border_fill.set_value(e),e.fillRect(i,s,n,a),e.clearRect(r,o,l,_)),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(e),e.fillRect(r,o,l,_))}_paint_outline(e,t){if(this.visuals.outline_line.doit){e.save(),this.visuals.outline_line.set_value(e);let[i,s,n,a]=t;i+n==this.bbox.width&&(n-=1),s+a==this.bbox.height&&(a-=1),e.strokeRect(i,s,n,a),e.restore()}}export(e=\"auto\",t=!0){const i=(()=>{switch(e){case\"auto\":return this.canvas_view.model.output_backend;case\"png\":return\"canvas\";case\"svg\":return\"svg\"}})(),s=new k.CanvasLayer(i,t),{width:n,height:a}=this.bbox;if(s.resize(n,a),0!=n&&0!=a){const{canvas:e}=this.canvas_view.compose();s.ctx.drawImage(e,0,0)}return s}serializable_state(){const e=super.serializable_state(),{children:t}=e,i=a.__rest(e,[\"children\"]),s=this.get_renderer_views().filter((e=>e.model.syncable)).map((e=>e.serializable_state())).filter((e=>null!=e.bbox)),n={type:\"CartesianFrame\",bbox:this.frame.bbox};return Object.assign(Object.assign({},i),{children:[...null!=t?t:[],n,...s]})}_hold_render_changed(){this.model.hold_render?this.pause():this.unpause()}}i.PlotView=A,A.__name__=\"PlotView\"},\n", - " function _(n,t,e,l,u){l(),e.throttle=function(n,t){let e,l=null,u=null,o=0,i=!1;const r=function(){return new Promise(((r,c)=>{e=r;const a=function(){o=Date.now(),l=null,u=null,i=!1;try{n(),r()}catch(n){c(n)}},m=Date.now(),s=t-(m-o);s<=0&&!i?(null!=l&&clearTimeout(l),i=!0,u=requestAnimationFrame(a)):null!=l||i?r():l=setTimeout((()=>u=requestAnimationFrame(a)),s)}))};return r.stop=function(){null!=l&&clearTimeout(l),null!=u&&cancelAnimationFrame(u),e()},r}},\n", - " function _(t,n,a,e,s){e();const o=t(93),r=t(18);class l{constructor(t){this.invalidate_dataranges=!0,this.parent=t}get frame(){return this.parent.frame}update(t,n={}){var a;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 o=[];for(const[n,a]of e)o.push([a,t.xrs.get(n)]);for(const[n,a]of s)o.push([a,t.yrs.get(n)]);null!==(a=n.scrolling)&&void 0!==a&&a&&this._update_ranges_together(o),this._update_ranges_individually(o,n)}}reset(){this.update(null)}_update_dataranges(t){const n=new Map,a=new Map;let e=!1;for(const[,n]of t.x_ranges)n instanceof o.DataRange1d&&\"log\"==n.scale_hint&&(e=!0);for(const[,n]of t.y_ranges)n instanceof o.DataRange1d&&\"log\"==n.scale_hint&&(e=!0);for(const t of this.parent.auto_ranged_renderers){const s=t.bounds();if(n.set(t.model,s),e){const n=t.log_bounds();a.set(t.model,n)}}let s=!1,l=!1;const i=t.x_target.span,d=t.y_target.span;let u;!1!==this.parent.model.match_aspect&&0!=i&&0!=d&&(u=1/this.parent.model.aspect_scale*(i/d));for(const[,e]of t.x_ranges){if(e instanceof o.DataRange1d){const t=\"log\"==e.scale_hint?a:n;e.update(t,0,this.parent,u),null!=e.follow&&(s=!0)}null!=e.bounds&&(l=!0)}for(const[,e]of t.y_ranges){if(e instanceof o.DataRange1d){const t=\"log\"==e.scale_hint?a:n;e.update(t,1,this.parent,u),null!=e.follow&&(s=!0)}null!=e.bounds&&(l=!0)}if(s&&l){r.logger.warn(\"Follow enabled so bounds are unset.\");for(const[,n]of t.x_ranges)n.bounds=null;for(const[,n]of t.y_ranges)n.bounds=null}}update_dataranges(){this._update_dataranges(this.frame);for(const t of this.parent.auto_ranged_renderers){const{coordinates:n}=t.model;null!=n&&this._update_dataranges(n)}null!=this.compute_initial()&&(this.invalidate_dataranges=!1)}compute_initial(){let t=!0;const{x_ranges:n,y_ranges:a}=this.frame,e=new Map,s=new Map;for(const[a,s]of n){const{start:n,end:o}=s;if(isNaN(n+o)){t=!1;break}e.set(a,{start:n,end:o})}if(t)for(const[n,e]of a){const{start:a,end:o}=e;if(isNaN(a+o)){t=!1;break}s.set(n,{start:a,end:o})}return t?{xrs:e,yrs:s}:(r.logger.warn(\"could not set initial ranges\"),null)}_update_ranges_together(t){let n=1;for(const[a,e]of t)n=Math.min(n,this._get_weight_to_constrain_interval(a,e));if(n<1)for(const[a,e]of t)e.start=n*e.start+(1-n)*a.start,e.end=n*e.end+(1-n)*a.end}_update_ranges_individually(t,n={}){var a,e,s;const o=null!==(a=n.panning)&&void 0!==a&&a,r=null!==(e=n.scrolling)&&void 0!==e&&e,l=null!==(s=n.maintain_focus)&&void 0!==s&&s;let i=!1;for(const[n,a]of t){if(!r){const t=this._get_weight_to_constrain_interval(n,a);t<1&&(a.start=t*a.start+(1-t)*n.start,a.end=t*a.end+(1-t)*n.end)}if(null!=n.bounds&&\"auto\"!=n.bounds){const[t,e]=n.bounds,s=Math.abs(a.end-a.start);n.is_reversed?(null!=t&&t>a.end&&(i=!0,a.end=t,(o||r)&&(a.start=t+s)),null!=e&&ea.start&&(i=!0,a.start=t,(o||r)&&(a.end=t+s)),null!=e&&e0&&r0&&r>e&&(s=(e-o)/(r-o)),s=Math.max(0,Math.min(1,s))}return s}}a.RangeManager=l,l.__name__=\"RangeManager\"},\n", - " function _(t,i,s,e,n){e();const h=t(15);class a{constructor(t,i){this.history=[],this.index=-1,this.parent=t,this.initial_state=i,this.changed=new h.Signal0(this.parent,\"state_changed\")}_do_state_change(t){const i=t in this.history?this.history[t].state:this.initial_state;return null!=i.range&&this.parent.update_range(i.range),null!=i.selection&&this.parent.update_selection(i.selection),i}peek(){return this.can_undo?this.history[this.index]:null}push(t,i){const{history:s,index:e}=this,n=e in s?s[e].state:{},h=Object.assign(Object.assign(Object.assign({},this.initial_state),n),i);this.history=this.history.slice(0,this.index+1),this.history.push({type:t,state:h}),this.index=this.history.length-1,this.changed.emit()}clear(){this.history=[],this.index=-1,this.changed.emit()}undo(){if(this.can_undo){this.index-=1;const t=this._do_state_change(this.index);return this.changed.emit(),t}return null}redo(){if(this.can_redo){this.index+=1;const t=this._do_state_change(this.index);return this.changed.emit(),t}return null}get can_undo(){return this.index>=0}get can_redo(){return this.indexh.emit();const s=encodeURIComponent,i=document.createElement(\"script\");i.type=\"text/javascript\",i.src=`https://maps.googleapis.com/maps/api/js?v=${s(e)}&key=${s(t)}&callback=_bokeh_gmaps_callback`,document.body.appendChild(i)}(this._api_key,t)}h.connect((()=>{this._build_map(),this.request_paint(\"everything\")}))}else this._build_map()}remove(){(0,p.remove)(this.map_el),super.remove()}update_range(t,e){var s,i;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!==(i=t.sdy)&&void 0!==i?i: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,i=this.map.getZoom();if(null!=i){const t=i+s;if(t>=2){this.map.setZoom(t);const[e,s]=this._get_projected_bounds();s-e<0&&this.map.setZoom(i)}}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=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_styling())),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,i]=this._get_latlon_bounds(),[o,a]=_.wgs84_mercator.compute(t,s),[n,p]=_.wgs84_mercator.compute(e,i);return[o,n,a,p]}_set_bokeh_ranges(){const[t,e,s,i]=this._get_projected_bounds();this.frame.x_range.setv({start:t,end:e}),this.frame.y_range.setv({start:s,end:i})}_update_center(t){var e;const s=null===(e=this.map.getCenter())||void 0===e?void 0:e.toJSON();null!=s&&(s[t]=this.model.map_options[t],this.map.setCenter(s),this._set_bokeh_ranges())}_update_map_type(){this.map.setOptions({mapTypeId:this.map_types[this.model.map_options.map_type]})}_update_scale_control(){this.map.setOptions({scaleControl:this.model.map_options.scale_control})}_update_tilt(){this.map.setOptions({tilt:this.model.map_options.tilt})}_update_options(){this._update_styling(),this._update_center(\"lat\"),this._update_center(\"lng\"),this._update_zoom(),this._update_map_type()}_update_styling(){const{styles:t}=this.model.map_options;this.map.setOptions({styles:null!=t?JSON.parse(t):null})}_update_zoom(){this.map.setOptions({zoom:this.model.map_options.zoom}),this._set_bokeh_ranges()}_after_layout(){super._after_layout();const{left:t,top:e,width:s,height:i}=this.frame.bbox;this.map_el.style.top=`${e}px`,this.map_el.style.left=`${t}px`,this.map_el.style.width=`${s}px`,this.map_el.style.height=`${i}px`}}s.GMapPlotView=d,d.__name__=\"GMapPlotView\"},\n", - " function _(e,a,t,s,n){var p;s();const _=e(393);class i extends _.GMapPlotView{serializable_state(){const e=super.serializable_state();return Object.assign(Object.assign({},e),{type:\"GMapPlot\"})}}t.GMapView=i,i.__name__=\"GMapView\";class l extends _.GMapPlot{constructor(e){super(e)}}t.GMap=l,p=l,l.__name__=\"GMap\",p.prototype.default_view=i},\n", - " function _(i,t,e,o,s){var l;o();const r=i(360),n=i(364),a=i(233),c=i(256),_=i(274),d=i(260),h=i(59),u=i(19);class b extends r.LayoutDOMView{constructor(){super(...arguments),this._tool_views=new Map}get toolbar_view(){return this.child_views.find((i=>i.model==this.model.toolbar))}get grid_box_view(){return this.child_views.find((i=>i.model==this._grid_box))}_update_location(){const i=this.model.toolbar_location;null==i?this.model.toolbar.visible=!1:this.model.toolbar.setv({visible:!0,location:i})}initialize(){super.initialize(),this._update_location();const{children:i,rows:t,cols:e,spacing:o}=this.model;this._grid_box=new n.GridBox({children:i,rows:t,cols:e,spacing:o,sizing_mode:\"inherit\"})}async lazy_initialize(){await super.lazy_initialize(),await this.build_tool_views()}connect_signals(){super.connect_signals();const{toolbar:i,toolbar_location:t,children:e,rows:o,cols:s,spacing:l}=this.model.properties;this.on_change(t,(()=>{this._update_location(),this.rebuild()})),this.on_change([i,e,o,s,l],(()=>{this.rebuild()})),this.on_change(this.model.toolbar.properties.tools,(async()=>{await this.build_tool_views()})),this.mouseenter.connect((()=>{this.toolbar_view.set_visibility(!0)})),this.mouseleave.connect((()=>{this.toolbar_view.set_visibility(!1)}))}remove(){(0,h.remove_views)(this._tool_views),super.remove()}async build_tool_views(){const i=this.model.toolbar.tools.filter((i=>i instanceof _.ActionTool));await(0,h.build_views)(this._tool_views,i,{parent:this})}*children(){yield*super.children(),yield*this._tool_views.values()}get child_models(){return[this.model.toolbar,this._grid_box]}_intrinsic_display(){return{inner:this.model.flow_mode,outer:\"flex\"}}_update_layout(){super._update_layout();const{location:i}=this.model.toolbar,t=(()=>{switch(i){case\"above\":return\"column\";case\"below\":return\"column-reverse\";case\"left\":return\"row\";case\"right\":return\"row-reverse\"}})();this.style.append(\":host\",{flex_direction:t})}export(i=\"auto\",t=!0){const e=(()=>{switch(i){case\"auto\":case\"png\":return\"canvas\";case\"svg\":return\"svg\"}})(),o=new d.CanvasLayer(e,t),{x:s,y:l,width:r,height:n}=this.grid_box_view.bbox.relative();o.resize(r,n),o.ctx.save();const a=getComputedStyle(this.el).backgroundColor;o.ctx.fillStyle=a,o.ctx.fillRect(s,l,r,n);for(const e of this.child_views){const s=e.export(i,t),{x:l,y:r}=e.bbox;o.ctx.drawImage(s.canvas,l,r)}return o.ctx.restore(),o}}e.GridPlotView=b,b.__name__=\"GridPlotView\";class w extends r.LayoutDOM{constructor(i){super(i)}}e.GridPlot=w,l=w,w.__name__=\"GridPlot\",l.prototype.default_view=b,l.define((({Array:i,Ref:t,Nullable:e})=>({toolbar:[t(c.Toolbar),()=>new c.Toolbar],toolbar_location:[e(u.Location),\"above\"],children:[i((0,a.GridChild)(r.LayoutDOM)),[]],rows:[e(a.TracksSizing),null],cols:[e(a.TracksSizing),null],spacing:[a.GridSpacing,0]})))},\n", - " function _(e,t,s,i,a){var r;i();const n=e(394);class _ extends n.PlotView{serializable_state(){const e=super.serializable_state();return Object.assign(Object.assign({},e),{type:\"Plot\"})}}s.FigureView=_,_.__name__=\"FigureView\";class l extends n.Plot{constructor(e){super(e)}}s.Figure=l,r=l,l.__name__=\"Figure\",r.prototype.default_view=_},\n", - " function _(t,_,n,o,r){o();t(1).__exportStar(t(163),n)},\n", - " function _(l,r,i,a,e){a(),e(\"ParkMillerLCG\",l(406).ParkMillerLCG)},\n", - " function _(e,n,r,a,l){var t;a();const o=e(389),s=e(262);class d extends o.RandomGenerator{constructor(e){super(e)}generator(){var e;return new s.LCGRandom(null!==(e=this.seed)&&void 0!==e?e:Date.now())}}r.ParkMillerLCG=d,t=d,d.__name__=\"ParkMillerLCG\",t.define((({Int:e,Nullable:n})=>({seed:[n(e),null]})))},\n", - " function _(e,r,n,d,R){d(),R(\"ContourRenderer\",e(408).ContourRenderer),R(\"GlyphRenderer\",e(199).GlyphRenderer),R(\"GraphRenderer\",e(409).GraphRenderer),R(\"GuideRenderer\",e(160).GuideRenderer);var G=e(74);R(\"Renderer\",G.Renderer),R(\"RendererGroup\",G.RendererGroup)},\n", - " function _(e,i,r,n,l){var t;n();const _=e(200),s=e(199),d=e(59);class a extends _.DataRendererView{*children(){yield*super.children(),yield this.fill_view,yield this.line_view}get glyph_view(){return this.fill_view.glyph.data_size>0?this.fill_view.glyph:this.line_view.glyph}async lazy_initialize(){await super.lazy_initialize();const{parent:e}=this,{fill_renderer:i,line_renderer:r}=this.model;this.fill_view=await(0,d.build_view)(i,{parent:e}),this.line_view=await(0,d.build_view)(r,{parent:e})}remove(){this.fill_view.remove(),this.line_view.remove(),super.remove()}_render(){this.fill_view.render(),this.line_view.render()}renderer_view(e){if(e instanceof s.GlyphRenderer){if(e==this.fill_view.model)return this.fill_view;if(e==this.line_view.model)return this.line_view}return super.renderer_view(e)}}r.ContourRendererView=a,a.__name__=\"ContourRendererView\";class h extends _.DataRenderer{constructor(e){super(e)}get_selection_manager(){return this.fill_renderer.data_source.selection_manager}}r.ContourRenderer=h,t=h,h.__name__=\"ContourRenderer\",t.prototype.default_view=a,t.define((({Array:e,Number:i,Ref:r})=>({fill_renderer:[r(s.GlyphRenderer)],line_renderer:[r(s.GlyphRenderer)],levels:[e(i),[]]})))},\n", - " function _(e,r,i,n,t){var d;n();const s=e(200),o=e(199),a=e(353),l=e(352),p=e(59),h=e(202),_=e(333),y=e(335);class c extends s.DataRendererView{get glyph_view(){return this.node_view.glyph}*children(){yield*super.children(),yield this.edge_view,yield this.node_view}async lazy_initialize(){await super.lazy_initialize(),this.apply_coordinates();const{parent:e}=this,{edge_renderer:r,node_renderer:i}=this.model;this.edge_view=await(0,p.build_view)(r,{parent:e}),this.node_view=await(0,p.build_view)(i,{parent:e})}connect_signals(){super.connect_signals(),this.connect(this.model.layout_provider.change,(()=>{this.apply_coordinates(),this.edge_view.set_data(),this.node_view.set_data(),this.request_render()}))}apply_coordinates(){const{edge_renderer:e,node_renderer:r}=this.model;if(!(e.glyph instanceof _.MultiLine||e.glyph instanceof y.Patches))throw new Error(`${this}.edge_renderer.glyph must be a MultiLine glyph`);if(!(r.glyph instanceof h.XYGlyph))throw new Error(`${this}.node_renderer.glyph must be a XYGlyph glyph`);const i=this.model.layout_provider.edge_coordinates,n=this.model.layout_provider.node_coordinates;e.glyph.properties.xs.internal=!0,e.glyph.properties.ys.internal=!0,r.glyph.properties.x.internal=!0,r.glyph.properties.y.internal=!0,e.glyph.xs={expr:i.x},e.glyph.ys={expr:i.y},r.glyph.x={expr:n.x},r.glyph.y={expr:n.y}}remove(){this.edge_view.remove(),this.node_view.remove(),super.remove()}_render(){this.edge_view.render(),this.node_view.render()}renderer_view(e){if(e instanceof 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)}}i.GraphRendererView=c,c.__name__=\"GraphRendererView\";class g extends s.DataRenderer{constructor(e){super(e)}get_selection_manager(){return this.node_renderer.data_source.selection_manager}}i.GraphRenderer=g,d=g,g.__name__=\"GraphRenderer\",d.prototype.default_view=c,d.define((({Ref:e})=>({layout_provider:[e(a.LayoutProvider)],node_renderer:[e(o.GlyphRenderer)],edge_renderer:[e(o.GlyphRenderer)],selection_policy:[e(l.GraphHitTestPolicy),()=>new l.NodesOnly],inspection_policy:[e(l.GraphHitTestPolicy),()=>new l.NodesOnly]})))},\n", - " function _(e,t,n,o,c){o();e(1).__exportStar(e(102),n),c(\"Selection\",e(101).Selection)},\n", - " function _(y,B,a,s,C){s(),C(\"ByID\",y(412).ByID),C(\"ByClass\",y(414).ByClass),C(\"ByCSS\",y(415).ByCSS),C(\"ByXPath\",y(416).ByXPath)},\n", - " function _(e,n,r,t,c){t();const o=e(413);class s extends o.Selector{constructor(e){super(e)}find_one(e){return e.querySelector(`#${this.query}`)}}r.ByID=s,s.__name__=\"ByID\"},\n", - " function _(e,n,r,t,c){var o;t();const s=e(50);class _ extends s.Model{constructor(e){super(e)}}r.Selector=_,o=_,_.__name__=\"Selector\",o.define((({String:e})=>({query:[e]})))},\n", - " function _(e,s,n,r,t){r();const c=e(413);class o extends c.Selector{constructor(e){super(e)}find_one(e){return e.querySelector(`.${this.query}`)}}n.ByClass=o,o.__name__=\"ByClass\"},\n", - " function _(e,n,r,t,c){t();const o=e(413);class s extends o.Selector{constructor(e){super(e)}find_one(e){return e.querySelector(this.query)}}r.ByCSS=s,s.__name__=\"ByCSS\"},\n", - " function _(e,t,n,r,a){r();const c=e(413);class o extends c.Selector{constructor(e){super(e)}find_one(e){return document.evaluate(this.query,e).iterateNext()}}n.ByXPath=o,o.__name__=\"ByXPath\"},\n", - " function _(a,e,S,o,r){o(),r(\"ServerSentDataSource\",a(418).ServerSentDataSource),r(\"AjaxDataSource\",a(420).AjaxDataSource),r(\"ColumnDataSource\",a(104).ColumnDataSource),r(\"ColumnarDataSource\",a(99).ColumnarDataSource),r(\"CDSView\",a(215).CDSView),r(\"DataSource\",a(103).DataSource),r(\"GeoJSONDataSource\",a(421).GeoJSONDataSource),r(\"WebDataSource\",a(419).WebDataSource)},\n", - " function _(e,t,i,a,s){a();const n=e(419);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,r){var s;n();const l=t(104),i=t(19);class o extends l.ColumnDataSource{constructor(t){super(t)}get_column(t){return t in this.data?this.data[t]:[]}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 r;switch(r=null!=n?n.execute(this,{response:t}):t,e){case\"replace\":this.data=r;break;case\"append\":{const t=this.data;for(const e of this.columns()){const n=Array.from(t[e]),s=Array.from(r[e]),l=n.concat(s);r[e]=null!=a?l.slice(-a):l}this.data=r;break}}}}a.WebDataSource=o,s=o,o.__name__=\"WebDataSource\",s.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]})))},\n", - " function _(t,e,i,s,a){var n;s();const r=t(419),o=t(19),l=t(18),d=t(9);class h extends r.WebDataSource{constructor(t){super(t),this.interval=null,this.initialized=!1}destroy(){null!=this.interval&&clearInterval(this.interval),super.destroy()}setup(){if(!this.initialized&&(this.initialized=!0,this.get_data(this.mode),null!=this.polling_interval)){const t=()=>this.get_data(this.mode,this.max_size,this.if_modified);this.interval=setInterval(t,this.polling_interval)}}get_data(t,e=null,i=!1){const s=this.prepare_request();s.addEventListener(\"load\",(()=>this.do_load(s,t,null!=e?e:void 0))),s.addEventListener(\"error\",(()=>this.do_error(s))),s.send()}prepare_request(){const t=new XMLHttpRequest;t.open(this.method,this.data_url,!0),t.withCredentials=!1,t.setRequestHeader(\"Content-Type\",this.content_type);const e=this.http_headers;for(const[i,s]of(0,d.entries)(e))t.setRequestHeader(i,s);return t}do_load(t,e,i){if(200===t.status){const s=JSON.parse(t.responseText);this.load_data(s,e,i)}}do_error(t){l.logger.error(`Failed to fetch JSON from ${this.data_url} with code ${t.status}`)}}i.AjaxDataSource=h,n=h,h.__name__=\"AjaxDataSource\",n.define((({Boolean:t,Int:e,String:i,Dict:s,Nullable:a})=>({polling_interval:[a(e),null],content_type:[i,\"application/json\"],http_headers:[s(i),{}],method:[o.HTTPMethod,\"POST\"],if_modified:[t,!1]})))},\n", - " function _(e,t,o,r,n){var s;r();const a=e(99),i=e(18),l=e(8),c=e(10),_=e(9);function g(e){return null!=e?e:NaN}const{hasOwnProperty:u}=Object.prototype;class y extends a.ColumnarDataSource{constructor(e){super(e)}initialize(){super.initialize(),this._update_data()}connect_signals(){super.connect_signals(),this.connect(this.properties.geojson.change,(()=>this._update_data()))}_update_data(){this.data=this.geojson_to_column_data()}_get_new_list_array(e){return(0,c.range)(0,e).map((e=>[]))}_get_new_nan_array(e){return(0,c.range)(0,e).map((e=>NaN))}_add_properties(e,t,o,r){var n;const s=null!==(n=e.properties)&&void 0!==n?n:{};for(const[e,n]of(0,_.entries)(s))u.call(t,e)||(t[e]=this._get_new_nan_array(r)),t[e][o]=g(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]=g(s);break}case\"LineString\":{const{coordinates:r}=e;for(let e=0;e1&&i.logger.warn(\"Bokeh does not support Polygons with holes in, only exterior ring used.\");const r=e.coordinates[0];for(let e=0;e1&&i.logger.warn(\"Bokeh does not support Polygons with holes in, only exterior ring used.\"),n.push(t[0]);const s=n.reduce(r);for(let e=0;e({geojson:[e]}))),s.internal((({Any:e,Dict:t,Arrayable:o})=>({data:[t(o(e)),{}]})))},\n", - " function _(e,r,T,o,S){o(),S(\"BBoxTileSource\",e(423).BBoxTileSource),S(\"MercatorTileSource\",e(424).MercatorTileSource),S(\"QUADKEYTileSource\",e(427).QUADKEYTileSource),S(\"TileRenderer\",e(428).TileRenderer),S(\"TileSource\",e(425).TileSource),S(\"TMSTileSource\",e(431).TMSTileSource),S(\"WMTSTileSource\",e(429).WMTSTileSource)},\n", - " function _(e,t,r,o,l){var i;o();const n=e(424);class s extends n.MercatorTileSource{constructor(e){super(e)}get_image_url(e,t,r){const o=this.string_lookup_replace(this.url,this.extra_url_vars);let l,i,n,s;return this.use_latlon?[i,s,l,n]=this.get_tile_geographic_bounds(e,t,r):[i,s,l,n]=this.get_tile_meter_bounds(e,t,r),o.replace(\"{XMIN}\",i.toString()).replace(\"{YMIN}\",s.toString()).replace(\"{XMAX}\",l.toString()).replace(\"{YMAX}\",n.toString())}}r.BBoxTileSource=s,i=s,s.__name__=\"BBoxTileSource\",i.define((({Boolean:e})=>({use_latlon:[e,!1]})))},\n", - " function _(t,e,i,_,s){var r;_();const o=t(425),n=t(10),l=t(426);class u extends o.TileSource{constructor(t){super(t)}initialize(){super.initialize(),this._resolutions=(0,n.range)(this.min_zoom,this.max_zoom+1).map((t=>this.get_resolution(t)))}_computed_initial_resolution(){return null!=this.initial_resolution?this.initial_resolution:2*Math.PI*6378137/this.tile_size}is_valid_tile(t,e,i){return!(!this.wrap_around&&(t<0||t>=2**i))&&!(e<0||e>=2**i)}parent_by_tile_xyz(t,e,i){const _=this.tile_xyz_to_quadkey(t,e,i),s=_.substring(0,_.length-1);return this.quadkey_to_tile_xyz(s)}get_resolution(t){return this._computed_initial_resolution()/2**t}get_resolution_by_extent(t,e,i){return[(t[2]-t[0])/i,(t[3]-t[1])/e]}get_level_by_extent(t,e,i){const _=(t[2]-t[0])/i,s=(t[3]-t[1])/e,r=Math.max(_,s);let o=0;for(const t of this._resolutions){if(r>t){if(0==o)return 0;if(o>0)return o-1}o+=1}return o-1}get_closest_level_by_extent(t,e,i){const _=(t[2]-t[0])/i,s=(t[3]-t[1])/e,r=Math.max(_,s),o=this._resolutions.reduce((function(t,e){return Math.abs(e-r)e?(u=o-s,a*=t):(u*=e,a=n-r)}const h=(u-(o-s))/2,c=(a-(n-r))/2;return[s-h,r-c,o+h,n+c]}tms_to_wmts(t,e,i){return[t,2**i-1-e,i]}wmts_to_tms(t,e,i){return[t,2**i-1-e,i]}pixels_to_meters(t,e,i){const _=this.get_resolution(i);return[t*_-this.x_origin_offset,e*_-this.y_origin_offset]}meters_to_pixels(t,e,i){const _=this.get_resolution(i);return[(t+this.x_origin_offset)/_,(e+this.y_origin_offset)/_]}pixels_to_tile(t,e){let i=Math.ceil(t/this.tile_size);i=0===i?i:i-1;return[i,Math.max(Math.ceil(e/this.tile_size)-1,0)]}pixels_to_raster(t,e,i){return[t,(this.tile_size<=l;t--)for(let i=n;i<=u;i++)this.is_valid_tile(i,t,e)&&h.push([i,t,e,this.get_tile_meter_bounds(i,t,e)]);return this.sort_tiles_from_center(h,[n,l,u,a]),h}quadkey_to_tile_xyz(t){let e=0,i=0;const _=t.length;for(let s=_;s>0;s--){const r=1<0;s--){const i=1<0;)if(s=s.substring(0,s.length-1),[t,e,i]=this.quadkey_to_tile_xyz(s),[t,e,i]=this.denormalize_xyz(t,e,i,_),this.tiles.has(this.tile_xyz_to_key(t,e,i)))return[t,e,i];return[0,0,0]}normalize_xyz(t,e,i){if(this.wrap_around){const _=2**i;return[(t%_+_)%_,e,i]}return[t,e,i]}denormalize_xyz(t,e,i,_){return[t+_*2**i,e,i]}denormalize_meters(t,e,i,_){return[t+2*_*Math.PI*6378137,e]}calculate_world_x_by_tile_xyz(t,e,i){return Math.floor(t/2**i)}}i.MercatorTileSource=u,r=u,u.__name__=\"MercatorTileSource\",r.define((({Boolean:t})=>({snap_to_zoom:[t,!1],wrap_around:[t,!0]}))),r.override({x_origin_offset:20037508.34,y_origin_offset:20037508.34,initial_resolution:156543.03392804097})},\n", - " function _(e,t,r,i,n){var l;i();const a=e(50),s=e(9);class c extends a.Model{constructor(e){super(e)}initialize(){super.initialize(),this.tiles=new Map,this._normalize_case()}connect_signals(){super.connect_signals(),this.connect(this.change,(()=>this._clear_cache()))}string_lookup_replace(e,t){let r=e;for(const[e,i]of(0,s.entries)(t))r=r.replace(`{${e}}`,i);return r}_normalize_case(){const e=this.url.replace(\"{x}\",\"{X}\").replace(\"{y}\",\"{Y}\").replace(\"{z}\",\"{Z}\").replace(\"{q}\",\"{Q}\").replace(\"{xmin}\",\"{XMIN}\").replace(\"{ymin}\",\"{YMIN}\").replace(\"{xmax}\",\"{XMAX}\").replace(\"{ymax}\",\"{YMAX}\");this.url=e}_clear_cache(){this.tiles=new Map}tile_xyz_to_key(e,t,r){return`${e}:${t}:${r}`}key_to_tile_xyz(e){const[t,r,i]=e.split(\":\").map((e=>parseInt(e)));return[t,r,i]}sort_tiles_from_center(e,t){const[r,i,n,l]=t,a=(n-r)/2+r,s=(l-i)/2+i;e.sort((function(e,t){return Math.sqrt((a-e[0])**2+(s-e[1])**2)-Math.sqrt((a-t[0])**2+(s-t[1])**2)}))}get_image_url(e,t,r){return this.string_lookup_replace(this.url,this.extra_url_vars).replace(\"{X}\",e.toString()).replace(\"{Y}\",t.toString()).replace(\"{Z}\",r.toString())}}r.TileSource=c,l=c,c.__name__=\"TileSource\",l.define((({Number:e,String:t,Dict:r,Nullable:i})=>({url:[t,\"\"],tile_size:[e,256],max_zoom:[e,30],min_zoom:[e,0],extra_url_vars:[r(t),{}],attribution:[t,\"\"],x_origin_offset:[e],y_origin_offset:[e],initial_resolution:[i(e),null]})))},\n", - " function _(t,e,r,n,o){n();const c=t(105);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(424);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,_){var n;s();const a=t(1),h=t(425),o=t(429),r=t(74),l=t(88),d=t(56),m=t(150),c=t(10),u=t(8),p=a.__importDefault(t(430));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()))}remove(){null!=this.attribution_el&&(0,d.remove)(this.attribution_el),super.remove()}get_extent(){return[this.x_range.start,this.y_range.start,this.x_range.end,this.y_range.end]}get map_plot(){return this.plot_model}get map_canvas(){return this.layer.ctx}get map_frame(){return this.plot_view.frame}get x_range(){return this.map_plot.x_range}get y_range(){return this.map_plot.y_range}_set_data(){this.extent=this.get_extent(),this._last_height=void 0,this._last_width=void 0}_update_attribution(){null!=this.attribution_el&&(0,d.remove)(this.attribution_el);const{attribution:t}=this.model.tile_source;if((0,u.isString)(t)&&t.length>0){const{layout:e,frame:i}=this.plot_view,s=e.bbox.width-i.bbox.right,_=e.bbox.height-i.bbox.bottom,n=i.bbox.width;this.attribution_el=(0,d.div)({style:{right:`${s}px`,bottom:`${_}px`,\"max-width\":`${n}px`}});const a=(0,d.div)();a.innerHTML=t;const h=this.attribution_el.attachShadow({mode:\"open\"});new d.InlineStyleSheet(p.default).install(h),h.appendChild(a),this.attribution_el.title=a.textContent.replace(/\\s*\\n\\s*/g,\" \"),this.plot_view.canvas_view.add_event(this.attribution_el)}}_map_data(){this.initial_extent=this.get_extent();const t=this.model.tile_source.get_level_by_extent(this.initial_extent,this.map_frame.bbox.height,this.map_frame.bbox.width),e=this.model.tile_source.snap_to_zoom_level(this.initial_extent,this.map_frame.bbox.height,this.map_frame.bbox.width,t);this.x_range.start=e[0],this.y_range.start=e[1],this.x_range.end=e[2],this.y_range.end=e[3],this.x_range instanceof l.Range1d&&(this.x_range.reset_start=e[0],this.x_range.reset_end=e[2]),this.y_range instanceof l.Range1d&&(this.y_range.reset_start=e[1],this.y_range.reset_end=e[3]),this._update_attribution()}_create_tile(t,e,i,s,_=!1){const n=this.model.tile_source.tile_xyz_to_quadkey(t,e,i),a=this.model.tile_source.tile_xyz_to_key(t,e,i);if(this.model.tile_source.tiles.has(a))return;const[h,o,r]=this.model.tile_source.normalize_xyz(t,e,i),l=this.model.tile_source.get_image_url(h,o,r),d={img:void 0,tile_coords:[t,e,i],normalized_coords:[h,o,r],quadkey:n,cache_key:a,bounds:s,loaded:!1,finished:!1,x_coord:s[0],y_coord:s[3]};this.model.tile_source.tiles.set(a,d),this._tiles.push(d),new m.ImageLoader(l,{loaded:t=>{Object.assign(d,{img:t,loaded:!0}),_?(d.finished=!0,this.notify_finished()):this.request_render()},failed(){d.finished=!0}})}_enforce_aspect_ratio(){if(this._last_height!==this.map_frame.bbox.height||this._last_width!==this.map_frame.bbox.width){const t=this.get_extent(),e=this.model.tile_source.get_level_by_extent(t,this.map_frame.bbox.height,this.map_frame.bbox.width),i=this.model.tile_source.snap_to_zoom_level(t,this.map_frame.bbox.height,this.map_frame.bbox.width,e);this.x_range.setv({start:i[0],end:i[2]}),this.y_range.setv({start:i[1],end:i[3]}),this.extent=i,this._last_height=this.map_frame.bbox.height,this._last_width=this.map_frame.bbox.width}}has_finished(){if(!super.has_finished())return!1;if(0==this._tiles.length)return!1;for(const t of this._tiles)if(!t.finished)return!1;return!0}_render(){null==this.map_initialized&&(this._set_data(),this._map_data(),this.map_initialized=!0),this._enforce_aspect_ratio(),this._update(),null!=this.prefetch_timer&&clearTimeout(this.prefetch_timer),this.prefetch_timer=setTimeout(this._prefetch_tiles.bind(this),500),this.has_finished()&&this.notify_finished()}_draw_tile(t){const e=this.model.tile_source.tiles.get(t);if(null!=e&&e.loaded){const[[t],[i]]=this.coordinates.map_to_screen([e.bounds[0]],[e.bounds[3]]),[[s],[_]]=this.coordinates.map_to_screen([e.bounds[2]],[e.bounds[1]]),n=s-t,a=_-i,h=t,o=i,r=this.map_canvas.imageSmoothingEnabled;this.map_canvas.imageSmoothingEnabled=this.model.smoothing,this.map_canvas.drawImage(e.img,h,o,n,a),this.map_canvas.imageSmoothingEnabled=r,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,o=!0),o&&(this.x_range.setv({start:s[0],end:s[2]}),this.y_range.setv({start:s[1],end:s[3]})),this.extent=s;const r=t.get_tiles_by_extent(s,h),l=[],d=[],m=[],u=[];for(const e of r){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),o=t.tile_xyz_to_key(e,a,h),r=t.tiles.get(o);if(null!=r&&r.loaded&&!(0,c.includes)(m,o)&&m.push(o),_){const e=t.children_by_tile_xyz(i,s,n);for(const[i,s,_]of e){const e=t.tile_xyz_to_key(i,s,_);t.tiles.has(e)&&u.push(e)}}}null==h&&l.push(e)}this._render_tiles(m),this._render_tiles(u),this._render_tiles(d),null!=this.render_timer&&clearTimeout(this.render_timer),this.render_timer=setTimeout((()=>this._fetch_tiles(l)),65)}}i.TileRendererView=g,g.__name__=\"TileRendererView\";class b extends r.Renderer{constructor(t){super(t)}}i.TileRenderer=b,n=b,b.__name__=\"TileRenderer\",n.prototype.default_view=g,n.define((({Boolean:t,Number:e,Ref:i})=>({alpha:[e,1],smoothing:[t,!0],tile_source:[i(h.TileSource),()=>new o.WMTSTileSource],render_parents:[t,!0]}))),n.override({level:\"image\"})},\n", - " function _(t,e,r,o,s){o();const c=t(424);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 _(o,e,i,l,t){l(),i.default=\":host{position:absolute;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;}a{color:black;}\"},\n", - " function _(e,r,t,c,o){c();const i=e(424);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(433).CanvasTexture),r(\"ImageURLTexture\",e(435).ImageURLTexture),r(\"Texture\",e(434).Texture)},\n", - " function _(t,e,n,c,s){var r;c();const o=t(434),a=t(38);class u extends o.Texture{constructor(t){super(t)}get func(){const t=(0,a.use_strict)(this.code);return new Function(\"ctx\",\"color\",\"scale\",\"weight\",t)}get_pattern(t,e,n){const c=document.createElement(\"canvas\");c.width=e,c.height=e;const s=c.getContext(\"2d\");return this.func.call(this,s,t,e,n),c}}n.CanvasTexture=u,r=u,u.__name__=\"CanvasTexture\",r.define((({String:t})=>({code:[t]})))},\n", - " function _(e,t,n,r,o){var i;r();const s=e(50),u=e(19);class c extends s.Model{constructor(e){super(e)}}n.Texture=c,i=c,c.__name__=\"Texture\",i.define((()=>({repetition:[u.TextureRepetition,\"repeat\"]})))},\n", - " function _(e,t,i,r,n){var a;r();const s=e(434),o=e(150);class u extends s.Texture{constructor(e){super(e)}initialize(){super.initialize(),this._loader=new o.ImageLoader(this.url)}get_pattern(e,t,i){const{_loader:r}=this;return this._loader.finished?r.image:r.promise}}i.ImageURLTexture=u,a=u,u.__name__=\"ImageURLTexture\",a.define((({String:e})=>({url:[e]})))},\n", - " function _(e,n,o,a,i){a();e(1).__exportStar(e(437),o),i(\"Dialog\",e(441).Dialog),i(\"Examiner\",e(445).Examiner),i(\"Pane\",e(447).Pane),i(\"Tooltip\",e(448).Tooltip),i(\"UIElement\",e(257).UIElement)},\n", - " function _(n,c,o,I,i){I(),i(\"BuiltinIcon\",n(438).BuiltinIcon),i(\"SVGIcon\",n(439).SVGIcon),i(\"TablerIcon\",n(440).TablerIcon)},\n", - " function _(e,n,t,i,s){var o;i();const r=e(1),a=e(378),l=e(56),c=e(21),m=e(8),u=r.__importDefault(e(269));class _ extends a.IconView{constructor(){super(...arguments),this._style=new l.InlineStyleSheet}stylesheets(){return[...super.stylesheets(),u.default,this._style]}render(){super.render();const e=`var(--bokeh-icon-${this.model.icon_name})`,n=(0,c.color2css)(this.model.color),t=(()=>{const{size:e}=this.model;return(0,m.isNumber)(e)?`${e}px`:e})();this._style.replace(`\\n :host {\\n display: inline-block;\\n vertical-align: middle;\\n width: ${t};\\n height: ${t};\\n background-color: ${n};\\n mask-image: ${e};\\n mask-size: contain;\\n mask-repeat: no-repeat;\\n -webkit-mask-image: ${e};\\n -webkit-mask-size: contain;\\n -webkit-mask-repeat: no-repeat;\\n }\\n `)}}t.BuiltinIconView=_,_.__name__=\"BuiltinIconView\";class d extends a.Icon{constructor(e){super(e)}}t.BuiltinIcon=d,o=d,d.__name__=\"BuiltinIcon\",o.prototype.default_view=_,o.define((({String:e,Color:n})=>({icon_name:[e],color:[n,\"gray\"]})))},\n", - " function _(e,n,s,t,r){var i;t();const o=e(378),l=e(56),c=e(8);class a extends o.IconView{constructor(){super(...arguments),this._style=new l.InlineStyleSheet}stylesheets(){return[...super.stylesheets(),this._style]}render(){super.render();const e=(()=>{const{size:e}=this.model;return(0,c.isNumber)(e)?`${e}px`:e})();this._style.replace(`\\n :host {\\n display: inline-block;\\n vertical-align: middle;\\n }\\n :host svg {\\n width: ${e};\\n height: ${e};\\n }\\n `);const n=(new DOMParser).parseFromString(this.model.svg,\"image/svg+xml\");this.shadow_el.append(n.documentElement)}}s.SVGIconView=a,a.__name__=\"SVGIconView\";class d extends o.Icon{constructor(e){super(e)}}s.SVGIcon=d,i=d,d.__name__=\"SVGIcon\",i.prototype.default_view=a,i.define((({String:e})=>({svg:[e]})))},\n", - " function _(e,n,t,s,r){var o,l;s();const i=e(378),a=e(56),c=e(8);class f extends i.IconView{constructor(){super(...arguments),this._tabler=new a.ImportedStyleSheet(`${f._url}/tabler-icons.min.css`),this._style=new a.InlineStyleSheet}stylesheets(){return[...super.stylesheets(),f._fonts,this._tabler,this._style]}render(){super.render();const e=(()=>{const{size:e}=this.model;return(0,c.isNumber)(e)?`${e}px`:e})();this._style.replace(`\\n :host {\\n display: inline-block;\\n vertical-align: middle;\\n font-size: ${e};\\n }\\n `);const n=(0,a.span)({class:[\"ti\",`ti-${this.model.icon_name}`]});this.shadow_el.appendChild(n)}}t.TablerIconView=f,o=f,f.__name__=\"TablerIconView\",f._url=\"https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@latest\",f._fonts=new a.GlobalInlineStyleSheet(` /*!\\n * Tabler Icons 1.68.0 by tabler - https://tabler.io\\n * License - https://github.com/tabler/tabler-icons/blob/master/LICENSE\\n */\\n @font-face {\\n font-family: \"tabler-icons\";\\n font-style: normal;\\n font-weight: 400;\\n src: url(\"${o._url}/fonts/tabler-icons.eot\");\\n src: url(\"${o._url}/fonts/tabler-icons.eot?#iefix\") format(\"embedded-opentype\"),\\n url(\"${o._url}/fonts/tabler-icons.woff2\") format(\"woff2\"),\\n url(\"${o._url}/fonts/tabler-icons.woff\") format(\"woff\"),\\n url(\"${o._url}/fonts/tabler-icons.ttf\") format(\"truetype\"),\\n url(\"${o._url}/fonts/tabler-icons.svg#tabler-icons\") format(\"svg\");\\n }\\n\\n @media screen and (-webkit-min-device-pixel-ratio: 0) {\\n @font-face {\\n font-family: \"tabler-icons\";\\n src: url(\"${o._url}/fonts/tabler-icons.svg#tabler-icons\") format(\"svg\");\\n }\\n }\\n`);class b extends i.Icon{constructor(e){super(e)}}t.TablerIcon=b,l=b,b.__name__=\"TablerIcon\",l.prototype.default_view=f,l.define((({String:e})=>({icon_name:[e]})))},\n", - " function _(e,t,i,s,n){var l;s();const o=e(1),a=e(257),d=e(442),r=e(443),c=e(56),h=e(8),_=e(59),p=o.__importStar(e(444)),u=p,m=o.__importDefault(e(269)),v=a.UIElement;class w extends a.UIElementView{*children(){yield*super.children(),yield this._content}stylesheets(){return[...super.stylesheets(),p.default,m.default]}async lazy_initialize(){await super.lazy_initialize();const e=(()=>{const{content:e}=this.model;return(0,h.isString)(e)?new r.Text({content:e}):e})();this._content=await(0,_.build_view)(e,{parent:this})}connect_signals(){super.connect_signals();const{visible:e}=this.model.properties;this.on_change(e,(()=>this.render()))}remove(){this._content.remove(),super.remove()}render(){if(super.render(),!this.model.visible)return void this.el.remove();document.body.appendChild(this.el),this._content.render();const e=(0,c.div)({class:u.title}),t=(0,c.div)({class:u.content},this._content.el),i=(0,c.div)({class:u.buttons});if(this.shadow_el.appendChild(e),this.shadow_el.appendChild(t),this.shadow_el.appendChild(i),this.model.closable){const e=(0,c.div)({class:u.close});e.addEventListener(\"click\",(()=>this.model.visible=!1)),this.shadow_el.appendChild(e)}}}i.DialogView=w,w.__name__=\"DialogView\";class b extends a.UIElement{constructor(e){super(e)}}i.Dialog=b,l=b,b.__name__=\"Dialog\",l.prototype.default_view=w,l.define((({Boolean:e,String:t,Array:i,Ref:s,Or:n,Nullable:l})=>({title:[l(n(t,s(d.DOMNode))),null],content:[n(t,s(d.DOMNode),s(a.UIElement))],buttons:[i(s(v)),[]],modal:[e,!1],closable:[e,!0],draggable:[e,!0]})))},\n", - " function _(e,o,_,d,s){d();const n=e(55),c=e(50);class t extends n.DOMView{}_.DOMNodeView=t,t.__name__=\"DOMNodeView\";class M extends c.Model{constructor(e){super(e)}}_.DOMNode=M,M.__name__=\"DOMNode\",M.__module__=\"bokeh.models.dom\"},\n", - " function _(e,t,n,o,r){var c;o();const s=e(442);class _ extends s.DOMNodeView{render(){this.el.textContent=this.model.content}_createElement(){return document.createTextNode(\"\")}}n.TextView=_,_.__name__=\"TextView\";class d extends s.DOMNode{constructor(e){super(e)}}n.Text=d,c=d,d.__name__=\"Text\",c.prototype.default_view=_,c.define((({String:e})=>({content:[e,\"\"]})))},\n", - " function _(o,e,t,i,r){i(),t.title=\"bk-title\",t.content=\"bk-content\",t.buttons=\"bk-buttons\",t.close=\"bk-close\",t.default=\":host{--bokeh-bg-color:white;--bokeh-border-color:#e5e5e5;--bokeh-shadow-color:#e5e5e5;}:host{position:fixed;z-index:1000;left:0;right:0;top:0;bottom:0;margin-left:auto;margin-right:auto;margin-top:auto;margin-bottom:auto;width:80vw;height:60vh;overflow:hidden;display:flex;flex-direction:column;flex-wrap:nowrap;background-color:var(--bokeh-bg-color);border:1px solid var(--bokeh-border-color);box-shadow:5px 5px 10px var(--bokeh-shadow-color);}.bk-title{position:relative;flex:1;min-height:0;}.bk-content{position:relative;flex:1;min-height:100%;display:flex;}.bk-buttons{position:relative;flex:1;min-height:0;}.bk-close{position:absolute;top:0;right:0;width:18px;height:18px;cursor:pointer;background-color:gray;mask-image:var(--bokeh-icon-x);mask-size:contain;mask-repeat:no-repeat;-webkit-mask-image:var(--bokeh-icon-x);-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;}.bk-close:hover{background-color:red;}\"},\n", - " function _(t,e,s,n,o){var i;n();const a=t(1),l=t(257),r=a.__importStar(t(17)),c=t(14),d=t(56),p=t(40),h=t(50),u=t(8),f=t(9),_=t(10),v=t(32),g=t(15),m=t(36),b=a.__importDefault(t(446));class y{constructor(t,e,s){this.visited=new WeakSet,this.depth=0,this.click=t,this.max_items=e,this.max_depth=s}to_html(t){if((0,u.isObject)(t)){if(this.visited.has(t))return(0,d.span)(\"\");this.visited.add(t)}return null==t?this.null():(0,u.isBoolean)(t)?this.boolean(t):(0,u.isNumber)(t)?this.number(t):(0,u.isString)(t)?this.string(t):(0,u.isSymbol)(t)?this.symbol(t):t instanceof h.Model?this.model(t):t instanceof r.Property?this.property(t):(0,u.isPlainObject)(t)?this.object(t):(0,u.isArray)(t)?this.array(t):(0,u.isIterable)(t)?this.iterable(t):(0,d.span)((0,p.to_string)(t))}null(){return(0,d.span)({class:\"null\"},\"null\")}token(t){return(0,d.span)({class:\"token\"},t)}boolean(t){return(0,d.span)({class:\"boolean\"},`${t}`)}number(t){return(0,d.span)({class:\"number\"},`${t}`)}string(t){const e=t.includes(\"'\"),s=t.includes('\"'),n=e&&s?`\\`${t.replace(/`/g,\"\\\\`\")}\\``:s?`'${t}'`:`\"${t}\"`;return(0,d.span)({class:\"string\"},n)}symbol(t){return(0,d.span)({class:\"symbol\"},t.toString())}array(t){const e=this.token,s=[];let n=0;for(const e of t)if(s.push(this.to_html(e)),n++>this.max_items){s.push((0,d.span)(\"\\u2026\"));break}return(0,d.span)({class:\"array\"},e(\"[\"),...(0,v.interleave)(s,(()=>e(\", \"))),e(\"]\"))}iterable(t){var e;const s=this.token,n=null!==(e=Object(t)[Symbol.toStringTag])&&void 0!==e?e:\"Object\",o=this.array([...t]);return(0,d.span)({class:\"iterable\"},`${n}`,s(\"(\"),o,s(\")\"))}object(t){const e=this.token,s=[];let n=0;for(const[o,i]of(0,f.entries)(t))if(s.push((0,d.span)(`${o}`,e(\": \"),this.to_html(i))),n++>this.max_items){s.push((0,d.span)(\"\\u2026\"));break}return(0,d.span)({class:\"object\"},e(\"{\"),...(0,v.interleave)(s,(()=>e(\", \"))),e(\"}\"))}model(t){const e=this.token,s=(0,d.span)({class:\"model\"},t.constructor.__qualified__,e(\"(\"),this.to_html(t.id),e(\")\"));return s.addEventListener(\"click\",(()=>this.click(t))),s}property(t){const e=this.model(t.obj),s=(0,d.span)({class:\"attr\"},t.attr);return(0,d.span)(e,this.token(\".\"),s)}}s.HTMLPrinter=y,y.__name__=\"HTMLPrinter\";class k extends l.UIElementView{constructor(){super(...arguments),this.prev_listener=null,this.watched_props=new Set}stylesheets(){return[...super.stylesheets(),b.default]}render(){super.render(),null!=this.prev_listener&&m.diagnostics.disconnect(this.prev_listener);const t=[],e=[],s=[],n=new WeakMap;m.diagnostics.connect((o=>{if(o instanceof r.Property){for(const[e,s]of t)e==o.obj&&i(s);for(const[t,s]of e)if(t==o){const[,,,e]=s.children;a(t,s,e);break}for(const[t,e]of s)if(t==o){const[,s]=e.children;a(t,e,s);break}}function i(t){const e=n.get(t);null!=e&&e.cancel();const s=t.animate([{backgroundColor:\"#def189\"},{backgroundColor:\"initial\"}],{duration:2e3});n.set(t,s)}function a(t,e,s){e.classList.toggle(\"dirty\",t.dirty),(0,d.empty)(s);const n=t.is_unset?(0,d.span)(\"unset\"):C(t.get_value());s.appendChild(n),i(s)}}));const o=(()=>{const e=(0,d.input)({class:\"filter\",type:\"text\",placeholder:\"Filter\"});return e.addEventListener(\"keyup\",(()=>{const s=e.value;for(const[e,n]of t){const t=e.constructor.__qualified__.includes(s);n.classList.toggle(\"hidden\",!t)}})),(0,d.div)({class:\"toolbar\"},e)})(),i=(0,d.input)({type:\"checkbox\",checked:!0}),a=(0,d.input)({type:\"checkbox\",checked:!0}),l=()=>{for(const[t,s]of e){const e=i.checked,n=a.checked,o=!t.dirty&&!e||t.internal&&!n;s.classList.toggle(\"hidden\",o)}};i.addEventListener(\"change\",(()=>l())),a.addEventListener(\"change\",(()=>l()));const p=(()=>{const t=(0,d.input)({class:\"filter\",type:\"text\",placeholder:\"Filter\"}),s=(0,d.span)({class:\"checkbox\"},(0,d.input)({type:\"checkbox\",checked:!0}),(0,d.span)(\"Group\")),n=(0,d.span)({class:\"checkbox\"},i,(0,d.span)(\"Initial?\")),o=(0,d.span)({class:\"checkbox\"},a,(0,d.span)(\"Internal?\"));return t.addEventListener(\"keyup\",(()=>{const s=t.value;for(const[t,n]of e){const e=t.attr.includes(s);n.classList.toggle(\"hidden\",!e)}})),(0,d.div)({class:\"toolbar\"},t,s,n,o)})(),u=(()=>{const t=(0,d.input)({class:\"filter\",type:\"text\",placeholder:\"Filter\"});return t.addEventListener(\"keyup\",(()=>{const e=t.value;for(const[t,n]of s){const s=t.attr.includes(e);n.classList.toggle(\"hidden\",!s)}})),(0,d.div)({class:\"toolbar\"},t)})(),v=(0,d.div)({class:\"models-list\"}),b=(0,d.div)({class:\"props-list\"}),k=(0,d.div)({class:\"watches-list\"}),x=(0,d.div)({class:\"models-panel\"},o,v),w=(0,d.div)({class:\"props-panel\"},p,b),L=(0,d.div)({class:\"watches-panel\"},u,k),E=(0,d.div)({class:\"col\",style:{width:\"100%\"}},L,w),j=(0,d.div)({class:\"examiner\"},x,E);function S(t){t instanceof h.Model&&O(t)}function C(t){return new y(S,5,3).to_html(t)}const P=(e,s)=>{(0,_.clear)(t),(0,d.empty)(v);const n=null!=s?new Set(s.roots()):new Set;for(const s of e){const e=n.has(s)?(0,d.span)({class:\"tag\"},\"root\"):null,o=(0,d.span)({class:\"model-ref\",tabIndex:0},C(s),e);o.addEventListener(\"keydown\",(t=>{\"Enter\"==t.key&&O(s)})),t.push([s,o]),v.appendChild(o)}},O=s=>{var n;(0,_.clear)(e),(0,d.empty)(b);for(const[e,n]of t)n.classList.toggle(\"active\",s==e);const o=(()=>{const t=[];let e=Object.getPrototypeOf(s);do{t.push([e.constructor,(0,f.keys)(e._props)]),e=Object.getPrototypeOf(e)}while(e.constructor!=c.HasProps);t.reverse();const n=[];for(const[,e]of t)e.splice(0,n.length),n.push(...e);return t})(),l=null!==(n=g.receivers_for_sender.get(s))&&void 0!==n?n:[];for(const[t,n]of o){if(0==n.length)continue;const o=(0,d.span)({class:[\"expander\"]}),r=(0,d.div)({class:\"base\"},o,\"inherited from\",\" \",(0,d.span)({class:\"monospace\"},t.__qualified__));b.appendChild(r);const c=[];for(const t of n){const n=s.property(t),o=n.kind.toString(),r=n.is_unset?(0,d.span)(\"unset\"):C(n.get_value()),p=n.internal?(0,d.span)({class:\"tag\"},\"internal\"):null,h=l.filter((t=>t.signal==n.change)).length,u=0!=h?(0,d.span)({class:\"tag\"},`${h}`):null,f=this.watched_props.has(n),_=(0,d.input)({type:\"checkbox\",checked:f}),v=(0,d.div)({class:\"prop-attr\",tabIndex:0},_,(0,d.span)({class:\"attr\"},t),p),g=(0,d.div)({class:\"prop-conns\"},u),m=(0,d.div)({class:\"prop-kind\"},o),y=(0,d.div)({class:\"prop-value\"},r),k=n.dirty?\"dirty\":null,x=n.internal?\"internal\":null,w=i.checked,L=a.checked,E=!n.dirty&&!w||n.internal&&!L?\"hidden\":null,j=(0,d.div)({class:[\"prop\",k,x,E]},v,g,m,y);c.push(j),e.push([n,j]),b.appendChild(j),_.addEventListener(\"change\",(()=>{this.watched_props[_.checked?\"add\":\"delete\"](n),$()}))}r.addEventListener(\"click\",(()=>{o.classList.toggle(\"closed\");for(const t of c)t.classList.toggle(\"closed\")}))}},$=()=>{if((0,_.clear)(s),(0,d.empty)(k),0==this.watched_props.size){const t=(0,d.div)({class:\"nothing\"},\"No watched properties\");k.appendChild(t)}else for(const t of this.watched_props){const e=(0,d.span)(C(t)),n=(0,d.span)(t.is_unset?(0,d.span)(\"unset\"):C(t.get_value())),o=(0,d.div)({class:[\"prop\",t.dirty?\"dirty\":null]},e,n);s.push([t,o]),k.appendChild(o)}};this.shadow_el.appendChild(j);const{target:I}=this.model;if(null!=I){const t=I.references(),{document:e}=I;P(t,e),O(I)}else{const{document:t}=this.model;if(null!=t){P(t._all_models.values(),t);const e=t.roots();if(0!=e.length){const[t]=e;O(t)}}}$()}}s.ExaminerView=k,k.__name__=\"ExaminerView\";class x extends l.UIElement{constructor(t){super(t)}}s.Examiner=x,i=x,x.__name__=\"Examiner\",i.prototype.default_view=k,i.define((({Ref:t,Nullable:e})=>({target:[e(t(c.HasProps)),null]})))},\n", - " function _(o,e,r,i,l){i(),r.default='.null{color:#7724c1;}.token{color:#881280;}.boolean{color:#007500;}.number{color:#1a1aa6;}.string{color:#994500;}.symbol{color:#c80000;}.model{cursor:pointer;}.attr{color:#c80000;}:root{--common-padding:3px;--common-outline:#1a73e8 solid 1px;--panel-bg-color:#f1f3f4;--panel-border-color:#cacdd1;}.monospace{font-family:var(--mono-font);}.hidden{display:none !important;}.col{display:flex;flex-direction:column;}.row{display:flex;flex-direction:row;}.toolbar{display:flex;flex-direction:row;gap:1em;background-color:var(--panel-bg-color);border-bottom:1px solid var(--panel-border-color);padding:var(--common-padding);}.checkbox{display:flex;flex-direction:row;align-items:center;gap:0.25em;}.filter:focus{outline:var(--common-outline);}.examiner{height:100%;display:flex;border:1px solid var(--panel-border-color);}.models-panel{display:flex;flex-direction:column;border-right:1px solid var(--panel-border-color);}.props-panel{display:flex;flex-direction:column;height:100%;overflow:auto;}.watches-panel{display:flex;flex-direction:column;border-bottom:1px solid var(--panel-border-color);}.models-list{display:flex;flex-direction:column;height:min-content;padding:var(--common-padding);overflow-x:hidden;overflow-y:auto;}.props-list{display:grid;grid-template-columns:min-content min-content 1fr 1fr;column-gap:1em;padding:var(--common-padding);}.watches-list{display:grid;grid-template-columns:1fr 1fr;column-gap:1em;padding:var(--common-padding);}.nothing{grid-column:1 / span 2;font-style:italic;text-align:center;}.prop{display:contents;}.prop.closed{display:none;}.prop > *{opacity:0.6;}.prop.dirty > *{opacity:1;}.model-ref{display:flex;align-items:center;flex-direction:row;font-family:var(--mono-font);}.model-ref:focus-visible{outline:var(--common-outline);}.model-ref:hover{background-color:#e2e2e2;}.model-ref.active{background-color:#c8e0ee;}.tag{margin-left:1em;padding:0 4px;font-size:60%;border-width:1px;border-style:solid;border-radius:4px;color:#202124;background-color:#f1f3f4;border-color:#cacdd1;}.expander{margin:0 2px;display:inline-block;vertical-align:middle;background-color:#5f6368;--open-image:url(\\'data:image/svg+xml;utf8, \\');--closed-image:url(\\'data:image/svg+xml;utf8, \\');}.expander{width:6px;height:6px;mask-image:var(--open-image);-webkit-mask-image:var(--open-image);}.expander.closed{width:6px;height:6px;mask-image:var(--closed-image);-webkit-mask-image:var(--closed-image);}.base{grid-column:1 / span 4;color:#5f6368;cursor:pointer;}.prop-attr,.prop-conns,.prop-kind,.prop-value{display:flex;flex-direction:row;align-items:center;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-family:var(--mono-font);}.prop-attr > input[type=\"checkbox\"]{visibility:hidden;margin-right:0.25em;}.prop-attr > input[type=\"checkbox\"]:checked,.prop-attr:hover > input{visibility:visible;}.prop-attr:focus-visible{outline:var(--common-outline);}'},\n", - " function _(e,i,s,t,n){var r;t();const l=e(257),_=e(59),a=e(8);class h extends l.UIElementView{constructor(){super(...arguments),this._child_views=new Map}get _ui_elements(){return this.model.children.filter((e=>e instanceof l.UIElement))}get child_views(){return this._ui_elements.map((e=>this._child_views.get(e)))}*children(){yield*super.children(),yield*this._child_views.values()}async lazy_initialize(){await super.lazy_initialize(),await this._rebuild_views()}async _rebuild_views(){await(0,_.build_views)(this._child_views,this._ui_elements,{parent:this})}remove(){(0,_.remove_views)(this._child_views),super.remove()}connect_signals(){super.connect_signals();const{children:e}=this.model.properties;this.on_change(e,(()=>{this._rebuild_views(),this.render()}))}render(){super.render();for(const e of this.model.children)if((0,a.isString)(e)){const i=document.createTextNode(e);this.shadow_el.append(i)}else{const i=this._child_views.get(e);i.render(),this.shadow_el.append(i.el),i.after_render()}}has_finished(){if(!super.has_finished())return!1;for(const e of this.child_views)if(!e.has_finished())return!1;return!0}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{children:this.child_views.map((e=>e.serializable_state()))})}}s.PaneView=h,h.__name__=\"PaneView\";class d extends l.UIElement{constructor(e){super(e)}}s.Pane=d,r=d,d.__name__=\"Pane\",r.prototype.default_view=h,r.define((({String:e,Array:i,Ref:s,Or:t})=>({children:[i(t(e,s(l.UIElement))),[]]})))},\n", - " function _(t,e,i,s,r){var n;s();const o=t(1),l=t(257),a=t(413),c=t(449),h=t(19),u=t(56),_=t(55),d=t(8),g=t(12),m=t(18),p=t(59),v=o.__importStar(t(450)),b=v,f=o.__importDefault(t(269));class w extends l.UIElementView{constructor(){super(...arguments),this._html=null}get target(){return this._target}_init_target(){const{target:t}=this.model,e=(()=>{var e,i;if(t instanceof l.UIElement)return null!==(i=null===(e=this.owner.find_one(t))||void 0===e?void 0:e.el)&&void 0!==i?i:null;if(t instanceof a.Selector)return t.find_one(document);if(t instanceof Node)return t;{const{parent:t}=this;return t instanceof _.DOMElementView?t.el:null}})();e instanceof Element?this._target=e:(m.logger.warn(`unable to resolve target '${t}' for '${this}'`),this._target=document.body)}initialize(){super.initialize(),this._init_target()}*children(){yield*super.children(),null!=this._html&&(yield this._html)}async lazy_initialize(){await super.lazy_initialize();const{content:t}=this.model;t instanceof c.HTML&&(this._html=await(0,p.build_view)(t,{parent:this})),this.render()}connect_signals(){super.connect_signals(),this._observer=new ResizeObserver((()=>{this._reposition()})),this._observer.observe(this.target);const{target:t,content:e,closable:i,interactive:s,position:r,attachment:n,visible:o}=this.model.properties;this.on_change(t,(()=>{this._init_target(),this._observer.disconnect(),this._observer.observe(this.target),this.render()})),this.on_change([e,i,s],(()=>this.render())),this.on_change([r,n,o],(()=>this._reposition()))}remove(){var t;null===(t=this._html)||void 0===t||t.remove(),this._observer.disconnect(),super.remove()}stylesheets(){return[...super.stylesheets(),v.default,f.default]}get content(){const{content:t}=this.model;return(0,d.isString)(t)?document.createTextNode(t):t instanceof c.HTML?((0,g.assert)(null!=this._html),this._html.el):t}render(){var t;if(super.render(),null===(t=this._html)||void 0===t||t.render(),this.content_el=(0,u.div)({class:b.tooltip_content},this.content),this.shadow_el.appendChild(this.content_el),this.model.closable){const t=(0,u.div)({class:b.close});t.addEventListener(\"click\",(()=>{this.model.visible=!1})),this.shadow_el.appendChild(t)}this.el.classList.toggle(b.tooltip_arrow,this.model.show_arrow),this.el.classList.toggle(b.non_interactive,!this.model.interactive),this._reposition()}_anchor_to_align(t){switch(t){case\"top_left\":return[\"top\",\"left\"];case\"top\":case\"top_center\":return[\"top\",\"center\"];case\"top_right\":return[\"top\",\"right\"];case\"left\":case\"center_left\":return[\"center\",\"left\"];case\"center\":case\"center_center\":return[\"center\",\"center\"];case\"right\":case\"center_right\":return[\"center\",\"right\"];case\"bottom_left\":return[\"bottom\",\"left\"];case\"bottom\":case\"bottom_center\":return[\"bottom\",\"center\"];case\"bottom_right\":return[\"bottom\",\"right\"]}}_reposition(){var t;const{position:e,visible:i}=this.model;if(null==e||!i)return void this.el.remove();(null!==(t=this.target.shadowRoot)&&void 0!==t?t:this.target).appendChild(this.el);const s=(0,u.bounding_box)(this.target).relative(),[r,n]=(()=>{if((0,d.isString)(e)){const[t,i]=this._anchor_to_align(e);return[(()=>{switch(i){case\"left\":return s.left;case\"center\":return s.hcenter;case\"right\":return s.right}})(),(()=>{switch(t){case\"top\":return s.top;case\"center\":return s.vcenter;case\"bottom\":return s.bottom}})()]}return e})(),o=(()=>{const t=(()=>{const{attachment:t}=this.model;if(\"auto\"==t){if((0,d.isString)(e)){const[t,i]=this._anchor_to_align(e);if(\"center\"!=i)return\"left\"==i?\"left\":\"right\";if(\"center\"!=t)return\"top\"==t?\"above\":\"below\"}return\"horizontal\"}return t})();switch(t){case\"horizontal\":return r({target:[r(n(l.UIElement),n(a.Selector),n(Node),u),\"auto\"],position:[o(r(h.Anchor,s(e,e))),null],content:[r(i,n(c.HTML),n(Node))],attachment:[r(h.TooltipAttachment,u),\"auto\"],show_arrow:[t,!0],closable:[t,!1],interactive:[t,!0]}))),n.override({visible:!1})},\n", - " function _(e,t,r,s,i){var n;s();const o=e(442),l=e(257),d=e(59),a=e(56),c=e(12),_=e(8);class f extends o.DOMNodeView{constructor(){super(...arguments),this._refs=new Map}*children(){yield*super.children(),yield*this._refs.values()}async lazy_initialize(){await super.lazy_initialize(),await(0,d.build_views)(this._refs,this.model.refs)}remove(){(0,d.remove_views)(this._refs),super.remove()}render(){(0,a.empty)(this.el),this.el.style.display=\"contents\";const e=new DOMParser,t=(()=>{const{html:t}=this.model;if((0,_.isString)(t)){const r=e.parseFromString(t,\"text/html\"),s=r.createNodeIterator(r,NodeFilter.SHOW_ELEMENT,(e=>\"ref\"==e.nodeName.toLowerCase()?NodeFilter.FILTER_ACCEPT:NodeFilter.FILTER_REJECT));let i;for(;null!=(i=s.nextNode());){(0,c.assert)(i instanceof Element);const e=i.getAttribute(\"id\");if(null!=e)for(const[t,r]of this._refs)if(t.id==e){r.render(),i.replaceWith(r.el);break}}return[...r.body.childNodes]}return[]})();for(const e of t)this.el.appendChild(e)}}r.HTMLView=f,f.__name__=\"HTMLView\";class h extends o.DOMNode{constructor(e){super(e)}}r.HTML=h,n=h,h.__name__=\"HTML\",n.prototype.default_view=f,n.define((({String:e,Array:t,Or:r,Ref:s})=>({html:[r(e,t(r(e,s(o.DOMNode),s(l.UIElement))))],refs:[t(r(s(o.DOMNode),s(l.UIElement))),[]]})))},\n", - " function _(o,t,r,i,l){i(),r.non_interactive=\"bk-non-interactive\",r.tooltip_content=\"bk-tooltip-content\",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.close=\"bk-close\",r.default=':host{--tooltip-border:#e5e5e5;--tooltip-color:white;--tooltip-text:#2f2f2f;--tooltip-arrow-color:#909599;--tooltip-arrow-width:10px;--tooltip-arrow-height:10px;--tooltip-arrow-half-width:7px;--tooltip-arrow-half-height:7px;}:host{width:max-content;font-weight:300;font-size:12px;position:absolute;padding:5px;border:1px solid var(--tooltip-border);color:var(--tooltip-text);background-color:var(--tooltip-color);opacity:0.95;z-index:100;}:host(.bk-non-interactive){pointer-events:none;}.bk-tooltip-content > div:not(:first-child){margin-top:5px;border-top:var(--tooltip-border) 1px dashed;}:host(.bk-left.bk-tooltip-arrow) .bk-tooltip-content::before{position:absolute;margin:calc(-1*var(--tooltip-arrow-half-height)) 0 0 0;top:50%;width:0;height:0;border-style:solid;border-width:var(--tooltip-arrow-half-height) 0 var(--tooltip-arrow-half-height) 0;border-color:transparent;content:\" \";display:block;left:calc(-1*var(--tooltip-arrow-width));border-right-width:var(--tooltip-arrow-width);border-right-color:var(--tooltip-arrow-color);}:host(.bk-left) .bk-tooltip-content::before{left:calc(-1*var(--tooltip-arrow-width));border-right-width:var(--tooltip-arrow-width);border-right-color:var(--tooltip-arrow-color);}:host(.bk-right.bk-tooltip-arrow) .bk-tooltip-content::after{position:absolute;margin:calc(-1*var(--tooltip-arrow-half-height)) 0 0 0;top:50%;width:0;height:0;border-style:solid;border-width:var(--tooltip-arrow-half-height) 0 var(--tooltip-arrow-half-height) 0;border-color:transparent;content:\" \";display:block;right:calc(-1*var(--tooltip-arrow-width));border-left-width:var(--tooltip-arrow-width);border-left-color:var(--tooltip-arrow-color);}:host(.bk-right) .bk-tooltip-content::after{right:calc(-1*var(--tooltip-arrow-width));border-left-width:var(--tooltip-arrow-width);border-left-color:var(--tooltip-arrow-color);}:host(.bk-above) .bk-tooltip-content::before{position:absolute;margin:0 0 0 calc(-1*var(--tooltip-arrow-half-width));left:50%;width:0;height:0;border-style:solid;border-width:0 var(--tooltip-arrow-half-width) 0 var(--tooltip-arrow-half-width);border-color:transparent;content:\" \";display:block;top:calc(-1*var(--tooltip-arrow-height));border-bottom-width:var(--tooltip-arrow-height);border-bottom-color:var(--tooltip-arrow-color);}:host(.bk-below) .bk-tooltip-content::after{position:absolute;margin:0 0 0 calc(-1*var(--tooltip-arrow-half-width));left:50%;width:0;height:0;border-style:solid;border-width:0 var(--tooltip-arrow-half-width) 0 var(--tooltip-arrow-half-width);border-color:transparent;content:\" \";display:block;bottom:calc(-1*var(--tooltip-arrow-height));border-top-width:var(--tooltip-arrow-height);border-top-color:var(--tooltip-arrow-color);}.bk-tooltip-row-label{text-align:right;color:#26aae1;}.bk-tooltip-row-value{color:none;}.bk-tooltip-color-block{width:12px;height:12px;margin-left:5px;margin-right:5px;outline:#dddddd solid 1px;display:inline-block;}.bk-close{position:absolute;top:2px;right:2px;width:12px;height:12px;cursor:pointer;background-color:gray;mask-image:var(--bokeh-icon-x);mask-size:contain;mask-repeat:no-repeat;-webkit-mask-image:var(--bokeh-icon-x);-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;}.bk-close:hover{background-color:red;}'},\n", - " function _(o,t,r,n,l){n();const _=o(1);_.__exportStar(o(452),r),_.__exportStar(o(466),r),_.__exportStar(o(476),r),_.__exportStar(o(488),r),l(\"Tool\",o(264).Tool),l(\"ToolProxy\",o(265).ToolProxy),l(\"Toolbar\",o(256).Toolbar),l(\"ToolButton\",o(266).ToolButton),l(\"OnOffButton\",o(272).OnOffButton),l(\"ClickButton\",o(275).ClickButton)},\n", - " function _(o,l,T,e,n){e(),n(\"ActionTool\",o(274).ActionTool),n(\"CopyTool\",o(453).CopyTool),n(\"CustomAction\",o(454).CustomAction),n(\"FullscreenTool\",o(455).FullscreenTool),n(\"HelpTool\",o(276).HelpTool),n(\"ExamineTool\",o(456).ExamineTool),n(\"RedoTool\",o(457).RedoTool),n(\"ResetTool\",o(459).ResetTool),n(\"SaveTool\",o(460).SaveTool),n(\"UndoTool\",o(461).UndoTool),n(\"ZoomInTool\",o(462).ZoomInTool),n(\"ZoomOutTool\",o(465).ZoomOutTool)},\n", - " function _(o,t,e,i,a){var n;i();const c=o(274),p=o(269);class s extends c.ActionToolView{async copy(){const o=await this.parent.export().to_blob(),t=new ClipboardItem({[o.type]:o});await navigator.clipboard.write([t])}doit(){this.copy()}}e.CopyToolView=s,s.__name__=\"CopyToolView\";class l extends c.ActionTool{constructor(o){super(o),this.tool_name=\"Copy\",this.tool_icon=p.tool_icon_copy}}e.CopyTool=l,n=l,l.__name__=\"CopyTool\",n.prototype.default_view=s,n.register_alias(\"copy\",(()=>new l))},\n", - " function _(o,t,n,e,i){var c;e();const l=o(1),s=o(274),_=l.__importStar(o(269));class a extends s.ActionToolView{doit(){var o;null===(o=this.model.callback)||void 0===o||o.execute(this.model)}}n.CustomActionView=a,a.__name__=\"CustomActionView\";class u extends s.ActionTool{constructor(o){super(o),this.tool_name=\"Custom Action\",this.tool_icon=_.tool_icon_unknown}}n.CustomAction=u,c=u,u.__name__=\"CustomAction\",c.prototype.default_view=a,c.define((({Any:o,Nullable:t})=>({callback:[t(o),null]}))),c.override({description:\"Perform a Custom Action\"})},\n", - " function _(e,l,o,t,n){var s;t();const c=e(1),r=e(274),u=c.__importStar(e(269)),i=void 0!==Element.prototype.webkitRequestFullscreen?(e,l)=>e.webkitRequestFullscreen(l):(e,l)=>e.requestFullscreen(l);class _ extends r.ActionToolView{doit(){null!=document.fullscreenElement?document.exitFullscreen():(async()=>{await i(this.parent.el)})()}}o.FullscreenToolView=_,_.__name__=\"FullscreenToolView\";class a extends r.ActionTool{constructor(e){super(e),this.tool_name=\"Fullscreen\",this.tool_icon=u.tool_icon_fullscreen}}o.FullscreenTool=a,s=a,a.__name__=\"FullscreenTool\",s.prototype.default_view=_,s.register_alias(\"fullscreen\",(()=>new a))},\n", - " function _(i,e,o,t,a){var n;t();const l=i(1),s=i(274),_=l.__importStar(i(269)),r=i(441),c=i(445),d=i(59);class m extends s.ActionToolView{*children(){yield*super.children(),yield this._dialog}async lazy_initialize(){await super.lazy_initialize();const i=new r.Dialog({content:new c.Examiner({target:this.parent.model}),closable:!0,visible:!1});this._dialog=await(0,d.build_view)(i,{parent:this.parent})}doit(){this._dialog.model.visible=!0}}o.ExamineToolView=m,m.__name__=\"ExamineToolView\";class w extends s.ActionTool{constructor(i){super(i),this.tool_name=\"Examine\",this.tool_icon=_.tool_icon_settings}}o.ExamineTool=w,n=w,w.__name__=\"ExamineTool\",n.prototype.default_view=m,n.register_alias(\"examine\",(()=>new w))},\n", - " function _(o,e,t,i,s){var n;i();const l=o(458),_=o(269);class d extends l.PlotActionToolView{connect_signals(){super.connect_signals(),this.connect(this.plot_view.state.changed,(()=>this.model.disabled=!this.plot_view.state.can_redo))}doit(){const o=this.plot_view.state.redo();null!=(null==o?void 0:o.range)&&this.plot_view.trigger_ranges_update_event()}}t.RedoToolView=d,d.__name__=\"RedoToolView\";class a extends l.PlotActionTool{constructor(o){super(o),this.tool_name=\"Redo\",this.tool_icon=_.tool_icon_redo}}t.RedoTool=a,n=a,a.__name__=\"RedoTool\",n.prototype.default_view=d,n.override({disabled:!0}),n.register_alias(\"redo\",(()=>new a))},\n", - " function _(o,t,n,e,l){e();const c=o(274);class i extends c.ActionToolView{get plot_view(){return this.parent}}n.PlotActionToolView=i,i.__name__=\"PlotActionToolView\";class s extends c.ActionTool{constructor(o){super(o)}}n.PlotActionTool=s,s.__name__=\"PlotActionTool\"},\n", - " function _(e,o,t,s,i){var l;s();const _=e(458),n=e(269);class c extends _.PlotActionToolView{doit(){this.plot_view.reset()}}t.ResetToolView=c,c.__name__=\"ResetToolView\";class r extends _.PlotActionTool{constructor(e){super(e),this.tool_name=\"Reset\",this.tool_icon=n.tool_icon_reset}}t.ResetTool=r,l=r,r.__name__=\"ResetTool\",l.prototype.default_view=c,l.register_alias(\"reset\",(()=>new r))},\n", - " function _(e,o,t,a,n){var i;a();const l=e(274),s=e(269);class c extends l.ActionToolView{async copy(){const e=await this.parent.export().to_blob(),o=new ClipboardItem({[e.type]:e});await navigator.clipboard.write([o])}async save(e){const o=await this.parent.export().to_blob(),t=document.createElement(\"a\");t.href=URL.createObjectURL(o),t.download=e,t.target=\"_blank\",t.dispatchEvent(new MouseEvent(\"click\"))}doit(e=\"save\"){var o;switch(e){case\"save\":{const e=null!==(o=this.model.filename)&&void 0!==o?o:prompt(\"Enter filename\",\"bokeh_plot\");null!=e&&this.save(e);break}case\"copy\":this.copy()}}}t.SaveToolView=c,c.__name__=\"SaveToolView\";class r extends l.ActionTool{constructor(e){super(e),this.tool_name=\"Save\",this.tool_icon=s.tool_icon_save}get menu(){return[{icon:\"bk-tool-icon-copy\",tooltip:\"Copy image to clipboard\",if:()=>\"undefined\"!=typeof ClipboardItem,handler:()=>{this.do.emit(\"copy\")}}]}}t.SaveTool=r,i=r,r.__name__=\"SaveTool\",i.prototype.default_view=c,i.define((({String:e,Nullable:o})=>({filename:[o(e),null]}))),i.register_alias(\"save\",(()=>new r))},\n", - " function _(o,t,e,n,i){var s;n();const l=o(458),_=o(269);class d extends l.PlotActionToolView{connect_signals(){super.connect_signals(),this.connect(this.plot_view.state.changed,(()=>this.model.disabled=!this.plot_view.state.can_undo))}doit(){const o=this.plot_view.state.undo();null!=(null==o?void 0:o.range)&&this.plot_view.trigger_ranges_update_event()}}e.UndoToolView=d,d.__name__=\"UndoToolView\";class a extends l.PlotActionTool{constructor(o){super(o),this.tool_name=\"Undo\",this.tool_icon=_.tool_icon_undo}}e.UndoTool=a,s=a,a.__name__=\"UndoTool\",s.prototype.default_view=d,s.override({disabled:!0}),s.register_alias(\"undo\",(()=>new a))},\n", - " function _(o,n,e,i,s){var t;i();const _=o(463),a=o(269);class m extends _.ZoomBaseToolView{}e.ZoomInToolView=m,m.__name__=\"ZoomInToolView\";class l extends _.ZoomBaseTool{constructor(o){super(o),this.maintain_focus=!0,this.tool_name=\"Zoom In\",this.tool_icon=a.tool_icon_zoom_in}get_factor(){return this.factor}}e.ZoomInTool=l,t=l,l.__name__=\"ZoomInTool\",t.prototype.default_view=m,t.register_alias(\"zoom_in\",(()=>new l({dimensions:\"both\"}))),t.register_alias(\"xzoom_in\",(()=>new l({dimensions:\"width\"}))),t.register_alias(\"yzoom_in\",(()=>new l({dimensions:\"height\"})))},\n", - " function _(o,t,e,i,s){var n;i();const a=o(458),l=o(19),_=o(464);class m extends a.PlotActionToolView{doit(){var o;const t=this.plot_view.frame,e=this.model.dimensions,i=\"width\"==e||\"both\"==e,s=\"height\"==e||\"both\"==e,n=this.model.get_factor(),a=(0,_.scale_range)(t,n,i,s);this.plot_view.state.push(\"zoom_out\",{range:a}),this.plot_view.update_range(a,{scrolling:!0,maintain_focus:this.model.maintain_focus}),null===(o=this.model.document)||void 0===o||o.interactive_start(this.plot_view.model),this.plot_view.trigger_ranges_update_event()}}e.ZoomBaseToolView=m,m.__name__=\"ZoomBaseToolView\";class r extends a.PlotActionTool{constructor(o){super(o)}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}e.ZoomBaseTool=r,n=r,r.__name__=\"ZoomBaseTool\",n.define((({Percent:o})=>({factor:[o,.1],dimensions:[l.Dimensions,\"both\"]})))},\n", - " function _(n,t,o,r,e){function s(n,t,o){const[r,e]=[n.start,n.end],s=null!=o?o:(e+r)/2;return[r-(r-s)*t,e-(e-s)*t]}function c(n,[t,o]){const r=new Map;for(const[e,s]of n){const[n,c]=s.r_invert(t,o);r.set(e,{start:n,end:c})}return r}r(),o.scale_highlow=s,o.get_info=c,o.scale_range=function(n,t,o=!0,r=!0,e){const a=o?t:0,[l,u]=s(n.bbox.h_range,a,null!=e?e.x:void 0),i=c(n.x_scales,[l,u]),_=r?t:0,[f,g]=s(n.bbox.v_range,_,null!=e?e.y:void 0);return{xrs:i,yrs:c(n.y_scales,[f,g]),factor:t}}},\n", - " function _(o,t,e,i,s){var n;i();const _=o(463),a=o(269);class m extends _.ZoomBaseToolView{}e.ZoomOutToolView=m,m.__name__=\"ZoomOutToolView\";class l extends _.ZoomBaseTool{constructor(o){super(o),this.tool_name=\"Zoom Out\",this.tool_icon=a.tool_icon_zoom_out}get_factor(){return-this.factor/(1-this.factor)}}e.ZoomOutTool=l,n=l,l.__name__=\"ZoomOutTool\",n.prototype.default_view=m,n.define((({Boolean:o})=>({maintain_focus:[o,!0]}))),n.register_alias(\"zoom_out\",(()=>new l({dimensions:\"both\"}))),n.register_alias(\"xzoom_out\",(()=>new l({dimensions:\"width\"}))),n.register_alias(\"yzoom_out\",(()=>new l({dimensions:\"height\"})))},\n", - " function _(o,l,T,i,t){i(),t(\"EditTool\",o(467).EditTool),t(\"BoxEditTool\",o(468).BoxEditTool),t(\"FreehandDrawTool\",o(469).FreehandDrawTool),t(\"LineEditTool\",o(470).LineEditTool),t(\"PointDrawTool\",o(472).PointDrawTool),t(\"PolyDrawTool\",o(473).PolyDrawTool),t(\"PolyTool\",o(474).PolyTool),t(\"PolyEditTool\",o(475).PolyEditTool)},\n", - " function _(e,t,s,o,n){var r;o();const i=e(10),_=e(8),c=e(12),a=e(199),l=e(271);class d extends l.GestureToolView{constructor(){super(...arguments),this._mouse_in_frame=!0}_select_mode(e){const{shift_key:t,ctrl_key:s}=e;return t||s?t&&!s?\"append\":!t&&s?\"intersect\":t&&s?\"subtract\":void(0,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({empty_value:[e,0],renderers:[t(s(a.GlyphRenderer)),[]]})))},\n", - " function _(e,t,s,i,_){var o;i();const n=e(19),a=e(467),d=e(269);class r 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(\"Backspace\"==e.key)this._delete_selected(t);else if(\"Escape\"==e.key){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,r=n.data_source,[l,h]=a.coordinates.x_scale.r_invert(e,t),[p,u]=a.coordinates.y_scale.r_invert(s,i),[c,m]=[(l+h)/2,(p+u)/2],[f,b]=[h-l,u-p],[x,y]=[d.x.field,d.y.field],[w,v]=[d.width.field,d.height.field];if(_)this._pop_glyphs(r,this.model.num_objects),x&&r.get_array(x).push(c),y&&r.get_array(y).push(m),w&&r.get_array(w).push(f),v&&r.get_array(v).push(b),this._pad_empty_columns(r,[x,y,w,v]);else{const e=r.data[x].length-1;x&&(r.data[x][e]=c),y&&(r.data[y][e]=m),w&&(r.data[w][e]=f),v&&(r.data[v][e]=b)}this._emit_cds_changes(r,!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,a]=this.model._get_dim_limits(this._draw_basepoint,i,_,o);this._set_extent(n,a,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.shift_key){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.shift_key){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.shift_key)this._draw_basepoint=null;else{this._basepoint=null;for(const e of this.model.renderers)this._emit_cds_changes(e.data_source,!1,!0,!0)}}}s.BoxEditToolView=r,r.__name__=\"BoxEditToolView\";class l extends a.EditTool{constructor(e){super(e),this.tool_name=\"Box Edit Tool\",this.tool_icon=d.tool_icon_box_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=1}}s.BoxEditTool=l,o=l,l.__name__=\"BoxEditTool\",o.prototype.default_view=r,o.define((({Int:e})=>({dimensions:[n.Dimensions,\"both\"],num_objects:[e,0]})))},\n", - " function _(e,t,a,s,r){var _;s();const o=e(8),d=e(467),n=e(269);class i extends d.EditToolView{_draw(e,t,a=!1){if(!this.model.active)return;const s=this.model.renderers[0],r=this._map_drag(e.sx,e.sy,s);if(null==r)return;const[_,d]=r,n=s.data_source,i=s.glyph,[l,h]=[i.xs.field,i.ys.field];if(\"new\"==t)this._pop_glyphs(n,this.model.num_objects),l&&n.get_array(l).push([_]),h&&n.get_array(h).push([d]),this._pad_empty_columns(n,[l,h]);else if(\"add\"==t){if(l){const e=n.data[l].length-1;let t=n.get_array(l)[e];(0,o.isArray)(t)||(t=Array.from(t),n.data[l][e]=t),t.push(_)}if(h){const e=n.data[h].length-1;let t=n.get_array(h)[e];(0,o.isArray)(t)||(t=Array.from(t),n.data[h][e]=t),t.push(d)}}this._emit_cds_changes(n,!0,!0,a)}_pan_start(e){this._draw(e,\"new\")}_pan(e){this._draw(e,\"add\")}_pan_end(e){this._draw(e,\"add\",!0)}_tap(e){this._select_event(e,this._select_mode(e),this.model.renderers)}_keyup(e){if(this.model.active&&this._mouse_in_frame)for(const t of this.model.renderers)\"Escape\"==e.key?t.data_source.selection_manager.clear():\"Backspace\"==e.key&&this._delete_selected(t)}}a.FreehandDrawToolView=i,i.__name__=\"FreehandDrawToolView\";class l extends d.EditTool{constructor(e){super(e),this.tool_name=\"Freehand Draw Tool\",this.tool_icon=n.tool_icon_freehand_draw,this.event_type=[\"pan\",\"tap\"],this.default_order=3}}a.FreehandDrawTool=l,_=l,l.__name__=\"FreehandDrawTool\",_.prototype.default_view=i,_.define((({Int:e})=>({num_objects:[e,0]}))),_.register_alias(\"freehand_draw\",(()=>new l))},\n", - " function _(e,t,s,i,n){var r;i();const _=e(19),d=e(471),o=e(269);class l extends d.LineToolView{constructor(){super(...arguments),this._drawing=!1}_doubletap(e){if(!this.model.active)return;const t=this.model.renderers;for(const s of t){1==this._select_event(e,\"replace\",[s]).length&&(this._selected_renderer=s)}this._show_intersections(),this._update_line_cds()}_show_intersections(){if(!this.model.active)return;if(null==this._selected_renderer)return;if(0==this.model.renderers.length)return this._set_intersection([],[]),this._selected_renderer=null,void(this._drawing=!1);const e=this._selected_renderer.data_source,t=this._selected_renderer.glyph,[s,i]=[t.x.field,t.y.field],n=e.get_array(s),r=e.get_array(i);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&&null!=this._selected_renderer){const s=this._select_mode(e);if(0==this._select_event(e,s,[t]).length)return}const s=this._select_mode(e);this._select_event(e,s,[t]),this._select_event(e,s,this.model.renderers)}_update_line_cds(){if(null==this._selected_renderer)return;const e=this.model.intersection_renderer.glyph,t=this.model.intersection_renderer.data_source,[s,i]=[e.x.field,e.y.field];if(s&&i){const e=t.data[s],n=t.data[i];this._selected_renderer.data_source.data[s]=e,this._selected_renderer.data_source.data[i]=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),null!=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),null!=this._selected_renderer&&this._emit_cds_changes(this._selected_renderer.data_source),this._basepoint=null)}activate(){this._drawing=!0}deactivate(){null!=this._selected_renderer&&(this._drawing&&(this._drawing=!1),this._hide_intersections())}}s.LineEditToolView=l,l.__name__=\"LineEditToolView\";class h extends d.LineTool{constructor(e){super(e),this.tool_name=\"Line Edit Tool\",this.tool_icon=o.tool_icon_line_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=4}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}s.LineEditTool=h,r=h,h.__name__=\"LineEditTool\",r.prototype.default_view=l,r.define((()=>({dimensions:[_.Dimensions,\"both\"]})))},\n", - " function _(e,i,n,t,s){var o;t();const r=e(8),_=e(467);class d extends _.EditToolView{_set_intersection(e,i){const n=this.model.intersection_renderer.glyph,t=this.model.intersection_renderer.data_source,[s,o]=[n.x.field,n.y.field];s&&((0,r.isArray)(e)?t.data[s]=e:n.x={value:e}),o&&((0,r.isArray)(i)?t.data[o]=i:n.y={value:i}),this._emit_cds_changes(t,!0,!0,!1)}_hide_intersections(){this._set_intersection([],[])}}n.LineToolView=d,d.__name__=\"LineToolView\";class a extends _.EditTool{constructor(e){super(e)}}n.LineTool=a,o=a,a.__name__=\"LineTool\",o.define((({AnyRef:e})=>({intersection_renderer:[e()]})))},\n", - " function _(e,t,s,o,a){var i;o();const _=e(467),n=e(269);class r extends _.EditToolView{_tap(e){if(0!=this._select_event(e,this._select_mode(e),this.model.renderers).length||!this.model.add)return;const t=this.model.renderers[0],s=this._map_drag(e.sx,e.sy,t);if(null==s)return;const o=t.glyph,a=t.data_source,[i,_]=[o.x.field,o.y.field],[n,r]=s;this._pop_glyphs(a,this.model.num_objects),i&&a.get_array(i).push(n),_&&a.get_array(_).push(r),this._pad_empty_columns(a,[i,_]);const{data:d}=a;a.setv({data:d},{check_eq:!1})}_keyup(e){if(this.model.active&&this._mouse_in_frame)for(const t of this.model.renderers)\"Backspace\"==e.key?this._delete_selected(t):\"Escape\"==e.key&&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 _.EditTool{constructor(e){super(e),this.tool_name=\"Point Draw Tool\",this.tool_icon=n.tool_icon_point_draw,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=2}}s.PointDrawTool=d,i=d,d.__name__=\"PointDrawTool\",i.prototype.default_view=r,i.define((({Boolean:e,Int:t})=>({add:[e,!0],drag:[e,!0],num_objects:[t,0]})))},\n", - " function _(e,t,s,i,a){var r;i();const o=e(8),n=e(474),_=e(269);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[r,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([r,r]),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]=r}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]=r,(0,o.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,(0,o.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),null!=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.tool_icon=_.tool_icon_poly_draw,this.event_type=[\"pan\",\"tap\",\"move\"],this.default_order=3}}s.PolyDrawTool=l,r=l,l.__name__=\"PolyDrawTool\",r.prototype.default_view=d,r.define((({Boolean:e,Int:t})=>({drag:[e,!0],num_objects:[t,0]})))},\n", - " function _(e,t,r,l,s){var o;l();const _=e(8),i=e(12),n=e(467);class d extends n.EditToolView{_set_vertices(e,t){const{vertex_renderer:r}=this.model;(0,i.assert)(null!=r);const l=r.glyph,s=r.data_source,[o,n]=[l.x.field,l.y.field];o&&((0,_.isArray)(e)?s.data[o]=e:l.x={value:e}),n&&((0,_.isArray)(t)?s.data[n]=t:l.y={value:t}),this._emit_cds_changes(s,!0,!0,!1)}_hide_vertices(){this._set_vertices([],[])}_snap_to_vertex(e,t,r){if(null!=this.model.vertex_renderer){const l=this._select_event(e,\"replace\",[this.model.vertex_renderer]),s=this.model.vertex_renderer.data_source,o=this.model.vertex_renderer.glyph,[_,i]=[o.x.field,o.y.field];if(0!=l.length){const e=s.selected.indices[0];_&&(t=s.data[_][e]),i&&(r=s.data[i][e]),s.selection_manager.clear()}}return[t,r]}}r.PolyToolView=d,d.__name__=\"PolyToolView\";class a extends n.EditTool{constructor(e){super(e)}}r.PolyTool=a,o=a,a.__name__=\"PolyTool\",o.define((({AnyRef:e,Nullable:t})=>({vertex_renderer:[t(e()),null]})))},\n", - " function _(e,t,r,s,i){var _;s();const n=e(8),d=e(474),l=e(269);class a extends d.PolyToolView{constructor(){super(...arguments),this._drawing=!1,this._cur_index=null}_doubletap(e){if(null==this.model.vertex_renderer||!this.model.active)return;const t=this._map_drag(e.sx,e.sy,this.model.vertex_renderer);if(null==t)return;const[r,s]=t,i=this._select_event(e,\"replace\",[this.model.vertex_renderer]),_=this.model.vertex_renderer.data_source,n=this.model.vertex_renderer.glyph,[d,l]=[n.x.field,n.y.field];if(0!=i.length&&null!=this._selected_renderer){const e=_.selected.indices[0];this._drawing?(this._drawing=!1,_.selection_manager.clear()):(_.selected.indices=[e+1],d&&_.get_array(d).splice(e+1,0,r),l&&_.get_array(l).splice(e+1,0,s),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;if(0==this.model.renderers.length)return;const t=this.model.renderers[0],r=()=>this._update_vertices(t),s=t.data_source,i=this._select_event(e,\"replace\",this.model.renderers);if(0==i.length)return this._set_vertices([],[]),this._selected_renderer=null,this._drawing=!1,this._cur_index=null,void s.disconnect(s.properties.data.change,r);s.connect(s.properties.data.change,r),this._cur_index=i[0].data_source.selected.indices[0],this._update_vertices(i[0])}_update_vertices(e){const t=e.glyph,r=e.data_source,s=this._cur_index,[i,_]=[t.xs.field,t.ys.field];if(this._drawing)return;if(null==s&&(i||_))return;let d,l;i&&null!=s?(d=r.data[i][s],(0,n.isArray)(d)||(r.data[i][s]=d=Array.from(d))):d=t.xs.value,_&&null!=s?(l=r.data[_][s],(0,n.isArray)(l)||(r.data[_][s]=l=Array.from(l))):l=t.ys.value,this._selected_renderer=e,this._set_vertices(d,l)}_move(e){if(this._drawing&&null!=this._selected_renderer){const t=this.model.vertex_renderer;if(null==t)return;const r=t.data_source,s=t.glyph,i=this._map_drag(e.sx,e.sy,t);if(null==i)return;let[_,n]=i;const d=r.selected.indices;[_,n]=this._snap_to_vertex(e,_,n),r.selected.indices=d;const[l,a]=[s.x.field,s.y.field],c=d[0];l&&(r.data[l][c]=_),a&&(r.data[a][c]=n),r.change.emit(),this._selected_renderer.data_source.change.emit()}}_tap(e){const t=this.model.vertex_renderer;if(null==t)return;const r=this._map_drag(e.sx,e.sy,t);if(null==r)return;if(this._drawing&&null!=this._selected_renderer){let[s,i]=r;const _=t.data_source,n=t.glyph,[d,l]=[n.x.field,n.y.field],a=_.selected.indices;[s,i]=this._snap_to_vertex(e,s,i);const c=a[0];if(_.selected.indices=[c+1],d){const e=_.get_array(d),t=e[c];e[c]=s,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 s=this._select_mode(e);this._select_event(e,s,[t]),this._select_event(e,s,this.model.renderers)}_remove_vertex(){if(!this._drawing||null==this._selected_renderer)return;const e=this.model.vertex_renderer;if(null==e)return;const t=e.data_source,r=e.glyph,s=t.selected.indices[0],[i,_]=[r.x.field,r.y.field];i&&t.get_array(i).splice(s,1),_&&t.get_array(_).splice(s,1),t.change.emit(),this._emit_cds_changes(this._selected_renderer.data_source)}_pan_start(e){null!=this.model.vertex_renderer&&(this._select_event(e,\"append\",[this.model.vertex_renderer]),this._basepoint=[e.sx,e.sy])}_pan(e){null!=this._basepoint&&null!=this.model.vertex_renderer&&(this._drag_points(e,[this.model.vertex_renderer]),null!=this._selected_renderer&&this._selected_renderer.data_source.change.emit())}_pan_end(e){null!=this._basepoint&&null!=this.model.vertex_renderer&&(this._drag_points(e,[this.model.vertex_renderer]),this._emit_cds_changes(this.model.vertex_renderer.data_source,!1,!0,!0),null!=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;if(null!=this._selected_renderer){const{vertex_renderer:e}=this.model;t=null!=e?[e]:[]}else t=this.model.renderers;for(const r of t)\"Backspace\"==e.key?(this._delete_selected(r),null!=this._selected_renderer&&this._emit_cds_changes(this._selected_renderer.data_source)):\"Escape\"==e.key&&(this._drawing?(this._remove_vertex(),this._drawing=!1):null!=this._selected_renderer&&this._hide_vertices(),r.data_source.selection_manager.clear())}deactivate(){null!=this._selected_renderer&&(this._drawing&&(this._remove_vertex(),this._drawing=!1),this._hide_vertices())}}r.PolyEditToolView=a,a.__name__=\"PolyEditToolView\";class c extends d.PolyTool{constructor(e){super(e),this.tool_name=\"Poly Edit Tool\",this.tool_icon=l.tool_icon_poly_edit,this.event_type=[\"tap\",\"pan\",\"move\"],this.default_order=4}}r.PolyEditTool=c,_=c,c.__name__=\"PolyEditTool\",_.prototype.default_view=a},\n", - " function _(o,l,e,T,t){T(),t(\"BoxSelectTool\",o(477).BoxSelectTool),t(\"BoxZoomTool\",o(480).BoxZoomTool),t(\"GestureTool\",o(271).GestureTool),t(\"LassoSelectTool\",o(481).LassoSelectTool),t(\"PanTool\",o(483).PanTool),t(\"PolySelectTool\",o(482).PolySelectTool),t(\"RangeTool\",o(484).RangeTool),t(\"SelectTool\",o(479).SelectTool),t(\"TapTool\",o(485).TapTool),t(\"WheelPanTool\",o(486).WheelPanTool),t(\"WheelZoomTool\",o(487).WheelZoomTool)},\n", - " function _(t,e,i,o,s){var l;o();const n=t(1),_=t(478),r=t(232),c=t(19),a=n.__importStar(t(269));class h extends _.RegionSelectToolView{connect_signals(){super.connect_signals();const{pan:t}=this.model.overlay;this.connect(t,(([t,e])=>{if(\"pan\"==t&&this._is_continuous(e)||\"pan:end\"==t){const{left:t,top:i,right:o,bottom:s}=this.model.overlay;if(null!=t&&null!=i&&null!=o&&null!=s){const l=this._compute_lrtb({left:t,right:o,top:i,bottom:s});this._do_select([l.left,l.right],[l.top,l.bottom],!1,this._select_mode(e))}}}));const{active:e}=this.model.properties;this.on_change(e,(()=>{this.model.active||this.model.persistent||this._clear_overlay()}))}_compute_limits(t){const e=this.plot_view.frame,i=this.model.dimensions;let o=this._base_point;if(\"center\"==this.model.origin){const[e,i]=o,[s,l]=t;o=[e-(s-e),i-(l-i)]}return this.model._get_dim_limits(o,t,e,i)}_mappers(){const t=(t,e,i,o)=>{switch(t){case\"canvas\":return o;case\"screen\":return i;case\"data\":return e}},{overlay:e}=this.model,{frame:i,canvas:o}=this.plot_view,{x_scale:s,y_scale:l}=i,{x_view:n,y_view:_}=i.bbox,{x_screen:r,y_screen:c}=o.bbox;return{left:t(e.left_units,s,n,r),right:t(e.right_units,s,n,r),top:t(e.top_units,l,_,c),bottom:t(e.bottom_units,l,_,c)}}_compute_lrtb({left:t,right:e,top:i,bottom:o}){const s=this._mappers();return{left:s.left.compute(t),right:s.right.compute(e),top:s.top.compute(i),bottom:s.bottom.compute(o)}}_invert_lrtb({left:t,right:e,top:i,bottom:o}){const s=this._mappers();return{left:s.left.invert(t),right:s.right.invert(e),top:s.top.invert(i),bottom:s.bottom.invert(o)}}_pan_start(t){const{sx:e,sy:i}=t,{frame:o}=this.plot_view;o.bbox.contains(e,i)&&(this._clear_other_overlays(),this._base_point=[e,i])}_pan(t){if(null==this._base_point)return;const{sx:e,sy:i}=t,[o,s]=this._compute_limits([e,i]),[[l,n],[_,r]]=[o,s];this.model.overlay.update(this._invert_lrtb({left:l,right:n,top:_,bottom:r})),this._is_continuous(t)&&this._do_select(o,s,!1,this._select_mode(t))}_pan_end(t){if(null==this._base_point)return;const{sx:e,sy:i}=t,[o,s]=this._compute_limits([e,i]);this._do_select(o,s,!0,this._select_mode(t)),this.model.persistent||this._clear_overlay(),this._base_point=null,this.plot_view.state.push(\"box_select\",{selection:this.plot_view.get_selection()})}get _is_selecting(){return null!=this._base_point}_stop(){this._clear_overlay(),this._base_point=null}_keyup(t){if(this.model.active){if(\"Escape\"==t.key){if(this._is_selecting)return void this._stop();if(this.model.overlay.visible)return void this._clear_overlay()}super._keyup(t)}}_clear_selection(){this.model.overlay.visible?this._clear_overlay():super._clear_selection()}_do_select([t,e],[i,o],s,l=\"replace\"){const n={type:\"rect\",sx0:t,sx1:e,sy0:i,sy1:o};this._select(n,s,l)}}i.BoxSelectToolView=h,h.__name__=\"BoxSelectToolView\";const p=()=>new r.BoxAnnotation({syncable:!1,level:\"overlay\",visible:!1,editable:!0,top_units:\"data\",left_units:\"data\",bottom_units:\"data\",right_units:\"data\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:2,line_dash:[4,4]});class m extends _.RegionSelectTool{constructor(t){super(t),this.tool_name=\"Box Select\",this.event_type=\"pan\",this.default_order=30}initialize(){super.initialize();const[t,e]=(()=>{switch(this.dimensions){case\"width\":return[\"x\",\"x\"];case\"height\":return[\"y\",\"y\"];case\"both\":return[\"all\",\"both\"]}})(),i=\"center\"==this.origin;this.overlay.setv({resizable:t,movable:e,symmetric:i})}get computed_icon(){const t=super.computed_icon;if(null!=t)return t;switch(this.dimensions){case\"both\":return`.${a.tool_icon_box_select}`;case\"width\":return`.${a.tool_icon_x_box_select}`;case\"height\":return`.${a.tool_icon_y_box_select}`}}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}i.BoxSelectTool=m,l=m,m.__name__=\"BoxSelectTool\",l.prototype.default_view=h,l.define((({Ref:t})=>({dimensions:[c.Dimensions,\"both\"],overlay:[t(r.BoxAnnotation),p],origin:[c.BoxOrigin,\"corner\"]}))),l.register_alias(\"box_select\",(()=>new m)),l.register_alias(\"xbox_select\",(()=>new m({dimensions:\"width\"}))),l.register_alias(\"ybox_select\",(()=>new m({dimensions:\"height\"})))},\n", - " function _(e,o,t,s,l){var n;s();const r=e(479);class c extends r.SelectToolView{get overlays(){return[...super.overlays,this.model.overlay]}_is_continuous(e){return this.model.continuous!=e.alt_key}_select(e,o,t){const s=this._computed_renderers_by_data_source();for(const[,l]of s){const s=l[0].get_selection_manager(),n=[];for(const e of l){const o=this.plot_view.renderer_view(e);null!=o&&n.push(o)}s.select(n,e,o,t)}this._emit_selection_event(e,o)}_clear_overlay(){super._clear_overlay(),this.model.overlay.clear()}}t.RegionSelectToolView=c,c.__name__=\"RegionSelectToolView\";class _ extends r.SelectTool{constructor(e){super(e)}}t.RegionSelectTool=_,n=_,_.__name__=\"RegionSelectTool\",n.define((({Boolean:e})=>({continuous:[e,!1],persistent:[e,!1]})))},\n", - " function _(e,t,r,s,o){var n;s();const i=e(271),c=e(199),a=e(409),l=e(200),_=e(95),d=e(19),h=e(52),p=e(15),u=e(12);class v extends i.GestureToolView{connect_signals(){super.connect_signals(),this.model.clear.connect((()=>this._clear_selection()))}get computed_renderers(){const{renderers:e}=this.model,t=this.plot_view.model.data_renderers;return(0,_.compute_renderers)(e,t)}_computed_renderers_by_data_source(){var e;const t=new Map;for(const r of this.computed_renderers){let s;if(r instanceof c.GlyphRenderer)s=r.data_source;else{if(!(r instanceof a.GraphRenderer))continue;s=r.node_renderer.data_source}const o=null!==(e=t.get(s))&&void 0!==e?e:[];t.set(s,[...o,r])}return t}_clear_overlay(){}_clear_other_overlays(){for(const e of this.plot_view.tool_views.values())e instanceof v&&e!=this&&e._clear_overlay()}_clear_selection(){this._clear()}_select_mode(e){const{shift_key:t,ctrl_key:r}=e;return t||r?t&&!r?\"append\":!t&&r?\"intersect\":t&&r?\"subtract\":void(0,u.unreachable)():this.model.mode}_keyup(e){this.model.active&&\"Escape\"==e.key&&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)}_emit_selection_event(e,t=!0){const{x_scale:r,y_scale:s}=this.plot_view.frame,o=(()=>{switch(e.type){case\"point\":{const{sx:t,sy:o}=e,n=r.invert(t),i=s.invert(o);return Object.assign(Object.assign({},e),{x:n,y:i})}case\"span\":{const{sx:t,sy:o}=e,n=r.invert(t),i=s.invert(o);return Object.assign(Object.assign({},e),{x:n,y:i})}case\"rect\":{const{sx0:t,sx1:o,sy0:n,sy1:i}=e,[c,a]=r.r_invert(t,o),[l,_]=s.r_invert(n,i);return Object.assign(Object.assign({},e),{x0:c,y0:l,x1:a,y1:_})}case\"poly\":{const{sx:t,sy:o}=e,n=r.v_invert(t),i=s.v_invert(o);return Object.assign(Object.assign({},e),{x:n,y:i})}}})();this.plot_view.model.trigger_event(new h.SelectionGeometry(o,t))}}r.SelectToolView=v,v.__name__=\"SelectToolView\";class m extends i.GestureTool{constructor(e){super(e)}initialize(){super.initialize(),this.clear=new p.Signal0(this,\"clear\")}get menu(){return[{icon:\"bk-tool-icon-replace-mode\",tooltip:\"Replace the current selection\",active:()=>\"replace\"==this.mode,handler:()=>{this.mode=\"replace\",this.active=!0}},{icon:\"bk-tool-icon-append-mode\",tooltip:\"Append to the current selection (Shift)\",active:()=>\"append\"==this.mode,handler:()=>{this.mode=\"append\",this.active=!0}},{icon:\"bk-tool-icon-intersect-mode\",tooltip:\"Intersect with the current selection (Ctrl)\",active:()=>\"intersect\"==this.mode,handler:()=>{this.mode=\"intersect\",this.active=!0}},{icon:\"bk-tool-icon-subtract-mode\",tooltip:\"Subtract from the current selection (Shift+Ctrl)\",active:()=>\"subtract\"==this.mode,handler:()=>{this.mode=\"subtract\",this.active=!0}},null,{icon:\"bk-tool-icon-clear-selection\",tooltip:\"Clear the current selection and/or selection overlay (Esc)\",handler:()=>{this.clear.emit()}}]}}r.SelectTool=m,n=m,m.__name__=\"SelectTool\",n.define((({Array:e,Ref:t,Or:r,Auto:s})=>({renderers:[r(e(t(l.DataRenderer)),s),\"auto\"],mode:[d.SelectionMode,\"replace\"]})))},\n", - " function _(o,t,e,i,s){var n;i();const a=o(1),_=o(271),r=o(232),l=o(19),h=a.__importStar(o(269));class c extends _.GestureToolView{constructor(){super(...arguments),this._base_point=null}get overlays(){return[...super.overlays,this.model.overlay]}_match_aspect([o,t],[e,i],s){const n=s.bbox.aspect,a=s.bbox.h_range.end,_=s.bbox.h_range.start,r=s.bbox.v_range.end,l=s.bbox.v_range.start;let h=Math.abs(o-e),c=Math.abs(t-i);const m=0==c?0:h/c,[d]=m>=n?[1,m/n]:[n/m,1];let p,u,b,x;return o<=e?(p=o,u=o+h*d,u>a&&(u=a)):(u=o,p=o-h*d,p<_&&(p=_)),h=Math.abs(u-p),t<=i?(x=t,b=t+h/n,b>r&&(b=r)):(b=t,x=t-h/n,x{const{dimensions:e}=this.model;if(\"auto\"==e){const[e,i]=o,[s,n]=t,a=Math.abs(e-s),_=Math.abs(i-n),r=5;return ar?\"height\":a>r&&_new r.BoxAnnotation({syncable:!1,level:\"overlay\",visible:!1,editable:!1,top_units:\"canvas\",left_units:\"canvas\",bottom_units:\"canvas\",right_units:\"canvas\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:2,line_dash:[4,4]});class d extends _.GestureTool{constructor(o){super(o),this.tool_name=\"Box Zoom\",this.event_type=[\"pan\",\"doubletap\"],this.default_order=20}get event_role(){return\"pan\"}get computed_icon(){const o=super.computed_icon;if(null!=o)return o;switch(this.dimensions){case\"both\":return`.${h.tool_icon_box_zoom}`;case\"width\":return`.${h.tool_icon_x_box_zoom}`;case\"height\":return`.${h.tool_icon_y_box_zoom}`;case\"auto\":return`.${h.tool_icon_auto_box_zoom}`}}get tooltip(){return this._get_dim_tooltip(this.dimensions)}get menu(){return[{icon:h.tool_icon_box_zoom,tooltip:\"Box zoom in both dimensions\",active:()=>\"both\"==this.dimensions,handler:()=>{this.dimensions=\"both\",this.active=!0}},{icon:h.tool_icon_x_box_zoom,tooltip:\"Box zoom in x-dimension\",active:()=>\"width\"==this.dimensions,handler:()=>{this.dimensions=\"width\",this.active=!0}},{icon:h.tool_icon_y_box_zoom,tooltip:\"Box zoom in y-dimension\",active:()=>\"height\"==this.dimensions,handler:()=>{this.dimensions=\"height\",this.active=!0}},{icon:h.tool_icon_auto_box_zoom,tooltip:\"Automatic mode (box zoom in x, y or both dimensions, depending on the mouse gesture)\",active:()=>\"auto\"==this.dimensions,handler:()=>{this.dimensions=\"auto\",this.active=!0}}]}}e.BoxZoomTool=d,n=d,d.__name__=\"BoxZoomTool\",n.prototype.default_view=c,n.define((({Boolean:o,Ref:t,Or:e,Auto:i})=>({dimensions:[e(l.Dimensions,i),\"both\"],overlay:[t(r.BoxAnnotation),m],match_aspect:[o,!1],origin:[l.BoxOrigin,\"corner\"]}))),n.register_alias(\"box_zoom\",(()=>new d({dimensions:\"both\"}))),n.register_alias(\"xbox_zoom\",(()=>new d({dimensions:\"width\"}))),n.register_alias(\"ybox_zoom\",(()=>new d({dimensions:\"height\"}))),n.register_alias(\"auto_box_zoom\",(()=>new d({dimensions:\"auto\"})))},\n", - " function _(e,s,t,o,i){var _;o();const l=e(478),n=e(252),c=e(482),a=e(12),r=e(269);class h extends l.RegionSelectToolView{constructor(){super(...arguments),this._is_selecting=!1}_mappers(){const e=(e,s,t,o)=>{switch(e){case\"canvas\":return o;case\"screen\":return t;case\"data\":return s}},{overlay:s}=this.model,{frame:t,canvas:o}=this.plot_view,{x_scale:i,y_scale:_}=t,{x_view:l,y_view:n}=t.bbox,{x_screen:c,y_screen:a}=o.bbox;return{x:e(s.xs_units,i,l,c),y:e(s.ys_units,_,n,a)}}_v_compute(e,s){const{x:t,y:o}=this._mappers();return[t.v_compute(e),o.v_compute(s)]}_v_invert(e,s){const{x:t,y:o}=this._mappers();return[t.v_invert(e),o.v_invert(s)]}connect_signals(){super.connect_signals();const{pan:e}=this.model.overlay;this.connect(e,(([e,s])=>{if(\"pan\"==e&&this._is_continuous(s)||\"pan:end\"==e){const{xs:e,ys:t}=this.model.overlay,[o,i]=this._v_compute(e,t);this._do_select(o,i,!1,this._select_mode(s))}}));const{active:s}=this.model.properties;this.on_change(s,(()=>{this.model.active||this.model.persistent||this._clear_overlay()}))}_pan_start(e){const{sx:s,sy:t}=e,{frame:o}=this.plot_view;if(!o.bbox.contains(s,t))return;this._clear_other_overlays(),this._is_selecting=!0;const[i,_]=this._v_invert([s],[t]);this.model.overlay.update({xs:i,ys:_})}_pan(e){(0,a.assert)(this._is_selecting);const[s,t]=(()=>{const{xs:e,ys:s}=this.model.overlay,[t,o]=this._v_compute(e,s);return[[...t],[...o]]})(),[o,i]=this.plot_view.frame.bbox.clip(e.sx,e.sy);s.push(o),t.push(i);const[_,l]=this._v_invert(s,t);this.model.overlay.update({xs:_,ys:l}),this._is_continuous(e)&&this._do_select(s,t,!1,this._select_mode(e))}_pan_end(e){(0,a.assert)(this._is_selecting),this._is_selecting=!1;const{xs:s,ys:t}=this.model.overlay,[o,i]=this._v_compute(s,t);this._do_select(o,i,!0,this._select_mode(e)),this.plot_view.state.push(\"lasso_select\",{selection:this.plot_view.get_selection()}),this.model.persistent||this._clear_overlay()}_keyup(e){this.model.active&&(\"Escape\"==e.key&&this.model.overlay.visible?this._clear_overlay():super._keyup(e))}_clear_selection(){this.model.overlay.visible?this._clear_overlay():super._clear_selection()}_do_select(e,s,t,o){const i={type:\"poly\",sx:e,sy:s};this._select(i,t,o)}}t.LassoSelectToolView=h,h.__name__=\"LassoSelectToolView\";class v extends l.RegionSelectTool{constructor(e){super(e),this.tool_name=\"Lasso Select\",this.tool_icon=r.tool_icon_lasso_select,this.event_type=\"pan\",this.default_order=12}}t.LassoSelectTool=v,_=v,v.__name__=\"LassoSelectTool\",_.prototype.default_view=h,_.define((({Ref:e})=>({overlay:[e(n.PolyAnnotation),c.DEFAULT_POLY_OVERLAY]}))),_.override({continuous:!0}),_.register_alias(\"lasso_select\",(()=>new v))},\n", - " function _(e,t,s,i,o){var _;i();const l=e(478),n=e(252),c=e(269);class a extends l.RegionSelectToolView{constructor(){super(...arguments),this._is_selecting=!1}_mappers(){const e=(e,t,s,i)=>{switch(e){case\"canvas\":return i;case\"screen\":return s;case\"data\":return t}},{overlay:t}=this.model,{frame:s,canvas:i}=this.plot_view,{x_scale:o,y_scale:_}=s,{x_view:l,y_view:n}=s.bbox,{x_screen:c,y_screen:a}=i.bbox;return{x:e(t.xs_units,o,l,c),y:e(t.ys_units,_,n,a)}}_v_compute(e,t){const{x:s,y:i}=this._mappers();return[s.v_compute(e),i.v_compute(t)]}_v_invert(e,t){const{x:s,y:i}=this._mappers();return[s.v_invert(e),i.v_invert(t)]}connect_signals(){super.connect_signals();const{pan:e}=this.model.overlay;this.connect(e,(([e,t])=>{if(\"pan\"==e&&this._is_continuous(t)||\"pan:end\"==e&&!this._is_selecting){const{xs:e,ys:s}=this.model.overlay,[i,o]=this._v_compute(e,s);this._do_select(i,o,!1,this._select_mode(t))}}));const{active:t}=this.model.properties;this.on_change(t,(()=>{this.model.active||this.model.persistent||this._clear_overlay()}))}_tap(e){const{sx:t,sy:s}=e,{frame:i}=this.plot_view;if(!i.bbox.contains(t,s))return;this._clear_other_overlays();const[o,_]=(()=>{if(this._is_selecting){const{xs:e,ys:t}=this.model.overlay,[s,i]=this._v_compute(e,t);return[[...s],[...i]]}return this._is_selecting=!0,[[],[]]})();o.push(t),_.push(s);const[l,n]=this._v_invert(o,_);this.model.overlay.update({xs:l,ys:n}),this._is_continuous(e)&&this._do_select(o,_,!0,this._select_mode(e))}_finish_selection(e){this._is_selecting=!1;const{xs:t,ys:s}=this.model.overlay,[i,o]=this._v_compute(t,s);this._do_select(i,o,!0,this._select_mode(e)),this.plot_view.state.push(\"poly_select\",{selection:this.plot_view.get_selection()}),this.model.persistent||this._clear_overlay()}_doubletap(e){this._finish_selection(e)}_keyup(e){this.model.active&&(\"Enter\"!=e.key?\"Escape\"==e.key&&this.model.overlay.visible?this._clear_overlay():super._keyup(e):this._finish_selection(e))}_clear_selection(){this.model.overlay.visible?this._clear_overlay():(this._is_selecting=!1,super._clear_selection())}_clear_overlay(){this._is_selecting=!1,super._clear_overlay()}_do_select(e,t,s,i){const o={type:\"poly\",sx:e,sy:t};this._select(o,s,i)}}s.PolySelectToolView=a,a.__name__=\"PolySelectToolView\";s.DEFAULT_POLY_OVERLAY=()=>new n.PolyAnnotation({syncable:!1,level:\"overlay\",visible:!1,editable:!0,xs_units:\"data\",ys_units:\"data\",fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:2,line_dash:[4,4]});class r extends l.RegionSelectTool{constructor(e){super(e),this.tool_name=\"Poly Select\",this.tool_icon=c.tool_icon_polygon_select,this.event_type=\"tap\",this.default_order=11}}s.PolySelectTool=r,_=r,r.__name__=\"PolySelectTool\",_.prototype.default_view=a,_.define((({Ref:e})=>({overlay:[e(n.PolyAnnotation),s.DEFAULT_POLY_OVERLAY]}))),_.register_alias(\"poly_select\",(()=>new r))},\n", - " function _(t,i,n,s,e){var o;s();const a=t(1),_=t(271),h=t(19),r=a.__importStar(t(269));function d(t,i,n){const s=new Map;for(const[e,o]of t){const[t,a]=o.r_invert(i,n);s.set(e,{start:t,end:a})}return s}n.update_ranges=d;class l extends _.GestureToolView{_pan_start(t){var i;this.last_dx=0,this.last_dy=0;const{sx:n,sy:s}=t,e=this.plot_view.frame.bbox;if(!e.contains(n,s)){const t=e.h_range,i=e.v_range;(nt.end)&&(this.v_axis_only=!0),(si.end)&&(this.h_axis_only=!0)}null===(i=this.model.document)||void 0===i||i.interactive_start(this.plot_view.model)}_pan(t){var i;this._update(t.dx,t.dy),null===(i=this.model.document)||void 0===i||i.interactive_start(this.plot_view.model)}_pan_end(t){this.h_axis_only=!1,this.v_axis_only=!1,null!=this.pan_info&&this.plot_view.state.push(\"pan\",{range:this.pan_info}),this.plot_view.trigger_ranges_update_event()}_update(t,i){const n=this.plot_view.frame,s=t-this.last_dx,e=i-this.last_dy,o=n.bbox.h_range,a=o.start-s,_=o.end-s,h=n.bbox.v_range,r=h.start-e,l=h.end-e,p=this.model.dimensions;let c,m,u,v,g,x;\"width\"!=p&&\"both\"!=p||this.v_axis_only?(c=o.start,m=o.end,u=0):(c=a,m=_,u=-s),\"height\"!=p&&\"both\"!=p||this.h_axis_only?(v=h.start,g=h.end,x=0):(v=r,g=l,x=-e),this.last_dx=t,this.last_dy=i;const{x_scales:w,y_scales:y}=n,f=d(w,c,m),b=d(y,v,g);this.pan_info={xrs:f,yrs:b,sdx:u,sdy:x},this.plot_view.update_range(this.pan_info,{panning:!0})}}n.PanToolView=l,l.__name__=\"PanToolView\";class p extends _.GestureTool{constructor(t){super(t),this.tool_name=\"Pan\",this.event_type=\"pan\",this.default_order=10}get tooltip(){return this._get_dim_tooltip(this.dimensions)}get computed_icon(){const t=super.computed_icon;if(null!=t)return t;switch(this.dimensions){case\"both\":return`.${r.tool_icon_pan}`;case\"width\":return`.${r.tool_icon_x_pan}`;case\"height\":return`.${r.tool_icon_y_pan}`}}get menu(){return[{icon:r.tool_icon_pan,tooltip:\"Pan in both dimensions\",active:()=>\"both\"==this.dimensions,handler:()=>{this.dimensions=\"both\",this.active=!0}},{icon:r.tool_icon_x_pan,tooltip:\"Pan in x-dimension\",active:()=>\"width\"==this.dimensions,handler:()=>{this.dimensions=\"width\",this.active=!0}},{icon:r.tool_icon_y_pan,tooltip:\"Pan in y-dimension\",active:()=>\"height\"==this.dimensions,handler:()=>{this.dimensions=\"height\",this.active=!0}}]}}n.PanTool=p,o=p,p.__name__=\"PanTool\",o.prototype.default_view=l,o.define((()=>({dimensions:[h.Dimensions,\"both\"]}))),o.register_alias(\"pan\",(()=>new p({dimensions:\"both\"}))),o.register_alias(\"xpan\",(()=>new p({dimensions:\"width\"}))),o.register_alias(\"ypan\",(()=>new p({dimensions:\"height\"})))},\n", - " function _(e,t,n,o,l){var a;o();const i=e(264),r=e(272),s=e(232),_=e(88),h=e(18),g=e(269);class c extends i.ToolView{get overlays(){return[...super.overlays,this.model.overlay]}initialize(){super.initialize(),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())),this.model.overlay.pan.connect((([e,t])=>{\"pan\"==e?this.model.update_ranges_from_overlay():\"pan:end\"==e&&this.parent.trigger_ranges_update_event()}));const{active:e}=this.model.properties;this.on_change(e,(()=>{this.model.overlay.editable=this.model.active}))}}n.RangeToolView=c,c.__name__=\"RangeToolView\";const v=()=>new s.BoxAnnotation({syncable:!1,level:\"overlay\",visible:!0,editable:!0,propagate_hover:!0,fill_color:\"lightgrey\",fill_alpha:.5,line_color:\"black\",line_alpha:1,line_width:.5,line_dash:[2,2]});class y extends i.Tool{constructor(e){super(e),this.tool_name=\"Range Tool\",this.tool_icon=g.tool_icon_range}initialize(){super.initialize(),this.overlay.editable=this.active;const e=null!=this.x_range&&this.x_interaction,t=null!=this.y_range&&this.y_interaction;e&&t?(this.overlay.movable=\"both\",this.overlay.resizable=\"all\"):e?(this.overlay.movable=\"x\",this.overlay.resizable=\"x\"):t?(this.overlay.movable=\"y\",this.overlay.resizable=\"y\"):(this.overlay.movable=\"none\",this.overlay.resizable=\"none\")}update_ranges_from_overlay(){const{left:e,right:t,top:n,bottom:o}=this.overlay;null!=this.x_range&&this.x_interaction&&this.x_range.setv({start:e,end:t}),null!=this.y_range&&this.y_interaction&&this.y_range.setv({start:o,end:n})}update_overlay_from_ranges(){const{x_range:e,y_range:t}=this,n=null!=e,o=null!=t;n||o?this.overlay.update({left:n?e.start:null,right:n?e.end:null,bottom:o?t.start:null,top:o?t.end:null}):(this.overlay.clear(),h.logger.warn(\"RangeTool not configured with any Ranges.\"))}tool_button(){return new r.OnOffButton({tool:this})}}n.RangeTool=y,a=y,y.__name__=\"RangeTool\",a.prototype.default_view=c,a.define((({Boolean:e,Ref:t,Nullable:n})=>({x_range:[n(t(_.Range1d)),null],y_range:[n(t(_.Range1d)),null],x_interaction:[e,!0],y_interaction:[e,!0],overlay:[t(s.BoxAnnotation),v]}))),a.override({active:!0})},\n", - " function _(e,t,s,o,i){var l;o();const a=e(479),n=e(19),c=e(269);class r extends a.SelectToolView{_tap(e){\"tap\"==this.model.gesture&&this._handle_tap(e)}_doubletap(e){\"doubletap\"==this.model.gesture&&this._handle_tap(e)}_handle_tap(e){const{sx:t,sy:s}=e,{frame:o}=this.plot_view;if(!o.bbox.contains(t,s))return;this._clear_other_overlays();const i={type:\"point\",sx:t,sy:s};this._select(i,!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=r,r.__name__=\"TapToolView\";class _ extends a.SelectTool{constructor(e){super(e),this.tool_name=\"Tap\",this.tool_icon=c.tool_icon_tap_select,this.event_type=\"tap\",this.default_order=10}}s.TapTool=_,l=_,_.__name__=\"TapTool\",l.prototype.default_view=r,l.define((({Any:e,Nullable:t})=>({behavior:[n.TapBehavior,\"select\"],gesture:[n.TapGesture,\"tap\"],callback:[t(e),null]}))),l.register_alias(\"click\",(()=>new _({behavior:\"inspect\"}))),l.register_alias(\"tap\",(()=>new _)),l.register_alias(\"doubletap\",(()=>new _({gesture:\"doubletap\"})))},\n", - " function _(e,t,s,i,n){var o;i();const a=e(271),l=e(19),_=e(269),r=e(483);class h extends a.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,_]=[n.start,n.end];let h,d,p,c;switch(this.model.dimension){case\"height\":{const t=Math.abs(_-l);h=o,d=a,p=l-t*e,c=_-t*e;break}case\"width\":{const t=Math.abs(a-o);h=o-t*e,d=a-t*e,p=l,c=_;break}}const{x_scales:w,y_scales:g}=s,u={xrs:(0,r.update_ranges)(w,h,d),yrs:(0,r.update_ranges)(g,p,c),factor:e};this.plot_view.state.push(\"wheel_pan\",{range:u}),this.plot_view.update_range(u,{scrolling:!0}),null===(t=this.model.document)||void 0===t||t.interactive_start(this.plot_view.model,(()=>this.plot_view.trigger_ranges_update_event()))}}s.WheelPanToolView=h,h.__name__=\"WheelPanToolView\";class d extends a.GestureTool{constructor(e){super(e),this.tool_name=\"Wheel Pan\",this.tool_icon=_.tool_icon_wheel_pan,this.event_type=\"scroll\",this.default_order=12}get tooltip(){return this._get_dim_tooltip(this.dimension)}}s.WheelPanTool=d,o=d,d.__name__=\"WheelPanTool\",o.prototype.default_view=h,o.define((()=>({dimension:[l.Dimension,\"width\"]}))),o.internal((({Number:e})=>({speed:[e,.001]}))),o.register_alias(\"xwheel_pan\",(()=>new d({dimension:\"width\"}))),o.register_alias(\"ywheel_pan\",(()=>new d({dimension:\"height\"})))},\n", - " function _(e,o,t,s,i){var l;s();const n=e(271),_=e(464),a=e(19),h=e(26),r=e(269);class m extends n.GestureToolView{_pinch(e){const{sx:o,sy:t,scale:s,shift_key:i,ctrl_key:l,alt_key:n}=e;let _;_=s>=1?20*(s-1):-20/s,this._scroll({type:\"wheel\",sx:o,sy:t,delta:_,shift_key:i,ctrl_key:l,alt_key:n})}_scroll(e){var o;const{frame:t}=this.plot_view,s=t.bbox.h_range,i=t.bbox.v_range,{sx:l,sy:n}=e,a=this.model.dimensions,h=(\"width\"==a||\"both\"==a)&&s.startthis.plot_view.trigger_ranges_update_event()))}}t.WheelZoomToolView=m,m.__name__=\"WheelZoomToolView\";class d extends n.GestureTool{constructor(e){super(e),this.tool_name=\"Wheel Zoom\",this.tool_icon=r.tool_icon_wheel_zoom,this.event_type=h.is_mobile?\"pinch\":\"scroll\",this.default_order=10}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}t.WheelZoomTool=d,l=d,d.__name__=\"WheelZoomTool\",l.prototype.default_view=m,l.define((({Boolean:e,Number:o})=>({dimensions:[a.Dimensions,\"both\"],maintain_focus:[e,!0],zoom_on_axis:[e,!0],speed:[o,1/600]}))),l.register_alias(\"wheel_zoom\",(()=>new d({dimensions:\"both\"}))),l.register_alias(\"xwheel_zoom\",(()=>new d({dimensions:\"width\"}))),l.register_alias(\"ywheel_zoom\",(()=>new d({dimensions:\"height\"})))},\n", - " function _(o,r,s,e,l){e(),l(\"CrosshairTool\",o(489).CrosshairTool),l(\"CustomJSHover\",o(490).CustomJSHover),l(\"HoverTool\",o(491).HoverTool),l(\"InspectTool\",o(273).InspectTool)},\n", - " function _(s,e,i,t,o){var n;t();const a=s(273),r=s(254),l=s(19),_=s(8),h=s(269);class c extends a.InspectToolView{get overlays(){return[...super.overlays,...this._spans]}initialize(){super.initialize(),this._update_overlays()}connect_signals(){super.connect_signals();const{overlay:s,dimensions:e,line_color:i,line_width:t,line_alpha:o}=this.model.properties;this.on_change([s,e,i,t,o],(()=>{this._update_overlays()}))}_update_overlays(){const{overlay:s}=this.model;if(\"auto\"==s){const{dimensions:e,line_color:i,line_alpha:t,line_width:o}=this.model;function n(s){return new r.Span({dimension:s,location_units:\"canvas\",level:\"overlay\",line_color:i,line_width:o,line_alpha:t})}switch(e){case\"width\":this._spans=[n(\"width\")];break;case\"height\":this._spans=[n(\"height\")];break;case\"both\":this._spans=[n(\"width\"),n(\"height\")]}}else(0,_.isArray)(s)?this._spans=[...s]:this._spans=[s]}_move(s){if(!this.model.active)return;const{sx:e,sy:i}=s;this.plot_view.frame.bbox.contains(e,i)?this._update_spans(e,i):this._update_spans(NaN,NaN)}_move_exit(s){this._update_spans(NaN,NaN)}_update_spans(s,e){const{frame:i}=this.plot_view;function t(s,e,t){const{dimension:o}=s;switch(s.location_units){case\"canvas\":return\"width\"==o?t:e;case\"screen\":{const{xview:s,yview:n}=i.bbox;return\"width\"==o?n.invert(t):s.invert(e)}case\"data\":{const{x_scale:s,y_scale:n}=i;return\"width\"==o?n.invert(t):s.invert(e)}}}for(const i of this._spans)i.location=t(i,s,e)}}i.CrosshairToolView=c,c.__name__=\"CrosshairToolView\";class p extends a.InspectTool{constructor(s){super(s),this.tool_name=\"Crosshair\",this.tool_icon=h.tool_icon_crosshair}get tooltip(){return this._get_dim_tooltip(this.dimensions)}}i.CrosshairTool=p,n=p,p.__name__=\"CrosshairTool\",n.prototype.default_view=c,n.define((({Alpha:s,Number:e,Color:i,Auto:t,Tuple:o,Ref:n,Or:a})=>({overlay:[a(t,n(r.Span),o(n(r.Span),n(r.Span))),\"auto\"],dimensions:[l.Dimensions,\"both\"],line_color:[i,\"black\"],line_width:[e,1],line_alpha:[s,1]}))),n.register_alias(\"crosshair\",(()=>new p))},\n", - " function _(e,s,t,r,n){var o;r();const a=e(50),u=e(9),c=e(38);class i extends a.Model{constructor(e){super(e)}get values(){return(0,u.values)(this.args)}_make_code(e,s,t,r){return new Function(...(0,u.keys)(this.args),e,s,t,(0,c.use_strict)(r))}format(e,s,t){return this._make_code(\"value\",\"format\",\"special_vars\",this.code)(...this.values,e,s,t)}}t.CustomJSHover=i,o=i,i.__name__=\"CustomJSHover\",o.define((({Unknown:e,String:s,Dict:t})=>({args:[t(e),{}],code:[s,\"\"]})))},\n", - " function _(e,t,n,s,i){var o;s();const r=e(1),l=e(59),a=e(56),c=e(19),_=r.__importStar(e(210)),d=e(15),p=e(12),u=e(21),h=e(32),m=e(9),y=e(170),f=e(8),v=e(269),x=r.__importStar(e(450)),w=e(448),g=e(492),b=e(212),C=e(329),T=e(201),S=e(333),$=e(211),k=e(214),V=e(200),A=e(199),M=e(409),H=e(95),R=e(490),z=e(273);function G(e,t,n,s){const i={x:n[e],y:s[e]},o={x:n[e+1],y:s[e+1]},{sx:r,sy:l}=t,[a,c]=function(){if(\"span\"==t.type)return\"h\"==t.direction?[Math.abs(i.x-r),Math.abs(o.x-r)]:[Math.abs(i.y-l),Math.abs(o.y-l)];const e={x:r,y:l};return[_.dist_2_pts(i,e),_.dist_2_pts(o,e)]}();return adelete this._template_el)),this.on_change([e,t,n],(async()=>await this._update_ttmodels()))}async _update_ttmodels(){const{ttmodels:e}=this;e.clear();const{tooltips:t}=this.model;if(null==t)return;const{computed_renderers:n}=this;for(const t of n){const n=new w.Tooltip({content:document.createElement(\"div\"),attachment:this.model.attachment,show_arrow:this.model.show_arrow,interactive:!1,visible:!0,position:null,target:this.parent.canvas.overlays_el});t instanceof A.GlyphRenderer?e.set(t,n):t instanceof M.GraphRenderer&&(e.set(t.node_renderer,n),e.set(t.edge_renderer,n))}await(0,l.build_views)(this._ttviews,[...e.values()],{parent:this.plot_view});const s=[...function*(){for(const e of n)e instanceof A.GlyphRenderer?yield e:e instanceof M.GraphRenderer&&(yield e.node_renderer,yield e.edge_renderer)}()],i=this._slots.get(this.update);if(null!=i){const e=new Set(s.map((e=>e.data_source)));d.Signal.disconnect_receiver(this,i,e)}for(const e of s)this.connect(e.data_source.inspect,this.update)}get computed_renderers(){const{renderers:e}=this.model,t=this.plot_view.model.data_renderers;return(0,H.compute_renderers)(e,t)}_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,t,n){var s,i;const o=e.get_selection_manager(),r=o.inspectors.get(e),l=e.view.convert_selection_to_subset(r);if(r.is_empty()&&null==r.view)return void n.clear();const c=o.source,_=this.plot_view.renderer_view(e);if(null==_)return;const{sx:d,sy:u}=t,h=_.coordinates.x_scale,y=_.coordinates.y_scale,f=h.invert(d),v=y.invert(u),{glyph:x}=_,w=[];if(x instanceof $.PatchView){const[t,n]=[d,u],[s,i]=[f,v],o={index:null,glyph_view:x,x:f,y:v,sx:d,sy:u,snap_x:s,snap_y:i,snap_sx:t,snap_sy:n,name:e.name},r=this._render_tooltips(c,o);w.push([t,n,r])}else if(x instanceof k.VAreaView||x instanceof b.HAreaView)for(const t of l.line_indices){const[n,s]=[f,v],[i,o]=[d,u],r={index:t,glyph_view:x,x:f,y:v,sx:d,sy:u,snap_x:n,snap_y:s,snap_sx:i,snap_sy:o,name:e.name,indices:l.line_indices},a=this._render_tooltips(c,r);w.push([i,o,a])}else if(x instanceof T.LineView){const{line_policy:n}=this.model;for(const s of l.line_indices){const[[i,o],[r,a],p]=(()=>{const[e,i]=[x._x,x._y];switch(n){case\"interp\":{const[e,n]=x.get_interpolation_hit(s,t);return[[e,n],[h.compute(e),y.compute(n)],s]}case\"prev\":{const[t,n]=P(x.sx,x.sy,s);return[[e[s+1],i[s+1]],t,n]}case\"next\":{const[t,n]=P(x.sx,x.sy,s+1);return[[e[s+1],i[s+1]],t,n]}case\"nearest\":{const[n,o]=G(s,t,x.sx,x.sy);return[[e[o],i[o]],n,o]}case\"none\":{const e=_.coordinates.x_scale,t=_.coordinates.y_scale;return[[e.invert(d),t.invert(u)],[d,u],s]}}})(),m={index:p,glyph_view:x,x:f,y:v,sx:d,sy:u,snap_x:i,snap_y:o,snap_sx:r,snap_sy:a,name:e.name,indices:l.line_indices},g=this._render_tooltips(c,m);w.push([r,a,g])}}else if(x instanceof C.ImageBaseView)for(const t of r.image_indices){const[n,s]=[d,u],[i,o]=[f,v],r={index:t.index,glyph_view:x,x:f,y:v,sx:d,sy:u,snap_x:i,snap_y:o,snap_sx:n,snap_sy:s,name:e.name,image_index:t},l=this._render_tooltips(c,r);w.push([n,s,l])}else for(const n of l.indices)if(x instanceof S.MultiLineView&&!(0,m.is_empty)(l.multiline_indices)){const{line_policy:s}=this.model;for(const i of l.multiline_indices[n.toString()]){const[[o,r],[a,_],p]=function(){if(\"interp\"==s){const[e,s]=x.get_interpolation_hit(n,i,t);return[[e,s],[h.compute(e),y.compute(s)],i]}const[e,o]=[x._xs.get(n),x._ys.get(n)];if(\"prev\"==s){const[t,s]=P(x.sxs.get(n),x.sys.get(n),i);return[[e[i],o[i]],t,s]}if(\"next\"==s){const[t,s]=P(x.sxs.get(n),x.sys.get(n),i+1);return[[e[i],o[i]],t,s]}if(\"nearest\"==s){const[s,r]=G(i,t,x.sxs.get(n),x.sys.get(n));return[[e[r],o[r]],s,r]}throw new Error(\"shouldn't have happened\")}(),m={index:e.view.convert_indices_from_subset([n])[0],glyph_view:x,x:f,y:v,sx:d,sy:u,snap_x:o,snap_y:r,snap_sx:a,snap_sy:_,name:e.name,indices:l.multiline_indices,segment_index:p},g=this._render_tooltips(c,m);w.push([a,_,g])}}else{const t=null===(s=x._x)||void 0===s?void 0:s[n],o=null===(i=x._y)||void 0===i?void 0:i[n],{point_policy:r,anchor:a}=this.model,[_,p]=function(){if(\"snap_to_data\"==r){const e=x.get_anchor_point(a,n,[d,u]);if(null!=e)return[e.x,e.y];const t=x.get_anchor_point(\"center\",n,[d,u]);return null!=t?[t.x,t.y]:[d,u]}return[d,u]}(),h={index:e.view.convert_indices_from_subset([n])[0],glyph_view:x,x:f,y:v,sx:d,sy:u,snap_x:t,snap_y:o,snap_sx:_,snap_sy:p,name:e.name,indices:l.indices},m=this._render_tooltips(c,h);w.push([_,p,m])}const{bbox:g}=this.plot_view.frame,V=w.filter((([e,t])=>g.contains(e,t)));if(0==V.length)n.clear();else{const{content:e}=n;(0,p.assert)(e instanceof Element),(0,a.empty)(e);for(const[,,t]of V)null!=t&&e.appendChild(t);const[t,s]=V[V.length-1];n.setv({position:[t,s]},{check_eq:!1})}}update([e,{geometry:t}]){if(!this.model.active)return;if(\"point\"!=t.type&&\"span\"!=t.type)return;if(\"ignore\"==this.model.muted_policy&&e.muted)return;const n=this.ttmodels.get(e);(0,f.is_undefined)(n)||this._update(e,t,n)}_emit_callback(e){const{callback:t}=this.model;if(null!=t)for(const n of this.computed_renderers){if(!(n instanceof A.GlyphRenderer))continue;const s=this.plot_view.renderer_view(n);if(null==s)continue;const{x_scale:i,y_scale:o}=s.coordinates,r=i.invert(e.sx),l=o.invert(e.sy),a=n.data_source.inspected;t.execute(this.model,{geometry:Object.assign({x:r,y:l},e),renderer:n,index:a})}}_create_template(e){const t=(0,a.div)({style:{display:\"table\",borderSpacing:\"2px\"}});for(const[n]of e){const e=(0,a.div)({style:{display:\"table-row\"}});t.appendChild(e);const s=(0,a.div)({style:{display:\"table-cell\"},class:x.tooltip_row_label},0!=n.length?`${n}: `:\"\");e.appendChild(s);const i=(0,a.span)();i.dataset.value=\"\";const o=(0,a.span)({class:x.tooltip_color_block},\" \");o.dataset.swatch=\"\",(0,a.undisplay)(o);const r=(0,a.div)({style:{display:\"table-cell\"},class:x.tooltip_row_value},i,o);e.appendChild(r)}return t}_render_template(e,t,n,s){const i=e.cloneNode(!0),o=(0,f.is_undefined)(s.image_index)?s.index:s.image_index,r=i.querySelectorAll(\"[data-value]\"),l=i.querySelectorAll(\"[data-swatch]\"),c=/\\$color(\\[.*\\])?:(\\w*)/,_=/\\$swatch:(\\w*)/;for(const[[,e],i]of(0,h.enumerate)(t)){const t=e.match(_),d=e.match(c);if(null!=t||null!=d){if(null!=t){const[,e]=t,s=n.get_column(e);if(null==s)r[i].textContent=`${e} unknown`;else{const e=(0,f.isNumber)(o)?s[o]:null;null!=e&&(l[i].style.backgroundColor=(0,u.color2css)(e),(0,a.display)(l[i]))}}if(null!=d){const[,e=\"\",t]=d,s=n.get_column(t);if(null==s){r[i].textContent=`${t} unknown`;continue}const c=e.indexOf(\"hex\")>=0,_=e.indexOf(\"swatch\")>=0,p=(0,f.isNumber)(o)?s[o]:null;if(null==p){r[i].textContent=\"(null)\";continue}r[i].textContent=c?(0,u.color2hex)(p):(0,u.color2css)(p),_&&(l[i].style.backgroundColor=(0,u.color2css)(p),(0,a.display)(l[i]))}}else{const t=(0,y.replace_placeholders)(e.replace(\"$~\",\"$data_\"),n,o,this.model.formatters,s);if((0,f.isString)(t))r[i].textContent=t;else for(const e of t)r[i].appendChild(e)}}return i}_render_tooltips(e,t){var n;const{tooltips:s}=this.model,i=t.index;if((0,f.isString)(s)){const n=(0,y.replace_placeholders)({html:s},e,i,this.model.formatters,t);return(0,a.div)(n)}if((0,f.isFunction)(s))return s(e,t);if(s instanceof g.Template)return this._template_view.update(e,i,t),this._template_view.el;if(null!=s){const i=null!==(n=this._template_el)&&void 0!==n?n:this._template_el=this._create_template(s);return this._render_template(i,s,e,t)}return null}}n.HoverToolView=N,N.__name__=\"HoverToolView\";class O extends z.InspectTool{constructor(e){super(e),this.tool_name=\"Hover\",this.tool_icon=v.tool_icon_hover}}n.HoverTool=O,o=O,O.__name__=\"HoverTool\",o.prototype.default_view=N,o.define((({Any:e,Boolean:t,String:n,Array:s,Tuple:i,Dict:o,Or:r,Ref:l,Function:a,Auto:_,Nullable:d})=>({tooltips:[d(r(l(g.Template),n,s(i(n,n)),a())),[[\"index\",\"$index\"],[\"data (x, y)\",\"($x, $y)\"],[\"screen (x, y)\",\"($sx, $sy)\"]]],formatters:[o(r(l(R.CustomJSHover),y.FormatterType)),{}],renderers:[r(s(l(V.DataRenderer)),_),\"auto\"],mode:[c.HoverMode,\"mouse\"],muted_policy:[c.MutedPolicy,\"show\"],point_policy:[c.PointPolicy,\"snap_to_data\"],line_policy:[c.LinePolicy,\"nearest\"],show_arrow:[t,!0],anchor:[c.Anchor,\"center\"],attachment:[c.TooltipAttachment,\"horizontal\"],callback:[d(e),null]}))),o.register_alias(\"hover\",(()=>new O))},\n", - " function _(e,i,t,a,s){var n;a();const o=e(493),l=e(494),c=e(495),_=e(59);class r extends o.DOMElementView{constructor(){super(...arguments),this.action_views=new Map}*children(){yield*super.children(),yield*this.action_views.values()}async lazy_initialize(){await super.lazy_initialize(),await(0,_.build_views)(this.action_views,this.model.actions,{parent:this})}remove(){(0,_.remove_views)(this.action_views),super.remove()}update(e,i,t={}){!function a(s){for(const n of s.child_views.values())n instanceof c.PlaceholderView?n.update(e,i,t):n instanceof o.DOMElementView&&a(n)}(this);for(const a of this.action_views.values())a.update(e,i,t)}}t.TemplateView=r,r.__name__=\"TemplateView\",r.tag_name=\"div\";class v extends o.DOMElement{}t.Template=v,n=v,v.__name__=\"Template\",n.prototype.default_view=r,n.define((({Array:e,Ref:i})=>({actions:[e(i(l.Action)),[]]})))},\n", - " function _(e,t,i,s,l){var n;s();const r=e(442),o=e(258),c=e(257),h=e(59),a=e(9),d=e(8);class _ extends r.DOMNodeView{constructor(){super(...arguments),this.child_views=new Map}*children(){yield*super.children(),yield*this.child_views.values()}async lazy_initialize(){await super.lazy_initialize();const e=this.model.children.filter((e=>!(0,d.isString)(e)));await(0,h.build_views)(this.child_views,e,{parent:this})}remove(){(0,h.remove_views)(this.child_views),super.remove()}render(){const{style:e}=this.model;if(null!=e)if(e instanceof o.Styles)for(const t of e){const e=t.get_value();if((0,d.isString)(e)){const i=t.attr.replace(/_/g,\"-\");this.el.style.hasOwnProperty(i)&&this.el.style.setProperty(i,e)}}else for(const[t,i]of(0,a.entries)(e)){const e=t.replace(/_/g,\"-\");this.el.style.hasOwnProperty(e)&&this.el.style.setProperty(e,i)}for(const e of this.model.children)if((0,d.isString)(e)){const t=document.createTextNode(e);this.el.appendChild(t)}else{this.child_views.get(e).render_to(this.el)}this.finish()}}i.DOMElementView=_,_.__name__=\"DOMElementView\";class y extends r.DOMNode{constructor(e){super(e)}}i.DOMElement=y,n=y,y.__name__=\"DOMElement\",n.define((({String:e,Array:t,Dict:i,Or:s,Nullable:l,Ref:n})=>({style:[l(s(n(o.Styles),i(e))),null],children:[t(s(e,n(r.DOMNode),n(c.UIElement))),[]]})))},\n", - " function _(e,o,_,n,c){n();const s=e(50),t=e(54);class i extends t.View{}_.ActionView=i,i.__name__=\"ActionView\";class d extends s.Model{constructor(e){super(e)}}_.Action=d,d.__name__=\"Action\",d.__module__=\"bokeh.models.dom\"},\n", - " function _(e,a,n,c,l){c();const o=e(442);class s extends o.DOMNodeView{render(){}}n.PlaceholderView=s,s.__name__=\"PlaceholderView\",s.tag_name=\"span\";class _ extends o.DOMNode{constructor(e){super(e)}}n.Placeholder=_,_.__name__=\"Placeholder\"},\n", - " function _(e,l,t,o,a){o(),a(\"Action\",e(494).Action),a(\"ColorRef\",e(497).ColorRef),a(\"DOMElement\",e(493).DOMElement),a(\"DOMNode\",e(442).DOMNode);var S=e(499);a(\"Span\",S.Span),a(\"Div\",S.Div),a(\"Table\",S.Table),a(\"TableRow\",S.TableRow),a(\"HTML\",e(449).HTML),a(\"Index\",e(500).Index),a(\"Placeholder\",e(495).Placeholder),a(\"Styles\",e(258).Styles);var n=e(259);a(\"InlineStyleSheet\",n.InlineStyleSheet),a(\"GlobalInlineStyleSheet\",n.GlobalInlineStyleSheet),a(\"ImportedStyleSheet\",n.ImportedStyleSheet),a(\"GlobalImportedStyleSheet\",n.GlobalImportedStyleSheet),a(\"Template\",e(492).Template),a(\"Text\",e(443).Text),a(\"ToggleGroup\",e(501).ToggleGroup),a(\"ValueOf\",e(502).ValueOf),a(\"ValueRef\",e(498).ValueRef)},\n", - " function _(e,l,t,o,s){var a;o();const n=e(1),_=e(498),i=e(170),r=e(56),c=n.__importStar(e(450));class h extends _.ValueRefView{render(){super.render(),this.value_el=(0,r.span)(),this.swatch_el=(0,r.span)({class:c.tooltip_color_block},\" \"),this.el.appendChild(this.value_el),this.el.appendChild(this.swatch_el)}update(e,l,t){const o=(0,i._get_column_value)(this.model.field,e,l),s=null==o?\"???\":`${o}`;this.el.textContent=s}}t.ColorRefView=h,h.__name__=\"ColorRefView\";class d extends _.ValueRef{constructor(e){super(e)}}t.ColorRef=d,a=d,d.__name__=\"ColorRef\",a.prototype.default_view=h,a.define((({Boolean:e})=>({hex:[e,!0],swatch:[e,!0]})))},\n", - " function _(e,l,t,n,a){var _;n();const o=e(495),s=e(170);class u extends o.PlaceholderView{update(e,l,t){const n=(0,s._get_column_value)(this.model.field,e,l),a=null==n?\"???\":`${n}`;this.el.textContent=a}}t.ValueRefView=u,u.__name__=\"ValueRefView\";class i extends o.Placeholder{constructor(e){super(e)}}t.ValueRef=i,_=i,i.__name__=\"ValueRef\",_.prototype.default_view=u,_.define((({String:e})=>({field:[e]})))},\n", - " function _(e,a,_,n,t){var l,s,i,m;n();const w=e(493);class o extends w.DOMElementView{}_.SpanView=o,o.__name__=\"SpanView\",o.tag_name=\"span\";class d extends w.DOMElement{}_.Span=d,l=d,d.__name__=\"Span\",l.prototype.default_view=o;class p extends w.DOMElementView{}_.DivView=p,p.__name__=\"DivView\",p.tag_name=\"div\";class D extends w.DOMElement{}_.Div=D,s=D,D.__name__=\"Div\",s.prototype.default_view=p;class V extends w.DOMElementView{}_.TableView=V,V.__name__=\"TableView\",V.tag_name=\"table\";class c extends w.DOMElement{}_.Table=c,i=c,c.__name__=\"Table\",i.prototype.default_view=V;class v extends w.DOMElementView{}_.TableRowView=v,v.__name__=\"TableRowView\",v.tag_name=\"tr\";class b extends w.DOMElement{}_.TableRow=b,m=b,b.__name__=\"TableRow\",m.prototype.default_view=v},\n", - " function _(e,n,t,l,d){var o;l();const s=e(495);class _ extends s.PlaceholderView{update(e,n,t){this.el.textContent=null==n?\"(null)\":n.toString()}}t.IndexView=_,_.__name__=\"IndexView\";class a extends s.Placeholder{constructor(e){super(e)}}t.Index=a,o=a,a.__name__=\"Index\",o.prototype.default_view=_},\n", - " function _(e,o,r,t,n){var s;t();const u=e(494),i=e(74),p=e(32);class g extends u.ActionView{update(e,o,r){for(const[e,r]of(0,p.enumerate)(this.model.groups))e.visible=o==r}}r.ToggleGroupView=g,g.__name__=\"ToggleGroupView\";class _ extends u.Action{constructor(e){super(e)}}r.ToggleGroup=_,s=_,_.__name__=\"ToggleGroup\",s.prototype.default_view=g,s.define((({Array:e,Ref:o})=>({groups:[e(o(i.RendererGroup)),[]]})))},\n", - " function _(e,t,n,s,o){var r;s();const i=e(442),a=e(14),l=e(56),c=e(40);class p extends i.DOMNodeView{connect_signals(){super.connect_signals();const{obj:e,attr:t}=this.model;t in e.properties&&this.on_change(e.properties[t],(()=>this.render()))}render(){(0,l.empty)(this.el),this.el.style.display=\"contents\";const e=(()=>{const{obj:e,attr:t}=this.model;if(t in e.properties){const n=e.properties[t].get_value();return(0,c.to_string)(n)}return``})();this.el.textContent=e}}n.ValueOfView=p,p.__name__=\"ValueOfView\";class _ extends i.DOMNode{constructor(e){super(e)}}n.ValueOf=_,r=_,_.__name__=\"ValueOf\",r.prototype.default_view=p,r.define((({String:e,Ref:t})=>({obj:[t(a.HasProps)],attr:[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/object\":9,\"core/util/array\":10,\"core/util/math\":11,\"core/util/assert\":12,\"core/util/arrayable\":13,\"core/has_props\":14,\"core/signaling\":15,\"core/util/defer\":16,\"core/properties\":17,\"core/logging\":18,\"core/enums\":19,\"core/kinds\":20,\"core/util/color\":21,\"core/util/svg_colors\":22,\"core/types\":23,\"core/util/bitset\":24,\"core/util/eq\":25,\"core/util/platform\":26,\"core/vectorization\":27,\"core/settings\":28,\"core/util/ndarray\":29,\"core/serialization/index\":30,\"core/serialization/serializer\":31,\"core/util/iterator\":32,\"core/serialization/buffer\":33,\"core/util/buffer\":34,\"core/serialization/reps\":35,\"core/diagnostics\":36,\"core/uniforms\":37,\"core/util/string\":38,\"document/events\":39,\"core/util/pretty\":40,\"core/util/cloneable\":41,\"core/patching\":42,\"core/util/set\":43,\"core/util/typed_array\":44,\"core/resolvers\":45,\"core/serialization/deserializer\":46,\"core/util/refs\":47,\"core/util/slice\":48,\"core/util/version\":49,\"model\":50,\"document/defs\":51,\"core/bokeh_events\":52,\"embed/standalone\":53,\"core/view\":54,\"core/dom_view\":55,\"core/dom\":56,\"core/util/bbox\":57,\"styles/base.css\":58,\"core/build_views\":59,\"embed/server\":60,\"client/connection\":61,\"protocol/message\":62,\"protocol/receiver\":63,\"client/session\":64,\"embed/dom\":65,\"embed/notebook\":66,\"protocol/index\":67,\"testing\":68,\"safely\":69,\"models/main\":70,\"models/index\":71,\"models/annotations/index\":72,\"models/annotations/annotation\":73,\"models/renderers/renderer\":74,\"core/visuals/index\":75,\"core/visuals/line\":76,\"core/visuals/visual\":77,\"core/property_mixins\":78,\"core/visuals/fill\":79,\"core/visuals/text\":80,\"core/visuals/hatch\":81,\"core/visuals/patterns\":82,\"core/visuals/image\":83,\"models/coordinates/coordinate_mapping\":84,\"models/scales/scale\":85,\"models/transforms/transform\":86,\"models/ranges/range\":87,\"models/ranges/range1d\":88,\"models/scales/linear_scale\":89,\"models/scales/continuous_scale\":90,\"models/scales/log_scale\":91,\"models/scales/categorical_scale\":92,\"models/ranges/data_range1d\":93,\"models/ranges/data_range\":94,\"models/util\":95,\"models/ranges/factor_range\":96,\"models/annotations/arrow\":97,\"models/annotations/data_annotation\":98,\"models/sources/columnar_data_source\":99,\"core/selection_manager\":100,\"models/selections/selection\":101,\"models/selections/interaction_policy\":102,\"models/sources/data_source\":103,\"models/sources/column_data_source\":104,\"core/util/projections\":105,\"models/annotations/arrow_head\":139,\"models/graphics/marking\":140,\"models/annotations/base_color_bar\":141,\"models/annotations/title\":142,\"models/annotations/text_annotation\":143,\"core/layout/side_panel\":144,\"core/layout/types\":145,\"core/layout/layoutable\":146,\"models/text/base_text\":147,\"models/text/utils\":148,\"models/text/math_text\":149,\"core/util/image\":150,\"core/graphics\":151,\"core/util/text\":152,\"core/util/affine\":153,\"models/text/providers\":154,\"core/util/modules\":155,\"models/text/plain_text\":156,\"models/canvas/cartesian_frame\":157,\"models/axes/index\":158,\"models/axes/axis\":159,\"models/renderers/guide_renderer\":160,\"models/tickers/ticker\":161,\"models/formatters/tick_formatter\":162,\"models/policies/labeling\":163,\"models/axes/categorical_axis\":164,\"models/tickers/categorical_ticker\":165,\"models/formatters/categorical_tick_formatter\":166,\"models/axes/continuous_axis\":167,\"models/axes/datetime_axis\":168,\"models/formatters/datetime_tick_formatter\":169,\"core/util/templating\":170,\"models/tickers/util\":174,\"models/tickers/datetime_ticker\":175,\"models/tickers/adaptive_ticker\":176,\"models/tickers/continuous_ticker\":177,\"models/tickers/composite_ticker\":178,\"models/tickers/days_ticker\":179,\"models/tickers/single_interval_ticker\":180,\"models/tickers/months_ticker\":181,\"models/tickers/years_ticker\":182,\"models/tickers/basic_ticker\":183,\"models/axes/linear_axis\":184,\"models/formatters/basic_tick_formatter\":185,\"models/axes/log_axis\":186,\"models/formatters/log_tick_formatter\":187,\"models/tickers/log_ticker\":188,\"models/axes/mercator_axis\":189,\"models/formatters/mercator_tick_formatter\":190,\"models/tickers/mercator_ticker\":191,\"models/tickers/index\":192,\"models/tickers/fixed_ticker\":193,\"models/tickers/binned_ticker\":194,\"models/mappers/scanning_color_mapper\":195,\"models/mappers/continuous_color_mapper\":196,\"models/mappers/color_mapper\":197,\"models/mappers/mapper\":198,\"models/renderers/glyph_renderer\":199,\"models/renderers/data_renderer\":200,\"models/glyphs/line\":201,\"models/glyphs/xy_glyph\":202,\"models/glyphs/glyph\":203,\"core/util/ragged_array\":204,\"core/util/spatial\":205,\"models/graphics/decoration\":208,\"models/glyphs/utils\":209,\"core/hittest\":210,\"models/glyphs/patch\":211,\"models/glyphs/harea\":212,\"models/glyphs/area\":213,\"models/glyphs/varea\":214,\"models/sources/cds_view\":215,\"models/filters/filter\":216,\"models/filters/all_indices\":217,\"models/filters/intersection_filter\":218,\"models/formatters/index\":219,\"models/formatters/customjs_tick_formatter\":220,\"models/formatters/numeral_tick_formatter\":221,\"models/formatters/printf_tick_formatter\":222,\"models/scales/index\":223,\"models/scales/linear_interpolation_scale\":224,\"models/ranges/index\":225,\"core/layout/index\":226,\"core/layout/alignments\":227,\"core/layout/grid\":228,\"core/layout/border\":229,\"models/annotations/band\":230,\"models/annotations/upper_lower\":231,\"models/annotations/box_annotation\":232,\"models/common/kinds\":233,\"models/common/painting\":234,\"models/common/resolve\":235,\"models/annotations/color_bar\":236,\"models/mappers/index\":237,\"models/mappers/categorical_color_mapper\":238,\"models/mappers/categorical_mapper\":239,\"models/mappers/categorical_marker_mapper\":240,\"models/mappers/categorical_pattern_mapper\":241,\"models/mappers/linear_color_mapper\":242,\"models/mappers/log_color_mapper\":243,\"models/mappers/eqhist_color_mapper\":244,\"models/mappers/stack_color_mapper\":245,\"models/mappers/weighted_stack_color_mapper\":246,\"models/annotations/contour_color_bar\":247,\"models/annotations/label\":248,\"models/annotations/label_set\":249,\"models/annotations/legend\":250,\"models/annotations/legend_item\":251,\"models/annotations/poly_annotation\":252,\"models/annotations/slope\":253,\"models/annotations/span\":254,\"models/annotations/toolbar_panel\":255,\"models/tools/toolbar\":256,\"models/ui/ui_element\":257,\"models/dom/styles\":258,\"models/dom/stylesheets\":259,\"core/util/canvas\":260,\"core/util/svg\":261,\"core/util/random\":262,\"styles/ui.css\":263,\"models/tools/tool\":264,\"models/tools/tool_proxy\":265,\"models/tools/tool_button\":266,\"core/util/menus\":267,\"styles/menus.css\":268,\"styles/icons.css\":269,\"styles/tool_button.css\":270,\"models/tools/gestures/gesture_tool\":271,\"models/tools/on_off_button\":272,\"models/tools/inspectors/inspect_tool\":273,\"models/tools/actions/action_tool\":274,\"models/tools/click_button\":275,\"models/tools/actions/help_tool\":276,\"styles/toolbar.css\":277,\"styles/logo.css\":278,\"models/annotations/whisker\":279,\"models/annotations/html/index\":280,\"models/annotations/html/label\":281,\"models/annotations/html/text_annotation\":282,\"models/annotations/html/label_set\":283,\"models/annotations/html/title\":284,\"models/callbacks/index\":285,\"models/callbacks/customjs\":286,\"models/callbacks/callback\":287,\"models/callbacks/open_url\":288,\"models/callbacks/set_value\":289,\"models/canvas/index\":290,\"models/canvas/canvas\":291,\"core/ui_events\":292,\"core/util/wheel\":294,\"styles/canvas.css\":295,\"models/coordinates/index\":296,\"models/expressions/index\":297,\"models/expressions/expression\":298,\"models/expressions/customjs_expr\":299,\"models/expressions/stack\":300,\"models/expressions/cumsum\":301,\"models/expressions/minimum\":302,\"models/expressions/maximum\":303,\"models/expressions/coordinate_transform\":304,\"models/expressions/polar\":305,\"models/filters/index\":306,\"models/filters/boolean_filter\":307,\"models/filters/customjs_filter\":308,\"models/filters/group_filter\":309,\"models/filters/index_filter\":310,\"models/filters/inversion_filter\":311,\"models/filters/union_filter\":312,\"models/filters/difference_filter\":313,\"models/filters/symmetric_difference_filter\":314,\"models/glyphs/index\":315,\"models/glyphs/annular_wedge\":316,\"models/glyphs/annulus\":317,\"models/glyphs/arc\":318,\"models/glyphs/bezier\":319,\"core/util/algorithms\":320,\"models/glyphs/block\":321,\"models/glyphs/lrtb\":322,\"models/glyphs/circle\":323,\"models/glyphs/ellipse\":324,\"models/glyphs/center_rotatable\":325,\"models/glyphs/hbar\":326,\"models/glyphs/hex_tile\":327,\"models/glyphs/image\":328,\"models/glyphs/image_base\":329,\"models/glyphs/image_rgba\":330,\"models/glyphs/image_stack\":331,\"models/glyphs/image_url\":332,\"models/glyphs/multi_line\":333,\"models/glyphs/multi_polygons\":334,\"models/glyphs/patches\":335,\"models/glyphs/quad\":336,\"models/glyphs/quadratic\":337,\"models/glyphs/ray\":338,\"models/glyphs/rect\":339,\"models/glyphs/scatter\":340,\"models/glyphs/marker\":341,\"models/glyphs/defs\":342,\"models/glyphs/segment\":343,\"models/glyphs/spline\":344,\"core/util/interpolation\":345,\"models/glyphs/step\":346,\"models/glyphs/text\":347,\"models/glyphs/vbar\":348,\"models/glyphs/wedge\":349,\"models/graphics/index\":350,\"models/graphs/index\":351,\"models/graphs/graph_hit_test_policy\":352,\"models/graphs/layout_provider\":353,\"models/graphs/static_layout_provider\":354,\"models/grids/index\":355,\"models/grids/grid\":356,\"models/layouts/index\":357,\"models/layouts/column\":358,\"models/layouts/flex_box\":359,\"models/layouts/layout_dom\":360,\"models/menus/menu\":361,\"models/menus/menu_item\":362,\"models/layouts/alignments\":363,\"models/layouts/grid_box\":364,\"models/layouts/css_grid_box\":365,\"models/layouts/group_box\":366,\"styles/group_box.css\":367,\"models/layouts/hbox\":368,\"models/layouts/row\":369,\"models/layouts/scroll_box\":370,\"models/layouts/spacer\":371,\"models/layouts/tab_panel\":372,\"models/layouts/tabs\":373,\"styles/tabs.css\":374,\"models/layouts/vbox\":375,\"models/menus/index\":376,\"models/menus/action\":377,\"models/ui/icons/icon\":378,\"models/menus/check_action\":379,\"models/menus/section\":380,\"models/menus/divider\":381,\"models/text/index\":382,\"models/transforms/index\":383,\"models/transforms/customjs_transform\":384,\"models/transforms/dodge\":385,\"models/transforms/range_transform\":386,\"models/transforms/interpolator\":387,\"models/transforms/jitter\":388,\"models/random/random_generator\":389,\"models/transforms/linear_interpolator\":390,\"models/transforms/step_interpolator\":391,\"models/plots/index\":392,\"models/plots/gmap_plot\":393,\"models/plots/plot\":394,\"models/plots/plot_canvas\":395,\"core/util/throttle\":396,\"models/plots/range_manager\":397,\"models/plots/state_manager\":398,\"styles/plots.css\":399,\"models/plots/gmap_plot_canvas\":400,\"models/plots/gmap\":401,\"models/plots/grid_plot\":402,\"models/plots/figure\":403,\"models/policies/index\":404,\"models/random/index\":405,\"models/random/park_miller_lcg\":406,\"models/renderers/index\":407,\"models/renderers/contour_renderer\":408,\"models/renderers/graph_renderer\":409,\"models/selections/index\":410,\"models/selectors/index\":411,\"models/selectors/by_id\":412,\"models/selectors/selector\":413,\"models/selectors/by_class\":414,\"models/selectors/by_css\":415,\"models/selectors/by_xpath\":416,\"models/sources/index\":417,\"models/sources/server_sent_data_source\":418,\"models/sources/web_data_source\":419,\"models/sources/ajax_data_source\":420,\"models/sources/geojson_data_source\":421,\"models/tiles/index\":422,\"models/tiles/bbox_tile_source\":423,\"models/tiles/mercator_tile_source\":424,\"models/tiles/tile_source\":425,\"models/tiles/tile_utils\":426,\"models/tiles/quadkey_tile_source\":427,\"models/tiles/tile_renderer\":428,\"models/tiles/wmts_tile_source\":429,\"styles/attribution.css\":430,\"models/tiles/tms_tile_source\":431,\"models/textures/index\":432,\"models/textures/canvas_texture\":433,\"models/textures/texture\":434,\"models/textures/image_url_texture\":435,\"models/ui/index\":436,\"models/ui/icons/index\":437,\"models/ui/icons/builtin_icon\":438,\"models/ui/icons/svg_icon\":439,\"models/ui/icons/tabler_icon\":440,\"models/ui/dialog\":441,\"models/dom/dom_node\":442,\"models/dom/text\":443,\"styles/dialogs.css\":444,\"models/ui/examiner\":445,\"styles/examiner.css\":446,\"models/ui/pane\":447,\"models/ui/tooltip\":448,\"models/dom/html\":449,\"styles/tooltips.css\":450,\"models/tools/index\":451,\"models/tools/actions/index\":452,\"models/tools/actions/copy_tool\":453,\"models/tools/actions/custom_action\":454,\"models/tools/actions/fullscreen_tool\":455,\"models/tools/actions/examine_tool\":456,\"models/tools/actions/redo_tool\":457,\"models/tools/actions/plot_action_tool\":458,\"models/tools/actions/reset_tool\":459,\"models/tools/actions/save_tool\":460,\"models/tools/actions/undo_tool\":461,\"models/tools/actions/zoom_in_tool\":462,\"models/tools/actions/zoom_base_tool\":463,\"core/util/zoom\":464,\"models/tools/actions/zoom_out_tool\":465,\"models/tools/edit/index\":466,\"models/tools/edit/edit_tool\":467,\"models/tools/edit/box_edit_tool\":468,\"models/tools/edit/freehand_draw_tool\":469,\"models/tools/edit/line_edit_tool\":470,\"models/tools/edit/line_tool\":471,\"models/tools/edit/point_draw_tool\":472,\"models/tools/edit/poly_draw_tool\":473,\"models/tools/edit/poly_tool\":474,\"models/tools/edit/poly_edit_tool\":475,\"models/tools/gestures/index\":476,\"models/tools/gestures/box_select_tool\":477,\"models/tools/gestures/region_select_tool\":478,\"models/tools/gestures/select_tool\":479,\"models/tools/gestures/box_zoom_tool\":480,\"models/tools/gestures/lasso_select_tool\":481,\"models/tools/gestures/poly_select_tool\":482,\"models/tools/gestures/pan_tool\":483,\"models/tools/gestures/range_tool\":484,\"models/tools/gestures/tap_tool\":485,\"models/tools/gestures/wheel_pan_tool\":486,\"models/tools/gestures/wheel_zoom_tool\":487,\"models/tools/inspectors/index\":488,\"models/tools/inspectors/crosshair_tool\":489,\"models/tools/inspectors/customjs_hover\":490,\"models/tools/inspectors/hover_tool\":491,\"models/dom/template\":492,\"models/dom/dom_element\":493,\"models/dom/action\":494,\"models/dom/placeholder\":495,\"models/dom/index\":496,\"models/dom/color_ref\":497,\"models/dom/value_ref\":498,\"models/dom/elements\":499,\"models/dom/index_\":500,\"models/dom/toggle_group\":501,\"models/dom/value_of\":502}, {});});\n", - "\n", - " /* END bokeh.min.js */\n", - " },\n", - " function(Bokeh) {\n", - " /* BEGIN bokeh-gl.min.js */\n", - " /*!\n", - " * Copyright (c) 2012 - 2023, 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\"], \"3.1.1\");\n", - " })(this, function(Bokeh, version) {\n", - " let define;\n", - " return (function(modules, entry, aliases, externals) {\n", - " const bokeh = typeof Bokeh !== \"undefined\" && (version != null ? Bokeh[version] : Bokeh);\n", - " if (bokeh != null) {\n", - " return bokeh.register_plugin(modules, entry, aliases);\n", - " } else {\n", - " throw new Error(\"Cannot find Bokeh \" + version + \". You have to load it prior to loading plugins.\");\n", - " }\n", - " })\n", - " ({\n", - " 503: function _(n,c,f,i,o){i(),n(504)},\n", - " 504: function _(t,_,r,e,o){e();const a=t(1);o(\"get_regl\",t(505).get_regl),a.__exportStar(t(513),r),a.__exportStar(t(517),r),a.__exportStar(t(518),r),a.__exportStar(t(520),r),a.__exportStar(t(521),r),a.__exportStar(t(522),r),a.__exportStar(t(523),r),a.__exportStar(t(524),r),a.__exportStar(t(519),r),a.__exportStar(t(525),r)},\n", - " 505: function _(t,i,e,_,a){_();const r=t(1),o=r.__importDefault(t(506)),n=t(507),s=r.__importDefault(t(509)),l=r.__importDefault(t(510)),p=r.__importDefault(t(511)),h=r.__importDefault(t(512));let c=null;e.get_regl=function(t){return null==c&&(c=new u(t)),c};class u{constructor(t){try{this._regl=(0,o.default)({gl:t,extensions:[\"ANGLE_instanced_arrays\",\"EXT_blend_minmax\"]}),this._regl_available=!0,this._line_geometry=this._regl.buffer({usage:\"static\",type:\"float\",data:[[-2,0],[-1,-1],[1,-1],[1,1],[-1,1]]}),this._line_triangles=this._regl.elements({usage:\"static\",primitive:\"triangle fan\",data:[0,1,2,3,4]})}catch(t){this._regl_available=!1}}buffer(t){return this._regl.buffer(t)}clear(t,i){this._viewport={x:0,y:0,width:t,height:i},this._regl.clear({color:[0,0,0,0]})}get has_webgl(){return this._regl_available}get scissor(){return this._scissor}set_scissor(t,i,e,_){this._scissor={x:t,y:i,width:e,height:_}}get viewport(){return this._viewport}dashed_line(){return null==this._dashed_line&&(this._dashed_line=function(t,i,e){const _={vert:`#define DASHED\\n\\n${s.default}`,frag:`#define DASHED\\n\\n${l.default}`,attributes:{a_position:{buffer:i,divisor:0},a_point_prev:(t,i)=>i.points.to_attribute_config(),a_point_start:(t,i)=>i.points.to_attribute_config(2*Float32Array.BYTES_PER_ELEMENT),a_point_end:(t,i)=>i.points.to_attribute_config(4*Float32Array.BYTES_PER_ELEMENT),a_point_next:(t,i)=>i.points.to_attribute_config(6*Float32Array.BYTES_PER_ELEMENT),a_show_prev:(t,i)=>i.show.to_attribute_config(),a_show_curr:(t,i)=>i.show.to_attribute_config(Uint8Array.BYTES_PER_ELEMENT),a_show_next:(t,i)=>i.show.to_attribute_config(2*Uint8Array.BYTES_PER_ELEMENT),a_length_so_far:(t,i)=>i.length_so_far.to_attribute_config()},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\"),u_line_color:t.prop(\"line_color\"),u_linewidth:t.prop(\"linewidth\"),u_miter_limit:t.prop(\"miter_limit\"),u_line_join:t.prop(\"line_join\"),u_line_cap:t.prop(\"line_cap\"),u_dash_tex:t.prop(\"dash_tex\"),u_dash_tex_info:t.prop(\"dash_tex_info\"),u_dash_scale:t.prop(\"dash_scale\"),u_dash_offset:t.prop(\"dash_offset\")},elements:e,instances:t.prop(\"nsegments\"),blend:{enable:!0,equation:\"max\",func:{srcRGB:1,srcAlpha:1,dstRGB:1,dstAlpha:1}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(_)}(this._regl,this._line_geometry,this._line_triangles)),this._dashed_line}get_dash(t){return null==this._dash_cache&&(this._dash_cache=new n.DashCache(this._regl)),this._dash_cache.get(t)}marker_no_hatch(t){null==this._marker_no_hatch_map&&(this._marker_no_hatch_map=new Map);let i=this._marker_no_hatch_map.get(t);return null==i&&(i=function(t,i){const e={vert:p.default,frag:` #define USE_${i.toUpperCase()}\\n ${h.default}\\n `,attributes:{a_position:{buffer:t.buffer([[-.5,-.5],[-.5,.5],[.5,.5],[.5,-.5]]),divisor:0},a_center:(t,i)=>i.center.to_attribute_config(),a_width:(t,i)=>i.width.to_attribute_config(),a_height:(t,i)=>i.height.to_attribute_config(),a_angle:(t,i)=>i.angle.to_attribute_config(),a_linewidth:(t,i)=>i.linewidth.to_attribute_config(),a_line_color:(t,i)=>i.line_color.to_attribute_config(),a_fill_color:(t,i)=>i.fill_color.to_attribute_config(),a_line_cap:(t,i)=>i.line_cap.to_attribute_config(),a_line_join:(t,i)=>i.line_join.to_attribute_config(),a_show:(t,i)=>i.show.to_attribute_config()},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\"),u_border_radius:t.prop(\"border_radius\"),u_size_hint:t.prop(\"size_hint\")},count:4,primitive:\"triangle fan\",instances:t.prop(\"nmarkers\"),blend:{enable:!0,func:{srcRGB:\"one\",srcAlpha:\"one\",dstRGB:\"one minus src alpha\",dstAlpha:\"one minus src alpha\"}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(e)}(this._regl,t),this._marker_no_hatch_map.set(t,i)),i}marker_hatch(t){null==this._marker_hatch_map&&(this._marker_hatch_map=new Map);let i=this._marker_hatch_map.get(t);return null==i&&(i=function(t,i){const e={vert:`#define HATCH\\n${p.default}`,frag:`#define USE_${i.toUpperCase()}\\n#define HATCH\\n${h.default}`,attributes:{a_position:{buffer:t.buffer([[-.5,-.5],[-.5,.5],[.5,.5],[.5,-.5]]),divisor:0},a_center:(t,i)=>i.center.to_attribute_config(),a_width:(t,i)=>i.width.to_attribute_config(),a_height:(t,i)=>i.height.to_attribute_config(),a_angle:(t,i)=>i.angle.to_attribute_config(),a_linewidth:(t,i)=>i.linewidth.to_attribute_config(),a_line_color:(t,i)=>i.line_color.to_attribute_config(),a_fill_color:(t,i)=>i.fill_color.to_attribute_config(),a_line_cap:(t,i)=>i.line_cap.to_attribute_config(),a_line_join:(t,i)=>i.line_join.to_attribute_config(),a_show:(t,i)=>i.show.to_attribute_config(),a_hatch_pattern:(t,i)=>i.hatch_pattern.to_attribute_config(),a_hatch_scale:(t,i)=>i.hatch_scale.to_attribute_config(),a_hatch_weight:(t,i)=>i.hatch_weight.to_attribute_config(),a_hatch_color:(t,i)=>i.hatch_color.to_attribute_config()},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\"),u_border_radius:t.prop(\"border_radius\"),u_size_hint:t.prop(\"size_hint\")},count:4,primitive:\"triangle fan\",instances:t.prop(\"nmarkers\"),blend:{enable:!0,func:{srcRGB:\"one\",srcAlpha:\"one\",dstRGB:\"one minus src alpha\",dstAlpha:\"one minus src alpha\"}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(e)}(this._regl,t),this._marker_hatch_map.set(t,i)),i}solid_line(){return null==this._solid_line&&(this._solid_line=function(t,i,e){const _={vert:s.default,frag:l.default,attributes:{a_position:{buffer:i,divisor:0},a_point_prev:(t,i)=>i.points.to_attribute_config(),a_point_start:(t,i)=>i.points.to_attribute_config(2*Float32Array.BYTES_PER_ELEMENT),a_point_end:(t,i)=>i.points.to_attribute_config(4*Float32Array.BYTES_PER_ELEMENT),a_point_next:(t,i)=>i.points.to_attribute_config(6*Float32Array.BYTES_PER_ELEMENT),a_show_prev:(t,i)=>i.show.to_attribute_config(),a_show_curr:(t,i)=>i.show.to_attribute_config(Uint8Array.BYTES_PER_ELEMENT),a_show_next:(t,i)=>i.show.to_attribute_config(2*Uint8Array.BYTES_PER_ELEMENT)},uniforms:{u_canvas_size:t.prop(\"canvas_size\"),u_pixel_ratio:t.prop(\"pixel_ratio\"),u_antialias:t.prop(\"antialias\"),u_line_color:t.prop(\"line_color\"),u_linewidth:t.prop(\"linewidth\"),u_miter_limit:t.prop(\"miter_limit\"),u_line_join:t.prop(\"line_join\"),u_line_cap:t.prop(\"line_cap\")},elements:e,instances:t.prop(\"nsegments\"),blend:{enable:!0,equation:\"max\",func:{srcRGB:1,srcAlpha:1,dstRGB:1,dstAlpha:1}},depth:{enable:!1},scissor:{enable:!0,box:t.prop(\"scissor\")},viewport:t.prop(\"viewport\")};return t(_)}(this._regl,this._line_geometry,this._line_triangles)),this._solid_line}}e.ReglWrapper=u,u.__name__=\"ReglWrapper\"},\n", - " 506: function _(e,t,r,n,a){var i,o;i=this,o=function(){\"use strict\";var e=function(e){return e instanceof Uint8Array||e instanceof Uint16Array||e instanceof Uint32Array||e instanceof Int8Array||e instanceof Int16Array||e instanceof Int32Array||e instanceof Float32Array||e instanceof Float64Array||e instanceof Uint8ClampedArray},t=function(e,t){for(var r=Object.keys(t),n=0;n=0&&(0|e)===e||n(\"invalid parameter type, (\"+e+\")\"+i(t)+\". must be a nonnegative integer\")},oneOf:f,shaderError:function(e,t,n,i,o){if(!e.getShaderParameter(t,e.COMPILE_STATUS)){var f=e.getShaderInfoLog(t),u=i===e.FRAGMENT_SHADER?\"fragment\":\"vertex\";g(n,\"string\",u+\" shader source must be a string\",o);var c=h(n,o),l=function(e){var t=[];return e.split(\"\\n\").forEach((function(e){if(!(e.length<5)){var r=/^ERROR:\\s+(\\d+):(\\d+):\\s*(.*)$/.exec(e);r?t.push(new d(0|r[1],0|r[2],r[3].trim())):e.length>0&&t.push(new d(\"unknown\",0,e))}})),t}(f);!function(e,t){t.forEach((function(t){var r=e[t.file];if(r){var n=r.index[t.line];if(n)return n.errors.push(t),void(r.hasErrors=!0)}e.unknown.hasErrors=!0,e.unknown.lines[0].errors.push(t)}))}(c,l),Object.keys(c).forEach((function(e){var t=c[e];if(t.hasErrors){var n=[\"\"],a=[\"\"];i(\"file number \"+e+\": \"+t.name+\"\\n\",\"color:red;text-decoration:underline;font-weight:bold\"),t.lines.forEach((function(e){if(e.errors.length>0){i(s(e.number,4)+\"| \",\"background-color:yellow; font-weight:bold\"),i(e.line+r,\"color:red; background-color:yellow; font-weight:bold\");var t=0;e.errors.forEach((function(n){var a=n.message,o=/^\\s*'(.*)'\\s*:\\s*(.*)$/.exec(a);if(o){var f=o[1];a=o[2],\"assign\"===f&&(f=\"=\"),t=Math.max(e.line.indexOf(f,t),0)}else t=0;i(s(\"| \",6)),i(s(\"^^^\",t+3)+r,\"font-weight:bold\"),i(s(\"| \",6)),i(a+r,\"font-weight:bold\")})),i(s(\"| \",6)+r)}else i(s(e.number,4)+\"| \"),i(e.line+r,\"color:red\")})),\"undefined\"==typeof document||window.chrome?console.log(n.join(\"\")):(a[0]=n.join(\"%c\"),console.log.apply(console,a))}function i(e,t){n.push(e),a.push(t||\"\")}})),a.raise(\"Error compiling \"+u+\" shader, \"+c[0].name)}},linkError:function(e,t,n,i,o){if(!e.getProgramParameter(t,e.LINK_STATUS)){var f=e.getProgramInfoLog(t),u=h(n,o),s='Error linking program with vertex shader, \"'+h(i,o)[0].name+'\", and fragment shader \"'+u[0].name+'\"';\"undefined\"!=typeof document?console.log(\"%c\"+s+r+\"%c\"+f,\"color:red;text-decoration:underline;font-weight:bold\",\"color:red\"):console.log(s+r+f),a.raise(s)}},callSite:p,saveCommandRef:b,saveDrawInfo:function(e,t,r,n){function a(e){return e?n.id(e):0}function i(e,t){Object.keys(t).forEach((function(t){e[n.id(t)]=!0}))}b(e),e._fragId=a(e.static.frag),e._vertId=a(e.static.vert);var o=e._uniformSet={};i(o,t.static),i(o,t.dynamic);var f=e._attributeSet={};i(f,r.static),i(f,r.dynamic),e._hasCount=\"count\"in e.static||\"count\"in e.dynamic||\"elements\"in e.static||\"elements\"in e.dynamic},framebufferFormat:function(e,t,r){e.texture?f(e.texture._texture.internalformat,t,\"unsupported texture format for attachment\"):f(e.renderbuffer._renderbuffer.format,r,\"unsupported renderbuffer format for attachment\")},guessCommand:m,texture2D:function(e,t,r){var n,i=t.width,o=t.height,f=t.channels;a(i>0&&i<=r.maxTextureSize&&o>0&&o<=r.maxTextureSize,\"invalid texture shape\"),e.wrapS===y&&e.wrapT===y||a(z(i)&&z(o),\"incompatible wrap mode for texture, both width and height must be power of 2\"),1===t.mipmask?1!==i&&1!==o&&a(e.minFilter!==w&&e.minFilter!==_&&e.minFilter!==A&&e.minFilter!==k,\"min filter requires mipmap\"):(a(z(i)&&z(o),\"texture must be a square power of 2 to support mipmapping\"),a(t.mipmask===(i<<1)-1,\"missing or incomplete mipmap data\")),t.type===S&&(r.extensions.indexOf(\"oes_texture_float_linear\")<0&&a(e.minFilter===x&&e.magFilter===x,\"filter not supported, must enable oes_texture_float_linear\"),a(!e.genMipmaps,\"mipmap generation not supported with float textures\"));var u=t.images;for(n=0;n<16;++n)if(u[n]){var s=i>>n,c=o>>n;a(t.mipmask&1<0&&i<=n.maxTextureSize&&o>0&&o<=n.maxTextureSize,\"invalid texture shape\"),a(i===o,\"cube map must be square\"),a(t.wrapS===y&&t.wrapT===y,\"wrap mode not supported by cube map\");for(var u=0;u>l,p=o>>l;a(s.mipmask&1<1&&t===r&&('\"'===t||\"'\"===t))return['\"'+R(e.substr(1,e.length-2))+'\"'];var n=/\\[(false|true|null|\\d+|'[^']*'|\"[^\"]*\")\\]/.exec(e);if(n)return M(e.substr(0,n.index)).concat(M(n[1])).concat(M(e.substr(n.index+n[0].length)));var a=e.split(\".\");if(1===a.length)return['\"'+R(e)+'\"'];for(var i=[],o=0;o0,\"invalid pixel ratio\"))):F.raise(\"invalid arguments to regl\"),r&&(\"canvas\"===r.nodeName.toLowerCase()?a=r:n=r),!i){if(!a){F(\"undefined\"!=typeof document,\"must manually specify webgl context outside of DOM environments\");var h=function(e,r,n){var a,i=document.createElement(\"canvas\");function o(){var t=window.innerWidth,r=window.innerHeight;if(e!==document.body){var a=i.getBoundingClientRect();t=a.right-a.left,r=a.bottom-a.top}i.width=n*t,i.height=n*r}return t(i.style,{border:0,margin:0,padding:0,top:0,left:0,width:\"100%\",height:\"100%\"}),e.appendChild(i),e===document.body&&(i.style.position=\"absolute\",t(e.style,{margin:0,padding:0})),e!==document.body&&\"function\"==typeof ResizeObserver?(a=new ResizeObserver((function(){setTimeout(o)}))).observe(e):window.addEventListener(\"resize\",o,!1),o(),{canvas:i,onDestroy:function(){a?a.disconnect():window.removeEventListener(\"resize\",o),e.removeChild(i)}}}(n||document.body,0,l);if(!h)return null;a=h.canvas,p=h.onDestroy}void 0===u.premultipliedAlpha&&(u.premultipliedAlpha=!0),i=function(e,t){function r(r){try{return e.getContext(r,t)}catch(e){return null}}return r(\"webgl\")||r(\"experimental-webgl\")||r(\"webgl-experimental\")}(a,u)}return i?{gl:i,canvas:a,container:n,extensions:s,optionalExtensions:c,pixelRatio:l,profile:d,onDone:m,onDestroy:p}:(p(),m(\"webgl not supported, try upgrading your browser or graphics drivers http://get.webgl.org\"),null)}function Y(e,t){for(var r=Array(e),n=0;n65535)<<4,t|=r=((e>>>=t)>255)<<3,t|=r=((e>>>=r)>15)<<2,(t|=r=((e>>>=r)>3)<<1)|(e>>>=r)>>1}function ne(){var e=Y(8,(function(){return[]}));function t(t){var r=function(e){for(var t=16;t<=1<<28;t*=16)if(e<=t)return t;return 0}(t),n=e[re(r)>>2];return n.length>0?n.pop():new ArrayBuffer(r)}function r(t){e[re(t.byteLength)>>2].push(t)}return{alloc:t,free:r,allocType:function(e,r){var n=null;switch(e){case X:n=new Int8Array(t(r),0,r);break;case $:n=new Uint8Array(t(r),0,r);break;case K:n=new Int16Array(t(2*r),0,r);break;case J:n=new Uint16Array(t(2*r),0,r);break;case Z:n=new Int32Array(t(4*r),0,r);break;case ee:n=new Uint32Array(t(4*r),0,r);break;case te:n=new Float32Array(t(4*r),0,r);break;default:return null}return n.length!==r?n.subarray(0,r):n},freeType:function(e){r(e.buffer)}}}var ae=ne();ae.zero=ne();var ie=3553,oe=6408,fe=5126,ue=36160,se=function(e,t){var r=1;t.ext_texture_filter_anisotropic&&(r=e.getParameter(34047));var n=1,a=1;t.webgl_draw_buffers&&(n=e.getParameter(34852),a=e.getParameter(36063));var i=!!t.oes_texture_float;if(i){var o=e.createTexture();e.bindTexture(ie,o),e.texImage2D(ie,0,oe,1,1,0,oe,fe,null);var f=e.createFramebuffer();if(e.bindFramebuffer(ue,f),e.framebufferTexture2D(ue,36064,ie,o,0),e.bindTexture(ie,null),36053!==e.checkFramebufferStatus(ue))i=!1;else{e.viewport(0,0,1,1),e.clearColor(1,0,0,1),e.clear(16384);var u=ae.allocType(fe,4);e.readPixels(0,0,1,1,oe,fe,u),e.getError()?i=!1:(e.deleteFramebuffer(f),e.deleteTexture(o),i=1===u[0]),ae.freeType(u)}}var s=!0;if(\"undefined\"==typeof navigator||!(/MSIE/.test(navigator.userAgent)||/Trident\\//.test(navigator.appVersion)||/Edge/.test(navigator.userAgent))){var c=e.createTexture(),l=ae.allocType(5121,36);e.activeTexture(33984),e.bindTexture(34067,c),e.texImage2D(34069,0,oe,3,3,0,oe,5121,l),ae.freeType(l),e.bindTexture(34067,null),e.deleteTexture(c),s=!e.getError()}return{colorBits:[e.getParameter(3410),e.getParameter(3411),e.getParameter(3412),e.getParameter(3413)],depthBits:e.getParameter(3414),stencilBits:e.getParameter(3415),subpixelBits:e.getParameter(3408),extensions:Object.keys(t).filter((function(e){return!!t[e]})),maxAnisotropic:r,maxDrawbuffers:n,maxColorAttachments:a,pointSizeDims:e.getParameter(33901),lineWidthDims:e.getParameter(33902),maxViewportDims:e.getParameter(3386),maxCombinedTextureUnits:e.getParameter(35661),maxCubeMapSize:e.getParameter(34076),maxRenderbufferSize:e.getParameter(34024),maxTextureUnits:e.getParameter(34930),maxTextureSize:e.getParameter(3379),maxAttributes:e.getParameter(34921),maxVertexUniforms:e.getParameter(36347),maxVertexTextureUnits:e.getParameter(35660),maxVaryingVectors:e.getParameter(36348),maxFragmentUniforms:e.getParameter(36349),glsl:e.getParameter(35724),renderer:e.getParameter(7937),vendor:e.getParameter(7936),version:e.getParameter(7938),readFloat:i,npotTextureCube:s}};function ce(t){return!!t&&\"object\"==typeof t&&Array.isArray(t.shape)&&Array.isArray(t.stride)&&\"number\"==typeof t.offset&&t.shape.length===t.stride.length&&(Array.isArray(t.data)||e(t.data))}var le=function(e){return Object.keys(e).map((function(t){return e[t]}))},de={shape:function(e){for(var t=[],r=e;r.length;r=r[0])t.push(r.length);return t},flatten:function(e,t,r,n){var a=1;if(t.length)for(var i=0;i>>31<<15,i=(n<<1>>>24)-127,o=n>>13&1023;if(i<-24)t[r]=a;else if(i<-14){var f=-14-i;t[r]=a+(o+1024>>f)}else t[r]=i>15?a+31744:a+(i+15<<10)+o}return t}function Ne(t){return Array.isArray(t)||e(t)}var qe=function(e){return!(e&e-1||!e)},Qe=34467,Ye=3553,Xe=34067,$e=34069,Ke=6408,Je=6406,Ze=6407,et=6409,tt=6410,rt=32854,nt=32855,at=36194,it=32819,ot=32820,ft=33635,ut=34042,st=6402,ct=34041,lt=35904,dt=35906,mt=36193,pt=33776,ht=33777,bt=33778,vt=33779,gt=35986,yt=35987,xt=34798,wt=35840,At=35841,_t=35842,kt=35843,St=36196,Ot=5121,Et=5123,Tt=5125,Dt=5126,jt=10242,Ct=10243,zt=10497,Ft=33071,Vt=33648,Bt=10240,It=10241,Pt=9728,Lt=9729,Rt=9984,Mt=9985,Ut=9986,Wt=9987,Gt=33170,Ht=4352,Nt=4353,qt=4354,Qt=34046,Yt=3317,Xt=37440,$t=37441,Kt=37443,Jt=37444,Zt=33984,er=[Rt,Ut,Mt,Wt],tr=[0,et,tt,Ze,Ke],rr={};function nr(e){return\"[object \"+e+\"]\"}rr[et]=rr[Je]=rr[st]=1,rr[ct]=rr[tt]=2,rr[Ze]=rr[lt]=3,rr[Ke]=rr[dt]=4;var ar=nr(\"HTMLCanvasElement\"),ir=nr(\"OffscreenCanvas\"),or=nr(\"CanvasRenderingContext2D\"),fr=nr(\"ImageBitmap\"),ur=nr(\"HTMLImageElement\"),sr=nr(\"HTMLVideoElement\"),cr=Object.keys(he).concat([ar,ir,or,fr,ur,sr]),lr=[];lr[Ot]=1,lr[Dt]=4,lr[mt]=2,lr[Et]=2,lr[Tt]=4;var dr=[];function mr(e){return Array.isArray(e)&&(0===e.length||\"number\"==typeof e[0])}function pr(e){return!!Array.isArray(e)&&!(0===e.length||!Ne(e[0]))}function hr(e){return Object.prototype.toString.call(e)}function br(e){return hr(e)===ar}function vr(e){return hr(e)===ir}function gr(e){if(!e)return!1;var t=hr(e);return cr.indexOf(t)>=0||mr(e)||pr(e)||ce(e)}function yr(e){return 0|he[Object.prototype.toString.call(e)]}function xr(e,t){return ae.allocType(e.type===mt?Dt:e.type,t)}function wr(e,t){e.type===mt?(e.data=He(t),ae.freeType(t)):e.data=t}function Ar(e,t,r,n,a,i){var o;if(o=void 0!==dr[e]?dr[e]:rr[e]*lr[t],i&&(o*=6),a){for(var f=0,u=r;u>=1;)f+=o*u*u,u/=2;return f}return o*r*n}function _r(r,n,a,i,o,f,u){var s={\"don't care\":Ht,\"dont care\":Ht,nice:qt,fast:Nt},c={repeat:zt,clamp:Ft,mirror:Vt},l={nearest:Pt,linear:Lt},d=t({mipmap:Wt,\"nearest mipmap nearest\":Rt,\"linear mipmap nearest\":Mt,\"nearest mipmap linear\":Ut,\"linear mipmap linear\":Wt},l),m={none:0,browser:Jt},p={uint8:Ot,rgba4:it,rgb565:ft,\"rgb5 a1\":ot},h={alpha:Je,luminance:et,\"luminance alpha\":tt,rgb:Ze,rgba:Ke,rgba4:rt,\"rgb5 a1\":nt,rgb565:at},b={};n.ext_srgb&&(h.srgb=lt,h.srgba=dt),n.oes_texture_float&&(p.float32=p.float=Dt),n.oes_texture_half_float&&(p.float16=p[\"half float\"]=mt),n.webgl_depth_texture&&(t(h,{depth:st,\"depth stencil\":ct}),t(p,{uint16:Et,uint32:Tt,\"depth stencil\":ut})),n.webgl_compressed_texture_s3tc&&t(b,{\"rgb s3tc dxt1\":pt,\"rgba s3tc dxt1\":ht,\"rgba s3tc dxt3\":bt,\"rgba s3tc dxt5\":vt}),n.webgl_compressed_texture_atc&&t(b,{\"rgb atc\":gt,\"rgba atc explicit alpha\":yt,\"rgba atc interpolated alpha\":xt}),n.webgl_compressed_texture_pvrtc&&t(b,{\"rgb pvrtc 4bppv1\":wt,\"rgb pvrtc 2bppv1\":At,\"rgba pvrtc 4bppv1\":_t,\"rgba pvrtc 2bppv1\":kt}),n.webgl_compressed_texture_etc1&&(b[\"rgb etc1\"]=St);var v=Array.prototype.slice.call(r.getParameter(Qe));Object.keys(b).forEach((function(e){var t=b[e];v.indexOf(t)>=0&&(h[e]=t)}));var g=Object.keys(h);a.textureFormats=g;var y=[];Object.keys(h).forEach((function(e){var t=h[e];y[t]=e}));var x=[];Object.keys(p).forEach((function(e){var t=p[e];x[t]=e}));var w=[];Object.keys(l).forEach((function(e){var t=l[e];w[t]=e}));var A=[];Object.keys(d).forEach((function(e){var t=d[e];A[t]=e}));var _=[];Object.keys(c).forEach((function(e){var t=c[e];_[t]=e}));var k=g.reduce((function(e,t){var r=h[t];return r===et||r===Je||r===et||r===tt||r===st||r===ct||n.ext_srgb&&(r===lt||r===dt)?e[r]=r:r===nt||t.indexOf(\"rgba\")>=0?e[r]=Ke:e[r]=Ze,e}),{});function S(){this.internalformat=Ke,this.format=Ke,this.type=Ot,this.compressed=!1,this.premultiplyAlpha=!1,this.flipY=!1,this.unpackAlignment=1,this.colorSpace=Jt,this.width=0,this.height=0,this.channels=0}function O(e,t){e.internalformat=t.internalformat,e.format=t.format,e.type=t.type,e.compressed=t.compressed,e.premultiplyAlpha=t.premultiplyAlpha,e.flipY=t.flipY,e.unpackAlignment=t.unpackAlignment,e.colorSpace=t.colorSpace,e.width=t.width,e.height=t.height,e.channels=t.channels}function E(e,t){if(\"object\"==typeof t&&t){if(\"premultiplyAlpha\"in t&&(F.type(t.premultiplyAlpha,\"boolean\",\"invalid premultiplyAlpha\"),e.premultiplyAlpha=t.premultiplyAlpha),\"flipY\"in t&&(F.type(t.flipY,\"boolean\",\"invalid texture flip\"),e.flipY=t.flipY),\"alignment\"in t&&(F.oneOf(t.alignment,[1,2,4,8],\"invalid texture unpack alignment\"),e.unpackAlignment=t.alignment),\"colorSpace\"in t&&(F.parameter(t.colorSpace,m,\"invalid colorSpace\"),e.colorSpace=m[t.colorSpace]),\"type\"in t){var r=t.type;F(n.oes_texture_float||!(\"float\"===r||\"float32\"===r),\"you must enable the OES_texture_float extension in order to use floating point textures.\"),F(n.oes_texture_half_float||!(\"half float\"===r||\"float16\"===r),\"you must enable the OES_texture_half_float extension in order to use 16-bit floating point textures.\"),F(n.webgl_depth_texture||!(\"uint16\"===r||\"uint32\"===r||\"depth stencil\"===r),\"you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures.\"),F.parameter(r,p,\"invalid texture type\"),e.type=p[r]}var i=e.width,o=e.height,f=e.channels,u=!1;\"shape\"in t?(F(Array.isArray(t.shape)&&t.shape.length>=2,\"shape must be an array\"),i=t.shape[0],o=t.shape[1],3===t.shape.length&&(f=t.shape[2],F(f>0&&f<=4,\"invalid number of channels\"),u=!0),F(i>=0&&i<=a.maxTextureSize,\"invalid width\"),F(o>=0&&o<=a.maxTextureSize,\"invalid height\")):(\"radius\"in t&&(i=o=t.radius,F(i>=0&&i<=a.maxTextureSize,\"invalid radius\")),\"width\"in t&&(i=t.width,F(i>=0&&i<=a.maxTextureSize,\"invalid width\")),\"height\"in t&&(o=t.height,F(o>=0&&o<=a.maxTextureSize,\"invalid height\")),\"channels\"in t&&(f=t.channels,F(f>0&&f<=4,\"invalid number of channels\"),u=!0)),e.width=0|i,e.height=0|o,e.channels=0|f;var s=!1;if(\"format\"in t){var c=t.format;F(n.webgl_depth_texture||!(\"depth\"===c||\"depth stencil\"===c),\"you must enable the WEBGL_depth_texture extension in order to use depth/stencil textures.\"),F.parameter(c,h,\"invalid texture format\");var l=e.internalformat=h[c];e.format=k[l],c in p&&(\"type\"in t||(e.type=p[c])),c in b&&(e.compressed=!0),s=!0}!u&&s?e.channels=rr[e.format]:u&&!s?e.channels!==tr[e.format]&&(e.format=e.internalformat=tr[e.channels]):s&&u&&F(e.channels===rr[e.format],\"number of channels inconsistent with specified format\")}}function T(e){r.pixelStorei(Xt,e.flipY),r.pixelStorei($t,e.premultiplyAlpha),r.pixelStorei(Kt,e.colorSpace),r.pixelStorei(Yt,e.unpackAlignment)}function D(){S.call(this),this.xOffset=0,this.yOffset=0,this.data=null,this.needsFree=!1,this.element=null,this.needsCopy=!1}function j(t,r){var n=null;if(gr(r)?n=r:r&&(F.type(r,\"object\",\"invalid pixel data type\"),E(t,r),\"x\"in r&&(t.xOffset=0|r.x),\"y\"in r&&(t.yOffset=0|r.y),gr(r.data)&&(n=r.data)),F(!t.compressed||n instanceof Uint8Array,\"compressed texture data must be stored in a uint8array\"),r.copy){F(!n,\"can not specify copy and data field for the same texture\");var i=o.viewportWidth,f=o.viewportHeight;t.width=t.width||i-t.xOffset,t.height=t.height||f-t.yOffset,t.needsCopy=!0,F(t.xOffset>=0&&t.xOffset=0&&t.yOffset0&&t.width<=i&&t.height>0&&t.height<=f,\"copy texture read out of bounds\")}else if(n){if(e(n))t.channels=t.channels||4,t.data=n,\"type\"in r||t.type!==Ot||(t.type=yr(n));else if(mr(n))t.channels=t.channels||4,function(e,t){var r=t.length;switch(e.type){case Ot:case Et:case Tt:case Dt:var n=ae.allocType(e.type,r);n.set(t),e.data=n;break;case mt:e.data=He(t);break;default:F.raise(\"unsupported texture type, must specify a typed array\")}}(t,n),t.alignment=1,t.needsFree=!0;else if(ce(n)){var u=n.data;Array.isArray(u)||t.type!==Ot||(t.type=yr(u));var s,c,l,d,m,p,h=n.shape,b=n.stride;3===h.length?(l=h[2],p=b[2]):(F(2===h.length,\"invalid ndarray pixel data, must be 2 or 3D\"),l=1,p=1),s=h[0],c=h[1],d=b[0],m=b[1],t.alignment=1,t.width=s,t.height=c,t.channels=l,t.format=t.internalformat=tr[l],t.needsFree=!0,function(e,t,r,n,a,i){for(var o=e.width,f=e.height,u=e.channels,s=xr(e,o*f*u),c=0,l=0;l=0,\"oes_texture_float extension not enabled\"):t.type===mt&&F(a.extensions.indexOf(\"oes_texture_half_float\")>=0,\"oes_texture_half_float extension not enabled\")}function C(e,t,n){var a=e.element,o=e.data,f=e.internalformat,u=e.format,s=e.type,c=e.width,l=e.height;T(e),a?r.texImage2D(t,n,u,u,s,a):e.compressed?r.compressedTexImage2D(t,n,f,c,l,0,o):e.needsCopy?(i(),r.copyTexImage2D(t,n,u,e.xOffset,e.yOffset,c,l,0)):r.texImage2D(t,n,u,c,l,0,u,s,o||null)}function z(e,t,n,a,o){var f=e.element,u=e.data,s=e.internalformat,c=e.format,l=e.type,d=e.width,m=e.height;T(e),f?r.texSubImage2D(t,o,n,a,c,l,f):e.compressed?r.compressedTexSubImage2D(t,o,n,a,s,d,m,u):e.needsCopy?(i(),r.copyTexSubImage2D(t,o,n,a,e.xOffset,e.yOffset,d,m)):r.texSubImage2D(t,o,n,a,d,m,c,l,u)}var V=[];function B(){return V.pop()||new D}function I(e){e.needsFree&&ae.freeType(e.data),D.call(e),V.push(e)}function P(){S.call(this),this.genMipmaps=!1,this.mipmapHint=Ht,this.mipmask=0,this.images=Array(16)}function L(e,t,r){var n=e.images[0]=B();e.mipmask=1,n.width=e.width=t,n.height=e.height=r,n.channels=e.channels=4}function R(e,t){var r=null;if(gr(t))O(r=e.images[0]=B(),e),j(r,t),e.mipmask=1;else if(E(e,t),Array.isArray(t.mipmap))for(var n=t.mipmap,a=0;a>=a,r.height>>=a,j(r,n[a]),e.mipmask|=1<=0&&!(\"faces\"in t)&&(e.genMipmaps=!0)}if(\"mag\"in t){var n=t.mag;F.parameter(n,l),e.magFilter=l[n]}var i=e.wrapS,o=e.wrapT;if(\"wrap\"in t){var f=t.wrap;\"string\"==typeof f?(F.parameter(f,c),i=o=c[f]):Array.isArray(f)&&(F.parameter(f[0],c),F.parameter(f[1],c),i=c[f[0]],o=c[f[1]])}else{if(\"wrapS\"in t){var u=t.wrapS;F.parameter(u,c),i=c[u]}if(\"wrapT\"in t){var m=t.wrapT;F.parameter(m,c),o=c[m]}}if(e.wrapS=i,e.wrapT=o,\"anisotropic\"in t){var p=t.anisotropic;F(\"number\"==typeof p&&p>=1&&p<=a.maxAnisotropic,\"aniso samples must be between 1 and \"),e.anisotropic=t.anisotropic}if(\"mipmap\"in t){var h=!1;switch(typeof t.mipmap){case\"string\":F.parameter(t.mipmap,s,\"invalid mipmap hint\"),e.mipmapHint=s[t.mipmap],e.genMipmaps=!0,h=!0;break;case\"boolean\":h=e.genMipmaps=t.mipmap;break;case\"object\":F(Array.isArray(t.mipmap),\"invalid mipmap type\"),e.genMipmaps=!1,h=!0;break;default:F.raise(\"invalid mipmap type\")}h&&!(\"min\"in t)&&(e.minFilter=Rt)}}function q(e,t){r.texParameteri(t,It,e.minFilter),r.texParameteri(t,Bt,e.magFilter),r.texParameteri(t,jt,e.wrapS),r.texParameteri(t,Ct,e.wrapT),n.ext_texture_filter_anisotropic&&r.texParameteri(t,Qt,e.anisotropic),e.genMipmaps&&(r.hint(Gt,e.mipmapHint),r.generateMipmap(t))}var Q=0,Y={},X=a.maxTextureUnits,$=Array(X).map((function(){return null}));function K(e){S.call(this),this.mipmask=0,this.internalformat=Ke,this.id=Q++,this.refCount=1,this.target=e,this.texture=r.createTexture(),this.unit=-1,this.bindCount=0,this.texInfo=new H,u.profile&&(this.stats={size:0})}function J(e){r.activeTexture(Zt),r.bindTexture(e.target,e.texture)}function Z(){var e=$[0];e?r.bindTexture(e.target,e.texture):r.bindTexture(Ye,null)}function ee(e){var t=e.texture;F(t,\"must not double destroy texture\");var n=e.unit,a=e.target;n>=0&&(r.activeTexture(Zt+n),r.bindTexture(a,null),$[n]=null),r.deleteTexture(t),e.texture=null,e.params=null,e.pixels=null,e.refCount=0,delete Y[e.id],f.textureCount--}return t(K.prototype,{bind:function(){var e=this;e.bindCount+=1;var t=e.unit;if(t<0){for(var n=0;n0)continue;a.unit=-1}$[n]=e,t=n;break}t>=X&&F.raise(\"insufficient number of texture units\"),u.profile&&f.maxTextureUnits>u)-o,s.height=s.height||(n.height>>u)-f,F(n.type===s.type&&n.format===s.format&&n.internalformat===s.internalformat,\"incompatible format for texture.subimage\"),F(o>=0&&f>=0&&o+s.width<=n.width&&f+s.height<=n.height,\"texture.subimage write out of bounds\"),F(n.mipmask&1<>f;++f){var s=a>>f,c=o>>f;if(!s||!c)break;r.texImage2D(Ye,f,n.format,s,c,0,n.format,n.type,null)}return Z(),u.profile&&(n.stats.size=Ar(n.internalformat,n.type,a,o,!1,!1)),i},i._reglType=\"texture2d\",i._texture=n,u.profile&&(i.stats=n.stats),i.destroy=function(){n.decRef()},i},createCube:function(e,t,n,i,o,s){var c=new K(Xe);Y[c.id]=c,f.cubeCount++;var l=new Array(6);function d(e,t,r,n,i,o){var f,s=c.texInfo;for(H.call(s),f=0;f<6;++f)l[f]=W();if(\"number\"!=typeof e&&e)if(\"object\"==typeof e)if(t)R(l[0],e),R(l[1],t),R(l[2],r),R(l[3],n),R(l[4],i),R(l[5],o);else if(N(s,e),E(c,e),\"faces\"in e){var m=e.faces;for(F(Array.isArray(m)&&6===m.length,\"cube faces must be a length 6 array\"),f=0;f<6;++f)F(\"object\"==typeof m[f]&&!!m[f],\"invalid input for cube map face\"),O(l[f],c),R(l[f],m[f])}else for(f=0;f<6;++f)R(l[f],e);else F.raise(\"invalid arguments to cube map\");else{var p=0|e||1;for(f=0;f<6;++f)L(l[f],p,p)}for(O(c,l[0]),F.optional((function(){a.npotTextureCube||F(qe(c.width)&&qe(c.height),\"your browser does not support non power or two texture dimensions\")})),s.genMipmaps?c.mipmask=(l[0].width<<1)-1:c.mipmask=l[0].mipmask,F.textureCube(c,s,l,a),c.internalformat=l[0].internalformat,d.width=l[0].width,d.height=l[0].height,J(c),f=0;f<6;++f)M(l[f],$e+f);for(q(s,Xe),Z(),u.profile&&(c.stats.size=Ar(c.internalformat,c.type,d.width,d.height,s.genMipmaps,!0)),d.format=y[c.internalformat],d.type=x[c.type],d.mag=w[s.magFilter],d.min=A[s.minFilter],d.wrapS=_[s.wrapS],d.wrapT=_[s.wrapT],f=0;f<6;++f)G(l[f]);return d}return d(e,t,n,i,o,s),d.subimage=function(e,t,r,n,a){F(!!t,\"must specify image data\"),F(\"number\"==typeof e&&e===(0|e)&&e>=0&&e<6,\"invalid face\");var i=0|r,o=0|n,f=0|a,u=B();return O(u,c),u.width=0,u.height=0,j(u,t),u.width=u.width||(c.width>>f)-i,u.height=u.height||(c.height>>f)-o,F(c.type===u.type&&c.format===u.format&&c.internalformat===u.internalformat,\"incompatible format for texture.subimage\"),F(i>=0&&o>=0&&i+u.width<=c.width&&o+u.height<=c.height,\"texture.subimage write out of bounds\"),F(c.mipmask&1<>a;++a)r.texImage2D($e+n,a,c.format,t>>a,t>>a,0,c.format,c.type,null);return Z(),u.profile&&(c.stats.size=Ar(c.internalformat,c.type,d.width,d.height,!1,!0)),d}},d._reglType=\"textureCube\",d._texture=c,u.profile&&(d.stats=c.stats),d.destroy=function(){c.decRef()},d},clear:function(){for(var e=0;e>t,e.height>>t,0,e.internalformat,e.type,null);else for(var n=0;n<6;++n)r.texImage2D($e+n,t,e.internalformat,e.width>>t,e.height>>t,0,e.internalformat,e.type,null);q(e.texInfo,e.target)}))},refresh:function(){for(var e=0;e=2,\"invalid renderbuffer shape\"),f=0|m[0],u=0|m[1]}else\"radius\"in d&&(f=u=0|d.radius),\"width\"in d&&(f=0|d.width),\"height\"in d&&(u=0|d.height);\"format\"in d&&(F.parameter(d.format,i,\"invalid renderbuffer format\"),s=i[d.format])}else\"number\"==typeof t?(f=0|t,u=\"number\"==typeof n?0|n:f):t?F.raise(\"invalid arguments to renderbuffer constructor\"):f=u=1;if(F(f>0&&u>0&&f<=r.maxRenderbufferSize&&u<=r.maxRenderbufferSize,\"invalid renderbuffer size\"),f!==c.width||u!==c.height||s!==c.format)return l.width=c.width=f,l.height=c.height=u,c.format=s,e.bindRenderbuffer(kr,c.renderbuffer),e.renderbufferStorage(kr,s,f,u),F(0===e.getError(),\"invalid render buffer format\"),a.profile&&(c.stats.size=Er(c.format,c.width,c.height)),l.format=o[c.format],l}return u[c.id]=c,n.renderbufferCount++,l(t,f),l.resize=function(t,n){var i=0|t,o=0|n||i;return i===c.width&&o===c.height||(F(i>0&&o>0&&i<=r.maxRenderbufferSize&&o<=r.maxRenderbufferSize,\"invalid renderbuffer size\"),l.width=c.width=i,l.height=c.height=o,e.bindRenderbuffer(kr,c.renderbuffer),e.renderbufferStorage(kr,c.format,i,o),F(0===e.getError(),\"invalid render buffer format\"),a.profile&&(c.stats.size=Er(c.format,c.width,c.height))),l},l._reglType=\"renderbuffer\",l._renderbuffer=c,a.profile&&(l.stats=c.stats),l.destroy=function(){c.decRef()},l},clear:function(){le(u).forEach(c)},restore:function(){le(u).forEach((function(t){t.renderbuffer=e.createRenderbuffer(),e.bindRenderbuffer(kr,t.renderbuffer),e.renderbufferStorage(kr,t.format,t.width,t.height)})),e.bindRenderbuffer(kr,null)}}},Dr=36160,jr=36161,Cr=3553,zr=34069,Fr=36064,Vr=36096,Br=36128,Ir=33306,Pr=36053,Lr=6402,Rr=[6407,6408],Mr=[];Mr[6408]=4,Mr[6407]=3;var Ur=[];Ur[5121]=1,Ur[5126]=4,Ur[36193]=2;var Wr=33189,Gr=36168,Hr=34041,Nr=[32854,32855,36194,35907,34842,34843,34836],qr={};qr[Pr]=\"complete\",qr[36054]=\"incomplete attachment\",qr[36057]=\"incomplete dimensions\",qr[36055]=\"incomplete, missing attachment\",qr[36061]=\"unsupported\";var Qr=5126,Yr=34962,Xr=34963,$r=[\"attributes\",\"elements\",\"offset\",\"count\",\"primitive\",\"instances\"];function Kr(){this.state=0,this.x=0,this.y=0,this.z=0,this.w=0,this.buffer=null,this.size=0,this.normalized=!1,this.type=Qr,this.offset=0,this.stride=0,this.divisor=0}var Jr=35632,Zr=35633,en=35718,tn=35721,rn=6408,nn=5121,an=3333,on=5126;function fn(t,r,n,a,i,o,f){function u(u){var s;null===r.next?(F(i.preserveDrawingBuffer,'you must create a webgl context with \"preserveDrawingBuffer\":true in order to read pixels from the drawing buffer'),s=nn):(F(null!==r.next.colorAttachments[0].texture,\"You cannot read from a renderbuffer\"),s=r.next.colorAttachments[0].texture._texture.type,F.optional((function(){o.oes_texture_float?(F(s===nn||s===on,\"Reading from a framebuffer is only allowed for the types 'uint8' and 'float'\"),s===on&&F(f.readFloat,\"Reading 'float' values is not permitted in your browser. For a fallback, please see: https://www.npmjs.com/package/glsl-read-float\")):F(s===nn,\"Reading from a framebuffer is only allowed for the type 'uint8'\")})));var c=0,l=0,d=a.framebufferWidth,m=a.framebufferHeight,p=null;e(u)?p=u:u&&(F.type(u,\"object\",\"invalid arguments to regl.read()\"),c=0|u.x,l=0|u.y,F(c>=0&&c=0&&l0&&d+c<=a.framebufferWidth,\"invalid width for read pixels\"),F(m>0&&m+l<=a.framebufferHeight,\"invalid height for read pixels\"),n();var h=d*m*4;return p||(s===nn?p=new Uint8Array(h):s===on&&(p=p||new Float32Array(h))),F.isTypedArray(p,\"data buffer for regl.read() must be a typedarray\"),F(p.byteLength>=h,\"data buffer for regl.read() too small\"),t.pixelStorei(an,4),t.readPixels(c,l,d,m,rn,s,p),p}return function(e){return e&&\"framebuffer\"in e?function(e){var t;return r.setFBO({framebuffer:e.framebuffer},(function(){t=u(e)})),t}(e):u(e)}}function un(e){return Array.prototype.slice.call(e)}function sn(e){return un(e).join(\"\")}var cn=\"xyzw\".split(\"\"),ln=5121,dn=1,mn=2,pn=0,hn=1,bn=2,vn=3,gn=4,yn=5,xn=6,wn=\"dither\",An=\"blend.enable\",_n=\"blend.color\",kn=\"blend.equation\",Sn=\"blend.func\",On=\"depth.enable\",En=\"depth.func\",Tn=\"depth.range\",Dn=\"depth.mask\",jn=\"colorMask\",Cn=\"cull.enable\",zn=\"cull.face\",Fn=\"frontFace\",Vn=\"lineWidth\",Bn=\"polygonOffset.enable\",In=\"polygonOffset.offset\",Pn=\"sample.alpha\",Ln=\"sample.enable\",Rn=\"sample.coverage\",Mn=\"stencil.enable\",Un=\"stencil.mask\",Wn=\"stencil.func\",Gn=\"stencil.opFront\",Hn=\"stencil.opBack\",Nn=\"scissor.enable\",qn=\"scissor.box\",Qn=\"viewport\",Yn=\"profile\",Xn=\"framebuffer\",$n=\"vert\",Kn=\"frag\",Jn=\"elements\",Zn=\"primitive\",ea=\"count\",ta=\"offset\",ra=\"instances\",na=\"vao\",aa=\"Width\",ia=\"Height\",oa=Xn+aa,fa=Xn+ia,ua=Qn+aa,sa=Qn+ia,ca=\"drawingBuffer\",la=ca+aa,da=ca+ia,ma=[Sn,kn,Wn,Gn,Hn,Rn,Qn,qn,In],pa=34962,ha=34963,ba=3553,va=34067,ga=2884,ya=3042,xa=3024,wa=2960,Aa=2929,_a=3089,ka=32823,Sa=32926,Oa=32928,Ea=5126,Ta=35664,Da=35665,ja=35666,Ca=5124,za=35667,Fa=35668,Va=35669,Ba=35670,Ia=35671,Pa=35672,La=35673,Ra=35674,Ma=35675,Ua=35676,Wa=35678,Ga=35680,Ha=4,Na=1028,qa=1029,Qa=2304,Ya=2305,Xa=32775,$a=32776,Ka=519,Ja=7680,Za=0,ei=1,ti=32774,ri=513,ni=36160,ai=36064,ii={0:0,1:1,zero:0,one:1,\"src color\":768,\"one minus src color\":769,\"src alpha\":770,\"one minus src alpha\":771,\"dst color\":774,\"one minus dst color\":775,\"dst alpha\":772,\"one minus dst alpha\":773,\"constant color\":32769,\"one minus constant color\":32770,\"constant alpha\":32771,\"one minus constant alpha\":32772,\"src alpha saturate\":776},oi=[\"constant color, constant alpha\",\"one minus constant color, constant alpha\",\"constant color, one minus constant alpha\",\"one minus constant color, one minus constant alpha\",\"constant alpha, constant color\",\"constant alpha, one minus constant color\",\"one minus constant alpha, constant color\",\"one minus constant alpha, one minus constant color\"],fi={never:512,less:513,\"<\":513,equal:514,\"=\":514,\"==\":514,\"===\":514,lequal:515,\"<=\":515,greater:516,\">\":516,notequal:517,\"!=\":517,\"!==\":517,gequal:518,\">=\":518,always:519},ui={0:0,zero:0,keep:7680,replace:7681,increment:7682,decrement:7683,\"increment wrap\":34055,\"decrement wrap\":34056,invert:5386},si={frag:35632,vert:35633},ci={cw:Qa,ccw:Ya};function li(t){return Array.isArray(t)||e(t)||ce(t)}function di(e){return e.sort((function(e,t){return e===Qn?-1:t===Qn?1:e=1,n>=2,t)}if(r===gn){var a=e.data;return new mi(a.thisDep,a.contextDep,a.propDep,t)}if(r===yn)return new mi(!1,!1,!1,t);if(r===xn){for(var i=!1,o=!1,f=!1,u=0;u=1&&(o=!0),c>=2&&(f=!0)}else s.type===gn&&(i=i||s.data.thisDep,o=o||s.data.contextDep,f=f||s.data.propDep)}return new mi(i,o,f,t)}return new mi(r===vn,r===bn,r===hn,t)}var vi=new mi(!1,!1,!1,(function(){}));function gi(e,r,n,a,i,o,f,u,s,c,l,d,m,p,h){var b=c.Record,v={add:32774,subtract:32778,\"reverse subtract\":32779};n.ext_blend_minmax&&(v.min=Xa,v.max=$a);var g=n.angle_instanced_arrays,y=n.webgl_draw_buffers,x=n.oes_vertex_array_object,w={dirty:!0,profile:h.profile},A={},_=[],k={},S={};function O(e){return e.replace(\".\",\"_\")}function E(e,t,r){var n=O(e);_.push(e),A[n]=w[n]=!!r,k[n]=t}function T(e,t,r){var n=O(e);_.push(e),Array.isArray(r)?(w[n]=r.slice(),A[n]=r.slice()):w[n]=A[n]=r,S[n]=t}E(wn,xa),E(An,ya),T(_n,\"blendColor\",[0,0,0,0]),T(kn,\"blendEquationSeparate\",[ti,ti]),T(Sn,\"blendFuncSeparate\",[ei,Za,ei,Za]),E(On,Aa,!0),T(En,\"depthFunc\",ri),T(Tn,\"depthRange\",[0,1]),T(Dn,\"depthMask\",!0),T(jn,jn,[!0,!0,!0,!0]),E(Cn,ga),T(zn,\"cullFace\",qa),T(Fn,Fn,Ya),T(Vn,Vn,1),E(Bn,ka),T(In,\"polygonOffset\",[0,0]),E(Pn,Sa),E(Ln,Oa),T(Rn,\"sampleCoverage\",[1,!1]),E(Mn,wa),T(Un,\"stencilMask\",-1),T(Wn,\"stencilFunc\",[Ka,0,-1]),T(Gn,\"stencilOpSeparate\",[Na,Ja,Ja,Ja]),T(Hn,\"stencilOpSeparate\",[qa,Ja,Ja,Ja]),E(Nn,_a),T(qn,\"scissor\",[0,0,e.drawingBufferWidth,e.drawingBufferHeight]),T(Qn,Qn,[0,0,e.drawingBufferWidth,e.drawingBufferHeight]);var D={gl:e,context:m,strings:r,next:A,current:w,draw:d,elements:o,buffer:i,shader:l,attributes:c.state,vao:c,uniforms:s,framebuffer:u,extensions:n,timer:p,isBufferArgs:li},j={primTypes:Te,compareFuncs:fi,blendFuncs:ii,blendEquations:v,stencilOps:ui,glTypes:be,orientationType:ci};F.optional((function(){D.isArrayLike=Ne})),y&&(j.backBuffer=[qa],j.drawBuffer=Y(a.maxDrawbuffers,(function(e){return 0===e?[0]:Y(e,(function(e){return ai+e}))})));var C=0;function z(){var e=function(){var e=0,r=[],n=[];function a(){var r=[],n=[];return t((function(){r.push.apply(r,un(arguments))}),{def:function(){var t=\"v\"+e++;return n.push(t),arguments.length>0&&(r.push(t,\"=\"),r.push.apply(r,un(arguments)),r.push(\";\")),t},toString:function(){return sn([n.length>0?\"var \"+n.join(\",\")+\";\":\"\",sn(r)])}})}function i(){var e=a(),r=a(),n=e.toString,i=r.toString;function o(t,n){r(t,n,\"=\",e.def(t,n),\";\")}return t((function(){e.apply(e,un(arguments))}),{def:e.def,entry:e,exit:r,save:o,set:function(t,r,n){o(t,r),e(t,r,\"=\",n,\";\")},toString:function(){return n()+i()}})}var o=a(),f={};return{global:o,link:function(t){for(var a=0;a=0,'unknown parameter \"'+t+'\"',d.commandStr)}))}t(m),t(p)}));var h=function(e,t){var r=e.static;if(\"string\"==typeof r[Kn]&&\"string\"==typeof r[$n]){if(Object.keys(t.dynamic).length>0)return null;var n=t.static,a=Object.keys(n);if(a.length>0&&\"number\"==typeof n[a[0]]){for(var i=[],o=0;o=0,\"invalid \"+e,r.commandStr)):u=!1,\"height\"in i?(f=0|i.height,F.command(f>=0,\"invalid \"+e,r.commandStr)):u=!1,new mi(!u&&t&&t.thisDep,!u&&t&&t.contextDep,!u&&t&&t.propDep,(function(e,t){var r=e.shared.context,n=o;\"width\"in i||(n=t.def(r,\".\",oa,\"-\",s));var a=f;return\"height\"in i||(a=t.def(r,\".\",fa,\"-\",c)),[s,c,n,a]}))}if(e in a){var l=a[e],d=bi(l,(function(t,r){var n=t.invoke(r,l);F.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e)}));var a=t.shared.context,i=r.def(n,\".x|0\"),o=r.def(n,\".y|0\"),f=r.def('\"width\" in ',n,\"?\",n,\".width|0:\",\"(\",a,\".\",oa,\"-\",i,\")\"),u=r.def('\"height\" in ',n,\"?\",n,\".height|0:\",\"(\",a,\".\",fa,\"-\",o,\")\");return F.optional((function(){t.assert(r,f+\">=0&&\"+u+\">=0\",\"invalid \"+e)})),[i,o,f,u]}));return t&&(d.thisDep=d.thisDep||t.thisDep,d.contextDep=d.contextDep||t.contextDep,d.propDep=d.propDep||t.propDep),d}return t?new mi(t.thisDep,t.contextDep,t.propDep,(function(e,t){var r=e.shared.context;return[0,0,t.def(r,\".\",oa),t.def(r,\".\",fa)]})):null}var o=i(Qn);if(o){var f=o;o=new mi(o.thisDep,o.contextDep,o.propDep,(function(e,t){var r=f.append(e,t),n=e.shared.context;return t.set(n,\".\"+ua,r[2]),t.set(n,\".\"+sa,r[3]),r}))}return{viewport:o,scissor_box:i(qn)}}(e,y,d),w=function(e,t){var r=e.static,n=e.dynamic,a={},i=!1,f=function(){if(na in r){var e=r[na];return null!==e&&null===c.getVAO(e)&&(e=c.createVAO(e)),i=!0,a.vao=e,hi((function(t){var r=c.getVAO(e);return r?t.link(r):\"null\"}))}if(na in n){i=!0;var t=n[na];return bi(t,(function(e,r){var n=e.invoke(r,t);return r.def(e.shared.vao+\".getVAO(\"+n+\")\")}))}return null}(),u=!1,s=function(){if(Jn in r){var e=r[Jn];if(a.elements=e,li(e)){var s=a.elements=o.create(e,!0);e=o.getElements(s),u=!0}else e&&(e=o.getElements(e),u=!0,F.command(e,\"invalid elements\",t.commandStr));var c=hi((function(t,r){if(e){var n=t.link(e);return t.ELEMENTS=n,n}return t.ELEMENTS=null,null}));return c.value=e,c}if(Jn in n){u=!0;var l=n[Jn];return bi(l,(function(e,t){var r=e.shared,n=r.isBufferArgs,a=r.elements,i=e.invoke(t,l),o=t.def(\"null\"),f=t.def(n,\"(\",i,\")\"),u=e.cond(f).then(o,\"=\",a,\".createStream(\",i,\");\").else(o,\"=\",a,\".getElements(\",i,\");\");return F.optional((function(){e.assert(u.else,\"!\"+i+\"||\"+o,\"invalid elements\")})),t.entry(u),t.exit(e.cond(f).then(a,\".destroyStream(\",o,\");\")),e.ELEMENTS=o,o}))}return i?new mi(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.elements+\".getElements(\"+e.shared.vao+\".currentVAO.elements):null\")})):null}();function l(e,o){if(e in r){var s=0|r[e];return o?a.offset=s:a.instances=s,F.command(!o||s>=0,\"invalid \"+e,t.commandStr),hi((function(e,t){return o&&(e.OFFSET=s),s}))}if(e in n){var c=n[e];return bi(c,(function(t,r){var n=t.invoke(r,c);return o&&(t.OFFSET=n,F.optional((function(){t.assert(r,n+\">=0\",\"invalid \"+e)}))),n}))}if(o){if(u)return hi((function(e,t){return e.OFFSET=0,0}));if(i)return new mi(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.vao+\".currentVAO.offset:0\")}))}else if(i)return new mi(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.vao+\".currentVAO.instances:-1\")}));return null}var d=l(ta,!0),m=function(){if(Zn in r){var e=r[Zn];return a.primitive=e,F.commandParameter(e,Te,\"invalid primitve\",t.commandStr),hi((function(t,r){return Te[e]}))}if(Zn in n){var o=n[Zn];return bi(o,(function(e,t){var r=e.constants.primTypes,n=e.invoke(t,o);return F.optional((function(){e.assert(t,n+\" in \"+r,\"invalid primitive, must be one of \"+Object.keys(Te))})),t.def(r,\"[\",n,\"]\")}))}return u?pi(s)?s.value?hi((function(e,t){return t.def(e.ELEMENTS,\".primType\")})):hi((function(){return Ha})):new mi(s.thisDep,s.contextDep,s.propDep,(function(e,t){var r=e.ELEMENTS;return t.def(r,\"?\",r,\".primType:\",Ha)})):i?new mi(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao+\".currentVAO?\"+e.shared.vao+\".currentVAO.primitive:\"+Ha)})):null}(),p=function(){if(ea in r){var e=0|r[ea];return a.count=e,F.command(\"number\"==typeof e&&e>=0,\"invalid vertex count\",t.commandStr),hi((function(){return e}))}if(ea in n){var o=n[ea];return bi(o,(function(e,t){var r=e.invoke(t,o);return F.optional((function(){e.assert(t,\"typeof \"+r+'===\"number\"&&'+r+\">=0&&\"+r+\"===(\"+r+\"|0)\",\"invalid vertex count\")})),r}))}if(u){if(pi(s)){if(s)return d?new mi(d.thisDep,d.contextDep,d.propDep,(function(e,t){var r=t.def(e.ELEMENTS,\".vertCount-\",e.OFFSET);return F.optional((function(){e.assert(t,r+\">=0\",\"invalid vertex offset/element buffer too small\")})),r})):hi((function(e,t){return t.def(e.ELEMENTS,\".vertCount\")}));var c=hi((function(){return-1}));return F.optional((function(){c.MISSING=!0})),c}var l=new mi(s.thisDep||d.thisDep,s.contextDep||d.contextDep,s.propDep||d.propDep,(function(e,t){var r=e.ELEMENTS;return e.OFFSET?t.def(r,\"?\",r,\".vertCount-\",e.OFFSET,\":-1\"):t.def(r,\"?\",r,\".vertCount:-1\")}));return F.optional((function(){l.DYNAMIC=!0})),l}if(i){var m=new mi(f.thisDep,f.contextDep,f.propDep,(function(e,t){return t.def(e.shared.vao,\".currentVAO?\",e.shared.vao,\".currentVAO.count:-1\")}));return m}return null}(),h=l(ra,!1);return{elements:s,primitive:m,count:p,instances:h,offset:d,vao:f,vaoActive:i,elementsActive:u,static:a}}(e,d),A=function(e,t){var r=e.static,n=e.dynamic,i={};return _.forEach((function(e){var o=O(e);function f(t,a){if(e in r){var f=t(r[e]);i[o]=hi((function(){return f}))}else if(e in n){var u=n[e];i[o]=bi(u,(function(e,t){return a(e,t,e.invoke(t,u))}))}}switch(e){case Cn:case An:case wn:case Mn:case On:case Nn:case Bn:case Pn:case Ln:case Dn:return f((function(r){return F.commandType(r,\"boolean\",e,t.commandStr),r}),(function(t,r,n){return F.optional((function(){t.assert(r,\"typeof \"+n+'===\"boolean\"',\"invalid flag \"+e,t.commandStr)})),n}));case En:return f((function(r){return F.commandParameter(r,fi,\"invalid \"+e,t.commandStr),fi[r]}),(function(t,r,n){var a=t.constants.compareFuncs;return F.optional((function(){t.assert(r,n+\" in \"+a,\"invalid \"+e+\", must be one of \"+Object.keys(fi))})),r.def(a,\"[\",n,\"]\")}));case Tn:return f((function(e){return F.command(Ne(e)&&2===e.length&&\"number\"==typeof e[0]&&\"number\"==typeof e[1]&&e[0]<=e[1],\"depth range is 2d array\",t.commandStr),e}),(function(e,t,r){return F.optional((function(){e.assert(t,e.shared.isArrayLike+\"(\"+r+\")&&\"+r+\".length===2&&typeof \"+r+'[0]===\"number\"&&typeof '+r+'[1]===\"number\"&&'+r+\"[0]<=\"+r+\"[1]\",\"depth range must be a 2d array\")})),[t.def(\"+\",r,\"[0]\"),t.def(\"+\",r,\"[1]\")]}));case Sn:return f((function(e){F.commandType(e,\"object\",\"blend.func\",t.commandStr);var r=\"srcRGB\"in e?e.srcRGB:e.src,n=\"srcAlpha\"in e?e.srcAlpha:e.src,a=\"dstRGB\"in e?e.dstRGB:e.dst,i=\"dstAlpha\"in e?e.dstAlpha:e.dst;return F.commandParameter(r,ii,o+\".srcRGB\",t.commandStr),F.commandParameter(n,ii,o+\".srcAlpha\",t.commandStr),F.commandParameter(a,ii,o+\".dstRGB\",t.commandStr),F.commandParameter(i,ii,o+\".dstAlpha\",t.commandStr),F.command(-1===oi.indexOf(r+\", \"+a),\"unallowed blending combination (srcRGB, dstRGB) = (\"+r+\", \"+a+\")\",t.commandStr),[ii[r],ii[a],ii[n],ii[i]]}),(function(t,r,n){var a=t.constants.blendFuncs;function i(i,o){var f=r.def('\"',i,o,'\" in ',n,\"?\",n,\".\",i,o,\":\",n,\".\",i);return F.optional((function(){t.assert(r,f+\" in \"+a,\"invalid \"+e+\".\"+i+o+\", must be one of \"+Object.keys(ii))})),f}F.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid blend func, must be an object\")}));var o=i(\"src\",\"RGB\"),f=i(\"dst\",\"RGB\");F.optional((function(){var e=t.constants.invalidBlendCombinations;t.assert(r,e+\".indexOf(\"+o+'+\", \"+'+f+\") === -1 \",\"unallowed blending combination for (srcRGB, dstRGB)\")}));var u=r.def(a,\"[\",o,\"]\"),s=r.def(a,\"[\",i(\"src\",\"Alpha\"),\"]\");return[u,r.def(a,\"[\",f,\"]\"),s,r.def(a,\"[\",i(\"dst\",\"Alpha\"),\"]\")]}));case kn:return f((function(r){return\"string\"==typeof r?(F.commandParameter(r,v,\"invalid \"+e,t.commandStr),[v[r],v[r]]):\"object\"==typeof r?(F.commandParameter(r.rgb,v,e+\".rgb\",t.commandStr),F.commandParameter(r.alpha,v,e+\".alpha\",t.commandStr),[v[r.rgb],v[r.alpha]]):void F.commandRaise(\"invalid blend.equation\",t.commandStr)}),(function(t,r,n){var a=t.constants.blendEquations,i=r.def(),o=r.def(),f=t.cond(\"typeof \",n,'===\"string\"');return F.optional((function(){function r(e,r,n){t.assert(e,n+\" in \"+a,\"invalid \"+r+\", must be one of \"+Object.keys(v))}r(f.then,e,n),t.assert(f.else,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e),r(f.else,e+\".rgb\",n+\".rgb\"),r(f.else,e+\".alpha\",n+\".alpha\")})),f.then(i,\"=\",o,\"=\",a,\"[\",n,\"];\"),f.else(i,\"=\",a,\"[\",n,\".rgb];\",o,\"=\",a,\"[\",n,\".alpha];\"),r(f),[i,o]}));case _n:return f((function(e){return F.command(Ne(e)&&4===e.length,\"blend.color must be a 4d array\",t.commandStr),Y(4,(function(t){return+e[t]}))}),(function(e,t,r){return F.optional((function(){e.assert(t,e.shared.isArrayLike+\"(\"+r+\")&&\"+r+\".length===4\",\"blend.color must be a 4d array\")})),Y(4,(function(e){return t.def(\"+\",r,\"[\",e,\"]\")}))}));case Un:return f((function(e){return F.commandType(e,\"number\",o,t.commandStr),0|e}),(function(e,t,r){return F.optional((function(){e.assert(t,\"typeof \"+r+'===\"number\"',\"invalid stencil.mask\")})),t.def(r,\"|0\")}));case Wn:return f((function(r){F.commandType(r,\"object\",o,t.commandStr);var n=r.cmp||\"keep\",a=r.ref||0,i=\"mask\"in r?r.mask:-1;return F.commandParameter(n,fi,e+\".cmp\",t.commandStr),F.commandType(a,\"number\",e+\".ref\",t.commandStr),F.commandType(i,\"number\",e+\".mask\",t.commandStr),[fi[n],a,i]}),(function(e,t,r){var n=e.constants.compareFuncs;return F.optional((function(){function a(){e.assert(t,Array.prototype.join.call(arguments,\"\"),\"invalid stencil.func\")}a(r+\"&&typeof \",r,'===\"object\"'),a('!(\"cmp\" in ',r,\")||(\",r,\".cmp in \",n,\")\")})),[t.def('\"cmp\" in ',r,\"?\",n,\"[\",r,\".cmp]\",\":\",Ja),t.def(r,\".ref|0\"),t.def('\"mask\" in ',r,\"?\",r,\".mask|0:-1\")]}));case Gn:case Hn:return f((function(r){F.commandType(r,\"object\",o,t.commandStr);var n=r.fail||\"keep\",a=r.zfail||\"keep\",i=r.zpass||\"keep\";return F.commandParameter(n,ui,e+\".fail\",t.commandStr),F.commandParameter(a,ui,e+\".zfail\",t.commandStr),F.commandParameter(i,ui,e+\".zpass\",t.commandStr),[e===Hn?qa:Na,ui[n],ui[a],ui[i]]}),(function(t,r,n){var a=t.constants.stencilOps;function i(i){return F.optional((function(){t.assert(r,'!(\"'+i+'\" in '+n+\")||(\"+n+\".\"+i+\" in \"+a+\")\",\"invalid \"+e+\".\"+i+\", must be one of \"+Object.keys(ui))})),r.def('\"',i,'\" in ',n,\"?\",a,\"[\",n,\".\",i,\"]:\",Ja)}return F.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e)})),[e===Hn?qa:Na,i(\"fail\"),i(\"zfail\"),i(\"zpass\")]}));case In:return f((function(e){F.commandType(e,\"object\",o,t.commandStr);var r=0|e.factor,n=0|e.units;return F.commandType(r,\"number\",o+\".factor\",t.commandStr),F.commandType(n,\"number\",o+\".units\",t.commandStr),[r,n]}),(function(t,r,n){return F.optional((function(){t.assert(r,n+\"&&typeof \"+n+'===\"object\"',\"invalid \"+e)})),[r.def(n,\".factor|0\"),r.def(n,\".units|0\")]}));case zn:return f((function(e){var r=0;return\"front\"===e?r=Na:\"back\"===e&&(r=qa),F.command(!!r,o,t.commandStr),r}),(function(e,t,r){return F.optional((function(){e.assert(t,r+'===\"front\"||'+r+'===\"back\"',\"invalid cull.face\")})),t.def(r,'===\"front\"?',Na,\":\",qa)}));case Vn:return f((function(e){return F.command(\"number\"==typeof e&&e>=a.lineWidthDims[0]&&e<=a.lineWidthDims[1],\"invalid line width, must be a positive number between \"+a.lineWidthDims[0]+\" and \"+a.lineWidthDims[1],t.commandStr),e}),(function(e,t,r){return F.optional((function(){e.assert(t,\"typeof \"+r+'===\"number\"&&'+r+\">=\"+a.lineWidthDims[0]+\"&&\"+r+\"<=\"+a.lineWidthDims[1],\"invalid line width\")})),r}));case Fn:return f((function(e){return F.commandParameter(e,ci,o,t.commandStr),ci[e]}),(function(e,t,r){return F.optional((function(){e.assert(t,r+'===\"cw\"||'+r+'===\"ccw\"',\"invalid frontFace, must be one of cw,ccw\")})),t.def(r+'===\"cw\"?'+Qa+\":\"+Ya)}));case jn:return f((function(e){return F.command(Ne(e)&&4===e.length,\"color.mask must be length 4 array\",t.commandStr),e.map((function(e){return!!e}))}),(function(e,t,r){return F.optional((function(){e.assert(t,e.shared.isArrayLike+\"(\"+r+\")&&\"+r+\".length===4\",\"invalid color.mask\")})),Y(4,(function(e){return\"!!\"+r+\"[\"+e+\"]\"}))}));case Rn:return f((function(e){F.command(\"object\"==typeof e&&e,o,t.commandStr);var r=\"value\"in e?e.value:1,n=!!e.invert;return F.command(\"number\"==typeof r&&r>=0&&r<=1,\"sample.coverage.value must be a number between 0 and 1\",t.commandStr),[r,n]}),(function(e,t,r){return F.optional((function(){e.assert(t,r+\"&&typeof \"+r+'===\"object\"',\"invalid sample.coverage\")})),[t.def('\"value\" in ',r,\"?+\",r,\".value:1\"),t.def(\"!!\",r,\".invert\")]}))}})),i}(e,d),k=function(e,t,n){var a=e.static,i=e.dynamic;function o(e){if(e in a){var t=r.id(a[e]);F.optional((function(){l.shader(si[e],t,F.guessCommand())}));var n=hi((function(){return t}));return n.id=t,n}if(e in i){var o=i[e];return bi(o,(function(t,r){var n=t.invoke(r,o),a=r.def(t.shared.strings,\".id(\",n,\")\");return F.optional((function(){r(t.shared.shader,\".shader(\",si[e],\",\",a,\",\",t.command,\");\")})),a}))}return null}var f,u=o(Kn),s=o($n),c=null;return pi(u)&&pi(s)?(c=l.program(s.id,u.id,null,n),f=hi((function(e,t){return e.link(c)}))):f=new mi(u&&u.thisDep||s&&s.thisDep,u&&u.contextDep||s&&s.contextDep,u&&u.propDep||s&&s.propDep,(function(e,t){var r,n=e.shared.shader;r=u?u.append(e,t):t.def(n,\".\",Kn);var a=n+\".program(\"+(s?s.append(e,t):t.def(n,\".\",$n))+\",\"+r;return F.optional((function(){a+=\",\"+e.command})),t.def(a+\")\")})),{frag:u,vert:s,progVar:f,program:c}}(e,0,h);function S(e){var t=x[e];t&&(A[e]=t)}S(Qn),S(O(qn));var E=Object.keys(A).length>0,T={framebuffer:y,draw:w,shader:k,state:A,dirty:E,scopeVAO:null,drawVAO:null,useVAO:!1,attributes:{}};if(T.profile=function(e){var t,r=e.static,n=e.dynamic;if(Yn in r){var a=!!r[Yn];(t=hi((function(e,t){return a}))).enable=a}else if(Yn in n){var i=n[Yn];t=bi(i,(function(e,t){return e.invoke(t,i)}))}return t}(e),T.uniforms=function(e,t){var r=e.static,n=e.dynamic,a={};return Object.keys(r).forEach((function(e){var n,i=r[e];if(\"number\"==typeof i||\"boolean\"==typeof i)n=hi((function(){return i}));else if(\"function\"==typeof i){var o=i._reglType;\"texture2d\"===o||\"textureCube\"===o?n=hi((function(e){return e.link(i)})):\"framebuffer\"===o||\"framebufferCube\"===o?(F.command(i.color.length>0,'missing color attachment for framebuffer sent to uniform \"'+e+'\"',t.commandStr),n=hi((function(e){return e.link(i.color[0])}))):F.commandRaise('invalid data for uniform \"'+e+'\"',t.commandStr)}else Ne(i)?n=hi((function(t){return t.global.def(\"[\",Y(i.length,(function(r){return F.command(\"number\"==typeof i[r]||\"boolean\"==typeof i[r],\"invalid uniform \"+e,t.commandStr),i[r]})),\"]\")})):F.commandRaise('invalid or missing data for uniform \"'+e+'\"',t.commandStr);n.value=i,a[e]=n})),Object.keys(n).forEach((function(e){var t=n[e];a[e]=bi(t,(function(e,r){return e.invoke(r,t)}))})),a}(f,d),T.drawVAO=T.scopeVAO=w.vao,!T.drawVAO&&k.program&&!h&&n.angle_instanced_arrays&&w.static.elements){var D=!0,j=k.program.attributes.map((function(e){var r=t.static[e];return D=D&&!!r,r}));if(D&&j.length>0){var C=c.getVAO(c.createVAO({attributes:j,elements:w.static.elements}));T.drawVAO=new mi(null,null,null,(function(e,t){return e.link(C)})),T.useVAO=!0}}return h?T.useVAO=!0:T.attributes=function(e,t){var n=e.static,a=e.dynamic,o={};return Object.keys(n).forEach((function(e){var a=n[e],f=r.id(e),u=new b;if(li(a))u.state=dn,u.buffer=i.getBuffer(i.create(a,pa,!1,!0)),u.type=0;else{var s=i.getBuffer(a);if(s)u.state=dn,u.buffer=s,u.type=0;else if(F.command(\"object\"==typeof a&&a,\"invalid data for attribute \"+e,t.commandStr),\"constant\"in a){var c=a.constant;u.buffer=\"null\",u.state=mn,\"number\"==typeof c?u.x=c:(F.command(Ne(c)&&c.length>0&&c.length<=4,\"invalid constant for attribute \"+e,t.commandStr),cn.forEach((function(e,t){t=0,'invalid offset for attribute \"'+e+'\"',t.commandStr);var d=0|a.stride;F.command(d>=0&&d<256,'invalid stride for attribute \"'+e+'\", must be integer betweeen [0, 255]',t.commandStr);var m=0|a.size;F.command(!(\"size\"in a)||m>0&&m<=4,'invalid size for attribute \"'+e+'\", must be 1,2,3,4',t.commandStr);var p=!!a.normalized,h=0;\"type\"in a&&(F.commandParameter(a.type,be,\"invalid type for attribute \"+e,t.commandStr),h=be[a.type]);var v=0|a.divisor;F.optional((function(){\"divisor\"in a&&(F.command(0===v||g,'cannot specify divisor for attribute \"'+e+'\", instancing not supported',t.commandStr),F.command(v>=0,'invalid divisor for attribute \"'+e+'\"',t.commandStr));var r=t.commandStr,n=[\"buffer\",\"offset\",\"divisor\",\"normalized\",\"type\",\"size\",\"stride\"];Object.keys(a).forEach((function(t){F.command(n.indexOf(t)>=0,'unknown parameter \"'+t+'\" for attribute pointer \"'+e+'\" (valid parameters are '+n+\")\",r)}))})),u.buffer=s,u.state=dn,u.size=m,u.normalized=p,u.type=h||s.dtype,u.offset=l,u.stride=d,u.divisor=v}}o[e]=hi((function(e,t){var r=e.attribCache;if(f in r)return r[f];var n={isStream:!1};return Object.keys(u).forEach((function(e){n[e]=u[e]})),u.buffer&&(n.buffer=e.link(u.buffer),n.type=n.type||n.buffer+\".dtype\"),r[f]=n,n}))})),Object.keys(a).forEach((function(e){var t=a[e];o[e]=bi(t,(function(r,n){var a=r.invoke(n,t),i=r.shared,o=r.constants,f=i.isBufferArgs,u=i.buffer;F.optional((function(){r.assert(n,a+\"&&(typeof \"+a+'===\"object\"||typeof '+a+'===\"function\")&&('+f+\"(\"+a+\")||\"+u+\".getBuffer(\"+a+\")||\"+u+\".getBuffer(\"+a+\".buffer)||\"+f+\"(\"+a+'.buffer)||(\"constant\" in '+a+\"&&(typeof \"+a+'.constant===\"number\"||'+i.isArrayLike+\"(\"+a+\".constant))))\",'invalid dynamic attribute \"'+e+'\"')}));var s={isStream:n.def(!1)},c=new b;c.state=dn,Object.keys(c).forEach((function(e){s[e]=n.def(\"\"+c[e])}));var l=s.buffer,d=s.type;function m(e){n(s[e],\"=\",a,\".\",e,\"|0;\")}return n(\"if(\",f,\"(\",a,\")){\",s.isStream,\"=true;\",l,\"=\",u,\".createStream(\",pa,\",\",a,\");\",d,\"=\",l,\".dtype;\",\"}else{\",l,\"=\",u,\".getBuffer(\",a,\");\",\"if(\",l,\"){\",d,\"=\",l,\".dtype;\",'}else if(\"constant\" in ',a,\"){\",s.state,\"=\",mn,\";\",\"if(typeof \"+a+'.constant === \"number\"){',s[cn[0]],\"=\",a,\".constant;\",cn.slice(1).map((function(e){return s[e]})).join(\"=\"),\"=0;\",\"}else{\",cn.map((function(e,t){return s[e]+\"=\"+a+\".constant.length>\"+t+\"?\"+a+\".constant[\"+t+\"]:0;\"})).join(\"\"),\"}}else{\",\"if(\",f,\"(\",a,\".buffer)){\",l,\"=\",u,\".createStream(\",pa,\",\",a,\".buffer);\",\"}else{\",l,\"=\",u,\".getBuffer(\",a,\".buffer);\",\"}\",d,'=\"type\" in ',a,\"?\",o.glTypes,\"[\",a,\".type]:\",l,\".dtype;\",s.normalized,\"=!!\",a,\".normalized;\"),m(\"size\"),m(\"offset\"),m(\"stride\"),m(\"divisor\"),n(\"}}\"),n.exit(\"if(\",s.isStream,\"){\",u,\".destroyStream(\",l,\");\",\"}\"),s}))})),o}(t,d),T.context=function(e){var t=e.static,r=e.dynamic,n={};return Object.keys(t).forEach((function(e){var r=t[e];n[e]=hi((function(e,t){return\"number\"==typeof r||\"boolean\"==typeof r?\"\"+r:e.link(r)}))})),Object.keys(r).forEach((function(e){var t=r[e];n[e]=bi(t,(function(e,r){return e.invoke(r,t)}))})),n}(s),T}function B(e,t,r){var n=e.shared.context,a=e.scope();Object.keys(r).forEach((function(i){t.save(n,\".\"+i);var o=r[i].append(e,t);Array.isArray(o)?a(n,\".\",i,\"=[\",o.join(),\"];\"):a(n,\".\",i,\"=\",o,\";\")})),t(a)}function I(e,t,r,n){var a,i=e.shared,o=i.gl,f=i.framebuffer;y&&(a=t.def(i.extensions,\".webgl_draw_buffers\"));var u,s=e.constants,c=s.drawBuffer,l=s.backBuffer;u=r?r.append(e,t):t.def(f,\".next\"),n||t(\"if(\",u,\"!==\",f,\".cur){\"),t(\"if(\",u,\"){\",o,\".bindFramebuffer(\",ni,\",\",u,\".framebuffer);\"),y&&t(a,\".drawBuffersWEBGL(\",c,\"[\",u,\".colorAttachments.length]);\"),t(\"}else{\",o,\".bindFramebuffer(\",ni,\",null);\"),y&&t(a,\".drawBuffersWEBGL(\",l,\");\"),t(\"}\",f,\".cur=\",u,\";\"),n||t(\"}\")}function P(e,t,r){var n=e.shared,a=n.gl,i=e.current,o=e.next,f=n.current,u=n.next,s=e.cond(f,\".dirty\");_.forEach((function(t){var n,c,l=O(t);if(!(l in r.state))if(l in o){n=o[l],c=i[l];var d=Y(w[l].length,(function(e){return s.def(n,\"[\",e,\"]\")}));s(e.cond(d.map((function(e,t){return e+\"!==\"+c+\"[\"+t+\"]\"})).join(\"||\")).then(a,\".\",S[l],\"(\",d,\");\",d.map((function(e,t){return c+\"[\"+t+\"]=\"+e})).join(\";\"),\";\"))}else{n=s.def(u,\".\",l);var m=e.cond(n,\"!==\",f,\".\",l);s(m),l in k?m(e.cond(n).then(a,\".enable(\",k[l],\");\").else(a,\".disable(\",k[l],\");\"),f,\".\",l,\"=\",n,\";\"):m(a,\".\",S[l],\"(\",n,\");\",f,\".\",l,\"=\",n,\";\")}})),0===Object.keys(r.state).length&&s(f,\".dirty=false;\"),t(s)}function L(e,t,r,n){var a=e.shared,i=e.current,o=a.current,f=a.gl;di(Object.keys(r)).forEach((function(a){var u=r[a];if(!n||n(u)){var s=u.append(e,t);if(k[a]){var c=k[a];pi(u)?t(f,s?\".enable(\":\".disable(\",c,\");\"):t(e.cond(s).then(f,\".enable(\",c,\");\").else(f,\".disable(\",c,\");\")),t(o,\".\",a,\"=\",s,\";\")}else if(Ne(s)){var l=i[a];t(f,\".\",S[a],\"(\",s,\");\",s.map((function(e,t){return l+\"[\"+t+\"]=\"+e})).join(\";\"),\";\")}else t(f,\".\",S[a],\"(\",s,\");\",o,\".\",a,\"=\",s,\";\")}}))}function R(e,t){g&&(e.instancing=t.def(e.shared.extensions,\".angle_instanced_arrays\"))}function M(e,t,r,n,a){var i,o,f,u=e.shared,s=e.stats,c=u.current,l=u.timer,d=r.profile;function m(){return\"undefined\"==typeof performance?\"Date.now()\":\"performance.now()\"}function h(e){e(i=t.def(),\"=\",m(),\";\"),\"string\"==typeof a?e(s,\".count+=\",a,\";\"):e(s,\".count++;\"),p&&(n?e(o=t.def(),\"=\",l,\".getNumPendingQueries();\"):e(l,\".beginQuery(\",s,\");\"))}function b(e){e(s,\".cpuTime+=\",m(),\"-\",i,\";\"),p&&(n?e(l,\".pushScopeStats(\",o,\",\",l,\".getNumPendingQueries(),\",s,\");\"):e(l,\".endQuery();\"))}function v(e){var r=t.def(c,\".profile\");t(c,\".profile=\",e,\";\"),t.exit(c,\".profile=\",r,\";\")}if(d){if(pi(d))return void(d.enable?(h(t),b(t.exit),v(\"true\")):v(\"false\"));v(f=d.append(e,t))}else f=t.def(c,\".profile\");var g=e.block();h(g),t(\"if(\",f,\"){\",g,\"}\");var y=e.block();b(y),t.exit(\"if(\",f,\"){\",y,\"}\")}function U(e,t,r,n,a){var i=e.shared;n.forEach((function(n){var o,f=n.name,u=r.attributes[f];if(u){if(!a(u))return;o=u.append(e,t)}else{if(!a(vi))return;var s=e.scopeAttrib(f);F.optional((function(){e.assert(t,s+\".state\",\"missing attribute \"+f)})),o={},Object.keys(new b).forEach((function(e){o[e]=t.def(s,\".\",e)}))}!function(r,n,a){var o=i.gl,f=t.def(r,\".location\"),u=t.def(i.attributes,\"[\",f,\"]\"),s=a.state,c=a.buffer,l=[a.x,a.y,a.z,a.w],d=[\"buffer\",\"normalized\",\"offset\",\"stride\"];function m(){t(\"if(!\",u,\".buffer){\",o,\".enableVertexAttribArray(\",f,\");}\");var r,i=a.type;if(r=a.size?t.def(a.size,\"||\",n):n,t(\"if(\",u,\".type!==\",i,\"||\",u,\".size!==\",r,\"||\",d.map((function(e){return u+\".\"+e+\"!==\"+a[e]})).join(\"||\"),\"){\",o,\".bindBuffer(\",pa,\",\",c,\".buffer);\",o,\".vertexAttribPointer(\",[f,r,i,a.normalized,a.stride,a.offset],\");\",u,\".type=\",i,\";\",u,\".size=\",r,\";\",d.map((function(e){return u+\".\"+e+\"=\"+a[e]+\";\"})).join(\"\"),\"}\"),g){var s=a.divisor;t(\"if(\",u,\".divisor!==\",s,\"){\",e.instancing,\".vertexAttribDivisorANGLE(\",[f,s],\");\",u,\".divisor=\",s,\";}\")}}function p(){t(\"if(\",u,\".buffer){\",o,\".disableVertexAttribArray(\",f,\");\",u,\".buffer=null;\",\"}if(\",cn.map((function(e,t){return u+\".\"+e+\"!==\"+l[t]})).join(\"||\"),\"){\",o,\".vertexAttrib4f(\",f,\",\",l,\");\",cn.map((function(e,t){return u+\".\"+e+\"=\"+l[t]+\";\"})).join(\"\"),\"}\")}s===dn?m():s===mn?p():(t(\"if(\",s,\"===\",dn,\"){\"),m(),t(\"}else{\"),p(),t(\"}\"))}(e.link(n),function(e){switch(e){case Ta:case za:case Ia:return 2;case Da:case Fa:case Pa:return 3;case ja:case Va:case La:return 4;default:return 1}}(n.info.type),o)}))}function G(e,t,n,a,i,o){for(var f,u=e.shared,s=u.gl,c={},l=0;l1){if(!b)continue;var v=m.replace(\"[0]\",\"\");if(c[v])continue;c[v]=1}var g,y=e.link(d)+\".location\";if(b){if(!i(b))continue;if(pi(b)){var x=b.value;if(F.command(null!=x,'missing uniform \"'+m+'\"',e.commandStr),p===Wa||p===Ga){F.command(\"function\"==typeof x&&(p===Wa&&(\"texture2d\"===x._reglType||\"framebuffer\"===x._reglType)||p===Ga&&(\"textureCube\"===x._reglType||\"framebufferCube\"===x._reglType)),\"invalid texture for uniform \"+m,e.commandStr);var w=e.link(x._texture||x.color[0]._texture);t(s,\".uniform1i(\",y,\",\",w+\".bind());\"),t.exit(w,\".unbind();\")}else if(p===Ra||p===Ma||p===Ua){F.optional((function(){F.command(Ne(x),\"invalid matrix for uniform \"+m,e.commandStr),F.command(p===Ra&&4===x.length||p===Ma&&9===x.length||p===Ua&&16===x.length,\"invalid length for matrix uniform \"+m,e.commandStr)}));var A=e.global.def(\"new Float32Array([\"+Array.prototype.slice.call(x)+\"])\"),_=2;p===Ma?_=3:p===Ua&&(_=4),t(s,\".uniformMatrix\",_,\"fv(\",y,\",false,\",A,\");\")}else{switch(p){case Ea:1===h?F.commandType(x,\"number\",\"uniform \"+m,e.commandStr):F.command(Ne(x)&&x.length===h,\"uniform \"+m,e.commandStr),f=\"1f\";break;case Ta:F.command(Ne(x)&&x.length&&x.length%2==0&&x.length<=2*h,\"uniform \"+m,e.commandStr),f=\"2f\";break;case Da:F.command(Ne(x)&&x.length&&x.length%3==0&&x.length<=3*h,\"uniform \"+m,e.commandStr),f=\"3f\";break;case ja:F.command(Ne(x)&&x.length&&x.length%4==0&&x.length<=4*h,\"uniform \"+m,e.commandStr),f=\"4f\";break;case Ba:1===h?F.commandType(x,\"boolean\",\"uniform \"+m,e.commandStr):F.command(Ne(x)&&x.length===h,\"uniform \"+m,e.commandStr),f=\"1i\";break;case Ca:1===h?F.commandType(x,\"number\",\"uniform \"+m,e.commandStr):F.command(Ne(x)&&x.length===h,\"uniform \"+m,e.commandStr),f=\"1i\";break;case Ia:case za:F.command(Ne(x)&&x.length&&x.length%2==0&&x.length<=2*h,\"uniform \"+m,e.commandStr),f=\"2i\";break;case Pa:case Fa:F.command(Ne(x)&&x.length&&x.length%3==0&&x.length<=3*h,\"uniform \"+m,e.commandStr),f=\"3i\";break;case La:case Va:F.command(Ne(x)&&x.length&&x.length%4==0&&x.length<=4*h,\"uniform \"+m,e.commandStr),f=\"4i\"}h>1?(f+=\"v\",x=e.global.def(\"[\"+Array.prototype.slice.call(x)+\"]\")):x=Ne(x)?Array.prototype.slice.call(x):x,t(s,\".uniform\",f,\"(\",y,\",\",x,\");\")}continue}g=b.append(e,t)}else{if(!i(vi))continue;g=t.def(u.uniforms,\"[\",r.id(m),\"]\")}p===Wa?(F(!Array.isArray(g),\"must specify a scalar prop for textures\"),t(\"if(\",g,\"&&\",g,'._reglType===\"framebuffer\"){',g,\"=\",g,\".color[0];\",\"}\")):p===Ga&&(F(!Array.isArray(g),\"must specify a scalar prop for cube maps\"),t(\"if(\",g,\"&&\",g,'._reglType===\"framebufferCube\"){',g,\"=\",g,\".color[0];\",\"}\")),F.optional((function(){function r(r,n){e.assert(t,r,'bad data or missing for uniform \"'+m+'\". '+n)}function n(e,t){1===t&&F(!Array.isArray(g),\"must not specify an array type for uniform\"),r(\"Array.isArray(\"+g+\") && typeof \"+g+'[0]===\" '+e+'\" || typeof '+g+'===\"'+e+'\"',\"invalid type, expected \"+e)}function a(t,n,a){Array.isArray(g)?F(g.length&&g.length%t==0&&g.length<=t*a,\"must have length of \"+(1===a?\"\":\"n * \")+t):r(u.isArrayLike+\"(\"+g+\")&&\"+g+\".length && \"+g+\".length % \"+t+\" === 0 && \"+g+\".length<=\"+t*a,\"invalid vector, should have length of \"+(1===a?\"\":\"n * \")+t,e.commandStr)}function i(t){F(!Array.isArray(g),\"must not specify a value type\"),r(\"typeof \"+g+'===\"function\"&&'+g+'._reglType===\"texture'+(t===ba?\"2d\":\"Cube\")+'\"',\"invalid texture type\",e.commandStr)}switch(p){case Ca:n(\"number\",h);break;case za:a(2,0,h);break;case Fa:a(3,0,h);break;case Va:a(4,0,h);break;case Ea:n(\"number\",h);break;case Ta:a(2,0,h);break;case Da:a(3,0,h);break;case ja:a(4,0,h);break;case Ba:n(\"boolean\",h);break;case Ia:a(2,0,h);break;case Pa:a(3,0,h);break;case La:case Ra:a(4,0,h);break;case Ma:a(9,0,h);break;case Ua:a(16,0,h);break;case Wa:i(ba);break;case Ga:i(va)}}));var k=1;switch(p){case Wa:case Ga:var S=t.def(g,\"._texture\");t(s,\".uniform1i(\",y,\",\",S,\".bind());\"),t.exit(S,\".unbind();\");continue;case Ca:case Ba:f=\"1i\";break;case za:case Ia:f=\"2i\",k=2;break;case Fa:case Pa:f=\"3i\",k=3;break;case Va:case La:f=\"4i\",k=4;break;case Ea:f=\"1f\";break;case Ta:f=\"2f\",k=2;break;case Da:f=\"3f\",k=3;break;case ja:f=\"4f\",k=4;break;case Ra:f=\"Matrix2fv\";break;case Ma:f=\"Matrix3fv\";break;case Ua:f=\"Matrix4fv\"}if(-1===f.indexOf(\"Matrix\")&&h>1&&(f+=\"v\",k=1),\"M\"===f.charAt(0)){t(s,\".uniform\",f,\"(\",y,\",\");var O=Math.pow(p-Ra+2,2),E=e.global.def(\"new Float32Array(\",O,\")\");Array.isArray(g)?t(\"false,(\",Y(O,(function(e){return E+\"[\"+e+\"]=\"+g[e]})),\",\",E,\")\"):t(\"false,(Array.isArray(\",g,\")||\",g,\" instanceof Float32Array)?\",g,\":(\",Y(O,(function(e){return E+\"[\"+e+\"]=\"+g+\"[\"+e+\"]\"})),\",\",E,\")\"),t(\");\")}else if(k>1){for(var T=[],D=[],j=0;j=0\",\"missing vertex count\")}))):(a=u.def(o,\".\",ea),F.optional((function(){e.assert(u,a+\">=0\",\"missing vertex count\")}))),a}();if(\"number\"==typeof p){if(0===p)return}else r(\"if(\",p,\"){\"),r.exit(\"}\");g&&(c=s(ra),l=e.instancing);var h=u+\".type\",b=f.elements&&pi(f.elements)&&!f.vaoActive;function v(){function e(){r(l,\".drawElementsInstancedANGLE(\",[d,p,h,m+\"<<((\"+h+\"-\"+ln+\")>>1)\",c],\");\")}function t(){r(l,\".drawArraysInstancedANGLE(\",[d,m,p,c],\");\")}u&&\"null\"!==u?b?e():(r(\"if(\",u,\"){\"),e(),r(\"}else{\"),t(),r(\"}\")):t()}function y(){function e(){r(i+\".drawElements(\"+[d,p,h,m+\"<<((\"+h+\"-\"+ln+\")>>1)\"]+\");\")}function t(){r(i+\".drawArrays(\"+[d,m,p]+\");\")}u&&\"null\"!==u?b?e():(r(\"if(\",u,\"){\"),e(),r(\"}else{\"),t(),r(\"}\")):t()}g&&(\"number\"!=typeof c||c>=0)?\"string\"==typeof c?(r(\"if(\",c,\">0){\"),v(),r(\"}else if(\",c,\"<0){\"),y(),r(\"}\")):v():y()}function N(e,t,r,n,a){var i=z(),o=i.proc(\"body\",a);return F.optional((function(){i.commandStr=t.commandStr,i.command=i.link(t.commandStr)})),g&&(i.instancing=o.def(i.shared.extensions,\".angle_instanced_arrays\")),e(i,o,r,n),i.compile().body}function q(e,t,r,n){R(e,t),r.useVAO?r.drawVAO?t(e.shared.vao,\".setVAO(\",r.drawVAO.append(e,t),\");\"):t(e.shared.vao,\".setVAO(\",e.shared.vao,\".targetVAO);\"):(t(e.shared.vao,\".setVAO(null);\"),U(e,t,r,n.attributes,(function(){return!0}))),G(e,t,r,n.uniforms,(function(){return!0}),!1),H(e,t,t,r)}function Q(e,t,r,n){function a(){return!0}e.batchId=\"a1\",R(e,t),U(e,t,r,n.attributes,a),G(e,t,r,n.uniforms,a,!1),H(e,t,t,r)}function X(e,t,r,n){R(e,t);var a=r.contextDep,i=t.def(),o=t.def();e.shared.props=o,e.batchId=i;var f=e.scope(),u=e.scope();function s(e){return e.contextDep&&a||e.propDep}function c(e){return!s(e)}if(t(f.entry,\"for(\",i,\"=0;\",i,\"<\",\"a1\",\";++\",i,\"){\",o,\"=\",\"a0\",\"[\",i,\"];\",u,\"}\",f.exit),r.needsContext&&B(e,u,r.context),r.needsFramebuffer&&I(e,u,r.framebuffer),L(e,u,r.state,s),r.profile&&s(r.profile)&&M(e,u,r,!1,!0),n)r.useVAO?r.drawVAO?s(r.drawVAO)?u(e.shared.vao,\".setVAO(\",r.drawVAO.append(e,u),\");\"):f(e.shared.vao,\".setVAO(\",r.drawVAO.append(e,f),\");\"):f(e.shared.vao,\".setVAO(\",e.shared.vao,\".targetVAO);\"):(f(e.shared.vao,\".setVAO(null);\"),U(e,f,r,n.attributes,c),U(e,u,r,n.attributes,s)),G(e,f,r,n.uniforms,c,!1),G(e,u,r,n.uniforms,s,!0),H(e,f,u,r);else{var l=e.global.def(\"{}\"),d=r.shader.progVar.append(e,u),m=u.def(d,\".id\"),p=u.def(l,\"[\",m,\"]\");u(e.shared.gl,\".useProgram(\",d,\".program);\",\"if(!\",p,\"){\",p,\"=\",l,\"[\",m,\"]=\",e.link((function(t){return N(Q,e,r,t,2)})),\"(\",d,\");}\",p,\".call(this,a0[\",i,\"],\",i,\");\")}}function $(e,t,r){var n=t.static[r];if(n&&function(e){if(\"object\"==typeof e&&!Ne(e)){for(var t=Object.keys(e),r=0;r0&&r(e.shared.current,\".dirty=true;\"),e.shared.vao&&r(e.shared.vao,\".setVAO(null);\")}(f,u),function(e,t){var n=e.proc(\"scope\",3);e.batchId=\"a2\";var a=e.shared,i=a.current;function o(r){var i=t.shader[r];i&&n.set(a.shader,\".\"+r,i.append(e,n))}B(e,n,t.context),t.framebuffer&&t.framebuffer.append(e,n),di(Object.keys(t.state)).forEach((function(r){var i=t.state[r].append(e,n);Ne(i)?i.forEach((function(t,a){n.set(e.next[r],\"[\"+a+\"]\",t)})):n.set(a.next,\".\"+r,i)})),M(e,n,t,!0,!0),[Jn,ta,ea,ra,Zn].forEach((function(r){var i=t.draw[r];i&&n.set(a.draw,\".\"+r,\"\"+i.append(e,n))})),Object.keys(t.uniforms).forEach((function(i){var o=t.uniforms[i].append(e,n);Array.isArray(o)&&(o=\"[\"+o.join()+\"]\"),n.set(a.uniforms,\"[\"+r.id(i)+\"]\",o)})),Object.keys(t.attributes).forEach((function(r){var a=t.attributes[r].append(e,n),i=e.scopeAttrib(r);Object.keys(new b).forEach((function(e){n.set(i,\".\"+e,a[e])}))})),t.scopeVAO&&n.set(a.vao,\".targetVAO\",t.scopeVAO.append(e,n)),o($n),o(Kn),Object.keys(t.state).length>0&&(n(i,\".dirty=true;\"),n.exit(i,\".dirty=true;\")),n(\"a1(\",e.shared.context,\",a0,\",e.batchId,\");\")}(f,u),function(e,t){var r=e.proc(\"batch\",2);e.batchId=\"0\",R(e,r);var n=!1,a=!0;Object.keys(t.context).forEach((function(e){n=n||t.context[e].propDep})),n||(B(e,r,t.context),a=!1);var i=t.framebuffer,o=!1;function f(e){return e.contextDep&&n||e.propDep}i?(i.propDep?n=o=!0:i.contextDep&&n&&(o=!0),o||I(e,r,i)):I(e,r,null),t.state.viewport&&t.state.viewport.propDep&&(n=!0),P(e,r,t),L(e,r,t.state,(function(e){return!f(e)})),t.profile&&f(t.profile)||M(e,r,t,!1,\"a1\"),t.contextDep=n,t.needsContext=a,t.needsFramebuffer=o;var u=t.shader.progVar;if(u.contextDep&&n||u.propDep)X(e,r,t,null);else{var s=u.append(e,r);if(r(e.shared.gl,\".useProgram(\",s,\".program);\"),t.shader.program)X(e,r,t,t.shader.program);else{r(e.shared.vao,\".setVAO(null);\");var c=e.global.def(\"{}\"),l=r.def(s,\".id\"),d=r.def(c,\"[\",l,\"]\");r(e.cond(d).then(d,\".call(this,a0,a1);\").else(d,\"=\",c,\"[\",l,\"]=\",e.link((function(r){return N(X,e,t,r,2)})),\"(\",s,\");\",d,\".call(this,a0,a1);\"))}}Object.keys(t.state).length>0&&r(e.shared.current,\".dirty=true;\"),e.shared.vao&&r(e.shared.vao,\".setVAO(null);\")}(f,u),t(f.compile(),{destroy:function(){u.shader.program.destroy()}})}}}var yi=34918,xi=34919,wi=35007,Ai=function(e,t){if(!t.ext_disjoint_timer_query)return null;var r=[];function n(e){r.push(e)}var a=[];function i(){this.startQueryIndex=-1,this.endQueryIndex=-1,this.sum=0,this.stats=null}var o=[];function f(e){o.push(e)}var u=[];function s(e,t,r){var n=o.pop()||new i;n.startQueryIndex=e,n.endQueryIndex=t,n.sum=0,n.stats=r,u.push(n)}var c=[],l=[];return{beginQuery:function(e){var n=r.pop()||t.ext_disjoint_timer_query.createQueryEXT();t.ext_disjoint_timer_query.beginQueryEXT(wi,n),a.push(n),s(a.length-1,a.length,e)},endQuery:function(){t.ext_disjoint_timer_query.endQueryEXT(wi)},pushScopeStats:s,update:function(){var e,r,i=a.length;if(0!==i){l.length=Math.max(l.length,i+1),c.length=Math.max(c.length,i+1),c[0]=0,l[0]=0;var o=0;for(e=0,r=0;r0)if(Array.isArray(r[0])){f=ye(r);for(var c=1,l=1;l0)if(\"number\"==typeof t[0]){var i=ae.allocType(d.dtype,t.length);Oe(i,t),p(i,a),ae.freeType(i)}else if(Array.isArray(t[0])||e(t[0])){n=ye(t);var o=ge(t,n,d.dtype);p(o,a),ae.freeType(o)}else F.raise(\"invalid buffer data\")}else if(ce(t)){n=t.shape;var f=t.stride,u=0,s=0,c=0,l=0;1===n.length?(u=n[0],s=1,c=f[0],l=0):2===n.length?(u=n[0],s=n[1],c=f[0],l=f[1]):F.raise(\"invalid shape\");var h=Array.isArray(t.data)?d.dtype:Se(t.data),b=ae.allocType(h,u*s);Ee(b,t.data,u,s,c,l,t.offset),p(b,a),ae.freeType(b)}else F.raise(\"invalid data for buffer subdata\");return m},n.profile&&(m.stats=d.stats),m.destroy=function(){l(d)},m},createStream:function(e,t){var r=u.pop();return r||(r=new f(e)),r.bind(),c(r,t,we,0,1,!1),r},destroyStream:function(e){u.push(e)},clear:function(){le(o).forEach(l),u.forEach(l)},getBuffer:function(e){return e&&e._buffer instanceof f?e._buffer:null},restore:function(){le(o).forEach((function(e){e.buffer=t.createBuffer(),t.bindBuffer(e.type,e.buffer),t.bufferData(e.type,e.persistentData||e.byteLength,e.usage)}))},_initBuffer:c}}(a,l,n,(function(e){return A.destroyBuffer(e)})),w=function(t,r,n,a){var i={},o=0,f={uint8:Fe,uint16:Be};function u(e){this.id=o++,i[this.id]=this,this.buffer=e,this.primType=Ce,this.vertCount=0,this.type=0}r.oes_element_index_uint&&(f.uint32=Pe),u.prototype.bind=function(){this.buffer.bind()};var s=[];function c(a,i,o,f,u,s,c){var l;if(a.buffer.bind(),i){var d=c;c||e(i)&&(!ce(i)||e(i.data))||(d=r.oes_element_index_uint?Pe:Be),n._initBuffer(a.buffer,i,o,d,3)}else t.bufferData(Le,s,o),a.buffer.dtype=l||Fe,a.buffer.usage=o,a.buffer.dimension=3,a.buffer.byteLength=s;if(l=c,!c){switch(a.buffer.dtype){case Fe:case ze:l=Fe;break;case Be:case Ve:l=Be;break;case Pe:case Ie:l=Pe;break;default:F.raise(\"unsupported type for element array\")}a.buffer.dtype=l}a.type=l,F(l!==Pe||!!r.oes_element_index_uint,\"32 bit element buffers not supported, enable oes_element_index_uint first\");var m=u;m<0&&(m=a.buffer.byteLength,l===Be?m>>=1:l===Pe&&(m>>=2)),a.vertCount=m;var p=f;if(f<0){p=Ce;var h=a.buffer.dimension;1===h&&(p=De),2===h&&(p=je),3===h&&(p=Ce)}a.primType=p}function l(e){a.elementsCount--,F(null!==e.buffer,\"must not double destroy elements\"),delete i[e.id],e.buffer.destroy(),e.buffer=null}return{create:function(t,r){var i=n.create(null,Le,!0),o=new u(i._buffer);function s(t){if(t)if(\"number\"==typeof t)i(t),o.primType=Ce,o.vertCount=0|t,o.type=Fe;else{var r=null,n=Me,a=-1,u=-1,l=0,d=0;Array.isArray(t)||e(t)||ce(t)?r=t:(F.type(t,\"object\",\"invalid arguments for elements\"),\"data\"in t&&(r=t.data,F(Array.isArray(r)||e(r)||ce(r),\"invalid data for element buffer\")),\"usage\"in t&&(F.parameter(t.usage,ve,\"invalid element buffer usage\"),n=ve[t.usage]),\"primitive\"in t&&(F.parameter(t.primitive,Te,\"invalid element buffer primitive\"),a=Te[t.primitive]),\"count\"in t&&(F(\"number\"==typeof t.count&&t.count>=0,\"invalid vertex count for elements\"),u=0|t.count),\"type\"in t&&(F.parameter(t.type,f,\"invalid buffer type\"),d=f[t.type]),\"length\"in t?l=0|t.length:(l=u,d===Be||d===Ve?l*=2:d!==Pe&&d!==Ie||(l*=4))),c(o,r,n,a,u,l,d)}else i(),o.primType=Ce,o.vertCount=0,o.type=Fe;return s}return a.elementsCount++,s(t),s._reglType=\"elements\",s._elements=o,s.subdata=function(e,t){return i.subdata(e,t),s},s.destroy=function(){l(o)},s},createStream:function(e){var t=s.pop();return t||(t=new u(n.create(null,Le,!0,!1)._buffer)),c(t,e,Re,-1,-1,0,0),t},destroyStream:function(e){s.push(e)},getElements:function(e){return\"function\"==typeof e&&e._elements instanceof u?e._elements:null},clear:function(){le(i).forEach(l)}}}(a,d,x,l),A=function(t,r,n,a,i,o,f){for(var u=n.maxAttributes,s=new Array(u),c=0;c{for(var e=Object.keys(t),r=0;r=0,'invalid option for vao: \"'+e[r]+'\" valid options are '+$r)})),F(Array.isArray(a),\"attributes must be an array\")}F(a.length0,\"must specify at least one attribute\");var c={},l=n.attributes;l.length=a.length;for(var d=0;d=b.byteLength?m.subdata(b):(m.destroy(),n.buffers[d]=null)),n.buffers[d]||(m=n.buffers[d]=i.create(p,Yr,!1,!0)),h.buffer=i.getBuffer(m),h.size=0|h.buffer.dimension,h.normalized=!1,h.type=h.buffer.dtype,h.offset=0,h.stride=0,h.divisor=0,h.state=1,c[d]=1):i.getBuffer(p)?(h.buffer=i.getBuffer(p),h.size=0|h.buffer.dimension,h.normalized=!1,h.type=h.buffer.dtype,h.offset=0,h.stride=0,h.divisor=0,h.state=1):i.getBuffer(p.buffer)?(h.buffer=i.getBuffer(p.buffer),h.size=0|(+p.size||h.buffer.dimension),h.normalized=!!p.normalized||!1,\"type\"in p?(F.parameter(p.type,be,\"invalid buffer type\"),h.type=be[p.type]):h.type=h.buffer.dtype,h.offset=0|(p.offset||0),h.stride=0|(p.stride||0),h.divisor=0|(p.divisor||0),h.state=1,F(h.size>=1&&h.size<=4,\"size must be between 1 and 4\"),F(h.offset>=0,\"invalid offset\"),F(h.stride>=0&&h.stride<=255,\"stride must be between 0 and 255\"),F(h.divisor>=0,\"divisor must be positive\"),F(!h.divisor||!!r.angle_instanced_arrays,\"ANGLE_instanced_arrays must be enabled to use divisor\")):\"x\"in p?(F(d>0,\"first attribute must not be a constant\"),h.x=+p.x||0,h.y=+p.y||0,h.z=+p.z||0,h.w=+p.w||0,h.state=2):F(!1,\"invalid attribute spec for location \"+d)}for(var v=0;v1)for(var v=0;v1&&(y=y.replace(\"[0]\",\"\")),u(b,new f(y,r.id(y),e.getUniformLocation(m,y),c))}var x=e.getProgramParameter(m,tn);a.profile&&(t.stats.attributesCount=x);var w=t.attributes;for(o=0;oe&&(e=t.stats.uniformsCount)})),e},n.getMaxAttributesCount=function(){var e=0;return l.forEach((function(t){t.stats.attributesCount>e&&(e=t.stats.attributesCount)})),e}),{clear:function(){var t=e.deleteShader.bind(e);le(i).forEach(t),i={},le(o).forEach(t),o={},l.forEach((function(t){e.deleteProgram(t.program)})),l.length=0,c={},n.shaderCount=0},program:function(r,a,f,u){F.command(r>=0,\"missing vertex shader\",f),F.command(a>=0,\"missing fragment shader\",f);var s=c[a];s||(s=c[a]={});var d=s[r];if(d&&(d.refCount++,!u))return d;var h=new m(a,r);return n.shaderCount++,p(h,f,u),d||(s[r]=h),l.push(h),t(h,{destroy:function(){if(h.refCount--,h.refCount<=0){e.deleteProgram(h.program);var t=l.indexOf(h);l.splice(t,1),n.shaderCount--}s[h.vertId].refCount<=0&&(e.deleteShader(o[h.vertId]),delete o[h.vertId],delete c[h.fragId][h.vertId]),Object.keys(c[h.fragId]).length||(e.deleteShader(i[h.fragId]),delete i[h.fragId],delete c[h.fragId])}})},restore:function(){i={},o={};for(var e=0;e=zr&&t=2,\"invalid shape for framebuffer\"),o=C[0],d=C[1]}else\"radius\"in j&&(o=d=j.radius),\"width\"in j&&(o=j.width),\"height\"in j&&(d=j.height);(\"color\"in j||\"colors\"in j)&&(y=j.color||j.colors,Array.isArray(y)&&F(1===y.length||r.webgl_draw_buffers,\"multiple render targets not supported\")),y||(\"colorCount\"in j&&(S=0|j.colorCount,F(S>0,\"invalid color buffer count\")),\"colorTexture\"in j&&(x=!!j.colorTexture,w=\"rgba4\"),\"colorType\"in j&&(_=j.colorType,x?(F(r.oes_texture_float||!(\"float\"===_||\"float32\"===_),\"you must enable OES_texture_float in order to use floating point framebuffer objects\"),F(r.oes_texture_half_float||!(\"half float\"===_||\"float16\"===_),\"you must enable OES_texture_half_float in order to use 16-bit floating point framebuffer objects\")):\"half float\"===_||\"float16\"===_?(F(r.ext_color_buffer_half_float,\"you must enable EXT_color_buffer_half_float to use 16-bit render buffers\"),w=\"rgba16f\"):\"float\"!==_&&\"float32\"!==_||(F(r.webgl_color_buffer_float,\"you must enable WEBGL_color_buffer_float in order to use 32-bit floating point renderbuffers\"),w=\"rgba32f\"),F.oneOf(_,c,\"invalid color type\")),\"colorFormat\"in j&&(w=j.colorFormat,u.indexOf(w)>=0?x=!0:s.indexOf(w)>=0?x=!1:F.optional((function(){x?F.oneOf(j.colorFormat,u,\"invalid color format for texture\"):F.oneOf(j.colorFormat,s,\"invalid color format for renderbuffer\")})))),(\"depthTexture\"in j||\"depthStencilTexture\"in j)&&(D=!(!j.depthTexture&&!j.depthStencilTexture),F(!D||r.webgl_depth_texture,\"webgl_depth_texture extension not supported\")),\"depth\"in j&&(\"boolean\"==typeof j.depth?p=j.depth:(O=j.depth,g=!1)),\"stencil\"in j&&(\"boolean\"==typeof j.stencil?g=j.stencil:(E=j.stencil,p=!1)),\"depthStencil\"in j&&(\"boolean\"==typeof j.depthStencil?p=g=j.depthStencil:(T=j.depthStencil,p=!1,g=!1))}else o=d=1;var z=null,V=null,B=null,I=null;if(Array.isArray(y))z=y.map(h);else if(y)z=[h(y)];else for(z=new Array(S),a=0;a=0||z[a].renderbuffer&&Nr.indexOf(z[a].renderbuffer._renderbuffer.format)>=0,\"framebuffer color attachment \"+a+\" is invalid\"),z[a]&&z[a].texture){var L=Mr[z[a].texture._texture.format]*Ur[z[a].texture._texture.type];null===P?P=L:F(P===L,\"all color attachments much have the same number of bits per pixel.\")}return m(V,o,d),F(!V||V.texture&&V.texture._texture.format===Lr||V.renderbuffer&&V.renderbuffer._renderbuffer.format===Wr,\"invalid depth attachment for framebuffer object\"),m(B,o,d),F(!B||B.renderbuffer&&B.renderbuffer._renderbuffer.format===Gr,\"invalid stencil attachment for framebuffer object\"),m(I,o,d),F(!I||I.texture&&I.texture._texture.format===Hr||I.renderbuffer&&I.renderbuffer._renderbuffer.format===Hr,\"invalid depth-stencil attachment for framebuffer object\"),A(i),i.width=o,i.height=d,i.colorAttachments=z,i.depthAttachment=V,i.stencilAttachment=B,i.depthStencilAttachment=I,l.color=z.map(v),l.depth=v(V),l.stencil=v(B),l.depthStencil=v(I),l.width=i.width,l.height=i.height,k(i),l}return o.framebufferCount++,l(e,a),t(l,{resize:function(e,t){F(f.next!==i,\"can not resize a framebuffer which is currently in use\");var r=Math.max(0|e,1),n=Math.max(0|t||r,1);if(r===i.width&&n===i.height)return l;for(var a=i.colorAttachments,o=0;o=2,\"invalid shape for framebuffer\"),F(g[0]===g[1],\"cube framebuffer must be square\"),d=g[0]}else\"radius\"in v&&(d=0|v.radius),\"width\"in v?(d=0|v.width,\"height\"in v&&F(v.height===d,\"must be square\")):\"height\"in v&&(d=0|v.height);(\"color\"in v||\"colors\"in v)&&(m=v.color||v.colors,Array.isArray(m)&&F(1===m.length||r.webgl_draw_buffers,\"multiple render targets not supported\")),m||(\"colorCount\"in v&&(b=0|v.colorCount,F(b>0,\"invalid color buffer count\")),\"colorType\"in v&&(F.oneOf(v.colorType,c,\"invalid color type\"),h=v.colorType),\"colorFormat\"in v&&(p=v.colorFormat,F.oneOf(v.colorFormat,u,\"invalid color format for texture\"))),\"depth\"in v&&(l.depth=v.depth),\"stencil\"in v&&(l.stencil=v.stencil),\"depthStencil\"in v&&(l.depthStencil=v.depthStencil)}else d=1;if(m)if(Array.isArray(m))for(s=[],n=0;n0&&(l.depth=i[0].depth,l.stencil=i[0].stencil,l.depthStencil=i[0].depthStencil),i[n]?i[n](l):i[n]=S(l)}return t(o,{width:d,height:d,color:s})}return o(e),t(o,{faces:i,resize:function(e){var t,r=0|e;if(F(r>0&&r<=n.maxCubeMapSize,\"invalid radius for cube fbo\"),r===o.width)return o;var a=o.color;for(t=0;t=0;--e){var t=C[e];t&&t(v,null,0)}a.flush(),m&&m.update()}function L(){!I&&C.length>0&&(I=G.next(P))}function R(){I&&(G.cancel(P),I=null)}function M(e){e.preventDefault(),o=!0,R(),z.forEach((function(e){e()}))}function U(e){a.getError(),o=!1,f.restore(),_.restore(),x.restore(),k.restore(),S.restore(),O.restore(),A.restore(),m&&m.restore(),E.procs.refresh(),L(),V.forEach((function(e){e()}))}function N(e){function r(e,t){var r={},n={};return Object.keys(e).forEach((function(a){var i=e[a];if(W.isDynamic(i))n[a]=W.unbox(i,a);else{if(t&&Array.isArray(i))for(var o=0;o0)return l.call(this,function(e){for(;m.length=0,\"cannot cancel a frame twice\"),C[t]=function e(){var t=zi(C,e);C[t]=C[C.length-1],C.length-=1,C.length<=0&&R()}}}}function $(){var e=D.viewport,t=D.scissor_box;e[0]=e[1]=t[0]=t[1]=0,v.viewportWidth=v.framebufferWidth=v.drawingBufferWidth=e[2]=t[2]=a.drawingBufferWidth,v.viewportHeight=v.framebufferHeight=v.drawingBufferHeight=e[3]=t[3]=a.drawingBufferHeight}function K(){v.tick+=1,v.time=Z(),$(),E.procs.poll()}function J(){k.refresh(),$(),E.procs.refresh(),m&&m.update()}function Z(){return(H()-p)/1e3}J();var ee=t(N,{clear:function(e){if(F(\"object\"==typeof e&&e,\"regl.clear() takes an object as input\"),\"framebuffer\"in e)if(e.framebuffer&&\"framebufferCube\"===e.framebuffer_reglType)for(var r=0;r<6;++r)q(t({framebuffer:e.framebuffer.faces[r]},e),Y);else q(e,Y);else Y(0,e)},prop:W.define.bind(null,Di),context:W.define.bind(null,ji),this:W.define.bind(null,Ci),draw:N({}),buffer:function(e){return x.create(e,Oi,!1,!1)},elements:function(e){return w.create(e,!1)},texture:k.create2D,cube:k.createCube,renderbuffer:S.create,framebuffer:O.create,framebufferCube:O.createCube,vao:A.createVAO,attributes:i,frame:X,on:function(e,t){var r;switch(F.type(t,\"function\",\"listener callback must be a function\"),e){case\"frame\":return X(t);case\"lost\":r=z;break;case\"restore\":r=V;break;case\"destroy\":r=B;break;default:F.raise(\"invalid event, must be one of frame,lost,restore,destroy\")}return r.push(t),{cancel:function(){for(var e=0;e=0},read:T,destroy:function(){C.length=0,R(),j&&(j.removeEventListener(Ei,M),j.removeEventListener(Ti,U)),_.clear(),O.clear(),S.clear(),A.clear(),k.clear(),w.clear(),x.clear(),m&&m.clear(),B.forEach((function(e){e()}))},_gl:a,_refresh:J,poll:function(){K(),m&&m.update()},now:Z,stats:l});return n.onDone(null,ee),ee}},\"object\"==typeof r&&void 0!==t?t.exports=o():\"function\"==typeof define&&define.amd?define(o):i.createREGL=o()},\n", - " 507: function _(t,e,a,s,r){s();const n=t(508),_=t(10),o=t(13);class c{constructor(t){this._regl=t,this._map=new Map}_create_texture(t){const e=t.length;let a=0;const s=[];let r=0,_=0;for(let n=0;nc[f+1]&&f++;const s=t[f],n=c[f]+.5*s;let o=.5*s-Math.abs(a-n);f%2==1&&(o=-o),m[e]=Math.round(255*(o-r)/(_-r))}return[[a,u,r,_],this._regl.texture({shape:[l,1,1],data:m,wrapS:\"repeat\",format:\"alpha\",type:\"uint8\",mag:\"linear\",min:\"linear\"})]}_get_key(t){return t.join(\",\")}_get_or_create(t){const e=this._get_key(t);let a=this._map.get(e);if(null==a){const s=(0,n.gcd)(t);if(s>1){t=(0,o.map)(t,(t=>t/s)),a=this._get_or_create(t);const[r,n,_]=a;a=[r,n,s],this._map.set(e,a)}else{const[r,n]=this._create_texture(t);a=[r,n,s],this._map.set(e,a)}}return a}get(t){return t.length%2==1&&(t=(0,_.concat)([t,t])),this._get_or_create(t)}}a.DashCache=c,c.__name__=\"DashCache\"},\n", - " 508: function _(n,t,e,r,o){function u(n,t){let e,r;n>t?(e=n,r=t):(e=t,r=n);let o=e%r;for(;0!=o;)e=r,r=o,o=e%r;return r}r(),e.gcd=function(n){let t=n[0];for(let e=1;e= 0.0 ? 1.0 : -1.0;\\n\\n bool miter_too_large_start = !has_start_cap && miter_too_large(join_type, v_cos_turn_angle_start);\\n bool miter_too_large_end = !has_end_cap && miter_too_large(join_type, v_cos_turn_angle_end);\\n\\n float sign_at_start = -sign(a_position.x); // +ve at segment start, -ve end.\\n vec2 point = sign_at_start > 0.0 ? a_point_start : a_point_end;\\n\\n if ( (has_start_cap && sign_at_start > 0.0) ||\\n (has_end_cap && sign_at_start < 0.0) ) {\\n // Cap.\\n xy = point - segment_right*(halfwidth*a_position.y);\\n if (cap_type == butt_cap)\\n xy -= sign_at_start*0.5*u_antialias*segment_along;\\n else\\n xy -= sign_at_start*halfwidth*segment_along;\\n }\\n else if (sign_at_start > 0.0) {\\n vec2 inside_point = a_point_start + segment_right*(sign_turn_right_start*halfwidth);\\n vec2 prev_outside_point = a_point_start - prev_right*(sign_turn_right_start*halfwidth);\\n\\n // join at start.\\n if (join_type == round_join || join_type == bevel_join || miter_too_large_start) {\\n if (v_cos_turn_angle_start <= 0.0) { // |turn_angle| > 90 degrees\\n xy = a_point_start - segment_right*(halfwidth*a_position.y) - halfwidth*segment_along;\\n }\\n else {\\n if (a_position.x < -1.5) {\\n xy = prev_outside_point;\\n v_coords.y = -dot(xy - a_point_start, segment_right);\\n }\\n else if (a_position.y*sign_turn_right_start > 0.0) { // outside corner of turn\\n float d = halfwidth*abs(sin_turn_angle_start);\\n xy = a_point_start - segment_right*(halfwidth*a_position.y) - d*segment_along;\\n }\\n else { // inside corner of turn\\n xy = inside_point;\\n }\\n }\\n }\\n else { // miter join\\n if (a_position.x < -1.5) {\\n xy = prev_outside_point;\\n v_coords.y = -dot(xy - a_point_start, segment_right);\\n }\\n else if (a_position.y*sign_turn_right_start > 0.0) { // outside corner of turn\\n float tan_half_turn_angle = (1.0-v_cos_turn_angle_start) / sin_turn_angle_start; // Trig identity\\n float d = sign_turn_right_start*halfwidth*tan_half_turn_angle;\\n xy = a_point_start - segment_right*(halfwidth*a_position.y) - d*segment_along;\\n }\\n else { // inside corner if turn\\n xy = inside_point;\\n }\\n }\\n }\\n else {\\n xy = point - segment_right*(halfwidth*a_position.y);\\n }\\n\\n vec2 pos = xy + 0.5; // Bokeh's offset.\\n pos /= u_canvas_size / u_pixel_ratio; // in 0..1\\n gl_Position = vec4(2.0*pos.x - 1.0, 1.0 - 2.0*pos.y, 0.0, 1.0);\\n\\n bool turn_right_start = sin_turn_angle_start >= 0.0;\\n bool turn_right_end = sin_turn_angle_end >= 0.0;\\n\\n v_coords.x = dot(xy - a_point_start, segment_along);\\n v_flags = float(int(has_start_cap) +\\n 2*int(has_end_cap) +\\n 4*int(miter_too_large_start) +\\n 8*int(miter_too_large_end) +\\n 16*int(turn_right_start) +\\n 32*int(turn_right_end));\\n\\n#ifdef DASHED\\n v_length_so_far = a_length_so_far;\\n#endif\\n}\\n\"},\n", - " 510: function _(n,t,a,i,e){i();a.default=\"\\nprecision mediump float;\\n\\nconst int butt_cap = 0;\\nconst int round_cap = 1;\\nconst int square_cap = 2;\\n\\nconst int miter_join = 0;\\nconst int round_join = 1;\\nconst int bevel_join = 2;\\n\\nuniform float u_linewidth;\\nuniform float u_antialias;\\nuniform float u_line_join;\\nuniform float u_line_cap;\\nuniform vec4 u_line_color;\\n#ifdef DASHED\\nuniform sampler2D u_dash_tex;\\nuniform vec4 u_dash_tex_info;\\nuniform float u_dash_scale;\\nuniform float u_dash_offset;\\n#endif\\n\\nvarying float v_segment_length;\\nvarying vec2 v_coords;\\nvarying float v_flags;\\nvarying float v_cos_turn_angle_start;\\nvarying float v_cos_turn_angle_end;\\n#ifdef DASHED\\nvarying float v_length_so_far;\\n#endif\\n\\n#define ONE_MINUS_SMALL (1.0 - 1e-6)\\n\\nfloat cross_z(in vec2 v0, in vec2 v1)\\n{\\n return v0.x*v1.y - v0.y*v1.x;\\n}\\n\\nvec2 right_vector(in vec2 v)\\n{\\n return vec2(v.y, -v.x);\\n}\\n\\nfloat bevel_join_distance(in vec2 coords, in vec2 other_right, in float sign_turn_right)\\n{\\n // other_right is unit vector facing right of the other (previous or next) segment, in coord reference frame\\n float hw = 0.5*u_linewidth; // Not including antialiasing\\n if (other_right.y >= ONE_MINUS_SMALL) { // other_right.y is -cos(turn_angle)\\n // 180 degree turn.\\n return abs(hw - v_coords.x);\\n }\\n else {\\n const vec2 segment_right = vec2(0.0, -1.0);\\n // corner_right is unit vector bisecting corner facing right, in coord reference frame\\n vec2 corner_right = normalize(other_right + segment_right);\\n vec2 outside_point = (-hw*sign_turn_right)*segment_right;\\n return hw + sign_turn_right*dot(outside_point - coords, corner_right);\\n }\\n}\\n\\nfloat cap(in int cap_type, in float x, in float y)\\n{\\n // x is distance along segment in direction away from end of segment,\\n // y is distance across segment.\\n if (cap_type == butt_cap)\\n return max(0.5*u_linewidth - x, abs(y));\\n else if (cap_type == square_cap)\\n return max(-x, abs(y));\\n else // cap_type == round_cap\\n return distance(vec2(min(x, 0.0), y), vec2(0.0, 0.0));\\n}\\n\\nfloat distance_to_alpha(in float dist)\\n{\\n return 1.0 - smoothstep(0.5*(u_linewidth - u_antialias),\\n 0.5*(u_linewidth + u_antialias), dist);\\n}\\n\\nvec2 turn_angle_to_right_vector(in float cos_turn_angle, in float sign_turn_right)\\n{\\n float sin_turn_angle = sign_turn_right*sqrt(1.0 - cos_turn_angle*cos_turn_angle);\\n return vec2(sin_turn_angle, -cos_turn_angle);\\n}\\n\\n#ifdef DASHED\\nfloat dash_distance(in float x)\\n{\\n // x is in direction of v_coords.x, i.e. along segment.\\n float tex_length = u_dash_tex_info.x;\\n float tex_offset = u_dash_tex_info.y;\\n float tex_dist_min = u_dash_tex_info.z;\\n float tex_dist_max = u_dash_tex_info.w;\\n\\n // Apply offset.\\n x += v_length_so_far - u_dash_scale*tex_offset + u_dash_offset;\\n\\n // Interpolate within texture to obtain distance to dash.\\n float dist = texture2D(u_dash_tex,\\n vec2(x / (tex_length*u_dash_scale), 0.0)).a;\\n\\n // Scale distance within min and max limits.\\n dist = tex_dist_min + dist*(tex_dist_max - tex_dist_min);\\n\\n return u_dash_scale*dist;\\n}\\n\\nmat2 rotation_matrix(in vec2 other_right)\\n{\\n float sin_angle = other_right.x;\\n float cos_angle = -other_right.y;\\n return mat2(cos_angle, -sin_angle, sin_angle, cos_angle);\\n}\\n#endif\\n\\nvoid main()\\n{\\n int join_type = int(u_line_join + 0.5);\\n int cap_type = int(u_line_cap + 0.5);\\n float halfwidth = 0.5*(u_linewidth + u_antialias);\\n float half_antialias = 0.5*u_antialias;\\n\\n // Extract flags.\\n int flags = int(v_flags + 0.5);\\n bool turn_right_end = (flags / 32 > 0);\\n float sign_turn_right_end = turn_right_end ? 1.0 : -1.0;\\n flags -= 32*int(turn_right_end);\\n bool turn_right_start = (flags / 16 > 0);\\n float sign_turn_right_start = turn_right_start ? 1.0 : -1.0;\\n flags -= 16*int(turn_right_start);\\n bool miter_too_large_end = (flags / 8 > 0);\\n flags -= 8*int(miter_too_large_end);\\n bool miter_too_large_start = (flags / 4 > 0);\\n flags -= 4*int(miter_too_large_start);\\n bool has_end_cap = (flags / 2 > 0);\\n flags -= 2*int(has_end_cap);\\n bool has_start_cap = flags > 0;\\n\\n // Unit vectors to right of previous and next segments in coord reference frame\\n vec2 prev_right = turn_angle_to_right_vector(v_cos_turn_angle_start, sign_turn_right_start);\\n vec2 next_right = turn_angle_to_right_vector(v_cos_turn_angle_end, sign_turn_right_end);\\n\\n float dist = v_coords.y; // For straight segment, and miter join.\\n\\n // Along-segment coords with respect to end of segment, facing inwards\\n vec2 end_coords = vec2(v_segment_length, 0.0) - v_coords;\\n\\n if (v_coords.x <= half_antialias) {\\n // At start of segment, either cap or join.\\n if (has_start_cap)\\n dist = cap(cap_type, v_coords.x, v_coords.y);\\n else if (join_type == round_join) {\\n if (v_coords.x <= 0.0)\\n dist = distance(v_coords, vec2(0.0, 0.0));\\n }\\n else { // bevel or miter join\\n if (join_type == bevel_join || miter_too_large_start)\\n dist = max(abs(dist), bevel_join_distance(v_coords, prev_right, sign_turn_right_start));\\n float prev_sideways_dist = -sign_turn_right_start*dot(v_coords, prev_right);\\n dist = max(abs(dist), prev_sideways_dist);\\n }\\n }\\n\\n if (end_coords.x <= half_antialias) {\\n if (has_end_cap) {\\n dist = max(abs(dist), cap(cap_type, end_coords.x, v_coords.y));\\n }\\n else if (join_type == bevel_join || miter_too_large_end) {\\n // Bevel join at end impacts half antialias distance\\n dist = max(abs(dist), bevel_join_distance(end_coords, next_right, sign_turn_right_end));\\n }\\n }\\n\\n float alpha = distance_to_alpha(abs(dist));\\n\\n#ifdef DASHED\\n if (u_dash_tex_info.x >= 0.0) {\\n // Dashes in straight segments (outside of joins) are easily calculated.\\n dist = dash_distance(v_coords.x);\\n\\n vec2 prev_coords = rotation_matrix(prev_right)*v_coords;\\n float start_dash_distance = dash_distance(0.0);\\n\\n if (!has_start_cap && cap_type == butt_cap) {\\n // Outer of start join rendered solid color or not at all depending on whether corner\\n // point is in dash or gap, with antialiased ends.\\n bool outer_solid = start_dash_distance >= 0.0 && v_coords.x < half_antialias && prev_coords.x > -half_antialias;\\n if (outer_solid) {\\n // Within solid outer region, antialiased at ends\\n float half_aa_dist = dash_distance(half_antialias);\\n if (half_aa_dist > 0.0) // Next dash near, do not want antialiased gap\\n dist = half_aa_dist - v_coords.x + half_antialias;\\n else\\n dist = start_dash_distance - v_coords.x;\\n\\n half_aa_dist = dash_distance(-half_antialias);\\n if (half_aa_dist > 0.0) // Prev dash nearm do not want antialiased gap\\n dist = min(dist, half_aa_dist + prev_coords.x + half_antialias);\\n else\\n dist = min(dist, start_dash_distance + prev_coords.x);\\n }\\n else {\\n // Outer not rendered, antialias ends.\\n if (v_coords.x < half_antialias)\\n dist = min(0.0, dash_distance(half_antialias) - half_antialias) + v_coords.x;\\n\\n if (prev_coords.x > -half_antialias && prev_coords.x <= half_antialias) {\\n // Antialias from end of previous segment into join\\n float prev_dist = min(0.0, dash_distance(-half_antialias) - half_antialias) - prev_coords.x;\\n // Consider width of previous segment\\n prev_dist = min(prev_dist, 0.5*u_linewidth - abs(prev_coords.y));\\n dist = max(dist, prev_dist);\\n }\\n }\\n }\\n\\n if (!has_end_cap && cap_type == butt_cap && end_coords.x < half_antialias) {\\n float end_dash_distance = dash_distance(v_segment_length);\\n bool increasing = end_dash_distance >= 0.0 && sign_turn_right_end*v_coords.y < 0.0;\\n if (!increasing) {\\n float half_aa_dist = dash_distance(v_segment_length - half_antialias);\\n dist = min(0.0, half_aa_dist - half_antialias) + end_coords.x;\\n }\\n }\\n\\n dist = cap(cap_type, dist, v_coords.y);\\n\\n float dash_alpha = distance_to_alpha(dist);\\n alpha = min(alpha, dash_alpha);\\n }\\n#endif\\n\\n alpha = u_line_color.a*alpha;\\n gl_FragColor = vec4(u_line_color.rgb*alpha, alpha); // Premultiplied alpha.\\n}\\n\"},\n", - " 511: function _(n,i,e,a,t){a();e.default=\"\\nprecision mediump float;\\n\\nattribute vec2 a_position;\\nattribute vec2 a_center;\\nattribute float a_width;\\nattribute float a_height;\\nattribute float a_angle; // In radians\\nuniform vec4 u_border_radius;\\nattribute float a_linewidth;\\nattribute vec4 a_line_color;\\nattribute vec4 a_fill_color;\\nattribute float a_line_cap;\\nattribute float a_line_join;\\nattribute float a_show;\\n#ifdef HATCH\\nattribute float a_hatch_pattern;\\nattribute float a_hatch_scale;\\nattribute float a_hatch_weight;\\nattribute vec4 a_hatch_color;\\n#endif\\n\\nuniform float u_pixel_ratio;\\nuniform vec2 u_canvas_size;\\nuniform float u_antialias;\\nuniform float u_size_hint;\\n\\nvarying float v_linewidth;\\nvarying vec2 v_size; // 2D size for rects compared to 1D for markers.\\nvarying vec4 v_border_radius;\\nvarying vec4 v_line_color;\\nvarying vec4 v_fill_color;\\nvarying float v_line_cap;\\nvarying float v_line_join;\\nvarying vec2 v_coords;\\n#ifdef HATCH\\nvarying float v_hatch_pattern;\\nvarying float v_hatch_scale;\\nvarying float v_hatch_weight;\\nvarying vec4 v_hatch_color;\\nvarying vec2 v_hatch_coords;\\n#endif\\n\\nvoid main()\\n{\\n if (a_show < 0.5 || a_width <= 0.0 || a_height <= 0.0) {\\n // Do not show this rect.\\n gl_Position = vec4(-2.0, -2.0, 0.0, 1.0);\\n return;\\n }\\n\\n v_size = vec2(a_width, a_height);\\n v_border_radius = u_border_radius;\\n v_linewidth = a_linewidth;\\n v_line_color = a_line_color;\\n v_fill_color = a_fill_color;\\n v_line_cap = a_line_cap;\\n v_line_join = a_line_join;\\n\\n if (v_linewidth < 1.0) {\\n // Linewidth less than 1 is implemented as 1 but with reduced alpha.\\n v_line_color.a *= v_linewidth;\\n v_linewidth = 1.0;\\n }\\n\\n#ifdef HATCH\\n v_hatch_pattern = a_hatch_pattern;\\n v_hatch_scale = a_hatch_scale;\\n v_hatch_weight = a_hatch_weight;\\n v_hatch_color = a_hatch_color;\\n#endif\\n\\n vec2 enclosing_size;\\n // Need extra size of (v_linewidth+u_antialias) if edge of marker parallel to\\n // edge of bounding box. If symmetric spike towards edge then multiply by\\n // 1/cos(theta) where theta is angle between spike and bbox edges.\\n int size_hint = int(u_size_hint + 0.5);\\n if (size_hint == 1) // Dash\\n enclosing_size = vec2(v_size.x + v_linewidth + u_antialias,\\n v_linewidth + u_antialias);\\n else if (size_hint == 2) // Dot\\n enclosing_size = 0.25*v_size + u_antialias;\\n else if (size_hint == 3) // Diamond\\n enclosing_size = vec2(v_size.x*(2.0/3.0) + (v_linewidth + u_antialias)*1.20185,\\n v_size.y + (v_linewidth + u_antialias)*1.80278);\\n else if (size_hint == 4) // Hex\\n enclosing_size = v_size + (v_linewidth + u_antialias)*vec2(2.0/sqrt(3.0), 1.0);\\n else if (size_hint == 5) // Square pin\\n enclosing_size = v_size + (v_linewidth + u_antialias)*3.1;\\n else if (size_hint == 6) // Triangle\\n enclosing_size = vec2(v_size.x + (v_linewidth + u_antialias)*sqrt(3.0),\\n v_size.y*(2.0/sqrt(3.0)) + (v_linewidth + u_antialias)*2.0);\\n else if (size_hint == 7) // Triangle pin\\n enclosing_size = v_size + (v_linewidth + u_antialias)*vec2(4.8, 6.0);\\n else if (size_hint == 8) // Star\\n enclosing_size = vec2(v_size.x*0.95106 + (v_linewidth + u_antialias)*3.0,\\n v_size.y + (v_linewidth + u_antialias)*3.2);\\n else\\n enclosing_size = v_size + v_linewidth + u_antialias;\\n\\n // Coordinates in rotated frame with respect to center of marker, used for\\n // distance functions in fragment shader.\\n v_coords = a_position*enclosing_size;\\n\\n float c = cos(-a_angle);\\n float s = sin(-a_angle);\\n mat2 rotation = mat2(c, -s, s, c);\\n\\n vec2 pos = a_center + rotation*v_coords;\\n#ifdef HATCH\\n // Coordinates for hatching in unrotated frame of reference.\\n v_hatch_coords = pos - 0.5;\\n#endif\\n pos += 0.5; // Make up for Bokeh's offset.\\n pos /= u_canvas_size / u_pixel_ratio; // 0 to 1.\\n gl_Position = vec4(2.0*pos.x - 1.0, 1.0 - 2.0*pos.y, 0.0, 1.0);\\n}\\n\"},\n", - " 512: function _(n,i,e,t,a){t();e.default=\"\\nprecision mediump float;\\n\\nconst float SQRT2 = sqrt(2.0);\\nconst float SQRT3 = sqrt(3.0);\\nconst float PI = 3.14159265358979323846;\\n\\nconst int butt_cap = 0;\\nconst int round_cap = 1;\\nconst int square_cap = 2;\\n\\nconst int miter_join = 0;\\nconst int round_join = 1;\\nconst int bevel_join = 2;\\n\\n#ifdef HATCH\\nconst int hatch_dot = 1;\\nconst int hatch_ring = 2;\\nconst int hatch_horizontal_line = 3;\\nconst int hatch_vertical_line = 4;\\nconst int hatch_cross = 5;\\nconst int hatch_horizontal_dash = 6;\\nconst int hatch_vertical_dash = 7;\\nconst int hatch_spiral = 8;\\nconst int hatch_right_diagonal_line = 9;\\nconst int hatch_left_diagonal_line = 10;\\nconst int hatch_diagonal_cross = 11;\\nconst int hatch_right_diagonal_dash = 12;\\nconst int hatch_left_diagonal_dash = 13;\\nconst int hatch_horizontal_wave = 14;\\nconst int hatch_vertical_wave = 15;\\nconst int hatch_criss_cross = 16;\\n#endif\\n\\nuniform float u_antialias;\\n\\nvarying float v_linewidth;\\nvarying vec2 v_size;\\nvarying vec4 v_border_radius;\\nvarying vec4 v_line_color;\\nvarying vec4 v_fill_color;\\nvarying float v_line_cap;\\nvarying float v_line_join;\\nvarying vec2 v_coords;\\n#ifdef HATCH\\nvarying float v_hatch_pattern;\\nvarying float v_hatch_scale;\\nvarying float v_hatch_weight;\\nvarying vec4 v_hatch_color;\\nvarying vec2 v_hatch_coords;\\n#endif\\n\\n// Lines within the marker (dot, cross, x and y) are added at the end as they are\\n// on top of the fill rather than astride it.\\n#if defined(USE_CIRCLE_DOT) || defined(USE_DIAMOND_DOT) || defined(USE_DOT) || defined(USE_HEX_DOT) || defined(USE_SQUARE_DOT) || defined(USE_STAR_DOT) || defined(USE_TRIANGLE_DOT)\\n #define APPEND_DOT\\n#endif\\n\\n#if defined(USE_CIRCLE_CROSS) || defined(USE_SQUARE_CROSS)\\n #define APPEND_CROSS\\n#endif\\n\\n#ifdef USE_DIAMOND_CROSS\\n #define APPEND_CROSS_2\\n#endif\\n\\n#ifdef USE_CIRCLE_X\\n #define APPEND_X\\n #define APPEND_X_LEN (0.5*v_size.x)\\n#endif\\n\\n#ifdef USE_SQUARE_X\\n #define APPEND_X\\n #define APPEND_X_LEN (v_size.x/SQRT2)\\n#endif\\n\\n#ifdef USE_CIRCLE_Y\\n #define APPEND_Y\\n#endif\\n\\n#if defined(USE_ASTERISK) || defined(USE_CROSS) || defined(USE_DASH) || defined(USE_DOT) || defined(USE_X) || defined(USE_Y)\\n // No fill.\\n #define LINE_ONLY\\n#endif\\n\\n#if defined(LINE_ONLY) || defined(APPEND_CROSS) || defined(APPEND_CROSS_2) || defined(APPEND_X) || defined(APPEND_Y)\\nfloat end_cap_distance(in vec2 p, in vec2 end_point, in vec2 unit_direction, in int line_cap)\\n{\\n vec2 offset = p - end_point;\\n if (line_cap == butt_cap)\\n return dot(offset, unit_direction) + 0.5*v_linewidth;\\n else if (line_cap == square_cap)\\n return dot(offset, unit_direction);\\n else if (line_cap == round_cap && dot(offset, unit_direction) > 0.0)\\n return length(offset);\\n else\\n // Default is outside of line and should be -0.5*(v_linewidth+u_antialias) or less,\\n // so here avoid the multiplication.\\n return -v_linewidth-u_antialias;\\n}\\n#endif\\n\\n#if !(defined(LINE_ONLY) || defined(USE_SQUARE_PIN) || defined(USE_TRIANGLE_PIN))\\n// For line join at a vec2 corner where 2 line segments meet, consider bevel points which are the 2\\n// points obtained by moving half a linewidth away from the corner point in the directions normal to\\n// the line segments. The line through these points is the bevel line, characterised by a vec2\\n// unit_normal and offset distance from the corner point. Edge of bevel join straddles this line,\\n// round join occurs outside of this line centred on the corner point. In general\\n// offset = (linewidth/2)*sin(alpha/2)\\n// where alpha is the angle between the 2 line segments at the corner.\\nfloat line_join_distance_no_miter(\\n in vec2 p, in vec2 corner, in vec2 unit_normal, in float offset, in int line_join)\\n{\\n // Simplified version of line_join_distance ignoring miter which most markers do implicitly\\n // as they are composed of straight line segments.\\n float dist_outside = dot((p - corner), unit_normal) - offset;\\n\\n if (line_join == bevel_join && dist_outside > -0.5*u_antialias)\\n return dist_outside + 0.5*v_linewidth;\\n else if (dist_outside > 0.0) // round_join\\n return distance(p, corner);\\n else\\n // Default is outside of line and should be -0.5*(v_linewidth+u_antialias) or less,\\n // so here avoid the multiplication.\\n return -v_linewidth-u_antialias;\\n}\\n#endif\\n\\n#if defined(USE_SQUARE_PIN) || defined(USE_TRIANGLE_PIN)\\n// Line join distance including miter but only one-sided check as assuming use of symmetry in\\n// calling function.\\nfloat line_join_distance_incl_miter(\\n in vec2 p, in vec2 corner, in vec2 unit_normal, in float offset, in int line_join,\\n vec2 miter_unit_normal)\\n{\\n float dist_outside = dot((p - corner), unit_normal) - offset;\\n\\n if (line_join == miter_join && dist_outside > 0.0)\\n return dot((p - corner), miter_unit_normal);\\n else if (line_join == bevel_join && dist_outside > -0.5*u_antialias)\\n return dist_outside + 0.5*v_linewidth;\\n else if (dist_outside > 0.0) // round_join\\n return distance(p, corner);\\n else\\n return -v_linewidth-u_antialias;\\n}\\n#endif\\n\\n#if defined(APPEND_CROSS) || defined(APPEND_X) || defined(USE_ASTERISK) || defined(USE_CROSS) || defined(USE_X)\\nfloat one_cross(in vec2 p, in int line_cap, in float len)\\n{\\n p = abs(p);\\n p = (p.y > p.x) ? p.yx : p.xy;\\n float dist = p.y;\\n float end_dist = end_cap_distance(p, vec2(len, 0.0), vec2(1.0, 0.0), line_cap);\\n return max(dist, end_dist);\\n}\\n#endif\\n\\n#ifdef APPEND_CROSS_2\\nfloat one_cross_2(in vec2 p, in int line_cap, in vec2 lengths)\\n{\\n // Cross with different length in x and y directions.\\n p = abs(p);\\n bool switch_xy = (p.y > p.x);\\n p = switch_xy ? p.yx : p.xy;\\n float len = switch_xy ? lengths.y : lengths.x;\\n float dist = p.y;\\n float end_dist = end_cap_distance(p, vec2(len, 0.0), vec2(1.0, 0.0), line_cap);\\n return max(dist, end_dist);\\n}\\n#endif\\n\\n#if defined(APPEND_Y) || defined(USE_Y)\\nfloat one_y(in vec2 p, in int line_cap, in float len)\\n{\\n p = vec2(abs(p.x), -p.y);\\n\\n // End point of line to right is (1/2, 1/3)*len*SQRT3.\\n // Unit vector along line is (1/2, 1/3)*k where k = 6/SQRT13.\\n const float k = 6.0/sqrt(13.0);\\n vec2 unit_along = vec2(0.5*k, k/3.0);\\n vec2 end_point = vec2(0.5*len*SQRT3, len*SQRT3/3.0);\\n float dist = max(abs(dot(p, vec2(-unit_along.y, unit_along.x))),\\n end_cap_distance(p, end_point, unit_along, line_cap));\\n\\n if (p.y < 0.0) {\\n // Vertical line.\\n float vert_dist = max(p.x,\\n end_cap_distance(p, vec2(0.0, -len), vec2(0.0, -1.0), line_cap));\\n dist = min(dist, vert_dist);\\n }\\n return dist;\\n}\\n#endif\\n\\n// One marker_distance function per marker type.\\n// Distance is zero on edge of marker, +ve outside and -ve inside.\\n\\n#ifdef USE_ASTERISK\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n vec2 p_diag = vec2((p.x + p.y)/SQRT2, (p.x - p.y)/SQRT2);\\n float len = 0.5*v_size.x;\\n return min(one_cross(p, line_cap, len), // cross\\n one_cross(p_diag, line_cap, len)); // x\\n}\\n#endif\\n\\n#if defined(USE_CIRCLE) || defined(USE_CIRCLE_CROSS) || defined(USE_CIRCLE_DOT) || defined(USE_CIRCLE_X) || defined(USE_CIRCLE_Y)\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n return length(p) - 0.5*v_size.x;\\n}\\n#endif\\n\\n#ifdef USE_CROSS\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n return one_cross(p, line_cap, 0.5*v_size.x);\\n}\\n#endif\\n\\n#ifdef USE_DASH\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n p = abs(p);\\n float dist = p.y;\\n float end_dist = end_cap_distance(p, vec2(0.5*v_size.x, 0.0), vec2(1.0, 0.0), line_cap);\\n return max(dist, end_dist);\\n}\\n#endif\\n\\n#if defined(USE_DIAMOND) || defined(USE_DIAMOND_CROSS) || defined(USE_DIAMOND_DOT)\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n // Only need to consider +ve quadrant, the 2 end points are (2r/3, 0) and (0, r)\\n // where r = radius = v_size.x/2.\\n // Line has outward-facing unit normal vec2(1, 2/3)/k where k = SQRT13/3\\n // hence vec2(3, 2)/SQRT13, and distance from origin of 2r/(3k) = 2r/SQRT13.\\n p = abs(p);\\n float r = 0.5*v_size.x;\\n const float SQRT13 = sqrt(13.0);\\n float dist = dot(p, vec2(3.0, 2.0))/SQRT13 - 2.0*r/SQRT13;\\n\\n if (line_join != miter_join) {\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(0.0, r), vec2(0.0, 1.0), v_linewidth/SQRT13, line_join));\\n\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(r*2.0/3.0, 0.0), vec2(1.0, 0.0), v_linewidth*(1.5/SQRT13), line_join));\\n }\\n\\n return dist;\\n}\\n#endif\\n\\n#ifdef USE_DOT\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Dot is always appended.\\n return v_linewidth+u_antialias;\\n}\\n#endif\\n\\n#if defined(USE_HEX) || defined(USE_HEX_DOT)\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // A regular hexagon has v_size.x == v.size_y = r where r is the length of\\n // each of the 3 sides of the 6 equilateral triangles that comprise the hex.\\n // Only consider +ve quadrant, the 3 corners are at (0, h), (rx/2, h), (rx, 0)\\n // where rx = 0.5*v_size.x, ry = 0.5*v_size.y and h = ry*SQRT3/2.\\n // Sloping line has outward normal vec2(h, rx/2). Length of this is\\n // len = sqrt(h**2 + rx**2/4) to give unit normal (h, rx/2)/len and distance\\n // from origin of this line is rx*h/len.\\n p = abs(p);\\n float rx = v_size.x/2.0;\\n float h = v_size.y*(SQRT3/4.0);\\n float len_normal = sqrt(h*h + 0.25*rx*rx);\\n vec2 unit_normal = vec2(h, 0.5*rx) / len_normal;\\n float dist = max(dot(p, unit_normal) - rx*h/len_normal, // Distance from sloping line.\\n p.y - h); // Distance from horizontal line.\\n\\n if (line_join != miter_join) {\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(rx, 0.0), vec2(1.0, 0.0), 0.5*v_linewidth*unit_normal.x, line_join));\\n\\n unit_normal = normalize(unit_normal + vec2(0.0, 1.0)); // At (rx/2, h) corner.\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(0.5*rx, h), unit_normal, 0.5*v_linewidth*unit_normal.y, line_join));\\n }\\n return dist;\\n}\\n#endif\\n\\n#ifdef USE_PLUS\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n // Only need to consider one octant, the +ve quadrant with x >= y.\\n p = abs(p);\\n p = (p.y > p.x) ? p.yx : p.xy;\\n\\n // 3 corners are (r, 0), (r, 3r/8) and (3r/8, 3r/8).\\n float r = 0.5*v_size.x;\\n p = p - vec2(r, 0.375*r); // Distance with respect to outside corner\\n float dist = max(p.x, p.y);\\n\\n if (line_join != miter_join) {\\n // Outside corner\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(0.0, 0.0), vec2(1.0/SQRT2, 1.0/SQRT2), v_linewidth/(2.0*SQRT2), line_join));\\n\\n // Inside corner\\n dist = min(dist, -line_join_distance_no_miter(\\n p, vec2(-5.0*r/8.0, 0.0), vec2(-1.0/SQRT2, -1.0/SQRT2), v_linewidth/(2.0*SQRT2), line_join));\\n }\\n\\n return dist;\\n}\\n#endif\\n\\n#if defined(USE_RECT)\\n// From https://www.shadertoy.com/view/4llXD7 (MIT licensed)\\nfloat rounded_box(in vec2 p, in vec2 size, in vec4 r)\\n{\\n float width = size.x;\\n float height = size.y;\\n\\n float top_left = r.x;\\n float top_right = r.y;\\n float bottom_right = r.z;\\n float bottom_left = r.w;\\n\\n float top = top_left + top_right;\\n float right = top_right + bottom_right;\\n float bottom = bottom_right + bottom_left;\\n float left = top_left + bottom_left;\\n\\n float top_scale = top == 0.0 ? 1.0 : width / top;\\n float right_scale = right == 0.0 ? 1.0 : height / right;\\n float bottom_scale = bottom == 0.0 ? 1.0 : width / bottom;\\n float left_scale = left == 0.0 ? 1.0 : height / left;\\n\\n float scale = min(min(min(top_scale, right_scale), bottom_scale), left_scale);\\n if (scale < 1.0) {\\n r *= scale;\\n }\\n\\n // tl r.x x=-1 y=-1\\n // tr r.y x=+1 y=-1\\n // br r.z x=+1 y=+1\\n // bl r.w x=-1 y=+1\\n vec2 rh = p.x > 0.0 ? r.yz : r.xw;\\n float rq = p.y > 0.0 ? rh.y : rh.x;\\n\\n // special case for corner miter joins\\n vec2 half_size = size/2.0;\\n if (rq == 0.0) {\\n vec2 q = abs(p) - half_size;\\n return max(q.x, q.y);\\n } else {\\n vec2 q = abs(p) - half_size + rq;\\n return min(max(q.x, q.y), 0.0) + length(max(q, 0.0)) - rq;\\n }\\n}\\n\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n float dist = rounded_box(p, v_size, v_border_radius);\\n\\n if (line_join != miter_join) {\\n vec2 p2 = abs(p) - v_size/2.0; // Offset from corner\\n dist = max(dist, line_join_distance_no_miter(\\n p2, vec2(0.0, 0.0), vec2(1.0/SQRT2, 1.0/SQRT2), v_linewidth/(2.0*SQRT2), line_join));\\n }\\n\\n return dist;\\n}\\n#endif\\n\\n#if defined(USE_SQUARE) || defined(USE_SQUARE_CROSS) || defined(USE_SQUARE_DOT) || defined(USE_SQUARE_X)\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n vec2 p2 = abs(p) - v_size/2.0; // Offset from corner\\n float dist = max(p2.x, p2.y);\\n\\n if (line_join != miter_join) {\\n dist = max(dist, line_join_distance_no_miter(\\n p2, vec2(0.0, 0.0), vec2(1.0/SQRT2, 1.0/SQRT2), v_linewidth/(2.0*SQRT2), line_join));\\n }\\n\\n return dist;\\n}\\n#endif\\n\\n#ifdef USE_SQUARE_PIN\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n p = abs(p);\\n p = (p.y > p.x) ? p.yx : p.xy;\\n // p is in octant between y=0 and y=x.\\n // Quadratic bezier curve passes through (r, r), (11r/16, 0) and (r, -r).\\n // Circular arc that passes through the same points has center at\\n // x = r + 231r/160 = 2.44275r and y = 0 and hence radius is\\n // x - 11r/16 = 1.75626 precisely.\\n float r = 0.5*v_size.x;\\n float center_x = r*2.44375;\\n float radius = r*1.75626;\\n float dist = radius - distance(p, vec2(center_x, 0.0));\\n\\n // Magic number is 0.5*sin(atan(8/5) - pi/4)\\n dist = max(dist, line_join_distance_incl_miter(\\n p, vec2(r, r), vec2(1.0/SQRT2, 1.0/SQRT2), v_linewidth*0.1124297533493792, line_join,\\n vec2(8.0/sqrt(89.0), -5.0/sqrt(89.0))));\\n\\n return dist;\\n}\\n#endif\\n\\n#if defined(USE_STAR) || defined(USE_STAR_DOT)\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n const float SQRT5 = sqrt(5.0);\\n const float COS72 = 0.25*(SQRT5 - 1.0);\\n const float SIN72 = sqrt((5.0+SQRT5) / 8.0);\\n\\n float angle = atan(p.x, p.y); // In range -pi to +pi clockwise from +y direction.\\n angle = mod(angle, 0.4*PI) - 0.2*PI; // In range -pi/5 to +pi/5 clockwise from +y direction.\\n p = length(p)*vec2(cos(angle), abs(sin(angle))); // (x,y) in pi/10 (36 degree) sector.\\n\\n // 2 corners are at (r, 0) and (r-a*SIN72, a*COS72) where a = r sqrt(5-2*sqrt(5)).\\n // Line has outward-facing unit normal vec2(COS72, SIN72) and distance from\\n // origin of dot(vec2(r, 0), vec2(COS72, SIN72)) = r*COS72\\n float r = 0.5*v_size.x;\\n float a = r*sqrt(5.0 - 2.0*SQRT5);\\n float dist = dot(p, vec2(COS72, SIN72)) - r*COS72;\\n\\n if (line_join != miter_join) {\\n // Outside corner\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(r, 0.0), vec2(1.0, 0.0), v_linewidth*(0.5*COS72), line_join));\\n\\n // Inside corner\\n const float COS36 = sqrt(0.5 + COS72/2.0);\\n const float SIN36 = sqrt(0.5 - COS72/2.0);\\n dist = min(dist, -line_join_distance_no_miter(\\n p, vec2(r-a*SIN72, a*COS72), vec2(-COS36, -SIN36), v_linewidth*(0.5*COS36), line_join));\\n }\\n\\n return dist;\\n}\\n#endif\\n\\n#if defined(USE_TRIANGLE) || defined(USE_TRIANGLE_DOT) || defined(USE_INVERTED_TRIANGLE)\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n // For normal triangle 3 corners are at (-r, a), (r, a), (0, a-h)=(0, -2h/3)\\n // given r = radius = v_size.x/2, h = SQRT3*r, a = h/3.\\n // Sloping line has outward-facing unit normal vec2(h, -r)/2r = vec2(SQRT3, -1)/2\\n // and distance from origin of a. Horizontal line has outward-facing unit normal\\n // vec2(0, 1) and distance from origin of a.\\n float r = 0.5*v_size.x;\\n float a = r*SQRT3/3.0;\\n\\n // Only need to consider +ve x.\\n#ifdef USE_INVERTED_TRIANGLE\\n p = vec2(abs(p.x), -p.y);\\n#else\\n p = vec2(abs(p.x), p.y);\\n#endif\\n\\n float dist = max(0.5*dot(p, vec2(SQRT3, -1.0)) - a, // Distance from sloping line.\\n p.y - a); // Distance from horizontal line.\\n\\n if (line_join != miter_join) {\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(0.0, -(2.0/SQRT3)*r), vec2(0.0, -1.0), v_linewidth*0.25, line_join));\\n\\n dist = max(dist, line_join_distance_no_miter(\\n p, vec2(r, a), vec2(SQRT3/2.0, 0.5), v_linewidth*0.25, line_join));\\n }\\n\\n return dist;\\n}\\n#endif\\n\\n#ifdef USE_TRIANGLE_PIN\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n float angle = atan(p.x, -p.y); // In range -pi to +pi.\\n angle = mod(angle, PI*2.0/3.0) - PI/3.0; // In range -pi/3 to pi/3.\\n p = length(p)*vec2(cos(angle), abs(sin(angle))); // (x,y) in range 0 to pi/3.\\n // Quadratic bezier curve passes through (a, r), ((a+b)/2, 0) and (a, -r) where\\n // a = r/SQRT3, b = 3a/8 = r SQRT3/8. Circular arc that passes through the same points has\\n // center at (a+x, 0) and radius x+c where c = (a-b)/2 and x = (r**2 - c**2) / (2c).\\n // Ignore r factor until the end so can use const.\\n const float a = 1.0/SQRT3;\\n const float b = SQRT3/8.0;\\n const float c = (a-b)/2.0;\\n const float x = (1.0 - c*c) / (2.0*c);\\n const float center_x = x + a;\\n const float radius = x + c;\\n float r = 0.5*v_size.x;\\n float dist = r*radius - distance(p, vec2(r*center_x, 0.0));\\n\\n // Magic number is 0.5*sin(atan(8*sqrt(3)/5) - pi/3)\\n dist = max(dist, line_join_distance_incl_miter(\\n p, vec2(a*r, r), vec2(0.5, 0.5*SQRT3), v_linewidth*0.0881844526878324, line_join,\\n vec2(8.0*SQRT3, -5.0)/sqrt(217.0)));\\n\\n return dist;\\n}\\n#endif\\n\\n#ifdef USE_X\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n p = vec2((p.x + p.y)/SQRT2, (p.x - p.y)/SQRT2);\\n return one_cross(p, line_cap, 0.5*v_size.x);\\n}\\n#endif\\n\\n#ifdef USE_Y\\nfloat marker_distance(in vec2 p, in int line_cap, in int line_join)\\n{\\n // Assuming v_size.x == v.size_y\\n return one_y(p, line_cap, 0.5*v_size.x);\\n}\\n#endif\\n\\n// Convert distance from edge of marker to fraction in range 0 to 1, depending\\n// on antialiasing width.\\nfloat distance_to_fraction(in float dist)\\n{\\n return 1.0 - smoothstep(-0.5*u_antialias, 0.5*u_antialias, dist);\\n}\\n\\n// Return fraction from 0 (no fill color) to 1 (full fill color).\\nfloat fill_fraction(in float dist)\\n{\\n return distance_to_fraction(dist);\\n}\\n\\n// Return fraction in range 0 (no line color) to 1 (full line color).\\nfloat line_fraction(in float dist)\\n{\\n return distance_to_fraction(abs(dist) - 0.5*v_linewidth);\\n}\\n\\n// Return fraction (in range 0 to 1) of a color, with premultiplied alpha.\\nvec4 fractional_color(in vec4 color, in float fraction)\\n{\\n color.a *= fraction;\\n color.rgb *= color.a;\\n return color;\\n}\\n\\n// Blend colors that have premultiplied alpha.\\nvec4 blend_colors(in vec4 src, in vec4 dest)\\n{\\n return (1.0 - src.a)*dest + src;\\n}\\n\\n#ifdef APPEND_DOT\\nfloat dot_fraction(in vec2 p)\\n{\\n // Assuming v_size.x == v_size.y\\n float radius = 0.125*v_size.x;\\n float dot_distance = max(length(p) - radius, -0.5*u_antialias);\\n return fill_fraction(dot_distance);\\n}\\n#endif\\n\\n#ifdef HATCH\\n// Wrap coordinate(s) by removing integer part to give distance from center of\\n// repeat, in the range -0.5 to +0.5.\\nfloat wrap(in float x)\\n{\\n return fract(x) - 0.5;\\n}\\n\\nvec2 wrap(in vec2 xy)\\n{\\n return fract(xy) - 0.5;\\n}\\n\\n// Return fraction from 0 (no hatch color) to 1 (full hatch color).\\nfloat hatch_fraction(in vec2 coords, in int hatch_pattern)\\n{\\n float scale = v_hatch_scale; // Hatch repeat distance.\\n\\n // Coordinates and linewidth/halfwidth are scaled to hatch repeat distance.\\n coords = coords / scale;\\n float halfwidth = 0.5*v_hatch_weight / scale; // Half the hatch linewidth.\\n\\n // Default is to return fraction of zero, i.e. no pattern.\\n float dist = u_antialias;\\n\\n if (hatch_pattern == hatch_dot) {\\n const float dot_radius = 0.25;\\n dist = length(wrap(coords)) - dot_radius;\\n }\\n else if (hatch_pattern == hatch_ring) {\\n const float ring_radius = 0.25;\\n dist = abs(length(wrap(coords)) - ring_radius) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_horizontal_line) {\\n dist = abs(wrap(coords.y)) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_vertical_line) {\\n dist = abs(wrap(coords.x)) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_cross) {\\n dist = min(abs(wrap(coords.x)), abs(wrap(coords.y))) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_horizontal_dash) {\\n // Dashes have square caps.\\n const float halflength = 0.25;\\n dist = max(abs(wrap(coords.y)),\\n abs(wrap(coords.x) + 0.25) - halflength) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_vertical_dash) {\\n const float halflength = 0.25;\\n dist = max(abs(wrap(coords.x)),\\n abs(wrap(coords.y) + 0.25) - halflength) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_spiral) {\\n vec2 wrap2 = wrap(coords);\\n float angle = wrap(atan(wrap2.y, wrap2.x) / (2.0*PI));\\n // Canvas spiral radius increases by scale*pi/15 each rotation.\\n const float dr = PI/15.0;\\n float radius = length(wrap2);\\n // At any angle, spiral lines are equally spaced dr apart.\\n // Find distance to nearest of these lines.\\n float frac = fract((radius - dr*angle) / dr); // 0 to 1.\\n dist = dr*(abs(frac - 0.5));\\n dist = min(dist, radius) - halfwidth; // Consider center point also.\\n }\\n else if (hatch_pattern == hatch_right_diagonal_line) {\\n dist = abs(wrap(2.0*coords.x + coords.y))/sqrt(5.0) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_left_diagonal_line) {\\n dist = abs(wrap(2.0*coords.x - coords.y))/sqrt(5.0) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_diagonal_cross) {\\n coords = vec2(coords.x + coords.y + 0.5, coords.x - coords.y + 0.5);\\n dist = min(abs(wrap(coords.x)), abs(wrap(coords.y))) / SQRT2 - halfwidth;\\n }\\n else if (hatch_pattern == hatch_right_diagonal_dash) {\\n float across = coords.x + coords.y + 0.5;\\n dist = abs(wrap(across)) / SQRT2; // Distance to nearest solid line.\\n\\n across = floor(across); // Offset for dash.\\n float along = wrap(0.5*(coords.x - coords.y + across));\\n const float halflength = 0.25;\\n along = abs(along) - halflength; // Distance along line.\\n\\n dist = max(dist, along) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_left_diagonal_dash) {\\n float across = coords.x - coords.y + 0.5;\\n dist = abs(wrap(across)) / SQRT2; // Distance to nearest solid line.\\n\\n across = floor(across); // Offset for dash.\\n float along = wrap(0.5*(coords.x + coords.y + across));\\n const float halflength = 0.25;\\n along = abs(along) - halflength; // Distance along line.\\n\\n dist = max(dist, along) - halfwidth;\\n }\\n else if (hatch_pattern == hatch_horizontal_wave) {\\n float wrapx = wrap(coords.x);\\n float wrapy = wrap(coords.y - 0.25 + abs(wrapx));\\n dist = abs(wrapy) / SQRT2 - halfwidth;\\n }\\n else if (hatch_pattern == hatch_vertical_wave) {\\n float wrapy = wrap(coords.y);\\n float wrapx = wrap(coords.x - 0.25 + abs(wrapy));\\n dist = abs(wrapx) / SQRT2 - halfwidth;\\n }\\n else if (hatch_pattern == hatch_criss_cross) {\\n float plus = min(abs(wrap(coords.x)), abs(wrap(coords.y)));\\n\\n coords = vec2(coords.x + coords.y + 0.5, coords.x - coords.y + 0.5);\\n float X = min(abs(wrap(coords.x)), abs(wrap(coords.y))) / SQRT2;\\n\\n dist = min(plus, X) - halfwidth;\\n }\\n\\n return distance_to_fraction(dist*scale);\\n}\\n#endif\\n\\nvoid main()\\n{\\n int line_cap = int(v_line_cap + 0.5);\\n int line_join = int(v_line_join + 0.5);\\n#ifdef HATCH\\n int hatch_pattern = int(v_hatch_pattern + 0.5);\\n#endif\\n\\n float dist = marker_distance(v_coords, line_cap, line_join);\\n\\n#ifdef LINE_ONLY\\n vec4 color = vec4(0.0, 0.0, 0.0, 0.0);\\n#else\\n float fill_frac = fill_fraction(dist);\\n vec4 color = fractional_color(v_fill_color, fill_frac);\\n#endif\\n\\n#if defined(HATCH) && !defined(LINE_ONLY)\\n if (hatch_pattern > 0 && fill_frac > 0.0) {\\n float hatch_frac = hatch_fraction(v_hatch_coords, hatch_pattern);\\n vec4 hatch_color = fractional_color(v_hatch_color, hatch_frac*fill_frac);\\n color = blend_colors(hatch_color, color);\\n }\\n#endif\\n\\n float line_frac = line_fraction(dist);\\n\\n#ifdef APPEND_DOT\\n line_frac = max(line_frac, dot_fraction(v_coords));\\n#endif\\n#ifdef APPEND_CROSS\\n line_frac = max(line_frac, line_fraction(one_cross(v_coords, line_cap, 0.5*v_size.x)));\\n#endif\\n#ifdef APPEND_CROSS_2\\n vec2 lengths = vec2(v_size.x/3.0, v_size.x/2.0);\\n line_frac = max(line_frac, line_fraction(one_cross_2(v_coords, line_cap, lengths)));\\n#endif\\n#ifdef APPEND_X\\n vec2 p = vec2((v_coords.x + v_coords.y)/SQRT2, (v_coords.x - v_coords.y)/SQRT2);\\n line_frac = max(line_frac, line_fraction(one_cross(p, line_cap, APPEND_X_LEN)));\\n#endif\\n#ifdef APPEND_Y\\n line_frac = max(line_frac, line_fraction(one_y(v_coords, line_cap, 0.5*v_size.x)));\\n#endif\\n\\n if (line_frac > 0.0) {\\n vec4 line_color = fractional_color(v_line_color, line_frac);\\n color = blend_colors(line_color, color);\\n }\\n\\n gl_FragColor = color;\\n}\\n\"},\n", - " 513: function _(s,i,t,_,e){_();const h=s(514),a=s(515),l=s(516),n=s(21),o=s(76);class r extends h.BaseGLGlyph{constructor(s,i){super(s,i),this.glyph=i,this._antialias=1.5,this._miter_limit=10}_draw_impl(s,i,t){this.visuals_changed&&(this._set_visuals(),this.visuals_changed=!1),t.data_changed&&(t._set_data(),t.data_changed=!1);const _=this._get_visuals().line,e=l.cap_lookup[_.line_cap.value],h=l.join_lookup[_.line_join.value],a=t._points,n=a.length/2-3,o=this._get_show_buffer(s,t),r={scissor:this.regl_wrapper.scissor,viewport:this.regl_wrapper.viewport,canvas_size:[i.width,i.height],pixel_ratio:i.pixel_ratio,line_color:this._color,linewidth:this._linewidth,antialias:this._antialias,miter_limit:this._miter_limit,points:a,show:o,nsegments:n,line_join:h,line_cap:e};if(this._is_dashed()){const s=Object.assign(Object.assign({},r),{length_so_far:this._length_so_far,dash_tex:this._dash_tex,dash_tex_info:this._dash_tex_info,dash_scale:this._dash_scale,dash_offset:this._dash_offset});this.regl_wrapper.dashed_line()(s)}else this.regl_wrapper.solid_line()(r)}_is_dashed(){return null!=this._line_dash&&this._line_dash.length>0}_set_data(){const s=this._set_data_points(),i=s.length/2-2;null==this._show&&(this._show=new a.Uint8Buffer(this.regl_wrapper));const t=this._show.get_sized_array(i+1);let _=isFinite(s[2])&&isFinite(s[3]);for(let e=1;es/255)),this._linewidth=s.line_width.value,this._linewidth<1&&(this._color[3]*=this._linewidth,this._linewidth=1),this._line_dash=(0,o.resolve_line_dash)(s.line_dash.value),this._is_dashed()&&([this._dash_tex_info,this._dash_tex,this._dash_scale]=this.regl_wrapper.get_dash(this._line_dash),this._dash_offset=s.line_dash_offset.value)}}t.BaseLineGL=r,r.__name__=\"BaseLineGL\"},\n", - " 514: function _(e,t,s,i,h){i();class a{constructor(e,t){this.nvertices=0,this.size_changed=!1,this.data_changed=!1,this.visuals_changed=!1,this.glyph=t,this.regl_wrapper=e}set_data_changed(){const{data_size:e}=this.glyph;e!=this.nvertices&&(this.nvertices=e,this.size_changed=!0),this.data_changed=!0}set_visuals_changed(){this.visuals_changed=!0}render(e,t,s){if(0==t.length)return!0;const{width:i,height:h}=this.glyph.renderer.plot_view.canvas_view.webgl.canvas,a={pixel_ratio:this.glyph.renderer.plot_view.canvas_view.pixel_ratio,width:i,height:h};return this.draw(t,s,a),!0}}s.BaseGLGlyph=a,a.__name__=\"BaseGLGlyph\"},\n", - " 515: function _(r,t,a,e,s){e();const i=r(516),_=r(21);class n{constructor(r){this.regl_wrapper=r,this.is_scalar=!0}get_sized_array(r){return null!=this.array&&this.array.length==r||(this.array=this.new_array(r)),this.array}is_normalized(){return!1}get length(){return null!=this.array?this.array.length:0}set_from_array(r){const t=r.length,a=this.get_sized_array(t);for(let e=0;e0&&(l[o]=n[o]);for(let e=1;e2&&t[0]==t[e-1]&&s[0]==s[e-1]&&isFinite(t[0])&&isFinite(s[0]),null==this._points&&(this._points=new _.Float32Buffer(this.regl_wrapper));const i=this._points.get_sized_array(2*(e+2));for(let h=1;h1||s.length<_){this._show_all=!1,n.fill(0),r=0;for(const e of s)1!=h&&i._marker_types.get(e)!=t||(n[e]=255,r++)}else this._show_all&&a==_||(this._show_all=!0,n.fill(255));this._show.update(),0!=r&&this._draw_one_marker_type(t,e,i)}}_get_visuals(){return this.glyph.visuals}_set_data(){const s=this.nvertices;null==this._centers&&(this._centers=new r.Float32Buffer(this.regl_wrapper),this._widths=new r.Float32Buffer(this.regl_wrapper),this._heights=this._widths,this._angles=new r.Float32Buffer(this.regl_wrapper));const t=this._centers.get_sized_array(2*s);for(let e=0;e2&&e[0]==e[i-1]&&s[0]==s[i-1]&&isFinite(e[0])&&isFinite(s[0]);const a=\"center\"==t?2*i:2*i-1;null==this._points&&(this._points=new r.Float32Buffer(this.regl_wrapper));const n=this._points.get_sized_array(2*(a+2));let l=isFinite(e[0]+s[0]),h=2;\"center\"==t&&(n[h++]=l?e[0]:NaN,n[h++]=s[0]);for(let a=0;athis.render()))}remove(){null!=this.icon_view&&this.icon_view.remove(),super.remove()}stylesheets(){return[...super.stylesheets(),d.default]}_render_button(...t){return(0,c.button)({type:\"button\",disabled:this.model.disabled,class:[h.btn,h[`btn_${this.model.button_type}`]]},...t)}render(){if(super.render(),this.button_el=this._render_button(this.model.label),this.button_el.addEventListener(\"click\",(()=>this.click())),null!=this.icon_view){const t=\"\"!=this.model.label?(0,c.nbsp)():(0,c.text)(\"\");(0,c.prepend)(this.button_el,this.icon_view.el,t),this.icon_view.render()}this.group_el=(0,c.div)({class:h.btn_group},this.button_el),this.shadow_el.appendChild(this.group_el)}click(){}}i.AbstractButtonView=b,b.__name__=\"AbstractButtonView\";class p extends _.Control{constructor(t){super(t)}}i.AbstractButton=p,l=p,p.__name__=\"AbstractButton\",l.define((({String:t,Ref:e,Nullable:i})=>({label:[t,\"Button\"],icon:[i(e(a.Icon)),null],button_type:[r.ButtonType,\"default\"]})))},\n", - " 545: function _(t,n,o,s,e){s();const c=t(640),i=t(56);class l extends c.WidgetView{connect_signals(){super.connect_signals(),this.connect(this.disabled,(t=>{for(const n of this.controls())(0,i.toggle_attribute)(n,\"disabled\",t)}))}}o.ControlView=l,l.__name__=\"ControlView\";class _ extends c.Widget{constructor(t){super(t)}}o.Control=_,_.__name__=\"Control\"},\n", - " 640: function _(t,e,i,s,r){s();const a=t(360),n=t(154);class d extends a.LayoutDOMView{update_style(){super.update_style(),this.style.append(\":host\",{margin:\"5px\"})}get child_models(){return[]}get provider(){return n.default_provider}async lazy_initialize(){await super.lazy_initialize(),\"not_started\"==this.provider.status&&await this.provider.fetch()}_after_layout(){super._after_layout(),\"loading\"==this.provider.status&&(this._has_finished=!1)}process_tex(t){if(null==this.provider.MathJax)return t;const e=this.provider.MathJax.find_tex(t),i=[];let s=0;for(const r of e)i.push(t.slice(s,r.start.n)),i.push(this.provider.MathJax.tex2svg(r.math,{display:r.display}).outerHTML),s=r.end.n;return s0}}i.WidgetView=d,d.__name__=\"WidgetView\";class o extends a.LayoutDOM{constructor(t){super(t)}}i.Widget=o,o.__name__=\"Widget\"},\n", - " 547: function _(b,o,r,e,t){e(),r.btn=\"bk-btn\",r.active=\"bk-active\",r.btn_default=\"bk-btn-default\",r.btn_primary=\"bk-btn-primary\",r.btn_success=\"bk-btn-success\",r.btn_warning=\"bk-btn-warning\",r.btn_danger=\"bk-btn-danger\",r.btn_light=\"bk-btn-light\",r.btn_group=\"bk-btn-group\",r.vertical=\"bk-vertical\",r.horizontal=\"bk-horizontal\",r.dropdown_toggle=\"bk-dropdown-toggle\",r.default=\".bk-btn,::file-selector-button{height:100%;display:inline-block;text-align:center;vertical-align:middle;white-space:nowrap;cursor:pointer;padding:var(--padding-vertical) var(--padding-horizontal);font-size:var(--font-size);border:1px solid transparent;border-radius:var(--border-radius);outline:0;outline-offset:-5px;user-select:none;-webkit-user-select:none;}.bk-btn:hover,::file-selector-button:hover,.bk-btn:focus,::file-selector-button:focus{text-decoration:none;}.bk-btn:active,::file-selector-button:active,.bk-active.bk-btn,.bk-active::file-selector-button{background-image:none;box-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);}.bk-btn[disabled]{cursor:not-allowed;pointer-events:none;opacity:0.65;box-shadow:none;}::file-selector-button{color:#333;background-color:#fff;border-color:#ccc;}::file-selector-button:hover{background-color:#f5f5f5;border-color:#b8b8b8;}.bk-active::file-selector-button{background-color:#ebebeb;border-color:#adadad;}::file-selector-button[disabled],::file-selector-button[disabled]:hover,::file-selector-button[disabled]:focus,::file-selector-button[disabled]:active,.bk-active::file-selector-button[disabled]{background-color:#e6e6e6;border-color:#ccc;}::file-selector-button:focus,::file-selector-button:active{outline:1px dotted #ccc;}.bk-btn-default{color:#333;background-color:#fff;border-color:#ccc;}.bk-btn-default:hover{background-color:#f5f5f5;border-color:#b8b8b8;}.bk-active.bk-btn-default{background-color:#ebebeb;border-color:#adadad;}.bk-btn-default[disabled],.bk-btn-default[disabled]:hover,.bk-btn-default[disabled]:focus,.bk-btn-default[disabled]:active,.bk-active.bk-btn-default[disabled]{background-color:#e6e6e6;border-color:#ccc;}.bk-btn-default:focus,.bk-btn-default:active{outline:1px dotted #ccc;}.bk-btn-primary{color:#fff;background-color:#428bca;border-color:#357ebd;}.bk-btn-primary:hover{background-color:#3681c1;border-color:#2c699e;}.bk-active.bk-btn-primary{background-color:#3276b1;border-color:#285e8e;}.bk-btn-primary[disabled],.bk-btn-primary[disabled]:hover,.bk-btn-primary[disabled]:focus,.bk-btn-primary[disabled]:active,.bk-active.bk-btn-primary[disabled]{background-color:#506f89;border-color:#357ebd;}.bk-btn-primary:focus,.bk-btn-primary:active{outline:1px dotted #ccc;}.bk-btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c;}.bk-btn-success:hover{background-color:#4eb24e;border-color:#409240;}.bk-active.bk-btn-success{background-color:#47a447;border-color:#398439;}.bk-btn-success[disabled],.bk-btn-success[disabled]:hover,.bk-btn-success[disabled]:focus,.bk-btn-success[disabled]:active,.bk-active.bk-btn-success[disabled]{background-color:#667b66;border-color:#4cae4c;}.bk-btn-success:focus,.bk-btn-success:active{outline:1px dotted #ccc;}.bk-btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236;}.bk-btn-warning:hover{background-color:#eea43b;border-color:#e89014;}.bk-active.bk-btn-warning{background-color:#ed9c28;border-color:#d58512;}.bk-btn-warning[disabled],.bk-btn-warning[disabled]:hover,.bk-btn-warning[disabled]:focus,.bk-btn-warning[disabled]:active,.bk-active.bk-btn-warning[disabled]{background-color:#c89143;border-color:#eea236;}.bk-btn-warning:focus,.bk-btn-warning:active{outline:1px dotted #ccc;}.bk-btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a;}.bk-btn-danger:hover{background-color:#d5433e;border-color:#bd2d29;}.bk-active.bk-btn-danger{background-color:#d2322d;border-color:#ac2925;}.bk-btn-danger[disabled],.bk-btn-danger[disabled]:hover,.bk-btn-danger[disabled]:focus,.bk-btn-danger[disabled]:active,.bk-active.bk-btn-danger[disabled]{background-color:#a55350;border-color:#d43f3a;}.bk-btn-danger:focus,.bk-btn-danger:active{outline:1px dotted #ccc;}.bk-btn-light{color:#333;background-color:#fff;border-color:#ccc;border-color:transparent;}.bk-btn-light:hover{background-color:#f5f5f5;border-color:#b8b8b8;}.bk-active.bk-btn-light{background-color:#ebebeb;border-color:#adadad;}.bk-btn-light[disabled],.bk-btn-light[disabled]:hover,.bk-btn-light[disabled]:focus,.bk-btn-light[disabled]:active,.bk-active.bk-btn-light[disabled]{background-color:#e6e6e6;border-color:#ccc;}.bk-btn-light:focus,.bk-btn-light:active{outline:1px dotted #ccc;}.bk-btn-group{height:100%;display:flex;flex-wrap:nowrap;align-items:center;}.bk-btn-group:not(.bk-vertical),.bk-btn-group.bk-horizontal{flex-direction:row;}.bk-btn-group.bk-vertical{flex-direction:column;}.bk-btn-group > .bk-btn{flex-grow:1;}.bk-btn-group:not(.bk-vertical) > .bk-btn + .bk-btn{margin-left:-1px;}.bk-btn-group.bk-vertical > .bk-btn + .bk-btn{margin-top:-1px;}.bk-btn-group:not(.bk-vertical) > .bk-btn:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0;}.bk-btn-group.bk-vertical > .bk-btn:first-child:not(:last-child){border-bottom-left-radius:0;border-bottom-right-radius:0;}.bk-btn-group:not(.bk-vertical) > .bk-btn:not(:first-child):last-child{border-bottom-left-radius:0;border-top-left-radius:0;}.bk-btn-group.bk-vertical > .bk-btn:not(:first-child):last-child{border-top-left-radius:0;border-top-right-radius:0;}.bk-btn-group > .bk-btn:not(:first-child):not(:last-child){border-radius:0;}.bk-btn-group.bk-vertical > .bk-btn{width:100%;}.bk-btn-group .bk-dropdown-toggle{flex:0 0 0;padding:var(--padding-vertical) calc(var(--padding-horizontal)/2);}\"},\n", - " 548: function _(e,t,n,i,s){var h;i();const o=e(1),_=e(549),u=e(56),r=e(32),l=e(11),a=o.__importStar(e(553)),c=a;class d extends _.TextInputView{constructor(){super(...arguments),this._open=!1,this._last_value=\"\",this._hover_index=0}stylesheets(){return[...super.stylesheets(),a.default]}render(){super.render(),this.input_el.addEventListener(\"keydown\",(e=>this._keydown(e))),this.input_el.addEventListener(\"keyup\",(e=>this._keyup(e))),this.input_el.addEventListener(\"focusin\",(()=>this._toggle_menu())),this.menu=(0,u.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.shadow_el.appendChild(this.menu),(0,u.undisplay)(this.menu)}change_input(){this._open&&this.menu.children.length>0?(this.model.value=this.menu.children[this._hover_index].textContent,this.input_el.focus(),this._hide_menu()):this.model.restrict||super.change_input()}_update_completions(e){var t;(0,u.empty)(this.menu);const{max_completions:n}=this.model,i=null!=n?(0,r.take)(e,n):e;for(const e of i){const t=(0,u.div)(e);this.menu.append(t)}null===(t=this.menu.firstElementChild)||void 0===t||t.classList.add(c.active)}_toggle_menu(){const{value:e}=this.input_el;if(e.length{const{case_sensitive:e}=this.model;return e?e=>e:e=>e.toLowerCase()})(),n=[];for(const i of this.model.completions)t(i).startsWith(t(e))&&n.push(i);this._update_completions(n),0==n.length?this._hide_menu():this._show_menu()}_show_menu(){if(!this._open){this._open=!0,this._hover_index=0,this._last_value=this.model.value,(0,u.display)(this.menu);const e=t=>{t.composedPath().includes(this.el)||(document.removeEventListener(\"click\",e),this._hide_menu())};document.addEventListener(\"click\",e)}}_hide_menu(){this._open&&(this._open=!1,(0,u.undisplay)(this.menu))}_menu_click(e){e.target!=e.currentTarget&&e.target instanceof Element&&(this.model.value=e.target.textContent,this.input_el.focus(),this._hide_menu())}_menu_hover(e){if(e.target!=e.currentTarget&&e.target instanceof Element)for(let t=0;t0&&(this.menu.children[this._hover_index].classList.remove(c.active),this._hover_index=(0,l.clamp)(e,0,t-1),this.menu.children[this._hover_index].classList.add(c.active))}_keydown(e){}_keyup(e){switch(super._keyup(e),e.key){case\"Enter\":this.change_input();break;case\"Escape\":this._hide_menu();break;case\"ArrowUp\":this._bump_hover(this._hover_index-1);break;case\"ArrowDown\":this._bump_hover(this._hover_index+1);break;default:this._toggle_menu()}}}n.AutocompleteInputView=d,d.__name__=\"AutocompleteInputView\";class m extends _.TextInput{constructor(e){super(e)}}n.AutocompleteInput=m,h=m,m.__name__=\"AutocompleteInput\",h.prototype.default_view=d,h.define((({Boolean:e,Int:t,String:n,Array:i,NonNegative:s,Positive:h,Nullable:o})=>({completions:[i(n),[]],min_characters:[s(t),2],max_completions:[o(h(t)),null],case_sensitive:[e,!0],restrict:[e,!0]})))},\n", - " 549: function _(e,t,n,i,s){var u;i();const l=e(1),p=e(550),r=e(56),_=e(52),a=l.__importStar(e(552));class c extends p.TextLikeInputView{connect_signals(){super.connect_signals();const{prefix:e,suffix:t}=this.model.properties;this.on_change([e,t],(()=>this.render()))}_render_input(){this.input_el=(0,r.input)({type:\"text\",class:a.input});const{prefix:e,suffix:t}=this.model,n=null!=e?(0,r.div)({class:\"bk-input-prefix\"},e):null,i=null!=t?(0,r.div)({class:\"bk-input-suffix\"},t):null;return(0,r.div)({class:\"bk-input-container\"},n,this.input_el,i)}render(){super.render(),this.input_el.addEventListener(\"keyup\",(e=>this._keyup(e)))}_keyup(e){\"Enter\"!=e.key||e.shiftKey||e.ctrlKey||e.altKey||this.model.trigger_event(new _.ValueSubmit(this.input_el.value))}}n.TextInputView=c,c.__name__=\"TextInputView\";class o extends p.TextLikeInput{constructor(e){super(e)}}n.TextInput=o,u=o,o.__name__=\"TextInput\",u.prototype.default_view=c,u.define((({String:e,Nullable:t})=>({prefix:[t(e),null],suffix:[t(e),null]})))},\n", - " 550: function _(e,t,n,i,l){var s;i();const h=e(551);class a extends h.InputWidgetView{connect_signals(){super.connect_signals(),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(){super.render();const e=this._render_input();this.group_el.appendChild(e);const{input_el:t}=this;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()))}change_input(){this.model.value=this.input_el.value,super.change_input()}change_input_value(){this.model.value_input=this.input_el.value,super.change_input()}}n.TextLikeInputView=a,a.__name__=\"TextLikeInputView\";class u extends h.InputWidget{constructor(e){super(e)}}n.TextLikeInput=u,s=u,u.__name__=\"TextLikeInput\",s.define((({Int:e,String:t,Nullable:n})=>({value:[t,\"\"],value_input:[t,\"\"],placeholder:[t,\"\"],max_length:[n(e),null]})))},\n", - " 551: function _(e,t,i,s,l){var n;s();const o=e(1),d=e(545),r=e(448),c=e(12),a=e(8),u=e(59),p=e(56),h=o.__importStar(e(552)),_=h,m=o.__importDefault(e(269));class v extends d.ControlView{constructor(){super(...arguments),this.description=null,this.desc_el=null}*controls(){yield this.input_el}*children(){yield*super.children(),null!=this.description&&(yield this.description)}async lazy_initialize(){await super.lazy_initialize();const{description:e}=this.model;e instanceof r.Tooltip&&(this.description=await(0,u.build_view)(e,{parent:this}))}remove(){var e;null===(e=this.description)||void 0===e||e.remove(),super.remove()}connect_signals(){super.connect_signals(),this.connect(this.model.properties.title.change,(()=>{this.label_el.textContent=this.model.title}))}stylesheets(){return[...super.stylesheets(),h.default,m.default]}render(){super.render();const{title:e,description:t}=this.model;if(null==t)this.desc_el=null;else{const e=(0,p.div)({class:_.icon});if(this.desc_el=(0,p.div)({class:_.description},e),(0,a.isString)(t))this.desc_el.title=t;else{const{description:t}=this;(0,c.assert)(null!=t);const{desc_el:i}=this;t.model.target=i;let s=!1;const l=i=>{t.model.setv({visible:i,closable:s}),e.classList.toggle(_.opaque,i&&s)};this.on_change(t.model.properties.visible,(()=>{const{visible:e}=t.model;e||(s=!1),l(e)})),i.addEventListener(\"mouseenter\",(()=>{l(!0)})),i.addEventListener(\"mouseleave\",(()=>{s||l(!1)})),document.addEventListener(\"mousedown\",(e=>{const n=e.composedPath();n.includes(t.el)||(n.includes(i)?(s=!s,l(s)):(s=!1,l(!1)))})),window.addEventListener(\"blur\",(()=>{s=!1,l(!1)}))}}this.label_el=(0,p.label)({style:{display:0==e.length?\"none\":\"\"}},e,this.desc_el),this.group_el=(0,p.div)({class:_.input_group},this.label_el),this.shadow_el.appendChild(this.group_el)}change_input(){}}i.InputWidgetView=v,v.__name__=\"InputWidgetView\";class g extends d.Control{constructor(e){super(e)}}i.InputWidget=g,n=g,g.__name__=\"InputWidget\",n.define((({String:e,Nullable:t,Or:i,Ref:s})=>({title:[e,\"\"],description:[t(i(e,s(r.Tooltip))),null]})))},\n", - " 552: function _(i,n,t,e,p){e(),t.input=\"bk-input\",t.input_container=\"bk-input-container\",t.input_prefix=\"bk-input-prefix\",t.input_suffix=\"bk-input-suffix\",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.description=\"bk-description\",t.icon=\"bk-icon\",t.opaque=\"bk-opaque\",t.default=':host{--input-min-height:calc(var(--line-height-computed) + 2*var(--padding-vertical) + 2px);}.bk-input{display:inline-block;width:100%;flex-grow:1;min-height:var(--input-min-height);padding:0 var(--padding-horizontal);background-color:#fff;border:1px solid #ccc;border-radius:var(--border-radius);}.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-input::placeholder,.bk-input:-ms-input-placeholder,.bk-input::-moz-placeholder,.bk-input::-webkit-input-placeholder{color:#999;opacity:1;}.bk-input[disabled]{cursor:not-allowed;background-color:#eee;opacity:1;}.bk-input-container{width:100%;height:100%;display:flex;flex-direction:row;flex-wrap:nowrap;}.bk-input-container .bk-input-prefix,.bk-input-container .bk-input-suffix{display:flex;align-items:center;flex:0 1 0;border:1px solid #ccc;border-radius:var(--border-radius);padding:0 var(--padding-horizontal);background-color:#e6e6e6;}.bk-input-container .bk-input-prefix{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;}.bk-input-container .bk-input-suffix{border-left:none;border-top-left-radius:0;border-bottom-left-radius:0;}.bk-input-container .bk-input{flex:1 0 0;}.bk-input-container .bk-input:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0;}.bk-input-container .bk-input:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0;}input[type=file].bk-input{padding-left:0;}input[type=file]::file-selector-button{box-sizing:inherit;font-family:inherit;font-size:inherit;line-height:inherit;}select:not([multiple]).bk-input,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;padding-right:calc(var(--padding-horizontal) + 8px);}option{padding:0;}select[multiple].bk-input,select[size].bk-input,textarea.bk-input{height:auto;}.bk-input-group{width:100%;height:100%;display:inline-flex;flex-wrap:nowrap;align-items:start;flex-direction:column;white-space:nowrap;}.bk-input-group.bk-inline{flex-direction:row;}.bk-input-group.bk-inline > *:not(:first-child){margin-left:5px;}.bk-input-group > .bk-spin-wrapper{display:inherit;width:inherit;height:inherit;position:relative;overflow:hidden;padding:0;vertical-align:middle;}.bk-input-group > .bk-spin-wrapper input{padding-right:20px;}.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-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-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-up{top:0;}.bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-up:before{border-bottom:5px solid black;}.bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-up:disabled:before{border-bottom-color:grey;}.bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-down{bottom:0;}.bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-down:before{border-top:5px solid black;}.bk-input-group > .bk-spin-wrapper > .bk-spin-btn.bk-spin-btn-down:disabled:before{border-top-color:grey;}.bk-description{position:relative;display:inline-block;margin-left:0.25em;vertical-align:middle;margin-top:-2px;cursor:pointer;}.bk-description > .bk-icon{opacity:0.5;width:18px;height:18px;background-color:gray;mask-image:var(--bokeh-icon-help);mask-size:contain;mask-repeat:no-repeat;-webkit-mask-image:var(--bokeh-icon-help);-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;}label:hover > .bk-description > .bk-icon,.bk-icon.bk-opaque{opacity:1;}'},\n", - " 553: function _(e,o,i,b,r){b(),i.menu=\"bk-menu\",i.above=\"bk-above\",i.below=\"bk-below\",i.divider=\"bk-divider\",i.active=\"bk-active\",i.default=\":host{position:relative;}.bk-menu{position:absolute;left:0;width:100%;z-index:100;cursor:pointer;font-size:var(--font-size);background-color:#fff;border:1px solid #ccc;border-radius:var(--border-radius);box-shadow:0 6px 12px rgba(0, 0, 0, 0.175);}.bk-menu.bk-above{bottom:100%;}.bk-menu.bk-below{top:100%;}.bk-menu > .bk-divider{height:1px;margin:calc(var(--line-height-computed)/2 - 1px) 0;overflow:hidden;background-color:#e5e5e5;}.bk-menu > :not(.bk-divider){padding:var(--padding-vertical) var(--padding-horizontal);}.bk-menu > :not(.bk-divider):hover,.bk-menu > :not(.bk-divider).bk-active{background-color:#e6e6e6;}\"},\n", - " 554: function _(t,e,n,o,c){var i;o();const s=t(544),u=t(52);class _ extends s.AbstractButtonView{click(){this.model.trigger_event(new u.ButtonClick),super.click()}}n.ButtonView=_,_.__name__=\"ButtonView\";class r extends s.AbstractButton{constructor(t){super(t)}on_click(t){this.on_event(u.ButtonClick,t)}}n.Button=r,i=r,r.__name__=\"Button\",i.prototype.default_view=_,i.override({label:\"Button\"})},\n", - " 555: function _(t,e,o,a,c){var s;a();const i=t(1),n=t(556),r=i.__importStar(t(547));class u extends n.ToggleButtonGroupView{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)=>{e.classList.toggle(r.active,t.has(o))}))}}o.CheckboxButtonGroupView=u,u.__name__=\"CheckboxButtonGroupView\";class _ extends n.ToggleButtonGroup{constructor(t){super(t)}}o.CheckboxButtonGroup=_,s=_,_.__name__=\"CheckboxButtonGroup\",s.prototype.default_view=u,s.define((({Int:t,Array:e})=>({active:[e(t),[]]})))},\n", - " 556: function _(t,e,n,s,o){var i;s();const r=t(1),l=t(557),a=t(52),_=t(19),d=t(56),u=r.__importStar(t(547)),c=u;class h extends l.OrientedControlView{*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()))}stylesheets(){return[...super.stylesheets(),u.default]}render(){super.render(),this._buttons=this.model.labels.map(((t,e)=>{const n=(0,d.button)({class:[c.btn,c[`btn_${this.model.button_type}`]],disabled:this.model.disabled},t);return n.addEventListener(\"click\",(()=>{this.change_active(e),this.model.trigger_event(new a.ButtonClick)})),n})),this._update_active();const t=\"horizontal\"==this.model.orientation?c.horizontal:c.vertical,e=(0,d.div)({class:[c.btn_group,t]},this._buttons);this.shadow_el.appendChild(e)}}n.ToggleButtonGroupView=h,h.__name__=\"ToggleButtonGroupView\";class p extends l.OrientedControl{constructor(t){super(t)}}n.ToggleButtonGroup=p,i=p,p.__name__=\"ToggleButtonGroup\",i.define((({String:t,Array:e})=>({labels:[e(t),[]],button_type:[_.ButtonType,\"default\"]})))},\n", - " 557: function _(n,e,o,t,r){var i;t();const l=n(545),s=n(19);class _ extends l.ControlView{}o.OrientedControlView=_,_.__name__=\"OrientedControlView\";class a extends l.Control{constructor(n){super(n)}}o.OrientedControl=a,i=a,a.__name__=\"OrientedControl\",i.define((()=>({orientation:[s.Orientation,\"horizontal\"]})))},\n", - " 558: function _(e,t,s,n,i){var c;n();const o=e(1),a=e(559),h=e(56),l=e(10),r=e(32),d=o.__importStar(e(552));class p extends a.ToggleInputGroupView{get active(){return new Set(this.model.active)}connect_signals(){super.connect_signals();const{active:e}=this.model.properties;this.on_change(e,(()=>{const{active:e}=this;for(const[t,s]of(0,r.enumerate)(this._inputs))t.checked=e.has(s)}))}render(){super.render();const e=(0,h.div)({class:[d.input_group,this.model.inline?d.inline:null]});this.shadow_el.appendChild(e);const{active:t,labels:s}=this.model;this._inputs=[];for(let n=0;nthis.change_active(n))),this._inputs.push(i),this.model.disabled&&(i.disabled=!0),(0,l.includes)(t,n)&&(i.checked=!0);const c=(0,h.label)(i,(0,h.span)(s[n]));e.appendChild(c)}}change_active(e){const{active:t}=this;t.has(e)?t.delete(e):t.add(e),this.model.active=[...t].sort()}}s.CheckboxGroupView=p,p.__name__=\"CheckboxGroupView\";class u extends a.ToggleInputGroup{constructor(e){super(e)}}s.CheckboxGroup=u,c=u,u.__name__=\"CheckboxGroup\",c.prototype.default_view=p,c.define((({Int:e,Array:t})=>({active:[t(e),[]]})))},\n", - " 559: function _(e,n,t,s,o){var l;s();const r=e(1),i=e(545),u=r.__importDefault(e(552)),_=r.__importDefault(e(560));class a extends i.ControlView{*controls(){yield*this._inputs}connect_signals(){super.connect_signals();const{labels:e,inline:n}=this.model.properties;this.on_change([e,n],(()=>this.render()))}stylesheets(){return[...super.stylesheets(),u.default,_.default]}}t.ToggleInputGroupView=a,a.__name__=\"ToggleInputGroupView\";class p extends i.Control{constructor(e){super(e)}}t.ToggleInputGroup=p,l=p,p.__name__=\"ToggleInputGroup\",l.define((({Boolean:e,String:n,Array:t})=>({labels:[t(n),[]],inline:[e,!1]})))},\n", - " 560: function _(t,i,p,e,n){e(),p.default='input[type=\"checkbox\"],input[type=\"radio\"]{margin:0;}input[type=\"checkbox\"] + *,input[type=\"radio\"] + *{position:relative;top:-2px;margin-left:3px;}'},\n", - " 561: function _(e,t,s,l,i){var a;l();const _=e(1),c=e(562),h=e(56),o=_.__importDefault(e(560));class n extends c.ToggleInputView{stylesheets(){return[...super.stylesheets(),o.default]}connect_signals(){super.connect_signals();const{label:e}=this.model.properties;this.on_change(e,(()=>this._update_label()))}render(){super.render(),this.checkbox_el=(0,h.input)({type:\"checkbox\"}),this.label_el=(0,h.span)(this.model.label),this.checkbox_el.addEventListener(\"change\",(()=>this._toggle_active())),this._update_active(),this._update_disabled(),this.shadow_el.append(this.checkbox_el,this.label_el)}_update_active(){this.checkbox_el.checked=this.model.active}_update_disabled(){this.checkbox_el.toggleAttribute(\"disabled\",this.model.disabled)}_update_label(){this.label_el.textContent=this.model.label}}s.CheckboxView=n,n.__name__=\"CheckboxView\";class d extends c.ToggleInput{constructor(e){super(e)}}s.Checkbox=d,a=d,d.__name__=\"Checkbox\",a.prototype.default_view=n,a.define((({String:e})=>({label:[e,\"\"]})))},\n", - " 562: function _(e,t,i,s,n){var a;s();const o=e(640);class c extends o.WidgetView{connect_signals(){super.connect_signals();const{active:e,disabled:t}=this.model.properties;this.on_change(e,(()=>this._update_active())),this.on_change(t,(()=>this._update_disabled()))}_toggle_active(){this.model.disabled||(this.model.active=!this.model.active)}}i.ToggleInputView=c,c.__name__=\"ToggleInputView\";class _ extends o.Widget{constructor(e){super(e)}}i.ToggleInput=_,a=_,_.__name__=\"ToggleInput\",a.define((({Boolean:e})=>({active:[e,!1]})))},\n", - " 563: function _(e,t,i,n,o){var s;n();const l=e(1),r=e(551),c=e(56),a=e(21),d=l.__importStar(e(552));class h extends r.InputWidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.name.change,(()=>{var e;return this.input_el.name=null!==(e=this.model.name)&&void 0!==e?e:\"\"})),this.connect(this.model.properties.color.change,(()=>this.input_el.value=(0,a.color2hexrgb)(this.model.color))),this.connect(this.model.properties.disabled.change,(()=>this.input_el.disabled=this.model.disabled))}render(){super.render(),this.input_el=(0,c.input)({type:\"color\",class:d.input,name:this.model.name,value:this.model.color,disabled:this.model.disabled}),this.input_el.addEventListener(\"change\",(()=>this.change_input())),this.group_el.appendChild(this.input_el)}change_input(){this.model.color=this.input_el.value,super.change_input()}}i.ColorPickerView=h,h.__name__=\"ColorPickerView\";class p extends r.InputWidget{constructor(e){super(e)}}i.ColorPicker=p,s=p,p.__name__=\"ColorPicker\",s.prototype.default_view=h,s.define((({Color:e})=>({color:[e,\"#000000\"]})))},\n", - " 564: function _(e,t,a,s,i){var n;s();const l=e(565),c=e(12);class r extends l.BaseDatePickerView{get flatpickr_options(){return Object.assign(Object.assign({},super.flatpickr_options),{mode:\"single\"})}_on_change(e){switch(e.length){case 0:this.model.value=null;break;case 1:{const[t]=e,a=this._format_date(t);this.model.value=a;break}default:(0,c.assert)(!1,\"invalid length\")}}}a.DatePickerView=r,r.__name__=\"DatePickerView\";class o extends l.BaseDatePicker{constructor(e){super(e)}}a.DatePicker=o,n=o,o.__name__=\"DatePicker\",n.prototype.default_view=r,n.define((({Nullable:e})=>({value:[e(l.DateLike),null]})))},\n", - " 565: function _(e,t,a,s,i){var n;s();const l=e(566),c=e(8),r=e(20);a.DateLike=(0,r.Or)((0,r.Ref)(Date),r.String,r.Number),a.DateLikeList=(0,r.Array)((0,r.Or)(a.DateLike,(0,r.Tuple)(a.DateLike,a.DateLike),(0,r.Struct)({from:a.DateLike,to:a.DateLike})));class d extends l.PickerBaseView{_format_date(e){const{picker:t}=this;return t.formatDate(e,t.config.dateFormat)}connect_signals(){super.connect_signals();const{value:e,min_date:t,max_date:a,disabled_dates:s,enabled_dates:i,date_format:n}=this.model.properties;this.connect(e.change,(()=>{const{value:e}=this.model;null!=e?this.picker.setDate(e):this.picker.clear()})),this.connect(t.change,(()=>this.picker.set(\"minDate\",this.model.min_date))),this.connect(a.change,(()=>this.picker.set(\"maxDate\",this.model.max_date))),this.connect(s.change,(()=>{const{disabled_dates:e}=this.model;this.picker.set(\"disable\",null!=e?this._convert_date_list(e):void 0)})),this.connect(i.change,(()=>{const{enabled_dates:e}=this.model;this.picker.set(\"enable\",null!=e?this._convert_date_list(e):void 0)})),this.connect(n.change,(()=>this.picker.set(\"altFormat\",this.model.date_format)))}get flatpickr_options(){const{value:e,min_date:t,max_date:a,disabled_dates:s,enabled_dates:i,date_format:n}=this.model,l=super.flatpickr_options;return l.altInput=!0,l.altFormat=n,l.dateFormat=\"Y-m-d\",null!=e&&(l.defaultDate=e),null!=t&&(l.minDate=t),null!=a&&(l.maxDate=a),null!=s&&(l.disable=this._convert_date_list(s)),null!=i&&(l.enable=this._convert_date_list(i)),l}_convert_date_list(e){const t=[];for(const a of e)if((0,c.isArray)(a)){const[e,s]=a;t.push({from:e,to:s})}else t.push(a);return t}}a.BaseDatePickerView=d,d.__name__=\"BaseDatePickerView\";class o extends l.PickerBase{constructor(e){super(e)}}a.BaseDatePicker=o,n=o,o.__name__=\"BaseDatePicker\",n.define((({Nullable:e})=>({min_date:[e(a.DateLike),null],max_date:[e(a.DateLike),null],disabled_dates:[e(a.DateLikeList),null],enabled_dates:[e(a.DateLikeList),null],date_format:[r.String,\"Y-m-d\"]})))},\n", - " 566: function _(e,t,i,n,o){var s;n();const r=e(1),a=r.__importDefault(e(567)),l=e(551),c=e(56),d=e(19),h=e(56),p=e(12),f=r.__importDefault(e(575)),g=r.__importStar(e(552));class u extends l.InputWidgetView{get picker(){return(0,p.assert)(null!=this._picker),this._picker}remove(){var e;null===(e=this._picker)||void 0===e||e.destroy(),super.remove()}stylesheets(){return[...super.stylesheets(),f.default]}connect_signals(){super.connect_signals();const{inline:e}=this.model.properties;this.connect(e.change,(()=>this.picker.set(\"inline\",this.model.inline)))}get flatpickr_options(){return{appendTo:this.group_el,inline:this.model.inline,position:this._position.bind(this),onChange:e=>{this._on_change(e),this.change_input()}}}render(){var e;super.render(),null===(e=this._picker)||void 0===e||e.destroy(),this.input_el=(0,c.input)({type:\"text\",class:g.input,disabled:this.model.disabled}),this.group_el.appendChild(this.input_el);const t=this.flatpickr_options;this._picker=(0,a.default)(this.input_el,t)}_position(e,t){const i=null!=t?t:e._positionElement,n=[...e.calendarContainer.children].reduce(((e,t)=>e+(0,h.bounding_box)(t).height),0),o=e.calendarContainer.offsetWidth,s=this.model.position.split(\" \"),r=s[0],a=s.length>1?s[1]:null,l=i.offsetTop,c=i.offsetTop+i.offsetHeight,d=i.offsetLeft,p=i.offsetLeft+i.offsetWidth,f=i.offsetWidth,g=window.innerHeight-c,u=\"above\"===r||\"below\"!==r&&gn,_=null!=e.config.appendTo?l+(u?-n-2:i.offsetHeight+2):window.scrollY+l+(u?-n-2:i.offsetHeight+2);if(e.calendarContainer.classList.toggle(\"arrowTop\",!u),e.calendarContainer.classList.toggle(\"arrowBottom\",u),e.config.inline)return;let w=window.scrollX+d,C=!1,m=!1;\"center\"===a?(w-=(o-f)/2,C=!0):\"right\"===a&&(w-=o-f,m=!0),e.calendarContainer.classList.toggle(\"arrowLeft\",!C&&!m),e.calendarContainer.classList.toggle(\"arrowCenter\",C),e.calendarContainer.classList.toggle(\"arrowRight\",m);const y=window.document.body.offsetWidth-(window.scrollX+p),k=w+o>window.document.body.offsetWidth,b=y+o>window.document.body.offsetWidth;if(e.calendarContainer.classList.toggle(\"rightMost\",k),!e.config.static)if(e.calendarContainer.style.top=`${_}px`,k)if(b){const t=this.shadow_el.styleSheets[0],i=window.document.body.offsetWidth,n=Math.max(0,i/2-o/2),s=\".flatpickr-calendar.centerMost:before\",r=\".flatpickr-calendar.centerMost:after\",a=t.cssRules.length,l=`{left:${d}px;right:auto;}`;e.calendarContainer.classList.toggle(\"rightMost\",!1),e.calendarContainer.classList.toggle(\"centerMost\",!0),t.insertRule(`${s},${r}${l}`,a),e.calendarContainer.style.left=`${n}px`,e.calendarContainer.style.right=\"auto\"}else e.calendarContainer.style.left=\"auto\",e.calendarContainer.style.right=`${y}px`;else e.calendarContainer.style.left=`${w}px`,e.calendarContainer.style.right=\"auto\"}}i.PickerBaseView=u,u.__name__=\"PickerBaseView\";class _ extends l.InputWidget{constructor(e){super(e)}}i.PickerBase=_,s=_,_.__name__=\"PickerBase\",s.define((({Boolean:e})=>({position:[d.CalendarPosition,\"auto\"],inline:[e,!1]})))},\n", - " 567: function _(e,t,n,a,i){a();const o=e(1);var r=this&&this.__assign||function(){return r=Object.assign||function(e){for(var t,n=1,a=arguments.length;n=0?new Date:new Date(n.config.minDate.getTime()),a=(0,f.getDefaultHours)(n.config);t.setHours(a.hours,a.minutes,a.seconds,t.getMilliseconds()),n.selectedDates=[t],n.latestSelectedDateObj=t}void 0!==e&&\"blur\"!==e.type&&function(e){e.preventDefault();var t=\"keydown\"===e.type,a=(0,u.getEventTarget)(e),i=a;void 0!==n.amPM&&a===n.amPM&&(n.amPM.textContent=n.l10n.amPM[(0,d.int)(n.amPM.textContent===n.l10n.amPM[0])]);var o=parseFloat(i.getAttribute(\"min\")),r=parseFloat(i.getAttribute(\"max\")),l=parseFloat(i.getAttribute(\"step\")),c=parseInt(i.value,10),s=e.delta||(t?38===e.which?1:-1:0),f=c+l*s;if(void 0!==i.value&&2===i.value.length){var m=i===n.hourElement,g=i===n.minuteElement;fr&&(f=i===n.hourElement?f-r-(0,d.int)(!n.amPM):o,g&&x(void 0,1,n.hourElement)),n.amPM&&m&&(1===l?f+c===23:Math.abs(f-c)>l)&&(n.amPM.textContent=n.l10n.amPM[(0,d.int)(n.amPM.textContent===n.l10n.amPM[0])]),i.value=(0,d.pad)(f)}}(e);var i=n._input.value;h(),se(),n._input.value!==i&&n._debouncedChange()}function h(){if(void 0!==n.hourElement&&void 0!==n.minuteElement){var e,t,a=(parseInt(n.hourElement.value.slice(-2),10)||0)%24,i=(parseInt(n.minuteElement.value,10)||0)%60,o=void 0!==n.secondElement?(parseInt(n.secondElement.value,10)||0)%60:0;void 0!==n.amPM&&(e=a,t=n.amPM.textContent,a=e%12+12*(0,d.int)(t===n.l10n.amPM[1]));var r=void 0!==n.config.minTime||n.config.minDate&&n.minDateHasTime&&n.latestSelectedDateObj&&0===(0,f.compareDates)(n.latestSelectedDateObj,n.config.minDate,!0),l=void 0!==n.config.maxTime||n.config.maxDate&&n.maxDateHasTime&&n.latestSelectedDateObj&&0===(0,f.compareDates)(n.latestSelectedDateObj,n.config.maxDate,!0);if(void 0!==n.config.maxTime&&void 0!==n.config.minTime&&n.config.minTime>n.config.maxTime){var c=(0,f.calculateSecondsSinceMidnight)(n.config.minTime.getHours(),n.config.minTime.getMinutes(),n.config.minTime.getSeconds()),s=(0,f.calculateSecondsSinceMidnight)(n.config.maxTime.getHours(),n.config.maxTime.getMinutes(),n.config.maxTime.getSeconds()),u=(0,f.calculateSecondsSinceMidnight)(a,i,o);if(u>s&&u=12)]),void 0!==n.secondElement&&(n.secondElement.value=(0,d.pad)(a)))}function b(e){var t=(0,u.getEventTarget)(e),n=parseInt(t.value)+(e.delta||0);(n/1e3>1||\"Enter\"===e.key&&!/[^\\d]/.test(n.toString()))&&R(n)}function M(e,t,a,i){return t instanceof Array?t.forEach((function(t){return M(e,t,a,i)})):e instanceof Array?e.forEach((function(e){return M(e,t,a,i)})):(e.addEventListener(t,a,i),void n._handlers.push({remove:function(){return e.removeEventListener(t,a,i)}}))}function y(){ie(\"onChange\")}function w(e,t){var a=void 0!==e?n.parseDate(e):n.latestSelectedDateObj||(n.config.minDate&&n.config.minDate>n.now?n.config.minDate:n.config.maxDate&&n.config.maxDate=0&&(0,f.compareDates)(e,n.selectedDates[1])<=0)}(t)&&!re(t)&&r.classList.add(\"inRange\"),n.weekNumbers&&1===n.config.showMonths&&\"prevMonthDay\"!==e&&i%7==6&&n.weekNumbers.insertAdjacentHTML(\"beforeend\",\"\"+n.config.getWeek(t)+\"\"),ie(\"onDayCreate\",r),r}function T(e){e.focus(),\"range\"===n.config.mode&&J(e)}function _(e){for(var t=e>0?0:n.config.showMonths-1,a=e>0?n.config.showMonths:-1,i=t;i!=a;i+=e)for(var o=n.daysContainer.children[i],r=e>0?0:o.children.length-1,l=e>0?o.children.length:-1,c=r;c!=l;c+=e){var s=o.children[c];if(-1===s.className.indexOf(\"hidden\")&&W(s.dateObj))return s}}function I(e,t){var i=a(),o=B(i||document.body),r=void 0!==e?e:o?i:void 0!==n.selectedDateElem&&B(n.selectedDateElem)?n.selectedDateElem:void 0!==n.todayDateElem&&B(n.todayDateElem)?n.todayDateElem:_(t>0?1:-1);void 0===r?n._input.focus():o?function(e,t){for(var a=-1===e.className.indexOf(\"Month\")?e.dateObj.getMonth():n.currentMonth,i=t>0?n.config.showMonths:-1,o=t>0?1:-1,r=a-n.currentMonth;r!=i;r+=o)for(var l=n.daysContainer.children[r],c=a-n.currentMonth===r?e.$i+t:t<0?l.children.length-1:0,s=l.children.length,d=c;d>=0&&d0?s:-1);d+=o){var u=l.children[d];if(-1===u.className.indexOf(\"hidden\")&&W(u.dateObj)&&Math.abs(e.$i-d)>=Math.abs(t))return T(u)}n.changeMonth(o),I(_(o),0)}(r,t):T(r)}function S(e,t){for(var a=(new Date(e,t,1).getDay()-n.l10n.firstDayOfWeek+7)%7,i=n.utils.getDaysInMonth((t-1+12)%12,e),o=n.utils.getDaysInMonth(t,e),r=window.document.createDocumentFragment(),l=n.config.showMonths>1,c=l?\"prevMonthDay hidden\":\"prevMonthDay\",s=l?\"nextMonthDay hidden\":\"nextMonthDay\",d=i+1-a,f=0;d<=i;d++,f++)r.appendChild(k(\"flatpickr-day \"+c,new Date(e,t-1,d),0,f));for(d=1;d<=o;d++,f++)r.appendChild(k(\"flatpickr-day\",new Date(e,t,d),0,f));for(var m=o+1;m<=42-a&&(1===n.config.showMonths||f%7!=0);m++,f++)r.appendChild(k(\"flatpickr-day \"+s,new Date(e,t+1,m%o),0,f));var g=(0,u.createElement)(\"div\",\"dayContainer\");return g.appendChild(r),g}function O(){if(void 0!==n.daysContainer){(0,u.clearNode)(n.daysContainer),n.weekNumbers&&(0,u.clearNode)(n.weekNumbers);for(var e=document.createDocumentFragment(),t=0;t1||\"dropdown\"!==n.config.monthSelectorType)){var e=function(e){return!(void 0!==n.config.minDate&&n.currentYear===n.config.minDate.getFullYear()&&en.config.maxDate.getMonth())};n.monthsDropdownContainer.tabIndex=-1,n.monthsDropdownContainer.innerHTML=\"\";for(var t=0;t<12;t++)if(e(t)){var a=(0,u.createElement)(\"option\",\"flatpickr-monthDropdown-month\");a.value=new Date(n.currentYear,t).getMonth().toString(),a.textContent=(0,m.monthToStr)(t,n.config.shorthandCurrentMonth,n.l10n),a.tabIndex=-1,n.currentMonth===t&&(a.selected=!0),n.monthsDropdownContainer.appendChild(a)}}}function A(){var e,t=(0,u.createElement)(\"div\",\"flatpickr-month\"),a=window.document.createDocumentFragment();n.config.showMonths>1||\"static\"===n.config.monthSelectorType?e=(0,u.createElement)(\"span\",\"cur-month\"):(n.monthsDropdownContainer=(0,u.createElement)(\"select\",\"flatpickr-monthDropdown-months\"),n.monthsDropdownContainer.setAttribute(\"aria-label\",n.l10n.monthAriaLabel),M(n.monthsDropdownContainer,\"change\",(function(e){var t=(0,u.getEventTarget)(e),a=parseInt(t.value,10);n.changeMonth(a-n.currentMonth),ie(\"onMonthChange\")})),N(),e=n.monthsDropdownContainer);var i=(0,u.createNumberInput)(\"cur-year\",{tabindex:\"-1\"}),o=i.getElementsByTagName(\"input\")[0];o.setAttribute(\"aria-label\",n.l10n.yearAriaLabel),n.config.minDate&&o.setAttribute(\"min\",n.config.minDate.getFullYear().toString()),n.config.maxDate&&(o.setAttribute(\"max\",n.config.maxDate.getFullYear().toString()),o.disabled=!!n.config.minDate&&n.config.minDate.getFullYear()===n.config.maxDate.getFullYear());var r=(0,u.createElement)(\"div\",\"flatpickr-current-month\");return r.appendChild(e),r.appendChild(i),a.appendChild(r),t.appendChild(a),{container:t,yearElement:o,monthElement:e}}function P(){(0,u.clearNode)(n.monthNav),n.monthNav.appendChild(n.prevMonthNav),n.config.showMonths&&(n.yearElements=[],n.monthElements=[]);for(var e=n.config.showMonths;e--;){var t=A();n.yearElements.push(t.yearElement),n.monthElements.push(t.monthElement),n.monthNav.appendChild(t.container)}n.monthNav.appendChild(n.nextMonthNav)}function Y(){n.weekdayContainer?(0,u.clearNode)(n.weekdayContainer):n.weekdayContainer=(0,u.createElement)(\"div\",\"flatpickr-weekdays\");for(var e=n.config.showMonths;e--;){var t=(0,u.createElement)(\"div\",\"flatpickr-weekdaycontainer\");n.weekdayContainer.appendChild(t)}return F(),n.weekdayContainer}function F(){if(n.weekdayContainer){var e=n.l10n.firstDayOfWeek,t=l(n.l10n.weekdays.shorthand);e>0&&e\\n \"+t.join(\"\")+\"\\n \\n \"}}function j(e,t){void 0===t&&(t=!0);var a=t?e:e-n.currentMonth;a<0&&!0===n._hidePrevMonthArrow||a>0&&!0===n._hideNextMonthArrow||(n.currentMonth+=a,(n.currentMonth<0||n.currentMonth>11)&&(n.currentYear+=n.currentMonth>11?1:-1,n.currentMonth=(n.currentMonth+12)%12,ie(\"onYearChange\"),N()),O(),ie(\"onMonthChange\"),le())}function L(e){return n.calendarContainer.contains(e)}function H(e){if(n.isOpen&&!n.config.inline){var t=(0,u.getEventTarget)(e),a=L(t),i=!(t===n.input||t===n.altInput||n.element.contains(t)||e.path&&e.path.indexOf&&(~e.path.indexOf(n.input)||~e.path.indexOf(n.altInput)))&&!a&&!L(e.relatedTarget),o=!n.config.ignoredFocusElements.some((function(e){return e.contains(t)}));i&&o&&(n.config.allowInput&&n.setDate(n._input.value,!1,n.config.altInput?n.config.altFormat:n.config.dateFormat),void 0!==n.timeContainer&&void 0!==n.minuteElement&&void 0!==n.hourElement&&\"\"!==n.input.value&&void 0!==n.input.value&&p(),n.close(),n.config&&\"range\"===n.config.mode&&1===n.selectedDates.length&&n.clear(!1))}}function R(e){if(!(!e||n.config.minDate&&en.config.maxDate.getFullYear())){var t=e,a=n.currentYear!==t;n.currentYear=t||n.currentYear,n.config.maxDate&&n.currentYear===n.config.maxDate.getFullYear()?n.currentMonth=Math.min(n.config.maxDate.getMonth(),n.currentMonth):n.config.minDate&&n.currentYear===n.config.minDate.getFullYear()&&(n.currentMonth=Math.max(n.config.minDate.getMonth(),n.currentMonth)),a&&(n.redraw(),ie(\"onYearChange\"),N())}}function W(e,t){var a;void 0===t&&(t=!0);var i=n.parseDate(e,void 0,t);if(n.config.minDate&&i&&(0,f.compareDates)(i,n.config.minDate,void 0!==t?t:!n.minDateHasTime)<0||n.config.maxDate&&i&&(0,f.compareDates)(i,n.config.maxDate,void 0!==t?t:!n.maxDateHasTime)>0)return!1;if(!n.config.enable&&0===n.config.disable.length)return!0;if(void 0===i)return!1;for(var o=!!n.config.enable,r=null!==(a=n.config.enable)&&void 0!==a?a:n.config.disable,l=0,c=void 0;l=c.from.getTime()&&i.getTime()<=c.to.getTime())return o}return!o}function B(e){return void 0!==n.daysContainer&&(-1===e.className.indexOf(\"hidden\")&&-1===e.className.indexOf(\"flatpickr-disabled\")&&n.daysContainer.contains(e))}function K(e){var t=e.target===n._input,a=n._input.value.trimEnd()!==ce();!t||!a||e.relatedTarget&&L(e.relatedTarget)||n.setDate(n._input.value,!0,e.target===n.altInput?n.config.altFormat:n.config.dateFormat)}function q(t){var i=(0,u.getEventTarget)(t),o=n.config.wrap?e.contains(i):i===n._input,r=n.config.allowInput,l=n.isOpen&&(!r||!o),c=n.config.inline&&o&&!r;if(13===t.keyCode&&o){if(r)return n.setDate(n._input.value,!0,i===n.altInput?n.config.altFormat:n.config.dateFormat),n.close(),i.blur();n.open()}else if(L(i)||l||c){var s=!!n.timeContainer&&n.timeContainer.contains(i);switch(t.keyCode){case 13:s?(t.preventDefault(),p(),G()):Z(t);break;case 27:t.preventDefault(),G();break;case 8:case 46:o&&!n.config.allowInput&&(t.preventDefault(),n.clear());break;case 37:case 39:if(s||o)n.hourElement&&n.hourElement.focus();else{t.preventDefault();var d=a();if(void 0!==n.daysContainer&&(!1===r||d&&B(d))){var f=39===t.keyCode?1:-1;t.ctrlKey?(t.stopPropagation(),j(f),I(_(1),0)):I(void 0,f)}}break;case 38:case 40:t.preventDefault();var m=40===t.keyCode?1:-1;n.daysContainer&&void 0!==i.$i||i===n.input||i===n.altInput?t.ctrlKey?(t.stopPropagation(),R(n.currentYear-m),I(_(1),0)):s||I(void 0,7*m):i===n.currentYearElement?R(n.currentYear-m):n.config.enableTime&&(!s&&n.hourElement&&n.hourElement.focus(),p(t),n._debouncedChange());break;case 9:if(s){var g=[n.hourElement,n.minuteElement,n.secondElement,n.amPM].concat(n.pluginElements).filter((function(e){return e})),v=g.indexOf(i);if(-1!==v){var D=g[v+(t.shiftKey?-1:1)];t.preventDefault(),(D||n._input).focus()}}else!n.config.noCalendar&&n.daysContainer&&n.daysContainer.contains(i)&&t.shiftKey&&(t.preventDefault(),n._input.focus())}}if(void 0!==n.amPM&&i===n.amPM)switch(t.key){case n.l10n.amPM[0].charAt(0):case n.l10n.amPM[0].charAt(0).toLowerCase():n.amPM.textContent=n.l10n.amPM[0],h(),se();break;case n.l10n.amPM[1].charAt(0):case n.l10n.amPM[1].charAt(0).toLowerCase():n.amPM.textContent=n.l10n.amPM[1],h(),se()}(o||L(i))&&ie(\"onKeyDown\",t)}function J(e,t){if(void 0===t&&(t=\"flatpickr-day\"),1===n.selectedDates.length&&(!e||e.classList.contains(t)&&!e.classList.contains(\"flatpickr-disabled\"))){for(var a=e?e.dateObj.getTime():n.days.firstElementChild.dateObj.getTime(),i=n.parseDate(n.selectedDates[0],void 0,!0).getTime(),o=Math.min(a,n.selectedDates[0].getTime()),r=Math.max(a,n.selectedDates[0].getTime()),l=!1,c=0,s=0,d=o;do&&dc)?c=d:d>i&&(!s||d .\"+t)).forEach((function(t){var o=t.dateObj.getTime(),r=c>0&&o0&&o>s;if(r)return t.classList.add(\"notAllowed\"),void[\"inRange\",\"startRange\",\"endRange\"].forEach((function(e){t.classList.remove(e)}));l&&!r||([\"startRange\",\"inRange\",\"endRange\",\"notAllowed\"].forEach((function(e){t.classList.remove(e)})),void 0!==e&&(e.classList.add(a<=n.selectedDates[0].getTime()?\"startRange\":\"endRange\"),ia&&o===i&&t.classList.add(\"endRange\"),o>=c&&(0===s||o<=s)&&(0,f.isBetween)(o,i,a)&&t.classList.add(\"inRange\")))}))}}function U(){!n.isOpen||n.config.static||n.config.inline||X()}function $(e){return function(t){var a=n.config[\"_\"+e+\"Date\"]=n.parseDate(t,n.config.dateFormat),i=n.config[\"_\"+(\"min\"===e?\"max\":\"min\")+\"Date\"];void 0!==a&&(n[\"min\"===e?\"minDateHasTime\":\"maxDateHasTime\"]=a.getHours()>0||a.getMinutes()>0||a.getSeconds()>0),n.selectedDates&&(n.selectedDates=n.selectedDates.filter((function(e){return W(e)})),n.selectedDates.length||\"min\"!==e||D(a),se()),n.daysContainer&&(z(),void 0!==a?n.currentYearElement[e]=a.getFullYear().toString():n.currentYearElement.removeAttribute(e),n.currentYearElement.disabled=!!i&&void 0!==a&&i.getFullYear()===a.getFullYear())}}function Q(){return n.config.wrap?e.querySelector(\"[data-input]\"):e}function V(){\"object\"!=typeof n.config.locale&&void 0===v.l10ns[n.config.locale]&&n.config.errorHandler(new Error(\"flatpickr: invalid locale \"+n.config.locale)),n.l10n=r(r({},v.l10ns.default),\"object\"==typeof n.config.locale?n.config.locale:\"default\"!==n.config.locale?v.l10ns[n.config.locale]:void 0),m.tokenRegex.D=\"(\"+n.l10n.weekdays.shorthand.join(\"|\")+\")\",m.tokenRegex.l=\"(\"+n.l10n.weekdays.longhand.join(\"|\")+\")\",m.tokenRegex.M=\"(\"+n.l10n.months.shorthand.join(\"|\")+\")\",m.tokenRegex.F=\"(\"+n.l10n.months.longhand.join(\"|\")+\")\",m.tokenRegex.K=\"(\"+n.l10n.amPM[0]+\"|\"+n.l10n.amPM[1]+\"|\"+n.l10n.amPM[0].toLowerCase()+\"|\"+n.l10n.amPM[1].toLowerCase()+\")\",void 0===r(r({},t),JSON.parse(JSON.stringify(e.dataset||{}))).time_24hr&&void 0===v.defaultConfig.time_24hr&&(n.config.time_24hr=n.l10n.time_24hr),n.formatDate=(0,f.createDateFormatter)(n),n.parseDate=(0,f.createDateParser)({config:n.config,l10n:n.l10n})}function X(e){if(\"function\"!=typeof n.config.position){if(void 0!==n.calendarContainer){ie(\"onPreCalendarPosition\");var t=e||n._positionElement,a=Array.prototype.reduce.call(n.calendarContainer.children,(function(e,t){return e+t.offsetHeight}),0),i=n.calendarContainer.offsetWidth,o=n.config.position.split(\" \"),r=o[0],l=o.length>1?o[1]:null,c=t.getBoundingClientRect(),s=window.innerHeight-c.bottom,d=\"above\"===r||\"below\"!==r&&sa,f=window.pageYOffset+c.top+(d?-a-2:t.offsetHeight+2);if((0,u.toggleClass)(n.calendarContainer,\"arrowTop\",!d),(0,u.toggleClass)(n.calendarContainer,\"arrowBottom\",d),!n.config.inline){var m=window.pageXOffset+c.left,g=!1,p=!1;\"center\"===l?(m-=(i-c.width)/2,g=!0):\"right\"===l&&(m-=i-c.width,p=!0),(0,u.toggleClass)(n.calendarContainer,\"arrowLeft\",!g&&!p),(0,u.toggleClass)(n.calendarContainer,\"arrowCenter\",g),(0,u.toggleClass)(n.calendarContainer,\"arrowRight\",p);var h=window.document.body.offsetWidth-(window.pageXOffset+c.right),v=m+i>window.document.body.offsetWidth,D=h+i>window.document.body.offsetWidth;if((0,u.toggleClass)(n.calendarContainer,\"rightMost\",v),!n.config.static)if(n.calendarContainer.style.top=f+\"px\",v)if(D){var C=function(){for(var e=null,t=0;tn.currentMonth+n.config.showMonths-1)&&\"range\"!==n.config.mode;if(n.selectedDateElem=a,\"single\"===n.config.mode)n.selectedDates=[i];else if(\"multiple\"===n.config.mode){var r=re(i);r?n.selectedDates.splice(parseInt(r),1):n.selectedDates.push(i)}else\"range\"===n.config.mode&&(2===n.selectedDates.length&&n.clear(!1,!1),n.latestSelectedDateObj=i,n.selectedDates.push(i),0!==(0,f.compareDates)(i,n.selectedDates[0],!0)&&n.selectedDates.sort((function(e,t){return e.getTime()-t.getTime()})));if(h(),o){var l=n.currentYear!==i.getFullYear();n.currentYear=i.getFullYear(),n.currentMonth=i.getMonth(),l&&(ie(\"onYearChange\"),N()),ie(\"onMonthChange\")}if(le(),O(),se(),o||\"range\"===n.config.mode||1!==n.config.showMonths?void 0!==n.selectedDateElem&&void 0===n.hourElement&&n.selectedDateElem&&n.selectedDateElem.focus():T(a),void 0!==n.hourElement&&void 0!==n.hourElement&&n.hourElement.focus(),n.config.closeOnSelect){var c=\"single\"===n.config.mode&&!n.config.enableTime,s=\"range\"===n.config.mode&&2===n.selectedDates.length&&!n.config.enableTime;(c||s)&&G()}y()}}n.parseDate=(0,f.createDateParser)({config:n.config,l10n:n.l10n}),n._handlers=[],n.pluginElements=[],n.loadedPlugins=[],n._bind=M,n._setHoursFromDate=D,n._positionCalendar=X,n.changeMonth=j,n.changeYear=R,n.clear=function(e,t){void 0===e&&(e=!0);void 0===t&&(t=!0);n.input.value=\"\",void 0!==n.altInput&&(n.altInput.value=\"\");void 0!==n.mobileInput&&(n.mobileInput.value=\"\");n.selectedDates=[],n.latestSelectedDateObj=void 0,!0===t&&(n.currentYear=n._initialDate.getFullYear(),n.currentMonth=n._initialDate.getMonth());if(!0===n.config.enableTime){var a=(0,f.getDefaultHours)(n.config);C(a.hours,a.minutes,a.seconds)}n.redraw(),e&&ie(\"onChange\")},n.close=function(){n.isOpen=!1,n.isMobile||(void 0!==n.calendarContainer&&n.calendarContainer.classList.remove(\"open\"),void 0!==n._input&&n._input.classList.remove(\"active\"));ie(\"onClose\")},n.onMouseOver=J,n._createElement=u.createElement,n.createDay=k,n.destroy=function(){void 0!==n.config&&ie(\"onDestroy\");for(var e=n._handlers.length;e--;)n._handlers[e].remove();if(n._handlers=[],n.mobileInput)n.mobileInput.parentNode&&n.mobileInput.parentNode.removeChild(n.mobileInput),n.mobileInput=void 0;else if(n.calendarContainer&&n.calendarContainer.parentNode)if(n.config.static&&n.calendarContainer.parentNode){var t=n.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 n.calendarContainer.parentNode.removeChild(n.calendarContainer);n.altInput&&(n.input.type=\"text\",n.altInput.parentNode&&n.altInput.parentNode.removeChild(n.altInput),delete n.altInput);n.input&&(n.input.type=n.input._type,n.input.classList.remove(\"flatpickr-input\"),n.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 n[e]}catch(e){}}))},n.isEnabled=W,n.jumpToDate=w,n.updateValue=se,n.open=function(e,t){void 0===t&&(t=n._positionElement);if(!0===n.isMobile){if(e){e.preventDefault();var a=(0,u.getEventTarget)(e);a&&a.blur()}return void 0!==n.mobileInput&&(n.mobileInput.focus(),n.mobileInput.click()),void ie(\"onOpen\")}if(n._input.disabled||n.config.inline)return;var i=n.isOpen;n.isOpen=!0,i||(n.calendarContainer.classList.add(\"open\"),n._input.classList.add(\"active\"),ie(\"onOpen\"),X(t));!0===n.config.enableTime&&!0===n.config.noCalendar&&(!1!==n.config.allowInput||void 0!==e&&n.timeContainer.contains(e.relatedTarget)||setTimeout((function(){return n.hourElement.select()}),50))},n.redraw=z,n.set=function(e,t){if(null!==e&&\"object\"==typeof e)for(var a in Object.assign(n.config,e),e)void 0!==ee[a]&&ee[a].forEach((function(e){return e()}));else n.config[e]=t,void 0!==ee[e]?ee[e].forEach((function(e){return e()})):c.HOOKS.indexOf(e)>-1&&(n.config[e]=(0,d.arrayify)(t));n.redraw(),se(!0)},n.setDate=function(e,t,a){void 0===t&&(t=!1);void 0===a&&(a=n.config.dateFormat);if(0!==e&&!e||e instanceof Array&&0===e.length)return n.clear(t);te(e,a),n.latestSelectedDateObj=n.selectedDates[n.selectedDates.length-1],n.redraw(),w(void 0,t),D(),0===n.selectedDates.length&&n.clear(!1);se(t),t&&ie(\"onChange\")},n.toggle=function(e){if(!0===n.isOpen)return n.close();n.open(e)};var ee={locale:[V,F],showMonths:[P,o,Y],minDate:[w],maxDate:[w],positionElement:[ae],clickOpens:[function(){!0===n.config.clickOpens?(M(n._input,\"focus\",n.open),M(n._input,\"click\",n.open)):(n._input.removeEventListener(\"focus\",n.open),n._input.removeEventListener(\"click\",n.open))}]};function te(e,t){var a=[];if(e instanceof Array)a=e.map((function(e){return n.parseDate(e,t)}));else if(e instanceof Date||\"number\"==typeof e)a=[n.parseDate(e,t)];else if(\"string\"==typeof e)switch(n.config.mode){case\"single\":case\"time\":a=[n.parseDate(e,t)];break;case\"multiple\":a=e.split(n.config.conjunction).map((function(e){return n.parseDate(e,t)}));break;case\"range\":a=e.split(n.l10n.rangeSeparator).map((function(e){return n.parseDate(e,t)}))}else n.config.errorHandler(new Error(\"Invalid date supplied: \"+JSON.stringify(e)));n.selectedDates=n.config.allowInvalidPreload?a:a.filter((function(e){return e instanceof Date&&W(e,!1)})),\"range\"===n.config.mode&&n.selectedDates.sort((function(e,t){return e.getTime()-t.getTime()}))}function ne(e){return e.slice().map((function(e){return\"string\"==typeof e||\"number\"==typeof e||e instanceof Date?n.parseDate(e,void 0,!0):e&&\"object\"==typeof e&&e.from&&e.to?{from:n.parseDate(e.from,void 0),to:n.parseDate(e.to,void 0)}:e})).filter((function(e){return e}))}function ae(){n._positionElement=n.config.positionElement||n._input}function ie(e,t){if(void 0!==n.config){var a=n.config[e];if(void 0!==a&&a.length>0)for(var i=0;a[i]&&i1||\"static\"===n.config.monthSelectorType?n.monthElements[t].textContent=(0,m.monthToStr)(a.getMonth(),n.config.shorthandCurrentMonth,n.l10n)+\" \":n.monthsDropdownContainer.value=a.getMonth().toString(),e.value=a.getFullYear().toString()})),n._hidePrevMonthArrow=void 0!==n.config.minDate&&(n.currentYear===n.config.minDate.getFullYear()?n.currentMonth<=n.config.minDate.getMonth():n.currentYearn.config.maxDate.getMonth():n.currentYear>n.config.maxDate.getFullYear()))}function ce(e){var t=e||(n.config.altInput?n.config.altFormat:n.config.dateFormat);return n.selectedDates.map((function(e){return n.formatDate(e,t)})).filter((function(e,t,a){return\"range\"!==n.config.mode||n.config.enableTime||a.indexOf(e)===t})).join(\"range\"!==n.config.mode?n.config.conjunction:n.l10n.rangeSeparator)}function se(e){void 0===e&&(e=!0),void 0!==n.mobileInput&&n.mobileFormatStr&&(n.mobileInput.value=void 0!==n.latestSelectedDateObj?n.formatDate(n.latestSelectedDateObj,n.mobileFormatStr):\"\"),n.input.value=ce(n.config.dateFormat),void 0!==n.altInput&&(n.altInput.value=ce(n.config.altFormat)),!1!==e&&ie(\"onValueUpdate\")}function de(e){var t=(0,u.getEventTarget)(e),a=n.prevMonthNav.contains(t),i=n.nextMonthNav.contains(t);a||i?j(a?-1:1):n.yearElements.indexOf(t)>=0?t.select():t.classList.contains(\"arrowUp\")?n.changeYear(n.currentYear+1):t.classList.contains(\"arrowDown\")&&n.changeYear(n.currentYear-1)}return function(){n.element=n.input=e,n.isOpen=!1,function(){var a=[\"wrap\",\"weekNumbers\",\"allowInput\",\"allowInvalidPreload\",\"clickOpens\",\"time_24hr\",\"enableTime\",\"noCalendar\",\"altInput\",\"shorthandCurrentMonth\",\"inline\",\"static\",\"enableSeconds\",\"disableMobile\"],o=r(r({},JSON.parse(JSON.stringify(e.dataset||{}))),t),l={};n.config.parseDate=o.parseDate,n.config.formatDate=o.formatDate,Object.defineProperty(n.config,\"enable\",{get:function(){return n.config._enable},set:function(e){n.config._enable=ne(e)}}),Object.defineProperty(n.config,\"disable\",{get:function(){return n.config._disable},set:function(e){n.config._disable=ne(e)}});var s=\"time\"===o.mode;if(!o.dateFormat&&(o.enableTime||s)){var u=v.defaultConfig.dateFormat||c.defaults.dateFormat;l.dateFormat=o.noCalendar||s?\"H:i\"+(o.enableSeconds?\":S\":\"\"):u+\" H:i\"+(o.enableSeconds?\":S\":\"\")}if(o.altInput&&(o.enableTime||s)&&!o.altFormat){var f=v.defaultConfig.altFormat||c.defaults.altFormat;l.altFormat=o.noCalendar||s?\"h:i\"+(o.enableSeconds?\":S K\":\" K\"):f+\" h:i\"+(o.enableSeconds?\":S\":\"\")+\" K\"}Object.defineProperty(n.config,\"minDate\",{get:function(){return n.config._minDate},set:$(\"min\")}),Object.defineProperty(n.config,\"maxDate\",{get:function(){return n.config._maxDate},set:$(\"max\")});var m=function(e){return function(t){n.config[\"min\"===e?\"_minTime\":\"_maxTime\"]=n.parseDate(t,\"H:i:S\")}};Object.defineProperty(n.config,\"minTime\",{get:function(){return n.config._minTime},set:m(\"min\")}),Object.defineProperty(n.config,\"maxTime\",{get:function(){return n.config._maxTime},set:m(\"max\")}),\"time\"===o.mode&&(n.config.noCalendar=!0,n.config.enableTime=!0);Object.assign(n.config,l,o);for(var g=0;g-1?n.config[h]=(0,d.arrayify)(p[h]).map(i).concat(n.config[h]):void 0===o[h]&&(n.config[h]=p[h])}o.altInputClass||(n.config.altInputClass=Q().className+\" \"+n.config.altInputClass);ie(\"onParseConfig\")}(),V(),function(){if(n.input=Q(),!n.input)return void n.config.errorHandler(new Error(\"Invalid input element specified\"));n.input._type=n.input.type,n.input.type=\"text\",n.input.classList.add(\"flatpickr-input\"),n._input=n.input,n.config.altInput&&(n.altInput=(0,u.createElement)(n.input.nodeName,n.config.altInputClass),n._input=n.altInput,n.altInput.placeholder=n.input.placeholder,n.altInput.disabled=n.input.disabled,n.altInput.required=n.input.required,n.altInput.tabIndex=n.input.tabIndex,n.altInput.type=\"text\",n.input.setAttribute(\"type\",\"hidden\"),!n.config.static&&n.input.parentNode&&n.input.parentNode.insertBefore(n.altInput,n.input.nextSibling));n.config.allowInput||n._input.setAttribute(\"readonly\",\"readonly\");ae()}(),function(){n.selectedDates=[],n.now=n.parseDate(n.config.now)||new Date;var e=n.config.defaultDate||(\"INPUT\"!==n.input.nodeName&&\"TEXTAREA\"!==n.input.nodeName||!n.input.placeholder||n.input.value!==n.input.placeholder?n.input.value:null);e&&te(e,n.config.dateFormat);n._initialDate=n.selectedDates.length>0?n.selectedDates[0]:n.config.minDate&&n.config.minDate.getTime()>n.now.getTime()?n.config.minDate:n.config.maxDate&&n.config.maxDate.getTime()0&&(n.latestSelectedDateObj=n.selectedDates[0]);void 0!==n.config.minTime&&(n.config.minTime=n.parseDate(n.config.minTime,\"H:i\"));void 0!==n.config.maxTime&&(n.config.maxTime=n.parseDate(n.config.maxTime,\"H:i\"));n.minDateHasTime=!!n.config.minDate&&(n.config.minDate.getHours()>0||n.config.minDate.getMinutes()>0||n.config.minDate.getSeconds()>0),n.maxDateHasTime=!!n.config.maxDate&&(n.config.maxDate.getHours()>0||n.config.maxDate.getMinutes()>0||n.config.maxDate.getSeconds()>0)}(),n.utils={getDaysInMonth:function(e,t){return void 0===e&&(e=n.currentMonth),void 0===t&&(t=n.currentYear),1===e&&(t%4==0&&t%100!=0||t%400==0)?29:n.l10n.daysInMonth[e]}},n.isMobile||function(){var e=window.document.createDocumentFragment();if(n.calendarContainer=(0,u.createElement)(\"div\",\"flatpickr-calendar\"),n.calendarContainer.tabIndex=-1,!n.config.noCalendar){if(e.appendChild((n.monthNav=(0,u.createElement)(\"div\",\"flatpickr-months\"),n.yearElements=[],n.monthElements=[],n.prevMonthNav=(0,u.createElement)(\"span\",\"flatpickr-prev-month\"),n.prevMonthNav.innerHTML=n.config.prevArrow,n.nextMonthNav=(0,u.createElement)(\"span\",\"flatpickr-next-month\"),n.nextMonthNav.innerHTML=n.config.nextArrow,P(),Object.defineProperty(n,\"_hidePrevMonthArrow\",{get:function(){return n.__hidePrevMonthArrow},set:function(e){n.__hidePrevMonthArrow!==e&&((0,u.toggleClass)(n.prevMonthNav,\"flatpickr-disabled\",e),n.__hidePrevMonthArrow=e)}}),Object.defineProperty(n,\"_hideNextMonthArrow\",{get:function(){return n.__hideNextMonthArrow},set:function(e){n.__hideNextMonthArrow!==e&&((0,u.toggleClass)(n.nextMonthNav,\"flatpickr-disabled\",e),n.__hideNextMonthArrow=e)}}),n.currentYearElement=n.yearElements[0],le(),n.monthNav)),n.innerContainer=(0,u.createElement)(\"div\",\"flatpickr-innerContainer\"),n.config.weekNumbers){var t=function(){n.calendarContainer.classList.add(\"hasWeeks\");var e=(0,u.createElement)(\"div\",\"flatpickr-weekwrapper\");e.appendChild((0,u.createElement)(\"span\",\"flatpickr-weekday\",n.l10n.weekAbbreviation));var t=(0,u.createElement)(\"div\",\"flatpickr-weeks\");return e.appendChild(t),{weekWrapper:e,weekNumbers:t}}(),a=t.weekWrapper,i=t.weekNumbers;n.innerContainer.appendChild(a),n.weekNumbers=i,n.weekWrapper=a}n.rContainer=(0,u.createElement)(\"div\",\"flatpickr-rContainer\"),n.rContainer.appendChild(Y()),n.daysContainer||(n.daysContainer=(0,u.createElement)(\"div\",\"flatpickr-days\"),n.daysContainer.tabIndex=-1),O(),n.rContainer.appendChild(n.daysContainer),n.innerContainer.appendChild(n.rContainer),e.appendChild(n.innerContainer)}n.config.enableTime&&e.appendChild(function(){n.calendarContainer.classList.add(\"hasTime\"),n.config.noCalendar&&n.calendarContainer.classList.add(\"noCalendar\");var e=(0,f.getDefaultHours)(n.config);n.timeContainer=(0,u.createElement)(\"div\",\"flatpickr-time\"),n.timeContainer.tabIndex=-1;var t=(0,u.createElement)(\"span\",\"flatpickr-time-separator\",\":\"),a=(0,u.createNumberInput)(\"flatpickr-hour\",{\"aria-label\":n.l10n.hourAriaLabel});n.hourElement=a.getElementsByTagName(\"input\")[0];var i=(0,u.createNumberInput)(\"flatpickr-minute\",{\"aria-label\":n.l10n.minuteAriaLabel});n.minuteElement=i.getElementsByTagName(\"input\")[0],n.hourElement.tabIndex=n.minuteElement.tabIndex=-1,n.hourElement.value=(0,d.pad)(n.latestSelectedDateObj?n.latestSelectedDateObj.getHours():n.config.time_24hr?e.hours:function(e){switch(e%24){case 0:case 12:return 12;default:return e%12}}(e.hours)),n.minuteElement.value=(0,d.pad)(n.latestSelectedDateObj?n.latestSelectedDateObj.getMinutes():e.minutes),n.hourElement.setAttribute(\"step\",n.config.hourIncrement.toString()),n.minuteElement.setAttribute(\"step\",n.config.minuteIncrement.toString()),n.hourElement.setAttribute(\"min\",n.config.time_24hr?\"0\":\"1\"),n.hourElement.setAttribute(\"max\",n.config.time_24hr?\"23\":\"12\"),n.hourElement.setAttribute(\"maxlength\",\"2\"),n.minuteElement.setAttribute(\"min\",\"0\"),n.minuteElement.setAttribute(\"max\",\"59\"),n.minuteElement.setAttribute(\"maxlength\",\"2\"),n.timeContainer.appendChild(a),n.timeContainer.appendChild(t),n.timeContainer.appendChild(i),n.config.time_24hr&&n.timeContainer.classList.add(\"time24hr\");if(n.config.enableSeconds){n.timeContainer.classList.add(\"hasSeconds\");var o=(0,u.createNumberInput)(\"flatpickr-second\");n.secondElement=o.getElementsByTagName(\"input\")[0],n.secondElement.value=(0,d.pad)(n.latestSelectedDateObj?n.latestSelectedDateObj.getSeconds():e.seconds),n.secondElement.setAttribute(\"step\",n.minuteElement.getAttribute(\"step\")),n.secondElement.setAttribute(\"min\",\"0\"),n.secondElement.setAttribute(\"max\",\"59\"),n.secondElement.setAttribute(\"maxlength\",\"2\"),n.timeContainer.appendChild((0,u.createElement)(\"span\",\"flatpickr-time-separator\",\":\")),n.timeContainer.appendChild(o)}n.config.time_24hr||(n.amPM=(0,u.createElement)(\"span\",\"flatpickr-am-pm\",n.l10n.amPM[(0,d.int)((n.latestSelectedDateObj?n.hourElement.value:n.config.defaultHour)>11)]),n.amPM.title=n.l10n.toggleTitle,n.amPM.tabIndex=-1,n.timeContainer.appendChild(n.amPM));return n.timeContainer}());(0,u.toggleClass)(n.calendarContainer,\"rangeMode\",\"range\"===n.config.mode),(0,u.toggleClass)(n.calendarContainer,\"animate\",!0===n.config.animate),(0,u.toggleClass)(n.calendarContainer,\"multiMonth\",n.config.showMonths>1),n.calendarContainer.appendChild(e);var o=void 0!==n.config.appendTo&&void 0!==n.config.appendTo.nodeType;if((n.config.inline||n.config.static)&&(n.calendarContainer.classList.add(n.config.inline?\"inline\":\"static\"),n.config.inline&&(!o&&n.element.parentNode?n.element.parentNode.insertBefore(n.calendarContainer,n._input.nextSibling):void 0!==n.config.appendTo&&n.config.appendTo.appendChild(n.calendarContainer)),n.config.static)){var r=(0,u.createElement)(\"div\",\"flatpickr-wrapper\");n.element.parentNode&&n.element.parentNode.insertBefore(r,n.element),r.appendChild(n.element),n.altInput&&r.appendChild(n.altInput),r.appendChild(n.calendarContainer)}n.config.static||n.config.inline||(void 0!==n.config.appendTo?n.config.appendTo:window.document.body).appendChild(n.calendarContainer)}(),function(){n.config.wrap&&[\"open\",\"close\",\"toggle\",\"clear\"].forEach((function(e){Array.prototype.forEach.call(n.element.querySelectorAll(\"[data-\"+e+\"]\"),(function(t){return M(t,\"click\",n[e])}))}));if(n.isMobile)return void function(){var e=n.config.enableTime?n.config.noCalendar?\"time\":\"datetime-local\":\"date\";n.mobileInput=(0,u.createElement)(\"input\",n.input.className+\" flatpickr-mobile\"),n.mobileInput.tabIndex=1,n.mobileInput.type=e,n.mobileInput.disabled=n.input.disabled,n.mobileInput.required=n.input.required,n.mobileInput.placeholder=n.input.placeholder,n.mobileFormatStr=\"datetime-local\"===e?\"Y-m-d\\\\TH:i:S\":\"date\"===e?\"Y-m-d\":\"H:i:S\",n.selectedDates.length>0&&(n.mobileInput.defaultValue=n.mobileInput.value=n.formatDate(n.selectedDates[0],n.mobileFormatStr));n.config.minDate&&(n.mobileInput.min=n.formatDate(n.config.minDate,\"Y-m-d\"));n.config.maxDate&&(n.mobileInput.max=n.formatDate(n.config.maxDate,\"Y-m-d\"));n.input.getAttribute(\"step\")&&(n.mobileInput.step=String(n.input.getAttribute(\"step\")));n.input.type=\"hidden\",void 0!==n.altInput&&(n.altInput.type=\"hidden\");try{n.input.parentNode&&n.input.parentNode.insertBefore(n.mobileInput,n.input.nextSibling)}catch(e){}M(n.mobileInput,\"change\",(function(e){n.setDate((0,u.getEventTarget)(e).value,!1,n.mobileFormatStr),ie(\"onChange\"),ie(\"onClose\")}))}();var e=(0,d.debounce)(U,50);n._debouncedChange=(0,d.debounce)(y,g),n.daysContainer&&!/iPhone|iPad|iPod/i.test(navigator.userAgent)&&M(n.daysContainer,\"mouseover\",(function(e){\"range\"===n.config.mode&&J((0,u.getEventTarget)(e))}));M(n._input,\"keydown\",q),void 0!==n.calendarContainer&&M(n.calendarContainer,\"keydown\",q);n.config.inline||n.config.static||M(window,\"resize\",e);void 0!==window.ontouchstart?M(window.document,\"touchstart\",H):M(window.document,\"mousedown\",H);M(window.document,\"focus\",H,{capture:!0}),!0===n.config.clickOpens&&(M(n._input,\"focus\",n.open),M(n._input,\"click\",n.open));void 0!==n.daysContainer&&(M(n.monthNav,\"click\",de),M(n.monthNav,[\"keyup\",\"increment\"],b),M(n.daysContainer,\"click\",Z));if(void 0!==n.timeContainer&&void 0!==n.minuteElement&&void 0!==n.hourElement){var t=function(e){return(0,u.getEventTarget)(e).select()};M(n.timeContainer,[\"increment\"],p),M(n.timeContainer,\"blur\",p,{capture:!0}),M(n.timeContainer,\"click\",E),M([n.hourElement,n.minuteElement],[\"focus\",\"click\"],t),void 0!==n.secondElement&&M(n.secondElement,\"focus\",(function(){return n.secondElement&&n.secondElement.select()})),void 0!==n.amPM&&M(n.amPM,\"click\",(function(e){p(e)}))}n.config.allowInput&&M(n._input,\"blur\",K)}(),(n.selectedDates.length||n.config.noCalendar)&&(n.config.enableTime&&D(n.config.noCalendar?n.latestSelectedDateObj:void 0),se(!1)),o();var a=/^((?!chrome|android).)*safari/i.test(navigator.userAgent);!n.isMobile&&a&&X(),ie(\"onReady\")}(),n}function h(e,t){for(var n=Array.prototype.slice.call(e).filter((function(e){return e instanceof HTMLElement})),a=[],i=0;i\",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}},\n", - " 569: function _(e,r,a,n,t){n(),a.english={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 r=e%100;if(r>3&&r<21)return\"th\";switch(r%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},a.default=a.english},\n", - " 570: function _(n,t,r,i,u){i();r.pad=function(n,t){return void 0===t&&(t=2),(\"000\"+n).slice(-1*t)};r.int=function(n){return!0===n?1:0},r.debounce=function(n,t){var r;return function(){var i=this,u=arguments;clearTimeout(r),r=setTimeout((function(){return n.apply(i,u)}),t)}};r.arrayify=function(n){return n instanceof Array?n:[n]}},\n", - " 571: function _(t,e,n,r,a){function i(t,e,n){var r=window.document.createElement(t);return e=e||\"\",n=n||\"\",r.className=e,void 0!==n&&(r.textContent=n),r}r(),n.toggleClass=function(t,e,n){if(!0===n)return t.classList.add(e);t.classList.remove(e)},n.createElement=i,n.clearNode=function(t){for(;t.firstChild;)t.removeChild(t.firstChild)},n.findParent=function t(e,n){return n(e)?e:e.parentNode?t(e.parentNode,n):void 0},n.createNumberInput=function(t,e){var n=i(\"div\",\"numInputWrapper\"),r=i(\"input\",\"numInput \"+t),a=i(\"span\",\"arrowUp\"),o=i(\"span\",\"arrowDown\");if(-1===navigator.userAgent.indexOf(\"MSIE 9.0\")?r.type=\"number\":(r.type=\"text\",r.pattern=\"\\\\d*\"),void 0!==e)for(var d in e)r.setAttribute(d,e[d]);return n.appendChild(r),n.appendChild(a),n.appendChild(o),n},n.getEventTarget=function(t){try{return\"function\"==typeof t.composedPath?t.composedPath()[0]:t.target}catch(e){return t.target}}},\n", - " 572: function _(e,t,n,a,r){a();const i=e(573),o=e(568),s=e(569);n.createDateFormatter=function(e){var t=e.config,n=void 0===t?o.defaults:t,a=e.l10n,r=void 0===a?s.english:a,u=e.isMobile,f=void 0!==u&&u;return function(e,t,a){var o=a||r;return void 0===n.formatDate||f?t.split(\"\").map((function(t,a,r){return i.formats[t]&&\"\\\\\"!==r[a-1]?i.formats[t](e,o,n):\"\\\\\"!==t?t:\"\"})).join(\"\"):n.formatDate(e,t,o)}};n.createDateParser=function(e){var t=e.config,n=void 0===t?o.defaults:t,a=e.l10n,r=void 0===a?s.english:a;return function(e,t,a,s){if(0===e||e){var u,f=s||r,d=e;if(e instanceof Date)u=new Date(e.getTime());else if(\"string\"!=typeof e&&void 0!==e.toFixed)u=new Date(e);else if(\"string\"==typeof e){var c=t||(n||o.defaults).dateFormat,g=String(e).trim();if(\"today\"===g)u=new Date,a=!0;else if(n&&n.parseDate)u=n.parseDate(e,c);else if(/Z$/.test(g)||/GMT$/.test(g))u=new Date(e);else{for(var m=void 0,l=[],v=0,D=0,h=\"\";vMath.min(t,n)&&e=12?12:0)+parseFloat(n))},H:function(t,n){t.setHours(parseFloat(n))},J:function(t,n){t.setDate(parseFloat(n))},K:function(t,n,e){t.setHours(t.getHours()%12+12*(0,u.int)(new RegExp(e.amPM[1],\"i\").test(n)))},M:function(t,n,e){t.setMonth(e.months.shorthand.indexOf(n))},S:function(t,n){t.setSeconds(parseFloat(n))},U:function(t,n){return new Date(1e3*parseFloat(n))},W:function(t,n,e){var o=parseInt(n),r=new Date(t.getFullYear(),0,2+7*(o-1),0,0,0,0);return r.setDate(r.getDate()-r.getDay()+e.firstDayOfWeek),r},Y:function(t,n){t.setFullYear(parseFloat(n))},Z:function(t,n){return new Date(n)},d:function(t,n){t.setDate(parseFloat(n))},h:function(t,n){t.setHours((t.getHours()>=12?12:0)+parseFloat(n))},i:function(t,n){t.setMinutes(parseFloat(n))},j:function(t,n){t.setDate(parseFloat(n))},l:a,m:function(t,n){t.setMonth(parseFloat(n)-1)},n:function(t,n){t.setMonth(parseFloat(n)-1)},s:function(t,n){t.setSeconds(parseFloat(n))},u:function(t,n){return new Date(parseFloat(n))},w:a,y:function(t,n){t.setFullYear(2e3+parseFloat(n))}},e.tokenRegex={D:\"\",F:\"\",G:\"(\\\\d\\\\d|\\\\d)\",H:\"(\\\\d\\\\d|\\\\d)\",J:\"(\\\\d\\\\d|\\\\d)\\\\w+\",K:\"\",M:\"\",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:\"\",m:\"(\\\\d\\\\d|\\\\d)\",n:\"(\\\\d\\\\d|\\\\d)\",s:\"(\\\\d\\\\d|\\\\d)\",u:\"(.+)\",w:\"(\\\\d\\\\d|\\\\d)\",y:\"(\\\\d{2})\"},e.formats={Z:function(t){return t.toISOString()},D:function(t,n,o){return n.weekdays.shorthand[e.formats.w(t,n,o)]},F:function(t,n,o){return(0,e.monthToStr)(e.formats.n(t,n,o)-1,!1,n)},G:function(t,n,o){return(0,u.pad)(e.formats.h(t,n,o))},H:function(t){return(0,u.pad)(t.getHours())},J:function(t,n){return void 0!==n.ordinal?t.getDate()+n.ordinal(t.getDate()):t.getDate()},K:function(t,n){return n.amPM[(0,u.int)(t.getHours()>11)]},M:function(t,n){return(0,e.monthToStr)(t.getMonth(),!0,n)},S:function(t){return(0,u.pad)(t.getSeconds())},U:function(t){return t.getTime()/1e3},W:function(t,n,e){return e.getWeek(t)},Y:function(t){return(0,u.pad)(t.getFullYear(),4)},d:function(t){return(0,u.pad)(t.getDate())},h:function(t){return t.getHours()%12?t.getHours()%12:12},i:function(t){return(0,u.pad)(t.getMinutes())},j:function(t){return t.getDate()},l:function(t,n){return n.weekdays.longhand[t.getDay()]},m:function(t){return(0,u.pad)(t.getMonth()+1)},n:function(t){return t.getMonth()+1},s:function(t){return t.getSeconds()},u:function(t){return t.getTime()},w:function(t){return t.getDay()},y:function(t){return String(t.getFullYear()).substring(2)}}},\n", - " 574: function _(n,t,o,r,e){\"function\"!=typeof Object.assign&&(Object.assign=function(n){for(var t=[],o=1;o({value:[a(e(l.DateLike,l.DateLike)),null]})))},\n", - " 577: function _(e,t,a,i,r){var s;i();const n=e(565);class c extends n.BaseDatePickerView{get flatpickr_options(){return Object.assign(Object.assign({},super.flatpickr_options),{mode:\"multiple\",conjunction:this.model.separator})}_on_change(e){this.model.value=e.map((e=>this._format_date(e)))}}a.MultipleDatePickerView=c,c.__name__=\"MultipleDatePickerView\";class l extends n.BaseDatePicker{constructor(e){super(e)}}a.MultipleDatePicker=l,s=l,l.__name__=\"MultipleDatePicker\",s.prototype.default_view=c,s.define((({String:e,Array:t})=>({value:[t(n.DateLike),[]],separator:[e,\", \"]})))},\n", - " 578: function _(e,t,a,i,s){var n;i();const l=e(579),c=e(565),r=e(12);class o extends l.BaseDatetimePickerView{get flatpickr_options(){return Object.assign(Object.assign({},super.flatpickr_options),{mode:\"single\"})}_on_change(e){switch(e.length){case 0:this.model.value=null;break;case 1:{const[t]=e,a=this._format_date(t);this.model.value=a;break}default:(0,r.assert)(!1,\"invalid length\")}}}a.DatetimePickerView=o,o.__name__=\"DatetimePickerView\";class _ extends l.BaseDatetimePicker{constructor(e){super(e)}}a.DatetimePicker=_,n=_,_.__name__=\"DatetimePicker\",n.prototype.default_view=o,n.define((({Nullable:e})=>({value:[e(c.DateLike),null]})))},\n", - " 579: function _(e,t,n,c,i){var s;c();const r=e(565),o=e(19);class m extends r.BaseDatePickerView{connect_signals(){super.connect_signals();const{value:e,hour_increment:t,minute_increment:n,second_increment:c,seconds:i,clock:s}=this.model.properties;this.connect(e.change,(()=>{const{value:e}=this.model;null!=e?this.picker.setDate(e):this.picker.clear()})),this.connect(t.change,(()=>this.picker.set(\"hourIncrement\",this.model.hour_increment))),this.connect(n.change,(()=>this.picker.set(\"minuteIncrement\",this.model.minute_increment))),this.connect(c.change,(()=>this._update_second_increment())),this.connect(i.change,(()=>this.picker.set(\"enableSeconds\",this.model.seconds))),this.connect(s.change,(()=>this.picker.set(\"time_24hr\",\"24h\"==this.model.clock)))}get flatpickr_options(){const{hour_increment:e,minute_increment:t,seconds:n,clock:c}=this.model,i=super.flatpickr_options;return i.enableTime=!0,i.dateFormat=\"Y-m-dTH:i:S\",i.hourIncrement=e,i.minuteIncrement=t,i.enableSeconds=n,i.time_24hr=\"24h\"==c,i}render(){super.render(),this._update_second_increment()}_update_second_increment(){var e;const{second_increment:t}=this.model;null===(e=this.picker.secondElement)||void 0===e||e.setAttribute(\"step\",t.toString())}}n.BaseDatetimePickerView=m,m.__name__=\"BaseDatetimePickerView\";class a extends r.BaseDatePicker{constructor(e){super(e)}}n.BaseDatetimePicker=a,s=a,a.__name__=\"BaseDatetimePicker\",s.define((({Boolean:e,Positive:t,Int:n})=>({hour_increment:[t(n),1],minute_increment:[t(n),1],second_increment:[t(n),1],seconds:[e,!1],clock:[o.Clock,\"24h\"]}))),s.override({date_format:\"Y-m-d H:i\"})},\n", - " 580: function _(e,t,a,i,s){var n;i();const l=e(579),r=e(565),c=e(12);class o extends l.BaseDatetimePickerView{get flatpickr_options(){return Object.assign(Object.assign({},super.flatpickr_options),{mode:\"range\"})}_on_change(e){switch(e.length){case 0:this.model.value=null;break;case 1:{const[t]=e,a=this._format_date(t);this.model.value=[a,a];break}case 2:{const[t,a]=e,i=this._format_date(t),s=this._format_date(a);this.model.value=[i,s];break}default:(0,c.assert)(!1,\"invalid length\")}}}a.DatetimeRangePickerView=o,o.__name__=\"DatetimeRangePickerView\";class _ extends l.BaseDatetimePicker{constructor(e){super(e)}}a.DatetimeRangePicker=_,n=_,_.__name__=\"DatetimeRangePicker\",n.prototype.default_view=o,n.define((({Nullable:e,Tuple:t})=>({value:[e(t(r.DateLike,r.DateLike)),null]})))},\n", - " 581: function _(e,t,i,a,r){var s;a();const n=e(579),c=e(565);class l extends n.BaseDatetimePickerView{get flatpickr_options(){return Object.assign(Object.assign({},super.flatpickr_options),{mode:\"multiple\",conjunction:this.model.separator})}_on_change(e){this.model.value=e.map((e=>this._format_date(e)))}}i.MultipleDatetimePickerView=l,l.__name__=\"MultipleDatetimePickerView\";class o extends n.BaseDatetimePicker{constructor(e){super(e)}}i.MultipleDatetimePicker=o,s=o,o.__name__=\"MultipleDatetimePicker\",s.prototype.default_view=l,s.define((({String:e,Array:t})=>({value:[t(c.DateLike),[]],separator:[e,\", \"]})))},\n", - " 582: function _(e,t,n,i,c){var s;i();const m=e(566),r=e(20),o=e(19),a=e(12);n.TimeLike=(0,r.Or)(r.String,r.Number);class l extends m.PickerBaseView{_format_time(e){const{picker:t}=this;return t.formatDate(e,t.config.dateFormat)}connect_signals(){super.connect_signals();const{value:e,min_time:t,max_time:n,time_format:i,hour_increment:c,minute_increment:s,second_increment:m,seconds:r,clock:o}=this.model.properties;this.connect(e.change,(()=>{const{value:e}=this.model;null!=e?this.picker.setDate(e):this.picker.clear()})),this.connect(t.change,(()=>this.picker.set(\"minTime\",this.model.min_time))),this.connect(n.change,(()=>this.picker.set(\"maxTime\",this.model.max_time))),this.connect(i.change,(()=>this.picker.set(\"altFormat\",this.model.time_format))),this.connect(c.change,(()=>this.picker.set(\"hourIncrement\",this.model.hour_increment))),this.connect(s.change,(()=>this.picker.set(\"minuteIncrement\",this.model.minute_increment))),this.connect(m.change,(()=>this._update_second_increment())),this.connect(r.change,(()=>this.picker.set(\"enableSeconds\",this.model.seconds))),this.connect(o.change,(()=>this.picker.set(\"time_24hr\",\"24h\"==this.model.clock)))}get flatpickr_options(){const{value:e,min_time:t,max_time:n,time_format:i,hour_increment:c,minute_increment:s,seconds:m,clock:r}=this.model,o=super.flatpickr_options;return o.enableTime=!0,o.noCalendar=!0,o.altInput=!0,o.altFormat=i,o.dateFormat=\"H:i:S\",o.hourIncrement=c,o.minuteIncrement=s,o.enableSeconds=m,o.time_24hr=\"24h\"==r,null!=e&&(o.defaultDate=e),null!=t&&(o.minTime=t),null!=n&&(o.maxTime=n),o}render(){super.render(),this._update_second_increment()}_update_second_increment(){var e;const{second_increment:t}=this.model;null===(e=this.picker.secondElement)||void 0===e||e.setAttribute(\"step\",t.toString())}_on_change(e){switch(e.length){case 0:this.model.value=null;break;case 1:{const[t]=e,n=this._format_time(t);this.model.value=n;break}default:(0,a.assert)(!1,\"invalid length\")}}}n.TimePickerView=l,l.__name__=\"TimePickerView\";class h extends m.PickerBase{constructor(e){super(e)}}n.TimePicker=h,s=h,h.__name__=\"TimePicker\",s.prototype.default_view=l,s.define((({Boolean:e,String:t,Nullable:i,Positive:c,Int:s})=>({value:[i(n.TimeLike),null],min_time:[i(n.TimeLike),null],max_time:[i(n.TimeLike),null],time_format:[t,\"H:i\"],hour_increment:[c(s),1],minute_increment:[c(s),1],second_increment:[c(s),1],seconds:[e,!1],clock:[o.Clock,\"24h\"]})))},\n", - " 583: function _(e,t,a,r,n){var s;r();const i=e(1).__importDefault(e(173)),d=e(584),o=e(8);class l extends d.AbstractRangeSliderView{_calc_to(){const{start:e,end:t,value:a,step:r}=this.model;return{start:e,end:t,value:a,step:864e5*r}}}a.DateRangeSliderView=l,l.__name__=\"DateRangeSliderView\";class _ extends d.AbstractSlider{constructor(e){super(e),this.behaviour=\"drag\",this.connected=[!1,!0,!1]}_formatter(e,t){return(0,o.isString)(t)?(0,i.default)(e,t):t.compute(e)}}a.DateRangeSlider=_,s=_,_.__name__=\"DateRangeSlider\",s.prototype.default_view=l,s.override({format:\"%d %b %Y\"})},\n", - " 584: function _(t,e,s,i,l){var o;i();const r=t(1),n=r.__importDefault(t(585)),_=r.__importStar(t(17)),a=t(56),d=t(10),h=t(21),c=t(557),u=t(162),m=r.__importStar(t(586)),p=m,g=r.__importDefault(t(587)),b=r.__importStar(t(552));class v extends c.OrientedControlView{constructor(){super(...arguments),this._auto_width=\"auto\",this._auto_height=\"auto\"}*controls(){yield this.slider_el}get _steps(){return this._noUiSlider.steps}connect_signals(){super.connect_signals();const{direction:t,orientation:e,tooltips:s}=this.model.properties;this.on_change([t,e,s],(()=>this.render()));const{start:i,end:l,value:o,step:r,title:n}=this.model.properties;this.on_change([i,l,o,r],(()=>{const{start:t,end:e,value:s,step:i}=this._calc_to();this._noUiSlider.updateOptions({range:{min:t,max:e},start:s,step:i},!0)}));const{bar_color:_}=this.model.properties;this.on_change(_,(()=>{this._set_bar_color()}));const{show_value:a}=this.model.properties;this.on_change([o,n,a],(()=>this._update_title()))}stylesheets(){return[...super.stylesheets(),g.default,m.default]}_update_title(){(0,a.empty)(this.title_el);const t=null==this.model.title||0==this.model.title.length&&!this.model.show_value;if(this.title_el.style.display=t?\"none\":\"\",!t){const{title:t}=this.model;if(null!=t&&t.length>0&&(this.contains_tex_string(t)?this.title_el.innerHTML=`${this.process_tex(t)}: `:this.title_el.textContent=`${t}: `),this.model.show_value){const{value:t}=this._calc_to(),e=t.map((t=>this.model.pretty(t))).join(\" .. \");this.title_el.appendChild((0,a.span)({class:p.slider_value},e))}}}_set_bar_color(){if(!this.model.disabled&&null!=this.slider_el){this.slider_el.querySelector(\".noUi-connect\").style.backgroundColor=(0,h.color2css)(this.model.bar_color)}}render(){super.render();const{start:t,end:e,value:s,step:i}=this._calc_to();let l;if(this.model.tooltips){const t={to:t=>this.model.pretty(t)};l=(0,d.repeat)(t,s.length)}else l=null;if(null==this.slider_el){this.slider_el=(0,a.div)(),this._noUiSlider=n.default.create(this.slider_el,{range:{min:t,max:e},start:s,step:i,behaviour:this.model.behaviour,connect:this.model.connected,tooltips:null!=l&&l,orientation:this.model.orientation,direction:this.model.direction}),this._noUiSlider.on(\"slide\",((t,e,s)=>this._slide(s))),this._noUiSlider.on(\"change\",((t,e,s)=>this._change(s)));const o=(t,e)=>{if(null==l||null==this.slider_el)return;this.slider_el.querySelectorAll(\".noUi-handle\")[t].querySelector(\".noUi-tooltip\").style.display=e?\"block\":\"\"};this._noUiSlider.on(\"start\",(()=>this._toggle_user_select(!1))),this._noUiSlider.on(\"end\",(()=>this._toggle_user_select(!0))),this._noUiSlider.on(\"start\",((t,e)=>o(e,!0))),this._noUiSlider.on(\"end\",((t,e)=>o(e,!1)))}else this._noUiSlider.updateOptions({range:{min:t,max:e},start:s,step:i},!0);this._set_bar_color(),this.model.disabled?this.slider_el.setAttribute(\"disabled\",\"true\"):this.slider_el.removeAttribute(\"disabled\"),this.title_el=(0,a.div)({class:p.slider_title}),this._update_title(),this.group_el=(0,a.div)({class:b.input_group},this.title_el,this.slider_el),this.shadow_el.appendChild(this.group_el),this._has_finished=!0}_toggle_user_select(t){const{style:e}=document.body,s=t?\"\":\"none\";e.userSelect=s,e.webkitUserSelect=s}_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})}}v.__name__=\"AbstractBaseSliderView\";class S extends v{_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}}s.AbstractSliderView=S,S.__name__=\"AbstractSliderView\";class f extends v{_calc_to(){return{start:this.model.start,end:this.model.end,value:this.model.value,step:this.model.step}}_calc_from(t){return t}}s.AbstractRangeSliderView=f,f.__name__=\"AbstractRangeSliderView\";class y extends c.OrientedControl{constructor(t){super(t),this.connected=!1}pretty(t){return this._formatter(t,this.format)}}s.AbstractSlider=y,o=y,y.__name__=\"AbstractSlider\",o.define((({Any:t,Boolean:e,Number:s,String:i,Color:l,Or:o,Enum:r,Ref:n,Nullable:a})=>({title:[a(i),\"\"],show_value:[e,!0],start:[t],end:[t],value:[t],value_throttled:[t,_.unset,{readonly:!0}],step:[s,1],format:[o(i,n(u.TickFormatter))],direction:[r(\"ltr\",\"rtl\"),\"ltr\"],tooltips:[e,!0],bar_color:[l,\"#e6e6e6\"]}))),o.override({width:300})},\n", - " 585: function _(t,e,r,n,i){var o,s;o=this,s=function(t){\"use strict\";var e,r;function n(t){return\"object\"==typeof t&&\"function\"==typeof t.to}function i(t){t.parentElement.removeChild(t)}function o(t){return null!=t}function s(t){t.preventDefault()}function a(t){return\"number\"==typeof t&&!isNaN(t)&&isFinite(t)}function l(t,e,r){r>0&&(f(t,e),setTimeout((function(){d(t,e)}),r))}function u(t){return Math.max(Math.min(t,100),0)}function c(t){return Array.isArray(t)?t:[t]}function p(t){var e=(t=String(t)).split(\".\");return e.length>1?e[1].length:0}function f(t,e){t.classList&&!/\\s/.test(e)?t.classList.add(e):t.className+=\" \"+e}function d(t,e){t.classList&&!/\\s/.test(e)?t.classList.remove(e):t.className=t.className.replace(new RegExp(\"(^|\\\\b)\"+e.split(\" \").join(\"|\")+\"(\\\\b|$)\",\"gi\"),\" \")}function h(t){var e=void 0!==window.pageXOffset,r=\"CSS1Compat\"===(t.compatMode||\"\");return{x:e?window.pageXOffset:r?t.documentElement.scrollLeft:t.body.scrollLeft,y:e?window.pageYOffset:r?t.documentElement.scrollTop:t.body.scrollTop}}function m(t,e){return 100/(e-t)}function g(t,e,r){return 100*e/(t[r+1]-t[r])}function v(t,e){for(var r=1;t>=e[r];)r+=1;return r}function b(t,e,r){if(r>=t.slice(-1)[0])return 100;var n=v(r,t),i=t[n-1],o=t[n],s=e[n-1],a=e[n];return s+function(t,e){return g(t,t[0]<0?e+Math.abs(t[0]):e-t[0],0)}([i,o],r)/m(s,a)}function S(t,e,r,n){if(100===n)return n;var i=v(n,t),o=t[i-1],s=t[i];return r?n-o>(s-o)/2?s:o:e[i-1]?t[i-1]+function(t,e){return Math.round(t/e)*e}(n-t[i-1],e[i-1]):n}t.PipsMode=void 0,(e=t.PipsMode||(t.PipsMode={})).Range=\"range\",e.Steps=\"steps\",e.Positions=\"positions\",e.Count=\"count\",e.Values=\"values\",t.PipsType=void 0,(r=t.PipsType||(t.PipsType={}))[r.None=-1]=\"None\",r[r.NoValue=0]=\"NoValue\",r[r.LargeValue=1]=\"LargeValue\",r[r.SmallValue=2]=\"SmallValue\";var x=function(){function t(t,e,r){var n;this.xPct=[],this.xVal=[],this.xSteps=[],this.xNumSteps=[],this.xHighestCompleteStep=[],this.xSteps=[r||!1],this.xNumSteps=[!1],this.snap=e;var i=[];for(Object.keys(t).forEach((function(e){i.push([c(t[e]),e])})),i.sort((function(t,e){return t[0][0]-e[0][0]})),n=0;nthis.xPct[i+1];)i++;else t===this.xPct[this.xPct.length-1]&&(i=this.xPct.length-2);r||t!==this.xPct[i+1]||i++,null===e&&(e=[]);var o=1,s=e[i],a=0,l=0,u=0,c=0;for(n=r?(t-this.xPct[i])/(this.xPct[i+1]-this.xPct[i]):(this.xPct[i+1]-t)/(this.xPct[i+1]-this.xPct[i]);s>0;)a=this.xPct[i+1+c]-this.xPct[i+c],e[i+c]*o+100-100*n>100?(l=a*n,o=(s-100*n)/e[i+c],n=1):(l=e[i+c]*a/100*o,o=0),r?(u-=l,this.xPct.length+c>=1&&c--):(u+=l,this.xPct.length-c>=1&&c++),s=e[i+c]*o;return t+u},t.prototype.toStepping=function(t){return t=b(this.xVal,this.xPct,t)},t.prototype.fromStepping=function(t){return function(t,e,r){if(r>=100)return t.slice(-1)[0];var n=v(r,e),i=t[n-1],o=t[n],s=e[n-1];return function(t,e){return e*(t[1]-t[0])/100+t[0]}([i,o],(r-s)*m(s,e[n]))}(this.xVal,this.xPct,t)},t.prototype.getStep=function(t){return t=S(this.xPct,this.xSteps,this.snap,t)},t.prototype.getDefaultStep=function(t,e,r){var n=v(t,this.xPct);return(100===t||e&&t===this.xPct[n-1])&&(n=Math.max(n-1,1)),(this.xVal[n]-this.xVal[n-1])/r},t.prototype.getNearbySteps=function(t){var e=v(t,this.xPct);return{stepBefore:{startValue:this.xVal[e-2],step:this.xNumSteps[e-2],highestStep:this.xHighestCompleteStep[e-2]},thisStep:{startValue:this.xVal[e-1],step:this.xNumSteps[e-1],highestStep:this.xHighestCompleteStep[e-1]},stepAfter:{startValue:this.xVal[e],step:this.xNumSteps[e],highestStep:this.xHighestCompleteStep[e]}}},t.prototype.countStepDecimals=function(){var t=this.xNumSteps.map(p);return Math.max.apply(null,t)},t.prototype.hasNoSize=function(){return this.xVal[0]===this.xVal[this.xVal.length-1]},t.prototype.convert=function(t){return this.getStep(this.toStepping(t))},t.prototype.handleEntryPoint=function(t,e){var r;if(!a(r=\"min\"===t?0:\"max\"===t?100:parseFloat(t))||!a(e[0]))throw new Error(\"noUiSlider: 'range' value isn't numeric.\");this.xPct.push(r),this.xVal.push(e[0]);var n=Number(e[1]);r?this.xSteps.push(!isNaN(n)&&n):isNaN(n)||(this.xSteps[0]=n),this.xHighestCompleteStep.push(0)},t.prototype.handleStepPoint=function(t,e){if(e)if(this.xVal[t]!==this.xVal[t+1]){this.xSteps[t]=g([this.xVal[t],this.xVal[t+1]],e,0)/m(this.xPct[t],this.xPct[t+1]);var r=(this.xVal[t+1]-this.xVal[t])/this.xNumSteps[t],n=Math.ceil(Number(r.toFixed(3))-1),i=this.xVal[t]+this.xNumSteps[t]*n;this.xHighestCompleteStep[t]=i}else this.xSteps[t]=this.xHighestCompleteStep[t]=this.xVal[t]},t}(),y={to:function(t){return void 0===t?\"\":t.toFixed(2)},from:Number},w={target:\"target\",base:\"base\",origin:\"origin\",handle:\"handle\",handleLower:\"handle-lower\",handleUpper:\"handle-upper\",touchArea:\"touch-area\",horizontal:\"horizontal\",vertical:\"vertical\",background:\"background\",connect:\"connect\",connects:\"connects\",ltr:\"ltr\",rtl:\"rtl\",textDirectionLtr:\"txt-dir-ltr\",textDirectionRtl:\"txt-dir-rtl\",draggable:\"draggable\",drag:\"state-drag\",tap:\"state-tap\",active:\"active\",tooltip:\"tooltip\",pips:\"pips\",pipsHorizontal:\"pips-horizontal\",pipsVertical:\"pips-vertical\",marker:\"marker\",markerHorizontal:\"marker-horizontal\",markerVertical:\"marker-vertical\",markerNormal:\"marker-normal\",markerLarge:\"marker-large\",markerSub:\"marker-sub\",value:\"value\",valueHorizontal:\"value-horizontal\",valueVertical:\"value-vertical\",valueNormal:\"value-normal\",valueLarge:\"value-large\",valueSub:\"value-sub\"},E={tooltips:\".__tooltips\",aria:\".__aria\"};function P(t,e){if(!a(e))throw new Error(\"noUiSlider: 'step' is not numeric.\");t.singleStep=e}function C(t,e){if(!a(e))throw new Error(\"noUiSlider: 'keyboardPageMultiplier' is not numeric.\");t.keyboardPageMultiplier=e}function N(t,e){if(!a(e))throw new Error(\"noUiSlider: 'keyboardMultiplier' is not numeric.\");t.keyboardMultiplier=e}function V(t,e){if(!a(e))throw new Error(\"noUiSlider: 'keyboardDefaultStep' is not numeric.\");t.keyboardDefaultStep=e}function A(t,e){if(\"object\"!=typeof e||Array.isArray(e))throw new Error(\"noUiSlider: 'range' is not an object.\");if(void 0===e.min||void 0===e.max)throw new Error(\"noUiSlider: Missing 'min' or 'max' in 'range'.\");t.spectrum=new x(e,t.snap||!1,t.singleStep)}function k(t,e){if(e=c(e),!Array.isArray(e)||!e.length)throw new Error(\"noUiSlider: 'start' option is incorrect.\");t.handles=e.length,t.start=e}function M(t,e){if(\"boolean\"!=typeof e)throw new Error(\"noUiSlider: 'snap' option must be a boolean.\");t.snap=e}function U(t,e){if(\"boolean\"!=typeof e)throw new Error(\"noUiSlider: 'animate' option must be a boolean.\");t.animate=e}function D(t,e){if(\"number\"!=typeof e)throw new Error(\"noUiSlider: 'animationDuration' option must be a number.\");t.animationDuration=e}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: 'padding' option must not exceed 100% of the range.\")}}function H(t,e){switch(e){case\"ltr\":t.dir=0;break;case\"rtl\":t.dir=1;break;default:throw new Error(\"noUiSlider: 'direction' option was not recognized.\")}}function F(t,e){if(\"string\"!=typeof e)throw new Error(\"noUiSlider: 'behaviour' must be a string containing options.\");var r=e.indexOf(\"tap\")>=0,n=e.indexOf(\"drag\")>=0,i=e.indexOf(\"fixed\")>=0,o=e.indexOf(\"snap\")>=0,s=e.indexOf(\"hover\")>=0,a=e.indexOf(\"unconstrained\")>=0,l=e.indexOf(\"drag-all\")>=0,u=e.indexOf(\"smooth-steps\")>=0;if(i){if(2!==t.handles)throw new Error(\"noUiSlider: 'fixed' behaviour must be used with 2 handles\");T(t,t.start[1]-t.start[0])}if(a&&(t.margin||t.limit))throw new Error(\"noUiSlider: 'unconstrained' behaviour cannot be used with margin or limit\");t.events={tap:r||o,drag:n,dragAll:l,smoothSteps:u,fixed:i,snap:o,hover:s,unconstrained:a}}function R(t,e){if(!1!==e)if(!0===e||n(e)){t.tooltips=[];for(var r=0;r= 2) required for mode 'count'.\");for(var r=e.values-1,n=100/r,i=[];r--;)i[r]=r*n;return i.push(100),B(i,e.stepped)}return e.mode===t.PipsMode.Positions?B(e.values,e.stepped):e.mode===t.PipsMode.Values?e.stepped?e.values.map((function(t){return P.fromStepping(P.getStep(P.toStepping(t)))})):e.values:[]}(e),i={},o=P.xVal[0],s=P.xVal[P.xVal.length-1],a=!1,l=!1,u=0;return r=n.slice().sort((function(t,e){return t-e})),(n=r.filter((function(t){return!this[t]&&(this[t]=!0)}),{}))[0]!==o&&(n.unshift(o),a=!0),n[n.length-1]!==s&&(n.push(s),l=!0),n.forEach((function(r,o){var s,c,p,f,d,h,m,g,v,b,S=r,x=n[o+1],y=e.mode===t.PipsMode.Steps;for(y&&(s=P.xNumSteps[o]),s||(s=x-S),void 0===x&&(x=S),s=Math.max(s,1e-7),c=S;c<=x;c=Number((c+s).toFixed(7))){for(g=(d=(f=P.toStepping(c))-u)/(e.density||1),b=d/(v=Math.round(g)),p=1;p<=v;p+=1)i[(h=u+p*b).toFixed(5)]=[P.fromStepping(h),0];m=n.indexOf(c)>-1?t.PipsType.LargeValue:y?t.PipsType.SmallValue:t.PipsType.NoValue,!o&&a&&c!==x&&(m=0),c===x&&l||(i[f.toFixed(5)]=[c,m]),u=f}})),i}function X(e,n,i){var o,s,a=M.createElement(\"div\"),l=((o={})[t.PipsType.None]=\"\",o[t.PipsType.NoValue]=r.cssClasses.valueNormal,o[t.PipsType.LargeValue]=r.cssClasses.valueLarge,o[t.PipsType.SmallValue]=r.cssClasses.valueSub,o),u=((s={})[t.PipsType.None]=\"\",s[t.PipsType.NoValue]=r.cssClasses.markerNormal,s[t.PipsType.LargeValue]=r.cssClasses.markerLarge,s[t.PipsType.SmallValue]=r.cssClasses.markerSub,s),c=[r.cssClasses.valueHorizontal,r.cssClasses.valueVertical],p=[r.cssClasses.markerHorizontal,r.cssClasses.markerVertical];function d(t,e){var n=e===r.cssClasses.value,i=n?l:u;return e+\" \"+(n?c:p)[r.ort]+\" \"+i[t]}return f(a,r.cssClasses.pips),f(a,0===r.ort?r.cssClasses.pipsHorizontal:r.cssClasses.pipsVertical),Object.keys(e).forEach((function(o){!function(e,o,s){if((s=n?n(o,s):s)!==t.PipsType.None){var l=L(a,!1);l.className=d(s,r.cssClasses.marker),l.style[r.style]=e+\"%\",s>t.PipsType.NoValue&&((l=L(a,!1)).className=d(s,r.cssClasses.value),l.setAttribute(\"data-value\",String(o)),l.style[r.style]=e+\"%\",l.innerHTML=String(i.to(o)))}}(o,e[o][0],e[o][1])})),a}function Y(){g&&(i(g),g=null)}function I(t){Y();var e=q(t),r=t.filter,n=t.format||{to:function(t){return String(Math.round(t))}};return g=w.appendChild(X(e,r,n))}function W(){var t=a.getBoundingClientRect(),e=\"offset\"+[\"Width\",\"Height\"][r.ort];return 0===r.ort?t.width||a[e]:t.height||a[e]}function G(t,e,n,i){var o=function(o){var s,a,l=function(t,e,r){var n=0===t.type.indexOf(\"touch\"),i=0===t.type.indexOf(\"mouse\"),o=0===t.type.indexOf(\"pointer\"),s=0,a=0;if(0===t.type.indexOf(\"MSPointer\")&&(o=!0),\"mousedown\"===t.type&&!t.buttons&&!t.touches)return!1;if(n){var l=function(e){var n=e.target;return n===r||r.contains(n)||t.composed&&t.composedPath().shift()===r};if(\"touchstart\"===t.type){var u=Array.prototype.filter.call(t.touches,l);if(u.length>1)return!1;s=u[0].pageX,a=u[0].pageY}else{var c=Array.prototype.find.call(t.changedTouches,l);if(!c)return!1;s=c.pageX,a=c.pageY}}return e=e||h(M),(i||o)&&(s=t.clientX+e.x,a=t.clientY+e.y),t.pageOffset=e,t.points=[s,a],t.cursor=i||o,t}(o,i.pageOffset,i.target||e);return!!l&&!(H()&&!i.doNotReject)&&(s=w,a=r.cssClasses.tap,!((s.classList?s.classList.contains(a):new RegExp(\"\\\\b\"+a+\"\\\\b\").test(s.className))&&!i.doNotReject)&&!(t===x.start&&void 0!==l.buttons&&l.buttons>1)&&(!i.hover||!l.buttons)&&(y||l.preventDefault(),l.calcPoint=l.points[r.ort],void n(l,i)))},s=[];return t.split(\" \").forEach((function(t){e.addEventListener(t,o,!!y&&{passive:!0}),s.push([t,o])})),s}function J(t){var e,n,i,o,s,l,c=100*(t-(e=a,n=r.ort,i=e.getBoundingClientRect(),o=e.ownerDocument,s=o.documentElement,l=h(o),/webkit.*Chrome.*Mobile/i.test(navigator.userAgent)&&(l.x=0),n?i.top+l.y-s.clientTop:i.left+l.x-s.clientLeft))/W();return c=u(c),r.dir?100-c:c}function K(t,e){\"mouseout\"===t.type&&\"HTML\"===t.target.nodeName&&null===t.relatedTarget&&Z(t,e)}function Q(t,e){if(-1===navigator.appVersion.indexOf(\"MSIE 9\")&&0===t.buttons&&0!==e.buttonsProperty)return Z(t,e);var n=(r.dir?-1:1)*(t.calcPoint-e.startCalcPoint);lt(n>0,100*n/e.baseSize,e.locations,e.handleNumbers,e.connect)}function Z(t,e){e.handle&&(d(e.handle,r.cssClasses.active),A-=1),e.listeners.forEach((function(t){U.removeEventListener(t[0],t[1])})),0===A&&(d(w,r.cssClasses.drag),ct(),t.cursor&&(D.style.cursor=\"\",D.removeEventListener(\"selectstart\",s))),r.events.smoothSteps&&(e.handleNumbers.forEach((function(t){pt(t,N[t],!0,!0,!1,!1)})),e.handleNumbers.forEach((function(t){ot(\"update\",t)}))),e.handleNumbers.forEach((function(t){ot(\"change\",t),ot(\"set\",t),ot(\"end\",t)}))}function tt(t,e){if(!e.handleNumbers.some(F)){var n;1===e.handleNumbers.length&&(n=p[e.handleNumbers[0]].children[0],A+=1,f(n,r.cssClasses.active)),t.stopPropagation();var i=[],o=G(x.move,U,Q,{target:t.target,handle:n,connect:e.connect,listeners:i,startCalcPoint:t.calcPoint,baseSize:W(),pageOffset:t.pageOffset,handleNumbers:e.handleNumbers,buttonsProperty:t.buttons,locations:N.slice()}),a=G(x.end,U,Z,{target:t.target,handle:n,listeners:i,doNotReject:!0,handleNumbers:e.handleNumbers}),l=G(\"mouseout\",U,K,{target:t.target,handle:n,listeners:i,doNotReject:!0,handleNumbers:e.handleNumbers});i.push.apply(i,o.concat(a,l)),t.cursor&&(D.style.cursor=getComputedStyle(t.target).cursor,p.length>1&&f(w,r.cssClasses.drag),D.addEventListener(\"selectstart\",s,!1)),e.handleNumbers.forEach((function(t){ot(\"start\",t)}))}}function et(t){t.stopPropagation();var e=J(t.calcPoint),n=function(t){var e=100,r=!1;return p.forEach((function(n,i){if(!F(i)){var o=N[i],s=Math.abs(o-t);(so||100===s&&100===e)&&(r=i,e=s)}})),r}(e);!1!==n&&(r.events.snap||l(w,r.cssClasses.tap,r.animationDuration),pt(n,e,!0,!0),ct(),ot(\"slide\",n,!0),ot(\"update\",n,!0),r.events.snap?tt(t,{handleNumbers:[n]}):(ot(\"change\",n,!0),ot(\"set\",n,!0)))}function rt(t){var e=J(t.calcPoint),r=P.getStep(e),n=P.fromStepping(r);Object.keys(k).forEach((function(t){\"hover\"===t.split(\".\")[0]&&k[t].forEach((function(t){t.call(vt,n)}))}))}function nt(t,e){k[t]=k[t]||[],k[t].push(e),\"update\"===t.split(\".\")[0]&&p.forEach((function(t,e){ot(\"update\",e)}))}function it(t){var e=t&&t.split(\".\")[0],r=e?t.substring(e.length):t;Object.keys(k).forEach((function(t){var n=t.split(\".\")[0],i=t.substring(n.length);e&&e!==n||r&&r!==i||function(t){return t===E.aria||t===E.tooltips}(i)&&r!==i||delete k[t]}))}function ot(t,e,n){Object.keys(k).forEach((function(i){var o=i.split(\".\")[0];t===o&&k[i].forEach((function(t){t.call(vt,C.map(r.format.to),e,C.slice(),n||!1,N.slice(),vt)}))}))}function st(t,e,n,i,o,s,a){var l;return p.length>1&&!r.events.unconstrained&&(i&&e>0&&(l=P.getAbsoluteDistance(t[e-1],r.margin,!1),n=Math.max(n,l)),o&&e1&&r.limit&&(i&&e>0&&(l=P.getAbsoluteDistance(t[e-1],r.limit,!1),n=Math.min(n,l)),o&&e1?i.forEach((function(t,r){var n=st(s,t,s[t]+e,u[r],c[r],!1,l);!1===n?e=0:(e=n-s[t],s[t]=n)})):u=c=[!0];var p=!1;i.forEach((function(t,r){p=pt(t,n[t]+e,u[r],c[r],!1,l)||p})),p&&(i.forEach((function(t){ot(\"update\",t),ot(\"slide\",t)})),null!=o&&ot(\"drag\",a))}function ut(t,e){return r.dir?100-t-e:t}function ct(){V.forEach((function(t){var e=N[t]>50?-1:1,r=3+(p.length+e*t);p[t].style.zIndex=String(r)}))}function pt(t,e,n,i,o,s){return o||(e=st(N,t,e,n,i,!1,s)),!1!==e&&(function(t,e){N[t]=e,C[t]=P.fromStepping(e);var n=\"translate(\"+at(ut(e,0)-O+\"%\",\"0\")+\")\";p[t].style[r.transformRule]=n,ft(t),ft(t+1)}(t,e),!0)}function ft(t){if(m[t]){var e=0,n=100;0!==t&&(e=N[t-1]),t!==m.length-1&&(n=N[t]);var i=n-e,o=\"translate(\"+at(ut(e,i)+\"%\",\"0\")+\")\",s=\"scale(\"+at(i/100,\"1\")+\")\";m[t].style[r.transformRule]=o+\" \"+s}}function dt(t,e){return null===t||!1===t||void 0===t?N[e]:(\"number\"==typeof t&&(t=String(t)),!1!==(t=r.format.from(t))&&(t=P.toStepping(t)),!1===t||isNaN(t)?N[e]:t)}function ht(t,e,n){var i=c(t),o=void 0===N[0];e=void 0===e||e,r.animate&&!o&&l(w,r.cssClasses.tap,r.animationDuration),V.forEach((function(t){pt(t,dt(i[t],t),!0,!1,n)}));var s=1===V.length?0:1;if(o&&P.hasNoSize()&&(n=!0,N[0]=0,V.length>1)){var a=100/(V.length-1);V.forEach((function(t){N[t]=t*a}))}for(;sn.stepAfter.startValue&&(o=n.stepAfter.startValue-i),s=i>n.thisStep.startValue?n.thisStep.step:!1!==n.stepBefore.step&&i-n.stepBefore.highestStep,100===e?o=null:0===e&&(s=null);var a=P.countStepDecimals();return null!==o&&!1!==o&&(o=Number(o.toFixed(a))),null!==s&&!1!==s&&(s=Number(s.toFixed(a))),[s,o]}f(b=w,r.cssClasses.target),0===r.dir?f(b,r.cssClasses.ltr):f(b,r.cssClasses.rtl),0===r.ort?f(b,r.cssClasses.horizontal):f(b,r.cssClasses.vertical),f(b,\"rtl\"===getComputedStyle(b).direction?r.cssClasses.textDirectionRtl:r.cssClasses.textDirectionLtr),a=L(b,r.cssClasses.base),function(t,e){var n=L(e,r.cssClasses.connects);p=[],(m=[]).push(j(n,t[0]));for(var i=0;i=0&&t({render_as_text:[e,!1]})))},\n", - " 591: function _(t,e,s,i,r){var a;i();const n=t(1),d=t(56),h=t(640),o=n.__importStar(t(592));class _ extends h.WidgetView{constructor(){super(...arguments),this._auto_width=\"fit-content\",this._auto_height=\"auto\"}async lazy_initialize(){await super.lazy_initialize(),\"not_started\"!=this.provider.status&&\"loading\"!=this.provider.status||this.provider.ready.connect((()=>{this.contains_tex_string(this.model.text)&&this.rerender()}))}has_math_disabled(){return this.model.disable_math||!this.contains_tex_string(this.model.text)}rerender(){this.render()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>{this.rerender()}))}stylesheets(){return[...super.stylesheets(),o.default,\"p { margin: 0; }\"]}render(){super.render(),this.markup_el=(0,d.div)({class:o.clearfix,style:{display:\"inline-block\"}}),this.shadow_el.appendChild(this.markup_el),\"failed\"!=this.provider.status&&\"loaded\"!=this.provider.status||(this._has_finished=!0)}}s.MarkupView=_,_.__name__=\"MarkupView\";class l extends h.Widget{constructor(t){super(t)}}s.Markup=l,a=l,l.__name__=\"Markup\",a.define((({Boolean:t,String:e})=>({text:[e,\"\"],disable_math:[t,!1]})))},\n", - " 592: function _(e,a,f,l,r){l(),f.clearfix=\"bk-clearfix\",f.default='.bk-clearfix:before,.bk-clearfix:after{content:\"\";display:table;}.bk-clearfix:after{clear:both;}'},\n", - " 593: function _(e,t,i,s,n){var o;s();const l=e(1),r=e(544),d=e(52),_=e(56),u=e(8),h=l.__importStar(e(547)),c=l.__importStar(e(553)),p=c,m=l.__importStar(e(594)),a=m;class g extends r.AbstractButtonView{constructor(){super(...arguments),this._open=!1}stylesheets(){return[...super.stylesheets(),c.default,m.default]}render(){super.render();const e=(0,_.div)({class:[a.caret,a.down]});if(this.model.is_split){const t=this._render_button(e);t.classList.add(h.dropdown_toggle),t.addEventListener(\"click\",(()=>this._toggle_menu())),this.group_el.appendChild(t)}else this.button_el.appendChild(e);const t=this.model.menu.map(((e,t)=>{if(null==e)return(0,_.div)({class:p.divider});{const i=(0,u.isString)(e)?e:e[0],s=(0,_.div)(i);return s.addEventListener(\"click\",(()=>this._item_click(t))),s}}));this.menu=(0,_.div)({class:[p.menu,p.below]},t),this.shadow_el.appendChild(this.menu),(0,_.undisplay)(this.menu)}_show_menu(){if(!this._open){this._open=!0,(0,_.display)(this.menu);const e=t=>{t.composedPath().includes(this.el)||(document.removeEventListener(\"click\",e),this._hide_menu())};document.addEventListener(\"click\",e)}}_hide_menu(){this._open&&(this._open=!1,(0,_.undisplay)(this.menu))}_toggle_menu(){this._open?this._hide_menu():this._show_menu()}click(){this.model.is_split?(this._hide_menu(),this.model.trigger_event(new d.ButtonClick),super.click()):this._toggle_menu()}_item_click(e){this._hide_menu();const t=this.model.menu[e];if(null!=t){const i=(0,u.isString)(t)?t:t[1];(0,u.isString)(i)?this.model.trigger_event(new d.MenuItemClick(i)):i.execute(this.model,{index:e})}}}i.DropdownView=g,g.__name__=\"DropdownView\";class w extends r.AbstractButton{constructor(e){super(e)}get is_split(){return this.split}}i.Dropdown=w,o=w,w.__name__=\"Dropdown\",o.prototype.default_view=g,o.define((({Null:e,Boolean:t,String:i,Array:s,Tuple:n,Or:o})=>({split:[t,!1],menu:[s(o(i,n(i,o(i)),e)),[]]}))),o.override({label:\"Dropdown\"})},\n", - " 594: function _(t,r,e,a,d){a(),e.caret=\"bk-caret\",e.down=\"bk-down\",e.up=\"bk-up\",e.left=\"bk-left\",e.right=\"bk-right\",e.default=\":host{--caret-width:4px;}.bk-caret{display:inline-block;vertical-align:middle;width:0;height:0;margin:0 5px;}.bk-caret.bk-down{border-top:var(--caret-width) solid;}.bk-caret.bk-up{border-bottom:var(--caret-width) solid;}.bk-caret.bk-down,.bk-caret.bk-up{border-right:var(--caret-width) solid transparent;border-left:var(--caret-width) solid transparent;}.bk-caret.bk-left{border-right:var(--caret-width) solid;}.bk-caret.bk-right{border-left:var(--caret-width) solid;}.bk-caret.bk-left,.bk-caret.bk-right{border-top:var(--caret-width) solid transparent;border-bottom:var(--caret-width) solid transparent;}\"},\n", - " 595: function _(e,t,n,l,i){var s;l();const r=e(1),a=e(551),u=e(56),o=e(8),p=r.__importStar(e(17)),d=r.__importStar(e(552)),_=r.__importDefault(e(547));class c extends a.InputWidgetView{stylesheets(){return[...super.stylesheets(),_.default]}render(){super.render();const{multiple:e,disabled:t}=this.model,n=(()=>{const{accept:e}=this.model;return(0,o.isString)(e)?e:e.join(\",\")})();this.input_el=(0,u.input)({type:\"file\",class:d.input,multiple:e,accept:n,disabled:t}),this.group_el.appendChild(this.input_el),this.input_el.addEventListener(\"change\",(()=>{const{files:e}=this.input_el;null!=e&&this.load_files(e)}))}async load_files(e){const t=[],n=[],l=[];for(const i of e){const e=await this._read_file(i),[,s=\"\",,r=\"\"]=e.split(/[:;,]/,4);t.push(r),n.push(i.name),l.push(s)}const[i,s,r]=(()=>this.model.multiple?[t,n,l]:0!=e.length?[t[0],n[0],l[0]]:[\"\",\"\",\"\"])();this.model.setv({value:i,filename:s,mime_type:r})}_read_file(e){return new Promise(((t,n)=>{const l=new FileReader;l.onload=()=>{var i;const{result:s}=l;null!=s?t(s):n(null!==(i=l.error)&&void 0!==i?i:new Error(`unable to read '${e.name}'`))},l.readAsDataURL(e)}))}}n.FileInputView=c,c.__name__=\"FileInputView\";class m extends a.InputWidget{constructor(e){super(e)}}n.FileInput=m,s=m,m.__name__=\"FileInput\",s.prototype.default_view=c,s.define((({Boolean:e,String:t,Array:n,Or:l})=>({value:[l(t,n(t)),p.unset,{readonly:!0}],mime_type:[l(t,n(t)),p.unset,{readonly:!0}],filename:[l(t,n(t)),p.unset,{readonly:!0}],accept:[l(t,n(t)),\"\"],multiple:[e,!1]})))},\n", - " 596: function _(e,t,i,o,n){var s;o();const l=e(544),d=e(448),r=e(438),a=e(59);class p extends l.AbstractButtonView{*children(){yield*super.children(),yield this.tooltip}async lazy_initialize(){await super.lazy_initialize();const{tooltip:e}=this.model;this.tooltip=await(0,a.build_view)(e,{parent:this})}remove(){this.tooltip.remove(),super.remove()}render(){super.render();let e=!1;const t=t=>{this.tooltip.model.setv({visible:t,closable:e})};this.on_change(this.tooltip.model.properties.visible,(()=>{const{visible:i}=this.tooltip.model;i||(e=!1),t(i)})),this.el.addEventListener(\"mouseenter\",(()=>{t(!0)})),this.el.addEventListener(\"mouseleave\",(()=>{e||t(!1)})),document.addEventListener(\"mousedown\",(i=>{const o=i.composedPath();o.includes(this.tooltip.el)||(o.includes(this.el)?(e=!e,t(e)):(e=!1,t(!1)))})),window.addEventListener(\"blur\",(()=>{e=!1,t(!1)}))}}i.HelpButtonView=p,p.__name__=\"HelpButtonView\";class u extends l.AbstractButton{constructor(e){super(e)}}i.HelpButton=u,s=u,u.__name__=\"HelpButton\",s.prototype.default_view=p,s.define((({Ref:e})=>({tooltip:[e(d.Tooltip)]}))),s.override({label:\"\",icon:new r.BuiltinIcon({icon_name:\"help\",size:18}),button_type:\"default\"})},\n", - " 597: function _(e,t,s,i,n){var l;i();const o=e(1),r=e(56),c=e(8),h=e(551),d=o.__importStar(e(552));class p extends h.InputWidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.value.change,(()=>this.render_selection())),this.connect(this.model.properties.options.change,(()=>this.render())),this.connect(this.model.properties.name.change,(()=>this.render())),this.connect(this.model.properties.title.change,(()=>this.render())),this.connect(this.model.properties.size.change,(()=>this.render())),this.connect(this.model.properties.disabled.change,(()=>this.render()))}render(){super.render();const e=this.model.options.map((e=>{let t,s;return(0,c.isString)(e)?t=s=e:[t,s]=e,(0,r.option)({value:t},s)}));this.input_el=(0,r.select)({multiple:!0,class:d.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.shadow_el.querySelectorAll(\"option\"))t.selected=e.has(t.value);this.input_el.size=this.model.size}change_input(){const e=null!=this.shadow_el.querySelector(\"select:focus\"),t=[];for(const e of this.shadow_el.querySelectorAll(\"option\"))e.selected&&t.push(e.value);this.model.value=t,super.change_input(),e&&this.input_el.focus()}}s.MultiSelectView=p,p.__name__=\"MultiSelectView\";class a extends h.InputWidget{constructor(e){super(e)}}s.MultiSelect=a,l=a,a.__name__=\"MultiSelect\",l.prototype.default_view=p,l.define((({Int:e,String:t,Array:s,Tuple:i,Or:n})=>({value:[s(t),[]],options:[s(n(t,i(t,t))),[]],size:[e,4]})))},\n", - " 598: function _(e,a,t,r,s){var n;r();const p=e(591),i=e(56);class _ extends p.MarkupView{render(){super.render();const e=(0,i.p)({style:{margin:0}});this.has_math_disabled()?e.textContent=this.model.text:e.innerHTML=this.process_tex(this.model.text),this.markup_el.appendChild(e)}}t.ParagraphView=_,_.__name__=\"ParagraphView\";class h extends p.Markup{constructor(e){super(e)}}t.Paragraph=h,n=h,h.__name__=\"Paragraph\",n.prototype.default_view=_},\n", - " 599: function _(e,t,s,l,n){var o;l();const p=e(1),r=e(549),a=e(56),i=p.__importDefault(e(600)),_=p.__importDefault(e(269));class u extends r.TextInputView{stylesheets(){return[...super.stylesheets(),i.default,_.default]}render(){super.render(),this.input_el.type=\"password\",this.toggle_el=(0,a.div)({class:\"bk-toggle\"}),this.toggle_el.addEventListener(\"click\",(()=>{const{input_el:e,toggle_el:t}=this,s=\"text\"==e.type;t.classList.toggle(\"bk-visible\",!s),e.type=s?\"password\":\"text\"})),this.shadow_el.append(this.toggle_el)}}s.PasswordInputView=u,u.__name__=\"PasswordInputView\";class d extends r.TextInput{constructor(e){super(e)}}s.PasswordInput=d,o=d,d.__name__=\"PasswordInput\",o.prototype.default_view=u},\n", - " 600: function _(e,i,o,t,g){t(),o.input=\"bk-input\",o.toggle=\"bk-toggle\",o.visible=\"bk-visible\",o.default=\":host{--toggle-size:14px;--toggle-padding:4px;--toggle-width:calc(var(--toggle-size) + 2*var(--toggle-padding));}.bk-input{padding-right:max(var(--padding-horizontal), var(--toggle-width));}.bk-toggle{position:absolute;right:0;top:0;width:var(--toggle-width);height:100%;padding:0 var(--toggle-padding);background-color:var(--bokeh-icon-color);mask-image:var(--bokeh-icon-see-off);-webkit-mask-image:var(--bokeh-icon-see-off);mask-size:var(--toggle-size) var(--toggle-size);-webkit-mask-size:var(--toggle-size) var(--toggle-size);mask-position:center center;-webkit-mask-position:center center;mask-repeat:no-repeat;-webkit-mask-repeat:no-repeat;cursor:pointer;}.bk-toggle.bk-visible{mask-image:var(--bokeh-icon-see-on);-webkit-mask-image:var(--bokeh-icon-see-on);}\"},\n", - " 601: function _(e,t,i,l,o){var s;l();const n=e(1),u=n.__importDefault(e(602)),_=e(56),r=e(8),a=e(25),h=n.__importStar(e(552)),c=n.__importDefault(e(603)),d=e(551);function p(e){return Object.defineProperty(e,\"target\",{get:()=>{var t;return null!==(t=e.composedPath()[0])&&void 0!==t?t:null},configurable:!0}),e}class m extends u.default{_onFocus(e){super._onFocus(p(e))}_onBlur(e){super._onBlur(p(e))}_onKeyUp(e){super._onKeyUp(p(e))}_onKeyDown(e){super._onKeyDown(p(e))}_onClick(e){super._onClick(p(e))}_onTouchEnd(e){super._onTouchEnd(p(e))}_onMouseDown(e){super._onMouseDown(p(e))}_onMouseOver(e){super._onMouseOver(p(e))}}m.__name__=\"OurChoices\";class v extends d.InputWidgetView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.disabled.change,(()=>this.set_disabled()));const{value:e,max_items:t,option_limit:i,search_option_limit:l,delete_button:o,placeholder:s,options:n,name:u,title:_}=this.model.properties;this.on_change([t,i,l,o,s,n,u,_],(()=>this.render())),this.on_change(e,(()=>{(0,a.is_equal)(this.model.value,this._current_values)||this.render()}))}stylesheets(){return[...super.stylesheets(),c.default]}render(){var e,t,i;super.render(),this.input_el=(0,_.select)({multiple:!0,class:h.input,name:this.model.name,disabled:this.model.disabled}),this.group_el.appendChild(this.input_el);const l=new Set(this.model.value),o=this.model.options.map((e=>{let t,i;return(0,r.isString)(e)?t=i=e:[t,i]=e,{value:t,label:i,selected:l.has(t)}})),s=this.model.solid?\"solid\":\"light\",n=`choices__item ${s}`,u=`choices__button ${s}`,a={choices:o,itemSelectText:\"\",duplicateItemsAllowed:!1,shouldSort:!1,removeItemButton:this.model.delete_button,classNames:{item:n,button:u},placeholderValue:this.model.placeholder,maxItemCount:null!==(e=this.model.max_items)&&void 0!==e?e:-1,renderChoiceLimit:null!==(t=this.model.option_limit)&&void 0!==t?t:-1,searchResultLimit:null!==(i=this.model.search_option_limit)&&void 0!==i?i:4};this.choice_el=new m(this.input_el,a),this.input_el.addEventListener(\"change\",(()=>this.change_input()))}set_disabled(){this.model.disabled?this.choice_el.disable():this.choice_el.enable()}get _current_values(){return this.choice_el.getValue().map((e=>e.value))}change_input(){this.model.value=this._current_values,super.change_input()}}i.MultiChoiceView=v,v.__name__=\"MultiChoiceView\";class g extends d.InputWidget{constructor(e){super(e)}}i.MultiChoice=g,s=g,g.__name__=\"MultiChoice\",s.prototype.default_view=v,s.define((({Boolean:e,Int:t,String:i,Array:l,Tuple:o,Or:s,Nullable:n})=>({value:[l(i),[]],options:[l(s(i,o(i,i))),[]],max_items:[n(t),null],delete_button:[e,!0],placeholder:[n(i),null],option_limit:[n(t),null],search_option_limit:[n(t),null],solid:[e,!0]})))},\n", - " 602: function _(e,t,i,n,r){\n", - " /*! choices.js v10.2.0 | © 2022 Josh Johnson | https://github.com/jshjohnson/Choices#readme */\n", - " var s,o;s=window,o=function(){return function(){\"use strict\";var e={282:function(e,t,i){Object.defineProperty(t,\"__esModule\",{value:!0}),t.clearChoices=t.activateChoices=t.filterChoices=t.addChoice=void 0;var n=i(883);t.addChoice=function(e){var t=e.value,i=e.label,r=e.id,s=e.groupId,o=e.disabled,a=e.elementId,c=e.customProperties,l=e.placeholder,h=e.keyCode;return{type:n.ACTION_TYPES.ADD_CHOICE,value:t,label:i,id:r,groupId:s,disabled:o,elementId:a,customProperties:c,placeholder:l,keyCode:h}},t.filterChoices=function(e){return{type:n.ACTION_TYPES.FILTER_CHOICES,results:e}},t.activateChoices=function(e){return void 0===e&&(e=!0),{type:n.ACTION_TYPES.ACTIVATE_CHOICES,active:e}},t.clearChoices=function(){return{type:n.ACTION_TYPES.CLEAR_CHOICES}}},783:function(e,t,i){Object.defineProperty(t,\"__esModule\",{value:!0}),t.addGroup=void 0;var n=i(883);t.addGroup=function(e){var t=e.value,i=e.id,r=e.active,s=e.disabled;return{type:n.ACTION_TYPES.ADD_GROUP,value:t,id:i,active:r,disabled:s}}},464:function(e,t,i){Object.defineProperty(t,\"__esModule\",{value:!0}),t.highlightItem=t.removeItem=t.addItem=void 0;var n=i(883);t.addItem=function(e){var t=e.value,i=e.label,r=e.id,s=e.choiceId,o=e.groupId,a=e.customProperties,c=e.placeholder,l=e.keyCode;return{type:n.ACTION_TYPES.ADD_ITEM,value:t,label:i,id:r,choiceId:s,groupId:o,customProperties:a,placeholder:c,keyCode:l}},t.removeItem=function(e,t){return{type:n.ACTION_TYPES.REMOVE_ITEM,id:e,choiceId:t}},t.highlightItem=function(e,t){return{type:n.ACTION_TYPES.HIGHLIGHT_ITEM,id:e,highlighted:t}}},137:function(e,t,i){Object.defineProperty(t,\"__esModule\",{value:!0}),t.setIsLoading=t.resetTo=t.clearAll=void 0;var n=i(883);t.clearAll=function(){return{type:n.ACTION_TYPES.CLEAR_ALL}},t.resetTo=function(e){return{type:n.ACTION_TYPES.RESET_TO,state:e}},t.setIsLoading=function(e){return{type:n.ACTION_TYPES.SET_IS_LOADING,isLoading:e}}},373:function(e,t,i){var n=this&&this.__spreadArray||function(e,t,i){if(i||2===arguments.length)for(var n,r=0,s=t.length;r=0?this._store.getGroupById(r):null;return this._store.dispatch((0,l.highlightItem)(i,!0)),t&&this.passedElement.triggerEvent(d.EVENTS.highlightItem,{id:i,value:o,label:c,groupValue:h&&h.value?h.value:null}),this},e.prototype.unhighlightItem=function(e){if(!e||!e.id)return this;var t=e.id,i=e.groupId,n=void 0===i?-1:i,r=e.value,s=void 0===r?\"\":r,o=e.label,a=void 0===o?\"\":o,c=n>=0?this._store.getGroupById(n):null;return this._store.dispatch((0,l.highlightItem)(t,!1)),this.passedElement.triggerEvent(d.EVENTS.highlightItem,{id:t,value:s,label:a,groupValue:c&&c.value?c.value:null}),this},e.prototype.highlightAll=function(){var e=this;return this._store.items.forEach((function(t){return e.highlightItem(t)})),this},e.prototype.unhighlightAll=function(){var e=this;return this._store.items.forEach((function(t){return e.unhighlightItem(t)})),this},e.prototype.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},e.prototype.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},e.prototype.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},e.prototype.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.EVENTS.showDropdown,{})})),this},e.prototype.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(d.EVENTS.hideDropdown,{})})),this):this},e.prototype.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},e.prototype.setValue=function(e){var t=this;return this.initialised?(e.forEach((function(e){return t._setChoiceOrItem(e)})),this):this},e.prototype.setChoiceByValue=function(e){var t=this;return!this.initialised||this._isTextElement||(Array.isArray(e)?e:[e]).forEach((function(e){return t._findAndSelectChoiceByValue(e)})),this},e.prototype.setChoices=function(e,t,i,n){var r=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 s=e(this);if(\"function\"==typeof Promise&&s instanceof Promise)return new Promise((function(e){return requestAnimationFrame(e)})).then((function(){return r._handleLoadingState(!0)})).then((function(){return s})).then((function(e){return r.setChoices(e,t,i,n)})).catch((function(e){r.config.silent||console.error(e)})).then((function(){return r._handleLoadingState(!1)})).then((function(){return r}));if(!Array.isArray(s))throw new TypeError(\".setChoices first argument function must return either array of choices or Promise, got: \".concat(typeof s));return this.setChoices(s,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){if(e.choices)r._addGroup({id:e.id?parseInt(\"\".concat(e.id),10):null,group:e,valueKey:t,labelKey:i});else{var n=e;r._addChoice({value:n[t],label:n[i],isSelected:!!n.selected,isDisabled:!!n.disabled,placeholder:!!n.placeholder,customProperties:n.customProperties})}})),this._stopLoading(),this},e.prototype.clearChoices=function(){return this._store.dispatch((0,a.clearChoices)()),this},e.prototype.clearStore=function(){return this._store.dispatch((0,h.clearAll)()),this},e.prototype.clearInput=function(){var e=!this._isSelectOneElement;return this.input.clear(e),!this._isTextElement&&this._canSearch&&(this._isSearching=!1,this._store.dispatch((0,a.activateChoices)(!0))),this},e.prototype._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)}},e.prototype._renderChoices=function(){var e=this,t=this._store,i=t.activeGroups,n=t.activeChoices,r=document.createDocumentFragment();if(this.choiceList.clear(),this.config.resetScrollPosition&&requestAnimationFrame((function(){return e.choiceList.scrollToTop()})),i.length>=1&&!this._isSearching){var s=n.filter((function(e){return!0===e.placeholder&&-1===e.groupId}));s.length>=1&&(r=this._createChoicesFragment(s,r)),r=this._createGroupsFragment(i,n,r)}else n.length>=1&&(r=this._createChoicesFragment(n,r));if(r.childNodes&&r.childNodes.length>0){var o=this._store.activeItems,a=this._canAddItem(o,this.input.value);if(a.response)this.choiceList.append(r),this._highlightChoice();else{var c=this._getTemplate(\"notice\",a.notice);this.choiceList.append(c)}}else{var l=void 0;c=void 0,this._isSearching?(c=\"function\"==typeof this.config.noResultsText?this.config.noResultsText():this.config.noResultsText,l=this._getTemplate(\"notice\",c,\"no-results\")):(c=\"function\"==typeof this.config.noChoicesText?this.config.noChoicesText():this.config.noChoicesText,l=this._getTemplate(\"notice\",c,\"no-choices\")),this.choiceList.append(l)}},e.prototype._renderItems=function(){var e=this._store.activeItems||[];this.itemList.clear();var t=this._createItemsFragment(e);t.childNodes&&this.itemList.append(t)},e.prototype._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 r=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(r.length>=1){var s=n._getTemplate(\"choiceGroup\",e);i.appendChild(s),n._createChoicesFragment(r,i,!0)}})),i},e.prototype._createChoicesFragment=function(e,t,i){var r=this;void 0===t&&(t=document.createDocumentFragment()),void 0===i&&(i=!1);var s=this.config,o=s.renderSelectedChoices,a=s.searchResultLimit,c=s.renderChoiceLimit,l=this._isSearching?f.sortByScore:this.config.sorter,h=function(e){if(\"auto\"!==o||r._isSelectOneElement||!e.selected){var i=r._getTemplate(\"choice\",e,r.config.itemSelectText);t.appendChild(i)}},u=e;\"auto\"!==o||this._isSelectOneElement||(u=e.filter((function(e){return!e.selected})));var d=u.reduce((function(e,t){return t.placeholder?e.placeholderChoices.push(t):e.normalChoices.push(t),e}),{placeholderChoices:[],normalChoices:[]}),p=d.placeholderChoices,m=d.normalChoices;(this.config.shouldSort||this._isSearching)&&m.sort(l);var v=u.length,g=this._isSelectOneElement?n(n([],p,!0),m,!0):m;this._isSearching?v=a:c&&c>0&&!i&&(v=c);for(var _=0;_=n){var o=r?this._searchChoices(e):0;this.passedElement.triggerEvent(d.EVENTS.search,{value:e,resultCount:o})}else s&&(this._isSearching=!1,this._store.dispatch((0,a.activateChoices)(!0)))}},e.prototype._canAddItem=function(e,t){var i=!0,n=\"function\"==typeof this.config.addItemText?this.config.addItemText(t):this.config.addItemText;if(!this._isSelectOneElement){var r=(0,f.existsInArray)(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&&r&&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}},e.prototype._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===\"\".concat(i,\" \"))return 0;var r=this._store.searchableChoices,s=t,c=Object.assign(this.config.fuseOptions,{keys:n([],this.config.searchFields,!0),includeMatches:!0}),l=new o.default(r,c).search(s);return this._currentValue=t,this._highlightPosition=0,this._isSearching=!0,this._store.dispatch((0,a.filterChoices)(l)),l.length},e.prototype._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()},e.prototype._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()},e.prototype._onKeyDown=function(e){var t=e.keyCode,i=this._store.activeItems,n=this.input.isFocussed,r=this.dropdown.isActive,s=this.itemList.hasChildren(),o=String.fromCharCode(t),a=/[^\\x00-\\x1F]/.test(o),c=d.KEY_CODES.BACK_KEY,l=d.KEY_CODES.DELETE_KEY,h=d.KEY_CODES.ENTER_KEY,u=d.KEY_CODES.A_KEY,p=d.KEY_CODES.ESC_KEY,f=d.KEY_CODES.UP_KEY,m=d.KEY_CODES.DOWN_KEY,v=d.KEY_CODES.PAGE_UP_KEY,g=d.KEY_CODES.PAGE_DOWN_KEY;switch(this._isTextElement||r||!a||(this.showDropdown(),this.input.isFocussed||(this.input.value+=e.key.toLowerCase())),t){case u:return this._onSelectKey(e,s);case h:return this._onEnterKey(e,i,r);case p:return this._onEscapeKey(r);case f:case v:case m:case g:return this._onDirectionKey(e,r);case l:case c:return this._onDeleteKey(e,i,n)}},e.prototype._onKeyUp=function(e){var t=e.target,i=e.keyCode,n=this.input.value,r=this._store.activeItems,s=this._canAddItem(r,n),o=d.KEY_CODES.BACK_KEY,c=d.KEY_CODES.DELETE_KEY;if(this._isTextElement)if(s.notice&&n){var l=this._getTemplate(\"notice\",s.notice);this.dropdown.element.innerHTML=l.outerHTML,this.showDropdown(!0)}else this.hideDropdown(!0);else{var h=(i===o||i===c)&&t&&!t.value,u=!this._isTextElement&&this._isSearching,p=this._canSearch&&s.response;h&&u?(this._isSearching=!1,this._store.dispatch((0,a.activateChoices)(!0))):p&&this._handleSearch(this.input.rawValue)}this._canSearch=this.config.searchEnabled},e.prototype._onSelectKey=function(e,t){var i=e.ctrlKey,n=e.metaKey;(i||n)&&t&&(this._canSearch=!1,this.config.removeItems&&!this.input.value&&this.input.element===document.activeElement&&this.highlightAll())},e.prototype._onEnterKey=function(e,t,i){var n=e.target,r=d.KEY_CODES.ENTER_KEY,s=n&&n.hasAttribute(\"data-button\");if(this._isTextElement&&n&&n.value){var o=this.input.value;this._canAddItem(t,o).response&&(this.hideDropdown(!0),this._addItem({value:o}),this._triggerChange(o),this.clearInput())}if(s&&(this._handleButtonAction(t,n),e.preventDefault()),i){var a=this.dropdown.getChild(\".\".concat(this.config.classNames.highlightedState));a&&(t[0]&&(t[0].keyCode=r),this._handleChoiceAction(t,a)),e.preventDefault()}else this._isSelectOneElement&&(this.showDropdown(),e.preventDefault())},e.prototype._onEscapeKey=function(e){e&&(this.hideDropdown(!0),this.containerOuter.focus())},e.prototype._onDirectionKey=function(e,t){var i=e.keyCode,n=e.metaKey,r=d.KEY_CODES.DOWN_KEY,s=d.KEY_CODES.PAGE_UP_KEY,o=d.KEY_CODES.PAGE_DOWN_KEY;if(t||this._isSelectOneElement){this.showDropdown(),this._canSearch=!1;var a=i===r||i===o?1:-1,c=\"[data-choice-selectable]\",l=void 0;if(n||i===o||i===s)l=a>0?this.dropdown.element.querySelector(\"\".concat(c,\":last-of-type\")):this.dropdown.element.querySelector(c);else{var h=this.dropdown.element.querySelector(\".\".concat(this.config.classNames.highlightedState));l=h?(0,f.getAdjacentEl)(h,c,a):this.dropdown.element.querySelector(c)}l&&((0,f.isScrolledIntoView)(l,this.choiceList.element,a)||this.choiceList.scrollToChildElement(l,a),this._highlightChoice(l)),e.preventDefault()}},e.prototype._onDeleteKey=function(e,t,i){var n=e.target;this._isSelectOneElement||n.value||!i||(this._handleBackspace(t),e.preventDefault())},e.prototype._onTouchMove=function(){this._wasTap&&(this._wasTap=!1)},e.prototype._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},e.prototype._onMouseDown=function(e){var t=e.target;if(t instanceof HTMLElement){if(_&&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))},e.prototype._onFocus=function(e){var t,i=this,n=e.target;n&&this.containerOuter.element.contains(n)&&((t={})[d.TEXT_TYPE]=function(){n===i.input.element&&i.containerOuter.addFocusState()},t[d.SELECT_ONE_TYPE]=function(){i.containerOuter.addFocusState(),n===i.input.element&&i.showDropdown(!0)},t[d.SELECT_MULTIPLE_TYPE]=function(){n===i.input.element&&(i.showDropdown(!0),i.containerOuter.addFocusState())},t)[this.passedElement.element.type]()},e.prototype._onBlur=function(e){var t,i=this,n=e.target;if(n&&this.containerOuter.element.contains(n)&&!this._isScrollingOnIe){var r=this._store.activeItems.some((function(e){return e.highlighted}));((t={})[d.TEXT_TYPE]=function(){n===i.input.element&&(i.containerOuter.removeFocusState(),r&&i.unhighlightAll(),i.hideDropdown(!0))},t[d.SELECT_ONE_TYPE]=function(){i.containerOuter.removeFocusState(),(n===i.input.element||n===i.containerOuter.element&&!i._canSearch)&&i.hideDropdown(!0)},t[d.SELECT_MULTIPLE_TYPE]=function(){n===i.input.element&&(i.containerOuter.removeFocusState(),i.hideDropdown(!0),r&&i.unhighlightAll())},t)[this.passedElement.element.type]()}else this._isScrollingOnIe=!1,this.input.element.focus()},e.prototype._onFormReset=function(){this._store.dispatch((0,h.resetTo)(this._initialState))},e.prototype._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(\".\".concat(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(d.EVENTS.highlightChoice,{el:n}),this.dropdown.isActive&&(this.input.setActiveDescendant(n.id),this.containerOuter.setActiveDescendant(n.id))}},e.prototype._addItem=function(e){var t=e.value,i=e.label,n=void 0===i?null:i,r=e.choiceId,s=void 0===r?-1:r,o=e.groupId,a=void 0===o?-1:o,c=e.customProperties,h=void 0===c?{}:c,u=e.placeholder,p=void 0!==u&&u,f=e.keyCode,m=void 0===f?-1:f,v=\"string\"==typeof t?t.trim():t,g=this._store.items,_=n||v,y=s||-1,E=a>=0?this._store.getGroupById(a):null,b=g?g.length+1:1;this.config.prependValue&&(v=this.config.prependValue+v.toString()),this.config.appendValue&&(v+=this.config.appendValue.toString()),this._store.dispatch((0,l.addItem)({value:v,label:_,id:b,choiceId:y,groupId:a,customProperties:h,placeholder:p,keyCode:m})),this._isSelectOneElement&&this.removeActiveItems(b),this.passedElement.triggerEvent(d.EVENTS.addItem,{id:b,value:v,label:_,customProperties:h,groupValue:E&&E.value?E.value:null,keyCode:m})},e.prototype._removeItem=function(e){var t=e.id,i=e.value,n=e.label,r=e.customProperties,s=e.choiceId,o=e.groupId,a=o&&o>=0?this._store.getGroupById(o):null;t&&s&&(this._store.dispatch((0,l.removeItem)(t,s)),this.passedElement.triggerEvent(d.EVENTS.removeItem,{id:t,value:i,label:n,customProperties:r,groupValue:a&&a.value?a.value:null}))},e.prototype._addChoice=function(e){var t=e.value,i=e.label,n=void 0===i?null:i,r=e.isSelected,s=void 0!==r&&r,o=e.isDisabled,c=void 0!==o&&o,l=e.groupId,h=void 0===l?-1:l,u=e.customProperties,d=void 0===u?{}:u,p=e.placeholder,f=void 0!==p&&p,m=e.keyCode,v=void 0===m?-1:m;if(null!=t){var g=this._store.choices,_=n||t,y=g?g.length+1:1,E=\"\".concat(this._baseId,\"-\").concat(this._idNames.itemChoice,\"-\").concat(y);this._store.dispatch((0,a.addChoice)({id:y,groupId:h,elementId:E,value:t,label:_,disabled:c,customProperties:d,placeholder:f,keyCode:v})),s&&this._addItem({value:t,label:_,choiceId:y,customProperties:d,placeholder:f,keyCode:v})}},e.prototype._addGroup=function(e){var t=this,i=e.group,n=e.id,r=e.valueKey,s=void 0===r?\"value\":r,o=e.labelKey,a=void 0===o?\"label\":o,l=(0,f.isType)(\"Object\",i)?i.choices:Array.from(i.getElementsByTagName(\"OPTION\")),h=n||Math.floor((new Date).valueOf()*Math.random()),u=!!i.disabled&&i.disabled;l?(this._store.dispatch((0,c.addGroup)({value:i.label,id:h,active:!0,disabled:u})),l.forEach((function(e){var i=e.disabled||e.parentNode&&e.parentNode.disabled;t._addChoice({value:e[s],label:(0,f.isType)(\"Object\",e)?e[a]:e.innerHTML,isSelected:e.selected,isDisabled:i,groupId:h,customProperties:e.customProperties,placeholder:e.placeholder})}))):this._store.dispatch((0,c.addGroup)({value:i.label,id:i.id,active:!1,disabled:i.disabled}))},e.prototype._getTemplate=function(e){for(var t,i=[],r=1;r0?this.element.scrollTop+o-r:e.offsetTop;requestAnimationFrame((function(){i._animateScroll(a,t)}))}},e.prototype._scrollDown=function(e,t,i){var n=(i-e)/t,r=n>1?n:1;this.element.scrollTop=e+r},e.prototype._scrollUp=function(e,t,i){var n=(e-i)/t,r=n>1?n:1;this.element.scrollTop=e-r},e.prototype._animateScroll=function(e,t){var i=this,r=n.SCROLLING_SPEED,s=this.element.scrollTop,o=!1;t>0?(this._scrollDown(s,r,e),se&&(o=!0)),o&&requestAnimationFrame((function(){i._animateScroll(e,t)}))},e}();t.default=r},730:function(e,t,i){Object.defineProperty(t,\"__esModule\",{value:!0});var n=i(799),r=function(){function e(e){var t=e.element,i=e.classNames;if(this.element=t,this.classNames=i,!(t instanceof HTMLInputElement||t instanceof HTMLSelectElement))throw new TypeError(\"Invalid element passed\");this.isDisabled=!1}return Object.defineProperty(e.prototype,\"isActive\",{get:function(){return\"active\"===this.element.dataset.choice},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,\"dir\",{get:function(){return this.element.dir},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,\"value\",{get:function(){return this.element.value},set:function(e){this.element.value=e},enumerable:!1,configurable:!0}),e.prototype.conceal=function(){this.element.classList.add(this.classNames.input),this.element.hidden=!0,this.element.tabIndex=-1;var e=this.element.getAttribute(\"style\");e&&this.element.setAttribute(\"data-choice-orig-style\",e),this.element.setAttribute(\"data-choice\",\"active\")},e.prototype.reveal=function(){this.element.classList.remove(this.classNames.input),this.element.hidden=!1,this.element.removeAttribute(\"tabindex\");var e=this.element.getAttribute(\"data-choice-orig-style\");e?(this.element.removeAttribute(\"data-choice-orig-style\"),this.element.setAttribute(\"style\",e)):this.element.removeAttribute(\"style\"),this.element.removeAttribute(\"data-choice\"),this.element.value=this.element.value},e.prototype.enable=function(){this.element.removeAttribute(\"disabled\"),this.element.disabled=!1,this.isDisabled=!1},e.prototype.disable=function(){this.element.setAttribute(\"disabled\",\"\"),this.element.disabled=!0,this.isDisabled=!0},e.prototype.triggerEvent=function(e,t){(0,n.dispatchEvent)(this.element,e,t)},e}();t.default=r},541:function(e,t,i){var n,r=this&&this.__extends||(n=function(e,t){return n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i])},n(e,t)},function(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Class extends value \"+String(t)+\" is not a constructor or null\");function i(){this.constructor=e}n(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}),s=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,\"__esModule\",{value:!0});var o=function(e){function t(t){var i=t.element,n=t.classNames,r=t.delimiter,s=e.call(this,{element:i,classNames:n})||this;return s.delimiter=r,s}return r(t,e),Object.defineProperty(t.prototype,\"value\",{get:function(){return this.element.value},set:function(e){this.element.setAttribute(\"value\",e),this.element.value=e},enumerable:!1,configurable:!0}),t}(s(i(730)).default);t.default=o},982:function(e,t,i){var n,r=this&&this.__extends||(n=function(e,t){return n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var i in t)Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i])},n(e,t)},function(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Class extends value \"+String(t)+\" is not a constructor or null\");function i(){this.constructor=e}n(e,t),e.prototype=null===t?Object.create(t):(i.prototype=t.prototype,new i)}),s=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,\"__esModule\",{value:!0});var o=function(e){function t(t){var i=t.element,n=t.classNames,r=t.template,s=e.call(this,{element:i,classNames:n})||this;return s.template=r,s}return r(t,e),Object.defineProperty(t.prototype,\"placeholderOption\",{get:function(){return this.element.querySelector('option[value=\"\"]')||this.element.querySelector(\"option[placeholder]\")},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,\"optionGroups\",{get:function(){return Array.from(this.element.getElementsByTagName(\"OPTGROUP\"))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,\"options\",{get:function(){return Array.from(this.element.options)},set:function(e){var t=this,i=document.createDocumentFragment();e.forEach((function(e){return n=e,r=t.template(n),void i.appendChild(r);var n,r})),this.appendDocFragment(i)},enumerable:!1,configurable:!0}),t.prototype.appendDocFragment=function(e){this.element.innerHTML=\"\",this.element.appendChild(e)},t}(s(i(730)).default);t.default=o},883:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0}),t.SCROLLING_SPEED=t.SELECT_MULTIPLE_TYPE=t.SELECT_ONE_TYPE=t.TEXT_TYPE=t.KEY_CODES=t.ACTION_TYPES=t.EVENTS=void 0,t.EVENTS={showDropdown:\"showDropdown\",hideDropdown:\"hideDropdown\",change:\"change\",choice:\"choice\",search:\"search\",addItem:\"addItem\",removeItem:\"removeItem\",highlightItem:\"highlightItem\",highlightChoice:\"highlightChoice\",unhighlightItem:\"unhighlightItem\"},t.ACTION_TYPES={ADD_CHOICE:\"ADD_CHOICE\",FILTER_CHOICES:\"FILTER_CHOICES\",ACTIVATE_CHOICES:\"ACTIVATE_CHOICES\",CLEAR_CHOICES:\"CLEAR_CHOICES\",ADD_GROUP:\"ADD_GROUP\",ADD_ITEM:\"ADD_ITEM\",REMOVE_ITEM:\"REMOVE_ITEM\",HIGHLIGHT_ITEM:\"HIGHLIGHT_ITEM\",CLEAR_ALL:\"CLEAR_ALL\",RESET_TO:\"RESET_TO\",SET_IS_LOADING:\"SET_IS_LOADING\"},t.KEY_CODES={BACK_KEY:46,DELETE_KEY:8,ENTER_KEY:13,A_KEY:65,ESC_KEY:27,UP_KEY:38,DOWN_KEY:40,PAGE_UP_KEY:33,PAGE_DOWN_KEY:34},t.TEXT_TYPE=\"text\",t.SELECT_ONE_TYPE=\"select-one\",t.SELECT_MULTIPLE_TYPE=\"select-multiple\",t.SCROLLING_SPEED=4},789:function(e,t,i){Object.defineProperty(t,\"__esModule\",{value:!0}),t.DEFAULT_CONFIG=t.DEFAULT_CLASSNAMES=void 0;var n=i(799);t.DEFAULT_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\"},t.DEFAULT_CONFIG={items:[],choices:[],silent:!1,renderChoiceLimit:-1,maxItemCount:-1,addItems:!0,addItemFilter:null,removeItems:!0,removeItemButton:!1,editItems:!1,allowHTML:!0,duplicateItemsAllowed:!0,delimiter:\",\",paste:!0,searchEnabled:!0,searchChoices:!0,searchFloor:1,searchResultLimit:4,searchFields:[\"label\",\"value\"],position:\"auto\",resetScrollPosition:!0,shouldSort:!0,shouldSortItems:!1,sorter:n.sortByAlpha,placeholder:!0,placeholderValue:null,searchPlaceholderValue:null,prependValue:null,appendValue:null,renderSelectedChoices:\"auto\",loadingText:\"Loading...\",noResultsText:\"No results found\",noChoicesText:\"No choices to choose from\",itemSelectText:\"Press to select\",uniqueItemText:\"Only unique values can be added\",customAddItemText:\"Only values matching specific conditions can be added\",addItemText:function(e){return'Press Enter to add \"'.concat((0,n.sanitise)(e),'\"')},maxItemText:function(e){return\"Only \".concat(e,\" values can be added\")},valueComparer:function(e,t){return e===t},fuseOptions:{includeScore:!0},labelId:\"\",callbackOnInit:null,callbackOnCreateTemplates:null,classNames:t.DEFAULT_CLASSNAMES}},18:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},978:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},948:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},359:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},285:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},533:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},187:function(e,t,i){var n=this&&this.__createBinding||(Object.create?function(e,t,i,n){void 0===n&&(n=i);var r=Object.getOwnPropertyDescriptor(t,i);r&&!(\"get\"in r?!t.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return t[i]}}),Object.defineProperty(e,n,r)}:function(e,t,i,n){void 0===n&&(n=i),e[n]=t[i]}),r=this&&this.__exportStar||function(e,t){for(var i in e)\"default\"===i||Object.prototype.hasOwnProperty.call(t,i)||n(t,e,i)};Object.defineProperty(t,\"__esModule\",{value:!0}),r(i(18),t),r(i(978),t),r(i(948),t),r(i(359),t),r(i(285),t),r(i(533),t),r(i(287),t),r(i(132),t),r(i(837),t),r(i(598),t),r(i(369),t),r(i(37),t),r(i(47),t),r(i(923),t),r(i(876),t)},287:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},132:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},837:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},598:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},37:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},369:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},47:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},923:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},876:function(e,t){Object.defineProperty(t,\"__esModule\",{value:!0})},799:function(e,t){var i;Object.defineProperty(t,\"__esModule\",{value:!0}),t.parseCustomProperties=t.diff=t.cloneObject=t.existsInArray=t.dispatchEvent=t.sortByScore=t.sortByAlpha=t.strToEl=t.sanitise=t.isScrolledIntoView=t.getAdjacentEl=t.wrap=t.isType=t.getType=t.generateId=t.generateChars=t.getRandomNumber=void 0,t.getRandomNumber=function(e,t){return Math.floor(Math.random()*(t-e)+e)},t.generateChars=function(e){return Array.from({length:e},(function(){return(0,t.getRandomNumber)(0,36).toString(36)})).join(\"\")},t.generateId=function(e,i){var n=e.id||e.name&&\"\".concat(e.name,\"-\").concat((0,t.generateChars)(2))||(0,t.generateChars)(4);return n=n.replace(/(:|\\.|\\[|\\]|,)/g,\"\"),n=\"\".concat(i,\"-\").concat(n)},t.getType=function(e){return Object.prototype.toString.call(e).slice(8,-1)},t.isType=function(e,i){return null!=i&&(0,t.getType)(i)===e},t.wrap=function(e,t){return void 0===t&&(t=document.createElement(\"div\")),e.parentNode&&(e.nextSibling?e.parentNode.insertBefore(t,e.nextSibling):e.parentNode.appendChild(t)),t.appendChild(e)},t.getAdjacentEl=function(e,t,i){void 0===i&&(i=1);for(var n=\"\".concat(i>0?\"next\":\"previous\",\"ElementSibling\"),r=e[n];r;){if(r.matches(t))return r;r=r[n]}return r},t.isScrolledIntoView=function(e,t,i){return void 0===i&&(i=1),!!e&&(i>0?t.scrollTop+t.offsetHeight>=e.offsetTop+e.offsetHeight:e.offsetTop>=t.scrollTop)},t.sanitise=function(e){return\"string\"!=typeof e?e:e.replace(/&/g,\"&\").replace(/>/g,\">\").replace(/-1?e.map((function(e){var t=e;return t.id===parseInt(\"\".concat(o.choiceId),10)&&(t.selected=!0),t})):e;case\"REMOVE_ITEM\":var a=n;return a.choiceId&&a.choiceId>-1?e.map((function(e){var t=e;return t.id===parseInt(\"\".concat(a.choiceId),10)&&(t.selected=!1),t})):e;case\"FILTER_CHOICES\":var c=n;return e.map((function(e){var t=e;return t.active=c.results.some((function(e){var i=e.item,n=e.score;return i.id===t.id&&(t.score=n,!0)})),t}));case\"ACTIVATE_CHOICES\":var l=n;return e.map((function(e){var t=e;return t.active=l.active,t}));case\"CLEAR_CHOICES\":return t.defaultState;default:return e}}},871:function(e,t){var i=this&&this.__spreadArray||function(e,t,i){if(i||2===arguments.length)for(var n,r=0,s=t.length;r0?\"treeitem\":\"option\"),Object.assign(E.dataset,{choice:\"\",id:d,value:p,selectText:i}),g?(E.classList.add(h),E.dataset.choiceDisabled=\"\",E.setAttribute(\"aria-disabled\",\"true\")):(E.classList.add(c),E.dataset.choiceSelectable=\"\"),E},input:function(e,t){var i=e.classNames,n=i.input,r=i.inputCloned,s=Object.assign(document.createElement(\"input\"),{type:\"search\",name:\"search_terms\",className:\"\".concat(n,\" \").concat(r),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.classNames,i=t.list,n=t.listDropdown,r=document.createElement(\"div\");return r.classList.add(i,n),r.setAttribute(\"aria-expanded\",\"false\"),r},notice:function(e,t,i){var n,r=e.allowHTML,s=e.classNames,o=s.item,a=s.itemChoice,c=s.noResults,l=s.noChoices;void 0===i&&(i=\"\");var h=[o,a];return\"no-choices\"===i?h.push(l):\"no-results\"===i&&h.push(c),Object.assign(document.createElement(\"div\"),((n={})[r?\"innerHTML\":\"innerText\"]=t,n.className=h.join(\" \"),n))},option:function(e){var t=e.label,i=e.value,n=e.customProperties,r=e.active,s=e.disabled,o=new Option(t,i,!1,r);return n&&(o.dataset.customProperties=\"\".concat(n)),o.disabled=!!s,o}};t.default=i},996:function(e){var t=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===i}(e)}(e)},i=\"function\"==typeof Symbol&&Symbol.for?Symbol.for(\"react.element\"):60103;function n(e,t){return!1!==t.clone&&t.isMergeableObject(e)?c((i=e,Array.isArray(i)?[]:{}),e,t):e;var i}function r(e,t,i){return e.concat(t).map((function(e){return n(e,i)}))}function s(e){return Object.keys(e).concat(function(e){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(e).filter((function(t){return e.propertyIsEnumerable(t)})):[]}(e))}function o(e,t){try{return t in e}catch(e){return!1}}function a(e,t,i){var r={};return i.isMergeableObject(e)&&s(e).forEach((function(t){r[t]=n(e[t],i)})),s(t).forEach((function(s){(function(e,t){return o(e,t)&&!(Object.hasOwnProperty.call(e,t)&&Object.propertyIsEnumerable.call(e,t))})(e,s)||(o(e,s)&&i.isMergeableObject(t[s])?r[s]=function(e,t){if(!t.customMerge)return c;var i=t.customMerge(e);return\"function\"==typeof i?i:c}(s,i)(e[s],t[s],i):r[s]=n(t[s],i))})),r}function c(e,i,s){(s=s||{}).arrayMerge=s.arrayMerge||r,s.isMergeableObject=s.isMergeableObject||t,s.cloneUnlessOtherwiseSpecified=n;var o=Array.isArray(i);return o===Array.isArray(e)?o?s.arrayMerge(e,i,s):a(e,i,s):n(i,s)}c.all=function(e,t){if(!Array.isArray(e))throw new Error(\"first argument should be an array\");return e.reduce((function(e,i){return c(e,i,t)}),{})};var l=c;e.exports=l},221:function(e,t,i){\n", - " /**\n", - " * Fuse.js v6.6.2 - Lightweight fuzzy-search (http://fusejs.io)\n", - " *\n", - " * Copyright (c) 2022 Kiro 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", - " function n(e){return Array.isArray?Array.isArray(e):\"[object Array]\"===d(e)}i.r(t),i.d(t,{default:function(){return Z}});const r=1/0;function s(e){return null==e?\"\":function(e){if(\"string\"==typeof e)return e;let t=e+\"\";return\"0\"==t&&1/e==-r?\"-0\":t}(e)}function o(e){return\"string\"==typeof e}function a(e){return\"number\"==typeof e}function c(e){return!0===e||!1===e||function(e){return l(e)&&null!==e}(e)&&\"[object Boolean]\"==d(e)}function l(e){return\"object\"==typeof e}function h(e){return null!=e}function u(e){return!e.trim().length}function d(e){return null==e?void 0===e?\"[object Undefined]\":\"[object Null]\":Object.prototype.toString.call(e)}const p=e=>`Invalid value for key ${e}`,f=e=>`Pattern length exceeds max of ${e}.`,m=e=>`Missing ${e} property in key`,v=e=>`Property 'weight' in key '${e}' must be a positive integer`,g=Object.prototype.hasOwnProperty;class _{constructor(e){this._keys=[],this._keyMap={};let t=0;e.forEach((e=>{let i=y(e);t+=i.weight,this._keys.push(i),this._keyMap[i.id]=i,t+=i.weight})),this._keys.forEach((e=>{e.weight/=t}))}get(e){return this._keyMap[e]}keys(){return this._keys}toJSON(){return JSON.stringify(this._keys)}}function y(e){let t=null,i=null,r=null,s=1,a=null;if(o(e)||n(e))r=e,t=E(e),i=b(e);else{if(!g.call(e,\"name\"))throw new Error(m(\"name\"));const n=e.name;if(r=n,g.call(e,\"weight\")&&(s=e.weight,s<=0))throw new Error(v(n));t=E(n),i=b(n),a=e.getFn}return{path:t,id:i,weight:s,src:r,getFn:a}}function E(e){return n(e)?e:e.split(\".\")}function b(e){return n(e)?e.join(\".\"):e}var S={isCaseSensitive:!1,includeScore:!1,keys:[],shouldSort:!0,sortFn:(e,t)=>e.score===t.score?e.idx{if(h(e))if(t[u]){const d=e[t[u]];if(!h(d))return;if(u===t.length-1&&(o(d)||a(d)||c(d)))i.push(s(d));else if(n(d)){r=!0;for(let e=0,i=d.length;e{this._keysMap[e.id]=t}))}create(){!this.isCreated&&this.docs.length&&(this.isCreated=!0,o(this.docs[0])?this.docs.forEach(((e,t)=>{this._addString(e,t)})):this.docs.forEach(((e,t)=>{this._addObject(e,t)})),this.norm.clear())}add(e){const t=this.size();o(e)?this._addString(e,t):this._addObject(e,t)}removeAt(e){this.records.splice(e,1);for(let t=e,i=this.size();t{let s=t.getFn?t.getFn(e):this.getFn(e,t.path);if(h(s))if(n(s)){let e=[];const t=[{nestedArrIndex:-1,value:s}];for(;t.length;){const{nestedArrIndex:i,value:r}=t.pop();if(h(r))if(o(r)&&!u(r)){let t={v:r,i,n:this.norm.get(r)};e.push(t)}else n(r)&&r.forEach(((e,i)=>{t.push({nestedArrIndex:i,value:e})}))}i.$[r]=e}else if(o(s)&&!u(s)){let e={v:s,n:this.norm.get(s)};i.$[r]=e}})),this.records.push(i)}toJSON(){return{keys:this.keys,records:this.records}}}function C(e,t,{getFn:i=S.getFn,fieldNormWeight:n=S.fieldNormWeight}={}){const r=new I({getFn:i,fieldNormWeight:n});return r.setKeys(e.map(y)),r.setSources(t),r.create(),r}function T(e,{errors:t=0,currentLocation:i=0,expectedLocation:n=0,distance:r=S.distance,ignoreLocation:s=S.ignoreLocation}={}){const o=t/e.length;if(s)return o;const a=Math.abs(n-i);return r?o+a/r:a?1:o}const L=32;function w(e,t,i,{location:n=S.location,distance:r=S.distance,threshold:s=S.threshold,findAllMatches:o=S.findAllMatches,minMatchCharLength:a=S.minMatchCharLength,includeMatches:c=S.includeMatches,ignoreLocation:l=S.ignoreLocation}={}){if(t.length>L)throw new Error(f(L));const h=t.length,u=e.length,d=Math.max(0,Math.min(n,u));let p=s,m=d;const v=a>1||c,g=v?Array(u):[];let _;for(;(_=e.indexOf(t,m))>-1;){let e=T(t,{currentLocation:_,expectedLocation:d,distance:r,ignoreLocation:l});if(p=Math.min(e,p),m=_+h,v){let e=0;for(;e=c;s-=1){let o=s-1,a=i[e.charAt(o)];if(v&&(g[o]=+!!a),_[s]=(_[s+1]<<1|1)&a,n&&(_[s]|=(y[s+1]|y[s])<<1|1|y[s+1]),_[s]&O&&(E=T(t,{errors:n,currentLocation:o,expectedLocation:d,distance:r,ignoreLocation:l}),E<=p)){if(p=E,m=o,m<=d)break;c=Math.max(1,2*d-m)}}if(T(t,{errors:n+1,currentLocation:d,expectedLocation:d,distance:r,ignoreLocation:l})>p)break;y=_}const I={isMatch:m>=0,score:Math.max(.001,E)};if(v){const e=function(e=[],t=S.minMatchCharLength){let i=[],n=-1,r=-1,s=0;for(let o=e.length;s=t&&i.push([n,r]),n=-1)}return e[s-1]&&s-n>=t&&i.push([n,s-1]),i}(g,a);e.length?c&&(I.indices=e):I.isMatch=!1}return I}function A(e){let t={};for(let i=0,n=e.length;i{this.chunks.push({pattern:e,alphabet:A(e),startIndex:t})},h=this.pattern.length;if(h>L){let e=0;const t=h%L,i=h-t;for(;e{const{isMatch:f,score:m,indices:v}=w(e,t,d,{location:n+p,distance:r,threshold:s,findAllMatches:o,minMatchCharLength:a,includeMatches:i,ignoreLocation:c});f&&(u=!0),h+=m,f&&v&&(l=[...l,...v])}));let d={isMatch:u,score:u?h/this.chunks.length:1};return u&&i&&(d.indices=l),d}}class P{constructor(e){this.pattern=e}static isMultiMatch(e){return x(e,this.multiRegex)}static isSingleMatch(e){return x(e,this.singleRegex)}search(){}}function x(e,t){const i=e.match(t);return i?i[1]:null}class N extends P{constructor(e,{location:t=S.location,threshold:i=S.threshold,distance:n=S.distance,includeMatches:r=S.includeMatches,findAllMatches:s=S.findAllMatches,minMatchCharLength:o=S.minMatchCharLength,isCaseSensitive:a=S.isCaseSensitive,ignoreLocation:c=S.ignoreLocation}={}){super(e),this._bitapSearch=new M(e,{location:t,threshold:i,distance:n,includeMatches:r,findAllMatches:s,minMatchCharLength:o,isCaseSensitive:a,ignoreLocation:c})}static get type(){return\"fuzzy\"}static get multiRegex(){return/^\"(.*)\"$/}static get singleRegex(){return/^(.*)$/}search(e){return this._bitapSearch.searchIn(e)}}class D extends P{constructor(e){super(e)}static get type(){return\"include\"}static get multiRegex(){return/^'\"(.*)\"$/}static get singleRegex(){return/^'(.*)$/}search(e){let t,i=0;const n=[],r=this.pattern.length;for(;(t=e.indexOf(this.pattern,i))>-1;)i=t+r,n.push([t,i-1]);const s=!!n.length;return{isMatch:s,score:s?0:1,indices:n}}}const j=[class extends P{constructor(e){super(e)}static get type(){return\"exact\"}static get multiRegex(){return/^=\"(.*)\"$/}static get singleRegex(){return/^=(.*)$/}search(e){const t=e===this.pattern;return{isMatch:t,score:t?0:1,indices:[0,this.pattern.length-1]}}},D,class extends P{constructor(e){super(e)}static get type(){return\"prefix-exact\"}static get multiRegex(){return/^\\^\"(.*)\"$/}static get singleRegex(){return/^\\^(.*)$/}search(e){const t=e.startsWith(this.pattern);return{isMatch:t,score:t?0:1,indices:[0,this.pattern.length-1]}}},class extends P{constructor(e){super(e)}static get type(){return\"inverse-prefix-exact\"}static get multiRegex(){return/^!\\^\"(.*)\"$/}static get singleRegex(){return/^!\\^(.*)$/}search(e){const t=!e.startsWith(this.pattern);return{isMatch:t,score:t?0:1,indices:[0,e.length-1]}}},class extends P{constructor(e){super(e)}static get type(){return\"inverse-suffix-exact\"}static get multiRegex(){return/^!\"(.*)\"\\$$/}static get singleRegex(){return/^!(.*)\\$$/}search(e){const t=!e.endsWith(this.pattern);return{isMatch:t,score:t?0:1,indices:[0,e.length-1]}}},class extends P{constructor(e){super(e)}static get type(){return\"suffix-exact\"}static get multiRegex(){return/^\"(.*)\"\\$$/}static get singleRegex(){return/^(.*)\\$$/}search(e){const t=e.endsWith(this.pattern);return{isMatch:t,score:t?0:1,indices:[e.length-this.pattern.length,e.length-1]}}},class extends P{constructor(e){super(e)}static get type(){return\"inverse-exact\"}static get multiRegex(){return/^!\"(.*)\"$/}static get singleRegex(){return/^!(.*)$/}search(e){const t=-1===e.indexOf(this.pattern);return{isMatch:t,score:t?0:1,indices:[0,e.length-1]}}},N],F=j.length,k=/ +(?=(?:[^\\\"]*\\\"[^\\\"]*\\\")*[^\\\"]*$)/,K=\"|\",R=new Set([N.type,D.type]);class H{constructor(e,{isCaseSensitive:t=S.isCaseSensitive,includeMatches:i=S.includeMatches,minMatchCharLength:n=S.minMatchCharLength,ignoreLocation:r=S.ignoreLocation,findAllMatches:s=S.findAllMatches,location:o=S.location,threshold:a=S.threshold,distance:c=S.distance}={}){this.query=null,this.options={isCaseSensitive:t,includeMatches:i,minMatchCharLength:n,findAllMatches:s,ignoreLocation:r,location:o,threshold:a,distance:c},this.pattern=t?e:e.toLowerCase(),this.query=function(e,t={}){return e.split(K).map((e=>{let i=e.trim().split(k).filter((e=>e&&!!e.trim())),n=[];for(let e=0,r=i.length;e!(!e[B]&&!e[G]),$=e=>!!e[U.PATH],q=e=>!n(e)&&l(e)&&!W(e),X=e=>({[B]:Object.keys(e).map((t=>({[t]:e[t]})))});function z(e,t,{auto:i=!0}={}){const r=e=>{let s=Object.keys(e);const a=$(e);if(!a&&s.length>1&&!W(e))return r(X(e));if(q(e)){const n=a?e[U.PATH]:s[0],r=a?e[U.PATTERN]:e[n];if(!o(r))throw new Error(p(n));const c={keyId:b(n),pattern:r};return i&&(c.searcher=V(r,t)),c}let c={children:[],operator:s[0]};return s.forEach((t=>{const i=e[t];n(i)&&i.forEach((e=>{c.children.push(r(e))}))})),c};return W(e)||(e=X(e)),r(e)}function J(e,t){const i=e.matches;t.matches=[],h(i)&&i.forEach((e=>{if(!h(e.indices)||!e.indices.length)return;const{indices:i,value:n}=e;let r={indices:i,value:n};e.key&&(r.key=e.key.src),e.idx>-1&&(r.refIndex=e.idx),t.matches.push(r)}))}function Q(e,t){t.score=e.score}class Z{constructor(e,t={},i){this.options={...S,...t},this.options.useExtendedSearch,this._keyStore=new _(this.options.keys),this.setCollection(e,i)}setCollection(e,t){if(this._docs=e,t&&!(t instanceof I))throw new Error(\"Incorrect 'index' type\");this._myIndex=t||C(this.options.keys,this._docs,{getFn:this.options.getFn,fieldNormWeight:this.options.fieldNormWeight})}add(e){h(e)&&(this._docs.push(e),this._myIndex.add(e))}remove(e=(()=>!1)){const t=[];for(let i=0,n=this._docs.length;i{let i=1;e.matches.forEach((({key:e,norm:n,score:r})=>{const s=e?e.weight:null;i*=Math.pow(0===r&&s?Number.EPSILON:r,(s||1)*(t?1:n))})),e.score=i}))}(l,{ignoreFieldNorm:c}),r&&l.sort(s),a(t)&&t>-1&&(l=l.slice(0,t)),function(e,t,{includeMatches:i=S.includeMatches,includeScore:n=S.includeScore}={}){const r=[];return i&&r.push(J),n&&r.push(Q),e.map((e=>{const{idx:i}=e,n={item:t[i],refIndex:i};return r.length&&r.forEach((t=>{t(e,n)})),n}))}(l,this._docs,{includeMatches:i,includeScore:n})}_searchStringList(e){const t=V(e,this.options),{records:i}=this._myIndex,n=[];return i.forEach((({v:e,i,n:r})=>{if(!h(e))return;const{isMatch:s,score:o,indices:a}=t.searchIn(e);s&&n.push({item:e,idx:i,matches:[{score:o,value:e,norm:r,indices:a}]})})),n}_searchLogical(e){const t=z(e,this.options),i=(e,t,n)=>{if(!e.children){const{keyId:i,searcher:r}=e,s=this._findMatches({key:this._keyStore.get(i),value:this._myIndex.getValueForItemAtKeyId(t,i),searcher:r});return s&&s.length?[{idx:n,item:t,matches:s}]:[]}const r=[];for(let s=0,o=e.children.length;s{if(h(e)){let o=i(t,e,n);o.length&&(r[n]||(r[n]={idx:n,item:e,matches:[]},s.push(r[n])),o.forEach((({matches:e})=>{r[n].matches.push(...e)})))}})),s}_searchObjectList(e){const t=V(e,this.options),{keys:i,records:n}=this._myIndex,r=[];return n.forEach((({$:e,i:n})=>{if(!h(e))return;let s=[];i.forEach(((i,n)=>{s.push(...this._findMatches({key:i,value:e[n],searcher:t}))})),s.length&&r.push({idx:n,item:e,matches:s})})),r}_findMatches({key:e,value:t,searcher:i}){if(!h(t))return[];let r=[];if(n(t))t.forEach((({v:t,i:n,n:s})=>{if(!h(t))return;const{isMatch:o,score:a,indices:c}=i.searchIn(t);o&&r.push({score:a,key:e,value:t,idx:n,norm:s,indices:c})}));else{const{v:n,n:s}=t,{isMatch:o,score:a,indices:c}=i.searchIn(n);o&&r.push({score:a,key:e,value:n,norm:s,indices:c})}return r}}Z.version=\"6.6.2\",Z.createIndex=C,Z.parseIndex=function(e,{getFn:t=S.getFn,fieldNormWeight:i=S.fieldNormWeight}={}){const{keys:n,records:r}=e,s=new I({getFn:t,fieldNormWeight:i});return s.setKeys(n),s.setIndexRecords(r),s},Z.config=S,Z.parseQuery=z,function(...e){Y.push(...e)}(H)},791: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},n(e)}function r(e){var t=function(e,t){if(\"object\"!==n(e)||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var r=i.call(e,t||\"default\");if(\"object\"!==n(r))return r;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return(\"string\"===t?String:Number)(e)}(e,\"string\");return\"symbol\"===n(t)?t:String(t)}function s(e,t,i){return(t=r(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function o(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,n)}return i}function a(e){for(var t=1;t{var e;return this.input_el.name=null!==(e=this.model.name)&&void 0!==e?e:\"\"})),this.connect(this.model.properties.value.change,(()=>{this.input_el.value=this.format_value,this.old_value=this.input_el.value})),this.connect(this.model.properties.low.change,(()=>{const{value:e,low:t,high:l}=this.model;null!=t&&null!=l&&(0,p.assert)(t<=l,\"Invalid bounds, low must be inferior to high\"),null!=e&&null!=t&&e{const{value:e,low:t,high:l}=this.model;null!=t&&null!=l&&(0,p.assert)(l>=t,\"Invalid bounds, high must be superior to low\"),null!=e&&null!=l&&e>l&&(this.model.value=l)})),this.connect(this.model.properties.high.change,(()=>this.input_el.placeholder=this.model.placeholder)),this.connect(this.model.properties.disabled.change,(()=>this.input_el.disabled=this.model.disabled)),this.connect(this.model.properties.placeholder.change,(()=>this.input_el.placeholder=this.model.placeholder))}get format_value(){return null!=this.model.value?this.model.pretty(this.model.value):\"\"}_set_input_filter(e){this.input_el.addEventListener(\"input\",(()=>{const{selectionStart:t,selectionEnd:l}=this.input_el;if(e(this.input_el.value))this.old_value=this.input_el.value;else{const e=this.old_value.length-this.input_el.value.length;this.input_el.value=this.old_value,null!=t&&null!=l&&this.input_el.setSelectionRange(t-1,l+e)}}))}render(){super.render(),this.input_el=(0,r.input)({type:\"text\",class:_.input,name:this.model.name,value:this.format_value,disabled:this.model.disabled,placeholder:this.model.placeholder}),this.old_value=this.format_value,this.set_input_filter(),this.input_el.addEventListener(\"change\",(()=>this.change_input())),this.input_el.addEventListener(\"focusout\",(()=>this.input_el.value=this.format_value)),this.group_el.appendChild(this.input_el)}set_input_filter(){const e=\"int\"==this.model.mode?m:c;this._set_input_filter((t=>e.test(t)))}bound_value(e){let t=e;const{low:l,high:i}=this.model;return t=null!=l?Math.max(l,t):t,t=null!=i?Math.min(i,t):t,t}get value(){let e=\"\"!=this.input_el.value?Number(this.input_el.value):null;return null!=e&&(e=this.bound_value(e)),e}change_input(){null==this.value?this.model.value=null:Number.isNaN(this.value)||(this.model.value=this.value)}}l.NumericInputView=v,v.__name__=\"NumericInputView\";class g extends o.InputWidget{constructor(e){super(e)}_formatter(e,t){return(0,d.isString)(t)?h.format(e,t):t.doFormat([e],{loc:0})[0]}pretty(e){return null!=this.format?this._formatter(e,this.format):`${e}`}}l.NumericInput=g,s=g,g.__name__=\"NumericInput\",s.prototype.default_view=v,s.define((({Number:e,String:t,Enum:l,Ref:i,Or:n,Nullable:s})=>({value:[s(e),null],placeholder:[t,\"\"],mode:[l(\"int\",\"float\"),\"int\"],format:[s(n(t,i(a.TickFormatter))),null],low:[s(e),null],high:[s(e),null]})))},\n", - " 605: function _(e,t,r,s,n){var a;s();const o=e(591),_=e(56);class p extends o.MarkupView{render(){super.render();const e=(0,_.pre)({style:{overflow:\"auto\"}},this.model.text);this.markup_el.appendChild(e)}}r.PreTextView=p,p.__name__=\"PreTextView\";class u extends o.Markup{constructor(e){super(e)}}r.PreText=u,a=u,u.__name__=\"PreText\",a.prototype.default_view=p},\n", - " 606: function _(t,o,e,a,i){var n;a();const u=t(1),s=t(556),c=u.__importStar(t(547));class _ extends s.ToggleButtonGroupView{change_active(t){this.model.active!==t&&(this.model.active=t)}_update_active(){const{active:t}=this.model;this._buttons.forEach(((o,e)=>{o.classList.toggle(c.active,t===e)}))}}e.RadioButtonGroupView=_,_.__name__=\"RadioButtonGroupView\";class l extends s.ToggleButtonGroup{constructor(t){super(t)}}e.RadioButtonGroup=l,n=l,l.__name__=\"RadioButtonGroup\",n.prototype.default_view=_,n.define((({Int:t,Nullable:o})=>({active:[o(t),null]})))},\n", - " 607: function _(e,t,n,i,s){var o;i();const a=e(1),l=e(559),c=e(56),d=e(38),p=e(32),u=a.__importStar(e(552));class r extends l.ToggleInputGroupView{connect_signals(){super.connect_signals();const{active:e}=this.model.properties;this.on_change(e,(()=>{const{active:e}=this.model;for(const[t,n]of(0,p.enumerate)(this._inputs))t.checked=e==n}))}render(){super.render();const e=(0,c.div)({class:[u.input_group,this.model.inline?u.inline:null]});this.shadow_el.appendChild(e);const t=(0,d.unique_id)(),{active:n,labels:i}=this.model;this._inputs=[];for(let s=0;sthis.change_active(s))),this._inputs.push(o),this.model.disabled&&(o.disabled=!0),s==n&&(o.checked=!0);const a=(0,c.label)(o,(0,c.span)(i[s]));e.appendChild(a)}}change_active(e){this.model.active=e}}n.RadioGroupView=r,r.__name__=\"RadioGroupView\";class h extends l.ToggleInputGroup{constructor(e){super(e)}}n.RadioGroup=h,o=h,h.__name__=\"RadioGroup\",o.prototype.default_view=r,o.define((({Int:e,Nullable:t})=>({active:[t(e),null]})))},\n", - " 608: function _(e,r,t,a,i){var n;a();const o=e(1).__importStar(e(171)),s=e(584),_=e(8);class d extends s.AbstractRangeSliderView{}t.RangeSliderView=d,d.__name__=\"RangeSliderView\";class c extends s.AbstractSlider{constructor(e){super(e),this.behaviour=\"drag\",this.connected=[!1,!0,!1]}_formatter(e,r){return(0,_.isString)(r)?o.format(e,r):r.compute(e)}}t.RangeSlider=c,n=c,c.__name__=\"RangeSlider\",n.prototype.default_view=d,n.override({format:\"0[.]00\"})},\n", - " 609: function _(e,t,n,s,i){var l;s();const u=e(1),a=e(56),o=e(8),p=e(9),_=e(551),r=u.__importStar(e(552));class h extends _.InputWidgetView{constructor(){super(...arguments),this._known_values=new Set}connect_signals(){super.connect_signals();const{value:e,options:t}=this.model.properties;this.on_change(e,(()=>{this._update_value()})),this.on_change(t,(()=>{(0,a.empty)(this.input_el),(0,a.append)(this.input_el,...this.options_el()),this._update_value()}))}options_el(){const{_known_values:e}=this;function t(t){return t.map((t=>{let n,s;return(0,o.isString)(t)?n=s=t:[n,s]=t,e.add(n),(0,a.option)({value:n},s)}))}e.clear();const{options:n}=this.model;return(0,o.isArray)(n)?t(n):(0,p.entries)(n).map((([e,n])=>(0,a.optgroup)({label:e},t(n))))}render(){super.render(),this.input_el=(0,a.select)({class:r.input,name:this.model.name,disabled:this.model.disabled},this.options_el()),this._update_value(),this.input_el.addEventListener(\"change\",(()=>this.change_input())),this.group_el.appendChild(this.input_el)}change_input(){const e=this.input_el.value;this.model.value=e,super.change_input()}_update_value(){const{value:e}=this.model;this._known_values.has(e)?this.input_el.value=e:this.input_el.removeAttribute(\"value\")}}n.SelectView=h,h.__name__=\"SelectView\";class c extends _.InputWidget{constructor(e){super(e)}}n.Select=c,l=c,c.__name__=\"Select\",l.prototype.default_view=h,l.define((({String:e,Array:t,Tuple:n,Dict:s,Or:i})=>{const l=t(i(e,n(e,e)));return{value:[e,\"\"],options:[i(l,s(l)),[]]}}))},\n", - " 610: function _(e,t,r,i,a){var o;i();const s=e(1).__importStar(e(171)),_=e(584),n=e(8);class c extends _.AbstractSliderView{}r.SliderView=c,c.__name__=\"SliderView\";class d extends _.AbstractSlider{constructor(e){super(e),this.behaviour=\"tap\",this.connected=[!0,!1]}_formatter(e,t){return(0,n.isString)(t)?s.format(e,t):t.compute(e)}}r.Slider=d,o=d,d.__name__=\"Slider\",o.prototype.default_view=c,o.override({format:\"0[.]00\"})},\n", - " 611: function _(e,t,i,n,s){var l;n();const o=e(1),r=e(604),a=o.__importStar(e(17)),h=e(56),{min:_,max:u,floor:d,abs:p}=Math;function m(e){return d(e)!==e?e.toFixed(16).replace(/0+$/,\"\").split(\".\")[1].length:0}class c extends r.NumericInputView{*buttons(){yield this.btn_up_el,yield this.btn_down_el}initialize(){super.initialize(),this._handles={interval:void 0,timeout:void 0},this._interval=200}connect_signals(){super.connect_signals();const e=this.model.properties;this.on_change(e.disabled,(()=>{for(const e of this.buttons())(0,h.toggle_attribute)(e,\"disabled\",this.model.disabled)}))}render(){super.render(),this.wrapper_el=(0,h.div)({class:\"bk-spin-wrapper\"}),this.group_el.replaceChild(this.wrapper_el,this.input_el),this.btn_up_el=(0,h.button)({class:\"bk-spin-btn bk-spin-btn-up\"}),this.btn_down_el=(0,h.button)({class:\"bk-spin-btn bk-spin-btn-down\"}),this.wrapper_el.appendChild(this.input_el),this.wrapper_el.appendChild(this.btn_up_el),this.wrapper_el.appendChild(this.btn_down_el);for(const e of this.buttons())(0,h.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=m;return u(n(p(null!=e?e:0)),n(p(null!=t?t:0)),n(p(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.key){case\"ArrowUp\":return e.preventDefault(),this.increment(this.model.step);case\"ArrowDown\":return e.preventDefault(),this.increment(-this.model.step);case\"PageUp\":return e.preventDefault(),this.increment(this.model.page_step_multiplier*this.model.step);case\"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?_(0,i):0:e<0&&(this.model.value=null!=i?i:null!=t?u(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=c,c.__name__=\"SpinnerView\";class v extends r.NumericInput{constructor(e){super(e)}}i.Spinner=v,l=v,v.__name__=\"Spinner\",l.prototype.default_view=c,l.define((({Number:e,Nullable:t})=>({value_throttled:[t(e),a.unset,{readonly:!0}],step:[e,1],page_step_multiplier:[e,10],wheel_wait:[e,100]}))),l.override({mode:\"float\"})},\n", - " 612: function _(e,t,s,i,a){var l;i();const d=e(1),n=e(562),c=e(56),_=d.__importDefault(e(613));class h extends n.ToggleInputView{stylesheets(){return[...super.stylesheets(),_.default]}connect_signals(){super.connect_signals(),this.el.addEventListener(\"keydown\",(e=>{switch(e.key){case\"Enter\":case\" \":e.preventDefault(),this._toggle_active()}})),this.el.addEventListener(\"click\",(()=>this._toggle_active()))}render(){super.render(),this.bar_el=(0,c.div)({class:\"bar\"}),this.knob_el=(0,c.div)({class:\"knob\",tabIndex:0});const e=(0,c.div)({class:\"body\"},this.bar_el,this.knob_el);this._update_active(),this._update_disabled(),this.shadow_el.appendChild(e)}_update_active(){this.el.classList.toggle(\"active\",this.model.active)}_update_disabled(){this.el.classList.toggle(\"disabled\",this.model.disabled)}}s.SwitchView=h,h.__name__=\"SwitchView\";class o extends n.ToggleInput{constructor(e){super(e)}}s.Switch=o,l=o,o.__name__=\"Switch\",l.prototype.default_view=h,l.override({width:32})},\n", - " 613: function _(o,r,t,a,i){a(),t.default=\":host{cursor:pointer;}:host(.disabled){cursor:default;}:host{--switch-size:16px;--bar-height:10px;}.body{width:100%;height:var(--switch-size);}.bar{position:relative;top:calc(50% - var(--bar-height)/2);height:var(--bar-height);border-radius:calc(var(--bar-height)/2);background-color:#e5e5e5;transition-property:background-color;}.knob{position:absolute;top:0;left:0;width:var(--switch-size);height:var(--switch-size);border-radius:8px;background-color:#adadad;transition-property:left, background-color;}:host(.active) .bar{background-color:#c2d5f7;}:host(.active) .knob{left:calc(100% - var(--switch-size));background-color:#3b80f0;}\"},\n", - " 614: function _(e,t,s,n,i){var r;n();const o=e(1),l=e(550),c=e(56),p=o.__importStar(e(552));class _ extends l.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(){return this.input_el=(0,c.textarea)({class:p.input})}render(){super.render(),this.input_el.cols=this.model.cols,this.input_el.rows=this.model.rows}}s.TextAreaInputView=_,_.__name__=\"TextAreaInputView\";class u extends l.TextLikeInput{constructor(e){super(e)}}s.TextAreaInput=u,r=u,u.__name__=\"TextAreaInput\",r.prototype.default_view=_,r.define((({Int:e})=>({cols:[e,20],rows:[e,2]}))),r.override({max_length:500})},\n", - " 615: function _(e,t,i,s,c){var o;s();const a=e(1),n=e(544),l=e(52),r=a.__importStar(e(547));class _ extends n.AbstractButtonView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.active.change,(()=>this._update_active()))}render(){super.render(),this._update_active()}click(){this.model.active=!this.model.active,this.model.trigger_event(new l.ButtonClick),super.click()}_update_active(){this.button_el.classList.toggle(r.active,this.model.active)}}i.ToggleView=_,_.__name__=\"ToggleView\";class g extends n.AbstractButton{constructor(e){super(e)}}i.Toggle=g,o=g,g.__name__=\"Toggle\",o.prototype.default_view=_,o.define((({Boolean:e})=>({active:[e,!1]}))),o.override({label:\"Toggle\"})},\n", - " }, 542, {\"models/widgets/main\":542,\"models/widgets/index\":543,\"models/widgets/abstract_button\":544,\"models/widgets/control\":545,\"models/widgets/widget\":640,\"styles/buttons.css\":547,\"models/widgets/autocomplete_input\":548,\"models/widgets/text_input\":549,\"models/widgets/text_like_input\":550,\"models/widgets/input_widget\":551,\"styles/widgets/inputs.css\":552,\"styles/dropdown.css\":553,\"models/widgets/button\":554,\"models/widgets/checkbox_button_group\":555,\"models/widgets/toggle_button_group\":556,\"models/widgets/oriented_control\":557,\"models/widgets/checkbox_group\":558,\"models/widgets/toggle_input_group\":559,\"styles/widgets/checkbox.css\":560,\"models/widgets/checkbox\":561,\"models/widgets/toggle_input\":562,\"models/widgets/color_picker\":563,\"models/widgets/date_picker\":564,\"models/widgets/base_date_picker\":565,\"models/widgets/picker_base\":566,\"styles/widgets/flatpickr.css\":575,\"models/widgets/date_range_picker\":576,\"models/widgets/multiple_date_picker\":577,\"models/widgets/datetime_picker\":578,\"models/widgets/base_datetime_picker\":579,\"models/widgets/datetime_range_picker\":580,\"models/widgets/multiple_datetime_picker\":581,\"models/widgets/time_picker\":582,\"models/widgets/date_range_slider\":583,\"models/widgets/abstract_slider\":584,\"styles/widgets/sliders.css\":586,\"styles/widgets/nouislider.css\":587,\"models/widgets/date_slider\":588,\"models/widgets/datetime_range_slider\":589,\"models/widgets/div\":590,\"models/widgets/markup\":591,\"styles/clearfix.css\":592,\"models/widgets/dropdown\":593,\"styles/caret.css\":594,\"models/widgets/file_input\":595,\"models/widgets/help_button\":596,\"models/widgets/multiselect\":597,\"models/widgets/paragraph\":598,\"models/widgets/password_input\":599,\"styles/widgets/password_input.css\":600,\"models/widgets/multi_choice\":601,\"styles/widgets/choices.css\":603,\"models/widgets/numeric_input\":604,\"models/widgets/pretext\":605,\"models/widgets/radio_button_group\":606,\"models/widgets/radio_group\":607,\"models/widgets/range_slider\":608,\"models/widgets/selectbox\":609,\"models/widgets/slider\":610,\"models/widgets/spinner\":611,\"models/widgets/switch\":612,\"styles/widgets/switch.css\":613,\"models/widgets/textarea_input\":614,\"models/widgets/toggle\":615}, {});});\n", - "\n", - " /* END bokeh-widgets.min.js */\n", - " },\n", - " function(Bokeh) {\n", - " /* BEGIN bokeh-tables.min.js */\n", - " /*!\n", - " * Copyright (c) 2012 - 2023, 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\"], \"3.1.1\");\n", - " })(this, function(Bokeh, version) {\n", - " let define;\n", - " return (function(modules, entry, aliases, externals) {\n", - " const bokeh = typeof Bokeh !== \"undefined\" && (version != null ? Bokeh[version] : Bokeh);\n", - " if (bokeh != null) {\n", - " return bokeh.register_plugin(modules, entry, aliases);\n", - " } else {\n", - " throw new Error(\"Cannot find Bokeh \" + version + \". You have to load it prior to loading plugins.\");\n", - " }\n", - " })\n", - " ({\n", - " 616: function _(t,e,o,r,s){r();const _=t(1).__importStar(t(617));o.Tables=_;(0,t(7).register_models)(_)},\n", - " 617: function _(g,a,r,e,t){e();const o=g(1);o.__exportStar(g(618),r),o.__exportStar(g(621),r),t(\"DataTable\",g(624).DataTable),t(\"TableColumn\",g(642).TableColumn),t(\"TableWidget\",g(641).TableWidget);var n=g(644);t(\"AvgAggregator\",n.AvgAggregator),t(\"MinAggregator\",n.MinAggregator),t(\"MaxAggregator\",n.MaxAggregator),t(\"SumAggregator\",n.SumAggregator);var A=g(645);t(\"GroupingInfo\",A.GroupingInfo),t(\"DataCube\",A.DataCube)},\n", - " 618: function _(e,t,i,s,r){var a,l,n,u,d,o,p,_,c;s();const h=e(1),E=e(56),V=e(8),m=e(55),f=e(50),w=e(619),g=h.__importStar(e(620));class x extends m.DOMComponentView{get emptyValue(){return null}constructor(e){const{model:t,parent:i}=e.column;super(Object.assign({model:t,parent:i},e)),this.args=e,this.initialize(),this.render()}initialize(){super.initialize(),this.inputEl=this._createInput(),this.defaultValue=null}async lazy_initialize(){throw new Error(\"unsupported\")}css_classes(){return super.css_classes().concat(g.cell_editor)}render(){this.args.container.append(this.el),this.shadow_el.appendChild(this.inputEl),this.renderEditor(),this.disableNavigation()}renderEditor(){}disableNavigation(){this.inputEl.addEventListener(\"keydown\",(e=>{switch(e.key){case\"ArrowLeft\":case\"ArrowRight\":case\"ArrowUp\":case\"ArrowDown\":case\"PageUp\":case\"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[w.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=x,x.__name__=\"CellEditorView\";class v extends f.Model{}i.CellEditor=v,v.__name__=\"CellEditor\";class y extends x{get emptyValue(){return\"\"}_createInput(){return(0,E.input)({type:\"text\"})}renderEditor(){this.inputEl.focus(),this.inputEl.select()}loadValue(e){super.loadValue(e),this.inputEl.defaultValue=this.defaultValue,this.inputEl.select()}}i.StringEditorView=y,y.__name__=\"StringEditorView\";class I extends v{}i.StringEditor=I,a=I,I.__name__=\"StringEditor\",a.prototype.default_view=y,a.define((({String:e,Array:t})=>({completions:[t(e),[]]})));class N extends x{_createInput(){return(0,E.textarea)()}renderEditor(){this.inputEl.focus(),this.inputEl.select()}}i.TextEditorView=N,N.__name__=\"TextEditorView\";class b extends v{}i.TextEditor=b,l=b,b.__name__=\"TextEditor\",l.prototype.default_view=N;class C extends x{_createInput(){return(0,E.select)()}renderEditor(){for(const e of this.model.options)this.inputEl.appendChild((0,E.option)({value:e},e));this.focus()}}i.SelectEditorView=C,C.__name__=\"SelectEditorView\";class S extends v{}i.SelectEditor=S,n=S,S.__name__=\"SelectEditor\",n.prototype.default_view=C,n.define((({String:e,Array:t})=>({options:[t(e),[]]})));class D extends x{_createInput(){return(0,E.input)({type:\"text\"})}}i.PercentEditorView=D,D.__name__=\"PercentEditorView\";class k extends v{}i.PercentEditor=k,u=k,k.__name__=\"PercentEditor\",u.prototype.default_view=D;class z extends x{_createInput(){return(0,E.input)({type:\"checkbox\"})}renderEditor(){this.focus()}loadValue(e){this.defaultValue=!!e[this.args.column.field],this.inputEl.checked=this.defaultValue}serializeValue(){return this.inputEl.checked}}i.CheckboxEditorView=z,z.__name__=\"CheckboxEditorView\";class P extends v{}i.CheckboxEditor=P,d=P,P.__name__=\"CheckboxEditor\",d.prototype.default_view=z;class T extends x{_createInput(){return(0,E.input)({type:\"text\"})}renderEditor(){this.inputEl.focus(),this.inputEl.select()}remove(){super.remove()}serializeValue(){const e=parseInt(this.getValue(),10);return isNaN(e)?0:e}loadValue(e){super.loadValue(e),this.inputEl.defaultValue=this.defaultValue,this.inputEl.select()}validateValue(e){return(0,V.isString)(e)&&(e=Number(e)),(0,V.isInteger)(e)?super.validateValue(e):{valid:!1,msg:\"Please enter a valid integer\"}}}i.IntEditorView=T,T.__name__=\"IntEditorView\";class A extends v{}i.IntEditor=A,o=A,A.__name__=\"IntEditor\",o.prototype.default_view=T,o.define((({Int:e})=>({step:[e,1]})));class M extends x{_createInput(){return(0,E.input)({type:\"text\"})}renderEditor(){this.inputEl.focus(),this.inputEl.select()}remove(){super.remove()}serializeValue(){const e=parseFloat(this.getValue());return isNaN(e)?0:e}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=M,M.__name__=\"NumberEditorView\";class O extends v{}i.NumberEditor=O,p=O,O.__name__=\"NumberEditor\",p.prototype.default_view=M,p.define((({Number:e})=>({step:[e,.01]})));class F extends x{_createInput(){return(0,E.input)({type:\"text\"})}}i.TimeEditorView=F,F.__name__=\"TimeEditorView\";class L extends v{}i.TimeEditor=L,_=L,L.__name__=\"TimeEditor\",_.prototype.default_view=F;class U extends x{_createInput(){return(0,E.input)({type:\"text\"})}get emptyValue(){return new Date}renderEditor(){this.inputEl.focus(),this.inputEl.select()}destroy(){super.destroy()}show(){super.show()}hide(){super.hide()}position(){return super.position()}getValue(){}setValue(e){}}i.DateEditorView=U,U.__name__=\"DateEditorView\";class j extends v{}i.DateEditor=j,c=j,j.__name__=\"DateEditor\",c.prototype.default_view=U},\n", - " 619: function _(_,n,i,t,d){t(),i.DTINDEX_NAME=\"__bkdt_internal_index__\"},\n", - " 620: function _(e,l,t,i,r){i(),t.data_table=\"bk-data-table\",t.cell_special_defaults=\"bk-cell-special-defaults\",t.cell_select=\"bk-cell-select\",t.cell_index=\"bk-cell-index\",t.header_index=\"bk-header-index\",t.cell_editor=\"bk-cell-editor\",t.cell_editor_completion=\"bk-cell-editor-completion\",t.default=':host{--data-table-font-size:11px;}.bk-data-table{box-sizing:content-box;width:100%;height:100%;font-size:var(--data-table-font-size);}.bk-data-table input[type=\"checkbox\"]{margin-left:4px;margin-right:4px;}.bk-cell-special-defaults{border-right-color:silver;border-right-style:solid;background:#f5f5f5;}.bk-cell-select{border-right-color:silver;border-right-style:solid;background:#f5f5f5;}.slick-cell.bk-cell-index{border-right-color:silver;border-right-style:solid;background:#f5f5f5;text-align:right;background:#f0f0f0;color:#909090;}.bk-header-index .slick-column-name{float:right;}.slick-row.selected .bk-cell-index{background-color:transparent;}.slick-row.odd{background:#f0f0f0;}.slick-cell{padding-left:4px;padding-right:4px;border-right-color:transparent;border:0.25px solid transparent;}.slick-cell .bk{line-height:inherit;}.slick-cell.active{border-style:dashed;}.slick-cell.selected{background-color:#F0F8FF;}.slick-cell.editable{padding-left:0;padding-right:0;}.bk-cell-editor{display:contents;}.bk-cell-editor input,.bk-cell-editor select{width:100%;height:100%;border:0;margin:0;padding:0;outline:0;background:transparent;vertical-align:baseline;}.bk-cell-editor input{padding-left:4px;padding-right:4px;}.bk-cell-editor-completion{font-size:var(--data-table-font-size);}'},\n", - " 621: function _(t,e,r,n,a){var o,s,i,l,c,u;n();const m=t(1),_=m.__importDefault(t(173)),d=m.__importStar(t(171)),f=t(622),g=t(56),h=t(19),F=t(8),p=t(38),b=t(21),S=t(50);class x extends S.Model{constructor(t){super(t)}doFormat(t,e,r,n,a){return null==r?\"\":`${r}`.replace(/&/g,\"&\").replace(//g,\">\")}}r.CellFormatter=x,x.__name__=\"CellFormatter\";class N extends x{constructor(t){super(t)}doFormat(t,e,r,n,a){const{font_style:o,text_align:s,text_color:i}=this,l=(0,g.div)(null==r?\"\":`${r}`);switch(o){case\"normal\":break;case\"bold\":l.style.fontWeight=\"bold\";break;case\"italic\":l.style.fontStyle=\"italic\";break;case\"bold italic\":l.style.fontWeight=\"bold\",l.style.fontStyle=\"italic\"}return l.style.textAlign=s,null!=i&&(l.style.color=(0,b.color2css)(i)),l.outerHTML}}r.StringFormatter=N,o=N,N.__name__=\"StringFormatter\",o.define((({Color:t,Nullable:e,String:r})=>({font_style:[h.FontStyle,\"normal\"],text_align:[h.TextAlign,\"left\"],text_color:[e(t),null],nan_format:[r,\"-\"]})));class w extends N{constructor(t){super(t)}get scientific_limit_low(){return 10**this.power_limit_low}get scientific_limit_high(){return 10**this.power_limit_high}doFormat(t,e,r,n,a){const o=Math.abs(r)<=this.scientific_limit_low||Math.abs(r)>=this.scientific_limit_high;let s=this.precision;return s<1&&(s=1),r=null==r||isNaN(r)?this.nan_format:0==r?(0,p.to_fixed)(r,1):o?r.toExponential(s):(0,p.to_fixed)(r,s),super.doFormat(t,e,r,n,a)}}r.ScientificFormatter=w,s=w,w.__name__=\"ScientificFormatter\",s.define((({Number:t})=>({precision:[t,10],power_limit_high:[t,5],power_limit_low:[t,-3]})));class y extends N{constructor(t){super(t)}doFormat(t,e,r,n,a){const{format:o,language:s,nan_format:i}=this,l=(()=>{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)?i:d.format(r,o,s,l),super.doFormat(t,e,r,n,a)}}r.NumberFormatter=y,i=y,y.__name__=\"NumberFormatter\",i.define((({String:t})=>({format:[t,\"0,0\"],language:[t,\"en\"],rounding:[h.RoundingFunction,\"round\"]})));class M extends x{constructor(t){super(t)}doFormat(t,e,r,n,a){return r?(0,g.i)({class:this.icon}).outerHTML:\"\"}}r.BooleanFormatter=M,l=M,M.__name__=\"BooleanFormatter\",l.define((({String:t})=>({icon:[t,\"check\"]})));class C extends N{constructor(t){super(t)}getFormat(){switch(this.format){case\"ATOM\":case\"W3C\":case\"RFC-3339\":case\"ISO-8601\":return\"%Y-%m-%d\";case\"COOKIE\":return\"%a, %d %b %Y\";case\"RFC-850\":return\"%A, %d-%b-%y\";case\"RFC-1123\":case\"RFC-2822\":return\"%a, %e %b %Y\";case\"RSS\":case\"RFC-822\":case\"RFC-1036\":return\"%a, %e %b %y\";case\"TIMESTAMP\":return;default:return this.format}}doFormat(t,e,r,n,a){const o=(()=>{if(null==r||(0,F.isNumber)(r))return r;if((0,F.isString)(r)){const t=Number(r);return isNaN(t)?function(t){const e=/Z$|[+-]\\d\\d((:?)\\d\\d)?$/.test(t);return new Date(e?t:`${t}Z`).getTime()}(r):t}return r instanceof Date?r.valueOf():Number(r)})(),s=(()=>null==o||isNaN(o)||-9223372036854776==o?this.nan_format:(0,_.default)(o,this.getFormat()))();return super.doFormat(t,e,s,n,a)}}r.DateFormatter=C,c=C,C.__name__=\"DateFormatter\",c.define((({String:t})=>({format:[t,\"ISO-8601\"]})));class T extends x{constructor(t){super(t)}doFormat(t,e,r,n,a){const{template:o}=this;if(null==r)return\"\";return f._.template(o)(Object.assign(Object.assign({},a),{value:r}))}}r.HTMLTemplateFormatter=T,u=T,T.__name__=\"HTMLTemplateFormatter\",u.define((({String:t})=>({template:[t,\"<%= value %>\"]})))},\n", - " 622: function _(e,n,t,f,i){var o=e(623),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", - " 623: 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", - " 624: function _(e,t,i,s,o){var r;s();const n=e(1),l=e(625),d=e(629),a=e(630),h=e(631),u=e(56),c=e(38),_=e(8),m=e(10),g=e(29),f=e(9),p=e(18),w=e(640),b=e(619),v=e(641),x=e(642),z=e(59),C=n.__importStar(e(620)),y=C,A=n.__importDefault(e(643));i.AutosizeModes={fit_columns:\"FCV\",fit_viewport:\"FVC\",force_fit:\"LFF\",none:\"NOA\"};let D=!1;class N{constructor(e,t){this.init(e,t)}init(e,t){if(b.DTINDEX_NAME in e.data)throw new Error(`special name ${b.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={},{data:i}=this.source;for(const s of(0,f.keys)(i)){const o=i[s],r=this.index[e],n=(0,g.is_NDArray)(o)?o.get(r):o[r];t[s]=n}return t[b.DTINDEX_NAME]=this.index[e],t}getField(e,t){if(t==b.DTINDEX_NAME)return this.index[e];{const{data:i}=this.source,s=i[t],o=this.index[e];return(0,g.is_NDArray)(s)?s.get(o):s[o]}}setField(e,t,i){const s=this.index[e];this.source.patch({[t]:[[s,i]]})}getRecords(){return(0,m.range)(0,this.getLength()).map((e=>this.getItem(e)))}getItems(){return this.getRecords()}slice(e,t,i=1){return t=null!=t?t:this.getLength(),(0,m.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=[[b.DTINDEX_NAME,1]]);const i=this.getRecords(),s=this.index.slice();this.index.sort(((e,o)=>{for(const[r,n]of t){const t=i[s.indexOf(e)][r],l=i[s.indexOf(o)][r];if(t!==l){if((0,_.isNumber)(t)&&(0,_.isNumber)(l))return n*(t-l||+isNaN(t)-+isNaN(l));{const e=`${t}`.localeCompare(`${l}`);if(0==e)continue;return n*e}}}return 0}))}}i.TableDataProvider=N,N.__name__=\"TableDataProvider\";class M extends w.WidgetView{constructor(){super(...arguments),this._in_selection_update=!1,this._width=null}get data_source(){return this.model.properties.source}*children(){yield*super.children(),yield this.cds_view}async lazy_initialize(){await super.lazy_initialize(),this.cds_view=await(0,z.build_view)(this.model.view,{parent:this})}remove(){this.cds_view.remove(),this.grid.destroy(),super.remove()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>{this.render(),this.after_render(),this.invalidate_layout()}));for(const e of this.model.columns)this.connect(e.change,(()=>{this.render(),this.after_render(),this.invalidate_layout()}));this.connect(this.model.view.change,(()=>this.updateGrid())),this.connect(this.model.source.selected.change,(()=>this.updateSelection())),this.connect(this.model.source.selected.properties.indices.change,(()=>this.updateSelection()))}stylesheets(){return[...super.stylesheets(),A.default,C.default]}_after_resize(){super._after_resize(),this.grid.resizeCanvas(),this.updateLayout(!0,!1)}_after_layout(){super._after_layout(),this.grid.resizeCanvas(),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.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(!1===this.model.selectable||this._in_selection_update)return;const{indices:e}=this.model.source.selected,t=(0,m.sort_by)((0,m.map)(e,(e=>this.data.index.indexOf(e))),(e=>e));this._in_selection_update=!0;try{this.grid.setSelectedRows([...t])}finally{this._in_selection_update=!1}const i=this.grid.getViewport(),s=this.model.get_scroll_index(i,t);null!=s&&this.grid.scrollRowToTop(s)}newIndexColumn(){return{id:(0,c.unique_id)(),name:this.model.index_header,field:b.DTINDEX_NAME,width:this.model.index_width,behavior:\"select\",cannotTriggerInsert:!0,resizable:!1,selectable:!1,sortable:!0,cssClass:y.cell_index,headerCssClass:y.header_index}}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(){super.render(),this.wrapper_el=(0,u.div)({class:y.data_table}),this.shadow_el.appendChild(this.wrapper_el)}_after_render(){var e;super._after_render();const t=this.model.columns.filter((e=>e.visible)).map((e=>Object.assign(Object.assign({},e.toColumn()),{parent:this})));let s=null;if(\"checkbox\"==this.model.selectable&&(s=new d.CheckboxSelectColumn({cssClass:y.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 $&&void 0!==$.fn&&\"sortable\"in $.fn||(D||(p.logger.warn(\"jquery-ui is required to enable DataTable.reorderable\"),D=!0),o=!1);let r=-1,n=!1;const{frozen_rows:u,frozen_columns:c}=this.model,m=null==c?-1:c-1;null!=u&&(n=u<0,r=Math.abs(u));const g={enableCellNavigation:!1!==this.model.selectable,enableColumnReorder:o,autosizeColsMode:this.autosize,multiColumnSort:this.model.sortable,editable:this.model.editable,autoEdit:this.model.auto_edit,autoHeight:!1,rowHeight:this.model.row_height,frozenColumn:m,frozenRow:r,frozenBottom:n,explicitInitialization:!1},f=(0,_.is_defined)(this.grid);if(this.data=new N(this.model.source,this.model.view),this.grid=new h.Grid(this.wrapper_el,this.data,t,g),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(0,_.isString)(i)&&(i=i.replace(/\\n/g,\"\\\\n\")),i},includeHeaderWhenCopying:!1};this.grid.registerPlugin(new a.CellExternalCopyManager(e)),this.grid.onSelectedRowsChanged.subscribe(((e,t)=>{this._in_selection_update||(this.model.source.selected.indices=t.rows.map((e=>this.data.index[e])))})),this.updateSelection(),this.model.header_row||this._hide_header()}this.updateLayout(f,!1)}_hide_header(){for(const e of this.shadow_el.querySelectorAll(\".slick-header-columns\"))e.style.height=\"0px\";this.grid.resizeCanvas()}get_selected_rows(){return this.grid.getSelectedRows()}}i.DataTableView=M,M.__name__=\"DataTableView\";class I extends v.TableWidget{get sort_columns(){return this._sort_columns}constructor(e){super(e),this._sort_columns=[]}update_sort_columns(e){this._sort_columns=e.map((({sortCol:e,sortAsc:t})=>({field:e.field,sortAsc:t})))}get_scroll_index(e,t){return this.scroll_to_selection&&0!=t.length?(0,m.some)(t,(t=>e.top<=t&&t<=e.bottom))?null:Math.max(0,Math.min(...t)-1):null}}i.DataTable=I,r=I,I.__name__=\"DataTable\",r.prototype.default_view=M,r.define((({Array:e,Boolean:t,Int:i,Ref:s,String:o,Enum:r,Or:n,Nullable:l})=>({autosize_mode:[r(\"fit_columns\",\"fit_viewport\",\"none\",\"force_fit\"),\"force_fit\"],auto_edit:[t,!1],columns:[e(s(x.TableColumn)),[]],fit_columns:[l(t),null],frozen_columns:[l(i),null],frozen_rows:[l(i),null],sortable:[t,!0],reorderable:[t,!0],editable:[t,!1],selectable:[n(t,r(\"checkbox\")),!0],index_position:[l(i),0],index_header:[o,\"#\"],index_width:[i,40],scroll_to_selection:[t,!0],header_row:[t,!0],row_height:[i,25]}))),r.override({width:600,height:400})},\n", - " 625: function _(e,t,n,o,r){var l=e(626),i=e(628);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+~]|\"+M+\")\"+M+\"*\"),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)(?:\\\\(\"+M+\"*(even|odd|(([+-]|)(\\\\d*)n|)\"+M+\"*(?:([+-]|)\"+M+\"*(\\\\d+)|))\"+M+\"*\\\\)|)\",\"i\"),bool:new RegExp(\"^(?:\"+R+\")$\",\"i\"),needsContext:new RegExp(\"^\"+M+\"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\(\"+M+\"*((?:-\\\\d)?\\\\d*)\"+M+\"*\\\\)|)(?=[^-]|$)\",\"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}\"+M+\"?|\\\\\\\\([^\\\\r\\\\n\\\\f])\",\"g\"),ne=function(e,t){var n=\"0x\"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\\0-\\x1f\\x7f]|^-?\\d)|^-$|[^\\0-\\x1f\\x7f-\\uFFFF\\w-]/g,ie=function(e,t){return t?\"\\0\"===e?\"\\ufffd\":e.slice(0,-1)+\"\\\\\"+e.charCodeAt(e.length-1).toString(16)+\" \":\"\\\\\"+e},oe=function(){p()},ae=be((function(e){return!0===e.disabled&&\"fieldset\"===e.nodeName.toLowerCase()}),{dir:\"parentNode\",next:\"legend\"});try{H.apply(D=O.call(w.childNodes),w.childNodes),D[w.childNodes.length].nodeType}catch(e){H={apply:D.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){for(var n=e.length,r=0;e[n++]=t[r++];);e.length=n-1}}}function se(e,t,r,i){var o,s,l,c,f,h,y,m=t&&t.ownerDocument,w=t?t.nodeType:9;if(r=r||[],\"string\"!=typeof e||!e||1!==w&&9!==w&&11!==w)return r;if(!i&&(p(t),t=t||d,g)){if(11!==w&&(f=Z.exec(e)))if(o=f[1]){if(9===w){if(!(l=t.getElementById(o)))return r;if(l.id===o)return r.push(l),r}else if(m&&(l=m.getElementById(o))&&x(t,l)&&l.id===o)return r.push(l),r}else{if(f[2])return H.apply(r,t.getElementsByTagName(e)),r;if((o=f[3])&&n.getElementsByClassName&&t.getElementsByClassName)return H.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!A[e+\" \"]&&(!v||!v.test(e))&&(1!==w||\"object\"!==t.nodeName.toLowerCase())){if(y=e,m=t,1===w&&(U.test(e)||z.test(e))){for((m=ee.test(e)&&ye(t.parentNode)||t)===t&&n.scope||((c=t.getAttribute(\"id\"))?c=c.replace(re,ie):t.setAttribute(\"id\",c=b)),s=(h=a(e)).length;s--;)h[s]=(c?\"#\"+c:\":scope\")+\" \"+xe(h[s]);y=h.join(\",\")}try{if(n.cssSupportsSelector&&!CSS.supports(\"selector(:is(\"+y+\"))\"))throw new Error;return H.apply(r,m.querySelectorAll(y)),r}catch(t){A(e,!0)}finally{c===b&&t.removeAttribute(\"id\")}}}return u(e.replace(B,\"$1\"),t,r,i)}function ue(){var e=[];return function t(n,i){return e.push(n+\" \")>r.cacheLength&&delete t[e.shift()],t[n+\" \"]=i}}function le(e){return e[b]=!0,e}function ce(e){var t=d.createElement(\"fieldset\");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){for(var n=e.split(\"|\"),i=n.length;i--;)r.attrHandle[n[i]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)for(;n=n.nextSibling;)if(n===t)return-1;return e?1:-1}function de(e){return function(t){return\"input\"===t.nodeName.toLowerCase()&&t.type===e}}function he(e){return function(t){var n=t.nodeName.toLowerCase();return(\"input\"===n||\"button\"===n)&&t.type===e}}function ge(e){return function(t){return\"form\"in t?t.parentNode&&!1===t.disabled?\"label\"in t?\"label\"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&ae(t)===e:t.disabled===e:\"label\"in t&&t.disabled===e}}function ve(e){return le((function(t){return t=+t,le((function(n,r){for(var i,o=e([],n.length,t),a=o.length;a--;)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))}))}))}function ye(e){return e&&void 0!==e.getElementsByTagName&&e}for(t in n=se.support={},o=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||\"HTML\")},p=se.setDocument=function(e){var t,i,a=e?e.ownerDocument||e:w;return a!=d&&9===a.nodeType&&a.documentElement?(h=(d=a).documentElement,g=!o(d),w!=d&&(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener(\"unload\",oe,!1):i.attachEvent&&i.attachEvent(\"onunload\",oe)),n.scope=ce((function(e){return h.appendChild(e).appendChild(d.createElement(\"div\")),void 0!==e.querySelectorAll&&!e.querySelectorAll(\":scope fieldset div\").length})),n.cssSupportsSelector=ce((function(){return CSS.supports(\"selector(*)\")&&d.querySelectorAll(\":is(:jqfake)\")&&!CSS.supports(\"selector(:is(*,:jqfake))\")})),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(\"[*^$]=\"+M+\"*(?:''|\\\"\\\")\"),e.querySelectorAll(\"[selected]\").length||v.push(\"\\\\[\"+M+\"*(?:value|\"+R+\")\"),e.querySelectorAll(\"[id~=\"+b+\"-]\").length||v.push(\"~=\"),(t=d.createElement(\"input\")).setAttribute(\"name\",\"\"),e.appendChild(t),e.querySelectorAll(\"[name='']\").length||v.push(\"\\\\[\"+M+\"*name\"+M+\"*=\"+M+\"*(?:''|\\\"\\\")\"),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\"+M+\"*[*^$|!~]?=\"),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)})),n.cssSupportsSelector||v.push(\":has\"),v=v.length&&new RegExp(v.join(\"|\")),y=y.length&&new RegExp(y.join(\"|\")),t=K.test(h.compareDocumentPosition),x=t||K.test(h.contains)?function(e,t){var n=9===e.nodeType&&e.documentElement||e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)for(;t=t.parentNode;)if(t===e)return!0;return!1},N=t?function(e,t){if(e===t)return f=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e==d||e.ownerDocument==w&&x(w,e)?-1:t==d||t.ownerDocument==w&&x(w,t)?1:c?P(c,e)-P(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return f=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==d?-1:t==d?1:i?-1:o?1:c?P(c,e)-P(c,t):0;if(i===o)return pe(e,t);for(n=e;n=n.parentNode;)a.unshift(n);for(n=t;n=n.parentNode;)s.unshift(n);for(;a[r]===s[r];)r++;return r?pe(a[r],s[r]):a[r]==w?-1:s[r]==w?1:0},d):d},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(p(e),n.matchesSelector&&g&&!A[t+\" \"]&&(!y||!y.test(t))&&(!v||!v.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(e){A(t,!0)}return se(t,d,null,[e]).length>0},se.contains=function(e,t){return(e.ownerDocument||e)!=d&&p(e),x(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=d&&p(e);var i=r.attrHandle[t.toLowerCase()],o=i&&j.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},se.escape=function(e){return(e+\"\").replace(re,ie)},se.error=function(e){throw new Error(\"Syntax error, unrecognized expression: \"+e)},se.uniqueSort=function(e){var t,r=[],i=0,o=0;if(f=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(N),f){for(;t=e[o++];)t===e[o]&&(i=r.push(o));for(;i--;)e.splice(r[i],1)}return c=null,e},i=se.getText=function(e){var t,n=\"\",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if(\"string\"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else for(;t=e[r++];)n+=i(t);return n},r=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{\">\":{dir:\"parentNode\",first:!0},\" \":{dir:\"parentNode\"},\"+\":{dir:\"previousSibling\",first:!0},\"~\":{dir:\"previousSibling\"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||\"\").replace(te,ne),\"~=\"===e[2]&&(e[3]=\" \"+e[3]+\" \"),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),\"nth\"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*(\"even\"===e[3]||\"odd\"===e[3])),e[5]=+(e[7]+e[8]||\"odd\"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||\"\":n&&X.test(n)&&(t=a(n,!0))&&(t=n.indexOf(\")\",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return\"*\"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=S[e+\" \"];return t||(t=new RegExp(\"(^|\"+M+\")\"+e+\"(\"+M+\"|$)\"))&&S(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($,\" \")+\" \").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(B,\"$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 Se(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(B,\"$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),S=T+=null==w?1:Math.random()||.1,E=C.length;for(c&&(l=a==d||a||c);m!==E&&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=S)}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=S,l=w),x};return n?le(o):o}(o,i)),s.selector=e}return s},u=se.select=function(e,t,n,i){var o,u,l,c,f,p=\"function\"==typeof e&&e,d=!i&&a(e=p.selector||e);if(n=n||[],1===d.length){if((u=d[0]=d[0].slice(0)).length>2&&\"ID\"===(l=u[0]).type&&9===t.nodeType&&g&&r.relative[u[1].type]){if(!(t=(r.find.ID(l.matches[0].replace(te,ne),t)||[])[0]))return n;p&&(t=t.parentNode),e=e.slice(u.shift().value.length)}for(o=G.needsContext.test(e)?0:u.length;o--&&(l=u[o],!r.relative[c=l.type]);)if((f=r.find[c])&&(i=f(l.matches[0].replace(te,ne),ee.test(u[0].type)&&ye(t.parentNode)||t))){if(u.splice(o,1),!(e=i.length&&xe(u)))return H.apply(n,i),n;break}}return(p||s(e,d))(i,t,!g,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},n.sortStable=b.split(\"\").sort(N).join(\"\")===b,n.detectDuplicates=!!f,p(),n.sortDetached=ce((function(e){return 1&e.compareDocumentPosition(d.createElement(\"fieldset\"))})),ce((function(e){return e.innerHTML=\"\",\"#\"===e.firstChild.getAttribute(\"href\")}))||fe(\"type|href|height|width\",(function(e,t,n){if(!n)return e.getAttribute(t,\"type\"===t.toLowerCase()?1:2)})),n.attributes&&ce((function(e){return e.innerHTML=\"\",e.firstChild.setAttribute(\"value\",\"\"),\"\"===e.firstChild.getAttribute(\"value\")}))||fe(\"value\",(function(e,t,n){if(!n&&\"input\"===e.nodeName.toLowerCase())return e.defaultValue})),ce((function(e){return null==e.getAttribute(\"disabled\")}))||fe(R,(function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null})),se}(e);w.find=C,w.expr=C.selectors,w.expr[\":\"]=w.expr.pseudos,w.uniqueSort=w.unique=C.uniqueSort,w.text=C.getText,w.isXMLDoc=C.isXML,w.contains=C.contains,w.escapeSelector=C.escape;var S=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},E=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=w.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\\/\\0>:\\x20\\t\\r\\n\\f]*)[\\x20\\t\\r\\n\\f]*\\/?>(?:<\\/\\1>|)$/i;function j(e,t,n){return h(t)?w.grep(e,(function(e,r){return!!t.call(e,r,e)!==n})):t.nodeType?w.grep(e,(function(e){return e===t!==n})):\"string\"!=typeof t?w.grep(e,(function(e){return s.call(t,e)>-1!==n})):w.filter(t,e,n)}w.filter=function(e,t,n){var r=t[0];return n&&(e=\":not(\"+e+\")\"),1===t.length&&1===r.nodeType?w.find.matchesSelector(r,e)?[r]:[]:w.find.matches(e,w.grep(t,(function(e){return 1===e.nodeType})))},w.fn.extend({find:function(e){var t,n,r=this.length,i=this;if(\"string\"!=typeof e)return this.pushStack(w(e).filter((function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,\"string\"==typeof e&&k.test(e)?w(e):e||[],!1).length}});var D,q=/^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]+))$/;(w.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,\"string\"==typeof e){if(!(r=\"<\"===e[0]&&\">\"===e[e.length-1]&&e.length>=3?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:v,!0)),N.test(r[1])&&w.isPlainObject(t))for(r in t)h(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=v.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):h(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,D=w(v);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){for(;(e=e[t])&&1!==e.nodeType;);return e}w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter((function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?w.uniqueSort(o):o)},index:function(e){return e?\"string\"==typeof e?s.call(w(e),this[0]):s.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return S(e,\"parentNode\")},parentsUntil:function(e,t,n){return S(e,\"parentNode\",n)},next:function(e){return O(e,\"nextSibling\")},prev:function(e){return O(e,\"previousSibling\")},nextAll:function(e){return S(e,\"nextSibling\")},prevAll:function(e){return S(e,\"previousSibling\")},nextUntil:function(e,t,n){return S(e,\"nextSibling\",n)},prevUntil:function(e,t,n){return S(e,\"previousSibling\",n)},siblings:function(e){return E((e.parentNode||{}).firstChild,e)},children:function(e){return E(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 $(){v.removeEventListener(\"DOMContentLoaded\",$),e.removeEventListener(\"load\",$),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\",$),e.addEventListener(\"load\",$));var B=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)B(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,h(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(w(e),n)})),t))for(;s1,null,!0)},removeData:function(e){return this.each((function(){Q.remove(this,e)}))}}),w.extend({queue:function(e,t,n){var r;if(e)return t=(t||\"fx\")+\"queue\",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,w.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||\"fx\";var n=w.queue(e,t),r=n.length,i=n.shift(),o=w._queueHooks(e,t);\"inprogress\"===i&&(i=n.shift(),r--),i&&(\"fx\"===t&&n.unshift(\"inprogress\"),delete o.stop,i.call(e,(function(){w.dequeue(e,t)}),o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+\"queueHooks\";return Y.get(e,n)||Y.access(e,n,{empty:w.Callbacks(\"once memory\").add((function(){Y.remove(e,[t+\"queue\",n])}))})}}),w.fn.extend({queue:function(e,t){var n=2;return\"string\"!=typeof e&&(t=e,e=\"fx\",n--),arguments.length\\x20\\t\\r\\n\\f]*)/i,ge=/^$|^module$|\\/(?:java|ecma)script/i;fe=v.createDocumentFragment().appendChild(v.createElement(\"div\")),(pe=v.createElement(\"input\")).setAttribute(\"type\",\"radio\"),pe.setAttribute(\"checked\",\"checked\"),pe.setAttribute(\"name\",\"t\"),fe.appendChild(pe),d.checkClone=fe.cloneNode(!0).cloneNode(!0).lastChild.checked,fe.innerHTML=\"\",d.noCloneChecked=!!fe.cloneNode(!0).lastChild.defaultValue,fe.innerHTML=\"\",d.option=!!fe.lastChild;var ve={thead:[1,\"\",\"
\"],col:[2,\"\",\"
\"],tr:[2,\"\",\"
\"],td:[3,\"\",\"
\"],_default:[0,\"\",\"\"]};function ye(e,t){var n;return n=void 0!==e.getElementsByTagName?e.getElementsByTagName(t||\"*\"):void 0!==e.querySelectorAll?e.querySelectorAll(t||\"*\"):[],void 0===t||t&&A(e,t)?w.merge([e],n):n}function me(e,t){for(var n=0,r=e.length;n\",\"\"]);var xe=/<|&#?\\w+;/;function be(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d-1)i&&i.push(o);else if(l=ie(o),a=ye(f.appendChild(o),\"script\"),l&&me(a),n)for(c=0;o=a[c++];)ge.test(o.type||\"\")&&n.push(o);return f}var we=/^([^.]*)(?:\\.(.+)|)/;function Te(){return!0}function Ce(){return!1}function Se(e,t){return e===function(){try{return v.activeElement}catch(e){}}()==(\"focus\"===t)}function Ee(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)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&(\"string\"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Ce;else if(!i)return e;return 1===o&&(a=i,i=function(e){return w().off(e),a.apply(this,arguments)},i.guid=a.guid||(a.guid=w.guid++)),e.each((function(){w.event.add(this,t,i,r,n)}))}function ke(e,t,n){n?(Y.set(e,t,!1),w.event.add(e,t,{namespace:!1,handler:function(e){var r,o,a=Y.get(this,t);if(1&e.isTrigger&&this[t]){if(a.length)(w.event.special[t]||{}).delegateType&&e.stopPropagation();else if(a=i.call(arguments),Y.set(this,t,a),r=n(this,t),this[t](),a!==(o=Y.get(this,t))||r?Y.set(this,t,!1):o={},a!==o)return e.stopImmediatePropagation(),e.preventDefault(),o&&o.value}else a.length&&(Y.set(this,t,{value:w.event.trigger(w.extend(a[0],w.Event.prototype),a.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,t)&&w.event.add(e,t,Te)}w.event={global:{},add:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(e);if(V(e))for(n.handler&&(n=(o=n).handler,i=o.selector),i&&w.find.matchesSelector(re,i),n.guid||(n.guid=w.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(t){return void 0!==w&&w.event.triggered!==t.type?w.event.dispatch.apply(e,arguments):void 0}),l=(t=(t||\"\").match(P)||[\"\"]).length;l--;)d=g=(s=we.exec(t[l])||[])[1],h=(s[2]||\"\").split(\".\").sort(),d&&(f=w.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=w.event.special[d]||{},c=w.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&w.expr.match.needsContext.test(i),namespace:h.join(\".\")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(e,r,h,a)||e.addEventListener&&e.addEventListener(d,a)),f.add&&(f.add.call(e,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),w.event.global[d]=!0)},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){for(l=(t=(t||\"\").match(P)||[\"\"]).length;l--;)if(d=g=(s=we.exec(t[l])||[])[1],h=(s[2]||\"\").split(\".\").sort(),d){for(f=w.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp(\"(^|\\\\.)\"+h.join(\"\\\\.(?:.*\\\\.|)\")+\"(\\\\.|$)\"),a=o=p.length;o--;)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&(\"**\"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||w.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)w.event.remove(e,d+t[l],n,r,!0);w.isEmptyObject(u)&&Y.remove(e,\"handle events\")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=w.event.fix(e),l=(Y.get(this,\"events\")||Object.create(null))[u.type]||[],c=w.event.special[u.type]||{};for(s[0]=u,t=1;t=1))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&(\"click\"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n-1:w.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u\\s*$/g;function De(e,t){return A(e,\"table\")&&A(11!==t.nodeType?t:t.firstChild,\"tr\")&&w(e).children(\"tbody\")[0]||e}function qe(e){return e.type=(null!==e.getAttribute(\"type\"))+\"/\"+e.type,e}function Le(e){return\"true/\"===(e.type||\"\").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute(\"type\"),e}function He(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,\"handle events\"),s)for(n=0,r=s[i].length;n1&&\"string\"==typeof v&&!d.checkClone&&Ne.test(v))return e.each((function(i){var o=e.eq(i);y&&(t[0]=v.call(this,i,o.html())),Pe(o,t,n,r)}));if(p&&(a=(i=be(t,e[0].ownerDocument,!1,e,r)).firstChild,1===i.childNodes.length&&(i=a),a||r)){for(u=(s=w.map(ye(i,\"script\"),qe)).length;f0&&me(a,!u&&ye(e,\"script\")),s},cleanData:function(e){for(var t,n,r,i=w.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?w.event.remove(n,r):w.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),w.fn.extend({detach:function(e){return Re(this,e,!0)},remove:function(e){return Re(this,e)},text:function(e){return B(this,(function(e){return void 0===e?w.text(this):this.empty().each((function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)}))}),null,e,arguments.length)},append:function(){return Pe(this,arguments,(function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||De(this,e).appendChild(e)}))},prepend:function(){return Pe(this,arguments,(function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=De(this,e);t.insertBefore(e,t.firstChild)}}))},before:function(){return Pe(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this)}))},after:function(){return Pe(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)}))},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(w.cleanData(ye(e,!1)),e.textContent=\"\");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map((function(){return w.clone(this,e,t)}))},html:function(e){return B(this,(function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if(\"string\"==typeof e&&!Ae.test(e)&&!ve[(he.exec(e)||[\"\",\"\"])[1].toLowerCase()]){e=w.htmlPrefilter(e);try{for(;n=0&&(u+=Math.max(0,Math.ceil(e[\"offset\"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function tt(e,t,n){var r=We(e),i=(!d.boxSizingReliable()||n)&&\"border-box\"===w.css(e,\"boxSizing\",!1,r),o=i,a=ze(e,t,r),s=\"offset\"+t[0].toUpperCase()+t.slice(1);if(Me.test(a)){if(!n)return a;a=\"auto\"}return(!d.boxSizingReliable()&&i||!d.reliableTrDimensions()&&A(e,\"tr\")||\"auto\"===a||!parseFloat(a)&&\"inline\"===w.css(e,\"display\",!1,r))&&e.getClientRects().length&&(i=\"border-box\"===w.css(e,\"boxSizing\",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+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=ze(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=Ie.test(t),l=e.style;if(u||(t=Ye(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 Ie.test(t)||(t=Ye(s)),(a=w.cssHooks[t]||w.cssHooks[s])&&\"get\"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=ze(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!Qe.test(w.css(e,\"display\"))||e.getClientRects().length&&e.getBoundingClientRect().width?tt(e,t,r):Fe(e,Je,(function(){return tt(e,t,r)}))},set:function(e,n,r){var i,o=We(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=Ue(d.reliableMarginLeft,(function(e,t){if(t)return(parseFloat(ze(e,\"marginLeft\"))||e.getBoundingClientRect().left-Fe(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 B(this,(function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=We(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[Ye(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 B(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;return h(e)?this.each((function(t){w(this).addClass(e.call(this,t,yt(this)))})):(t=mt(e)).length?this.each((function(){if(r=yt(this),n=1===this.nodeType&&\" \"+vt(r)+\" \"){for(o=0;o-1;)n=n.replace(\" \"+i+\" \",\" \");a=vt(n),r!==a&&this.setAttribute(\"class\",a)}})):this:this.attr(\"class\",\"\")},toggleClass:function(e,t){var n,r,i,o,a=typeof e,s=\"string\"===a||Array.isArray(e);return h(e)?this.each((function(n){w(this).toggleClass(e.call(this,n,yt(this),t),t)})):\"boolean\"==typeof t&&s?t?this.addClass(e):this.removeClass(e):(n=mt(e),this.each((function(){if(s)for(o=w(this),i=0;i-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()},St=/\\?/;w.parseXML=function(t){var n,r;if(!t||\"string\"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,\"text/xml\")}catch(e){}return r=n&&n.getElementsByTagName(\"parsererror\")[0],n&&!r||w.error(\"Invalid XML: \"+(r?w.map(r.childNodes,(function(e){return e.textContent})).join(\"\\n\"):t)),n};var Et=/\\[\\]$/,kt=/\\r?\\n/g,At=/^(?:submit|button|image|reset|file)$/i,Nt=/^(?:input|select|textarea|keygen)/i;function jt(e,t,n,r){var i;if(Array.isArray(t))w.each(t,(function(t,i){n||Et.test(e)?r(e,i):jt(e+\"[\"+(\"object\"==typeof i&&null!=i?t:\"\")+\"]\",i,n,r)}));else if(n||\"object\"!==x(t))r(e,t);else for(i in t)jt(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)jt(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 Dt=/%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 $t(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 Bt(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?Bt(Bt(e,w.ajaxSettings),t):Bt(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\",S={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)S.always(e[S.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),E(0,t),this}};if(y.promise(S),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)),$t(Rt,d,n,S),l)return S;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(Dt,\"+\")):(p=d.url.slice(i.length),d.data&&(d.processData||\"string\"==typeof d.data)&&(i+=(St.test(i)?\"&\":\"?\")+d.data,delete d.data),!1===d.cache&&(i=i.replace(Lt,\"$1\"),p=(St.test(i)?\"&\":\"?\")+\"_=\"+Ct.guid+++p),d.url=i+p),d.ifModified&&(w.lastModified[i]&&S.setRequestHeader(\"If-Modified-Since\",w.lastModified[i]),w.etag[i]&&S.setRequestHeader(\"If-None-Match\",w.etag[i])),(d.data&&d.hasContent&&!1!==d.contentType||n.contentType)&&S.setRequestHeader(\"Content-Type\",d.contentType),S.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)S.setRequestHeader(f,d.headers[f]);if(d.beforeSend&&(!1===d.beforeSend.call(h,S,d)||l))return S.abort();if(C=\"abort\",m.add(d.complete),S.done(d.success),S.fail(d.error),r=$t(Mt,d,n,S)){if(S.readyState=1,c&&g.trigger(\"ajaxSend\",[S,d]),l)return S;d.async&&d.timeout>0&&(s=e.setTimeout((function(){S.abort(\"timeout\")}),d.timeout));try{l=!1,r.send(b,E)}catch(e){if(l)throw e;E(-1,e)}}else E(-1,\"No Transport\");function E(t,n,a,u){var f,p,v,b,T,C=n;l||(l=!0,s&&e.clearTimeout(s),r=void 0,o=u||\"\",S.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,S,a)),!f&&w.inArray(\"script\",d.dataTypes)>-1&&w.inArray(\"json\",d.dataTypes)<0&&(d.converters[\"text script\"]=function(){}),b=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];for(o=c.shift();o;)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if(\"*\"===o)o=u;else if(\"*\"!==u&&u!==o){if(!(a=l[u+\" \"+o]||l[\"* \"+o]))for(i in l)if((s=i.split(\" \"))[1]===o&&(a=l[u+\" \"+s[0]]||l[\"* \"+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e.throws)t=a(t);else try{t=a(t)}catch(e){return{state:\"parsererror\",error:a?e:\"No conversion from \"+u+\" to \"+o}}}return{state:\"success\",data:t}}(d,b,S,f),f?(d.ifModified&&((T=S.getResponseHeader(\"Last-Modified\"))&&(w.lastModified[i]=T),(T=S.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))),S.status=t,S.statusText=(n||C)+\"\",f?y.resolveWith(h,[p,C,S]):y.rejectWith(h,[S,C,v]),S.statusCode(x),x=void 0,c&&g.trigger(f?\"ajaxSuccess\":\"ajaxError\",[S,d,f?p:v]),m.fireWith(h,[S,C]),c&&(g.trigger(\"ajaxComplete\",[S,d]),--w.active||w.event.trigger(\"ajaxStop\")))}return S},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, height=300, sizing_mode='fixed', widget_location='bottom', width=700)\n", - " [1] WidgetBox(align=('center', 'end'))\n", - " [0] Select(margin=(20, 20, 20, 20), name='id', options=['020302', '020404', ...], value='020302', width=250)" - ] - }, - "execution_count": 3, - "metadata": { - "application/vnd.holoviews_exec.v0+json": { - "id": "p1001" - } - }, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "ds.streamflow.dropna(\"time\", how=\"all\").hvplot(\n", " x=\"time\", grid=True, widget_location=\"bottom\", groupby=\"id\"\n", @@ -2421,7 +104,7 @@ }, { "cell_type": "code", - "execution_count": 4, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -2463,719 +146,9 @@ }, { "cell_type": "code", - "execution_count": 5, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset> Size: 8kB\n",
-       "Dimensions:                (id: 5, time: 56)\n",
-       "Coordinates: (12/15)\n",
-       "    drainage_area          (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n",
-       "    end_date               (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n",
-       "  * id                     (id) object 40B '020302' '020404' ... '020802'\n",
-       "    latitude               (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n",
-       "    longitude              (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n",
-       "    name                   (id) object 40B 'Saint' 'York' ... 'Madeleine'\n",
-       "    ...                     ...\n",
-       "    spatial_agg            <U9 36B 'watershed'\n",
-       "    start_date             (id) datetime64[ns] 40B 1989-08-12 ... 1970-01-01\n",
-       "    time_agg               <U4 16B 'mean'\n",
-       "    timestep               <U1 4B 'D'\n",
-       "    variable               <U10 40B 'streamflow'\n",
-       "  * time                   (time) datetime64[ns] 448B 1970-01-01 ... 2025-01-01\n",
-       "Data variables:\n",
-       "    streamflow_max_spring  (id, time) float32 1kB nan nan nan ... nan nan nan\n",
-       "    streamflow_max_summer  (id, time) float32 1kB nan nan nan ... nan nan nan\n",
-       "    streamflow_max_fall    (id, time) float32 1kB nan nan nan ... nan nan nan\n",
-       "    streamflow_max_august  (id, time) float32 1kB nan nan nan ... nan nan nan\n",
-       "    streamflow_max_annual  (id, time) float32 1kB nan nan nan ... nan nan nan\n",
-       "    streamflow_max_winter  (id, time) float32 1kB nan nan nan ... nan nan nan\n",
-       "Attributes:\n",
-       "    cat:frequency:         yr\n",
-       "    cat:processing_level:  indicators\n",
-       "    cat:id:                
" - ], - "text/plain": [ - " Size: 8kB\n", - "Dimensions: (id: 5, time: 56)\n", - "Coordinates: (12/15)\n", - " drainage_area (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n", - " end_date (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n", - " * id (id) object 40B '020302' '020404' ... '020802'\n", - " latitude (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n", - " longitude (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n", - " name (id) object 40B 'Saint' 'York' ... 'Madeleine'\n", - " ... ...\n", - " spatial_agg \n", - "
\n", - "\n", - "" - ], - "text/plain": [ - "Column\n", - " [0] HoloViews(DynamicMap, height=300, sizing_mode='fixed', widget_location='bottom', width=700)\n", - " [1] WidgetBox(align=('center', 'end'))\n", - " [0] Select(margin=(20, 20, 20, 20), name='id', options=['020302', '020404', ...], value='020302', width=250)" - ] - }, - "execution_count": 6, - "metadata": { - "application/vnd.holoviews_exec.v0+json": { - "id": "p1519" - } - }, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "ds_4fa.streamflow_max_summer.dropna(\"time\", how=\"all\").hvplot(\n", " x=\"time\", grid=True, widget_location=\"bottom\", groupby=\"id\"\n", @@ -3304,7 +180,7 @@ }, { "cell_type": "code", - "execution_count": 7, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -3338,113 +214,16 @@ }, { "cell_type": "code", - "execution_count": 8, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": {}, - "metadata": {}, - "output_type": "display_data" - }, - { - "data": {}, - "metadata": {}, - "output_type": "display_data" - }, - { - "data": { - "application/vnd.holoviews_exec.v0+json": "", - "text/html": [ - "
\n", - "
\n", - "
\n", - "" - ], - "text/plain": [ - "Column\n", - " [0] HoloViews(DynamicMap, height=300, sizing_mode='fixed', widget_location='bottom', width=700)\n", - " [1] WidgetBox(align=('center', 'end'))\n", - " [0] Select(margin=(20, 20, 20, 20), name='id', options=['020302', '020404', ...], value='020302', width=250)" - ] - }, - "execution_count": 8, - "metadata": { - "application/vnd.holoviews_exec.v0+json": { - "id": "p1999" - } - }, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "mask.hvplot(x=\"time\", grid=True, widget_location=\"bottom\", groupby=\"id\")" ] }, { "cell_type": "code", - "execution_count": 9, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -3474,106 +253,9 @@ }, { "cell_type": "code", - "execution_count": 10, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": {}, - "metadata": {}, - "output_type": "display_data" - }, - { - "data": {}, - "metadata": {}, - "output_type": "display_data" - }, - { - "data": { - "application/vnd.holoviews_exec.v0+json": "", - "text/html": [ - "
\n", - "
\n", - "
\n", - "" - ], - "text/plain": [ - "Column\n", - " [0] HoloViews(DynamicMap, height=300, sizing_mode='fixed', widget_location='bottom', width=700)\n", - " [1] WidgetBox(align=('center', 'end'))\n", - " [0] Select(margin=(20, 20, 20, 20), name='id', options=['020302', '020404', ...], value='020302', width=250)" - ] - }, - "execution_count": 10, - "metadata": { - "application/vnd.holoviews_exec.v0+json": { - "id": "p2479" - } - }, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "ds_4fa.streamflow_max_custom.dropna(\"time\", how=\"all\").hvplot(\n", " x=\"time\", grid=True, widget_location=\"bottom\", groupby=\"id\"\n", @@ -3591,7 +273,7 @@ }, { "cell_type": "code", - "execution_count": 11, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -3620,106 +302,9 @@ }, { "cell_type": "code", - "execution_count": 12, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": {}, - "metadata": {}, - "output_type": "display_data" - }, - { - "data": {}, - "metadata": {}, - "output_type": "display_data" - }, - { - "data": { - "application/vnd.holoviews_exec.v0+json": "", - "text/html": [ - "
\n", - "
\n", - "
\n", - "" - ], - "text/plain": [ - "Column\n", - " [0] HoloViews(DynamicMap, height=300, sizing_mode='fixed', widget_location='bottom', width=700)\n", - " [1] WidgetBox(align=('center', 'end'))\n", - " [0] Select(margin=(20, 20, 20, 20), name='id', options=['020302', '020404', ...], value='020302', width=250)" - ] - }, - "execution_count": 12, - "metadata": { - "application/vnd.holoviews_exec.v0+json": { - "id": "p2959" - } - }, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "ds_4fa.volume_sum_spring.dropna(\"time\", how=\"all\").hvplot(\n", " x=\"time\", grid=True, widget_location=\"bottom\", groupby=\"id\"\n", @@ -3741,624 +326,9 @@ }, { "cell_type": "code", - "execution_count": 13, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset> Size: 4kB\n",
-       "Dimensions:                (id: 5, dparams: 5, scipy_dist: 7)\n",
-       "Coordinates: (12/16)\n",
-       "  * id                     (id) object 40B '020302' '020404' ... '020802'\n",
-       "  * dparams                (dparams) <U5 100B 'a' 'c' 'skew' 'loc' 'scale'\n",
-       "  * scipy_dist             (scipy_dist) <U11 308B 'expon' ... 'weibull_min'\n",
-       "    drainage_area          (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n",
-       "    end_date               (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n",
-       "    latitude               (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n",
-       "    ...                     ...\n",
-       "    source                 <U102 408B 'Ministère de l’Environnement, de la Lu...\n",
-       "    spatial_agg            <U9 36B 'watershed'\n",
-       "    start_date             (id) datetime64[ns] 40B 1989-08-12 ... 1970-01-01\n",
-       "    time_agg               <U4 16B 'mean'\n",
-       "    timestep               <U1 4B 'D'\n",
-       "    variable               <U10 40B 'streamflow'\n",
-       "Data variables:\n",
-       "    streamflow_max_spring  (scipy_dist, id, dparams) float64 1kB dask.array<chunksize=(1, 5, 5), meta=np.ndarray>\n",
-       "    volume_sum_spring      (scipy_dist, id, dparams) float64 1kB dask.array<chunksize=(1, 5, 5), meta=np.ndarray>\n",
-       "Attributes:\n",
-       "    cat:frequency:         yr\n",
-       "    cat:processing_level:  indicators\n",
-       "    cat:id:                
" - ], - "text/plain": [ - " Size: 4kB\n", - "Dimensions: (id: 5, dparams: 5, scipy_dist: 7)\n", - "Coordinates: (12/16)\n", - " * id (id) object 40B '020302' '020404' ... '020802'\n", - " * dparams (dparams) \n", - " volume_sum_spring (scipy_dist, id, dparams) float64 1kB dask.array\n", - "Attributes:\n", - " cat:frequency: yr\n", - " cat:processing_level: indicators\n", - " cat:id: " - ] - }, - "execution_count": 13, - "metadata": {}, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "# To speed up the Notebook, we'll only perform the analysis on a subset of variables\n", "params = xhfa.local.fit(\n", @@ -4377,624 +347,9 @@ }, { "cell_type": "code", - "execution_count": 14, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset> Size: 3kB\n",
-       "Dimensions:                (id: 5, scipy_dist: 7, criterion: 3)\n",
-       "Coordinates: (12/16)\n",
-       "    drainage_area          (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n",
-       "    end_date               (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n",
-       "  * id                     (id) object 40B '020302' '020404' ... '020802'\n",
-       "    latitude               (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n",
-       "    longitude              (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n",
-       "    name                   (id) object 40B 'Saint' 'York' ... 'Madeleine'\n",
-       "    ...                     ...\n",
-       "    start_date             (id) datetime64[ns] 40B 1989-08-12 ... 1970-01-01\n",
-       "    time_agg               <U4 16B 'mean'\n",
-       "    timestep               <U1 4B 'D'\n",
-       "    variable               <U10 40B 'streamflow'\n",
-       "  * scipy_dist             (scipy_dist) <U11 308B 'expon' ... 'weibull_min'\n",
-       "  * criterion              (criterion) <U4 48B 'aic' 'bic' 'aicc'\n",
-       "Data variables:\n",
-       "    streamflow_max_spring  (scipy_dist, id, criterion) float64 840B dask.array<chunksize=(1, 5, 3), meta=np.ndarray>\n",
-       "    volume_sum_spring      (scipy_dist, id, criterion) float64 840B dask.array<chunksize=(1, 5, 3), meta=np.ndarray>\n",
-       "Attributes:\n",
-       "    cat:frequency:         yr\n",
-       "    cat:processing_level:  indicators\n",
-       "    cat:id:                
" - ], - "text/plain": [ - " Size: 3kB\n", - "Dimensions: (id: 5, scipy_dist: 7, criterion: 3)\n", - "Coordinates: (12/16)\n", - " drainage_area (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n", - " end_date (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n", - " * id (id) object 40B '020302' '020404' ... '020802'\n", - " latitude (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n", - " longitude (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n", - " name (id) object 40B 'Saint' 'York' ... 'Madeleine'\n", - " ... ...\n", - " start_date (id) datetime64[ns] 40B 1989-08-12 ... 1970-01-01\n", - " time_agg \n", - " volume_sum_spring (scipy_dist, id, criterion) float64 840B dask.array\n", - "Attributes:\n", - " cat:frequency: yr\n", - " cat:processing_level: indicators\n", - " cat:id: " - ] - }, - "execution_count": 14, - "metadata": {}, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "criteria = xhfa.local.criteria(\n", " ds_4fa[[\"streamflow_max_spring\", \"volume_sum_spring\"]], params\n", @@ -5015,512 +370,9 @@ }, { "cell_type": "code", - "execution_count": 15, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset> Size: 2kB\n",
-       "Dimensions:                (id: 5, scipy_dist: 7, return_period: 2)\n",
-       "Coordinates: (12/17)\n",
-       "  * id                     (id) object 40B '020302' '020404' ... '020802'\n",
-       "  * scipy_dist             (scipy_dist) <U11 308B 'expon' ... 'weibull_min'\n",
-       "    drainage_area          (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n",
-       "    end_date               (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n",
-       "    latitude               (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n",
-       "    longitude              (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n",
-       "    ...                     ...\n",
-       "    start_date             (id) datetime64[ns] 40B 1989-08-12 ... 1970-01-01\n",
-       "    time_agg               <U4 16B 'mean'\n",
-       "    timestep               <U1 4B 'D'\n",
-       "    variable               <U10 40B 'streamflow'\n",
-       "  * return_period          (return_period) int64 16B 20 100\n",
-       "    p_quantile             (return_period) float64 16B 0.95 0.99\n",
-       "Data variables:\n",
-       "    streamflow_max_spring  (scipy_dist, return_period, id) float64 560B nan ....\n",
-       "    volume_sum_spring      (scipy_dist, return_period, id) float64 560B 751.2...\n",
-       "Attributes:\n",
-       "    cat:frequency:         yr\n",
-       "    cat:processing_level:  indicators\n",
-       "    cat:id:                
" - ], - "text/plain": [ - " Size: 2kB\n", - "Dimensions: (id: 5, scipy_dist: 7, return_period: 2)\n", - "Coordinates: (12/17)\n", - " * id (id) object 40B '020302' '020404' ... '020802'\n", - " * scipy_dist (scipy_dist) \n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset> Size: 30kB\n",
-       "Dimensions:                (id: 5, scipy_dist: 7, return_period: 50)\n",
-       "Coordinates: (12/17)\n",
-       "  * id                     (id) object 40B '020302' '020404' ... '020802'\n",
-       "  * scipy_dist             (scipy_dist) <U11 308B 'expon' ... 'weibull_min'\n",
-       "    drainage_area          (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n",
-       "    end_date               (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n",
-       "    latitude               (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n",
-       "    longitude              (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n",
-       "    ...                     ...\n",
-       "    start_date             (id) datetime64[ns] 40B 1989-08-12 ... 1970-01-01\n",
-       "    time_agg               <U4 16B 'mean'\n",
-       "    timestep               <U1 4B 'D'\n",
-       "    variable               <U10 40B 'streamflow'\n",
-       "  * return_period          (return_period) float64 400B 1.0 1.151 ... 1e+03\n",
-       "    p_quantile             (return_period) float64 400B 0.0 0.1315 ... 0.999\n",
-       "Data variables:\n",
-       "    streamflow_max_spring  (scipy_dist, return_period, id) float64 14kB nan ....\n",
-       "    volume_sum_spring      (scipy_dist, return_period, id) float64 14kB 130.9...\n",
-       "Attributes:\n",
-       "    cat:frequency:         yr\n",
-       "    cat:processing_level:  indicators\n",
-       "    cat:id:                
" - ], - "text/plain": [ - " Size: 30kB\n", - "Dimensions: (id: 5, scipy_dist: 7, return_period: 50)\n", - "Coordinates: (12/17)\n", - " * id (id) object 40B '020302' '020404' ... '020802'\n", - " * scipy_dist (scipy_dist) \n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset> Size: 5kB\n",
-       "Dimensions:                   (id: 5, time: 56)\n",
-       "Coordinates: (12/15)\n",
-       "    drainage_area             (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n",
-       "    end_date                  (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n",
-       "  * id                        (id) object 40B '020302' '020404' ... '020802'\n",
-       "    latitude                  (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n",
-       "    longitude                 (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n",
-       "    name                      (id) object 40B 'Saint' 'York' ... 'Madeleine'\n",
-       "    ...                        ...\n",
-       "    spatial_agg               <U9 36B 'watershed'\n",
-       "    start_date                (id) datetime64[ns] 40B 1989-08-12 ... 1970-01-01\n",
-       "    time_agg                  <U4 16B 'mean'\n",
-       "    timestep                  <U1 4B 'D'\n",
-       "    variable                  <U10 40B 'streamflow'\n",
-       "  * time                      (time) datetime64[ns] 448B 1970-01-01 ... 2025-...\n",
-       "Data variables:\n",
-       "    streamflow_max_spring_pp  (id, time) float64 2kB nan nan nan ... nan nan nan\n",
-       "    streamflow_max_spring     (id, time) float32 1kB nan nan nan ... nan nan nan
" - ], - "text/plain": [ - " Size: 5kB\n", - "Dimensions: (id: 5, time: 56)\n", - "Coordinates: (12/15)\n", - " drainage_area (id) float32 20B 1.09e+03 647.0 59.8 626.0 1.2e+03\n", - " end_date (id) datetime64[ns] 40B 2006-10-13 ... 1996-08-13\n", - " * id (id) object 40B '020302' '020404' ... '020802'\n", - " latitude (id) float32 20B 48.77 48.81 48.98 48.98 49.2\n", - " longitude (id) float32 20B -64.52 -64.92 -64.43 -64.7 -65.29\n", - " name (id) object 40B 'Saint' 'York' ... 'Madeleine'\n", - " ... ...\n", - " spatial_agg \n", - "
\n", - "\n", - "" - ], - "text/plain": [ - ":DynamicMap [id]\n", - " :Overlay\n", - " .NdOverlay.I :NdOverlay [scipy_dist]\n", - " :Curve [return_period] (streamflow_max_spring)\n", - " .Scatter.I :Scatter [streamflow_max_spring_pp] (streamflow_max_spring)" - ] - }, - "execution_count": 20, - "metadata": { - "application/vnd.holoviews_exec.v0+json": { - "id": "p3439" - } - }, - "output_type": "execute_result" - } - ], + "outputs": [], "source": [ "# And now combining the plots\n", "p1 * p2" @@ -6798,7 +476,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.11.8" + "version": "3.12.3" }, "vscode": { "interpreter": { diff --git a/docs/notebooks/optimal_interpolation.ipynb b/docs/notebooks/optimal_interpolation.ipynb index ac339bff..10dc3667 100644 --- a/docs/notebooks/optimal_interpolation.ipynb +++ b/docs/notebooks/optimal_interpolation.ipynb @@ -20,18 +20,9 @@ }, { "cell_type": "code", - "execution_count": 1, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stderr", - "output_type": "stream", - "text": [ - "/home/richard/miniconda3/envs/xhydro/lib/python3.11/site-packages/clisops/core/regrid.py:42: UserWarning: xarray version >= 2023.03.0 is not supported for regridding operations with cf-time indexed arrays. Please use xarray version < 2023.03.0. For more information, see: https://github.com/pydata/xarray/issues/7794.\n", - " warnings.warn(\n" - ] - } - ], + "outputs": [], "source": [ "import datetime as dt\n", "from functools import partial\n", @@ -75,7 +66,7 @@ }, { "cell_type": "code", - "execution_count": 2, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -112,7 +103,7 @@ }, { "cell_type": "code", - "execution_count": 3, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -139,7 +130,7 @@ }, { "cell_type": "code", - "execution_count": 4, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -176,7 +167,7 @@ }, { "cell_type": "code", - "execution_count": 5, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -199,26 +190,9 @@ }, { "cell_type": "code", - "execution_count": 6, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "lat_est: [45. 45.5 45.8 44.2 45.4]\n", - "lon_est: [-71. -70.4 -71.8 -70.2 -71.9]\n", - "lat_obs: [45. 45.5 45.8]\n", - "lon_obs: [-71. -70.4 -71.8]\n", - "bg_departures: [ 0.07696104 0.20479441 -0.01342302]\n", - "bg_est: [-1.49165488 -0.69314718 -1.4325072 -1.87080268 -2.07374352]\n", - "bg_var_obs: (array([1., 1., 1.]),)\n", - "bg_var_est: (array([1., 1., 1., 1., 1.]),)\n", - "var_obs: [0.15 0.15 0.15]\n", - "ecf: functools.partial(, form=4, par=[1.0, 0.5])\n" - ] - } - ], + "outputs": [], "source": [ "print(\"lat_est: \" + str(lat_est))\n", "print(\"lon_est: \" + str(lon_est))\n", @@ -234,7 +208,7 @@ }, { "cell_type": "code", - "execution_count": 7, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -266,19 +240,9 @@ }, { "cell_type": "code", - "execution_count": 8, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "Estimated values are: [113.44733348 161.14678052 142.02962921 154.00037475 87.99639936]\n", - "Simulated values were: [108. 135. 148. 154. 88.]\n", - "Observed values are: [100. 110. 150.]\n" - ] - } - ], + "outputs": [], "source": [ "# Transform back into absolute values and rescale by the drainage area\n", "estimated_flow = np.exp(v_est) * drainage_area\n", @@ -297,19 +261,9 @@ }, { "cell_type": "code", - "execution_count": 9, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "Estimated values for the 25th percentile are: [[111.26527089 158.04725979 139.29781056 144.97663776 82.84020497]]\n", - "Estimated values for the 50th percentile are: [113.44733348 161.14678052 142.02962921 154.00037475 87.99639936]\n", - "Estimated values for the 75th percentile are: [[115.67218928 164.30708704 144.81502252 163.58577347 93.473529 ]]\n" - ] - } - ], + "outputs": [], "source": [ "# Get the log-normal error model, whose variance depends on the interpolation variance and the variance of the departures.\n", "var_bg = np.var(departures) # Variance of the departures of the background field\n", @@ -366,7 +320,7 @@ }, { "cell_type": "code", - "execution_count": 10, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -405,7 +359,7 @@ }, { "cell_type": "code", - "execution_count": 11, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -429,449 +383,9 @@ }, { "cell_type": "code", - "execution_count": 12, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset>\n",
-       "Dimensions:        (time: 1097, station: 274)\n",
-       "Coordinates:\n",
-       "  * time           (time) datetime64[ns] 2016-01-01 2016-01-02 ... 2019-01-01\n",
-       "    lat            (station) float32 ...\n",
-       "    lon            (station) float32 ...\n",
-       "    station_id     (station) object ...\n",
-       "Dimensions without coordinates: station\n",
-       "Data variables:\n",
-       "    drainage_area  (station) float32 ...\n",
-       "    centroid_lat   (station) float32 ...\n",
-       "    centroid_lon   (station) float32 ...\n",
-       "    classement     (station) float32 ...\n",
-       "    streamflow     (station, time) float64 ...\n",
-       "Attributes: (12/13)\n",
-       "    title:                          Observations hydrométriques aux stations ...\n",
-       "    summary:                        Streamflow measurement at water gauge of ...\n",
-       "    institution:                    DEH (Direction de l'Expertise Hydrique)\n",
-       "    institute_id:                   DEH\n",
-       "    contact:                        simon.lachance-cloutier@environnement.gou...\n",
-       "    date_created:                   2020-10-13\n",
-       "    ...                             ...\n",
-       "    featureType:                    timeSeries\n",
-       "    cdm_data_type:                  station\n",
-       "    license:                        ODC-BY\n",
-       "    keywords:                       hydrology, Quebec, observed, streamflow, ...\n",
-       "    conventions:                    CF-1.6\n",
-       "    project_internal_codification:  CQ2
" - ], - "text/plain": [ - "\n", - "Dimensions: (time: 1097, station: 274)\n", - "Coordinates:\n", - " * time (time) datetime64[ns] 2016-01-01 2016-01-02 ... 2019-01-01\n", - " lat (station) float32 ...\n", - " lon (station) float32 ...\n", - " station_id (station) object ...\n", - "Dimensions without coordinates: station\n", - "Data variables:\n", - " drainage_area (station) float32 ...\n", - " centroid_lat (station) float32 ...\n", - " centroid_lon (station) float32 ...\n", - " classement (station) float32 ...\n", - " streamflow (station, time) float64 ...\n", - "Attributes: (12/13)\n", - " title: Observations hydrométriques aux stations ...\n", - " summary: Streamflow measurement at water gauge of ...\n", - " institution: DEH (Direction de l'Expertise Hydrique)\n", - " institute_id: DEH\n", - " contact: simon.lachance-cloutier@environnement.gou...\n", - " date_created: 2020-10-13\n", - " ... ...\n", - " featureType: timeSeries\n", - " cdm_data_type: station\n", - " license: ODC-BY\n", - " keywords: hydrology, Quebec, observed, streamflow, ...\n", - " conventions: CF-1.6\n", - " project_internal_codification: CQ2" - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], + "outputs": [], "source": [ "# First show the contents of the observed streamflow file:\n", "display(qobs)" @@ -896,415 +410,9 @@ }, { "cell_type": "code", - "execution_count": 13, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset>\n",
-       "Dimensions:        (time: 1097, station: 274)\n",
-       "Coordinates:\n",
-       "  * time           (time) datetime64[ns] 2016-01-01 2016-01-02 ... 2019-01-01\n",
-       "    lat            (station) float32 ...\n",
-       "    lon            (station) float32 ...\n",
-       "    station_id     (station) object ...\n",
-       "Dimensions without coordinates: station\n",
-       "Data variables:\n",
-       "    drainage_area  (station) float32 ...\n",
-       "    streamflow     (station, time) float32 ...
" - ], - "text/plain": [ - "\n", - "Dimensions: (time: 1097, station: 274)\n", - "Coordinates:\n", - " * time (time) datetime64[ns] 2016-01-01 2016-01-02 ... 2019-01-01\n", - " lat (station) float32 ...\n", - " lon (station) float32 ...\n", - " station_id (station) object ...\n", - "Dimensions without coordinates: station\n", - "Data variables:\n", - " drainage_area (station) float32 ...\n", - " streamflow (station, time) float32 ..." - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], + "outputs": [], "source": [ "# Next show the contents of the simulated streamflow file:\n", "display(qsim)" @@ -1329,395 +437,9 @@ }, { "cell_type": "code", - "execution_count": 14, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset>\n",
-       "Dimensions:     (station: 296)\n",
-       "Dimensions without coordinates: station\n",
-       "Data variables:\n",
-       "    reach_id    (station) object ...\n",
-       "    station_id  (station) object ...
" - ], - "text/plain": [ - "\n", - "Dimensions: (station: 296)\n", - "Dimensions without coordinates: station\n", - "Data variables:\n", - " reach_id (station) object ...\n", - " station_id (station) object ..." - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], + "outputs": [], "source": [ "# Show the correspondence table\n", "display(station_correspondence)" @@ -1739,18 +461,9 @@ }, { "cell_type": "code", - "execution_count": 15, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "There are a total of 96 selected observation stations.\n", - "['011508', '011509', '020602', '020802', '021601', '021915', '021916', '022003', '022301', '022601', '022704', '023303', '023401', '023402', '023702', '024003', '024007', '024010', '024014', '024015', '030101', '030103', '030215', '030234', '030282', '030335', '030345', '030424', '030425', '030905', '030907', '030919', '030921', '040129', '040204', '040841', '040830', '040840', '041902', '041903', '042103', '043012', '050144', '050135', '050304', '050408', '050409', '050702', '050801', '050812', '050915', '050916', '051001', '051005', '051006', '051301', '051502', '052228', '052231', '052601', '052606', '052805', '060101', '060102', '060202', '060601', '060704', '060901', '061020', '061022', '061024', '061028', '061307', '061502', '061801', '061901', '061905', '061909', '062102', '062114', '062701', '062803', '070401', '072301', '073502', '073503', '073801', '074701', '074902', '075702', '075705', '076201', '076601', '080101', '080106', '080707']\n" - ] - } - ], + "outputs": [], "source": [ "print(\n", " \"There are a total of \"\n", @@ -1773,7 +486,7 @@ }, { "cell_type": "code", - "execution_count": 16, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -1800,7 +513,7 @@ }, { "cell_type": "code", - "execution_count": 17, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -1833,569 +546,9 @@ }, { "cell_type": "code", - "execution_count": 18, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "text/html": [ - "
\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.Dataset>\n",
-       "Dimensions:        (percentile: 3, station_id: 96, time: 62, station: 96,\n",
-       "                    nbnds: 2)\n",
-       "Coordinates:\n",
-       "  * percentile     (percentile) float64 25.0 50.0 75.0\n",
-       "  * station        (station) <U6 '011508' '011509' ... '080106' '080707'\n",
-       "Dimensions without coordinates: station_id, time, nbnds\n",
-       "Data variables:\n",
-       "    streamflow     (percentile, station_id, time) float64 2.124 2.058 ... 334.6\n",
-       "    lat            (station_id) float64 48.55 48.4 49.04 ... 48.21 47.99 48.73\n",
-       "    lon            (station_id) float64 -67.59 -67.35 -64.91 ... -77.73 -76.79\n",
-       "    drainage_area  (station_id) float64 555.0 2.753e+03 ... 365.0 2.228e+04\n",
-       "    time_bnds      (time, nbnds) datetime64[ns] 2018-10-31T23:59:59.999999999...
" - ], - "text/plain": [ - "\n", - "Dimensions: (percentile: 3, station_id: 96, time: 62, station: 96,\n", - " nbnds: 2)\n", - "Coordinates:\n", - " * percentile (percentile) float64 25.0 50.0 75.0\n", - " * station (station) \n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "
<xarray.DataArray 'streamflow' (station_id: 96, time: 62)>\n",
-       "array([[   3.06106887,    3.08482633,    3.40291866, ...,    7.21277941,\n",
-       "           7.17458224,    7.11689552],\n",
-       "       [  29.01027516,   28.1848719 ,   37.62187009, ...,   35.08815169,\n",
-       "          33.54158007,   32.22040804],\n",
-       "       [   9.59003258,    9.01568854,   12.50503336, ...,    6.63569636,\n",
-       "           6.23049285,    6.00326429],\n",
-       "       ...,\n",
-       "       [ 169.18115137,  203.11281048,  184.98202483, ...,   51.93455718,\n",
-       "          48.56459553,   60.16687057],\n",
-       "       [  10.93729979,   13.37748088,   11.88123852, ...,    3.16825856,\n",
-       "           2.96104113,    3.68364776],\n",
-       "       [1043.8106597 , 1291.35950895, 1219.39897879, ...,  247.07789419,\n",
-       "         227.94282961,  286.18602839]])\n",
-       "Coordinates:\n",
-       "    percentile  float64 50.0\n",
-       "Dimensions without coordinates: station_id, time\n",
-       "Attributes:\n",
-       "    long_name:              Streamflow\n",
-       "    standard_name:          outgoing_water_volume_transport_along_river_channel\n",
-       "    units:                  m3 s-1\n",
-       "    cell_methods:           time: mean\n",
-       "    coverage_content_type:  modelResult
" - ], - "text/plain": [ - "\n", - "array([[ 3.06106887, 3.08482633, 3.40291866, ..., 7.21277941,\n", - " 7.17458224, 7.11689552],\n", - " [ 29.01027516, 28.1848719 , 37.62187009, ..., 35.08815169,\n", - " 33.54158007, 32.22040804],\n", - " [ 9.59003258, 9.01568854, 12.50503336, ..., 6.63569636,\n", - " 6.23049285, 6.00326429],\n", - " ...,\n", - " [ 169.18115137, 203.11281048, 184.98202483, ..., 51.93455718,\n", - " 48.56459553, 60.16687057],\n", - " [ 10.93729979, 13.37748088, 11.88123852, ..., 3.16825856,\n", - " 2.96104113, 3.68364776],\n", - " [1043.8106597 , 1291.35950895, 1219.39897879, ..., 247.07789419,\n", - " 227.94282961, 286.18602839]])\n", - "Coordinates:\n", - " percentile float64 50.0\n", - "Dimensions without coordinates: station_id, time\n", - "Attributes:\n", - " long_name: Streamflow\n", - " standard_name: outgoing_water_volume_transport_along_river_channel\n", - " units: m3 s-1\n", - " cell_methods: time: mean\n", - " coverage_content_type: modelResult" - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], + "outputs": [], "source": [ "display(ds[\"streamflow\"].sel(percentile=50.0))" ] @@ -2873,7 +594,7 @@ }, { "cell_type": "code", - "execution_count": 20, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -2898,7 +619,7 @@ }, { "cell_type": "code", - "execution_count": 21, + "execution_count": null, "metadata": {}, "outputs": [], "source": [ @@ -2925,20 +646,9 @@ }, { "cell_type": "code", - "execution_count": 22, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "data": { - "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAGwCAYAAACHJU4LAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACndElEQVR4nOzdd3iT5dfA8W/SdO9dOmhZLXvvLXvIlCVDUERFEFFcOH4iDlzgBlkiyhQFREWQvffetFCgFEr33kneP562wEuBtrR90vZ8vHK1SZ4kpyDNyf2c+xyN0Wg0IoQQQghhgrRqByCEEEIIcT+SqAghhBDCZEmiIoQQQgiTJYmKEEIIIUyWJCpCCCGEMFmSqAghhBDCZEmiIoQQQgiTpVM7gEdhMBi4ceMG9vb2aDQatcMRQgghRAEYjUaSkpLw9vZGq33wmkmZTlRu3LiBn5+f2mEIIYQQogjCwsLw9fV94DFlOlGxt7cHlB/UwcFB5WiEEEIIURCJiYn4+fnlvY8/SJlOVHJP9zg4OEiiIoQQQpQxBSnbkGJaIYQQQpgsSVSEEEIIYbIkURFCCCGEyZJERQghhBAmSxIVIYQQQpgsSVSEEEIIYbIkURFCCCGEyZJERQghhBAmSxIVIYQQQpgsSVSEEEIIYbIkURFCCCGEyZJERQghhBAmSxIVIYQQoqwyGiEjGRJvgj5L7WhKRJmeniyEEEKUe6mxcHEjRJ6F1BhIicq5RCuX7DTlOI0W7CuBox84+ioXJz/luld9cKik7s9RRJKoCCGEEKYm8Sac/xvO/QVXdoNR/5AHaMBogMRw5RKWzyEedaB6J6jWGSq3AnOrkoi82EmiIoQQQpiC2MtKYnLuL7h+6O77POtCQFuw8wRbN7B1z7nkfK+zhpRISLgOCWEQH3b7+7grEHkOIs8ol73fKccHtIXqnaFGN3CtpsqPXBAao9FoVDuIokpMTMTR0ZGEhAQcHBzUDkcIIYQovJRo2PQ+HF9y9+1+LaDm41DrcXCp+oivEQOXt8GlrRCyBZIj7r4/oB00exZq9gYz80d7rQIozPu3JCpCCCGEGgwGOLoYNk+D9HjltqodoVYfCOpdcjUlRqNS7xKyBUI2w5VdymkjUGpcmjwNTUaDvVfJvD6SqAghhBCm7cZx+GcKhB9WrnvWg8dngV/z0o8l4TocXqQkTSlRym1aHdTqq6yy+LcGjaZYX1ISFSGEEMIUpSfA1o/h0HxlFcPCHjq9A83GgdmDy0azDdnEpccRnRZNTHoM0WnRyvdpMSRnJeNq5YqXrRdetl542njiZeuFk6UTmoImGdmZcG4dHJwPYftv316tM4xa/Qg/9L0K8/4txbRCCCFEabjwL6ybpBS9AtR9Arp9fN9TPEajkbMxZ9lybQtbrm0hNCEUI4VbW7A0s8TTxpMglyBaebeiZaWW+Nn75X+wzgLqDVIuN0/CoQVwahX4NivUaxY3WVERQgghStrxZfDnBGUVxbUG9P5SqUf5f/QGPUcjj+YlJxEpdxe9ajVanC2dcbN2w9XaNe+rnbkd0WnR3Eq5RURqBLdSbhGTHpNvKL52vrT0bkmrSq1o7tUcJyun+8edFq98tX7AMUUgp36EEEIIU3FwPqx/Tfm+0UjoPQt0lncdcj3pOgtOLWDrta3EZcTl3W6ts6atT1s6V+5Mc6/muFi5YKY1K9DLZuozuZV6i5vJNzkSeYT9N/ZzMuok2cbsvGM0aKjnVo8BNQbQq0ovbMxtHv3nLQBJVIQQQghTsPsrZVcPQIvx0GPGXYWpGfoMfjr9EwtPLSRDnwGAo6UjHX070sW/Cy0rtcRKV3yN2VKyUjhy6wj7buxj/839hMSH5N1na27L41UfZ3DgYIJcgortNfMjiYoQQgihJqMRtn4Eu75Urrd/HR57564kZdf1Xcw4OIOwJKWNbHOv5oyrP46mnk3RaUunhDQyNZJ/Q/9l1cVVXE28mnd7fff6DA4cTPeA7ljrrIv9dSVREUIIIdRiMMDGqXDgR+V6l2nQ9pW8u28k3+Czg5+xNWwrAO7W7rze7HV6BPQo+A6dYmY0GjkYcZBVF1ex5eqWvNND9hb2DA0aysuNXy7W15NdP0IIIYQaDHr4axIcy+ky2+tLaD4OUGpGFp9ZzLyT80jXp2OmMWNkrZGMbzgeW3NbFYMGjUZDi0otaFGpBdFp0awNWcvvF38nPDmc2PRYdWOTFRUhhBCiGBj0sHocnP5DmWTc7wdoOByAhIwEXtz8IiejTwLQ1LMpb7d4mxrONdSM+IEMRgP7buyjkm0lqjo9Ygv//0dWVIQQQojStu8HJUnRmsMTC6BOfwCiUqN4btNzhMSH4GjpyFvN36J3ld6qneYpKK1GSxufNmqHgVbNFw8ICECj0dxzmTBhgpphCSGEEIVz6yxs/VD5vtcXeUlKeHI4ozeMJiQ+BHdrd37u/jOPV33c5JMUU6LqisqhQ4fQ6/V510+fPk3Xrl0ZPHiwilEJIYQQhZCdCWueA30m1OgOTcYAcDnhMuP+G0dkaiQ+dj7M7zb//l1hxX2pmqi4u7vfdf3TTz+lWrVqdOjQId/jMzIyyMjIyLuemJhYovEJIYQQD7XjM4g4BdYu0Pc70Gg4G3OWFza9QFxGHNUcqzG361w8bT3VjrRMUvXUz50yMzNZsmQJzzzzzH2XxGbMmIGjo2Pexc9PMlMhhBAqCjsEu2cp3z/+Fdh7cvTWUcZuHEtcRhx1XOuwqMciSVIegckkKmvXriU+Pp4xY8bc95ipU6eSkJCQdwkLCyu9AIUQQog7ZabAmueV+T31hkCd/uwJ38Pzm54nOSuZJp5NWNBtAc5WzmpHWqaZzK6fhQsX0rNnT7y9ve97jKWlJZaWlve9XwghhCg1m96H2Etg7w29PudMzBle2voSWYYs2vm0Y1bHWcXa/r6iMolE5erVq2zevJnVq1erHYoQQgjxcCFb4NB85fv+P5Bubs3UXVPJMmTRwbcDX3X8CnMzc3VjLCdMIlFZtGgRHh4e9O7dW+1QREWVla4Uw0VfgIxkyExWlnXv+poK1s7g7A9O/re/OviAmUn8UxJClIa0OPhzovJ9s3FQrRNfH/yU0IRQ3K3d+ajNR5KkFCPVf7saDAYWLVrE6NGj0elUD0dUBPpsiDoPN45C+FHl660zYMh++GPzo9UpyYp7EFRuBQFtwbsRyC8qIcqn9W9A0g1wqQZdP2Dvjb0sPbcUgOltpuNk5aRufOWM6pnB5s2buXbtGs8884zaoYjyzKCH4P/g0EK4ugeyUu89xsYNvOopqyYWtmBhl/PVFiztQWcFqdEQdxXirypfE8KU3gnxObcF/6c8l7kN+DVXkhb/tuDTGHRSXyVEmXfuLzj1m9Iif8BcEozZvLf7PQCGBQ2jrU9blQMsf1RPVLp160YZHjckTF1anDIc7OB8JZHIZWEP3g2VBMK7sfLV0e+uEewFYjBA0k3luW+ehCu74OpeSIuFy9uVC4DOGmr2UuZ+VH0MtGbF9AMKIUqN0QjbZijft3kZo29TPtr5BpFpkQQ4BPBq01fVja+cUj1REaJE3DoLB+fCyd9ur55YOUHjp6DBk+BeE7TFsDtfqwVHH+Xi3xpavqAkL1Hn4cpuuLobruxRVmJO/6FcHHygwTBoOAJcqz16DEKI0nF5G0SeUVZM27zM+tD1bLiyAZ1Gx4x2M7DWWasdYbkkiYooX8KPwqb/KSsbuTzrQvPnoN5gsLAp+Ri0WvCsrVxaPKd8Crt5HI4vUxKnxHDYNVO5+LWERiOgzgDl9JIQwnTt/V752mgkEYYMPt7/MQDPN3ieum51VQysfNMYy/B5l8KMiRblXGYqbJ8B+75Xmi9pzKBmb2jxPPi3KdApncTMRK4nXSdTn0mmPpMsQ9btr4ZMsg3ZuFq54u/gj7edNzptEfL87Ay4sB6OLYVLW5RYASwdoOnT0GI8OFQq/PMKIUrWrbMwpxWgwfDSYZ47/CkHIg5Q360+i3suLtrvgwqsMO/f8icryr7QXfDXJIi9rFyvOwi6TAOn/Ecs6A16wpLCuBB3gYtxF7kYe5ELcRe4mXKzwC+p0+jwtfelskNlKttXxt/Bn+pO1anvXh8LM4sHPNBSWT2pMwASb8DJlUoNTUwI7PkG9s2G+kOg9UvgUasQfwhCiBK1/wfla63HWXprHwciDmCts+aTdp9IklLCZEVFlF3pCUpnyCOLlOv23vD4LAjqefdh2emciDrBwYiDHI44zLnYc6Rlp+X7lG7WbljrrDHXmmNhZoG51ly5mJmj0+iITIskLDGMdH16vo+3NLOkkUcjWlRqQQuvFtRyrfXwX2IGAwRvVBKVa/tu316jO7R5Wal9kZHwQqgn6RZ8XRf0mYQMXcTQwx+TacjkvZbvMSRoiNrRlUmyoiLKvwv/wt+vKr0MAJo8DV0/ACtHMvWZnIw6yaGIQxyMOMjJqJNkGjLveriVmRXVnaoT6BJIoHMgQc5B1HCugaOl40Nf2mA0EJkaydXEq3ddTkefJiY9hv0397P/5n4A7M3taeLVhJaVWtKlcpf8B5NptUpyFdQTwg4qCcv5f5TkJXgj+DSFzv+DqvlPFRdClLBD85U2BL7N+ObGNjINmbT3bc/gwMFqR1YhyIqKKFv0WfD3K3DsV+W6cxVlrHqVdqRmpbLg1AKWnFtyz4qJh7UHzSo1o7lXcxp6NMTf3h+zYt4ibDQauZxwmf0393Pw5kEO3TpEUmZS3v1ajZY23m0YWGMgHXw7PLhzZXSIUm9zfBnoM5TbAntA1+lKYzkhROnITIWv6kBaLJcf/5J+Z75Fg4Z1/dcR4BigdnRlVmHevyVREWVHRjL89pRShKrRQqsJ0PFtDOZW/H35b7458g2RaZEAuFi50NyrOc28lOTE38EfTSmfPtEb9JyPPc+BiAPsCNvB0cijefe5WLnweNXHGVB9ANWdq9//SZIjYecXSqM6o14pEm4yGjpOBTuPUvgphKjgDi2Af6aAkz/TmvXnj5A1dPLrxDedvlE7sjJNEhVR/iRHwbLBcOOY0sNg8GII7MbxyON8fuhzTkWfAsDXzpcpTafQuXLnUk9MHuZKwhXWhqxl3aV1RKVF5d1ez60egwMH07tq7/sX4kYHK/U4F/5RrlvYQ9vJ0PLF0tlyLURFZDDA900h9hLRXf5Ht9ClZBmy+LXnrzT0aKh2dGWaJCqifIkNhSUDlV091i4wYhURzr58deQr1oeuB8BGZ8Nz9Z9jVO1RD951YwKyDdnsCd/D6uDV7Ly+k2yjMmPIzdqNEbVGMCRoCA4W9/n/+cpu+O9dJWEDpXlclw+g3iApuBWiuJ3/B1YMBytHvuv8MvPO/kwD9wYs6bVE7cjKPElURPlx4zgsHQQpUeBUGeOI1Sy+tYfZJ2aTlp2GBg39q/dnUuNJuFm7qR1toUWnRbPu0jqWnVvGrdRbgJJ0DQocxKjao/Cy9br3QQaD0uF2ywfKrCFQ5gn1/lK2NAtRnH7qCdf2ktpqIt3idpCQkcBXHb+ii38XtSMr8yRREeXDpa2wchRkJoNXPVKG/MJ7J79n09VNADT2aMwbzd+gjmsdlQN9dFn6LP698i+LTi8iJD4EUHq19KjSgzF1xhDkkk8BbVY67PsOds6E7DRlinPL8dDhTelyK8SjCj8C8zuBVseyPh8x4+RsKttXZl3/dcVeiF8RSaIiyr6Tv8Ha8WDIhirtudrrU17e8w6XEi6h0+qY2nwqgwMHm1wdyqMyGo3sDt/Nz2d+5mDEwbzbewT0YFLjSfjZ59PELu4qbHwbzv+tXLevBN0/hjoD5XSQEEW16mk4sxp9vaH05hrhyeG82+JdhtYcqnZk5YIkKqJsO7MGVo1Rvq/7BDuaDmfq3v+RlJWEh7UHMzvOrBCFbGeiz7DozCL+u/IfRozotDqGBQ3j+frP42TldO8DLm6Ef9+AuCvK9SodoNeX4B5YvIFFB8PFDZCZAllpOZdUyE5Xvtdngk8TZbaSDF0UZVH8NfimIRj1/Nd/JlNOfIOTpRP/DfpPBg8WE0lURNkVdgh+7g36DAxNnmauXyCzT8wBoJFHI2Z1nFUma1EexfnY88w6PIt9N5Wutfbm9oyrP47htYZjaWZ598FZ6UrDuN2zlMTBzELZytx6Epg9Yn9Hgx72fgvbPlGSkYLwbqQkLHUGygwjUXZseBv2/4CxSntGuNlzKvoULzR4gQkNJ6gdWbkhiYoom+KuwPzOkBpNUmB33vb0ZPv17QAMDRrKm83efHCTtHJub/heZh6ZycW4iwBUsq3ES41eonfV3mg12rsPjg1VVleC/1Ou+zSB/nOK3iwuOlg5FXf9kHLdv62yUqOzBnNrMLdSto2bWysJzcWNSo2RUZ/zBBqo0k5JWmr1BWunosUhRElLi4Ov6kFmEkf6fM6Y099jaWbJxic24mrtqnZ05YYkKqLsSYuHhd0g+gK3vOryrIcTV5KuYaG14N2W7zKgxgC1IzQJeoOevy//zXfHvsvbJVTbtTZTm0+993SY0QgnVsC/b0JGAphZQuf3lN4rBS0GNBjgwBzYMl1ZobF0gB4zoOGIh9e/pEQrp/FO/Q5h+2/fbm4LzZ+FVi+BnXvBf3ghSsOOL2DbR+BRm5eCmrL9+nYGBw7mf63+p3Zk5YokKqJs0WfBkicgdAexDt6M8a9CaHIYnjaefP3Y19R1q6t2hCYnPTudJeeWsPDUQpKzkgHoW60vkxtPxt3m/735J4Qr06VDNivX/VpC/9kPrx+JvQxrJ8C1vcr1ap2UcQWOvoUPOO6qsqX65G8QdU65TWcNTZ+BNpPAPp9t2EKUtsxUZfhgagyhvT6l77nZaNDwZ/8/qeJYRe3oyhVJVETZYTQqb6JHfyHJwo6xNRtzLukKnjae/NLzF7ztvNWO0KRFp0XzzdFvWBuyFgBbc1uer/88I2uNvPs0mdGozEfa8DZkJilJQqd3oVJ9yM7IKYRNV75mp0NSBOyfrRTJmttC94+UwY+PuovIaITgTbDjU2X7JygrPU3GKJOiHX0e7fmFeBT7f4QNb4JzANOa9uePkNU85vcY33b6Vu3Iyh1JVETZsftr2Pw+aVozXqjblqNJobhYufBzj5/lE0whnIo6xYyDM/JGCQQ4BPBm8zdp69P27gPjr8GfEyF0R8GeOKAd9PsenAOKN2CjUalh2fEZhB1QbjOzgEajoP3rUngrSl92JnzbEBLDie7+Id1DFpNpyGRxj8U09mysdnTljiQqomw4+yf89hRZwEt127In5Rr25vYs7L6QWq7SYbWwDEYD6y6t46sjXxGbHgtAR7+OvNfyPTxs7hhgaDTC4YVw6Cel2FVnlXOxVL6a51wPaAsNR4L27kLdY5HH2HJ1C6nZqaRnp5OuT7/ra5YhizqudegW0I3mXs3RaR+w28hohNCdsONzuLpbuc3cRlldaf0SWNgW9x+TEPk7tgT+nAB2nnz/2IvMPb2Q+m71WdJrSbnr12QKJFERpi/8CCzqhT47nTdqNue/jAiszKyY120ejTwaqR1dmZaUmcSPJ35k2bllZBuzcbBw4O0Wb9OrSq9H+oWbnJnMV0e+4reLvxX4Mc6WznT270w3/24082r24KTlym6laDd3hcW+knJ6qsGTBS/+FaIoDHr4oQXEBJPa+T26ha8lISOBWR1n0dW/q9rRlUuSqAjTlpEMP7bBGHeFaVXrsdqYgE6r4/tO39PGp43a0ZUbIXEhvLPnHc7GnAWgq39X3m35Li5WLoV+rp3XdzJ93/S8nUa9qvQiwDEAazNrLHWWWJlZYa2zxtLMEiNG9oTvYfO1zXkrO6AkLV38u9C7am8aezTOP2kyGuHsWmVSdPxV5TavetDtY6jaodBxC1EgOau7WDmyuOc7fHn8e/wd/Pmz35/SLr+ESKIiTNvfr2I8vJAvvPz41VqDVqPlyw5fyieXEpBlyGLBqQXMOzGPbGM2LlYuvN/qfTpV7lSgx8emx/LZwc/yplT72fvxQesPaObV7KGPzTZkc/jWYTZe2cjmq5uJz4jPu6++W33G1htLR7+O9/aAAaXA98Bc2PmlsrUaILAHdPsI3GoUKHYhCsRohHkd4OYJMtq9So+Y7USnRTO99XRpi1CCJFERpitkCywZyGIHe750dQaQXwil4EzMGd7d/W7ewMO+1fryZvM3cbDI/9+N0Wjk39B/+fTgp8RlxKHVaBldezTjG44vUgvxbEM2ByMOsiF0A+tD15OhzwCgmmM1nqn3DD2r9MRcm08zv5QYpeD28EJl7pPWHNq+Au2mKLU0QjyqnN9JmNuwss/HfHTsK7xsvVg/YH2FbjBZ0iRREaYpLQ5mt+ZsRhQjfLzJxshrTV9jdJ3RakdWIWToM/jh+A/8fPpnjBhxt3anqlNVyPkNYMz5D5R6lHOxSr+TGs41+LD1h9RxK54p1dFp0Sw5u4SVF1bm9YDxtvVmdJ3RDKwxECtdPglIdLAyeDG3065LNXh8FlTtWCwxiQrs58fhyi6ymj/P46knuJFyg6nNpzK81nC1IyvXJFERpmn186SdWskQPz+umCk1EzM7zJSK+lJ2LPIY7+x+h7CksAcep9PqeL7+84ytO7ZEPlkmZSax8sJKfj37a14ti4uVC+PqjWNo0NB7X9NohHPrYP0bkByh3FZ/qFK/Ih1uRVGEHYSFXUFrzroBX/LO0Zm4WLmw8YmN+SfMothIoiJMz7m/YOVIPnJ1YaWDHe7W7qzuuzr/KcCixKVmpbLvxj7S9eloUBJFjUaT9z0aqOtaF1/7InShLaT07HTWhKzh59M/cyPlBgC+dr5MajyJ7gHd761hSU+ArR/BwfmAEaycoOt0pQeLNp96FyHuZ9kwuPgvhoYj6M91QhNCmdx4MmPrjVU7snJPEhVhWpKjYHZLdhqTmeCl9POY23Uurb1bqxyYMCVZhizWhqxl9vHZRKdFA1DHtQ6vNnmV5pWa3/uA60fg75chQmlyR+VW0OdbZViiEA9z6wzMaQ1o+O+Jb5hy9EvsLez574n/sLOwUzu6cq8w79/y8UOULKMR/p5MTHos73l6AjCy1khJUsQ9zLXmDA4czD8D/mFCwwnY6Gw4E3OGsf+NZfzm8XlTo/P4NoFx25VTP+a2cG0f/NhG2Smkz1LlZxBlyO6vADDW6sOCK/8AMKLWCElSTJAkKqJknVyJ8fzfTHN3I1ZjpLpTdSY3max2VMKE2Zjb8EKDF1g/cD1P1nwSnUbH7vDdDFo3iPf3vk9cetztg8100HoiTDgA1buAPhO2fgjzH4Mbx1X7GYSJi7uiDMkEdtXszLnYc1jrrBlRc4S6cYl8SaIiSk5COKx/g9/tbdluY4W51pxP232KpZml2pGJMsDV2pW3W7zNn/3/pJt/N4wYWR28mj5r+/D7xd8xGA23D3bygxG/w4B5YO2snA6a3wk2T4OsNNV+BmGiQneB0YDRrwXzw7cAMDRoqNTMmShJVETJMBph3Utc0afwhasrAC83fpkglyCVAxNlTWWHyszsOJNfe/5KkHMQCRkJfLDvA0atH8W5mHO3D9RooMFQmHAI6gxU5hjt/gp+bAtX96r3AwjTkxIJwGEHV45HHcdCa8FTtZ9SOShxP5KoiJJx/m+yLm3hLU930jTQolILRtUepXZUogxr6NGQFY+v4I1mb2BrbsvJ6JMM+2cYnx78lKTMpNsH2rnD4EUwbJkyLygmBBb1hPWvQ2aKej+AMB0pSrH2fL2SsAyoMQB3G9nibqokURHFLzsT/nuPH50cOWNhjoOFAx+1+Sj/VulCFIJOq2NU7VGs67+OngE9MRgNLD23lL5r+7L+8nru2sRYsze8uB8a5zQUPDhPWV25tl+d4IXpSInitIUF+zIiMdOY8XTdp9WOSDyAvHOI4ndoPiHJ11nopGw5+1+r/+Fl66VyUKI88bDx4PMOnzOv6zwCHAKITovmzV1v8sLmF+5uZGftBH2/hVFrwMEXYi/DTz1g4ztSu1KRJUcyL+f3U++qvfGx81E5IPEgkqiI4pUai3HHZ3zh4oReo6GTXye6B3RXOypRTrXybsUfff9gYsOJWGgt2HtjLwP/HMii04vINmTfPrBaJ3hxLzQcCRhh3/cwtz1cP6xa7EI9l1Jvsc3WBg0anq33rNrhiIeQREUUr+2fskuTwV4ba3RaHa81fU3tiEQ5Z2FmwfMNnmd1v9U092pOuj6dWUdm8eQ/T3Im+sztA60cof8P8ORKsPOE6ItK+/TNHyjTmkWFcSxbmcjd3KU2VRyrqByNeBhJVETxibpI1qEFfOmiTEUeWWskfg5+KgclKgp/B38WdFvA9NbTcbBw4HzseYavH85nBz8jNSv19oFBPZTalXqDwWiA3bNg3mNKp1JR/hn0xOiV/x987OX3U1kgiYooPpv+xyo7a0ItzHGxcuG5+s+pHZGoYDQaDQNqDGBd/3X0qtILg9HAknNL6P9nf3Zd33X7QBsXeGIBDPkVbNwg8oySrOybDQbD/V9AlH1pccTkzIRytfdWORhREKonKuHh4YwcORJXV1dsbGxo2LAhR44cUTssUViXt5MQsoHZzk4ATGg4AXsLe3VjEhWWq7Urn7X/jDld5uBj58PNlJu8uOVF3t39LgkZCbcPrN0XXtwHNbqDPgM2ToUlAyHxpnrBi5KVEkWsmfLW52ItW5LLAlUTlbi4ONq0aYO5uTn//vsvZ8+eZebMmTg5OakZligsgx42vsuPTo4kmGmp7lSdgTUGqh2VELT1acvqvqsZWWskGjT8eelPBvw5gO1h228fZOcBw1dC75mgs4bL25Rhdef+UitsUZKSI4kxMwOUhFaYPlUTlc8++ww/Pz8WLVpE8+bNCQgIoHPnzlSrVk3NsERhHV9KaOw5VjgoKyivN3sdnVanclBCKGzMbXiz+Zss7rmYAIcAotKieGnrS7y96+3bqysaDTR7Fp7fAV71IS0WVo6EPydCRrK6P4AoXilRtxMVK0lUygJVE5V169bRtGlTBg8ejIeHB40aNWL+/Pn3PT4jI4PExMS7LkJlGUmw9SNmOTuRrdHQ3re9TEYWJqmRRyNW9VnFmDpj0Gq0/HX5L/r/2Z8t17bcPsg9CJ7dAm1eBjRw7FeY2062MZcnKdHE5J76sXJRORhREKomKpcvX2bOnDnUqFGDjRs38sILLzBp0iR++eWXfI+fMWMGjo6OeRc/P6nYVt2eb9iXHc92Wxt0GjOmNJ2idkRC3JeVzoopTafwa89fqepYlei0aCZvm8wbO9+4vbqis4Cu02H0OnDwUZrELewG22aAPvvBLyBMXlZyBIly6qdM0Rjv6jlduiwsLGjatCl7994eGDZp0iQOHTrEvn377jk+IyODjIzb/Q4SExPx8/MjISEBBweHUolZ3CHhOtnfNWGwpxMhFhaMqDWCt5q/pXZUQhRIhj6DOcfnsOjMIgxGAx7WHnzY9sO7VwTT4uCfKXD6D+W6T1MYOA9c5fR0WXVr7XN0SdiHGRqOPnVcRnuoJDExEUdHxwK9f6v6N1SpUiVq16591221atXi2rVr+R5vaWmJg4PDXRehoj3fsNpaR4iFBQ4WDoxvMF7tiIQoMEszSyY3mcySnksIcAggMi2S5zc9zycHPiEtO6e9vrUzDPoJBi4AS0cIP6zMCzq8SJkQLsqcmJzJyS46G0lSyghV/5batGnDhQsX7rrt4sWL+Pv7qxSRKLDUWJKOL+UHZ0cAXmz4Io6WjioHJUTh1XOvx299fuPJmk8CsPz8cob8NYTT0advH1R/MIzfAwHtICsV/p4My5+E5Ch1ghZFFpumTE52sZAPumWFqonKK6+8wv79+/nkk08ICQlh2bJlzJs3jwkTJqgZliiIwwtZamNGrJkZAQ4BDAkaonZEQhSZtc6at1u8zdwuc/Gw9uBK4hVGrh/JnONzyDJkKQc5+cFT66DbR2BmARf/hTmt4OJGdYMXhRKTqdQiuVpKIW1ZoWqi0qxZM9asWcPy5cupW7cuH374IV9//TUjRoxQMyzxMFnpZByYx/Kc7cjjG4zHXGuuclBCPLrWPq1Z3W81PQJ6oDfqmX1iNk+tf4rQhFDlAK0WWr8E47aBR21IiYJlQ2DDVMjOVDd4USAxWSkAuNpIs7eyQvUTdI8//jinTp0iPT2dc+fOMW7cOLVDEg9z6jf+1qQQa2aGl40XXQO6qh2REMXG0dKRLzp8wWftPsPewp7TMacZ8tcQlp5bisGY017fq66SrLTIqcvaP1sZcBhzSb3AxcNlphCj0QPgYldJ5WBEQameqIgyxmDAsPc7fnFUzu+OrD1SVlNEudSrai9W911Nq0qtSNen8+nBT3lu03NEpEQoB5hbQc9PYdhypej25nGY2wFO/a5q3OIBUqKIzd2abOulcjCioCRREYUTsondKde4bGGOrc5GWuWLcs3L1osfu/7I2y3exsrMigM3DzDgzwGsu7SOvM4ONXvBC3ugcmvITII/xsKfEyAzRd3gxb3uaPbmauOmcjCioCRREYVzx2rKE4GDZPCgKPe0Gi1P1nySVX1WUd+9PslZybyz+x1e2f4KsemxykGOPjD6L+jwJkpH2yXKNOZbZ1SNXfw/yZHEaKV9flkjiYoouPCjnL+xnwPWVphptIysNVLtiIQoNQGOASzusZhJjSah0+rYcm0LA/4cwLZr25QDzHTw2NtKR1s7L4i+APM7wcH50nPFVNxx6kfa55cdkqiIgtv3PYtzVlO6+XenkhSjiQpGp9Uxrv44lvdeTnWn6sSmxzJp2yQ+2v8R6dnpykFV2is9V2p0g+x0WP+a0nMlJVrd4AWG5Ejick/9SPv8MkMSFVEwcVeJOL+ODbY2AIyuM1rlgIRQT02Xmqx8fCVP1X4KgJUXVvLkP08SHBesHGDrBsN/gx6f3dFzpTVc2qpi1CI++QZ6jQYAZytnlaMRBSWJiiiYAz+yzN6WbI2GJp5NqONWR+2IhFCVhZkFrzd7nR+7/IirlSsh8SEM+3sYy88vVwptNRpo+YKyjdm9JiTfgl8HwMZ3IDvj4S8gil1Myk0AHLWWsluxDJFERTxcWhwpRxfzu70dAKNry2qKELna+LThj75/0NanLZmGTD458AmTtk0iLj1OOSC350rTscr1fd/Dgi4QdVG9oCuo3Pb5rrIJoEyRREU83JGfWWOlJclMS4CDPx38OqgdkRAmxdXaldmdZ/Nmszcx15qzPWw7g9YN4sDNA8oBFjbw+KycnisuEHES5raHI4ul0LYUxaTHA+Bq6aRqHKJwJFERD5adSfb+H1mS0y5/VO2nZOKoEPnQaDSMrD2SZb2XUcWxCpFpkYz7bxyzDs8iU5/TXr9mLxi/F6p2hOw0+GsSrB4HGUmqxl5RxGQpf86u1tI+vyyRdxzxYKdWscWQQLi5DidLR/pU66N2REKYtJouNVnRewWDAgdhxMiiM4sY/s9wQuJClAMcKsHINdBlGmjM4NQqZXXl5glV4y73DHpi9crOLBdbT5WDEYUhiYq4P6MR4/7ZeQ3ehgYNw1pnrXJQQpg+G3Mb3m/1Pt889g3Ols5ciLvA0L+H3p4XpNVC21fg6X/BwRdiLyt1K9JzpeSkxt7uSmvno3IwojAkURH3d/0wx+MvctLKEgutBcNqDlM7IiHKlE6VO7G63+q8QttPD37K+M3jiUyNVA6o3AJe2AVBvUCfqfRc+W0UpMWrGne5lBJJTO6cH5mcXKZIoiLu78iivNWUx6s9jpu1zMYQorDcrN2Y3Xk277R4B0szS/be2MvAdQPZfHWzcoCNCwxbBj0+Ba05nPsLfmwHYYfUDby8SYnKW1GRrrRliyQqIn9pcUSeXcM2G+VUj7TLF6LoNBoNw2oO47fHf6OWSy0SMhJ4ZfsrvL/3fVKzUnN6royHsf+BcwAkXINFPWDXTDDo1Q6/fEiJvj05WbrSlimSqIj8nVjJahsdeo2Gxh6NqOFcQ+2IhCjzqjpVZWmvpYytOxYNGlYHr2bo30M5H3teOcCnMTy/E+oMBEM2bJkOv/SDxBvqBl4OGJNu3R5IKIlKmSKJiriX0Yj+yE/8kdPgbVDgYJUDEqL8MDczZ3KTySzotgAPaw+uJF5h+D/DWXpuqdLR1soRBv0E/WaDuS1c2aW03z//j9qhl2nJyTfJ1Crt8+XUT9kiiYq417X97Em+SoROh6OFA90CuqkdkRDlTvNKzfm97+909OtIliGLTw9+yktbX1I62mo00GiEsrpSqQGkxcGK4fD3q5CVpnboZVJssrIqZaPRye7FMkYSFXGvI4tYlbOa0rd6PyzNLFUOSIjyydnKmW8f+5a3W7yNhdaCHdd38MS6J253tHWrDmM3Q+uXlOuHF8K8jnDrjGoxl1UxqVEAuJrbqRxJ2ZGepee/MxFk6w2qxiGJirhbaiwR59exM6eIdlCNQSoHJET5ptFoeLLmkyzrvYyqjlWJSoti3H/j+OboN2QZskBnAd0+gpGrwdYDos7DvMek50ohxaTHAuBq4ahyJGXH3ydv8tyvRxg+/4CqcUiiIu52YjlrbMwx5ExJrupUVe2IhKgQglyCWPH47Y62C04tYNT6UVxJuKIcUL2z0n6/RnfQZ9zRcyVO1bjLitjMREDqUwrj1/1XAegQpG7fGUlUxG1GI/rDt4toB0sRrRClylpnzfut3mdWx1k4WDhwJuYMQ/4ewqqLq5RCWzt3GL4Sus+4o+dKewg7qHbops1oJCY7BQBXaZ9fICevx3MiLB5zMw1Dm/mpGoskKuK2q3vYnXqdWzodThaOdPHvonZEQlRIXf27srrvalpUakFadhrT901n0rZJxKbHKoW2rV7M6blSRem58lMP2DULDOrWEpiszBRiNMqfjaudt8rBlA1LclZTetWrhJudunWKkqiI2w4vYlXOlGQpohVCXZ62nszrOo/Xmr6Gudac7WHbGfjnQHZd36UckNtzpe4TYNTDlg9g6ROQHKlq3CYpJSqvfb6LrZfKwZi+hNQs1p1QdkmNaumvcjSSqIhcKTFEXPybXdZWAAwKlCJaIdSm1WgZXWc0y3svp7pTdWLSY3hxy4t8cuAT0rPTwcoBnlgIfb8HnTVc2gpz2ihfxW0pUcTmDiSUZm8P9fvR66RnGajpZU8Tf2e1w5FEReQ4vpTVNpYYNBqaeTWjimMVtSMSQuQIcgliee/leaMslp9fzpP/PMnFuIvKqaDGo+C57eBRG1Ii4dcBsPEdyM5QN3BTcceKiiQqD2YwGPNO+4xq5Y9Go1E5IklUBIDRSPaRRfxhbwtIEa0QpshKZ8Wbzd/kxy4/4mrlSkh8CE/+/STLzi1TCm09asK4rdB0rPKAfd/Dgs4QdUHdwE3BnYmKlSQqD7L3Ugyh0SnYWero39BH7XAASVQEQOhOdqXfJFKnw9nSic6VO6sdkRDiPtr4tOGPvn/QzqcdmYZMZhycwaStk5SOtubW8PgsGLYcbFwh4hTM7QCHFlbonivpiTdJ0eZMTraW7ckP8uv+KwAMbOyDraVO3WBySKIi7upE2696fyzMLFQOSAjxIK7WrvzQ+Qfeav6WUmh7fTtPrHuCfTf2KQfU7KX0XKn6GGSnwT+vKi34U6LVDVwlue3zzdFib26vcjSm62ZCGpvO3gJgpAkU0eYyjXRJqCcpghsX/2W3j9LQR4pohSgbNBoNI2qNoKlnU97Y+QaXEy7z/KbnGVN3DC81fAlzey+lm+3+2cqOoAvrYc4R6D9HaR5XgcSkRADgqrMxiZqL4rY3JJqZmy5iZa7F2cZCudha4GJjrny1taBxZeeHrpAsP3ANgxFaVHEh0NN0EjpJVCq67TNYbWuJUaOhhVcL/B1MJ4sWQjxcbkfbLw59waqLq1h0ehH7b+zn03afKp2lW0+EKu3hj2ch+gIsGQitJkLn/4GuYrQgiEmPAQ24WJjOm29xMRqNfLz+HGduJD7wOB8na34d25yq7vnPOsrMNrD8UBigFNGaEjn1U5FFnif76C+sySmildUUIcoma501/2v1P77u+DWOlo6ciz3HkL+H3C60rVRf2RV0Z6Htwq4QHaJq3KUlNiMBAFdL9bfaFreT1xM4cyMRC52WLwc34P0+tZnUqTojW1amd/1KtK7miru9JeHxaQyZu4+z90lo/jsbQVRSBu72lnSrbVq9ZmRFpSLbPI2/bK2J1OlwsXKRIlohyrjO/p2p61aX/+39H3tv7GXGwRnsuL6DD9t8iIeNh1JoW60TrJsIN0/A3PbQ63NoOELZ5lxOxWQlg5UFrjYeaodS7JYduAZAr7peDGrim+8xMckZPPXTQc7cSGTYvH0seroZTfzvLirO3ZI8rJkfFjrTWsMolmj0ej3Hjx8nLk6GY5UZV3aTFryB752dAHim7jOYm5mrG5MQ4pF52nryY5cfmdp8KpZmluy9sZeB6wby35X/lANqPQ4v7IGAdpCVAn9OgN+fgbR4VeMuMfpsYgxKPxlXu0oqB1O8EtNvd5Ad8YDiV1c7S5aNa0lTf2cS07MZueAgu4NvF1YH30pi/+VYtBp4snnlEo+7sIqUqEyePJmFCxcCSpLSoUMHGjdujJ+fH9u3by/O+ERJMBjgv3dZ6mBPpM4Mb1tvhtUcpnZUQohiotFoGF5rOL/1+Y3arrVJyEhgyo4pvLP7HZIyk8DRB576U6lT0ZjBmdXwYzu4dkDt0ItfakxeV1qXcjbnZ+2xcNKy9NTwsKPpQzrIOlqb8+vYFrQPdCctS88zPx9iw2mlyDh3NaVLLU+8naxLPO7CKlKi8vvvv9OgQQMA/vrrL0JDQzl//jyTJ0/mnXfeKdYARQk4s5rYiBMscHIE4KXGL8lcHyHKoaqOVVnScwnj6o1Dq9Gy7tI6Bq0bxOGIw6A1g3ZTlOGGTv7KcMNFPWHbJ6DPUjv04nNnszcbd5WDKT5GozHvtM/wFpULtJvJ2sKM+U81oWddLzL1BiYsO8qv+6/yx9FwwPSKaHMVKVGJjo7Gy0sptlm/fj2DBw8mMDCQsWPHcurUqWINUBSz7AzY8gHznBxJ0Wqo5VKLXlV6qR2VEKKEmJuZM6nxJBb3WIyvnS83Um7wzMZn+OboN2Tps8C3KbywG+oNUYYb7vhMKbSNuqh26MUjJYqYcjjn5+i1eM5HJGGp0zKwUf61Kfmx1Jnx3ZONGNzEF73ByHtrT5OckU0VN1vaVHMrwYiLrkiJiqenJ2fPnkWv17Nhwwa6dOkCQGpqKmY5maswUQfnE5Z8g5UOyha1V5q8glZjWoVTQoji19CjIb/3/Z0B1QdgxMiCUwsYsX4ElxMu5ww3nK8MOLRyghvHYG472D9HOVVclt05Odmq/HSlzV1Neby+N442hasv1Jlp+eyJ+jzT5vZMtxEtKqPVmmZBdZHeoZ5++mmGDBlC3bp10Wg0dO3aFYADBw5Qs2bNYg1QFKO0ONj5Bd86O5Kt0dDGuw2tvFupHZUQopTYmtsyvc10vur4Vd425qF/DWXl+ZXKNuZ6g+DFfVCtM2Snw4a34Nd+EB+mduhFlp18i/gyMOfndHgCA2fvYeWhaw89NiE1i79P5hbRFq34VavV8N7jtXjv8dr0rl+JYSZYRJurSInKtGnTWLBgAc899xx79uzB0lKpbzAzM+Ott94q1gBFMdr5JacNqWyws0WDhleavKJ2REIIFXTx78LqvqtpVakV6fp0PjrwERO3TiQ6LRocvGHkH9B7JpjbQOhOmNMaji8vk/OC4pKuA8qbnZOlk6qx3E9sSibP/3qEo9fimbr61F07cvLzx9HrZGQbqOllTyM/pyK/rkajYWzbKvwwvDF2JjLXJz+FSlSGDx/Ob7/9RmJiIoMGDeKVV17B1/f2ubHRo0fTr1+/Yg9SFIO4KxgPzmOmixMAfar1IcglSN2YhBCq8bDx4MeuP/Jmszex0Fqw8/pOnlj3BFuvbVV6qjR7Vqld8W0GGYmw9gVYObLMzQuKSVZ2tjibWWGmNb3SBL3ByMsrjhEen4ZOq8FghEk51/NjNBpZdlBZdRlRwCLasq5QiUpQUBCfffYZHh4edOvWjR9++IGwsKIvCU6bNg2NRnPXJbdIVxSzLR+yy0LLYWsrLLQWTGw4Ue2IhBAq02q0jKw9kuWPL6eGcw1i02N5edvLvL3rbRIyEsC1Gjy9ATq9B1odnP8bfmgB5/5WO/QCi02NAsBFl3/reLV9syWYXcHRWJlr+X18a+r6OBCbksn4JUdIz9Lfc/yhK3GERCZjbW5Gv0Y+KkRc+gqVqLz//vscOXKEkJAQ+vfvz7p166hRowaNGzdm2rRpHDt2rNAB1KlTh5s3b+ZdZNdQCQg/iv7073zlouyzH1FrBJXKWeMjIUTRBToHsrz3cp6p+wxajZa/Lv/FwD8Hsuv6LjDTQfvXYNw28KgNqdGwcgSseaFMNImLyVAakbpamV77/G3nI/l2SzAAnwyoR0M/J+aMaIKTjTknryfwwV9n7nnMsgNKz5O+DbxxsKoYTTqLVKPi6+vLiy++yMaNG4mKiuKtt94iODiYzp074+/vz8SJEzlz5t4/4PzodDq8vLzyLu7u5Wefu8nY9jHr7GwJsTDHwcKBsfXGqh2REMLEWJpZ8kqTV1jcYzEBDgFEpkXy4pYXeX/v+0qTuNx5QW0mg0YLJ5YrtSuXtqkd+gPFZCUBprc1OSw2lckrjwMwsmVlBjZWyij8XGz4dlgjNBpYfjDsruLauJRM1uc0aStqEW1Z9Mj7Uu3t7RkyZAhLly4lKiqKn376CTMzM/bt21egxwcHB+Pt7U2VKlUYNmwYly9fvu+xGRkZJCYm3nURD3HjGGmXtuS1yn+u/nM4WjqqG5MQwmQ19GjIqj6rGFV7FBo0rA5ezcB1A9l3Y58ybbnrB/D0v+BcBRLD4df+sP51yExVO/R7GY3EZCtxudh4qhzMbelZesYvPUJCWhYN/Jx47/Had93fPtCdKV0DAXjvzzOcvB4PKEW0mdkG6vo4UN/XqZSjVk+hEpX09HRCQkLIzMxk3bp1JCcn33W/mZkZnTt35ptvvuHZZ5996PO1aNGCX375hY0bNzJ//nwiIiJo3bo1MTEx+R4/Y8YMHB0d8y5+fn6FCb9i2jWTZQ52ea3yn6z5pNoRCSFMnJXOijeavcGiHovwtfMlIiWC5zY9x4f7PiQlKwUqt1QKbZvl/J4/OA9+bGt6Lfgzk4nVKDuVXO1Np55j2roznA5PxNnGnNkjGmOpu7fI98WO1elSy5PMbAPjlxwlJjnjdifa5qbZQbakFCpRGTNmDHXq1GHGjBl88cUXPPPMM4/04j179uSJJ56gXr16dOnShX/++QeAxYsX53v81KlTSUhIyLs8SiFvhRB5nvTzf/OLowMAExpNwMLMQuWghBBlRRPPJvzR9w+GBSmzwH67+BtPrHuCgzcPgqWdsoV55Gqw94bYS7CoB/z3HmSlqxx5juTI2+3zTaQu77dDYaw4FIZGA98Ma4TPfWbraLUaZg1tQICrDeHxaQz+cR+Xo1OwtTCjb8PyNbPoYQqVqMTGxlK1alWmTp3Kzp07uXixeFss29raUq9ePYKDg/O939LSEgcHh7su4gF2z2KtnS2xZmb42PlIq3whRKHZmNvwTst3WNBtAd623oQnhzP2v7F8vP9jUrNSoXpnpUlcgyfBaIC938K8DhB+VO3QISX6dqJiAs3eTocn8N6fpwF4tUsg7QMfXJPpYGXO3FFNsTY343J0CgD9GvmYdM+TklCoRMXCwoLBgwdjYWGBRqPBycmpWIPJyMjg3LlzVKpkGplvmRYbSvap3/k5ZzVldJ3R6LQV639uIUTxaVGpBav7rWZI4BAAVlxYwcB1AzkUcQisnWDAjzBsOdh6QNR5WNAFtn4E2ZnqBZ0SdXtysrW67fMT0rJ4celRMrINPBbkzoTHqhfocUFe9nz6RL2868NNuINsSSl0w7fp06cDSlIRFPRoDcNee+01duzYQWhoKAcOHGDQoEEkJiYyevToR3peAez5mg02loSb63CxcqF/9f5qRySEKONszW15r9V7zOs6j0q2lQhPDueZjc8w48AMZXWlZi+YcADqPqEMONz5BczvBBHqtJ0wJN8i1gRWVIxGI6+vOsG12FR8na35amjDQs3V6dfQh5mDG/DpwHrU9al4myEKnajksrS0ZO7cuY/04tevX+fJJ58kKCiIgQMHYmFhwf79+/H3r1iFQsUu8QbG48tY6KSspoysNRJrXf7nQYUQorBaebdidd/VDAocBMCy88sY9NcgZXXFxgUG/QSDfwYbV7h1CuZ1hB2fgz6rVONMTLpBdk7nVjUTlQW7Qvnv7C0szLTMHtEYJ5vC1wo+0cTXpOfxlCSN0Vi04Q3p6emcPHmSyMhIDP9vumbfvn2LJbiHSUxMxNHRkYSEBKlXudOGqew48RMTvTywNbflv0H/4WAhfz5CiOK398Ze3t/7PhEpSn+PoUFDeaXJK9ia20JyJPz9itLRFqBSA+g3G7zqlkpsl9aNp3/cbuw15ux9Sp2amUNXYhk2bz96g5EP+9VhVKsAVeIwNYV5/y5S0cKGDRt46qmniI6+d+aDRqNBr7+37a8oJSnRcHgRC92Vv/ghgUMkSRFClJjW3q1Z03cNs47MYtXFVay8sJJd13fxfuv3ae3dGoYugVO/w7+vw80TyupKhzeg7StgVrKdVWNTbgHgam5boq9zP9HJGUxcdhS9wUjfBt6MbClnC4qiSA3fJk6cyODBg7l58yYGg+GuiyQpKts/m6NmBo5ZWWGuNWdU7VFqRySEKOfsLOz4X6v/Mb/bfHzsfLiRcoPnNz3P+3vfJzErCeoPhhcPQFBvMGTBto9zaldOl2hcMemxALhalH5dh95gZPKK49xKzKCauy0zBtarEAMES0KREpXIyEheffVVPD1Np9OfQJm7cXA+C3JqU/pV74e7jYwkEEKUjpaVWrK672pG1BqR19V2wJ8D2BG2A+w9YdhSGLgArJ0h4mSJ167EZCrdy12tSn/Hz7dbgtkdEo21uRlzRjbBtoJtKS5ORUpUBg0axPbt24s5FPHIDi3ggiGNXTbWaDVanq7ztNoRCSEqGBtzG95q/hY/9/hZmRmUGsnErRN5a9dbxGXE315dqfn4/1tdKf6dQTHZSvd0FxuPYn/uB9l5MYpvtyr9wD4eUJdAT/tSff3ypkgp3vfff8/gwYPZtWsX9erVw9z87vOMkyZNKpbgRCFkpsD+2fyUs5rS1b8rlR0qZoW4EEJ9jT0bs6rPKmYfn83is4v55/I/7Luxj6nNp9I9oDuaoUvg9B+w/rXbqyvtX4e2r4KuGDpo67OINWYBlrjalV4n15sJaUxeeRyjEZ5sfnvYoCi6IiUqy5YtY+PGjVhbW7N9+/a7zrtpNBpJVNRwZDFhmfFs8FDmWYytKxOShRDqstJZ8WrTV+kW0I3/7f0fwXHBvL7zdf4J/Yd3W7yLZ71BUKX97Z1B22fAub+h/w/KDqFHkRpDjFY5aeBqXzrJgt5gZOKyY8SmZFLH24H3+9R++IPEQxXp1M+7777L9OnTSUhI4MqVK4SGhuZdHjT9WJQQfRbs/Y7Fjg4YNNDGuw21XGupHZUQQgBQ160uK3uv5MWGL6LT6tgetp3+f/Zn1cVVGGzdlJ1Bg34Caxel78r8TrD140frapscmdfszcWmdHqobL8QyZGrcdhb6pg9ojFW5vcOGxSFV6REJTMzk6FDh6LVFunhorid/ZPolAjW2NsBMLaerKYIIUyLuZk54xuMZ9Xjq6jvVp/krGSm75vOs/89y7WkMKWb7YSDULs/GLJh5+ePNjMoJarU5/ysORYOwKCmvvi7qrMlujwqUqYxevRoVq5cWdyxiKI6OI+ljvZkajTUd69PU8+makckhBD5qu5cnV96/sIbzd7AWmfNoYhDDFw3kJ9P/0y2jTMMWZzT1dYNIs8qM4M2vQ9ZaYV6HWNyFDE5c35crUs+UUlKz2LTWaVvy8BGUpdSnIpUo6LX6/n888/ZuHEj9evXv6eYdtasWcUSnCiAG8dIvX6QlZVv16bIXn0hhCkz05oxqvYoOvp15IN9H3Dg5gFmHpnJv1f+ZXrr6QTVGQAB7WD963BmNez5Gs6tgz7fKDUtBZCaHE56bo1KKayobDgdQUa2gWruttT1kSabxalIKyqnTp2iUaNGaLVaTp8+zbFjx/Iux48fL+YQxQMdmMffdrYkabVUtq9MR7+OakckhBAF4mfvx/yu8/mg9QfYm9tzNuYsw/4exrdHvyXDyh4GL4Jhy8DeG2Ivw+I+8OdESIt76HPHJimnYawxw8bcpqR/FNYeV15vQCMf+bBYzIq0orJt27bijkMURUo0xtN/sMLLGVBmbGg1UjckhCg7NBoNA2sMpJ1POz458Ambr21m/qn5bLq6iWmtp9GkZm9ldWXLB3BoARz7FS5uhF5fQO1+cJ+kICYlEgCXUhjIejMhjb2XYgBl0rEoXtIqryw78jNHdRBsYYGVmRX9qvdTOyIhhCgSdxt3vnrsKzZf3czHBz7mSuIVxmwYw9CgoUxuPBm73jOh7iD4axJEX4RVoyGoFzR4EpJvQWI4JN7Iu8Rk3AIPF1zNS/40zLrjNzAaoXmAC34uJb96U9EU+OP3Cy+8QFhYWIGOXblyJUuXLi1yUKIA9FlwaCErHZSdPr2r9sbRsvTnWQghRHHq4t+Ftf3WMrDGQABWXlhJv7X92Hx1M8bKLeGF3dDhTdCaw4X18NsopWnc7q/g5Eq4sgtiLxGT8+7m4lDyKxy5u336N5LVlJJQ4BUVd3d36tatS+vWrenbty9NmzbF29sbKysr4uLiOHv2LLt372bFihX4+Pgwb968koxbnP+b6NQINrkq/zCGBg1VOSAhhCgejpaOfND6A3pW6cn0fdMJSwrjle2v0NG3I2+3eJtKj70NdQbA5g+U1RRHH6WOxcEbHHzAoRIxETvhwnJcS7hD97mbiZyPSMLCTEvvepVK9LUqqgInKh9++CEvvfQSCxcu5Mcff+T06bunXtrb29OlSxcWLFhAt27dij1Q8f8cmMfv9nZkazQ0cG8gDd6EEOVO7pDD+afm89Ppn9h+fTsHIg4woeEERtQagW74ivs+NiZiO1DyW5Nzi2gfq+mOo435Q44WRVGoGhUPDw+mTp3K1KlTiY+P5+rVq6SlpeHm5ka1atWk0rm03DxJ9rW9rPJTVlOG1RymckBCCFEyrHRWvNToJXpV6cX0fdM5GnmULw9/yd+X/+b9Vu9T160uAEmZSUSkRCiX1AiORR4DwKUEJyfrDUb+PHYDUHb7iJJR5GJaJycnnJycijEUUWAH57LNxppInRkuVi5085cVLCFE+VbNqRqLeixibchaZh6eyfnY8wz/ZzgBjsqE5pSslHwf52tXcs3XDlyOISIxHQcrHY/VLN0JzRWJ7Popa1Jj4dTvrHRTKtmfqPEEFmbFMGlUCCFMnFajZWCNgXTw7ZC3qhKaEJp3v6OlI142XnjZKpcaTjVo49OmxOLJLaLtXd8bS53M9SkpkqiUNUcXc1mTzQFrK7QaLYMDB6sdkRBClCpXa1dmtJvBmDpjiE2PxcvWC08bz1Jp7JYrPUvPv6cjADntU9IkUSlL9NlwaCEr7O0B6ODbgUp2UmUuhKiYglyCVHvtzedukZyRjY+TNU39nVWLoyKQNqZlyYX1pCReZ13OlGQpohVCCHWsOXq7Zb5WKxtJSlKREpX58+cTHBxc3LGIhzmozPVJ0WoIcAigZaWWakckhBAVTkxyBjsuRgHQv5G3ytGUf0VKVGbOnEnNmjXx9vbmySefZO7cuZw/f764YxN3unUG45VdrHBQTvsMCRoic32EEEIF/5y6SbbBSD0fR6p72KsdTrlXpHe68+fPEx4ezsyZM3F0dOSrr76iTp06eHl5MWyYnI4oEft+4IiVJSEW5ljrrGWujxBCqERa5peuIhfTenl58eSTT9K3b9+81vlLlizh999/L874BChDtk7+xgpXZUtyryq9cLAo+UFbQggh7hYancKxa/FoNdCngWxmKA1FSlT+/fdfduzYwfbt2zlx4gR16tShffv2/PHHH7Rr1664YxQHfiRKo2eLrS0AT9Z8UuWAhBCiYlp3XOlE266GOx72VipHUzEUKVHp3bs37u7uTJkyhY0bN+LoKFN7S0x6IhxexHIHe7I10Mijkapb8oQQoiLbFawU0fas66VyJBVHkWpUZs2aRZs2bfjiiy8ICgpi6NChzJkzh3PnzhV3fOLoYlIyk1iRkww+VfsplQMSQoiKKSUjm+Nh8QC0ruambjAVSJESlcmTJ7N69WqioqLYtGkT7dq1Y/PmzTRo0IBKleScXbHRZ8H+Ofxub0eSBgIcAnjM7zG1oxJCiArp8NU4sg1GfJys8XOxVjucCuOROtMeO3aM7du3s23bNnbt2oXBYMDXt+QGQFU4p/8gKzGcXyr7AfB03acx08o8CSGEUMPeS9EAtK7mikYjTd5KS5FWVPr27YuLiwvNmjVj6dKlBAYG8uuvvxIbG8uhQ4eKO8aKyWiEPd/yt50tkWYaPKw9eLzq42pHJYQQFda+SzEAtKrmqnIkFUuRVlQCAwN57rnnaN++PQ4Osk22RFzagiHyDIt8la6HI2uPlCnJQgihkoS0LE6HJwCSqJS2IiUqX375ZXHHIf6/Pd+yzcaaUHMd9ub2MiVZCCFUdDA0FoMRqrrZUslR6lNKU5F7sO/YsYM+ffpQvXp1atSoQd++fdm1a1dxxlZx3TiOMXQHP+Xs9Blacyh2FnYqByWEEBVXbn1KS1lNKXVFSlSWLFlCly5dsLGxYdKkSUycOBFra2s6d+7MsmXLijvGimfvdxyxsuSklQUWWgtG1BqhdkRCCFGh5dantJZEpdQV6dTPxx9/zOeff84rr7ySd9vLL7/MrFmz+PDDDxk+fHixBVjhxF+DM2v4ycMFgH7V++FmLfv1hRBCLTHJGZyPSAKgZVVJVEpbkVZULl++TJ8+fe65vW/fvoSGhj5yUBXavtlc0GnZZWONVqNlTJ0xakckhBAV2v7LsQAEedrjZmepcjQVT5ESFT8/P7Zs2XLP7Vu2bMHPz++Rg6qw0uLg6C8sclJ2UnX170plh8oqByWEEBVbbn2K7PZRR5FO/UyZMoVJkyZx/PhxWrdujUajYffu3fz888988803xR1jxXFoIeHGdDbYKv8Ynqn7jMoBCSGE2HdZ6lPUVKREZfz48Xh5eTFz5kx+++03AGrVqsXKlSvp169fsQZYYaQnwr4f+MXBAb0GWlZqSW3X2mpHJYQQFVpEQjqXo1LQaKBFFUlU1FDk7ckDBgxg9+7dxMTEEBMTw+7dux8pSZkxYwYajYbJkycX+TnKtP1ziMuIZ7WDPQBj641VOSAhhBD7Liunfep6O+JoY65yNBVTkROV4nTo0CHmzZtH/fr11Q5FHamxsO97ljnYk66B2q61aeHVQu2oVGM0Gllx8FpeF0ghhFCLbEtWX4FP/Tg7Oxd4CFNsbGyBA0hOTmbEiBHMnz+fjz76qMCPK1f2fENCVjJLKykDHZ+p+0yFHnh19Focb60+RZCnPRtfaa92OEKICmxvTqIijd7UU+BE5euvvy6RACZMmEDv3r3p0qXLQxOVjIwMMjIy8q4nJiaWSEylKukWHJjLT472JGkg0DmQrv5d1Y5KVSGRyQAERyaRnqXHylwmRgshSl9YbCrX49LQaTU0C3BRO5wKq8CJyokTJ/jwww+xtbVl586dtG7dGp2uSLW4eVasWMHRo0cLPHF5xowZfPDBB4/0miZn10yijBksc3QHYFKjSWg1JnFGTjVhsWkAGIxwOSqF2t4y+FIIUfpyT/s08HPCzvLR3u9E0RX4HfG7774jOVn5pPvYY48V6vROfsLCwnj55ZdZsmQJVlZWBXrM1KlTSUhIyLuEhYU9Ugyqi78Gh39irpMj6Rpo4N6A9r5yquNabGre98GRSSpGIoSoyPL6p0g3WlUVOEUMCAjg22+/pVu3bhiNRvbt24ezs3O+x7Zv//A32yNHjhAZGUmTJk3ybtPr9ezcuZPvv/+ejIwMzMzuXvK3tLTE0rIcdQXc8RlhWgN/2Cs7fV5u/HKFrk3JFRZ3O1G5eEsSFSFE6TMajXn1KVJIq64CJypffPEFL7zwQt424gEDBuR7nEajQa/XP/T5OnfuzKlTp+667emnn6ZmzZq8+eab9yQp5U50CBxfzhxXJ7I10Nq7Nc28mqkdlUkIu2NF5UJEsoqRCCEqqsvRKUQmZWCh09LYP/8P5aJ0FDhR6d+/P/379yc5ORkHBwcuXLiAh4dHkV/Y3t6eunXr3nWbra0trq6u99xeLm3/hBCdlr/tbQGlNkVAamY20cmZedfl1I8QQg25qymNKztJQb/KCl0dZGdnx7Zt26hSpcojF9NWWBGn4PQffO/hhhFlpk8dtzpqR2USrscphbQWZloy9QauxaaSlqnH2kJ+UQghSs++nPqU1tVker3aipRpdOjQAYDIyEgiIyMxGAx33V/Uxm3bt28v0uPKnK0fc8rCgi22Nmg1WiY2nKh2RCbjWoxy2qeGpx03E9KJTcnkUlQydX0cVY5MCFFRGAzGvInJUp+iviIlKkePHuWpp57i3LlzGI3Gu+4raI1KhRV2CC7+y7deymmzPlX7UNWpqspBmY7cQtrKLjbYWeo4EBrLhYgkSVSEEKXmwq0kYlMysTY3o76vk9rhVHhFSlTGjBlDYGAgCxcuxNPTU3aqFMbWDzlgZcl+ayt0Wh3jG45XOyKTkttDxc/FBjc7Sw6ExnJR6lSEEKUotz6lWRUXLHQVu6+VKShSohIaGsrq1aupXr16ccdTvl0/gjF0B996ewEwOHAwPnY+KgdlWnJ7qPg5W+fdFnxLdv4IIUqPzPcxLUVKFTt37syJEyeKO5by78hPbLOx5qSlBdY6a56r/5zaEZmc6zmnfvxcbAj0VPrLSC8VIURpMRqNHAxVEhVp9GYairSismDBAkaPHs3p06epW7cu5uZ3j77u27dvsQRXrqQnoD+9mu88lFqLEbVG4GYt1eR3MhqNeT1U/FxscLGxAJSdQCkZ2dhKC2shRAm7mZBOYno2Oq2GWpVkfIcpKNJv/r1797J7927+/fffe+6TYtr7OPkbe3QGQiwssDe3Z0ydMWpHZHJiUzJJydSj0YCPkzVW5ma42VkSnZxBcGQyDf2c1A5RCFHOBecMRQ1ws5X6FBNRpL+FSZMmMWrUKG7evInBYLjrIklKPoxGOPIzq+ztABhQYwCOlrKL5f8Ly+mh4mlvlddgKdBT+TOT0z9CiNIQnPO7poaHncqRiFxFSlRiYmJ45ZVX8PT0LO54yqfwI9yMPsdOG6VAdFDgIJUDMk15hbQutwtpc+tUgiVREUKUgtzi/Ro5v3uE+oqUqAwcOJBt27YVdyzl1+FF/GFvh0GjoblXc6o4VlE7IpN0Z31KrtsFtbLzRwhR8nLbIciKiukoUo1KYGAgU6dOZffu3dSrV++eYtpJk2RuTZ70BLJO/8HqSspQq8FBg1UOyHTl7fhxvjNRkVM/QojSYTQaCclbUZFExVQUedePnZ0dO3bsYMeOHXfdp9FoJFG508nf2GkBUTodLlYudPbrrHZEJutaPisqucuvSiV+Fg5W5vk+VgghHtWtxAySMrIx02qo4mardjgiR5EbvokCMBrh8CJ+yy2irT4AczN5o72f3K60le9IVBytzfF0sORWYgbBt5JpIuPWhRAlJHfl1t/VBkudDEI1FbL3qiRdP0xY7AX22lijQcMTgU+oHZHJytYbuBGf2z7f+q77pKBWCFEacrcmB3pIIa0pKXIHrevXr7Nu3TquXbtGZmbmXffNmjXrkQMrF44s4nd7ZfmwtU9r/Oz9VA7IdN1MSCfbYMTCTIunvdVd9wV62rMrOJoLkqgIIUpQ3tZkqU8xKUVKVLZs2ULfvn2pUqUKFy5coG7duly5cgWj0Ujjxo2LO8ayKS2ezNOrWevtAihzfcT95U5N9nW2Rqu9e8hlbkGtzPwRQpSk3BUV2ZpsWop06mfq1KlMmTKF06dPY2VlxR9//EFYWBgdOnRg8GB5Qwbg5G9ssdQQa2aGh7UHHXw7qB2RSbueU5/ie0d9Sq4aMvNHCFHCjEajNHszUUVKVM6dO8fo0aMB0Ol0pKWlYWdnx/Tp0/nss8+KNcAy6f91on0i8Al0WplT8yD5TU3OlftLIzIpg4TUrFKNSwhRMUQmZZCYno1Wg+z4MTFFSlRsbW3JyMgAwNvbm0uXLuXdFx0dXTyRlWXXD3E57gKHrK3QarQMrDFQ7YhMXu6pn8r5rKjYW5nj46QkMLnNmIQQojjlnloOcLXNG+EhTEORPua3bNmSPXv2ULt2bXr37s2UKVM4deoUq1evpmXLlsUdY9lzx2pKe9/2eNl6qRyQ6cuvK+2danjaER6fxoWIJJoFuJRmaEKICiD31HJ1Oe1jcoqUqMyaNYvkZCX7nDZtGsnJyaxcuZLq1avz1VdfFWuAZU5aPOlnVvNnJVcAhgQOUTmgkmM0GjkdnkjNSvaYmz3aTvdrOTUqd3alvVOgpz3bL0TJFmUhRInI25oshbQmp0iJStWqVfO+t7GxYfbs2cUWUJl3ciX/WWpJMtPibetNa+/WakdUYjacjmD80qP0a+jNN8MaFfl50jL1RCcrpxLzO/UDt+tUZOaPEKIkyNZk01Xkj8Hx8fEsWLCAqVOnEhsbC8DRo0cJDw8vtuDKHIMBDszN60Q7KHAQZtrye65zZ3AUAH8ev8GJsPgiP09ufYq9lQ5Hm/w79wZ55TR9kxoVIUQxMxqNt7cmS7M3k1OkROXkyZMEBgby2Wef8eWXXxIfHw/AmjVrmDp1anHGV7aEbOJC0jVOWFmi05gxoMYAtSMqUSevJ+R9/+m/5zEajUV6ntz6lPutpsDt88bRyZnE5Ky+CCFEcYhKziAhLQutBqq6y44fU1OkROXVV19lzJgxBAcHY2V1u4toz5492blzZ7EFV+bsn80KB+UN9bHKnXCzdlM5oJKTnqXnQoSyumGm1bDvcgw7g4u24yuvkPY+9SkANha6vNb6cvpHCFGccnf8VHaxkR0/JqhIicqhQ4d4/vnn77ndx8eHiIiIRw6qTLp1ltgrO/nLTklUhtccrnJAJet8RBLZBiOuthaMaR0AwGf/nsdgKPyqSl4hrcu9PVTulDt/Q07/CCGK0+36FDntY4qKlKhYWVmRmJh4z+0XLlzA3d39kYMqkw7MYaWDHRlaDXVc69DEs4naEZWoU9fjAajn68iEx6pjb6nj7M1E/jp5o9DP9aAeKncK9JIOtUKI4ncxrz5FCmlNUZESlX79+jF9+nSyspQuoRqNhmvXrvHWW2/xxBMVcEJwSjQZJ1aywkF5I32q9lNoNJqHPKhsy61Pqe/jiIutBc93UHaCzfzvIpnZhkI9V+6pn/za598pd+ZPeTr1k6U38OrK4wyfv5/3/zzNkv1XORgaS3xq5sMfLIQoFiG3ZGuyKSvS9uQvv/ySXr164eHhQVpaGh06dCAiIoJWrVrx8ccfF3eMpu/IIv621hFrZoaXjRddA7qqHVGJOxWuJCr1fJ0AeKZtFRbvu8q12FSWH7zG6JzTQQ9jNBoLVKMCt6vxL95Kwmg0lotkcPHeK6w+puyU23sp5q773O0tCfS0o4GvE5M615Bz50KUAKPRmNfxWpq9maYiJSoODg7s3r2brVu3cvToUQwGA40bN6ZLly7FHZ/py87EcHABvzg6ADCy9kjMtflvsS0v0jL1eadf6vs6Akqx66TONXhv7Wm+2xrMoCa+2Fo+/H+vuNQsUjL1gDI5+UGqe9ih1UB8ahZRyRl42Fs98HhTF52cwTebgwEY0zoAS52WC7eSCL6VTHh8GlFJGUQlZbAnJIZKjlaMahWgbsBClEPRyZnEp2ah0UA1d0lUTFGhE5Xs7GysrKw4fvw4nTp1olOnTiURV9lxZg179PFctvDAVmdbIeb6nL2ZgMEIHvaWeDrcThaGNfNj4a7LXIlJZcGuUF7uUuOhz5W7muLpYPnQFQMrczP8XW0JjU4h+FZymU9Uvtx4gaSMbOr6OPDe47Ux095eIUrOyCb4VhIrDoax8nAYm85FSqIiRAnILc6v7GKDtYWsWpqiQteo6HQ6/P390ev1JRFP2WI0wv4fWJyzmvJE4BPYW5T/c5x59Sk5qym5zM20vNY9CIB5Oy/ldZt9kGsFPO2T63aH2rJdUHvqegIrD4cBMK1PnbuSFAA7Sx2NKjvzXE7tz75L0SSly+RoIYpb7tZkKaQ1XUUqpn333Xfv6khbYV3bz/mYsxywtsJMo2VkrZFqR1QqTuUkKvV8nO65r1fdStT3dSQlU8/3W0Me+lwF3fGTK7fYrSwnKkajkQ/+OoPRCP0aetP0AUMWq7nbUdXNliy9kV1F7FMjhLi/3BUV2ZpsuoqUqHz77bfs2rULb29vgoKCaNy48V2XCmP/bH5xUFZTuvl3p5JdJZUDKh0nw/NfUQHQajW82aMmAEsPXM07tXM/Bd3xk6tGOdj5s+7EDQ5fjcPa3Iy3etZ86PGda3kAsPnsrZIOTYgK56KsqJi8IhXT9uvXr1zsuHgkcVe5Fbyef32V5OSpOk+pHFDpSM7I5lKU8g+7rs+9iQpAm+putKvhxq7gaGZtushXQxve9/nC8qYmP7iQNtedKyplcedPamY2M9afB2DCY9Wo5Pjwn7tLLU/m7wpl24VIsvUGdI84qVoIcVuITE02eUVKVKZNm1bMYZRBB+ex3N6WbI2Gxh6NqetWV+2ISsWZ8ASMRvB2tMLd3vK+x73Zoya7gnez9ng449pVpba3Q77HFfbUT1V3W8y0GpLSs4lITC/QG30uo9HInB2XSM/U81TrANzs7h9/SZm97RIRien4uVjzbLuqD38A0MTfGScbc+JSszh6LZ7mVe5/qkgIUXAxyRnEpmTKjh8TV6SPZlWrViUmJuae2+Pj46latWC/fMu0jCRSj/3Kb/ZKBj66zmiVAyo9t/un5L+akquujyN9G3hjNMLnG8/ne4zeYCQ8Lrd9fsESFUudGTVzOtTO3napoGEDsOJQGJ9vuMC3W0No99k2Zvx7jtiU0musdi0mlXm7LgPwTq/aBe6LojPT8lhQzumfc3L6R4jiknvax9fZWnb8mLAiJSpXrlzJd9dPRkYG169ff+SgTN7x5ayx0JNkpsXfvjId/TqqHVGpub3jx+mhx07pFohOq2H7hSj2Xrq3EPRmQhrZBiPmZpq7tjk/TG5dx6/7r7IrOKpAj7kWk8qHf58FlNWgtCw9c3dcpt1nW/l8w3niSiFh+Xj9WTKzDbSp7kr3Op6FemyXWsrxUqciRPEJySmkzZ0jJkxToU79rFu3Lu/7jRs34uh4+1O1Xq9ny5YtVKlSpfiiU5vBAPFX4dYZiDwLt07DrTPoYy6xxNcLgFG1n0KrqTg1A3krKvepT7mTv6stI1pUZvG+q3z273nWTmhzV01Jbn2Kr7PNPdtzH6RdDXdGtfTn1/1XeeP3k2yY3B5H6/s32dMbjLy26gSpmXqaV3Fh+biWbDsfyddbLnI6PJHZ2y/xy76rjGkdwLPtquBkY1HgWApqT0g0G8/cwkyr4f0+dQpdW9M+0A1zMw2Xo1O4FJUsy9RCFIPcFZXqnvLvyZQVKlHp378/oMz2GT367tMd5ubmBAQEMHPmzGILTjUXNsCumUpyknnv7pKtNtZcNzfH0cKBvtX7qhCgOhLSsgiNTgEKlqgAvNS5Br8fuc6J6wn8ezqCXvVu74zK2/FTwELaO03tVZOdwVFcjUnlg7/OMGtIw/seu3D3ZQ5eicXWwoyZgxtgptXQpbYnnWt5sOnsLb7eHMzZm4l8vy2ExfuuMHtEY9rVKJ7hmkajkeSMbD746wwAo1r6F6loz97KnJZVXdkVHM2Wc7ckURGiGATLikqZUKhExWBQhs1VqVKFQ4cO4ebmViJBqU6fCdcPApBlZkGYRw1CnL25ZG3HJa2BQ0mhkBHPkKChWOsK/yZbVp3JWU3xc7HG2bZgqw5udpaMa1+VrzcH88XGC3St7Yl5zq6VwhbS3snGQsfMwQ0YPHcfq4+G072OF93reN1z3IWIJL7ceBGA9x6vfVctjEajoVsdL7rW9mTjmVt8vfki5yOSGPfLYRY/3ZwWVV0LHM+Oi1FsOhtBXEoWsSmZxKXmXFKyyNQr/26cbcx5pUtgoX/WXF1qebIrOJrNZyN5rn21Ij+PEEKRu+OnhqyomLQi7foJDQ0t7jhMyiFra1Y26sml7ESupN4k25AEaRcg7fYxduZ2DK81XL0gVZDXPyWfRm8P8my7qvy67yqh0SmsPBTGyJb+wO0VlYIW0v5/TQNceK59VebuuMw7a07R1N8Z1zt28mRmG3j1t+Nk6g10qunB0GZ++T6PRqOhR10vOtX04PlfD7PtQhTP/HyIpeNa0tDvwT+r0Wjkh20hfPnfxQceZ2thxrS+dXC0KfocqM61PHh/3RkOX40lLiWzwMmiEOJesSmZRCcrtWkyjNC0Faq44sCBA/z777933fbLL79QpUoVPDw8eO6558jIeHjb9Fxz5syhfv36ODg44ODgQKtWre55fjXEaPRsjD9DSHIY2YZsbHQ21HOrR79q/ZjSZAqzO89m/cD1uFmX0xWl+8jrSPuQHT//n52lMrAQ4JstwaRmZgOFb5+fn1e7BhLkaU90cibvrDmN0WjMu++7rcGcuZGIk405nw6s99C6EAudljkjm9C6mispmXqeWniAszcS73t8ZraB11adzEtSBjb2YVqf2nwzrCG/PNOcv19qy563OnF2endOf9Cdfg19ivxzglLLU9PLHoMRtl2IfKTnEqKiC87pbu3rbI2NRZE+s4tSUqi/nWnTptGxY0d69uwJwKlTpxg7dixjxoyhVq1afPHFF3h7exe4z4qvry+ffvop1atXB2Dx4sX069ePY8eOUadOncL9JMWooXtDpjSZQjWnalRzqkYl20plrrFYSTgZHg9A/QLWp9zpyeaVWbg7lGuxqfy0O5SJnWoQlrM1uSinfnJZ6syYOaQB/X/Yw4YzEfx5/Ab9G/lw7Focs7cr25c/7l8PjwLuKrIyN2P+U0156qeDHLkax6iFB1j5fEuq/79z2PGpmTz/6xEOhMZiptUwrW8dRuWsFJWkrrU9OR+RxOZztxjY2LfEX0+I8upipHSkLSsKtaJy/PhxOnfunHd9xYoVtGjRgvnz5/Pqq6/y7bff8ttvvxX4+fr06UOvXr0IDAwkMDCQjz/+GDs7O/bv31+YsIqdl60XY+qOoZ1vO7ztvCVJAeJSMvN26dQpQqJiobs9sPDHHZcJj08jKklZffNzebQ6n7o+jrycs2Lzvz9PExqdwpTfTqA3GOnbwJve9Qs32sDWUseip5tR18eBmJRMRiw4wNWYlLz7r0SnMHD2Xg6ExmJnqWPh6KalkqTA7W3KOy5EkZEtg0GFKKqQnBUV6Uhr+gqVqMTFxeHpebv/w44dO+jRo0fe9WbNmhEWFlakQPR6PStWrCAlJYVWrVrle0xGRgaJiYl3XUTpyN2WXMXN9oFbgR/k8XqVqOPtQHJGNlNXnwLA3lJX5Oe70/iO1Wjg60hiejZ9vtvN5egUPB0smd6vaCtzDlbm/PJMCwI97biVmMHw+Qe4EZ/GoSuxDJi9h8vRKfg4WfP7+FZ0zGnGVhrq+TjiYW9JSqaeA5cr+FBQIR5BcM6KitSnmL5CJSqenp55hbSZmZkcPXr0rqQiKSkJc/PCvemcOnUKOzs7LC0teeGFF1izZg21a9fO99gZM2bg6OiYd/Hzy784UhS/wvRPuR+tVpPXrG3nRaVRm5+LTbGsWOnMtMwc0hBLnZbkDKUG5vNBDR6pJ4qLrQVLnm1BgKsN4fFpDP5xHyPmHyAuNYv6vo6smdCaml75jwYoKVqt5vaQQulSK0SR5fZQkRUV01eoRKVHjx689dZb7Nq1i6lTp2JjY0O7du3y7j958iTVqhVu22RQUBDHjx9n//79jB8/ntGjR3P27Nl8j506dSoJCQl5l6Ku3ojCO3k9Hsh/YnJhtKvhTtvqt4uQH/W0z52qe9jxbu9aAIxpHUCHwEfvheJhb8XScS3xcbImPD6NTL2B7nU8WflcKzzsC95Ntzjd2aX2zuJhIUTBxKVkEp2snHqWFRXTV6hi2o8++oiBAwfSoUMH7OzsWLx4MRYWtz+x/vTTT3Tr1q1QAVhYWOQV0zZt2pRDhw7xzTffMHfu3HuOtbS0xNKy9AfJiTt2/DzCikquN3vUZPf3u4FH2/GTn1GtAuhWxwuPBwxMLCwfJ2uWjWvBu2tP08TfmUmdaqAtRCfd4tamuhtW5lpuJKRz9mYidbwf/e9EiIok97SPj5M1tpay48fUFepvyN3dnV27dpGQkICdnR1mZncPcVq1ahV2do+WnRqNxkJtcRYlLyopgxsJ6Wg0RSuk/f/q+ToysJEPq4+F06iyczFEeLfCzA0qKH9XW34d26LYn7corMzNaFvdnc3nbrHlXKQkKkIU0tkbygevQGn0ViYUaUiNo6PjPUkKgIuLy10rLA/z9ttvs2vXLq5cucKpU6d455132L59OyNGjChKWKKEnMrZllzN3Q67Yvr08fmg+vw1sS296t3bTVY8XNfaplmnkpyRzcLdoVyKunf0hBCm4lhYPAAN/Yr/g5Iofqqued26dYtRo0Zx8+ZNHB0dqV+/Phs2bKBr165qhiX+n7yJycWwmpJLZ6YtdOM4cVunmp5oNKc4eT2BiIR0vBzVqZe5U1xKJmMWHeTE9QTmbLdg3cS2eDupN2IiS2/gQkQSx8PiCb6VRP9GPiWygifKnqPX4gBo7O+kbiCiQFRNVBYuXKjmy4sCKmpHWlFy3O0taeDrxPGweLacv8WIFqXTx+V+IpPSGbXgIBdyelNEJ2fy3K+HWfV8a6wt7l19LW5Go5ErMamcCIvneFg8J67Hc+ZGIpnZhrxjVhwKY87IxnSq6fmAZxLlXVRSBmGxaWg0PHREhjANRTr1IyoOo9F4e8aPJCompWtt5Q130Z4rRCalqxbH9bhUhvy4jwu3kvCwt2TRmGY425hzOjyRt1afLJWdSW+vOcVjX25n8srj/Lz3CseuxZOZbcDR2px2NdxoFuBMRraB5345wtpj4SUejzBduaspgR722Fs9eg8nUfKk3Fk80K3EDKKSMtBqoHYlSVRMyRONfVm05wohkckM/nEfS8a2KPKAx6K6HJXMyAUHuJGQjq+zNcuebUllVxtmj2jCyIUH+PP4Dep4O5TotOcDl2NYfjAMbc4n5AZ+TspXXyf8XZU+PVl6A2/8fpI1x8KZvPI4CWlZjG4dUGIxCdN17Fo8AI0qO6kahyg4WVERD5TbPyXQ075UlvBFwXk5WvH7C63wdbbmakwqT8zZy4WIpFJ7/XM3Exkydx83EtKp5m7LqhdaUdlVSZRaVXPlf48rjRs//fc8O3Ia/BU3g8HIJ+vPAco8qdUvtuH9PnXo19CHADfbvGaC5mZaZg5uwJic5OT9dWf4evNF6UNTAeXVp0i9UpkhiYp4oOLoSCtKToCbLX+Mb02gpx2RSRkMmbsv7xdxSTp2LY6hc/cRnZxJ7UoOrHy+FZUc7y6cfaqVP0Oa+mIwwkvLjhIanXKfZyu6v0/d5MT1BGwtzJjcJfCBx2q1Gt7vU5tXco77enMwH/x1FoNBkpWKIktvyPvwJYW0ZYckKuK+Lkcls/FMBCD1KabM08GK355vRaPKTiSkZTFi/oG8EQXFLTYlkxUHrzFywQES07NpXNmJ5c+1xM3u3gZ7Go2GD/vXpVFlJxLTsxn3y2GS0rOKLZaMbD2fbzgPwPMdquFegCZ/Go2Gl7vU4IO+ygyon/de4dXfjpOlNzzkkaI8uBCRRHqWAQcrHVXdpIdKWSE1KuIe0ckZfLM5mGUHr6E3GLEy19IhsPQG74nCc7KxYMnYFryw5Ai7gqMZu/gQXw9tdNfkaKPRyK3EDEIikwmOTOJmTl1JkKc9Nb0ccLTJv7DwakwKm87e4r+ztzh8JZbcBYg21V2ZN6rpAzt7WurMmDuyCX2+301IZDKvrDzBvFFNiqWz76/7rnI9Lg0Pe0uebVelUI8d3ToAJxtzpvx2grXHbxCXmsVXQxviYlv02VDC9OWuNjas7Kxqd2lROJKoiDypmdks3BXKjzsukZKpB6BTTQ/e7FEzr/ZAmC5bSx0LRjfl1ZUn+OfUTSYuP8qhKwEkpWcTEpXM5chkknIGNubHy8GKIC97anrZU8PTntDoZDadvZU3vC1XTS97eterxLj2VbEyf3jdkoeDFXNHNWXI3H1sPneLWZsu8lr3oEf6WRNSs/huawgAU7oFYmNR+F9l/Rr6YG+lY/ySo+y4GEWPr3fy5eAGtC+GGVHCNB29mluf4qRuIKJQNMYyXE2WmJiIo6MjCQkJODiU7hTb8iRbb+D3I9eZtekikUnK+IL6vo681bMmrau5PeTRwtToDUbe+/M0yw5cu+c+M60Gf1cbqrvb4e1kTVhsKucjkgiPT7vv85lpNbSo4kLX2p50qeVZ5J1Fvx+5zmurTgAwtKkfH/SrU6BEJz8f/3OW+btCCfK0Z/3L7TB7hE/Hp8MTmLzyOCE581+eaVOFN3oEFTk2Ybo6fLGNqzGp/PJMc0lIVVaY929ZUangQiKTmbD0aF6jLj8Xa17vXpPH61WSpdEyykyr4eP+daldyYGjV+MIcLOluocdNTzs8He1xUJ3b2laUnoWF28lcT4iiQsRSQTfSsbFzoKutTx5LMjjvqeFCmNQE1+ikjL4fON5Vh4O42R4AnNGNCbAzbZQzxMWm8rivVcBeKtXzUdKUgDq+jjy18S2fLL+HL/uv8pPe0LZeymab4Y1IsjL/pGeW5iO6OQMrsakAtBAGr2VKbKiUoFtvxDJS8uPkZSejZONOS91qsHIlpWx1MknSVFydgdH8/KKY8SkZGJvqeOLwfXpUbfSwx+YY9LyY6w7cYM21V1ZMrZF3hbk4rD1/C3e+P0k0cmZWOi0vNWjJmNaB0jSXg5sOnuLcb8cpoaHHZte7aB2OBWerKiIBzIajfy05wof/3MWgxGa+jvz46gm+e7cEKK4ta3hxj+T2jFx2VEOX43jhSVHebZtFd7sWRNzswdvRDx5PZ51J26g0cDUnrWKNUkBZYbSvy+3580/TrL1fCTT/z7L5nO3aBbggp2lDltLHbaWZtha3P7e3d4SD3urR17ZESXrmPRPKbMkUalgMrMNvLf2NCsPhwEwuIkvHw2oK6soolR5OVqx/LmWfLHxAvN2XmbB7lCOhcXz/fBG9/RjyWU0Gvn4H6W524CGPtQtod4+7vaWLBzdlCUHrvHR32fZeymGvZdiHvgYnVaDl6MV3k7W+ORcvJ2sqVXJXgYhmojcHT/SkbbskUSlAolOzmD8kiMcuhKHVgNv96rF2LZViv1TqRAFYW6m5e1etWji78xrq05w5Gocvb7ZRYdAd6q621HN3Y6q7rZUcbPFytyMLeciORAai4VOy5RH3DX0MBqNhlEt/WlV1ZXVR6+TkJZFaqae5IxsUjOzSc7Qk5qRTXJGNlFJGWQbjFyPS+N63L1Fyb3qeTGtbx087NWfcF1RZesNnAhTmlc29pfEsayRRKWCOHczkWcXHyY8Pg17Sx3fDm/EY0HSG0Wor3sdL2p62fPi0qOcuZHI2uM37rpfowEfJ2tSc7bMP9OmCj5O+a+6FLfqHna80aPmA4/RG4xEJWUQHp9GeHwaN+LTCI9LIywulV3B0aw/FcGekBje7V2LQU185YOBCs5HJJGWpcfeUkd1d2n0VtZIolIBHAyNZcyig6Rm6glwtWHB6KZU95DdDMJ0+LvasvrF1uy8GE1wZBKXIlO4HJ3MpchkEtOz81YqnG3MefGxkhtwWBRmOad9vBytaPL/Pq2fuZHAm3+c5HR4Iq//fpJ1J27wyYB6pT48sqI7FhYPQMPKTlIYXQZJolIBfLbhPKmZelpVdWXOyMY42Uj3TWF6LHVmdK3tSdfannm3GY1GYlIyuRSZzNWYVBpWdsLB6tG3SpeWOt6OrH2xDQt3hzJr00V2BUfT7audTOkWyNNtqkgBbik5djW3PkVO+5RFkqiUcxdvJXHkahxmWg3fDGsoSYooUzQaDW52lrjZWdKiqqva4RSJzkzL8x2q0a2OF1NXn2T/5Vg++uccf528Sa+6Xng4WOJpb4WHgyXu9lY4WOkq1OmhzWdvERqdwpg2AQ/d9VVUtycmO5XI84uSJYlKObfioLK7p1NNDzwcpJhPCLVUcbNl2bMtWXk4jE/+OceJsHhO5JySuJOlTouHgyW1vBzo38iHTjU9ym2X3MtRybyw5AjZBiNHrsbx3fBGxZ6sxKZkciWn0VsjP1lRKYskUSnH0rP0rD52HYAnm/upHI0QQqvV8GTzynSq6ZEzVDGVyKQM5ZKYTmJ6NhnZBsJi0wiLTeO/s7dwsNLRu743Axv70NTfuVyttnyx8QLZOVMuN5yJYOKyo3z3ZON8uycXVW7/lGrutsXSYVmUPklUyrGNZyKIT82ikqOVTD8WwoR4OljlO5gxPUtPZGIGEYnpbLsQydpj4dxMSGf5wWssP3iNyi429G/kQ9daniSlZ3H9jl1GNxKUr5FJGTSv4sL7fepQpZDjCUrTkaux/Hs6Iq9VwucbL7DxzC0mLjvK98OLL1k5Ko3eyjxJVMqxlYdymro19ZOiPSHKACtzMyq72lDZ1YbmVVx4vVsQ+0NjWH00nH9P3eRabCrfbgnm2y3BD3ye7Rei2HtpJy92rMYLHaqZ3Kkjo9HIJ+vPAzCkqR/PtqtKdQ87nvv1CP+dvcWEZUf5oZiSlWPX4gHpn1KWyayfcupqTAodvtiORgO73ngMX2fZDilEWZaWqee/sxGsPhrOsWtxuNtb4u1kja/z7U64Pk7WWJmb8eV/F9gVHA0otTEf9qtL2xqmMwl9w+mbvLDkKFbmWna8/hieOfVzOy5GMe6Xw2RmG+hSy5PZIx4tWdEbjNSftpGUTD0bJrejppe8T5gKmfUjWJGzmtK+hrskKUKUA9YWZvRr6EO/hj4PPfaXZ5rzz6mbTP/rLKHRKYxceIB+Db15p3ct1TvkZukNfLbhAgDj2lXNS1IAOgS6s+Cppoz75TCbz93ixaVH+GFE4yKP+LgQkURKph47Sx01pHdUmVUye8GEqrL0BlYdliJaISoqjUbD4/W92TylgzL9WQN/Hr9B55k7WLL/KmoupC8/eI3Q6BRcbS14vsO9zfvaB7qzYHRTLHVaNp+L5MUlR8nI1hfptY6FKfUpDf2c5PR3GSaJSjm05Vwk0ckZuNlZ0rmW58MfIIQolxyszJnWtw5rJ7Shno8jSenZvLv2NG+vOUW23lDq8SSlZ/HNZqW+ZnKXGthZ5r+o366GOwtHN8NSp2XL+Uj6/7CXMzcSCv16R6/GA9I/payTRKUcWnHoGgCDmviWWAMlIUTZUd/XibUT2vBOr1poNbD8YBjjfjlMSkZ2gZ8jLDaViIT0R4pj7o7LxKRkUtXNlmHNKz/w2LY13Fg0phkuthacu5lIv+/3MGvTRTKzC55gHbsmHWnLA3kXK2fC49PYcTEKgGHN5LSPEEJhptUwrn1VfhzZBCtzLdsuRPHk/P1EJWU88HHxqZm8t/Y0Hb7YRpvPtvL6qhNciU4p9OtHJKSzYPdlAN7oUbNAH6JaV3fjv1fa07OuF9kGI99uCabv97s5Hf7w1ZW4lEwu58TZSFZUyjRJVMqZ3w6FYTRCq6quBJhwDwUhhDq61fFi2biWuNhacPJ6AgPn7OFyVPI9x+kNRpbsv0rHL7fz6/6rGIzKbauOXKfTzO28svI4IZH3Pu5+Zm26QHqWgab+znSvU/BT0m52lswZ2YTvhzfCxdaC8xFJ9P/h4asrx3O6/lZ1t5XRIWWc7PopR/QGI6sOK7t9hkkRrRDiPhpXduaP8a0Zs+ggV2NSeWLOXhaMbkoTfxcADl+J5f11ZzhzIxGAIE973u9bGytzM77bEsy2C1GsORbO2uPh9K5XiZc61SDI6/67as5HJPL7EaXAf2qvWkXqrvt4fW9aVnXlf3+eZv2pCL7dEsx/ZyJ4pm0VzM3ufb7N5yIBaZtfHkgflXJk24VInl50CCcbc/ZP7WxyTZ6EEKYlOjmDsT8f4sT1BCx1Wj7sV5d9l2NYcywcAHsrHa92DWRUS390d5yqOXU9gW+3BrPp7K282x4LcifAzRYHK3McrM1xsNLlfDVn9vYQdgVH06ueF7NHNHnkuP85eZP3/jxNbErmQ4/9eEBdRrTwf+TXFMWrMO/fkqiUI8//epiNZ27xdJsA3u9TR+1whBBlQGpmNi8tO8aW85F5t2k0MLSpH691D8LNzvK+jz17I5HvtwXz7+kIHvZOotNq2PRqh2Jr6x+dnME3m4O5EnP/ehk3O0um96uDvZXM+DE1kqhUQJFJ6bSesZVsg5H/XmlPoKc0NxJCFEy23sD7686w9MA1Gvo58UHfOjTwcyrw4y/eSmLb+UgS0rJITM8iIS2bxJzvE9OySM3U81SrAMZ3vLdviqiYpDNtBfT7ketkG4w0ruwkSYoQolB0Zlo+HlCPl7vUwM3WEm0hm6MFetrL7x1RYiRRKQcMBmPeAMKH9SYQQoj7Ubu9vhD5ke3J5cCO4CiuxqRib6Xj8fqV1A5HCCGEKDaSqJQDP++5AijFbzYWskgmhBCi/JBEpYy7HJXMjotRaDTwVKsAtcMRQgghipUkKmXcL/uuAtC5pgeVXW1UjkYIIYQoXpKolGFJ6Vl5nWhHtw5QNxghhBCiBEiiUob9ceQ6KZl6qnvY0ba6m9rhCCGEEMVOEpUyymAwsjjntM/o1gFFmp0hhBBCmDpVE5UZM2bQrFkz7O3t8fDwoH///ly4cEHNkMqMHcFRhEanYG+lY2AjH7XDEUIIIUqEqonKjh07mDBhAvv372fTpk1kZ2fTrVs3UlLuP7tBKBbvvQLAkKZ+2FrKlmQhhBDlk6rvcBs2bLjr+qJFi/Dw8ODIkSO0b9/+nuMzMjLIyMjIu56YmFjiMZqiy1HJbL+QuyVZpoIKIYQov0yqRiUhIQEAFxeXfO+fMWMGjo6OeRc/P7/SDM9k5G5J7hTkgb9r8UwiFUIIIUyRyUxPNhqN9OvXj7i4OHbt2pXvMfmtqPj5+VWo6clJ6Vm0mrGV5Ixsfh3bnHY13NUOSYhySa/Xk5WVpXYYQpRJ5ubmmJmZ3ff+Mjk9eeLEiZw8eZLdu3ff9xhLS0ssLS1LMSrT88eR6yRnZFPN3Va2JAtRAoxGIxEREcTHx6sdihBlmpOTE15eXo+8K9UkEpWXXnqJdevWsXPnTnx9fdUOx2TduSV5jGxJFqJE5CYpHh4e2NjYyL8zIQrJaDSSmppKZGQkAJUqPdqwXFUTFaPRyEsvvcSaNWvYvn07VapUUTMck7czd0uypY6BjSWhE6K46fX6vCTF1dVV7XCEKLOsra0BiIyMxMPD44GngR5G1URlwoQJLFu2jD///BN7e3siIiIAcHR0zPshxW0/52xJHixbkoUoEbk1KTY2MjdLiEeV++8oKyvrkRIVVXf9zJkzh4SEBDp27EilSpXyLitXrlQzLJN0IixetiQLUUrkdI8Qj664/h2pfuqnosnMNmBupinUX+Cqw2G8u/Y0AF1qeRLgJluShRBCVAwm1UelvEtIzaL1p1to9/k21hy7jsHw4EQtPUvPG7+f4PXfT5KRbaBDoDufP1G/lKIVQpRXAQEBfP3112qHUWwK8vNMmzYNT09PNBoNa9euZcyYMfTv379U4hOPRhKVUnT4aizRyZlcj0vjlZUn6P3dbnZcjMp3ZSk0OoUBs/fy2+HraDXwWrdAFo1phrOthQqRCyHKgrCwMMaOHYu3tzcWFhb4+/vz8ssvExMTo3Zoqjp37hwffPABc+fO5ebNm/Ts2VPtkEQhSKJSis7cUFr+V3Wzxd5Kx7mbiYz+6SAjFhzg5PX4vOM2nL5J3+92c+5mIm52Fvw6tgUTO9VAq5Xz5kKI/F2+fJmmTZty8eJFli9fTkhICD/++CNbtmyhVatWxMbGqhabXq/HYDCo9vqXLl0CoF+/fnh5eVX4flxljSQqpejMDWVEwPAWldn5+mM827YKFmZa9l6Koe/3e5iw7Cjv/3maF5YcJSkjm2YBzvwzqR1tpLGbEKoxGo2kZmarcilMHd+ECROwsLDgv//+o0OHDlSuXJmePXuyefNmwsPDeeedd+46PikpieHDh2NnZ4e3tzfffffdXfdPmzaNypUrY2lpibe3N5MmTcq7LzMzkzfeeAMfHx9sbW1p0aIF27dvz7v/559/xsnJib///pvatWtjaWnJ/PnzsbKyuqeR3qRJk+jQoUPe9b1799K+fXusra3x8/Nj0qRJdw2qjYyMpE+fPlhbW1OlShWWLl36wD+XadOm0adPHwC0Wu196wMzMjKYNGkSHh4eWFlZ0bZtWw4dOpR3f5MmTZg5c2be9f79+6PT6fJmzkVERKDRaLhw4cID4xGFJ3tcS1Huikodb0ecbS149/HajGkTwKxNF1lzLJx/Tt7MO/b59lV5rXsQ5maSSwqhprQsPbX/t1GV1z47vTs2Fg//NR0bG8vGjRv5+OOP72nt4OXlxYgRI1i5ciWzZ8/Oe6P+4osvePvtt5k2bRobN27klVdeoWbNmnTt2pXff/+dr776ihUrVlCnTh0iIiI4ceJE3nM+/fTTXLlyhRUrVuDt7c2aNWvo0aMHp06dokaNGgCkpqYyY8YMFixYgKurK76+vrz//vv88ccfjB07FlBWWn777TemT58OwKlTp+jevTsffvghCxcuJCoqiokTJzJx4kQWLVoEwJgxYwgLC2Pr1q1YWFgwadKkvMZi+XnttdcICAjg6aef5ubNm/c97o033uCPP/5g8eLF+Pv78/nnn9O9e3dCQkJwcXGhY8eObN++nSlTpmA0Gtm1axfOzs7s3r2bXr16sW3bNry8vAgKCnro35coHHkXLCUJqVlcj0sDoLb37bkGvs42zBrSkPWT2tGppgfejlbMHdWEqb1qSZIihCiQ4OBgjEYjtWrVyvf+WrVqERcXR1RUVN5tbdq04a233iIwMJCXXnqJQYMG8dVXXwFw7do1vLy86NKlC5UrV6Z58+aMGzcOUE6jLF++nFWrVtGuXTuqVavGa6+9Rtu2bfOSCVB6Z8yePZvWrVsTFBSEra0tQ4cOZdmyZXnHbNmyhbi4OAYPHgwoydPw4cOZPHkyNWrUoHXr1nz77bf88ssvpKenc/HiRf79918WLFhAq1ataNKkCQsXLiQtLe2+fzZ2dnY4OTkBStLm5eV1zzEpKSnMmTOHL774gp49e1K7dm3mz5+PtbU1CxcuBKBjx47s2rULg8HAyZMnMTMzY9SoUXkrSdu3b79rZUgUH1lRKSW5p338XKxxtDa/5/5alRz4aUyz0g5LCPEQ1uZmnJ3eXbXXLg65p5DuPO3RqlWru45p1apV3s6ZwYMH8/XXX1O1alV69OhBr1696NOnDzqdjqNHj2I0GgkMDLzr8RkZGXd187WwsKB+/bt3KY4YMYJWrVpx48YNvL29Wbp0Kb169cLZ2RmAI0eOEBISctfpHKPRiMFgIDQ0lIsXL6LT6WjatGne/TVr1sxLRIrq0qVLZGVl0aZNm7zbzM3Nad68OefOnQOgffv2JCUlcezYMfbs2UOHDh147LHH+OijjwAlUZk8efIjxSHyJ4lKKck77VPJUeVIhBCFodFoCnT6RU3Vq1dHo9Fw9uzZfLfcnj9/HmdnZ9zcHlzvlpvI+Pn5ceHCBTZt2sTmzZt58cUX+eKLL9ixYwcGgwEzMzOOHDlyT7dROzu7vO+tra3vqQdp3rw51apVY8WKFYwfP541a9bctQpjMBh4/vnn76qHyVW5cuW8+o/ibsiXXyKXe3vubY6OjjRs2JDt27ezd+9eOnXqRLt27Th+/DjBwcFcvHiRjh07FmtcQiHnFkpJ7opKXZ8Hj7MWQojCcnV1pWvXrsyePfue0yAREREsXbqUoUOH3vVGvH///ruO279/PzVr1sy7bm1tTd++ffn222/Zvn07+/bt49SpUzRq1Ai9Xk9kZCTVq1e/65LfaZX/b/jw4SxdupS//voLrVZL79698+5r3LgxZ86cued5q1evjoWFBbVq1SI7O5vDhw/nPebChQuPPOk69/l3796dd1tWVhaHDx++63Rax44d2bZtGzt37qRjx444OTlRu3ZtPvroIzw8PO576k08GklUSsmdhbRCCFHcvv/+ezIyMujevTs7d+4kLCyMDRs20LVrV3x8fPj444/vOn7Pnj18/vnnXLx4kR9++IFVq1bx8ssvA8qunYULF3L69GkuX77Mr7/+irW1Nf7+/gQGBjJixAieeuopVq9eTWhoKIcOHeKzzz5j/fr1D41zxIgRHD16lI8//phBgwZhZWWVd9+bb77Jvn37mDBhQt5Kxbp163jppZcACAoKokePHowbN44DBw5w5MgRnn322UeeDWdra8v48eN5/fXX2bBhA2fPnmXcuHGkpqbmFf6Ckqhs2LABjUZD7dq1825bunSp1KeUIElUSkFapp5LUckA1PGWFRUhRPGrUaMGhw8fplq1agwdOpRq1arx3HPP8dhjj7Fv3z5cXFzuOn7KlCkcOXKERo0a8eGHHzJz5ky6d1dqcZycnJg/fz5t2rShfv36bNmyhb/++iuvBmXRokU89dRTTJkyhaCgIPr27cuBAwfw8/MrUJzNmjXj5MmTjBgx4q776tevz44dOwgODqZdu3Y0atSI9957j0qVKuUds2jRIvz8/OjQoQMDBw7kueeew8PD41H/+Pj000954oknGDVqFI0bNyYkJISNGzfm1c+AUqcC0KFDh7zVqQ4dOqDX6yVRKUEaYxkeuJOYmIijoyMJCQk4OJhuAnD0WhwDZ+/Fzc6Sw+92UTscIcR9pKenExoaSpUqVe76pC+EKLwH/XsqzPu3rKiUgtunfUw3mRJCCCFMkSQqpeCsFNIKIYQQRSKJSimQQlohhBCiaCRRKWFZegPnbyYBcupHCCGEKCxJVEpYSGQymXoD9pY6/Jxt1A5HCCGEKFMkUSlhuad9ans7oNUWbzdFIYQQoryTRKWE5XaklfoUIYQQovAkUSlhsjVZCCGEKDpJVEqQwWDkbG6iIluThRBCiEKTRKUEXYtNJTkjGwudlmrudg9/gBBClGMdO3Zk8uTJJf46Y8aMyXeKtFrPIx6NJColKPe0Ty0ve8zN5I9aCFFyxowZg0ajQaPRoNPpqFy5MuPHjycuLk7t0PKsXr2aDz/8UO0w7nHlyhU0Gg3Hjx+/6/ZvvvmGn3/+WZWYxG06tQMoz3ILaWtLIa0QohT06NGDRYsW/V97dx4VxZX9AfxbzdIIzSYiS0QWURTZBdFGBRcEjQTUCBoTUJwkSBI1JBJNFEhcUDIC4oKj5ogx/jRMXMaYEUEUXFAElBGFaEQUJ0FRVFbZ3+8PhwrNJgKmG72fc/ocqupV1a0LdN9+9aoK9fX1yM3Nhb+/P548eYJ9+/ZJOzQAaPVgRFmnrk7v3bKAvua/RDSQlpBXAGNAbaV0Xi/4zFihUAhdXV0MGDAAkydPho+PDxITE/nlDQ0NWLBgAYyNjdGnTx+YmZlh48aN/PKcnBwIBAI8fPgQAPD48WMIBALMmjWLbxMeHo7Ro0e3G8PWrVsxePBgKCkpQUdHB2+//Ta/rOWpHyMjI6xevRq+vr4QiUQwNDTEv/71Lzx48ACenp4QiUSwtLREZmYmv05YWBhsbGwk9hkdHQ0jI6N2Y0pISMCYMWOgoaEBLS0tTJs2Dfn5+fxyY2NjAICtrS04joOLiwuA1qd+ampqsGjRIvTv3x9KSkoYM2YMMjIy+OUpKSngOA7Jycmwt7eHsrIyxGIxrl+/3m5s5PmoR+UlYYw1uzSZChVCeq26KmCtvnT2/eUfgKJKl1a9desWEhISoKCgwM9rbGzEgAEDEB8fj379+iEtLQ0ffPAB9PT04O3tDQsLC2hpaSE1NRUzZ87E6dOnoaWlhdOnT/PbSElJgbOzc5v7zMzMxKJFi7Bnzx6IxWI8evQIZ86c6TDOqKgorF27FitXrkRUVBTee+89ODk5wd/fH99++y2++OIL+Pr64tq1a+C4rt2LqrKyEkFBQbC0tERlZSVCQkIwffp0ZGdnQyAQ4OLFixg5ciROnDiB4cOHQ1FRsc3tBAcH48CBA9i9ezcMDQ0REREBNzc33Lx5U6K36KuvvsKGDRugra2NgIAA+Pv749y5c12KnVCh8tIUl9fgYUUt5AQchulRoUIIefmOHj0KkUiEhoYGVFdXAwAiIyP55QoKCvj666/5aWNjY6SlpSE+Ph7e3t7gOA7jxo1DSkoKZs6ciZSUFPj5+WH37t3Izc3FkCFDkJaWhk8//bTN/RcWFkJFRQXTpk2DqqoqDA0NYWtr22HMU6dOxYcffggACAkJQWxsLBwcHPhenC+++AKjR4/G/fv3oaur26W8zJw5U2L6u+++Q//+/ZGbmwsLCwtoa2sDALS0tNrdR2VlJWJjYxEXF4cpU6YAAHbs2IGkpCR89913WLp0Kd92zZo1fDG3bNkyvPnmm6iuroaSklKX4n/dUaHykjT1pgzSVoGSgpyUoyGEdJmC8rOeDWnt+wWMHz8esbGxqKqqws6dO3Hjxg188sknEm22bduGnTt34s6dO3j69Clqa2slTqW4uLhg+/btAIDU1FSsWrUKBQUFSE1NRWlpKZ4+fQonJ6c29+/q6gpDQ0OYmJjA3d0d7u7umD59OpSV2z8OKysr/mcdHR0AgKWlZat5xcXFXS5U8vPzsXLlSly4cAEPHz5EY2MjgGeFlYWFRae3UVdXJ3HsCgoKGDlyJPLy8to9Jj09PT7+gQMHdin+1x2NUXlJrv1OT0wm5JXAcc9Ov0jj9YKnOlRUVGBqagorKyvExMSgpqZGogclPj4en376Kfz9/ZGYmIjs7GzMnz8ftbW1fBsXFxdcu3YNN2/exNWrVzF27Fg4OzsjNTUVKSkpGDFiBFRVVdvcv6qqKi5duoR9+/ZBT08PISEhsLa2xpMnT9qNufmpqaZTO23NayouBAIBWIuxO3V1dR3mxcPDAyUlJdixYwfS09ORnp4OABLH/TxN+2x5+okx1mpeR/GTF0eFyktylcanEEKkLDQ0FH//+9/xxx/PeoTOnDkDsViMwMBA2NrawtTUVGJQKQB+nMrq1athbW0NNTU1iUKlvfEpTeTl5TFp0iRERETgypUruH37Nk6ePNljx6StrY179+5JFCstLyturqSkBHl5eVixYgUmTpyIYcOGtbpku2lMSkNDQ7vbMTU1haKiIs6ePcvPq6urQ2ZmJoYNG9bFoyGdQYXKS9L8YYSEECINLi4uGD58ONauXQvg2YdtZmYmjh8/jhs3bmDlypUSV60A4Mep/PDDD/zVL1ZWVqitrUVycjI/ry1Hjx5FTEwMsrOzcefOHXz//fdobGyEmZlZjx7TgwcPEBERgfz8fGzZsgXHjh1rt72mpia0tLSwfft23Lx5EydPnkRQUJBEm/79+6NPnz5ISEjA/fv3UVpa2mo7KioqWLhwIZYuXYqEhATk5ubi/fffR1VVFRYsWNBjx0dao0LlJSitqsN/Hz8FQKd+CCHSFRQUhB07duDu3bsICAjAjBkz4OPjA0dHR5SUlCAwMLDVOuPHj0dDQwNflHAch7FjxwIAxowZ0+6+NDQ0cPDgQUyYMAHDhg3Dtm3bsG/fPgwfPrzHjmfYsGHYunUrtmzZAmtra1y8eBGff/55u+0FAgH279+PrKwsWFhY4NNPP8W3334r0UZeXh4xMTH4xz/+AX19fXh6era5rXXr1mHmzJl47733YGdnh5s3b+L48ePQ1NTsseMjrXGs5cm+XqSsrAzq6uooLS2Fmprs9Fyk5T/EOzvSYdC3D84ET5B2OISQTqqurkZBQQGMjY3pCg1Cuqmj/6cX+fymHpWXgH8QoR71phBCCCHdQYXKS3D1dxpISwghhPQEKlRegqaBtBZvUI8KIYQQ0h1UqPSwp7UNyH9QAYB6VAghhJDuokKlh/16rwyNDOgnEqK/Gg3GI4QQQrqDCpUeRk9MJoQQQnoOFSo9qPRpHXacuQUAsDbQkG4whBBCyCuACpUewhjD5//8D+6UVOENjT6YLzaSdkiEEEJIryfVQuX06dPw8PCAvr4+OI7D4cOHpRlOt/zj9C0k5d6HopwAse/aQVNFUdohEUIIIb2eVAuVyspKWFtbY/PmzdIMo9vO55cgIuFXAEDYW8NhNUBDugERQkgvZWRkhOjoaKnsOy4uDhoaGl1e/6/6wt1TOZJmrl+EVAuVKVOmYPXq1ZgxY0an2tfU1KCsrEziJW33y6rxyb5LaGTATLsBmDPSQNohEUJeQ/PmzYOXl9cLrdPbe7KB7hcXPamoqAhTpkyRdhittJejjIwMfPDBB399QC+oV41RCQ8Ph7q6Ov8yMJBuUVDX0IiP9l7Cw4paDNVVxWovC3AcJ9WYCCHkr1ZXVyftEGSCrq4uhEKhtMPoNG1tbSgrK0s7jOfqVYXK8uXLUVpayr/u3r0r1XjWH/sVmXceQ1Uoj9h3R6CPopxU4yGE9DzGGKrqqqTy6s4zY11cXLBo0SIEBwejb9++0NXVRVhYGL/cyMgIADB9+nRwHMdPA8DPP/+MESNGQElJCSYmJvj6669RX1/PL+c4Dtu2bYOnpydUVFSwevVqpKSkgOM4/PLLL7C2toaSkhIcHR2Rk5MjEdeBAwcwfPhwCIVCGBkZYcOGDR0eR2RkJCwtLaGiogIDAwMEBgaiouLZTTVTUlIwf/58lJaWguM4cBzHH2NtbS2Cg4PxxhtvQEVFBY6OjkhJSZHYdlxcHAYOHAhlZWVMnz4dJSUlHcZSW1uLjz/+GHp6elBSUoKRkRHCw8Ml8tLUQ3X79m1wHIf4+HiMHTsWffr0gYODA27cuIGMjAzY29tDJBLB3d0dDx484Lfh4uKCJUuWSOzXy8sL8+bN6/EctTz1U1hYCE9PT4hEIqipqcHb2xv379/nl4eFhcHGxgZ79uyBkZER1NXVMXv2bJSXl3eYt+6Sf6lb72FCoVBmqtV/5xRh59kCAMDfva1h3E9FyhERQl6Gp/VP4fh/jlLZd/o76VBW6Po33t27dyMoKAjp6ek4f/485s2bBycnJ7i6uiIjIwP9+/fHrl274O7uDjm5Z1+0jh8/jnfffRcxMTEYO3Ys8vPz+dMDoaGh/LZDQ0MRHh6OqKgoyMnJoaDg2fvh0qVLsXHjRujq6uLLL7/EW2+9hRs3bkBBQQFZWVnw9vZGWFgYfHx8kJaWhsDAQGhpabX7QSwQCBATEwMjIyMUFBQgMDAQwcHB2Lp1K8RiMaKjoxESEoLr168DAEQiEQBg/vz5uH37Nvbv3w99fX0cOnQI7u7uyMnJweDBg5Geng5/f3+sXbsWM2bMQEJCgsTxtSUmJgZHjhxBfHw8Bg4ciLt37z73C3NoaCiio6MxcOBA+Pv7Y86cOVBTU8PGjRuhrKwMb29vhISEIDY29vm/0HZ0NUfNMcbg5eUFFRUVpKamor6+HoGBgfDx8ZEo8PLz83H48GEcPXoUjx8/hre3N9atW4c1a9Z0Of7n6VWFiqzIf1CBpf/8DwDgQ2cTuA3XlXJEhBDSmpWVFf/hO3jwYGzevBnJyclwdXWFtrY2AEBDQwO6un++h61ZswbLli2Dn58fAMDExASrVq1CcHCwxAf5O++8A39/f366qVAJDQ2Fq6srgGeF0oABA3Do0CF4e3sjMjISEydOxMqVKwEAQ4YMQW5uLr799tt2C5XmvQvGxsZYtWoVFi5ciK1bt0JRURHq6urgOE7iGPLz87Fv3z7897//hb6+PgDg888/R0JCAnbt2oW1a9di48aNcHNzw7Jly/hY0tLSkJCQ0G4+CwsLMXjwYIwZMwYcx8HQ0LCD7IPfr5ubGwBg8eLFmDNnDpKTk+Hk5AQAWLBgAeLi4p67nY50JUctnThxAleuXEFBQQE/rGLPnj0YPnw4MjIy4ODgAABobGxEXFwcVFVVAQDvvfcekpOTqVCRNsYYbhZX4OzNhzh38yHO55egsrYBjsZ9sXSymbTDI4S8RH3k+yD9nXSp7bs7rKysJKb19PRQXFzc4TpZWVnIyMiQ+OBpaGhAdXU1qqqq+DEN9vb2ba4/evRo/ue+ffvCzMwMeXl5AIC8vDx4enpKtHdyckJ0dDQaGhr4Xp3mTp06hbVr1yI3NxdlZWWor69HdXU1KisroaLSdk/2pUuXwBjDkCFDJObX1NRAS0uLj2X69OmtYu+oUJk3bx5cXV1hZmYGd3d3TJs2DZMnT263PSD5O9DR0QEAWFpaSsx73u/kebqSo5by8vJgYGAgMfbT3NwcGhoayMvL4wsVIyMjvkgBOvc31V1SLVQqKipw8+ZNfrqgoADZ2dno27cvBg4cKMXIgHul1Tj3v8Lk7M2HKC6vkVg+SFsFm96xhbxcrxrmQwh5QRzHdev0izQpKChITHMch8bGxg7XaWxsxNdff93m1ZhKSn8+v6yzH4BN+wWefelrecFBR+Nw7ty5g6lTpyIgIACrVq1C3759cfbsWSxYsKDDAbyNjY2Qk5NDVlZWq+Kn6bRHV8b/2NnZoaCgAMeOHcOJEyfg7e2NSZMm4aeffmp3nea/g6Zjbzmv+e9EIBC0iq2jY+1qjlpq63fT1vyu/E11l1QLlczMTIwfP56fDgoKAgD4+fl1uyusO3adK8DXP+dKzBPKCzDSuC/GmPaDk2k/mOupQSCgK3wIIb2XgoICGhoaJObZ2dnh+vXrMDU17dI2L1y4wH/RfPz4MW7cuIGhQ4cCePYN/ezZsxLt09LSMGTIkDZ7UzIzM1FfX48NGzZAIHj2pTA+Pl6ijaKiYqtjsLW1RUNDA4qLizF27Ng24zQ3N8eFCxdaxf48ampq8PHxgY+PD95++224u7vj0aNH6Nu373PX7QxtbW0UFRXx0w0NDbh69arEZ2VzXc1RS+bm5igsLMTdu3f5XpXc3FyUlpZi2LBh3TmkbpNqoeLi4tKtUe0vi+Ub6hBwgOUADYwx1YKTaT/YDdSEkgJd1UMIeXUYGRnx4yWEQiE0NTUREhKCadOmwcDAALNmzYJAIMCVK1eQk5OD1atXP3eb33zzDbS0tKCjo4OvvvoK/fr14+/v8tlnn8HBwQGrVq2Cj48Pzp8/j82bN2Pr1q1tbmvQoEGor6/Hpk2b4OHhgXPnzmHbtm2tjqGiogLJycmwtraGsrIyhgwZgrlz58LX1xcbNmyAra0tHj58iJMnT8LS0hJTp07FokWLIBaLERERAS8vLyQmJnZ42gcAoqKioKenBxsbGwgEAvzzn/+Erq5uj97HZcKECQgKCsIvv/yCQYMGISoqCk+ePGm3fVdz1PKy5EmTJsHKygpz585FdHQ0P5jW2dm53dN8fxU6b9EGGwMNXF45Gf/6yAlL3YZCPKgfFSmEkFfOhg0bkJSUBAMDA9ja2gIA3NzccPToUSQlJcHBwQGjRo1CZGRkpwaOAsC6deuwePFijBgxAkVFRThy5AgUFZ89UsTOzg7x8fHYv38/LCwsEBISgm+++abdgbQ2NjaIjIzE+vXrYWFhgb1790pcDgwAYrEYAQEB8PHxgba2NiIiIgAAu3btgq+vLz777DOYmZnhrbfeQnp6Ot9bMGrUKOzcuRObNm2CjY0NEhMTsWLFig6PTSQSYf369bC3t4eDgwNu376Nf//733xPRk/w9/eHn58ffH194ezsDGNj43Z7U4Du5ai5pkurNTU1MW7cOEyaNAkmJib48ccfe+zYuopjstil0UllZWVQV1dHaWkp1NTUpB0OIaSXq66uRkFBAYyNjSXGY5DnS0lJwfjx4/H48WOZuVMska6O/p9e5PObelQIIYQQIrOoUCGEEEKIzKL7qBBCCOk2Wb04gvR+1KNCCCGEEJlFhQohhLRAPQOEdF9P/R9RoUIIIf/TdNfNqqoqKUdCSO/X9H/U8m62L4rGqBBCyP/IyclBQ0ODf3aJsrJym7cVJ4S0jzGGqqoqFBcXQ0NDo827Dr8IKlQIIaSZpifMvuwHrRHyqmv5ZO6uokKFEEKa4TgOenp66N+//ws91I0Q8icFBYVu96Q0oUKFEELaICcn12NvtISQrqPBtIQQQgiRWVSoEEIIIURmUaFCCCGEEJnVq8eoNN1MpqysTMqREEIIIaSzmj63O3NTuF5dqJSXlwMADAwMpBwJIYQQQl5UeXk51NXVO2zDsV58r+jGxkb88ccfUFVV7fGbMpWVlcHAwAB3796Fmppaj277VUJ56hzK0/NRjjqH8tQ5lKfOkVaeGGMoLy+Hvr4+BIKOR6H06h4VgUCAAQMGvNR9qKmp0R95J1CeOofy9HyUo86hPHUO5alzpJGn5/WkNKHBtIQQQgiRWVSoEEIIIURmUaHSDqFQiNDQUAiFQmmHItMoT51DeXo+ylHnUJ46h/LUOb0hT716MC0hhBBCXm3Uo0IIIYQQmUWFCiGEEEJkFhUqhBBCCJFZVKgQQgghRGZRodKGrVu3wtjYGEpKShgxYgTOnDkj7ZCk6vTp0/Dw8IC+vj44jsPhw4clljPGEBYWBn19ffTp0wcuLi64du2adIKVovDwcDg4OEBVVRX9+/eHl5cXrl+/LtGGcgXExsbCysqKv8HU6NGjcezYMX455ai18PBwcByHJUuW8PMoT0BYWBg4jpN46erq8sspR3/6/fff8e6770JLSwvKysqwsbFBVlYWv1yWc0WFSgs//vgjlixZgq+++gqXL1/G2LFjMWXKFBQWFko7NKmprKyEtbU1Nm/e3ObyiIgIREZGYvPmzcjIyICuri5cXV35ZzG9LlJTU/HRRx/hwoULSEpKQn19PSZPnozKykq+DeUKGDBgANatW4fMzExkZmZiwoQJ8PT05N8UKUeSMjIysH37dlhZWUnMpzw9M3z4cBQVFfGvnJwcfhnl6JnHjx/DyckJCgoKOHbsGHJzc7FhwwZoaGjwbWQ6V4xIGDlyJAsICJCYN3ToULZs2TIpRSRbALBDhw7x042NjUxXV5etW7eOn1ddXc3U1dXZtm3bpBCh7CguLmYAWGpqKmOMctURTU1NtnPnTspRC+Xl5Wzw4MEsKSmJOTs7s8WLFzPG6G+pSWhoKLO2tm5zGeXoT1988QUbM2ZMu8tlPVfUo9JMbW0tsrKyMHnyZIn5kydPRlpampSikm0FBQW4d++eRM6EQiGcnZ1f+5yVlpYCAPr27QuActWWhoYG7N+/H5WVlRg9ejTlqIWPPvoIb775JiZNmiQxn/L0p99++w36+vowNjbG7NmzcevWLQCUo+aOHDkCe3t7zJo1C/3794etrS127NjBL5f1XFGh0szDhw/R0NAAHR0difk6Ojq4d++elKKSbU15oZxJYowhKCgIY8aMgYWFBQDKVXM5OTkQiUQQCoUICAjAoUOHYG5uTjlqZv/+/bh06RLCw8NbLaM8PePo6Ijvv/8ex48fx44dO3Dv3j2IxWKUlJRQjpq5desWYmNjMXjwYBw/fhwBAQFYtGgRvv/+ewCy//fUq5+e/LJwHCcxzRhrNY9IopxJ+vjjj3HlyhWcPXu21TLKFWBmZobs7Gw8efIEBw4cgJ+fH1JTU/nlr3uO7t69i8WLFyMxMRFKSkrttnvd8zRlyhT+Z0tLS4wePRqDBg3C7t27MWrUKACUIwBobGyEvb091q5dCwCwtbXFtWvXEBsbC19fX76drOaKelSa6devH+Tk5FpVkMXFxa0qTfJM0wh7ytmfPvnkExw5cgSnTp3CgAED+PmUqz8pKirC1NQU9vb2CA8Ph7W1NTZu3Eg5+p+srCwUFxdjxIgRkJeXh7y8PFJTUxETEwN5eXk+F697nlpSUVGBpaUlfvvtN/pbakZPTw/m5uYS84YNG8ZfJCLruaJCpRlFRUWMGDECSUlJEvOTkpIgFoulFJVsMzY2hq6urkTOamtrkZqa+trljDGGjz/+GAcPHsTJkydhbGwssZxy1T7GGGpqaihH/zNx4kTk5OQgOzubf9nb22Pu3LnIzs6GiYkJ5akNNTU1yMvLg56eHv0tNePk5NTqVgk3btyAoaEhgF7w3iStUbyyav/+/UxBQYF99913LDc3ly1ZsoSpqKiw27dvSzs0qSkvL2eXL19mly9fZgBYZGQku3z5Mrtz5w5jjLF169YxdXV1dvDgQZaTk8PmzJnD9PT0WFlZmZQj/2stXLiQqaurs5SUFFZUVMS/qqqq+DaUK8aWL1/OTp8+zQoKCtiVK1fYl19+yQQCAUtMTGSMUY7a0/yqH8YoT4wx9tlnn7GUlBR269YtduHCBTZt2jSmqqrKv19Tjp65ePEik5eXZ2vWrGG//fYb27t3L1NWVmY//PAD30aWc0WFShu2bNnCDA0NmaKiIrOzs+MvL31dnTp1igFo9fLz82OMPbu0LTQ0lOnq6jKhUMjGjRvHcnJypBu0FLSVIwBs165dfBvKFWP+/v78/5e2tjabOHEiX6QwRjlqT8tChfLEmI+PD9PT02MKCgpMX1+fzZgxg127do1fTjn6088//8wsLCyYUChkQ4cOZdu3b5dYLsu54hhjTDp9OYQQQgghHaMxKoQQQgiRWVSoEEIIIURmUaFCCCGEEJlFhQohhBBCZBYVKoQQQgiRWVSoEEIIIURmUaFCCCGEEJlFhQohhBBCZBYVKoS8hjiOw+HDh1/6foyMjBAdHS0z23lRcXFx0NDQ+Mv3Swj5ExUqhLxiiouL8eGHH2LgwIEQCoXQ1dWFm5sbzp8/z7cpKirClClTpBhl29orDDIyMvDBBx/89QERQqROXtoBEEJ61syZM1FXV4fdu3fDxMQE9+/fR3JyMh49esS3aXqse2+hra0t7RAIIVJCPSqEvEKePHmCs2fPYv369Rg/fjwMDQ0xcuRILF++HG+++Sbfrvmpn9u3b4PjOMTHx2Ps2LHo06cPHBwccOPGDWRkZMDe3h4ikQju7u548OABvw0XFxcsWbJEYv9eXl6YN29eu/FFRkbC0tISKioqMDAwQGBgICoqKgAAKSkpmD9/PkpLS8FxHDiOQ1hYGIDWp34KCwvh6ekJkUgENTU1eHt74/79+/zysLAw2NjYYM+ePTAyMoK6ujpmz56N8vLyDvMXFxeHgQMHQllZGdOnT0dJSYnE8vz8fHh6ekJHRwcikQgODg44ceIEv/ybb76BpaVlq+2OGDECISEhHe6bENI2KlQIeYWIRCKIRCIcPnwYNTU1L7RuaGgoVqxYgUuXLkFeXh5z5sxBcHAwNm7ciDNnziA/P7/bH7YCgQAxMTG4evUqdu/ejZMnTyI4OBgAIBaLER0dDTU1NRQVFaGoqAiff/55q20wxuDl5YVHjx4hNTUVSUlJyM/Ph4+Pj0S7/Px8HD58GEePHsXRo0eRmpqKdevWtRtbeno6/P39ERgYiOzsbIwfPx6rV6+WaFNRUYGpU6fixIkTuHz5Mtzc3ODh4YHCwkIAgL+/P3Jzc5GRkcGvc+XKFVy+fLnDAo4Q0gEpP72ZENLDfvrpJ6apqcmUlJSYWCxmy5cvZ//5z38k2gBghw4dYowxVlBQwACwnTt38sv37dvHALDk5GR+Xnh4ODMzM+OnnZ2d2eLFiyW26+npyfz8/PhpQ0NDFhUV1W6s8fHxTEtLi5/etWsXU1dXb9Wu+XYSExOZnJwcKyws5Jdfu3aNAWAXL15kjDEWGhrKlJWVWVlZGd9m6dKlzNHRsd1Y5syZw9zd3SXm+fj4tBlPc+bm5mzTpk389JQpU9jChQv56SVLljAXF5cOt0EIaR/1qBDyipk5cyb++OMPHDlyBG5ubkhJSYGdnR3i4uI6XM/Kyor/WUdHBwAkTmPo6OiguLi4W7GdOnUKrq6ueOONN6CqqgpfX1+UlJSgsrKy09vIy8uDgYEBDAwM+Hnm5ubQ0NBAXl4eP8/IyAiqqqr8tJ6eXofx5+XlYfTo0RLzWk5XVlYiODiY359IJMKvv/7K96gAwPvvv499+/ahuroadXV12Lt3L/z9/Tt9fIQQSVSoEPIKUlJSgqurK0JCQpCWloZ58+YhNDS0w3UUFBT4nzmOa3NeY2MjPy0QCMAYk9hGXV1du9u/c+cOpk6dCgsLCxw4cABZWVnYsmXLc9driTHGx9fR/OaxtxV/W+s/z9KlS3HgwAGsWbMGZ86cQXZ2NiwtLVFbW8u38fDwgFAoxKFDh/Dzzz+jpqYGM2fO7MyhEULaQFf9EPIaMDc37/H7pmhra6OoqIifbmhowNWrVzF+/Pg222dmZqK+vh4bNmyAQPDsO1J8fLxEG0VFRTQ0NHS4X3NzcxQWFuLu3bt8r0pubi5KS0sxbNiwLh+Pubk5Lly4IDGv5fSZM2cwb948TJ8+HcCzMSu3b9+WaCMvLw8/Pz/s2rULQqEQs2fPhrKycpfjIuR1R4UKIa+QkpISzJo1C/7+/rCysoKqqioyMzMREREBT0/PHt3XhAkTEBQUhF9++QWDBg1CVFQUnjx50m77QYMGob6+Hps2bYKHhwfOnTuHbdu2SbQxMjJCRUUFkpOTYW1tDWVl5VYf8pMmTYKVlRXmzp2L6Oho1NfXIzAwEM7OzrC3t+/y8SxatAhisRgRERHw8vJCYmIiEhISJNqYmpri4MGD8PDwAMdxWLlyZZu9NH/729/4ouncuXNdjokQQqd+CHmliEQiODo6IioqCuPGjYOFhQVWrlyJ999/H5s3b+7Rffn7+8PPzw++vr5wdnaGsbFxu70pAGBjY4PIyEisX78eFhYW2Lt3L8LDwyXaiMViBAQEwMfHB9ra2oiIiGi1naZLqzU1NTFu3DhMmjQJJiYm+PHHH7t1PKNGjcLOnTuxadMm2NjYIDExEStWrJBoExUVBU1NTYjFYnh4eMDNzQ12dnattjV48GCIxWKYmZnB0dGxW3ER8rrjWGdOzBJCCOk0xhiGDh2KDz/8EEFBQdIOh5BejU79EEJIDyouLsaePXvw+++/Y/78+dIOh5BejwoVQgjpQTo6OujXrx+2b98OTU1NaYdDSK9HhQohhPQgOptOSM+iwbSEEEIIkVlUqBBCCCFEZlGhQgghhBCZRYUKIYQQQmQWFSqEEEIIkVlUqBBCCCFEZlGhQgghhBCZRYUKIYQQQmTW/wOCRQK72Bj4mAAAAABJRU5ErkJggg==", - "text/plain": [ - "
" - ] - }, - "metadata": {}, - "output_type": "display_data" - } - ], + "outputs": [], "source": [ "plt.plot(observed_flow_select, label=\"Observed flow\")\n", "plt.plot(raw_simulated_flow_select, label=\"Raw simulation\")\n", @@ -2950,7 +660,7 @@ ] }, { - "cell_type": "raw", + "cell_type": "markdown", "metadata": {}, "source": [ "We can see that the optimal interpolation generally helped bring the model similation back in-line with the observations. Note that here the observations were not available and to the optimal interpolation algorithm in this leave-one-out cross-validation implementation, so the improvement is blind to the gauge observation data at this site." @@ -2968,7 +678,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.11.7" + "version": "3.12.3" }, "vscode": { "interpreter": { diff --git a/docs/notebooks/regional_frequency_analysis.ipynb b/docs/notebooks/regional_frequency_analysis.ipynb index 1ae8d434..fb984574 100644 --- a/docs/notebooks/regional_frequency_analysis.ipynb +++ b/docs/notebooks/regional_frequency_analysis.ipynb @@ -35,7 +35,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "Lets start with getting the 02 region stations that are natural and have a minimum duration of 15 years" + "Lets start with getting the 02 region stations that are natural and have a minimum duration of 30 years." ] }, { @@ -54,7 +54,7 @@ " \"variables\": [\"streamflow\"],\n", " }\n", " },\n", - " \"time\": {\"start\": \"1970-01-01\", \"minimum_duration\": (15 * 365, \"d\")},\n", + " \"time\": {\"start\": \"1970-01-01\", \"minimum_duration\": (30 * 365, \"d\")},\n", " }\n", " )\n", " .data.squeeze()\n", @@ -77,7 +77,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "Here, we hide years with more than 15% of missing data and get yearly max and spring max\n" + "Here, we hide years with more than 15% of missing data and get the annual maximum." ] }, { @@ -87,7 +87,6 @@ "outputs": [], "source": [ "timeargs = {\n", - " \"spring\": {\"date_bounds\": [\"02-11\", \"06-19\"]},\n", " \"annual\": {},\n", "}\n", "\n", @@ -100,7 +99,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "## Explainatory variables\n", + "## Explanatory variables\n", "\n", "### a) Extraction using `xhydro.gis`\n", "\n", @@ -122,7 +121,7 @@ " \"variables\": [\"streamflow\"],\n", " }\n", " },\n", - " \"time\": {\"start\": \"1970-01-01\", \"minimum_duration\": (15 * 365, \"d\")},\n", + " \"time\": {\"start\": \"1970-01-01\", \"minimum_duration\": (30 * 365, \"d\")},\n", " }\n", ").data.reset_index()\n", "\n", @@ -270,7 +269,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "To calculate H and Z, we also need a `KappaGen` object from the lmoment3 librairy. This librairy is not part of the xhydro package, so it need to be installed seperately." + "To calculate H and Z, we also need a `KappaGen` object from the lmoment3 library. This library is not part of the default xhydro environment and will need to be installed seperately." ] }, { @@ -313,9 +312,9 @@ "return_periods = [\n", " 2,\n", " 10,\n", + " 20,\n", " 100,\n", - " 1000,\n", - " 10000,\n", + " 350,\n", "]" ] }, @@ -323,7 +322,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "We can now calculate the return periods for each group and return period. Also since we dont want to do our analyssis on really small regions, `remove_small_regions` removes any region below a certain threshold. By default this threshold is 5." + "We can now calculate the return periods for each group and return period. Also, since we don't want to do our analysis on really small regions, `remove_small_regions` removes any region below a certain threshold. By default this threshold is 5." ] }, { @@ -393,7 +392,7 @@ "source": [ "# Uncertainties\n", "## Local frequency analysis uncertainties\n", - "To add some uncertainities, we will work with only one catchment and two distributions as uncertainities can be intensive in computation.\n", + "To add some uncertainities, we will work with only one catchment and two distributions, as uncertainities can be intensive in computation.\n", "We select the station 023401, and distribution 'genextreme' and 'pearson3'. \n", "\n", "For the local frequency analysis, we need to fit the distribution so the calulting time can be long." @@ -416,7 +415,7 @@ "metadata": {}, "source": [ "### Bootstraping the observations\n", - "A way to get uncertainities is to bootstrap the observations 200 times." + "A way to get uncertainities is to bootstrap the observations. For this example, we will boostrap the observations a low amount of times, although a higher number (e.g. 5000) would be preferable in practice." ] }, { @@ -425,7 +424,7 @@ "metadata": {}, "outputs": [], "source": [ - "ds_4fa_iter = xhfa.uncertainities.boostrap_obs(ds_4fa_one_station, 200)\n", + "ds_4fa_iter = xhfa.uncertainities.boostrap_obs(ds_4fa_one_station, 35)\n", "params_boot_obs = xhfa.local.fit(ds_4fa_iter, distributions=[\"genextreme\", \"pearson3\"])" ] }, @@ -446,7 +445,7 @@ "metadata": {}, "source": [ "### Resampling the fitted distributions\n", - "Here, instead of resampling the observations, we resample the fitted distributions 200 times to get the uncertainty" + "Here, instead of resampling the observations, we resample the fitted distributions to get the uncertainty. Once again this example will only bootstrap a minimal amount of times to reduce computation loads, but higher numbers would be preferable." ] }, { @@ -456,7 +455,7 @@ "outputs": [], "source": [ "values = xhfa.uncertainities.boostrap_dist(\n", - " ds_4fa_one_station, params_loc_one_station, 200\n", + " ds_4fa_one_station, params_loc_one_station, 35\n", ")\n", "params_boot_dist = xhfa.uncertainities.fit_boot_dist(values)" ] @@ -535,7 +534,7 @@ "metadata": {}, "outputs": [], "source": [ - "ds_reg_samples = xhfa.uncertainities.boostrap_obs(ds_4fa, 200)\n", + "ds_reg_samples = xhfa.uncertainities.boostrap_obs(ds_4fa, 35)\n", "ds_moments_iter = xhfa.uncertainities.calc_moments_iter(ds_reg_samples).load()" ] }, @@ -665,7 +664,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "So our station instead of beein in one region, will be in many of the regions" + "So our station, instead of being in one region, will be in many of the regions." ] }, { @@ -693,7 +692,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "The followin steps are similar to the previous one, just with more regions. " + "The following steps are similar to the previous one, just with more regions. " ] }, { @@ -773,7 +772,7 @@ "### Combining bootstrap and multiple regions\n", "\n", "calc_q_iter will check in how many `group_id` the station is present, and stack it with samples.\n", - "In this case, it will be stacked with 200 bootstraps, and we have 535 regions, so 104000 samples are generated.\n" + "In this case, it will be stacked with 35 bootstraps, and we have 434 regions, so 15 190 samples are generated.\n" ] }, { From dd562886a5567bc3e8c3ee48117a7b3e4c881010 Mon Sep 17 00:00:00 2001 From: RondeauG Date: Wed, 9 Oct 2024 16:26:10 -0400 Subject: [PATCH 2/4] upd changelog --- CHANGELOG.rst | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/CHANGELOG.rst b/CHANGELOG.rst index 667be0a0..08a6fde7 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -2,6 +2,14 @@ Changelog ========= +v0.5.0 (unreleased) +------------------- +Contributors to this version: Gabriel Rondeau-Genesse (:user:`RondeauG`). + +Internal changes +^^^^^^^^^^^^^^^^ +* Updated the notebooks to reduce the load on ReadTheDocs. (:pull:`211`). + v.4.0 (2024-10-04) ------------------ Contributors to this version: Trevor James Smith (:user:`Zeitsperre`), Gabriel Rondeau-Genesse (:user:`RondeauG`), Thomas-Charles Fortier Filion (:user:`TC-FF`). From 7e25032cb8b7fa13ec03759bbb03e3e4cf6f7873 Mon Sep 17 00:00:00 2001 From: RondeauG Date: Tue, 15 Oct 2024 13:44:12 -0400 Subject: [PATCH 3/4] remove obsolete import, testdata from main --- docs/notebooks/hydrological_modelling.ipynb | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/docs/notebooks/hydrological_modelling.ipynb b/docs/notebooks/hydrological_modelling.ipynb index 4a039bde..bad4cbd7 100644 --- a/docs/notebooks/hydrological_modelling.ipynb +++ b/docs/notebooks/hydrological_modelling.ipynb @@ -31,8 +31,6 @@ "metadata": {}, "outputs": [], "source": [ - "import planetary_computer\n", - "\n", "import xhydro as xh\n", "import xhydro.modelling as xhm\n", "\n", @@ -54,7 +52,7 @@ }, { "cell_type": "code", - "execution_count": 3, + "execution_count": null, "id": "3", "metadata": { "editable": true, @@ -114,7 +112,7 @@ "\n", "# This notebook will use ERA5 data for a small watershed in Eastern Quebec, along with faked elevation data.\n", "GITHUB_URL = \"https://github.com/hydrologie/xhydro-testdata\"\n", - "BRANCH_OR_COMMIT_HASH = \"for_nb\"\n", + "BRANCH_OR_COMMIT_HASH = \"main\"\n", "\n", "# Streamflow file (1 file - Hydrotel driven by BCC-CSM-1.1(m))\n", "meteo_file = pooch.retrieve(\n", @@ -137,7 +135,7 @@ }, { "cell_type": "code", - "execution_count": 9, + "execution_count": null, "id": "7", "metadata": {}, "outputs": [], From a665f38514160a4e2d64e15727827c1e459f281b Mon Sep 17 00:00:00 2001 From: Hydrologie Helper Bot Date: Tue, 15 Oct 2024 19:38:28 +0000 Subject: [PATCH 4/4] =?UTF-8?q?Bump=20version:=200.4.1-dev.0=20=E2=86=92?= =?UTF-8?q?=200.4.1-dev.1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .cruft.json | 2 +- pyproject.toml | 2 +- src/xhydro/__init__.py | 2 +- tests/test_xhydro.py | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.cruft.json b/.cruft.json index f5959b11..c46de170 100644 --- a/.cruft.json +++ b/.cruft.json @@ -11,7 +11,7 @@ "project_slug": "xhydro", "project_short_description": "Hydrological analysis library built with xarray.", "pypi_username": "TC-FF", - "version": "0.4.1-dev.0", + "version": "0.4.1-dev.1", "use_pytest": "y", "use_black": "y", "use_conda": "y", diff --git a/pyproject.toml b/pyproject.toml index 8f7512ba..1e6b43aa 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -123,7 +123,7 @@ target-version = [ ] [tool.bumpversion] -current_version = "0.4.1-dev.0" +current_version = "0.4.1-dev.1" commit = true commit_args = "--no-verify" tag = false diff --git a/src/xhydro/__init__.py b/src/xhydro/__init__.py index 6afa8c9f..5e4957f0 100644 --- a/src/xhydro/__init__.py +++ b/src/xhydro/__init__.py @@ -25,4 +25,4 @@ __author__ = """Thomas-Charles Fortier Filion""" __email__ = "tcff_hydro@outlook.com" -__version__ = "0.4.1-dev.0" +__version__ = "0.4.1-dev.1" diff --git a/tests/test_xhydro.py b/tests/test_xhydro.py index 26dff640..294bbbb4 100644 --- a/tests/test_xhydro.py +++ b/tests/test_xhydro.py @@ -35,4 +35,4 @@ def test_package_metadata(): contents = f.read() assert """Thomas-Charles Fortier Filion""" in contents assert '__email__ = "tcff_hydro@outlook.com"' in contents - assert '__version__ = "0.4.1-dev.0"' in contents + assert '__version__ = "0.4.1-dev.1"' in contents